Metadata-Version: 2.0
Name: django-overextends
Version: 0.4.2
Summary: A Django reusable app providing the ability to use circular template inheritance.
Home-page: http://github.com/stephenmcd/django-overextends
Author: Stephen McDonald
Author-email: stephen.mc@gmail.com
License: UNKNOWN
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Web Environment
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Framework :: Django
Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content
Classifier: Topic :: Internet :: WWW/HTTP :: Site Management
Requires-Dist: sphinx-me (>=0.1.2)
Requires-Dist: django (>=1.8,<1.11)

.. image:: https://secure.travis-ci.org/stephenmcd/django-overextends.png?branch=master
   :target: http://travis-ci.org/stephenmcd/django-overextends

Created by `Stephen McDonald <http://twitter.com/stephen_mcd>`_

Introduction
============

A Django reusable app providing the ``overextends`` template tag, a
drop-in replacement for Django's ``extends`` tag, which allows you to
use circular template inheritance.

The primary use-case for ``overextends`` is to simultaneously override
and extend templates from other reusable apps, in your own Django project.

Example
=======

Consider the following settings module and templates, with the apps
``app1`` and ``app2`` bundled in the project, for example's sake::

    # settings.py
    INSTALLED_APPS = (
        "app1",
        "app2",
        "overextends",
    )
    TEMPLATE_LOADERS = (
        "django.template.loaders.filesystem.Loader",
        "django.template.loaders.app_directories.Loader",
    )
    PROJECT_ROOT = os.path.dirname(os.path.abspath(__file__))
    TEMPLATE_DIRS = (os.path.join(PROJECT_ROOT, "templates"),)

    <!-- myproject/app1/templates/pages/page.html -->
    <h1>Title</h1>
    {% block main %}
    <p>A paragraph in app1</p>
    {% enblock %}
    <footer>Copyright 2012</footer>

    <!-- myproject/app2/templates/pages/page.html -->
    {% overextends "pages/page.html" %}
    {% block main %}
    <p>A paragraph in app2, that wants to be on top of app1's main block</p>
    {{ block.super }}
    {% enblock %}

    <!-- myproject/templates/pages/page.html -->
    {% overextends "pages/page.html" %}
    {% block main %}
    {{ block.super }}
    <p>A paragraph in the project's template directory, under the other main blocks</p>
    {% enblock %}

The resulting HTML rendered when ``pages/page.html`` was loaded would be::

    <h1>Title</h1>
    <p>A paragraph in app2, that wants to be on top of app1's main block</p>
    <p>A paragraph in app1</p>
    <p>A paragraph in the project's template directory, under the other main blocks</p>
    <footer>Copyright 2012</footer>

For a detailed analysis of why you would use this approach, how it works,
and alternative approaches, read my initial blog post:
`Circular Template Inheritance for Django`_

Installation
============

The easiest way to install django-overextends is directly from PyPi
using `pip`_ by running the following command::

    $ pip install -U django-overextends

Otherwise you can download django-overextends and install it directly
from source::

    $ python setup.py install

Project Configuration
=====================

Once installed you can configure your project to use
django-overextends by adding the ``overextends`` app to the
``INSTALLED_APPS`` in your project's ``settings`` module::

    INSTALLED_APPS = (
        # ... other apps here ...
        'overextends',
    )

For Django 1.9+ you must add overextends to the `builtins` key of your `TEMPLATES` setting::

    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'APP_DIRS': True,
            'OPTIONS': {
                'builtins': ['overextends.templatetags.overextends_tags'],
            }
        },
    ]


Note that while the ``overextends`` tag is provided by the package
``overextends.templatetags.overextends_tags``, it is unnecessary to use
``{% load overextends_tags %}`` in your templates. Like the ``extends``
tag, ``overextends`` must be the first tag in your template, so it is
automatically added to Django's built-in template tags, removing the
need to load its tag library in each template.

.. _`Circular Template Inheritance for Django`: http://blog.jupo.org/2012/05/17/circular-template-inheritance-for-django/
.. _`pip`: http://www.pip-installer.org/


