[Answer]-Get django to check current URL and if contains a particular string, to add in a class

1👍

page.html

 {% extends 'base.html' %}
 {% load utility %}

 {% block content %}
 <ul class="big-menu">
     <li>
         <a href="{% url main:home %}" class="{% ifpathmatch "main:home" %}current{% endifpathmatch %}">Home</a>
     </li>
 </ul>
 {% endblock %}

(template_tags)
utility.py

 import re

 from django import template
 from django.core.urlresolvers import NoReverseMatch
 from django.templatetags.future import url as django_url_func

 register = template.Library()


 def ifurlmatch(parser, token):
     """
     This is a block tag similar to an {% if %}{% endif %} block.

     It will conditionally display the content between matching
     {% ifurlmatch %}{% endifurlmatch %} tags if the URL path (minus hostname)
     matches the parameter, which should be a string or regex pattern.
     """
     tag_name, pattern = token.split_contents()

     # Arg, split_contents doesn't remove encapsing quotes.
     pattern = pattern.strip('"\'')
     nodelist = parser.parse(('endifurlmatch'))
     parser.delete_first_token()
     return UrlMatchNode(nodelist, pattern)


 class UrlMatchNode(template.Node):
     def __init__(self, nodelist, pattern):
        self.pattern = pattern
        self.nodelist = nodelist

     def render(self, context):
        if self._path_matches(context):
            return self.nodelist.render(context)
        return ''

     def _path_matches(self, context):
        req = context['request']
        path = req.META.get('PATH_INFO', '/')
        return re.search(self.pattern, path) is not None

 register.tag("ifurlmatch", ifurlmatch)


def ifpathmatch(parser, token):
    """
    This is a block tag similar to an {% if %}{% endif %} block.
    It will conditionally display the content between matching
    {% ifpathmatch %}{% endifpathmatch %} tags if the current page's URL
    matches the named path from v1.py passed in as the parameters.

    BUG/NOTE: Currently all string parameters to this must be quoted, or it
    will never match. For example, to match the
    relationships:clients:activity URL path you would need to do the
    following:
        {% ifpathmatch "relationships:clients:activity" "my-client-slug" %}
    Parameters which aren't literal strings shouldn't be quoted.
    For example, if passing in a client object's slug:
        {% ifpathmatch "relationships:clients:activity" myclientobj.slug %}
    """

    nodelist = parser.parse(('endifpathmatch'))
    parser.delete_first_token()
    return NamedPathMatchNode(nodelist, parser, token, True)


def ifpathcontains(parser, token):
    """
    Similar to ifpathmatch, but will return true if url contains passed in path
    """
    nodelist = parser.parse(('endifpathcontains'))
    parser.delete_first_token()
    return NamedPathMatchNode(nodelist, parser, token, False)


class NamedPathMatchNode(template.Node):
    def __init__(self, nodelist, parser, token, strict):
        self.token = token
        self.nodelist = nodelist
        self.parser = parser
        self.strict = strict

    def render(self, context):
        reversed_url = None
        try:
            reversed_url = django_url_func(
               self.parser, self.token).render(context)
        except NoReverseMatch:
            pass

        if self.strict:
            if reversed_url is not None and self._path_matches(
               context, reversed_url):
               return self.nodelist.render(context)
        else:
            if reversed_url is not None and self._path_contains(
               context, reversed_url):
               return self.nodelist.render(context)
        return ''

    def _path_matches(self, context, reversed_url):
        req = context['request']
        return req.META.get('PATH_INFO', '/') == reversed_url

    def _path_contains(self, context, reversed_url):
        req = context['request']
        return reversed_url in req.META.get('PATH_INFO', '/')

 register.tag("ifpathmatch", ifpathmatch)
 register.tag("ifpathcontains", ifpathcontains)

Leave a comment