Bug #18972
closed
"All processes" view reloading flicker
Added by Peter Amstutz almost 3 years ago.
Updated over 2 years ago.
Estimated time:
(Total: 0.00 h)
Release relationship:
Auto
Description
When processes are being updated, it triggers an automatic refresh of the "all processes" view. Unfortunately because it clears the content when it starts a reload, it is rapidly flickering back and forth between the content and "Loading data please wait" which makes it almost unusable.
"All processes" should not show "loading data please wait" when auto-refresh is triggered, it should just replace the contents.
Files
- Description updated (diff)
- Related to Bug #18207: Workbench2 is not clearing the project content when switching added
- Target version changed from 2022-04-27 Sprint to 2022-04-13 Sprint
- Status changed from New to In Progress
- Assigned To set to Lucas Di Pentima
Updates at arvados-workbench2|20acf4ed - branch 18972-all-procs-flickering-fix
- Avoids the DataTable component to show a "loading" indication when the route didn't change. Attached video for easier confirmation.
- The loading indication should be still visible when navigating through a project hierarchy, for example.
Lucas Di Pentima wrote:
Updates at arvados-workbench2|20acf4ed - branch 18972-all-procs-flickering-fix
- Avoids the DataTable component to show a "loading" indication when the route didn't change. Attached video for easier confirmation.
- The loading indication should be still visible when navigating through a project hierarchy, for example.
This re-introduces a previous issue where you could hit the refresh button, but then because there isn't clear feedback that the refresh has completed, you go to try and click on something in the list, but the list contents changes underneath your mouse pointer, and you click on the wrong thing.
Could we make it so that when you hit the refresh button explicitly, it still clears the data table?
Peter Amstutz wrote:
This re-introduces a previous issue where you could hit the refresh button, but then because there isn't clear feedback that the refresh has completed, you go to try and click on something in the list, but the list contents changes underneath your mouse pointer, and you click on the wrong thing.
Could we make it so that when you hit the refresh button explicitly, it still clears the data table?
I didn't addressed the Refresh button case because I understood that the issue was when the user navigates through projects.
Updates at arvados-workbench2|f8033266 now make the Refresh button record its latest click timestamp on the localStorage so that any interested party could check if it changed from the last render and act upon it as necessary.
Lucas Di Pentima wrote:
Peter Amstutz wrote:
This re-introduces a previous issue where you could hit the refresh button, but then because there isn't clear feedback that the refresh has completed, you go to try and click on something in the list, but the list contents changes underneath your mouse pointer, and you click on the wrong thing.
Could we make it so that when you hit the refresh button explicitly, it still clears the data table?
I didn't addressed the Refresh button case because I understood that the issue was when the user navigates through projects.
It actually even came up in cypress testing, there was a test that used the refresh button, then immediately tried to click on something in the list and the list contents would get replaced underneath it and cause the click to open on the wrong list item.
Updates at arvados-workbench2|f8033266 now make the Refresh button record its latest click timestamp on the localStorage so that any interested party could check if it changed from the last render and act upon it as necessary.
Using global variables in data-explorer.tsx feels a little dodgy, should this be done through redux? Looks like Danny introduced the globals in 18207.
- Target version changed from 2022-04-13 Sprint to 2022-04-27 Sprint
Rebased updates at arvados-workbench2|9858ad74 - developer-tests-workbench2: #666
Reimplements the "loading..." indicator behavior by using local state at the DataExplorer
component. External dependencies (on Router & RefreshButton) are kept in the view component and passed down as optional props.
Lucas Di Pentima wrote:
Rebased updates at arvados-workbench2|9858ad74 - developer-tests-workbench2: #666
Reimplements the "loading..." indicator behavior by using local state at the DataExplorer
component. External dependencies (on Router & RefreshButton) are kept in the view component and passed down as optional props.
I agree, keeping it as part of the data table state is much cleaner.
This LGTM!
- Status changed from In Progress to Resolved
Also available in: Atom
PDF