Created on 5 February 2025, about 2 months ago

Problem/Motivation

When you change a filter or change the page you're on, the entire existing set goes away (but not the pager or the results count), and then it pops in. This is a bit of a janky experience.

Steps to reproduce

Load the drupal.org contrib source plugin page, then change to page 2 (or change a filter).

Proposed resolution

Instead of immediately disappearing everything, "dim" the existing set and then replace it with the new set, scrolling to the top once loading is complete.

Feature request
Status

Active

Version

2.0

Component

User experience

Created by

🇺🇸United States chrisfromredfin Portland, Maine

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @chrisfromredfin
  • First commit to issue fork.
  • Merge request !734#3504655: UI enhancement → (Merged) created by omkar-pd
  • Pipeline finished with Canceled
    about 2 months ago
    Total: 96s
    #426470
  • Pipeline finished with Failed
    about 2 months ago
    Total: 504s
    #426472
  • Pipeline finished with Success
    about 2 months ago
    Total: 930s
    #426487
  • 🇮🇳India omkar-pd

    Raised PR with Proposed resolution.

  • 🇺🇸United States chrisfromredfin Portland, Maine
  • 🇮🇳India narendraR Jaipur, India

    Tested manually and observed that the page scrolls on initial load (when navigating to /admin/modules/browse/drupalorg_jsonapi, the page automatically scrolls to the list). This behaviour seems incorrect to me.

  • Pipeline finished with Canceled
    about 1 month ago
    Total: 814s
    #436154
  • Pipeline finished with Failed
    about 1 month ago
    Total: 1517s
    #436158
  • Pipeline finished with Failed
    about 1 month ago
    Total: 1326s
    #436190
  • Pipeline finished with Failed
    about 1 month ago
    Total: 1517s
    #436209
  • Pipeline finished with Skipped
    about 1 month ago
    #436237
  • Pipeline finished with Failed
    about 1 month ago
    Total: 1743s
    #436228
  • First commit to issue fork.
  • Pipeline finished with Failed
    30 days ago
    Total: 578s
    #441640
  • Pipeline finished with Failed
    30 days ago
    Total: 439s
    #441664
  • 🇮🇳India utkarsh_33

    All the tests that are failing are due to the extra wait that we need due to this change.I think this is not a good way.We might need something more robust here.Will try to find a better solution.
    Also @omkar-pd if you think you have any better approach inline with what you added it would be great if either you can suggest or push the fix related to what's mentioned in #6.

  • 🇮🇳India utkarsh_33

    I have pushed some changes that fixes tests.Most of the remaining tests can also be fixed in same manner, but i wonder if we really want to make changes in tests like this.I'll ask @phenaproxima about whether we want to do this.In the mean time if @omkar-pd has a better solution, then it's perfect.

  • Pipeline finished with Failed
    30 days ago
    Total: 487s
    #441760
  • 🇺🇸United States phenaproxima Massachusetts

    I do like the proposed resolution, although I think we should remove the bit that scrolls you directly to the projects, as @narendrar pointed out in #6. Let's just remove that outright.

    The test changes do make me a bit nervous, though -- we are, if I remember correctly, now bypassing all of these waits. I sorta wonder why this causes the tests to pass.

    This is frankly why I'd like to remove clickWithWait() and replace it with something better. Not yet sure what that would look like, though.

  • Pipeline finished with Failed
    29 days ago
    Total: 1693s
    #442457
  • Pipeline finished with Failed
    29 days ago
    Total: 583s
    #442509
  • Pipeline finished with Failed
    29 days ago
    Total: 400s
    #442531
  • Pipeline finished with Canceled
    29 days ago
    Total: 55s
    #442576
  • Pipeline finished with Failed
    29 days ago
    Total: 488s
    #442577
  • Pipeline finished with Failed
    29 days ago
    Total: 9040s
    #442590
  • Pipeline finished with Failed
    26 days ago
    Total: 489s
    #444400
  • Pipeline finished with Success
    26 days ago
    Total: 1904s
    #444407
  • Pipeline finished with Failed
    25 days ago
    Total: 401s
    #444962
  • 🇮🇳India utkarsh_33

    The tests are now passing.

  • 🇺🇸United States phenaproxima Massachusetts

    I dig this change. I think it increases the amount of polish - nice work.

    I gave it a quick manual test on a page with one instance of Project Browser, but didn't test it with multiple instances yet.

    The code looks reasonably straightforward but feels a little overcomplicated for what it's doing. It also needs more comments, and there appear to be out-of-scope test changes in there (which, to be honest, were probably introduced by me while I was fixing merge conflicts).

  • 🇺🇸United States phenaproxima Massachusetts

    Thanks for helping me analyze this, @utkarsh_33. 🙏

    I'm not entirely certain here. The current number of flags still feels somewhat...imprecise to me, and we need to keep the Svelte code as clean as we can because it is prone to messiness. :)

    I'd like to see what happens if we start removing flags.

  • 🇺🇸United States phenaproxima Massachusetts

    I realized, while reviewing this again, that one of the major reasons the code feels awkward is because it's taking place in ProjectGrid.svelte, which is totally disconnected from the loading code.

    Is there any chance we can move this stuff (mostly) into ProjectBrowser.svelte? It understands when loading is happening, and that, to me, feels like a much more natural place to call scrollIntoView().

  • Pipeline finished with Failed
    19 days ago
    Total: 532s
    #450083
  • Pipeline finished with Canceled
    19 days ago
    Total: 131s
    #450143
  • Pipeline finished with Failed
    19 days ago
    Total: 614s
    #450145
  • Pipeline finished with Failed
    19 days ago
    Total: 398s
    #450164
  • Pipeline finished with Success
    19 days ago
    Total: 457s
    #450170
  • 🇮🇳India narendraR Jaipur, India

    Changes done as suggested in #14

  • 🇺🇸United States phenaproxima Massachusetts

    This seems to work mostly as intended, with one problem: while the loading overlay is present, I can still interact with the Categories dropdown if it's open.

    I'm thinking the solution here is to ensure that the overlay sits, well, over the dropdown. z-index bug, maybe?

  • 🇺🇸United States phenaproxima Massachusetts

    Decided to fix the z-index bug myself; wasn't tricky.

    This is behaving rightly and looking good, and the code makes perfect sense. I think I'm happy with it.

  • 🇺🇸United States phenaproxima Massachusetts
  • Pipeline finished with Success
    18 days ago
    Total: 500s
    #450318
  • 🇮🇳India omkar-pd

    Tested this and it's working as expected. 🎉

  • Pipeline finished with Skipped
    18 days ago
    #450588
  • 🇺🇸United States chrisfromredfin Portland, Maine

    I've wanted this for so long; this is such a superior experience in such a subtle way.

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024