#!/usr/bin/env python # -*- coding: utf-8 -*- """ openslides.template ~~~~~~~~~~~~~~~~~~~ Useful template functions for OpenSlides. :copyright: 2011, 2012 by OpenSlides team, see AUTHORS. :license: GNU GPL, see LICENSE for more details. """ from django.http import HttpResponse from django.template import loader, Context, RequestContext, TextNode from django.template.loader_tags import BlockNode, ExtendsNode class Tab(object): def __init__(self, title='', app='', url='', permission='', selected=False): self.selected = False self.title = title self.app = app self.permission = permission self.selected = selected self.url = url def get_template(template): if isinstance(template, (tuple, list)): return loader.select_template(template) return loader.get_template(template) class BlockNotFound(Exception): pass def render_template_block(template, block, context): """ Renders a single block from a template. This template should have previously been rendered. """ return render_template_block_nodelist(template.nodelist, block, context) def render_template_block_nodelist(nodelist, block, context): for node in nodelist: if isinstance(node, BlockNode) and node.name == block: return node.render(context) for key in ('nodelist', 'nodelist_true', 'nodelist_false'): if hasattr(node, key): try: return render_template_block_nodelist(getattr(node, key), block, context) except: pass for node in nodelist: if isinstance(node, ExtendsNode): try: return render_template_block(node.get_parent(context), block, context) except BlockNotFound: pass raise BlockNotFound def render_block_to_string(template_name, block, dictionary=None, context_instance=None): """ Loads the given template_name and renders the given block with the given dictionary as context. Returns a string. """ dictionary = dictionary or {} t = get_template(template_name) if context_instance: context_instance.update(dictionary) else: context_instance = Context(dictionary) t.render(context_instance) return render_template_block(t, block, context_instance) def direct_block_to_template(request, template, block, extra_context=None, mimetype=None, **kwargs): """ Render a given block in a given template with any extra URL parameters in the context as ``{{ params }}``. """ if extra_context is None: extra_context = {} dictionary = {'params': kwargs} for key, value in extra_context.items(): if callable(value): dictionary[key] = value() else: dictionary[key] = value c = RequestContext(request, dictionary) t = get_template(template) t.render(c) return HttpResponse(render_template_block(t, block, c), mimetype=mimetype)