Django: Can't override admin templates when they are already overridden?

随声附和 提交于 2019-12-10 09:56:12

问题


To add some content to a Django admin view of a model, I want to override the change_form.html template. According to the documentation I would need to create a file change_form.html in a the folder /project-path/templates/admin/appname/modelname/. Of course I need to make sure, that this path is also available in TEMPLATE_DIRS. Such a file could look like this:

{% extends "admin/change_form.html" %}
{% load i18n  %}

{% block after_field_sets %}
SOME CONTENT
{% endblock %}

However, I make use of django-guardian to have object permissions. This Django app overrides change_form.html as well (which works fine -- relevant source seems to be here), but Django doesn't pick up my template extension file (i.e. "SOME CONTENT" from the sample above isn't displayed). The blocks/parts I want to override are not the same ones that django-guardian overrides and eventually I want to have the additions to change_form.html of django-guardion and of my template.

What am I doing wrong here? And is possible at all to have multiple applications overriding an admin template?

If it is of interest, this is my TEMPLATE_LOADERS setting:

TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader'
)

Also, django-guardian is the last app in the INSTALLED_APPS array.


回答1:


One possible solution seems to be to explicitly define the inheritance chain by referring to and overriding django-guardian's template (defined here) and not Django's general change_form.html. So instead of using

{% extends "admin/change_form.html" %}

in the beginning of my custom template, I would need to use

{% extends "admin/guardian/model/change_form.html" %}

Also I would need to extend my GuardedModelAdmin sub-class model to explicitly use my own template file as the change form template:

class MyModel(GuardedModelAdmin):
    change_form_template = 'admin/appname/mymodel/change_form.html'

This works, but it adds a clear dependency to the template and the model. Of course, the model has this dependency anyway, but I would be interested if there is also a solution that refers only to the default change_form.html -- however, I suspect that this is not really possible.




回答2:


If a path to your template is in TEMPLATE_DIRS, then you can reverse order of your TEMPLATE_LOADERS.

If your template in in your app, then you need to add your app after django-guardian in INSTALLED_APPS array.

Basically, if there are name collisions, then last loaded template will be in use.



来源:https://stackoverflow.com/questions/13122656/django-cant-override-admin-templates-when-they-are-already-overridden

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!