[PP-1] The install queue should be tolerant of page refreshes

Created on 4 October 2024, 6 months ago

Problem/Motivation

✨ GUI install multiple modules at once. Needs work is adding the ability to choose multiple projects at once and install them in a single batch. The only problem is that it's not refresh-tolerant. If you refresh the page, you don't know an install is in progress, until you try to select more things and install them. When you do that, you get an error that the stage is already locked. Not exactly the greatest user experience!

To be clear, this is not something that was introduced by ✨ GUI install multiple modules at once. Needs work ; it's the existing behavior in HEAD, a holdover from when projects had to be installed one at a time. But it's not really what we want.

Proposed resolution

If you kick off an install queue and you refresh the page, the UI should be able to figure out where you left off. This probably means that the current state of the install queue needs to be sent to the page in drupalSettings, then loaded into Svelte's memory space and dynamically updated as the install process proceeds, triggering re-renders (ideally only project-by-project) as necessary.

✨ Feature request
Status

Postponed

Version

2.0

Component

User experience

Created by

πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

Live updates comments and jobs are added and updated live.
  • Starshot blocker

    A potential blocker for Drupal Starshot. More information: http://www.drupal.org/project/starshot

Sign in to follow issues

Comments & Activities

  • Issue created by @phenaproxima
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    Ready to go!

  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    This probably means that the current state of the install queue needs to be sent to the page in drupalSettings

    I think this means we should move the state of the installations (basically, whatever's in \Drupal\project_browser\Controller\InstallerController::setRequiringState()) into its own service, then inject that service into the ProjectBrowser element so it can add everything to the drupalSettings object.

  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine
  • πŸ‡¦πŸ‡ΊAustralia pameeela
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    This isn't a stable blocker for Drupal CMS. It might be a stable blocker for Project Browser, but given the way Drupal CMS intends to expose Project Browser (based on the designs I've seen most recently), it's not a blocker for us.

  • Status changed to Active about 1 month ago
  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    I'd like to advocate for not making this a beta blocker. It shouldn't change our PHP API, and the Svelte code is internal, so although this would be a UX improvement, it could surely be a post-beta feature.

  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    Are there any rules around changing any "JavaScript APIs" for beta for Drupal? This probably got marked beta as a "boy it would be nice" so I'm ok downing it. I'm just gunshy over "API changes" - if we only care about the PHP API, then I'm comfortable because I'm sure most if not all of this solution is on the Svelte side.

  • πŸ‡ΊπŸ‡ΈUnited States phenaproxima Massachusetts

    The Svelte code is not an API, full stop. There is no way that I'm aware of for any external code to extend or integrate with it. All of the API exists on the PHP side.

    So we can change the frontend whenever we want.

  • πŸ‡ΊπŸ‡ΈUnited States chrisfromredfin Portland, Maine

    After discussing APIs with Adam on Zoom, I think this can safely move to stable blocking. I do consider it a shortcoming that we can't be tolerant, but after looking at all the APIs and where they _might_ change as a result of implementing this, we don't think there's any breakage--if anything, just possibly an addition, if at all.

    So I'm re-triaging to stable blocking.

Production build 0.71.5 2024