Skip to main content

Pipeline is an asset packaging library for Django.

Project description

Pipeline

Jazzband GitHub Actions Coverage Documentation Status

Pipeline is an asset packaging library for Django, providing both CSS and JavaScript concatenation and compression, built-in JavaScript template support, and optional data-URI image and font embedding.

Django Pipeline Overview

Installation

To install it, simply:

pip install django-pipeline

Quickstart

Pipeline compiles and compress your assets files from STATICFILES_DIRS to your STATIC_ROOT when you run Django’s collectstatic command.

These simple steps add Pipeline to your project to compile multiple .js and .css file into one and compress them.

Add Pipeline to your installed apps:

# settings.py
INSTALLED_APPS = [
    ...
    'pipeline',
]

Use Pipeline specified classes for STATICFILES_FINDERS and STATICFILES_STORAGE:

STATICFILES_STORAGE = 'pipeline.storage.PipelineManifestStorage'

STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
    'pipeline.finders.PipelineFinder',
)

Configure Pipeline:

# The folowing config merges CSS files(main.css, normalize.css)
# and JavaScript files(app.js, script.js) and compress them using
# `yuglify` into `css/styles.css` and `js/main.js`
# NOTE: Pipeline only works when DEBUG is False
PIPELINE = {
    'STYLESHEETS': {
        'css_files': {
            'source_filenames': (
                'css/main.css',
                'css/normalize.css',
            ),
            'output_filename': 'css/styles.css',
            'extra_context': {
                'media': 'screen,projection',
            },
        },
    },
    'JAVASCRIPT': {
        'js_files': {
            'source_filenames': (
                'js/app.js',
                'js/script.js',
            ),
            'output_filename': 'js/main.js',
        }
    }
}

Then, you have to install compilers and compressors binary manually.

For example, you can install them using NPM and address them from node_modules directory in your project path:

PIPELINE.update({
    'YUGLIFY_BINARY': path.join(BASE_DIR, 'node_modules/.bin/yuglify'),
})
# For a list of all supported compilers and compressors see documentation

Load static files in your template:

{% load pipeline %}
{% stylesheet 'css_files' %}
{% javascript 'js_files' %}

Documentation

For documentation, usage, and examples, see: https://django-pipeline.readthedocs.io

Issues

You can report bugs and discuss features on the issues page.

Changelog

See HISTORY.rst.

History

