I’ve tried several different ways a while ago, each of them gave a different exception, so I gave up and decided to manually write filters when I need them. But I’m missing the native escapejs and other useful but simple filters.
There are several related questions and answers, but as far as I see none of them gives a seamless way to implement this. I guess the main problem is that django filters routines are tied too much to the django environment.
Please answer only if you managed to use built-in django filters in the Appengine SDK environment, from my experience it’s harder compared to a normal environment, as Appengine environment is limited
Template tags in the Django template engine are simple functions that accept values and parameters. They can all be accessed directly in the source code.
This is output from IPython:
Most of the Django-specific magic resides in the decorator (
register.filter) and in the way that the language resolves calls when you type{% load <template library> %}in your template. Look for the definitions in<module>.templatetagsmodules. Built-ins are located indjango.template.defaulttagsanddjango.template.defaultfilters.If Jinja2 has a way to define new template filters (which it probably does), then you could simply wrap handmade template filters to actual Django functions.
So basically, just create Jinja2 filters that point to the actual Django function definitions.
Edit:
If you do not have access to the actual Django functions, just copy-paste the source code and remove or adapt Django-specific stuff.
The
escapejsfilter is actually a call to this function indjango.utils.html: