Skip to main content

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

Project description

Build Status https://coveralls.io/repos/zyegfryed/django-statici18n/badge.png?branch=master

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

Overview

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

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

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

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

    python manage.py compilejsi18n
  4. Add the django.core.context_processors.i18n context processor to your TEMPLATE_CONTEXT_PROCESSORS setting - should have already been set by Django:

    TEMPLATE_CONTEXT_PROCESSORS = (
      # ...
      'django.core.context_processors.i18n',
    )
  5. Edit your template(s) and replace the dynamically generated script by the statically generated one:

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

(Optionnal)

The following step assumes you’re using django.contrib.staticfiles.

  1. Edit your template(s) and use the provided template tag:

{% 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-1.0.1.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_statici18n-1.0.1-py2.py3-none-any.whl (11.4 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

File hashes

Hashes for django-statici18n-1.0.1.tar.gz
Algorithm Hash digest
SHA256 d84467c11a0a9fd2736283af2c55960d65448071c696dc0d7029d02aa25353b2
MD5 b8ef76c809b048f565507091683b8531
BLAKE2b-256 d5c21e93bfa39497866375806b371022aafc9106ce4a12091b5d5cb1d8aec5bd

See more details on using hashes here.

File details

Details for the file django_statici18n-1.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_statici18n-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b83fb0ea7e95769f223eff31e2ad39dfab21fa79e1d0cb9b50e366c6cb5f0f75
MD5 f64046572ade04960df0a8fe1402b0b6
BLAKE2b-256 0139d847dd252d0c669c43cdc56c1fda2c9420ba5d663e35662ae726a7abbe68

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