Fixed #35489 -- Fixed vertical alignment of raw_id_fields widget.

Co-authored-by: Sarah Boyce <42296566+sarahboyce@users.noreply.github.com>
This commit is contained in:
Vaarun Sinha 2024-07-05 20:50:10 +05:30 committed by Sarah Boyce
parent aa90795050
commit 54e8b4e582
2 changed files with 21 additions and 18 deletions

View File

@ -1,2 +1,2 @@
{% include 'django/forms/widgets/input.html' %}{% if related_url %}<a href="{{ related_url }}" class="related-lookup" id="lookup_id_{{ widget.name }}" title="{{ link_title }}"></a>{% endif %}{% if link_label %} {% if related_url %}<div>{% endif %}{% include 'django/forms/widgets/input.html' %}{% if related_url %}<a href="{{ related_url }}" class="related-lookup" id="lookup_id_{{ widget.name }}" title="{{ link_title }}"></a>{% endif %}{% if link_label %}
<strong>{% if link_url %}<a href="{{ link_url }}">{{ link_label }}</a>{% else %}{{ link_label }}{% endif %}</strong>{% endif %} <strong>{% if link_url %}<a href="{{ link_url }}">{{ link_label }}</a>{% else %}{{ link_label }}{% endif %}</strong>{% endif %}{% if related_url %}</div>{% endif %}

View File

