This is a pre-production deployment of Warehouse, however changes made here WILL affect the production instance of PyPI.
Latest Version Dependencies status unknown Test status unknown Test coverage unknown
Project Description

Quick Start

0. Install::

pip install aio_pybars

OR via

python install

1. Configure your app::

from aio_pybars import FSTemplateLoader

2. Use templates in the view::

async def index(request):
context = {"var": "value"}
return AIOBarsResponse(request, 'template_name', context)

It will render the `template_name.hbs` template with variables in the `context` to the aiohttp response.

Helpers and partials

Partial is the nested template that should be included in the specific place.
If the following code occurs in the template::

{{> "sidebar"}}

pybars3 will search the _partial_ named `sidebar` in the dictionary. How to add your own partial see below.

Helper is the callable that can be called from the template. Syntactically it looks same as the variable, but can
get the arguments::

<link rel="shortcut icon" href="{{asset " favicon.ico"}}"="">

would call the `asset` callable with "favicon.ico" argument and put the results in the rendered template.

*To use your own partials and helpers* implement your subclass of templates loader::

class AppFSTemplateLoader(FSTemplateLoader):
def __init__(self, app, base_dir):
super().__init__(app, base_dir)

def get_partials(self):
Load all files in the partials/ subdirectory of templates dir.
Method should return the dictionary {'partial_name': <compiled template="">, ...}
partials = super().get_partials()
base_partials = os.path.join(['TEMPLATES_DIR'], 'partials')
for name in os.listdir(base_partials):
filename = os.path.splitext(name)[0]
template_source = open(os.path.join(base_partials, name), 'r', encoding='utf8').read()
template = self.compiler.compile(template_source)
partials[filename] = template
return partials

def get_helpers(self):
Define your own set of helpers.
Method should return the dictionary {'helper_name': <callable>, ...}
helpers = super().get_helpers()
helpers.update({"asset": _asset})
return helpers

def _asset(options, val, *args, **kwargs):
return "/static/{}".format(val)

and pass it as Loader argument to the setup::


Recursive rendering of templates

The aio_pybars enables templates to be recursive. If the first line of the template contains::

{{!< base_template}}

all the rendered template will be passed as variable `body` to the base template.

For example:




{{!< base}}
Hello, {{name}}.

Then result of the `render(loader, 'test', {'name': 'Roma'})` will be::

Hello, Roma
Release History

Release History


This version

History Node

TODO: Figure out how to actually get changelog content.

Changelog content for this version goes here.

Donec et mollis dolor. Praesent et diam eget libero egestas mattis sit amet vitae augue. Nam tincidunt congue enim, ut porta lorem lacinia consectetur. Donec ut libero sed arcu vehicula ultricies a non tortor. Lorem ipsum dolor sit amet, consectetur adipiscing elit.

Show More

Download Files

Download Files

TODO: Brief introduction on what you do with files - including link to relevant help section.

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
aio_pybars-0.1.0.tar.gz (3.6 kB) Copy SHA256 Checksum SHA256 Source Apr 19, 2016

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS HPE HPE Development Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting