Metadata-Version: 2.1
Name: django-template-processors
Version: 0.1.2
Summary: Configurable template pre- and post-processing for Django.
Author-email: Fabian Binz <fabian.binz@gmail.com>
Description-Content-Type: text/markdown
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Framework :: Django :: 3.2
Classifier: Framework :: Django :: 4.0
Classifier: Framework :: Django :: 4.1
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Topic :: Utilities
Requires-Dist: django >=3.2,<6
Requires-Dist: typer~=0.9 ; extra == "dev"
Requires-Dist: freezegun~=1.3 ; extra == "dev"
Requires-Dist: pytest-django~=4.7 ; extra == "dev"
Requires-Dist: pytest-mock~=3.12 ; extra == "dev"
Requires-Dist: coverage~=7.3 ; extra == "dev"
Requires-Dist: pre-commit~=3.5 ; extra == "dev"
Requires-Dist: ruff~=0.1.7 ; extra == "dev"
Requires-Dist: sphinx~=7.1 ; extra == "dev"
Requires-Dist: sphinx-rtd-theme~=2.0 ; extra == "dev"
Requires-Dist: m2r2==0.3.3.post2 ; extra == "dev"
Requires-Dist: mistune<2.0.0 ; extra == "dev"
Requires-Dist: flit~=3.9 ; extra == "dev"
Requires-Dist: ambient-package-update~=24.6.4 ; extra == "dev"
Project-URL: Bugtracker, https://github.com/ambient-innovation/django-template-processors/issues
Project-URL: Changelog, https://django-template-processors.readthedocs.io/en/latest/features/changelog.html
Project-URL: Documentation, https://django-template-processors.readthedocs.io/en/latest/index.html
Project-URL: Homepage, https://github.com/ambient-innovation/django-template-processors/
Project-URL: Maintained by, https://ich.binz.dev
Provides-Extra: dev

