1
0
mirror of https://github.com/django/django.git synced 2025-10-24 22:26:08 +00:00

Fixed #36331 -- Reverted "Fixed #36055 -- Prevented overlap of object-tools buttons and page header in the admin."

This reverts commits b1324a680a and
02a5cbfe76. The former caused a regression
in admin sites that relied on the `object-tools` block being inside the
`content` block.

Thank you to Fabian Braun for the report.
This commit is contained in:
antoliny0919
2025-04-17 19:38:26 +09:00
committed by nessita
parent 1831f7733d
commit 1bc805e23b
7 changed files with 14 additions and 38 deletions

View File

@@ -782,6 +782,7 @@ a.deletelink:focus, a.deletelink:hover {
padding-left: 0; padding-left: 0;
float: right; float: right;
position: relative; position: relative;
margin-top: -48px;
} }
.object-tools li { .object-tools li {
@@ -829,10 +830,6 @@ a.deletelink:focus, a.deletelink:hover {
background-image: url(../img/tooltag-add.svg); background-image: url(../img/tooltag-add.svg);
} }
.object-tools:has(a.addlink) {
margin-top: -48px;
}
/* OBJECT HISTORY */ /* OBJECT HISTORY */
#change-history table { #change-history table {

View File

@@ -465,10 +465,6 @@ input[type="submit"], button {
margin-left: 15px; margin-left: 15px;
} }
.object-tools:has(a.addlink) {
margin-top: 0px;
}
/* Forms */ /* Forms */
.form-row { .form-row {

View File

@@ -99,9 +99,9 @@
<div id="content" class="{% block coltype %}colM{% endblock %}"> <div id="content" class="{% block coltype %}colM{% endblock %}">
{% block pretitle %}{% endblock %} {% block pretitle %}{% endblock %}
{% block content_title %}{% if title %}<h1>{{ title }}</h1>{% endif %}{% endblock %} {% block content_title %}{% if title %}<h1>{{ title }}</h1>{% endif %}{% endblock %}
{% block object-tools %}{% endblock %}
{% block content_subtitle %}{% if subtitle %}<h2>{{ subtitle }}</h2>{% endif %}{% endblock %} {% block content_subtitle %}{% if subtitle %}<h2>{{ subtitle }}</h2>{% endif %}{% endblock %}
{% block content %} {% block content %}
{% block object-tools %}{% endblock %}
{{ content }} {{ content }}
{% endblock %} {% endblock %}
{% block sidebar %}{% endblock %} {% block sidebar %}{% endblock %}

View File

@@ -24,6 +24,7 @@
{% endblock %} {% endblock %}
{% endif %} {% endif %}
{% block content %}<div id="content-main">
{% block object-tools %} {% block object-tools %}
{% if change and not is_popup %} {% if change and not is_popup %}
<ul class="object-tools"> <ul class="object-tools">
@@ -33,8 +34,6 @@
</ul> </ul>
{% endif %} {% endif %}
{% endblock %} {% endblock %}
{% block content %}<div id="content-main">
<form {% if has_file_field %}enctype="multipart/form-data" {% endif %}{% if form_url %}action="{{ form_url }}" {% endif %}method="post" id="{{ opts.model_name }}_form" novalidate>{% csrf_token %}{% block form_top %}{% endblock %} <form {% if has_file_field %}enctype="multipart/form-data" {% endif %}{% if form_url %}action="{{ form_url }}" {% endif %}method="post" id="{{ opts.model_name }}_form" novalidate>{% csrf_token %}{% block form_top %}{% endblock %}
<div> <div>
{% if is_popup %}<input type="hidden" name="{{ is_popup_var }}" value="1">{% endif %} {% if is_popup %}<input type="hidden" name="{{ is_popup_var }}" value="1">{% endif %}

View File

@@ -39,6 +39,8 @@
{% block coltype %}{% endblock %} {% block coltype %}{% endblock %}
{% block content %}
<div id="content-main">
{% block object-tools %} {% block object-tools %}
<ul class="object-tools"> <ul class="object-tools">
{% block object-tools-items %} {% block object-tools-items %}
@@ -46,9 +48,6 @@
{% endblock %} {% endblock %}
</ul> </ul>
{% endblock %} {% endblock %}
{% block content %}
<div id="content-main">
{% if cl.formset and cl.formset.errors %} {% if cl.formset and cl.formset.errors %}
<p class="errornote"> <p class="errornote">
{% blocktranslate count counter=cl.formset.total_error_count %}Please correct the error below.{% plural %}Please correct the errors below.{% endblocktranslate %} {% blocktranslate count counter=cl.formset.total_error_count %}Please correct the error below.{% plural %}Please correct the errors below.{% endblocktranslate %}

View File

@@ -40,3 +40,7 @@ Bugfixes
* Fixed a regression in Django 5.2 where the password validation error message * Fixed a regression in Django 5.2 where the password validation error message
from ``MinimumLengthValidator`` was not translated when using non-English from ``MinimumLengthValidator`` was not translated when using non-English
locales (:ticket:`36314`). locales (:ticket:`36314`).
* Fixed a regression in Django 5.2 that caused the ``object-tools`` block to be
rendered twice when using custom admin templates with overridden blocks due
to changes in the base admin page block structure (:ticket:`36331`).

View File

@@ -125,7 +125,6 @@ from .models import (
Song, Song,
State, State,
Story, Story,
Subscriber,
SuperSecretHideout, SuperSecretHideout,
SuperVillain, SuperVillain,
Telegram, Telegram,
@@ -6870,24 +6869,6 @@ class SeleniumTests(AdminSeleniumTestCase):
name_input_value = name_input.get_attribute("value") name_input_value = name_input.get_attribute("value")
self.assertEqual(name_input_value, "Test section 1") self.assertEqual(name_input_value, "Test section 1")
@screenshot_cases(["desktop_size", "mobile_size", "rtl", "dark", "high_contrast"])
def test_long_object_str_on_change_view(self):
from selenium.webdriver.common.by import By
self.admin_login(
username="super", password="secret", login_url=reverse("admin:index")
)
s = Subscriber.objects.create(name="a " * 40, email="b " * 80)
self.selenium.get(
self.live_server_url
+ reverse("admin:admin_views_subscriber_change", args=(s.pk,))
)
object_tools = self.selenium.find_elements(
By.CSS_SELECTOR, "div#content ul.object-tools li"
)
self.assertGreater(len(object_tools), 0)
self.take_screenshot("not-overwrap")
@override_settings(ROOT_URLCONF="admin_views.urls") @override_settings(ROOT_URLCONF="admin_views.urls")
class ReadonlyTest(AdminFieldExtractionMixin, TestCase): class ReadonlyTest(AdminFieldExtractionMixin, TestCase):