Modules uninstall filter does not filter by machine name

Created on 17 July 2017, over 7 years ago
Updated 9 January 2024, about 1 year ago

Problem/Motivation

When you visit /admin/modules/uninstall and search for a module machine_name, you will not find a result. The problem gets really visible, when you use modules where the module's machine_name differs from the human-readable name.

Examples in Core and Contrib:

  • Database Logging (dblog)
  • Chaos tools (ctools)

Especially in contrib we see more such examples, where also the module project page presents another name, as the human-readable name (see Chaos tool suite โ†’ , Configuration Update Manager โ†’ ).

Those inconsistencies let developers (when not using drush) to filter the module list by the module's machine_name. That is working fine at the module list, because the machine_name is part of the description, but not on the uninstall page).

Steps to reproduce the problem

Different behavior between the module list and uninstall module page.

Module list

  1. Go to /admin/modules
  2. Filter for dblog
  3. You'll see the "Database Logging" module

Uninstall module

  1. Go to /admin/modules/uninstall
  2. Filter for "dblog"
  3. You'll see no results

Proposed resolution

Make the filter by module machine_name working in the table at /admin/modules/uninstall.

Tasks

  • Decide, if it is a bug/feature request and/or should be fixed
  • DONE. Going to add machine name into a new details element.
    • NO. . Rejected because it takes up too much page space.
    • NO. . Presenting content to screen reader users but not to sighted users isn't inclusive design, rejected on accessibility grounds.
    • YES. Convert the description into a openable details element and add the machine name into it.
  • Update the system-modules-uninstall.html.twig template.
    • DONE. Add module machine name to template variables via preprocess hook.
    • DONE. Document the machine name variable in template docblock.
    • DONE. Convert description to a details element.
    • DONE. Add details machine name column to the new details element.
    • DONE. Add the show-all-columns feature. {{ attach_library('core/drupal.tableresponsive') }} in the form.
    • DONE. Make the description column responsive, by adding priority-low to match the install page.
    • DONE. Copy the template to Claro and adjust css classes to align with Claro install template.
    • DONE. Expand the javascript test to use the Claro theme in addition to the default, to test filtering on the new template.

User interface changes

Introduces a new machine name table column on the modules uninstall page. The machine name becomes searchable in the filter.
Make the uninstall table responsive, because the install page is already responsive.

Before

After - original solution

After - final solution

API changes

None

Data model changes

None

๐Ÿ› Bug report
Status

Needs work

Version

11.0 ๐Ÿ”ฅ

Component
Systemย  โ†’

Last updated 12 days ago

No maintainer
Created by

๐Ÿ‡ฉ๐Ÿ‡ชGermany szeidler Berlin

