Fixed #33051 -- Fixed highlighting the current model in admin's sidebar with non-ASCII model names.

This commit is contained in:
Hasan Ramezani 2021-08-26 17:43:40 +02:00 committed by Mariusz Felisiak
parent 5942ab5eb1
commit d1216e126f
3 changed files with 24 additions and 3 deletions

View File

@ -2,15 +2,15 @@
{% if app_list %} {% if app_list %}
{% for app in app_list %} {% for app in app_list %}
<div class="app-{{ app.app_label }} module{% if app.app_url in request.path %} current-app{% endif %}"> <div class="app-{{ app.app_label }} module{% if app.app_url in request.path|urlencode %} current-app{% endif %}">
<table> <table>
<caption> <caption>
<a href="{{ app.app_url }}" class="section" title="{% blocktranslate with name=app.name %}Models in the {{ name }} application{% endblocktranslate %}">{{ app.name }}</a> <a href="{{ app.app_url }}" class="section" title="{% blocktranslate with name=app.name %}Models in the {{ name }} application{% endblocktranslate %}">{{ app.name }}</a>
</caption> </caption>
{% for model in app.models %} {% for model in app.models %}
<tr class="model-{{ model.object_name|lower }}{% if model.admin_url in request.path %} current-model{% endif %}"> <tr class="model-{{ model.object_name|lower }}{% if model.admin_url in request.path|urlencode %} current-model{% endif %}">
{% if model.admin_url %} {% if model.admin_url %}
<th scope="row"><a href="{{ model.admin_url }}"{% if model.admin_url in request.path %} aria-current="page"{% endif %}>{{ model.name }}</a></th> <th scope="row"><a href="{{ model.admin_url }}"{% if model.admin_url in request.path|urlencode %} aria-current="page"{% endif %}>{{ model.name }}</a></th>
{% else %} {% else %}
<th scope="row">{{ model.name }}</th> <th scope="row">{{ model.name }}</th>
{% endif %} {% endif %}

View File

@ -1046,3 +1046,7 @@ class ReadOnlyRelatedField(models.Model):
chapter = models.ForeignKey(Chapter, models.CASCADE) chapter = models.ForeignKey(Chapter, models.CASCADE)
language = models.ForeignKey(Language, models.CASCADE) language = models.ForeignKey(Language, models.CASCADE)
user = models.ForeignKey(User, models.CASCADE) user = models.ForeignKey(User, models.CASCADE)
class Héllo(models.Model):
pass

View File

@ -4,6 +4,8 @@ from django.contrib.auth.models import User
from django.test import TestCase, override_settings from django.test import TestCase, override_settings
from django.urls import path, reverse from django.urls import path, reverse
from .models import Héllo
class AdminSiteWithSidebar(admin.AdminSite): class AdminSiteWithSidebar(admin.AdminSite):
pass pass
@ -17,6 +19,7 @@ site_with_sidebar = AdminSiteWithSidebar(name='test_with_sidebar')
site_without_sidebar = AdminSiteWithoutSidebar(name='test_without_sidebar') site_without_sidebar = AdminSiteWithoutSidebar(name='test_without_sidebar')
site_with_sidebar.register(User) site_with_sidebar.register(User)
site_with_sidebar.register(Héllo)
urlpatterns = [ urlpatterns = [
path('test_sidebar/admin/', site_with_sidebar.urls), path('test_sidebar/admin/', site_with_sidebar.urls),
@ -85,9 +88,23 @@ class AdminSidebarTests(TestCase):
with self.assertNoLogs('django.template', 'DEBUG'): with self.assertNoLogs('django.template', 'DEBUG'):
self.client.get(url) self.client.get(url)
def test_sidebar_model_name_non_ascii(self):
url = reverse('test_with_sidebar:admin_views_héllo_changelist')
response = self.client.get(url)
self.assertContains(response, '<div class="app-admin_views module current-app">')
self.assertContains(response, '<tr class="model-héllo current-model">')
self.assertContains(
response,
'<th scope="row">'
'<a href="/test_sidebar/admin/admin_views/h%C3%A9llo/" aria-current="page">'
'Héllos</a></th>'
)
@override_settings(ROOT_URLCONF='admin_views.test_nav_sidebar') @override_settings(ROOT_URLCONF='admin_views.test_nav_sidebar')
class SeleniumTests(AdminSeleniumTestCase): class SeleniumTests(AdminSeleniumTestCase):
available_apps = ['admin_views'] + AdminSeleniumTestCase.available_apps
def setUp(self): def setUp(self):
self.superuser = User.objects.create_superuser( self.superuser = User.objects.create_superuser(
username='super', username='super',