GitXplorerGitXplorer
f

player

public
3 stars
1 forks
1 issues

Commits

List of commits on branch master.
Unverified
afcc494d9ca965332d309e973d3e0fda9b7b8819

enable py3.3 travis-ci

ffafhrd91 committed 12 years ago
Unverified
f49f5ab921ef0a3bcc027cf31e0f061565ce05f7

prepare for rellease

ffafhrd91 committed 12 years ago
Unverified
7fc39d2ef7cd0b7a82db27a1674b69f7d28ac89a

allow to use standard renderers in render function

ffafhrd91 committed 12 years ago
Unverified
0f41c0eec1ecf523ce32738d3f100a127b4c0dd0

replace chameleon with jinja2

ffafhrd91 committed 12 years ago
Unverified
f5b3b34899a60d7fc1fc0f9d7acab327a3b86532

update tests for py3

ffafhrd91 committed 12 years ago
Unverified
3e451dd5a951c97d9e41992da31924dfe2ce8903

prepare release

ffafhrd91 committed 12 years ago

README

The README file for this repository.

player

.. image :: https://travis-ci.org/fafhrd91/player.png :target: https://travis-ci.org/fafhrd91/player

player allows to address templates with two parameters, category and name. Also it is possible to use set of directories for each layer, in that case player searches templates in each directory. It allows to override templates without changing code. For example form library can define layer field::

 >> ls ./fields/
 .. bool.pt
 .. file.pt
 ...
 .. textarea.pt

In your application you can override any of this template by defining new layer for field category::

 >> ls ./myproject/fields/
 .. bool.pt

Usually top level directory is a category and file in directory is template. For example 'form:view.lt'::

`form` - layer category
`view` - template name
`.lt`  - custom pyramid renderer factory

Layer can to be defined with add_layer config directive:

.. code-block:: python

>> config = Configurator()
.. config.include('player')
..
.. config.add_layer('form', path='./path_to_form_dirctory/form/')

form directory can contain any template:

.. code-block:: python

>> ./form/
..   view.pt
..   actions.jinja2

It is possible to use any of this templates as pyramid renderer path:

.. code-block:: python

>> config.add_view(
..     name='view.html', 
..     renderer='form:view.lt')

or :

.. code-block:: python

>> config.add_view(
..     name='actions.html', 
..     renderer='form:actions.lt')

It is possible to run python code before rendering template. There are add_tmpl_filter directive and player.tmpl_filter decorator:

.. code-block:: python

>> def form_actions(context, request):
..     return {'url': ...}

>> config.add_tmpl_filter('form:actions', form_action, name='custom')

or:

.. code-block:: python

>> import player

>> @player.tmpl_filter('form:actions', name='custom')
.. def form_actions(context, request):
..     return {'url': ...}

form_actions function gets call just before rendering template. Layer has to be defined with add_layer directve before registering template filter function.

Customization

Any number of layer categories can be registered and any number of layers can be registered in each category. It doesnt require to override all templates from category. For example it is possible to override just view.pt template::

>> config.add_layer('form', 'custom', path='path_to_form_directory_2/form')

and content of this new directory::

>> ./another_path/form/
..   view.jinja2

Now view view.html uses view.jinja2 template. But actions.html stil uses original template.

Another example, if you want customize bool field from ptah.form package all you need is to create some folder, add it as 'fields' layer, and put bool.pt template to this folder, something like that::

config.add_layer('fields', 'custom', 'mypackage:fields')

and ::

.mypackage/fields/ .. bool.pt

Request method

player also provides request method render_tmpl. It acccepts path::

.. ${structure: request.render_tmpl('form:actions')

.lt extension is optional in this case.

player

...

License

player is offered under the BSD license.