[![PyPI release](https://img.shields.io/pypi/v/django-template-processors.svg)](https://pypi.org/project/django-template-processors/)
[![Downloads](https://static.pepy.tech/badge/django-template-processors)](https://pepy.tech/project/django-template-processors)
[![Coverage](https://img.shields.io/badge/Coverage-100.0%25-success)](https://github.com/ambient-innovation/django-template-processors/actions?workflow=CI)
[![Linting](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)
[![Coding Style](https://img.shields.io/badge/code%20style-Ruff-000000.svg)](https://github.com/astral-sh/ruff)
[![Documentation Status](https://readthedocs.org/projects/django-template-processors/badge/?version=latest)](https://django-template-processors.readthedocs.io/en/latest/?badge=latest)

Template processor for Django

* [PyPI](https://pypi.org/project/django-template-processors/)
* [GitHub](https://github.com/ambient-innovation/django-template-processors)
* [Full documentation](https://django-template-processors.readthedocs.io/en/latest/index.html)
* Creator & Maintainer: [Fabian Binz](https://ich.binz.dev)


Adds pre- and post-processing hooks to your Django project.
While this package does not provide any functionality itself, it is
configurable to add your own pre- and post-processing hooks.

## Installation

- Install the package via pip:

  `pip install django-template-processors`

  or via pipenv:

  `pipenv install django-template-processors`

- Add module to `INSTALLED_APPS` within the main django `settings.py`:

    ```python
    INSTALLED_APPS = (
        ...
        'template_processors',
    )
     ```

- Extend the `TEMPLATE_PRE_PROCESSORS` and `TEMPLATE_POST_PROCESSORS` settings with your own processors:

    ```python
    TEMPLATE_PRE_PROCESSORS = [
        'my_app.processors.my_pre_processor',
    ]

    TEMPLATE_POST_PROCESSORS = [
        'my_app.processors.my_post_processor',
    ]
     ```

- Adjust the template loaders to use the new template processors. As an example, the
  following configuration assumse that you had the built-in `filesystem` and `app_directories`
  loaders configured. You need to wrap each loader with the `template_processors.loader.Loader`
  class:

    ```python
    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            ...,
            'OPTIONS': {
                ...,
                'loaders': [
                    (
                        'template_processors.loader.Loader',
                        'django.template.loaders.filesystem.Loader',
                    ),
                    (
                        'template_processors.loader.Loader',
                        'django.template.loaders.app_directories.Loader',
                    ),
                ],
            },
        },
    ]
     ```


## Usage

Configure pre- and post-processing hooks in your `settings.py`:

```python
TEMPLATE_PRE_PROCESSORS = [
    'my_app.processors.my_pre_processor',
]

TEMPLATE_POST_PROCESSORS = [
    'my_app.processors.my_post_processor',
]
```

Pre-processors are called before the template is rendered with the string contents of the template.
Post-processors are called after the template is rendered with the full `TemplateResponse` object.

Note that the post-processing only works, if the view returns a `TemplateResponse` object, i.e.
not if the view returns using djangos `render` function.

## Contribute

### Setup package for development

- Create a Python virtualenv and activate it
- Install "pip-tools" with `pip install -U pip-tools`
- Compile the requirements with `pip-compile --extra dev, -o requirements.txt pyproject.toml --resolver=backtracking`
- Sync the dependencies with your virtualenv with `pip-sync`

### Add functionality

- Create a new branch for your feature
- Change the dependency in your requirements.txt to a local (editable) one that points to your local file system:
  `-e /Users/workspace/django-template-processors` or via pip  `pip install -e /Users/workspace/django-template-processors`
- Ensure the code passes the tests
- Create a pull request

### Run tests

- Run tests
  ````
  pytest --ds settings tests
  ````

- Check coverage
  ````
  coverage run -m pytest --ds settings tests
  coverage report -m
  ````

### Git hooks (via pre-commit)

We use pre-push hooks to ensure that only linted code reaches our remote repository and pipelines aren't triggered in
vain.

To enable the configured pre-push hooks, you need to [install](https://pre-commit.com/) pre-commit and run once:

    pre-commit install -t pre-push -t pre-commit --install-hooks

This will permanently install the git hooks for both, frontend and backend, in your local
[`.git/hooks`](./.git/hooks) folder.
The hooks are configured in the [`.pre-commit-config.yaml`](templates/.pre-commit-config.yaml.tpl).

You can check whether hooks work as intended using the [run](https://pre-commit.com/#pre-commit-run) command:

    pre-commit run [hook-id] [options]

Example: run single hook

    pre-commit run ruff --all-files --hook-stage push

Example: run all hooks of pre-push stage

    pre-commit run --all-files --hook-stage push

### Update documentation

- To build the documentation run: `sphinx-build docs/ docs/_build/html/`.
- Open `docs/_build/html/index.html` to see the documentation.


### Translation files

If you have added custom text, make sure to wrap it in `_()` where `_` is
gettext_lazy (`from django.utils.translation import gettext_lazy as _`).

How to create translation file:

* Navigate to `django-template-processors`
* `python manage.py makemessages -l de`
* Have a look at the new/changed files within `django-template-processors/locale`

How to compile translation files:

* Navigate to `django-template-processors`
* `python manage.py compilemessages`
* Have a look at the new/changed files within `django-template-processors/locale`


### Publish to ReadTheDocs.io

- Fetch the latest changes in GitHub mirror and push them
- Trigger new build at ReadTheDocs.io (follow instructions in admin panel at RTD) if the GitHub webhook is not yet set
  up.

### Publish to PyPi

- Update documentation about new/changed functionality

- Update the `Changelog`

- Increment version in main `__init__.py`

- Create pull request / merge to master

- This project uses the flit package to publish to PyPI. Thus publishing should be as easy as running:
  ```
  flit publish
  ```

  To publish to TestPyPI use the following ensure that you have set up your .pypirc as
  shown [here](https://flit.readthedocs.io/en/latest/upload.html#using-pypirc) and use the following command:

  ```
  flit publish --repository testpypi
  ```

### Maintenance

Please note that this package supports the [ambient-package-update](https://pypi.org/project/ambient-package-update/).
So you don't have to worry about the maintenance of this package. All important configuration and setup files are
being rendered by this updater. It works similar to well-known updaters like `pyupgrade` or `django-upgrade`.

To run an update, refer to the [documentation page](https://pypi.org/project/ambient-package-update/)
of the "ambient-package-update".


