mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #13629 -- Added CSS classes to the <body>
tag of some admin templates to allow style customizations per app or per model.
This commit is contained in:
committed by
Julien Phalip
parent
11b7b9ad00
commit
bb145e2c47
1
AUTHORS
1
AUTHORS
@@ -544,6 +544,7 @@ answer newbie questions, and generally made Django that much better:
|
||||
George Song <george@damacy.net>
|
||||
sopel
|
||||
Leo Soto <leo.soto@gmail.com>
|
||||
Thomas Sorrel
|
||||
Wiliam Alves de Souza <wiliamsouza83@gmail.com>
|
||||
Don Spaulding <donspauldingii@gmail.com>
|
||||
Calvin Spealman <ironfroggy@gmail.com>
|
||||
|
@@ -439,6 +439,7 @@ class AdminSite(object):
|
||||
context = {
|
||||
'title': _('%s administration') % capfirst(app_label),
|
||||
'app_list': [app_dict],
|
||||
'app_label': app_label,
|
||||
}
|
||||
context.update(extra_context or {})
|
||||
|
||||
|
@@ -1,6 +1,8 @@
|
||||
{% extends "admin/index.html" %}
|
||||
{% load i18n %}
|
||||
|
||||
{% block bodyclass %}app-{{ app_label }} {{ block.super }}{% endblock %}
|
||||
|
||||
{% if not is_popup %}
|
||||
{% block breadcrumbs %}
|
||||
<div class="breadcrumbs">
|
||||
|
@@ -10,7 +10,7 @@
|
||||
|
||||
{% block coltype %}colM{% endblock %}
|
||||
|
||||
{% block bodyclass %}{{ opts.app_label }}-{{ opts.object_name.lower }} change-form{% endblock %}
|
||||
{% block bodyclass %}app-{{ opts.app_label }} model-{{ opts.object_name.lower }} change-form{% endblock %}
|
||||
|
||||
{% if not is_popup %}
|
||||
{% block breadcrumbs %}
|
||||
|
@@ -32,7 +32,7 @@
|
||||
{% endif %}{% endif %}
|
||||
{% endblock %}
|
||||
|
||||
{% block bodyclass %}change-list{% endblock %}
|
||||
{% block bodyclass %}app-{{ opts.app_label }} model-{{ opts.object_name.lower }} change-list{% endblock %}
|
||||
|
||||
{% if not is_popup %}
|
||||
{% block breadcrumbs %}
|
||||
|
@@ -1,6 +1,8 @@
|
||||
{% extends "admin/base_site.html" %}
|
||||
{% load i18n admin_urls %}
|
||||
|
||||
{% block bodyclass %}app-{{ opts.app_label }} model-{{ opts.object_name.lower }} delete-confirmation{% endblock %}
|
||||
|
||||
{% block breadcrumbs %}
|
||||
<div class="breadcrumbs">
|
||||
<a href="{% url 'admin:index' %}">{% trans 'Home' %}</a>
|
||||
|
@@ -1,6 +1,8 @@
|
||||
{% extends "admin/base_site.html" %}
|
||||
{% load i18n l10n admin_urls %}
|
||||
|
||||
{% block bodyclass %}app-{{ opts.app_label }} model-{{ opts.object_name.lower }} delete-confirmation delete-selected-confirmation{% endblock %}
|
||||
|
||||
{% block breadcrumbs %}
|
||||
<div class="breadcrumbs">
|
||||
<a href="{% url 'admin:index' %}">{% trans 'Home' %}</a>
|
||||
|
@@ -199,6 +199,10 @@ Minor features
|
||||
* The admin list columns have a ``column-<field_name>`` class in the HTML
|
||||
so the columns header can be styled with CSS, e.g. to set a column width.
|
||||
|
||||
* Some admin templates now have ``app-<app_name>`` and ``model-<model_name>``
|
||||
classes in their ``<body>`` tag to allow customizing the CSS per app or per
|
||||
model.
|
||||
|
||||
* The :ref:`isolation level<database-isolation-level>` can be customized under
|
||||
PostgreSQL.
|
||||
|
||||
|
@@ -3824,6 +3824,59 @@ class CSSTest(TestCase):
|
||||
self.assertContains(response, '<tr class="model-actor">')
|
||||
self.assertContains(response, '<tr class="model-album">')
|
||||
|
||||
def testAppModelInFormBodyClass(self):
|
||||
"""
|
||||
Ensure app and model tag are correcly read by change_form template
|
||||
"""
|
||||
response = self.client.get('/test_admin/admin/admin_views/section/add/')
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertContains(response,
|
||||
'<body class="app-admin_views model-section ')
|
||||
|
||||
def testAppModelInListBodyClass(self):
|
||||
"""
|
||||
Ensure app and model tag are correcly read by change_list template
|
||||
"""
|
||||
response = self.client.get('/test_admin/admin/admin_views/section/')
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertContains(response,
|
||||
'<body class="app-admin_views model-section ')
|
||||
|
||||
def testAppModelInDeleteConfirmationBodyClass(self):
|
||||
"""
|
||||
Ensure app and model tag are correcly read by delete_confirmation
|
||||
template
|
||||
"""
|
||||
response = self.client.get(
|
||||
'/test_admin/admin/admin_views/section/1/delete/')
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertContains(response,
|
||||
'<body class="app-admin_views model-section ')
|
||||
|
||||
def testAppModelInAppIndexBodyClass(self):
|
||||
"""
|
||||
Ensure app and model tag are correcly read by app_index template
|
||||
"""
|
||||
response = self.client.get('/test_admin/admin/admin_views/')
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertContains(response, '<body class="app-admin_views ')
|
||||
|
||||
def testAppModelInDeleteSelectedConfirmationBodyClass(self):
|
||||
"""
|
||||
Ensure app and model tag are correcly read by
|
||||
delete_selected_confirmation template
|
||||
"""
|
||||
action_data = {
|
||||
ACTION_CHECKBOX_NAME: [1],
|
||||
'action': 'delete_selected',
|
||||
'index': 0,
|
||||
}
|
||||
response = self.client.post('/test_admin/admin/admin_views/section/',
|
||||
action_data)
|
||||
self.assertEqual(response.status_code, 200)
|
||||
self.assertContains(response,
|
||||
'<body class="app-admin_views model-section ')
|
||||
|
||||
try:
|
||||
import docutils
|
||||
except ImportError:
|
||||
|
Reference in New Issue
Block a user