Skip to main content

A simple Django app for inlining static files in templates

Project description

django-simpleinliner

A simple Django app for inlining static CSS and JS files in templates. Read CSS, JS or generic files from your static directories and insert their contents into your Django templates, wrapping in appropriate HTML tags if necessary.

Rationale

Provides a quick and easy way to inline an entire JS or CSS file from staticfiles into a template, wrapping it in appropriate tags. django-compressor does this but I wanted something more lightweight, and also wanted to try my hand at writing a Django extension. Some inspiration and staticfile-handling code was taken from django-inlinecss.

Compatibility

The widget has been tested on all Python/Django version combinations officially supported by the Django project:

Django 4.2 5.0 5.1 5.2
Python 3.8
3.9
3.10
3.11
3.12
3.13
3.14

If you need to use django-simpleinliner with Django 3, please use a version of the package prior to 1.0.0.

Installation

$ pip install django-simpleinliner

Add simpleinliner to your INSTALLED_APPS setting.

Usage

Load the app at the top of your template:

{% load simpleinliner %}

Call inlinecss, inlinejs or inlinegeneric where you want to pull in a static file:

{% inlinejs 'path/to/my.js' %}

{% inlinecss 'path/to/my.css' %}

{% inlinegeneric 'path/to/my.svg' %}

The file will be inserted into the template each time the template is rendered, keeping it up to date. Note that when using inlinegeneric no wrapper tag will be rendered – this is designed for files such as SVGs that already include all necessary markup.

You can override the default attributes given to <script> and <style> tags generated by simpleinliner by including the following in your project settings:

SIMPLEINLINER_DEFAULT_TAG_ATTRIBUTES = {
    'script': {
        'type': 'text/javascript',
    },
    'style': {
        'type': 'text/css',
    },
}

Add or edit these as desired to change the attributes applied to these tags.

By default simpleinliner will silently fail (including an empty tag if using inlinejs or inlinecss) if the specified path doesn't exist. You can force it to raise an exception by setting SIMPLEINLINER_RAISE_EXCEPTIONS to True in your project settings.

Development

If working locally on the package you can install the development tools via pip:

$ pip install -e .[dev]

Run the runserver to load the test template:

$ cd example_project
$ python manage.py runserver 0.0.0.0:8000

Run the basic test suite across environments using tox:

$ tox run

Credits

Since version 0.2.5 this library bundles a lightly modified version 1.16 of the html library (in html.py), as that library does not correctly install itself in modern python/setuptools environments and cannot be correctly imported.

Issues, Suggestions, Contributions

...are welcome on GitHub. Thanks for your interest in simpleinliner!

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_simpleinliner-1.0.0.tar.gz (14.9 kB view details)

Uploaded Source

File details

Details for the file django_simpleinliner-1.0.0.tar.gz.

File metadata

  • Download URL: django_simpleinliner-1.0.0.tar.gz
  • Upload date:
  • Size: 14.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for django_simpleinliner-1.0.0.tar.gz
Algorithm Hash digest
SHA256 b22b0501b36692054ccb1f39308928393b98ae394036fdb4027a655e14ff9588
MD5 fb8400db6575fd05d740a0725521ab92
BLAKE2b-256 86a3c073eac1b6feae7794929ecffea8b78ce42888088b0499ec0fb3de02d68b

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