@ -23,6 +23,7 @@ from django.db.models import (
UUIDField, UUIDField,
) )
from django.test import SimpleTestCase, TestCase, ignore_warnings, override_settings from django.test import SimpleTestCase, TestCase, ignore_warnings, override_settings
from django.test.selenium import screenshot_cases
from django.test.utils import requires_tz_support from django.test.utils import requires_tz_support
from django.urls import reverse from django.urls import reverse
from django.utils import translation from django.utils import translation
@ -684,21 +685,21 @@ class ForeignKeyRawIdWidgetTest(TestCase):
w = widgets.ForeignKeyRawIdWidget(rel_uuid, widget_admin_site) w = widgets.ForeignKeyRawIdWidget(rel_uuid, widget_admin_site)
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", band.uuid, attrs={}), w.render("test", band.uuid, attrs={}),
'<input type="text" name="test" value="%(banduuid)s" ' '<div><input type="text" name="test" value="%(banduuid)s" '
'class="vForeignKeyRawIdAdminField vUUIDField">' 'class="vForeignKeyRawIdAdminField vUUIDField">'
'<a href="/admin_widgets/band/?_to_field=uuid" class="related-lookup" ' '<a href="/admin_widgets/band/?_to_field=uuid" class="related-lookup" '
'id="lookup_id_test" title="Lookup"></a>&nbsp;<strong>' 'id="lookup_id_test" title="Lookup"></a>&nbsp;<strong>'
'<a href="/admin_widgets/band/%(bandpk)s/change/">Linkin Park</a>' '<a href="/admin_widgets/band/%(bandpk)s/change/">Linkin Park</a>'
"</strong>" % {"banduuid": band.uuid, "bandpk": band.pk}, "</strong></div>" % {"banduuid": band.uuid, "bandpk": band.pk},
) )
rel_id = ReleaseEvent._meta.get_field("album").remote_field rel_id = ReleaseEvent._meta.get_field("album").remote_field
w = widgets.ForeignKeyRawIdWidget(rel_id, widget_admin_site) w = widgets.ForeignKeyRawIdWidget(rel_id, widget_admin_site)
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", None, attrs={}), w.render("test", None, attrs={}),
'<input type="text" name="test" class="vForeignKeyRawIdAdminField">' '<div><input type="text" name="test" class="vForeignKeyRawIdAdminField">'
'<a href="/admin_widgets/album/?_to_field=id" class="related-lookup" ' '<a href="/admin_widgets/album/?_to_field=id" class="related-lookup" '
'id="lookup_id_test" title="Lookup"></a>', 'id="lookup_id_test" title="Lookup"></a></div>',
) )
def test_relations_to_non_primary_key(self): def test_relations_to_non_primary_key(self):
@ -711,12 +712,12 @@ class ForeignKeyRawIdWidgetTest(TestCase):
w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site) w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site)
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", core.parent_id, attrs={}), w.render("test", core.parent_id, attrs={}),
'<input type="text" name="test" value="86" ' '<div><input type="text" name="test" value="86" '
'class="vForeignKeyRawIdAdminField">' 'class="vForeignKeyRawIdAdminField">'
'<a href="/admin_widgets/inventory/?_to_field=barcode" ' '<a href="/admin_widgets/inventory/?_to_field=barcode" '
'class="related-lookup" id="lookup_id_test" title="Lookup"></a>' 'class="related-lookup" id="lookup_id_test" title="Lookup"></a>'
'&nbsp;<strong><a href="/admin_widgets/inventory/%(pk)s/change/">' '&nbsp;<strong><a href="/admin_widgets/inventory/%(pk)s/change/">'
"Apple</a></strong>" % {"pk": apple.pk}, "Apple</a></strong></div>" % {"pk": apple.pk},
) )
def test_fk_related_model_not_in_admin(self): def test_fk_related_model_not_in_admin(self):
@ -760,12 +761,12 @@ class ForeignKeyRawIdWidgetTest(TestCase):
) )
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", child_of_hidden.parent_id, attrs={}), w.render("test", child_of_hidden.parent_id, attrs={}),
'<input type="text" name="test" value="93" ' '<div><input type="text" name="test" value="93" '
' class="vForeignKeyRawIdAdminField">' ' class="vForeignKeyRawIdAdminField">'
'<a href="/admin_widgets/inventory/?_to_field=barcode" ' '<a href="/admin_widgets/inventory/?_to_field=barcode" '
'class="related-lookup" id="lookup_id_test" title="Lookup"></a>' 'class="related-lookup" id="lookup_id_test" title="Lookup"></a>'
'&nbsp;<strong><a href="/admin_widgets/inventory/%(pk)s/change/">' '&nbsp;<strong><a href="/admin_widgets/inventory/%(pk)s/change/">'
"Hidden</a></strong>" % {"pk": hidden.pk}, "Hidden</a></strong></div>" % {"pk": hidden.pk},
) )
def test_render_unsafe_limit_choices_to(self): def test_render_unsafe_limit_choices_to(self):
@ -773,10 +774,10 @@ class ForeignKeyRawIdWidgetTest(TestCase):
w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site) w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site)
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", None), w.render("test", None),
'<input type="text" name="test" class="vForeignKeyRawIdAdminField">\n' '<div><input type="text" name="test" class="vForeignKeyRawIdAdminField">'
'<a href="/admin_widgets/band/?name=%22%26%3E%3Cescapeme&amp;' '<a href="/admin_widgets/band/?name=%22%26%3E%3Cescapeme&amp;'
'_to_field=artist_ptr" class="related-lookup" id="lookup_id_test" ' '_to_field=artist_ptr" class="related-lookup" id="lookup_id_test" '
'title="Lookup"></a>', 'title="Lookup"></a></div>',
) )
def test_render_fk_as_pk_model(self): def test_render_fk_as_pk_model(self):
@ -784,9 +785,9 @@ class ForeignKeyRawIdWidgetTest(TestCase):
w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site) w = widgets.ForeignKeyRawIdWidget(rel, widget_admin_site)
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", None), w.render("test", None),
'<input type="text" name="test" class="vForeignKeyRawIdAdminField">\n' '<div><input type="text" name="test" class="vForeignKeyRawIdAdminField">'
'<a href="/admin_widgets/releaseevent/?_to_field=album" ' '<a href="/admin_widgets/releaseevent/?_to_field=album" '
'class="related-lookup" id="lookup_id_test" title="Lookup"></a>', 'class="related-lookup" id="lookup_id_test" title="Lookup"></a></div>',
) )
@ -804,10 +805,10 @@ class ManyToManyRawIdWidgetTest(TestCase):
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", [m1.pk, m2.pk], attrs={}), w.render("test", [m1.pk, m2.pk], attrs={}),
( (
'<input type="text" name="test" value="%(m1pk)s,%(m2pk)s" ' '<div><input type="text" name="test" value="%(m1pk)s,%(m2pk)s" '
' class="vManyToManyRawIdAdminField">' ' class="vManyToManyRawIdAdminField">'
'<a href="/admin_widgets/member/" class="related-lookup" ' '<a href="/admin_widgets/member/" class="related-lookup" '
' id="lookup_id_test" title="Lookup"></a>' ' id="lookup_id_test" title="Lookup"></a></div>'
) )
% {"m1pk": m1.pk, "m2pk": m2.pk}, % {"m1pk": m1.pk, "m2pk": m2.pk},
) )
@ -815,10 +816,10 @@ class ManyToManyRawIdWidgetTest(TestCase):
self.assertHTMLEqual( self.assertHTMLEqual(
w.render("test", [m1.pk]), w.render("test", [m1.pk]),
( (
'<input type="text" name="test" value="%(m1pk)s" ' '<div><input type="text" name="test" value="%(m1pk)s" '
' class="vManyToManyRawIdAdminField">' ' class="vManyToManyRawIdAdminField">'
'<a href="/admin_widgets/member/" class="related-lookup" ' '<a href="/admin_widgets/member/" class="related-lookup" '
' id="lookup_id_test" title="Lookup"></a>' ' id="lookup_id_test" title="Lookup"></a></div>'
) )
% {"m1pk": m1.pk}, % {"m1pk": m1.pk},
) )
@ -1680,6 +1681,7 @@ class AdminRawIdWidgetSeleniumTests(AdminWidgetSeleniumTestCase):
Band.objects.create(id=42, name="Bogey Blues") Band.objects.create(id=42, name="Bogey Blues")
Band.objects.create(id=98, name="Green Potatoes") Band.objects.create(id=98, name="Green Potatoes")
@screenshot_cases(["desktop_size", "mobile_size", "rtl", "dark", "high_contrast"])
def test_ForeignKey(self): def test_ForeignKey(self):
from selenium.webdriver.common.by import By from selenium.webdriver.common.by import By
@ -1688,6 +1690,7 @@ class AdminRawIdWidgetSeleniumTests(AdminWidgetSeleniumTestCase):
self.live_server_url + reverse("admin:admin_widgets_event_add") self.live_server_url + reverse("admin:admin_widgets_event_add")
) )
main_window = self.selenium.current_window_handle main_window = self.selenium.current_window_handle
self.take_screenshot("raw_id_widget")
# No value has been selected yet # No value has been selected yet
self.assertEqual( self.assertEqual(