Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mypebble/rest-framework-latex

A LaTeX renderer for Django REST Framework
https://github.com/mypebble/rest-framework-latex

django django-rest-framework latex latex-renderer pdf rest rest-framework tex

Last synced: about 1 month ago
JSON representation

A LaTeX renderer for Django REST Framework

Awesome Lists containing this project

README

        

# REST Framework LaTeX Plugin

[![CircleCI](https://circleci.com/gh/mypebble/rest-framework-latex.svg?style=svg)](https://circleci.com/gh/mypebble/rest-framework-latex)
[![PyPI version](https://badge.fury.io/py/rest-framework-latex.svg)](https://badge.fury.io/py/rest-framework-latex)
[![Documentation Status](https://readthedocs.org/projects/drf-latex/badge/?version=latest)](http://drf-latex.readthedocs.io/en/latest/?badge=latest)

A simple plug-n-play LaTeX renderer for Django REST Framework.

[Documentation](http://drf-latex.readthedocs.io/en/latest/)

## Installing

REST Framework LaTeX can be downloaded from PyPI:

```bash
pip install rest-framework-latex
```

## Dependencies

Currently the LaTeX plugin requires `lualatex` - to install this on Ubuntu:

```bash
sudo aptitude install texlive-latex-extra texlive-xetex
```

This will probably take some time due to the size of LaTeX (around 1GB)

## Using the Renderer

You can then configure the renderer in your settings or on each view:

```python
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': [
'rest_framework_latex.renderers.LatexRenderer',
]
}
```

### `LATEX_RESOURCES` Setting

The `LATEX_RESOURCES` directory contains the base template environment e.g.
any images or static resources to include in your template. This must be set for
the renderer to work:

```python
LATEX_RESOURCES = '/home/user/path_to_resources'
```

This works just like `TemplateHTMLRenderer` but by setting a `latex_name` on
your view:

```python
from rest_framework import viewsets

from rest_framework_latex import renderers

class SomeViewSet(viewsets.ViewSet):
"""
"""
renderer_classes = [
renderers.LatexRenderer,
]

latex_name = 'directory/latexfile.tex'
```

### Latex Templates

To use the template tags, add `rest_framework_latex` to your `INSTALLED_APPS`:

```python
INSTALLED_APPS = [
...
'rest_framework_latex',
...
]
```

The TeX file used for rendering will be pushed through Django's templating
system. This will cause some issues whereby you want to do something like:

```latex
\textt{{{ some_variable }}}
```

To get around this issue you will need to do something like the following:

```latex
\textt{% templatetag openbrace %}{{ some_variable }}{% templatetag closebrace %}
```

#### Included Tags

| Tag | Tag/Filter | Purpose |
| ----------------- | ---------- | ----------------------------------------------- |
| `latex_safe` | Filter | Escape all user-entered content for LaTeX rules |
| `latex_resources` | Tag | Print the value of `settings.LATEX_RESOURCES` |

## How it works

The renderer works by creating a new temporary directory, and then copying
over the `LATEX_RESOURCES` directory into the new temporary directory.

Next it renders the TeX file into the temporary directory.

Then it runs lualatex over the TeX file, and this will produce the PDF file
we read into memory.

Then we delete the temporary directory and return the PDF to the client.

## Django Compatibility

The REST Framework LaTeX plugin is compatible with Django 1.11 and up and
Django REST Framework 3.3 and up.