-
Notifications
You must be signed in to change notification settings - Fork 326
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Provide UI feedback during Git command execution #630
Conversation
@kgryte I like the animation but it should definitely not block the all application. For all softwares I know that integrate VCS, none is blocking the UI when carrying out git commands. And this is clearly what I would expect from this extension (for instance I hate the current modal for pulling and pushing that block me on background synchronization tasks). Therefore the overlay should not expand outside of the Git panel. But then come the question, what if the panel is hidden. So I endorse too the idea of having feedback thanks to the status bar. |
…into ui-feedback
I am not convinced this is an entirely good idea, as why bother with a blocking modal at all if a user can dismiss. The main hope is that less technical users will simply respect the modal and wait until completion before moving on. The risk is that users will catch on and disregard the warning, allowing for potential footguns. However, reviewers appear hostile to a blocking modal which cannot be readily dismissed.
@kgryte I tried it out and this PR causes me to be unable to commit: Otherwise I've really come around to it. It looks nice and the removal of footguns is definitely positive. 2
makes sense. This actually made me realize that I miss having any feedback when I refresh the jupyterlab filebrowser. 3 4 |
@ianhi Thanks for trying it out! Will investigate the issues you mentioned above and circle back. |
One other thought that may have a bad hassle/benefit ratio: Could the modal be made to display only after the command has been running for some time that is short for humans but long for computers? i.e:
The idea being to maintain protection against conflicting commands while reducing visual interruption. Though maybe this would just have the effect of making the extension seem laggy which I think would be worse. |
|
For those interested, here is a Binder link for viewing the changes proposed in this PR: https://mybinder.org/v2/gh/kgryte/jupyterlab-git/ui-feedback?urlpath=lab/tree/examples/demo.ipynb |
@telamonian Should be ready for review now that the commit bug is resolved. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @kgryte for this big, yet modular 😉, work.
I only have one concern with this change. Up-to now, the model has close to a service for git commands. But with this, this is definitely no more the case as it increases the link with the UI.
So it would be nice to extract a service for the git commands after this is merged.
As example of the need for a service, I can point to that repository: https://github.com/fcollonval/jupyter-project
@fcollonval Thanks for the review! Re: model-UI coupling. I don't believe these are more coupled than before this PR. The PR simply adds "logging" which could be directed to a file, to a UI, or to anywhere. The model is still decoupled; the change introduced by this PR is simply to afford model consumers the opportunity to listen in on what the model is doing if they so choose. Here, the PR opts to take the information and bubble up to the end user, but this is not required. In general, there has been a long standing request by our clients to provide more insight into what the Git extension is doing when performing various operations/tasks. This PR simply moves us a couple steps in that direction. :) |
@fcollonval Should be good to go! |
@telamonian @fcollonval Are we able to move forward with this PR? :) |
I'm working on this one to rebase and merge. Sorry for the delay @kgryte. |
commit 1c2cb43 Author: Frederic Collonval <[email protected]> Date: Fri Jul 24 18:24:42 2020 +0200 Post Merge branch 'master' corrections commit 5ec36d7 Author: Frederic Collonval <[email protected]> Date: Fri Jul 24 17:41:07 2020 +0200 Merge with master commit ae71d8d Author: Athan Reines <[email protected]> Date: Sun Jun 14 23:30:28 2020 -0700 Use finally blocks commit 2cd0408 Author: Athan Reines <[email protected]> Date: Sun Jun 14 23:21:23 2020 -0700 Reorder properties and methods commit 9f2d7ca Author: Athan Reines <[email protected]> Date: Mon Jun 8 11:08:57 2020 -0700 Fix response consumption bug commit e5d86d7 Merge: cab4132 6169af0 Author: Athan Reines <[email protected]> Date: Mon Jun 8 10:33:38 2020 -0700 Merge branch 'master' of https://github.com/jupyterlab/jupyterlab-git into ui-feedback commit cab4132 Author: Athan Reines <[email protected]> Date: Mon Jun 1 03:30:55 2020 -0700 Fix broken tests commit c4f0813 Author: Athan Reines <[email protected]> Date: Mon Jun 1 03:30:02 2020 -0700 Fix broken tests commit c132ced Author: Athan Reines <[email protected]> Date: Mon Jun 1 03:06:07 2020 -0700 Add private annotation commit 28be7d5 Author: Athan Reines <[email protected]> Date: Mon Jun 1 03:04:40 2020 -0700 Reorder methods commit f2d40d8 Author: Athan Reines <[email protected]> Date: Mon Jun 1 02:57:31 2020 -0700 Refactor to support UI feedback commit b4d5513 Author: Athan Reines <[email protected]> Date: Mon Jun 1 02:22:26 2020 -0700 Fix broken test commit ab68b01 Author: Athan Reines <[email protected]> Date: Mon Jun 1 02:13:36 2020 -0700 Refactor to support toast alerts commit 99d6766 Author: Athan Reines <[email protected]> Date: Mon Jun 1 02:00:47 2020 -0700 Refactor to support toast alerts commit b1d79d6 Merge: 3daf4ba 8e79eae Author: Athan Reines <[email protected]> Date: Mon Jun 1 01:44:23 2020 -0700 Merge branch 'master' of https://github.com/jupyterlab/jupyterlab-git into ui-feedback commit 3daf4ba Author: Athan Reines <[email protected]> Date: Mon Jun 1 01:33:04 2020 -0700 Refactor to support log message alerts commit 2d48dda Author: Athan Reines <[email protected]> Date: Mon Jun 1 01:18:06 2020 -0700 Rename file and refactor into smaller components to support toasts commit d203738 Author: Athan Reines <[email protected]> Date: Wed May 27 16:11:15 2020 -0700 Refactor to use "toast" notifications commit 1d5c364 Author: Athan Reines <[email protected]> Date: Wed May 27 16:10:17 2020 -0700 Add Material UI dep for displaying alert messages within toast notifications commit e0e6a5e Author: Athan Reines <[email protected]> Date: Wed May 27 13:34:04 2020 -0700 Add support for providing UI feedback when committing changes commit bf5c52a Author: Athan Reines <[email protected]> Date: Wed May 27 10:42:28 2020 -0700 Fix broken tests commit 4d84996 Author: Athan Reines <[email protected]> Date: Wed May 27 10:40:37 2020 -0700 Add src documentation and rename variables to be in line with project conventions commit 018444b Author: Athan Reines <[email protected]> Date: Tue May 26 17:57:08 2020 -0700 Fix broken tests commit 29b9917 Author: Athan Reines <[email protected]> Date: Tue May 26 17:54:23 2020 -0700 Add support for providing feedback when creating a new branch and refactor error handling commit 126389f Author: Athan Reines <[email protected]> Date: Tue May 26 17:13:08 2020 -0700 Provide UI feedback when switching branches commit b1ec725 Author: Athan Reines <[email protected]> Date: Tue May 26 16:01:19 2020 -0700 Add backticks commit fc2edb0 Merge: 62d88de c34abef Author: Athan Reines <[email protected]> Date: Tue May 26 15:55:28 2020 -0700 Merge branch 'master' of https://github.com/jupyterlab/jupyterlab-git into ui-feedback commit 62d88de Author: Athan Reines <[email protected]> Date: Tue May 26 15:41:25 2020 -0700 Document function commit 1596dee Author: Athan Reines <[email protected]> Date: Tue May 26 15:39:47 2020 -0700 Remove console.log commit 697bab8 Author: Athan Reines <[email protected]> Date: Tue May 26 15:32:06 2020 -0700 Add support for toggling display of status bar updates commit 2b9da5e Author: Athan Reines <[email protected]> Date: Tue May 26 14:45:30 2020 -0700 Add setting to toggle status bar updates commit c51a449 Author: Athan Reines <[email protected]> Date: Mon May 18 22:00:56 2020 -0700 Allow the user to dismiss the modal I am not convinced this is an entirely good idea, as why bother with a blocking modal at all if a user can dismiss. The main hope is that less technical users will simply respect the modal and wait until completion before moving on. The risk is that users will catch on and disregard the warning, allowing for potential footguns. However, reviewers appear hostile to a blocking modal which cannot be readily dismissed. commit b0a1c44 Author: Athan Reines <[email protected]> Date: Mon May 18 21:48:45 2020 -0700 Fix operation order bug commit 062a2a1 Author: Athan Reines <[email protected]> Date: Mon May 18 21:40:06 2020 -0700 Move status widget to separate file and add widget style commit c34c33e Author: Athan Reines <[email protected]> Date: Mon May 18 21:22:16 2020 -0700 Update lockfile commit 5576d73 Author: Athan Reines <[email protected]> Date: Mon May 18 21:20:55 2020 -0700 Restore prior refresh status behavior when non-200 response commit 6bdba11 Author: Athan Reines <[email protected]> Date: Mon May 18 21:06:44 2020 -0700 Throttle status widget to prevent flashing updates commit cf3d9ac Author: Athan Reines <[email protected]> Date: Mon May 18 19:57:07 2020 -0700 Update task names and map log events to status messages commit 8d471f4 Author: Athan Reines <[email protected]> Date: Mon May 18 19:29:12 2020 -0700 Fix task queue management commit ccbfb70 Author: Athan Reines <[email protected]> Date: Mon May 18 18:29:02 2020 -0700 Add lumino collections dependency commit 2f155e5 Author: Athan Reines <[email protected]> Date: Mon May 18 18:28:25 2020 -0700 Refactor and clean-up the extension model commit d373478 Author: Athan Reines <[email protected]> Date: Mon May 18 11:26:12 2020 -0700 Wire up model event logging commit 3b3b915 Author: Athan Reines <[email protected]> Date: Mon May 18 11:12:57 2020 -0700 Fix capitalization commit 0169c2a Merge: a579a42 e923a5b Author: Athan Reines <[email protected]> Date: Mon May 18 00:51:45 2020 -0700 Merge branch 'master' of https://github.com/jupyterlab/jupyterlab-git into ui-feedback commit a579a42 Author: Athan Reines <[email protected]> Date: Mon May 18 00:50:59 2020 -0700 Fix capitalization commit 71442cb Author: Athan Reines <[email protected]> Date: Mon May 18 00:48:38 2020 -0700 Fix capitalization commit f3e25ec Author: Athan Reines <[email protected]> Date: Mon May 18 00:32:52 2020 -0700 Fix broken tests commit f58b51f Author: Athan Reines <[email protected]> Date: Mon May 18 00:23:45 2020 -0700 Toggle UI suspension based on plugin setting commit 6a93b34 Author: Athan Reines <[email protected]> Date: Mon May 18 00:23:05 2020 -0700 Update setting description commit 1e36470 Author: Athan Reines <[email protected]> Date: Mon May 18 00:22:24 2020 -0700 Update description commit 4437e60 Author: Athan Reines <[email protected]> Date: Mon May 11 11:22:06 2020 -0700 Document new setting commit 1bace21 Author: Athan Reines <[email protected]> Date: Mon May 11 11:20:34 2020 -0700 Document setting commit da2ec0e Author: Athan Reines <[email protected]> Date: Mon May 11 11:18:38 2020 -0700 Add setting for toggling UI suspension commit 4ced5a8 Author: Athan Reines <[email protected]> Date: Mon May 4 14:50:46 2020 -0700 Ensure a minimum duration commit 06300ff Author: Athan Reines <[email protected]> Date: Thu Apr 30 16:50:32 2020 -0700 Add UI feedback during toolbar actions
Merged manually in dafc400 |
Thanks @fcollonval! |
…11.x Backport PR #630 UI feedback of Git execution
Resolves #601 by providing UI feedback during Git command execution.
Overview
This PR
introduces an overlay over the JupyterLab window during the execution of the following Git UI actions:
cleans up the Git extension model by adding documentation, refactoring HTTP request handling to avoid error trapping, and instrumenting model actions to surface events which can then be shown in the JupyterLab status bar.
modifies error handling when creating a branch to allow displaying error messages directly in the new branch dialog.
adds two new extension settings to allow for customized extension behavior concerning UI suspension and status updates. This allows power users to configure extension behavior to their liking.
adds React components for displaying a blocking modal and toast notifications.
adds a status widget for displaying Git status updates in the JupyterLab status bar.
performs additional minor clean-up and documentation.
This PR addresses the fact that Git actions are executed asynchronously and such behavior can result in unexpected and undesired behavior.
For example, a user could attempt to push changes to a remote server. Currently, the UI only provides feedback upon receiving a response. If a user closes JupyterLab before receiving an error response, a user could walk away believing that her changes were successfully pushed. By blocking the UI and displaying a prominent status indicator, we encourage users to wait before further action, including closing JupyterLab.
Especially given the changes introduced in #564 where a server may not respond for several seconds while waiting for
index.lock
files to be removed, visual feedback indicating that actions are in-progress is critical in avoiding scenarios where work is lost (e.g., a commit fails unbeknown to the user, changes are overwritten upon pull) or conflicts arise (e.g., a merge action is submitted, changes are made, and a merge action resolves, resulting in conflicts).For example, consider the scenario where a user attempts to commit changes. Suppose the command takes 20s due to Git hooks and the command fails. During interim, the user makes changes and initiates another commit. What happens? Currently, we simply move on to the next queued command. However, a user may want to have first resolved the hook failures (e.g., linting) before executing the next commit. In fact, sometimes, you want something in history (for posterity's sake), but then want to "undo" the change subsequently. So if I commit something I want in history, it fails, but my subsequent commit succeeds, now my history is messed up. In short, we simplify everything, and reduce extension complexity, by forcing sequential operations. Otherwise, a user needs to be able to interrupt a queue, canceling any pending operations after a failure.
By blocking the UI, we effectively force the user to slow down (albeit in minor, if any, manor and without much annoyance, depending on connection speed, etc) to allow commands to fully execute before making and initiating further changes and actions.
To be clear, forcing sequential operation is likely to not be a hindrance for local development or for users on fast networks.
Screenshots
Notes
Other UI feedback mechanisms considered:
git pull
), then, on pull, unsaved changes could be overwritten (and thus lost) or a merge conflict could arise which would not have arisen had the user waited until the pull was complete.Demo
Here is a Binder link for the changes proposed in this PR: https://mybinder.org/v2/gh/kgryte/jupyterlab-git/ui-feedback?filepath=examples%2Fdemo.ipynb
.