Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/knowsuchagency/ninjadog
Pug/Jinja template support for Python.
https://github.com/knowsuchagency/ninjadog
html jinja2 pug python
Last synced: 3 months ago
JSON representation
Pug/Jinja template support for Python.
- Host: GitHub
- URL: https://github.com/knowsuchagency/ninjadog
- Owner: knowsuchagency
- License: mit
- Created: 2017-06-22T07:19:51.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-05-06T04:32:08.000Z (8 months ago)
- Last Synced: 2024-10-15T14:32:21.105Z (3 months ago)
- Topics: html, jinja2, pug, python
- Language: Python
- Homepage: http://journalpanic.com/ninjadog
- Size: 1.99 MB
- Stars: 24
- Watchers: 3
- Forks: 2
- Open Issues: 18
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
========
ninjadog
========.. image:: https://img.shields.io/pypi/v/ninjadog.svg
:target: https://pypi.org/project/ninjadog/.. image:: https://img.shields.io/travis/knowsuchagency/ninjadog.svg
:target: https://travis-ci.org/knowsuchagency/ninjadog.. image:: https://pyup.io/repos/github/knowsuchagency/ninjadog/shield.svg
:target: https://pyup.io/repos/github/knowsuchagency/ninjadog/
:alt: Updates.. image:: https://img.shields.io/github/license/mashape/apistatus.svg
`Pug`_ template (formerly `jade`_) support in Python
* Documentation: http://journalpanic.com/ninjadog
* GitHub: https://github.com/knowsuchagency/ninjadogInstallation
------------ninjadog requires Python 3, node-js, npm, and the `pug-cli`_ library
::
brew install npm
npm install -g pug-cli
pip install ninjadogFor use with `Pyramid`_, just add it to the configuration
.. code-block:: python
config.include('ninjadog')
Usage
-----ninjadog leverages the `pug-cli`_ library, written in nodejs, to render
`pug`_ templates in Python.It allows you to take something like this
.. code-block:: pug
html
head
title my pug template
body
#content
h1 Hello #{name}
.block
input#bar.foo1.foo2
input(type="text", placeholder="your name")
if name == "Bob"
h2 Hello Bob
ul
for book in books
li= book
else
li sorry, no booksand sprinkle some Python over it
.. code-block:: python
from ninjadog import render
context = {
'name': 'Bob',
'books': ['coloring book', 'audio book', "O'Reilly book"],
'type': 'text',
}print(render(file=filepath, context=context, pretty=True))
to render this
.. code-block:: html
my pug template
Hello Bob
Hello Bob
- coloring book
- audio book
- O'Reilly book
You can even combine `jinja2`_ syntax for unparalleled
template-rendering power... code-block:: python
from ninjadog import render
def stop_believing():
return Falsecontext = {
'stop_believing': stop_believing,
'happy': {
'birthday': 'today',
}
}template_string = """
h1 hello, world
if happy.birthday == 'today'
p it's time to celebrate!
p {{ "Don't" if not stop_believing() }} stop believing
"""print(render(template_string,
context=context,
pretty=True,
with_jinja=True)).. code-block:: html
hello, world
it's time to celebrate!
Don't stop believing
Why?
----`Pug`_ templates are a super elegant and expressive way to write
html, IMO.There exists a project, `pyjade`_ and a less-popular fork, `pypugjs`_,
that are pure-python implementations of the pug template engine,
but they have some minor bugs and the maintenance is a bit lacking.I figured it would be good to have an alternative method to render
`pug`_ templates that used the native javascript rendering engine.ninjadog does this by spawning the `pug cli`_ as a subprocess.
This means that it can't be as fast as a native template engine
like `pyjade`_, but it will likely be more reliable over time as
it's leveraging the popular and well-maintained nodejs implementation.Gotchas
-------Currently, rendering a template with `jinja2`_ syntax goes through the following process:
1. Render elements on the initial template through `jinja2`_
2. Pass the output to the `pug-cli`_, gathering extensions and inclusions in the process
3. Render the output through `jinja2`_ again, since the original template may have extended or included other templates that countained `jinja2`_ syntax themselves.What this means is that if you want to escape `jinja2`_ syntax, you need to do it twice.
For example, to have a literal ``{{ escaping inception }}`` rendered,
you'll need to have ``{{ "{{ '{{ escaping inception }}' }}" }}`` in your template.对不起
.. _pug: https://pugjs.org/api/getting-started.html
.. _jade: https://naltatis.github.io/jade-syntax-docs/
.. _pyjade: https://github.com/syrusakbary/pyjade
.. _pypugjs: https://github.com/matannoam/pypugjs
.. _pug-cli: https://www.npmjs.com/package/pug-cli
.. _pug cli: https://www.npmjs.com/package/pug-cli
.. _jinja2: http://jinja.pocoo.org/
.. _jinja 2: http://jinja.pocoo.org/
.. _pyramid: https://trypyramid.com/