Skip to main content

Localization support for the Muffin Framework

Project description

Muffin-Babel – an extension to Muffin that adds localization support with help of Babel.

Tests Status PYPI Version Python Versions

Requirements

  • python >= 3.7

Installation

Muffin-Babel should be installed using pip:

pip install muffin-babel

Usage

Initialize and setup the plugin:

import muffin
import muffin_babel

# Create Muffin Application
app = muffin.Application('example')

# Initialize the plugin
# As alternative: babel = muffin_babel.Plugin(app, **options)
babel = muffin_babel.Plugin()
babel.setup(app, template_folders=['src/templates'])

# Use it inside your handlers
@app.route('/')
async def index(request):
    # Get current locale
    assert babel.current_locale
    # Translate a text
    return babel.gettext('Hello World!')

Setup a locale selector function (by default the plugin is parsing accept-language header):

@babel.locale_selector
async def get_locale(request):
    """ Return locale either from request.query or from request headers. """
    locale = request.query.get('lang')
    if not locale:
        return await muffin_babel.select_locale_by_request(request, default)
    return locale

Use babel.gettext, babel.pgettext callables in your code:

@app.route('/')
def index(request):
    return babel.gettext('Hello!')

Jinja2

The Muffin-Babel has integration with Muffin-Jinja2, so if you have muffin_jinja2 plugin enabled, the plugin provides gettext and ngettext function inside the Jinja2 templates’ context.

Options

Name

Default Value

Description

AUTO_DETECT_LOCALE

True

Installs a middleware to automatically detect users locales

CONFIGURE_JINJA2

True

Installs i18n support for jinja2 templates (through muffin-jinja)

DEFAULT_LOCALE

"en"

Default locale

DOMAIN

"messages"

Default localization domain

SOURCES_MAP

Babel sources map

OPTIONS_MAP

Babel options map

You are able to provide the options when you are initiliazing the plugin:

babel.setup(app, default_locale='fr')

Or setup it inside Muffin.Application config using the BABEL_ prefix:

BABEL_DEFAULT_LOCALE = 'fr'

Muffin.Application configuration options are case insensitive

Commands

The plugin adds two commands to your Muffin application.

Extract messages

Extract strings from your application to locales:

$ muffin app_package babel_extract_messages [OPTIONS] appdir

Translate .po files and compile translations:

$ muffin app_package babel_compile_messages [OPTIONS]

Bug tracker

If you have any suggestions, bug reports or annoyances please report them to the issue tracker at https://github.com/klen/muffin-babel/issues

Contributing

Development of Muffin-Babel happens at: https://github.com/klen/muffin-babel

Contributors

  • klen (Kirill Klenov)

License

Licensed under a MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

muffin-babel-1.0.5.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

muffin_babel-1.0.5-py3-none-any.whl (6.6 kB view details)

Uploaded Python 3

File details

Details for the file muffin-babel-1.0.5.tar.gz.

File metadata

  • Download URL: muffin-babel-1.0.5.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for muffin-babel-1.0.5.tar.gz
Algorithm Hash digest
SHA256 eaa279477f9fba59d6d16e050c542cd4d3a6ab51bb9f6daaa50c49f0fa6f8b13
MD5 8d52c1f282d09e2f43566d123123c301
BLAKE2b-256 4d09df0167ed4ef6bbc6b3a8a1a635e1b3bfaf19baeda620b541084793c2d1c9

See more details on using hashes here.

File details

Details for the file muffin_babel-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: muffin_babel-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 6.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for muffin_babel-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 4d94e365ed67013565ce290aabe233c934dc48842c385926500a558909ac120e
MD5 fc4d953fd10c3d0f6155407c814f1b9b
BLAKE2b-256 3101e7761c2c680c7b7d13397ba4dc04704181e029db692d081af1e5164ade6e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page