Skip to main content

A Django app that provides helper for generating Javascript catalog to static files.

Project description

A Django app that provides helper for generating JavaScript catalog to static files.

When dealing with internationalization in JavaScript code, Django provides the javascript_catalog view which sends out a JavaScript code library with functions that mimic the gettext interface, plus an array of translation strings.

At first glance, it works well and everything is fine. But, because javascript_catalog view is generating JavaScript catalog dynamically on each request, it’s adding an overhead that can be an issue with site growth.

That’s what django-statici18n is for:

Collecting JavaScript catalogs from each of your Django apps (and any other place you specify) into a single location that can easily be served in production.

The main website for django-statici18n is github.com/zyegfryed/django-statici18n where you can also file tickets.

Installation

  • Use your favorite Python packaging tool to install django-statici18n from PyPI, e.g.:

    pip install django-statici18n
  • Add 'statici18n' to your INSTALLED_APPS setting:

    INSTALLED_APPS = [
        # ...
        'statici18n',
    ]
  • Once you have translated and compiled your messages, use the compilejsi18n management command:

    python manage.py compilejsi18n

By default, the generated catalogs are stored to static/jsi18n. You can modify it with the django-statici18n settings.

(Optionnal)

The following steps assumes you’re using either django.contrib.staticfiles or django-staticfiles.

  • Add the django.core.context_processors.i18n context processor to your TEMPLATE_CONTEXT_PROCESSORS setting - already set by Django by default:

    TEMPLATE_CONTEXT_PROCESSORS = (
      # ...
      'django.core.context_processors.i18n',
    )
  • Edit your templates and replace either the dynamically generated script by the statically generated one like this:

    <script src="{{ STATIC_URL }}jsi18n/{{ LANGUAGE_CODE }}/djangojs.js"></script>

    or use the provided template tag like this:

    {% load statici18n %}
    <script src="{% statici18n LANGUAGE_CODE %}"></script>

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

django-statici18n-0.4.5.tar.gz (17.4 kB view details)

Uploaded Source

File details

Details for the file django-statici18n-0.4.5.tar.gz.

File metadata

File hashes

Hashes for django-statici18n-0.4.5.tar.gz
Algorithm Hash digest
SHA256 04bbfed6428e5534307d19cfe5b7164655ad1e86cfe3b9a577af77042a69b0e0
MD5 a72a8598123318251063a27998617d3c
BLAKE2b-256 5b215933ed00bc1c6e463d20cc6e00c6d9ca02ac08fd6ed779145febea338190

See more details on using hashes here.

Supported by

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