mirror of
https://github.com/django/django.git
synced 2024-12-31 21:46:05 +00:00
Fixed #35809 -- Set background color for selected rows in the admin's form select widget.
Regression in b47bdb4cd9
.
Thank you Giannis Terzopoulos for the review, and Tom Carrick and Sarah Boyce
for the review.
This commit is contained in:
parent
747b417a22
commit
679d57816d
@ -169,6 +169,10 @@ form .aligned select + div.help {
|
|||||||
padding-left: 10px;
|
padding-left: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
form .aligned select option:checked {
|
||||||
|
background-color: var(--selected-row);
|
||||||
|
}
|
||||||
|
|
||||||
form .aligned ul li {
|
form .aligned ul li {
|
||||||
list-style: none;
|
list-style: none;
|
||||||
}
|
}
|
||||||
|
@ -16,3 +16,7 @@ Bugfixes
|
|||||||
|
|
||||||
* Fixed a regression in Django 5.1 that caused a crash of ``JSONObject()``
|
* Fixed a regression in Django 5.1 that caused a crash of ``JSONObject()``
|
||||||
when using server-side binding with PostgreSQL 16+ (:ticket:`35734`).
|
when using server-side binding with PostgreSQL 16+ (:ticket:`35734`).
|
||||||
|
|
||||||
|
* Fixed a regression in Django 5.1 that made selected items in multi-select
|
||||||
|
widgets indistinguishable from non-selected items in the admin dark theme
|
||||||
|
(:ticket:`35809`).
|
||||||
|
@ -6175,6 +6175,65 @@ class SeleniumTests(AdminSeleniumTestCase):
|
|||||||
)
|
)
|
||||||
self.take_screenshot("selectbox-non-collapsible")
|
self.take_screenshot("selectbox-non-collapsible")
|
||||||
|
|
||||||
|
@screenshot_cases(["desktop_size", "mobile_size", "rtl", "dark", "high_contrast"])
|
||||||
|
def test_selectbox_selected_rows(self):
|
||||||
|
from selenium.webdriver import ActionChains
|
||||||
|
from selenium.webdriver.common.by import By
|
||||||
|
from selenium.webdriver.common.keys import Keys
|
||||||
|
|
||||||
|
self.admin_login(
|
||||||
|
username="super", password="secret", login_url=reverse("admin:index")
|
||||||
|
)
|
||||||
|
# Create a new user to ensure that no extra permissions have been set.
|
||||||
|
user = User.objects.create_user(username="new", password="newuser")
|
||||||
|
url = self.live_server_url + reverse("admin:auth_user_change", args=[user.id])
|
||||||
|
self.selenium.get(url)
|
||||||
|
|
||||||
|
# Scroll to the User permissions section.
|
||||||
|
user_permissions = self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, "#id_user_permissions_from"
|
||||||
|
)
|
||||||
|
ActionChains(self.selenium).move_to_element(user_permissions).perform()
|
||||||
|
self.take_screenshot("selectbox-available-perms-none-selected")
|
||||||
|
|
||||||
|
# Select multiple permissions from the "Available" list.
|
||||||
|
ct = ContentType.objects.get_for_model(Permission)
|
||||||
|
perms = list(Permission.objects.filter(content_type=ct))
|
||||||
|
for perm in perms:
|
||||||
|
elem = self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, f"#id_user_permissions_from option[value='{perm.id}']"
|
||||||
|
)
|
||||||
|
ActionChains(self.selenium).key_down(Keys.CONTROL).click(elem).key_up(
|
||||||
|
Keys.CONTROL
|
||||||
|
).perform()
|
||||||
|
|
||||||
|
# Move focus to other element.
|
||||||
|
self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, "#id_user_permissions_input"
|
||||||
|
).click()
|
||||||
|
self.take_screenshot("selectbox-available-perms-some-selected")
|
||||||
|
|
||||||
|
# Move permissions to the "Chosen" list, but none is selected yet.
|
||||||
|
self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, "#id_user_permissions_add_link"
|
||||||
|
).click()
|
||||||
|
self.take_screenshot("selectbox-chosen-perms-none-selected")
|
||||||
|
|
||||||
|
# Select some permissions from the "Chosen" list.
|
||||||
|
for perm in [perms[0], perms[-1]]:
|
||||||
|
elem = self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, f"#id_user_permissions_to option[value='{perm.id}']"
|
||||||
|
)
|
||||||
|
ActionChains(self.selenium).key_down(Keys.CONTROL).click(elem).key_up(
|
||||||
|
Keys.CONTROL
|
||||||
|
).perform()
|
||||||
|
|
||||||
|
# Move focus to other element.
|
||||||
|
self.selenium.find_element(
|
||||||
|
By.CSS_SELECTOR, "#id_user_permissions_selected_input"
|
||||||
|
).click()
|
||||||
|
self.take_screenshot("selectbox-chosen-perms-some-selected")
|
||||||
|
|
||||||
@screenshot_cases(["desktop_size", "mobile_size", "rtl", "dark", "high_contrast"])
|
@screenshot_cases(["desktop_size", "mobile_size", "rtl", "dark", "high_contrast"])
|
||||||
def test_first_field_focus(self):
|
def test_first_field_focus(self):
|
||||||
"""JavaScript-assisted auto-focus on first usable form field."""
|
"""JavaScript-assisted auto-focus on first usable form field."""
|
||||||
|
Loading…
Reference in New Issue
Block a user