[4.2.x] Fixed #34645 -- Restored alignment for admin date/time timezone warnings.

Regression in 96a598356a.
Backport of caf80cb41f from main
This commit is contained in:
Mariusz Felisiak 2023-06-09 21:37:23 +02:00
parent eb84c068ed
commit 31d1fc36b3
7 changed files with 33 additions and 10 deletions

View File

@ -130,7 +130,9 @@ form .aligned div.help {
padding-left: 10px;
}
form .aligned p.datetime div.help.timezonewarning {
form .aligned p.date div.help.timezonewarning,
form .aligned p.datetime div.help.timezonewarning,
form .aligned p.time div.help.timezonewarning {
margin-left: 0;
padding-left: 0;
font-weight: normal;

View File

@ -147,7 +147,9 @@ form .aligned div.help {
form div.help ul,
form .aligned .checkbox-row + .help,
form .aligned p.datetime div.help.timezonewarning {
form .aligned p.date div.help.timezonewarning,
form .aligned p.datetime div.help.timezonewarning,
form .aligned p.time div.help.timezonewarning {
margin-right: 0;
padding-right: 0;
}

View File

@ -0,0 +1,3 @@
<p class="date">
{% include "django/forms/widgets/date.html" %}
</p>

View File

@ -0,0 +1,3 @@
<p class="time">
{% include "django/forms/widgets/time.html" %}
</p>

View File

@ -48,7 +48,7 @@ class FilteredSelectMultiple(forms.SelectMultiple):
return context
class AdminDateWidget(forms.DateInput):
class BaseAdminDateWidget(forms.DateInput):
class Media:
js = [
"admin/js/calendar.js",
@ -60,7 +60,11 @@ class AdminDateWidget(forms.DateInput):
super().__init__(attrs=attrs, format=format)
class AdminTimeWidget(forms.TimeInput):
class AdminDateWidget(BaseAdminDateWidget):
template_name = "admin/widgets/date.html"
class BaseAdminTimeWidget(forms.TimeInput):
class Media:
js = [
"admin/js/calendar.js",
@ -72,6 +76,10 @@ class AdminTimeWidget(forms.TimeInput):
super().__init__(attrs=attrs, format=format)
class AdminTimeWidget(BaseAdminTimeWidget):
template_name = "admin/widgets/time.html"
class AdminSplitDateTime(forms.SplitDateTimeWidget):
"""
A SplitDateTime Widget that has some admin-specific styling.
@ -80,7 +88,7 @@ class AdminSplitDateTime(forms.SplitDateTimeWidget):
template_name = "admin/widgets/split_datetime.html"
def __init__(self, attrs=None):
widgets = [AdminDateWidget, AdminTimeWidget]
widgets = [BaseAdminDateWidget, BaseAdminTimeWidget]
# Note that we're calling MultiWidget, not SplitDateTimeWidget, because
# we want to define widgets.
forms.MultiWidget.__init__(self, widgets, attrs)

View File

@ -9,4 +9,5 @@ Django 4.2.3 fixes several bugs in 4.2.2.
Bugfixes
========
* ...
* Fixed a regression in Django 4.2 that caused incorrect alignment of timezone
warnings for ``DateField`` and ``TimeField`` in the admin (:ticket:`34645`).

View File

@ -398,15 +398,17 @@ class AdminDateWidgetTest(SimpleTestCase):
w = widgets.AdminDateWidget()
self.assertHTMLEqual(
w.render("test", datetime(2007, 12, 1, 9, 30)),
'<p class="date">'
'<input value="2007-12-01" type="text" class="vDateField" name="test" '
'size="10">',
'size="10"></p>',
)
# pass attrs to widget
w = widgets.AdminDateWidget(attrs={"size": 20, "class": "myDateField"})
self.assertHTMLEqual(
w.render("test", datetime(2007, 12, 1, 9, 30)),
'<p class="date">'
'<input value="2007-12-01" type="text" class="myDateField" name="test" '
'size="20">',
'size="20"></p>',
)
@ -415,15 +417,17 @@ class AdminTimeWidgetTest(SimpleTestCase):
w = widgets.AdminTimeWidget()
self.assertHTMLEqual(
w.render("test", datetime(2007, 12, 1, 9, 30)),
'<p class="time">'
'<input value="09:30:00" type="text" class="vTimeField" name="test" '
'size="8">',
'size="8"></p>',
)
# pass attrs to widget
w = widgets.AdminTimeWidget(attrs={"size": 20, "class": "myTimeField"})
self.assertHTMLEqual(
w.render("test", datetime(2007, 12, 1, 9, 30)),
'<p class="time">'
'<input value="09:30:00" type="text" class="myTimeField" name="test" '
'size="20">',
'size="20"></p>',
)