Source code for distro_tracker.core.templatetags.distro_tracker_extras

# Copyright 2013-2016 The Distro Tracker Developers
# See the COPYRIGHT file at the top-level directory of this distribution and
# at https://deb.li/DTAuthors
#
# This file is part of Distro Tracker. It is subject to the license terms
# in the LICENSE file found in the top-level directory of this
# distribution and at https://deb.li/DTLicense. No part of Distro Tracker,
# including this file, may be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
"""Additional distro-tracker specific template tags."""

import re

from django import template
from django.template.loader import render_to_string
from django.utils.html import conditional_escape
from django.utils.safestring import mark_safe

register = template.Library()


[docs]class RepeatNode(template.Node): """ A :class:`Node <django.template.base.Node>` for implementing the :func:`repeat` template tag. """ def __init__(self, nodelist, count): self.nodelist = nodelist self.count = template.Variable(count)
[docs] def render(self, context): """ Renders the contents of the template tag :attr:`count` times. """ output = self.nodelist.render(context) return output * int(self.count.resolve(context))
[docs]@register.tag def repeat(parser, token): """ Repeats the string enclosed in the tag the number of times given in the parameter of the tag. """ try: tag_name, count = token.split_contents() except ValueError: raise template.TemplateSyntaxError( '{tag} tag requires an argument'.format( tag=token.contents.split()[0])) nodelist = parser.parse(('endrepeat',)) parser.delete_first_token() return RepeatNode(nodelist, count)
[docs]@register.simple_tag() def octicon(name, title='', content=None, role="img"): """ Renders an octicon with alternate text. """ if content is None: content = mark_safe('<span class="sr-only">[{}]</span>'.format(title)) return mark_safe(render_to_string( 'core/octicon.html', {'name': name, 'title': title, 'content': content, 'role': role} ).rstrip())
[docs]@register.simple_tag() def toggle_chevron(title='Toggle details'): """ Renders a chevron to toggle details. """ chevron = \ '<span role="button" aria-label="{}">{}</span>'.format( title, octicon('chevron-down', title=title, content='')) return mark_safe(chevron)
[docs]@register.filter(name='zip') def zip_iterables(first, second): """ A convenience template filter to :func:`zip` two sequences in the template. Using this filter it is possible to iterate through the values of two sequences in the same time in the template itself. """ return zip(first, second)
[docs]@register.filter() def lookup(dictionary, key): """ A filter to retrieve values from dictionaries. The lookup filter can access dictionary entries by their key, where the key can be a variable and not only a literal value. It can be used like this "dictionary|lookup:key" where both "dictionary" and "key" are variables. """ return dictionary.get(key, '')
[docs]@register.filter() def breakable(content): """ A filter that adds <wbr> (word breakpoints) to long words. Useful for very long versions strings that would otherwise cause text overflows in small cells. Returns an empty string when passed None. """ if content is None: return '' if len(content) >= 10: content = conditional_escape(content) return mark_safe(re.sub(r'([-~+\.])', '\\1<wbr>', content)) return content