Metadata-Version: 2.0
Name: django-bower
Version: 5.2.0
Summary: Integrate django with bower
Home-page: https://github.com/nvbn/django-bower
Author: Vladimir Iakovlev
Author-email: nvbn.rm@gmail.com
License: BSD
Platform: UNKNOWN
Classifier: Framework :: Django
Classifier: Programming Language :: JavaScript
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Requires-Dist: django
Requires-Dist: six

Django-bower
============

.. image:: https://travis-ci.org/nvbn/django-bower.png
   :alt: Build Status
   :target: https://travis-ci.org/nvbn/django-bower
.. image:: https://coveralls.io/repos/nvbn/django-bower/badge.png?branch=develop
   :alt: Coverage Status
   :target: https://coveralls.io/r/nvbn/django-bower
.. image:: https://pypip.in/v/django-bower/badge.png
   :target: https://crate.io/packages/django-bower/
.. image:: https://pypip.in/d/django-bower/badge.png
   :target: https://crate.io/packages/django-bower/

Easy way to use `bower <http://bower.io/>`_ with your `Django <https://www.djangoproject.com/>`_ project.

Bower is a package manager for the web. It offers a generic, unopinionated solution to the problem of front-end package management, while exposing the package dependency model via an API that can be consumed by a more opinionated build stack. There are no system wide dependencies, no dependencies are shared between different apps, and the dependency tree is flat.

Read full documentation on `read-the-docs <https://django-bower.readthedocs.io/en/latest/>`_.

Installation
------------

Install django-bower package:

.. code-block:: bash

    pip install django-bower

Add django-bower to `INSTALLED_APPS` in your settings:

.. code-block:: python

    'djangobower',

Add staticfinder to `STATICFILES_FINDERS`:

.. code-block:: python

    'djangobower.finders.BowerFinder',

Specify path to components root (you need to use an absolute path):

.. code-block:: python

    BOWER_COMPONENTS_ROOT = '/PROJECT_ROOT/components/'


If you need, you can manually set the path to bower:

.. code-block:: python

    BOWER_PATH = '/usr/bin/bower'

You can see an example settings file in `example project <https://github.com/nvbn/django-bower/blob/master/example/example/settings.py>`_.

Usage
-----

Specify `BOWER_INSTALLED_APPS` in settings, like:

.. code-block:: python

    BOWER_INSTALLED_APPS = (
        'jquery#1.9',
        'underscore',
    )

Download bower packages with the management command:

.. code-block:: bash

    ./manage.py bower install

Add scripts in the template, like:

.. code-block:: html+django

    {% load static %}
    <script type="text/javascript" src='{% static 'jquery/dist/jquery.js' %}'></script>

In production you need to call `bower install` before `collectstatic`:

.. code-block:: bash

    ./manage.py bower install
    ./manage.py collectstatic

If you need to pass arguments to bower, like `--allow-root`, use:

.. code-block:: bash

    ./manage.py bower install -- --allow-root

You can use `bower freeze` to receive `BOWER_INSTALLED_APPS` with fixed current versions:

.. code-block:: bash

    ./manage.py bower freeze

You can call bower commands like `info` and `update` with:

.. code-block:: bash

    ./manage.py bower info backbone
    ./manage.py bower update

Python 3 support
----------------
django-bower supports python 3.3+


