- Status changed to Needs review
about 2 years ago 4:07pm 17 January 2023 - 🇺🇸United States rtdean93
2719797-158.patch worked perfectly for me on 9.4.8. Thanks.
- Status changed to RTBC
almost 2 years ago 6:41pm 13 February 2023 - 🇺🇸United States smustgrave
Putting back to RTBC from #161 as there was no code change.
The last submitted patch, 158: 2719797-158.patch, failed testing. View results →
- 🇮🇳India arunkumark Coimbatore
Tested the patch manually with Drupal core 10.1.x. The patch was applied cleanly and was able to use the option of the Admin theme. Attached screenshot for reference.
Moving the status to RTBC.
- Status changed to Needs work
almost 2 years ago 8:29am 21 February 2023 - 🇫🇮Finland lauriii Finland
This has received multiple iterations of Usability review. All of the feedback has been addressed except explaining what other consequences there are from marking a page as admin page. The example provided there was Quickedit, which has been removed from core. I believe this might be outdated and therefore I'm not opening a follow-up issue for this.
-
+++ b/core/modules/views/config/schema/views.display.schema.yml @@ -68,6 +68,9 @@ views.display.page: + use_admin_theme: + type: boolean + label: 'Use the administration theme when rendering the view page'
Since this is no longer a required property, it should be marked as nullable.
-
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -244,6 +248,27 @@ public function optionsSummary(&$categories, &$options) { + $admin_theme_text = $this->t("Yes (admin path)"); ... + $admin_theme_text = $this->t("Yes"); ... + $admin_theme_text = $this->t("No");
Super nit: s/"/'
-
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -244,6 +248,27 @@ public function optionsSummary(&$categories, &$options) { + 'title' => $this->t('Admin theme'), ... + 'desc' => $this->t('Use the administration theme when rendering this display.'), @@ -445,6 +470,21 @@ public function buildOptionsForm(&$form, FormStateInterface $form_state) { + '#description' => $this->t('Paths starting with "admin/" use the admin theme even when this option is not checked.'),
We should use the term "administration theme" consistently across all of these strings instead of "admin theme"
-
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -445,6 +470,21 @@ public function buildOptionsForm(&$form, FormStateInterface $form_state) { + '#title' => $this->t('Always use admin theme'),
We are missing the before admin theme.
-
- Status changed to Needs review
almost 2 years ago 9:10am 21 February 2023 - 🇫🇮Finland lauriii Finland
Addressed my feedback and added some more test coverage for the UI.
- Status changed to RTBC
almost 2 years ago 2:21pm 21 February 2023 - 🇺🇸United States smustgrave
New changes look good.
I ran the new test locally too to make sure it failed
Behat\Mink\Exception\ResponseTextException : The text "Administration theme: No" was not found anywhere in the text of the current page.
Excited for this new feature.
- Status changed to Needs work
almost 2 years ago 10:25am 22 February 2023 - 🇬🇧United Kingdom alexpott 🇪🇺🌍
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -445,6 +470,21 @@ public function buildOptionsForm(&$form, FormStateInterface $form_state) { + $form['use_admin_theme'] = [ + '#type' => 'checkbox', + '#title' => $this->t('Always use the administration theme'), + '#description' => $this->t('Paths starting with "admin/" use the administration theme even when this option is not checked.'), + '#default_value' => $this->getOption('use_admin_theme'), + ]; + $display_path = $this->getOption('path'); + if (!empty($display_path) && stripos($display_path, 'admin/') === 0) { + $form['use_admin_theme']['#default_value'] = TRUE; + $form['use_admin_theme']['#attributes'] = ['disabled' => 'disabled']; + } + break;
The use of "Always" here was question by @pfrenssen in #56 and sent back for usability review but the UX review in #61 did not actually address this - it made other recommendations. I think the "always" perhaps was more relevant when this was in the path setting dialog.
Furthermore the description is odd because it says
Paths starting with "admin/" use the administration theme even when this option is not checked
but we have code below disabling and setting the field to TRUE when the path starts with admin so it will never be not set.I think we should change this code element to:
$form['use_admin_theme'] = [ '#type' => 'checkbox', '#title' => $this->t('Use the administration theme'), '#default_value' => $this->getOption('use_admin_theme'), ]; if (str_starts_with($this->getOption('path') ?? '', 'admin/')) { $form['use_admin_theme']['#description'] = $this->t('Paths starting with "admin/" always use the administration theme.'); $form['use_admin_theme']['#default_value'] = TRUE; $form['use_admin_theme']['#attributes'] = ['disabled' => 'disabled']; }
- Status changed to Needs review
almost 2 years ago 11:32am 22 February 2023 - Status changed to Needs work
almost 2 years ago 12:12pm 22 February 2023 - Status changed to Needs review
almost 2 years ago 3:10pm 22 February 2023 - Status changed to RTBC
almost 2 years ago 12:42am 23 February 2023 - 🇺🇸United States smustgrave
@catch think your points have been addressed.
- Status changed to Needs review
almost 2 years ago 2:46am 23 February 2023 - 🇨🇳China jungle Chongqing, China
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -244,6 +251,27 @@ public function optionsSummary(&$categories, &$options) { + if (!empty($display_path) && stripos($display_path, 'admin/') === 0) { @@ -445,6 +482,24 @@ public function buildOptionsForm(&$form, FormStateInterface $form_state) { + if (str_starts_with($this->getOption('path') ?? '', 'admin/')) {
I think the path should be case-insensitive. eg,
/admin
,/Admin
or/ADMIN
etc. should use the administration theme automatically. Sostr_starts_with
should be replaced withstripos
above. And we need to add a test for this.NR for agreement.
- Status changed to Needs work
almost 2 years ago 6:04am 23 February 2023 - 🇺🇸United States dww
So excited this is so close to being done! Thanks to everyone who has moved it forward.
Alas #176 introduced a ton of irrelevant whitespace changes, and undesirable capitalization changes. Un-saving "credit" for the anti-contribution.
And #174 did some things to #171 that were not requested in #173 (like removing the
#title
of the form itself).I think we need to go back to the patch in #171, and carefully re-address #173 only.
I'm a bit torn on #179, but yeah, we should probably fix that, too. 😅
- Status changed to Needs review
almost 2 years ago 6:11am 23 February 2023 - 🇺🇸United States dww
- Status changed to Needs work
almost 2 years ago 6:20am 23 February 2023 - 🇫🇮Finland lauriii Finland
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -244,6 +248,27 @@ public function optionsSummary(&$categories, &$options) { + if (!empty($display_path) && stripos($display_path, 'admin/') === 0) {
I think
str_starts_with
is better because it's consistent with\Drupal\system\EventSubscriber\AdminRouteSubscriber::alterRoutes
. Can we change this too to usestr_starts_with
? - Assigned to dww
- Issue was unassigned.
- Status changed to Needs review
almost 2 years ago 6:36am 23 February 2023 - 🇺🇸United States dww
- 🇺🇸United States dww
(Side note: Did something with d.o CI change in the last 3 days, or does the bot not run the same checks for core committer patches as it does for the rest of us? 😂 @lauriii's patch in #171 has all the same CS bugs as #181, but the testbot flagged mine and wouldn't even test it, but ran the whole test suite for 171... weird)
- Assigned to dww
- Status changed to Needs work
almost 2 years ago 6:52am 23 February 2023 - 🇺🇸United States dww
-
+++ b/core/modules/views/src/Plugin/views/display/Page.php @@ -445,6 +469,20 @@ public function buildOptionsForm(&$form, FormStateInterface $form_state) { + $form['use_admin_theme']['#description'] = $this->t('Paths starting with "admin/" always use the administration theme.');
Just noticed a possible minor nit:
The code here is totally hard-coded. Do we want to let translators potentially change this? In some other UI strings, I've seen placeholders used to ensure that the path output is always what core wants. Do we care?
-
+++ b/core/modules/views/tests/src/Functional/Plugin/DisplayPageWebTest.php @@ -148,6 +148,37 @@ public function testPagePaths() { + public function testAdminTheme() {
Oh, and more uber-nit, doesn't this want
: void
? -
+++ b/core/modules/views_ui/tests/src/Functional/DisplayPathTest.php @@ -286,4 +288,56 @@ public function testDefaultMenuTabRegression() { + * Tests the "Always use the administration theme" configuration.
That's not what the UI label is, anymore... 😅
I'll clean up 2 and 3 while waiting for feedback on 1.
-
- Issue was unassigned.
- Status changed to Needs review
almost 2 years ago 6:56am 23 February 2023 - 🇺🇸United States dww
Argh, sorry for the noise! I spotted one more "Always" we don't want.
- 🇫🇮Finland lauriii Finland
@dww IMO providing a placeholder for the "admin/" part would be great! 👍
- Status changed to RTBC
almost 2 years ago 7:55am 23 February 2023 - 🇺🇸United States dww
Great, thanks! Fixed the summary and screenshots to reflect the current patch.
However, I noticed the draft CR is stale, with stale screenshots, "Always", etc. But it's almost 1am here now, so I'm just going to add the tag and hope someone else can handle that. ;)
Thanks again, excited to see this almost in core! 🎉🙏
-Derek - 🇺🇸United States dww
Hiding obsolete files and updating remaining tasks.
- Status changed to Fixed
almost 2 years ago 9:49am 23 February 2023 -
alexpott →
committed 4dbf3f46 on 10.1.x
Issue #2719797 by claudiu.cristea, dww, pfrenssen, smustgrave, saurabh-...
-
alexpott →
committed 4dbf3f46 on 10.1.x
- Status changed to Fixed
almost 2 years ago 7:59am 21 March 2023 Automatically closed - issue fixed for 2 weeks with no activity.