Live updates comments and jobs are added and updated live.
  • Accessibility

    It affects the ability of people with disabilities or special needs (such as blindness or color-blindness) to use Drupal.

Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • Status changed to Needs work about 2 years ago
  • Status changed to Needs review about 2 years ago
  • Status changed to RTBC about 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    One minor inconsistency I noticed (in code, not in functionality) is the way that the drupal.tableresponsive library is added. The Install page form already had $form['#attached']['library'][] = 'core/drupal.tableresponsive'; but this was missing from the uninstall form. It does not appear to be needed for manual interactive functioning of the filter, but it is required to allow the javascript tests to react to changing input. It was only when the uninstall form got it's first javascript test (in this issue) that the library was added. However, it was added via {{ attach_library('core/drupal.tableresponsive') }} in templates/system-modules-uninstall.html.twig

    So is there a preference for adding the library via the $form or via the twig template? Even if there is no preference, we should make the two consistent, so that we don't ask this question again. I inadvertantly also added the library to the uninstall $form in this MR (because I was working on ๐Ÿ› Uninstall form does not add drupal.tableresponsive library Closed: duplicate so we at least need to remove one of them as it is unnecessary to do it twice.

  • Status changed to Needs work about 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom alexpott ๐Ÿ‡ช๐Ÿ‡บ๐ŸŒ

    We need to resolve #73 before committing this.

  • Status changed to Needs review almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Thanks @alexpott. I have removed the attach from the twig template, and left it in the $form. This also matches what is in the install form.

  • Status changed to RTBC almost 2 years ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Retested following steps from #72

    Good job @jonathan1055!

  • Status changed to Needs review almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom alexpott ๐Ÿ‡ช๐Ÿ‡บ๐ŸŒ

    I've looked at the design of this and I'm not sure what was implemented in #11 is the best we can do. I think we should do what the install form does and add the machine name to the description so that it appears visually (unlike patches before which added it as hidden text).

    The machine name is not at all important when uninstalling a module - it's really only useful as something you might know to search for. Yet we're placing in in front of the description which can contain important things like why a module can not be uninstalled.

    Compare...

    With...

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    I agree with @alexpott. Adding the new column just to get the machine name on the page is not the best way to do it. It wastes a lot of screen space, meaning more scrolling, and shows duplicated info for 90% of the modules. This is an admin page, and making admin tasks quick to achieve is a primary goal. It seems from comments #10 and #11 that the decision to make it a new column was done for ease of coding. It's a backwards step in usability and we should be able to improve it to be more like the install page.

    In the first instance the machine name can be added into the description cell. In the longer term, we could have a details element, collapsed by default, to match the install page.

  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Moving to NW for that change then. Makes sense to me.

  • Assigned to jonathan1055
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Happy to give this a try, unless anyone else wants to do it? No need for more than one person to do duplicate work.

  • Status changed to Needs work almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Argh, unintentional change (stale-form data?). Back to NW

  • Issue was unassigned.
  • Status changed to Needs review almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    First draft. Based the details element on the install page. Themeing was OK but not looking quite right, then I realised that Claro has it's own custom twig template for the install page, so I also made one for the uninstall page.

    I puposely left the modified twig template indentation wrong on the first commit, so that it is eaaier to see which lines are changed and which have not been altered but merely indented.

    If/when this design change is accepted I will update the issue summary.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    The test failures were because I missed copying {{ form|without('filters', 'modules', 'uninstall') }} when creating the Claro template, which meant that the Uninstall button was not in the form. I based it on the install template, which does not have this. Interesting that it was only picked up by HelpTopicSearchTest which checks for uninstalling. Or maybe other tests use the system twig template? The HelpTopic test has protected $defaultTheme = 'stark' so I'm not sure why the Claro template was being used anyway. But lucky that it was, otherwise we would have have green passing tests for a major error in the code.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Are these test failures random and/or unrelated to the chnages in this MR?

    Failure 26 Jan 2023 at 01:46 GMT https://www.drupal.org/pift-ci-job/2576971 โ†’

    Drupal\Tests\ckeditor5\FunctionalJavascript\MediaLibraryTest::testButton
    Failed asserting that a NULL is not empty.
    

    Rebase against 10.1.x but no code changes on this MR, we get a different fail
    26 Jan 2023 at 11:28 GMT https://www.drupal.org/pift-ci-job/2577847 โ†’

    Drupal\Tests\ckeditor5\FunctionalJavascript\CKEditor5AllowedTagsTest::testMediaElementAllowedTags
    Behat\Mink\Exception\ElementNotFoundException: Form field with id|name|label|value "filters[media_embed][settings][allowed_view_modes][view_mode_2]" not found.
    

    Branch test at 26 Jan 2023 at 12:42 GMT passes OK.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    I think the failures here are unrelated because there was a branch test at 25 Jan 2023 at 11:48 GMT with the same failure in ests/src/FunctionalJavascript/CKEditor5AllowedTagsTest
    https://www.drupal.org/pift-ci-job/2576653 โ†’

  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    If theyโ€™re ckeditor5 functionalJavascript most likely random.

  • Status changed to Needs work almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Yes, either random or unrelated to this MR, core branch did have a failure ealier. Re-ran after new rebase and all passes here now.

    Are we in principle agreed that the expanding details element I added in #82 in response to @alexpott in #77 is the right solution? It works for me, but would be good to get confirmation as many others have looked at this issue before I started on it.

    I am going to expand the test coverage for the uninstall page to check the Claro template in addition to the system default, as it was only by luck that the HelpTopic tests used the Claro theme and tested uninstalling, which showed the error in my change.

  • Status changed to Needs review almost 2 years ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    I have expanded the test to cover Claro theme in addition to the default. This will fail, demonstrating that the Claro template needs work. Also attempting to run only the 'system' module tests temporarily, for speed and efficiency.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    As expected, we now have one test failure:

    There was 1 error:
    1) Drupal\Tests\system\Functional\Module\UninstallTest::testUninstallPage with data set #1 ('claro')
    Behat\Mink\Exception\ElementNotFoundException: Element matching css "tr[data-drupal-selector="edit-module-test"] .module-machine-name.table-filter-text-source" not found.
    

    This shows that the new claro template system-modules-uninstall.html.twig being tested when it was not before.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Tests now pass. Here are few other tweaks to the claro template, to make it align better with both the Claro install template, as I based the original template only on system uninstall. This is now ready for full review again.

  • Status changed to Needs work almost 2 years ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Functional this works like a charm.

    Searching for dynamic_page_cache I get nothing
    Apply the fix and not I get the module.

    Tagging for CR updates as there seems to be additional changes to the system template that others may need to adopt for their custom themes.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Updated the issue summary to match the solution.

  • ๐Ÿ‡จ๐Ÿ‡ฆCanada star-szr

    I made some updates to the change record but I haven't fully updated it as suggested in #91.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Thanks. The change record still refers to adding a new column, but that is not how the solution is. Since #77 the description is now a details element, collapsed by default, but expandable to show machine name and requirements, similar to what is done on the install page.

    Sorry I can't update the change record right now, happy for someone else to do it, or I will next week.

  • last update almost 2 years ago
    Custom Commands Failed
  • last update almost 2 years ago
    Custom Commands Failed
  • 2:13
    1:20
    Running
  • Pipeline finished with Skipped
    over 1 year ago
    #19966
  • last update over 1 year ago
    29,479 pass
  • Pipeline finished with Skipped
    over 1 year ago
    #19967
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    @jonathan1055 can you update the MR for 11.x

  • Pipeline finished with Success
    about 1 year ago
    Total: 825s
    #52071
  • Pipeline finished with Failed
    about 1 year ago
    Total: 209s
    #53363
  • Pipeline finished with Success
    about 1 year ago
    Total: 785s
    #53356
  • Pipeline finished with Success
    about 1 year ago
    #53418
  • Pipeline finished with Canceled
    about 1 year ago
    Total: 9s
    #53421
  • Pipeline finished with Success
    about 1 year ago
    Total: 715s
    #53422
  • Pipeline finished with Success
    about 1 year ago
    Total: 587s
    #54743
  • Pipeline finished with Failed
    about 1 year ago
    Total: 3015590s
    #56649
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    The tests on MR 3273 were OK but now we get one failure
    https://git.drupalcode.org/issue/drupal-2895388/-/jobs/564727#L1443

    Drupal\Tests\media_library\FunctionalJavascript\WidgetViewsTest::testWidgetViews
        "Loading grid view." not found
        Failed asserting that a boolean is not empty.
    

    Is this related, or some other problem?

  • Pipeline finished with Failed
    about 1 year ago
    Total: 162s
    #71090
  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia Akhil Babu Chengannur

    Akhil Babu โ†’ made their first commit to this issueโ€™s fork.

  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia Akhil Babu Chengannur

    Akhil Babu โ†’ changed the visibility of the branch 11.x to hidden.

  • Pipeline finished with Failed
    about 1 year ago
    Total: 183s
    #73516
  • Pipeline finished with Canceled
    about 1 year ago
    Total: 229s
    #73520
  • Pipeline finished with Success
    about 1 year ago
    #73523
  • Status changed to Needs review about 1 year ago
  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia Akhil Babu Chengannur

    I have created a new MR against 11.x along with some minor coding standard fixes. Also, upon reviewing the changes,
    description table header of core/modules/system/templates/system-modules-uninstall.html.twig uses the priority-medium class while core/themes/claro/templates/admin/system-modules-uninstall.html.twig uses priority-low class. Was this intentional, or was it just a mistake?

  • Pipeline finished with Success
    about 1 year ago
    #73534
  • Pipeline finished with Failed
    about 1 year ago
    Total: 165s
    #73593
  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Multiple MRs not sure what's to be reviewed. Should have 1 MR visible or specify which is the one to be reviewed.

  • Pipeline finished with Success
    about 1 year ago
    #73644
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    jonathan1055 โ†’ changed the visibility of the branch 2895388-uninstall-machine-name-filter to hidden.

  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    I have hidden MR3273 as that was the original one, on 10.1.x so will not be committed.

    @Akhil Babu, can you confim that your first commit on the new MR 6065 is exactly the same as was on the 10.2 MR?

  • ๐Ÿ‡ฎ๐Ÿ‡ณIndia Akhil Babu Chengannur

    @jonathan1055 Yes, The first commit in 6065 has all the changes from MR 5496. The next 2 commits are for coding standard fixes.

  • Status changed to Needs review about 1 year ago
  • ๐Ÿ‡ฌ๐Ÿ‡งUnited Kingdom jonathan1055

    Thanks @Akhil Babu, it looked like that, but better to ask the person who actually did it.

    Your quesion in #102

    description table header of core/modules/system/templates/system-modules-uninstall.html.twig uses the priority-medium class, while core/themes/claro/templates/admin/system-modules-uninstall.html.twig uses priority-low class. Was this intentional, or was it just a mistake?

    I recall that it was difficult to decide which template to base the new one. Should the Claro uninstall match the Claro install or the System Uninstall? I used priority-low because Claro install had that. My thinking was that it was more important to be consistent with Claro, rather than between the two uninstall templates. But happy to change it if that was the wrong decision.

  • Status changed to Needs work about 1 year ago
  • ๐Ÿ‡บ๐Ÿ‡ธUnited States smustgrave

    Moving to NW for change record updates.

    Also believe we need a template for some of the other themes, stable9, maybe starterkit (not 100% on that).

  • Pipeline finished with Success
    6 months ago
    #248055
Production build 0.71.5 2024