3.1.0

  • Fixed concatenation to update relative sourceMappingURL paths (#808). This was effectively breaking pipeline usage on Django 4+.

  • Fixed the django-pipeline-error box that gets injected into HTML pages to hard-code a text color in addition to a background color. This ensures that the text is readable, even on pages that are rendered with light text colors.

  • Added filtering for the django-pipeline-error box to remove ANSI color codes, which are included by some tools.

3.0.0

  • Use Pypy 3.10

  • Drop support for Python 3.7

  • Drop support for Django 2

  • Add Python 3.12 support

  • Add Django 4.2 support

  • Add Django 5.0 support

2.1.0

  • Update README.rst and add Pipeline overview image.

  • Add TypeScript compiler support.

  • Drop support for manifesto package.

  • Add support for Python 3.11 and Django 4.1

2.0.9

  • Fixed some typos in the docs.

  • Fixed string type of errors reported from compilers and compressors.

  • Updated github actions matrix for host and django support.

  • Updated github actions configuration to use modern versions of third-party actions.

  • Improved the packager to copy files to (S3) storage if it does not exist (#502).

2.0.8

  • Added Django 4.0 compatibility. Thanks to @kevinmarsh (#760)

  • Add tests for Django 4.0, Python 3.9 and Python 3.10. Thank to @kevinmarsh (#739)

  • Introduce CODE_OF_CONDUCT.md for the project. Thank to @hugovk (#758)

  • Add precision in the documentation for PipelineCachedStorage. Thank to @gatsinski (#739)

  • Drop support for slimit compressor (#765) due to package not released an official version for Python 3 and not any new package release from 2013.

  • Edit github actions matrix: django 3.2.9 support python 3.10, remove python 4.0 (doesn’t exist) and exclude pypy-3.8 for django-main.

  • Add .pre-commit-config.yaml. Thanks to @hugovk (#762)

  • Update package.json due to CoffeeScript on NPM has moved to “coffeescript”

  • Update setup.py with Django 4.0 and Python 3.10

2.0.7

  • Added Django 3.2 compatibility (Thanks to @jramnai in #751)

2.0.6

2.0.5

  • Adding Django 3.1 compatibility.

  • CachedStaticFilesStorage is removed from Django. Add a check of the current version to prevent error while importing. Thank to @vmsp

  • Context in django.template.base is removed from Django and not used anymore in django-pipeline.

  • Fixing widgets tests of django-pipeline due to Media.render_js change in Django. More information in Django ticket #31892

2.0.4

  • Adding css-html-js-minify support to compress JS and CSS.

  • Update compressors documentation with css-html-js-minify.

  • Create tests for css-html-js-minify compressor.

  • Optimization by grouping the tests yuglify compressor.

2.0.3

  • Remove futures from pipeline setup.py requirements.

2.0.2

  • Fix Middleware to properly decode HTML. Thank to @gatsinski

  • Keep mimetypes as str. Thank to @benspaulding

  • Based on #642 add ‘NonPackagingPipelineManifestStorage’ and update the documentation: storages.rst. Thank to @kronion

2.0.1

  • Add subclass of ManifestStaticFilesStorage. Thank to @jhpinson

  • Change the documentation to use PipelineManifestStorage in configuration instead of PipelineCachedStorage now deprecated.

  • Change import MutableMapping from collections.abc. Thank to @colons

2.0.0

  • Definitely drop the support of Python 2.

  • Drop support for Python 3.5 (not compatible with PEP 498).

  • Remove ‘decorator.py’ how was used for backward compatibility between python 2 and 3 for metaclass inheritance on PipelineFormMedia.

  • Replace ‘format’ by ‘fstring’ (PEP 498: Literal String Interpolation).

  • Remove of old imports form ‘django.utils.six’ and these fixes (1.7.0).

  • Remove tests of uncovered versions of Python and Django.

  • Replace tests for Pypy by Pypy3.

  • Explicitly specify when files are read / write in binary mode.

  • Set opening files for tests to deal with universal newlines.

  • Upgrade documentation version to 2.0 to follow the project version.

1.7.0

  • Release the last major version of django-pipeline working on Python 2.

  • Thank you for all the modifications made since version 1.6.14, which we cannot quote.

  • Apply an optimization to save time during development. Thank to @blankser

  • Edit setup.py to follow the recommendation of the documentation. Thank to @shaneikennedy

  • Add tests for Django 3.0 and Python 3.8

  • Add alternatives imports for django.utils.six, who has been removed in Django 3.0

1.6.14

  • Fix packaging issues.

1.6.13

  • Fix forward-slashed paths on Windows. Thanks to @etiago

  • Fix CSS URL detector to match quotes correctly. Thanks to @vskh

  • Add a compiler_options dict to compile, to allow passing options to custom compilers. Thanks to @sassanh

  • Verify support for Django 1.11. Thanks to @jwhitlock

1.6.12

  • Supports Django 1.11

  • Fix a bug with os.rename on windows. Thanks to @wismill

  • Fix to view compile error if happens. Thanks to @brawaga

  • Add support for Pipeline CSS/JS packages in forms and widgets. Thanks to @chipx86

1.6.11

  • Fix performance regression. Thanks to Christian Hammond.

1.6.10

  • Added Django 1.10 compatiblity issues. Thanks to Austin Pua and Silvan Spross.

  • Documentation improvements. Thanks to Chris Streeter.

1.6.9

  • Various build improvements.

  • Improved setup.py classifiers. Thanks to Sobolev Nikita.

  • Documentation improvements. Thanks to Adam Chainz.

1.6.8

  • Made templatetags easier to subclass for special rendering behavior. Thanks to Christian Hammond.

  • Updated the link to readthedocs. Thanks to Corey Farwell.

  • Fixed some log messages to correctly refer to the new PIPELINE settings tructure. Thanks to Alvin Mites.

  • Changed file outdated checks to use os.path methods directly, avoiding potential SuspiciousFileOperation errors which could appear with some django storage configurations.

1.6.7

  • Add a view for collecting static files before serving them. This behaves like django’s built-in static view and allows running the collector for images, fonts, and other static files that do not need to be compiled. Thanks to Christian Hammond.

  • Update documentation for the ES6Compiler to clarify filename requirements. Thanks to Nathan Cox.

  • Add error output for compiler errors within the browser. This provides for a much better experience when compiling files from the devserver. Thanks to Christian Hammond.

  • Make unit tests run against Django 1.6 and 1.7. Thanks to Sławek Ehlert.

1.6.6

  • Fix filtering-out of files which require a finder to locate.

  • Allow compilers to override the output path.

  • Fix error reporting when a compiler fails to execute.

  • Fix IOErrors when running collectstatic with some nodejs-based compilers and compressors. Thanks to Frankie Dintino.

  • Fix compatibility of unit tests when running on Windows. Thanks to Frankie Dintino.

  • Add unit tests for compilers and compressors. Thanks to Frankie Dintino.

1.6.5

  • Fix Django < 1.8 compatibility. Thanks to David Trowbridge.

  • Allow to disable collector during development. Thanks to Leonardo Orozco.

1.6.4

  • Fix compressor subprocess calls.

1.6.3

  • Fix compressor command flattening.

1.6.2

  • Remove subprocess32 usage since it breaks universal support.

1.6.1

  • Fix path quoting issues. Thanks to Chad Miller.

  • Use subprocess32 package when possible.

  • Documentation fixes. Thanks to Sławek Ehlert and Jannis Leidel.

1.6.0

  • Add full support for Django 1.9.

  • Drop support for Django 1.7.

  • Drop support for Python 2.6.

  • BACKWARD INCOMPATIBLE : Change configuration settings.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

django_pipeline-3.1.0.tar.gz (71.5 kB view details)

Uploaded Source

Built Distribution

django_pipeline-3.1.0-py3-none-any.whl (40.5 kB view details)

Uploaded Python 3

File details

Details for the file django_pipeline-3.1.0.tar.gz.

File metadata

  • Download URL: django_pipeline-3.1.0.tar.gz
  • Upload date:
  • Size: 71.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for django_pipeline-3.1.0.tar.gz
Algorithm Hash digest
SHA256 36470aeced4889694b899a995bcd2eda512f45b61ac68d50adc5863c8bad5ee4
MD5 21996b9710c2ddf1c847dd661d21b681
BLAKE2b-256 2c2224a8fdfb07ebd60ed9af004cfbef4df0ee5af9fb9c06ad1d3e6e1e5b33ac

See more details on using hashes here.

File details

Details for the file django_pipeline-3.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_pipeline-3.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aa973adeb480762f9d795818140da32e0348b7cd85a90b316205b8e966f986b7
MD5 25431897ca3b92d0f86cc4fc018c1e7f
BLAKE2b-256 2e39e643d2f1836dcf3be399f4ec221101de2d07ba421afad682fdccc4341c8e

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