Skip to content
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

Global view transitions for history restore #2873

Open
wants to merge 1 commit into
base: dev
Choose a base branch
from

Conversation

davidwilde
Copy link

@davidwilde davidwilde commented Sep 5, 2024

Description

I added ViewTransitions to the restoreHistory function. In this pull request I only made this change when the user has enabled htmx.config.globalViewTransitions. This is as a PR for opening a discussion on this as anything else as I have some questions to the best approach for this work.

Screen.Recording.2024-09-06.at.12.05.21.mov

I understand that because this not a either a bugfix, a documentation update, or a new feature that has been explicitly approved via an issue. I apologise as I only saw those particular guideline

Questions

  1. Should this have its own config flag to enable this behavior? Potentially this is breaking expectations by adding this to navigating history. Is adding this under globalViewTransitions sensible here? Maybe a config flag like htmx.config.historyViewTransitions?
  2. Should a htmx:beforeTransition event be thrown?

Idea

During development of this I had an idea but I thought it would be too big a PR and I wanted to start this initial discussion first, but I considered that it could be possible to add a transition flag into the history. This would be caught from the hx-swap of each request and mean that requests which updated the history, would also be able to play back the transition even without globalViewTransitions needing to be set (but then htmx.config.historyViewTransitions would make more sense)

Corresponding issue:

#1703

Testing

I tested this manually, switching on and off the htmx.config.globalViewTransitions flag. I ran the test suite locally and the linting rules

Checklist

  • I have read the contribution guidelines
  • I have targeted this PR against the correct branch (master for website changes, dev for
    source changes)
  • This is either a bugfix, a documentation update, or a new feature that has been explicitly
    approved via an issue
  • I ran the test suite locally (npm run test) and verified that it succeeded

The view transitions are added when the user navigates back and forth
through the history for configs that have enabled globalViewTransitions.
@davidwilde davidwilde changed the base branch from master to dev September 5, 2024 21:31
@pokonski
Copy link
Contributor

pokonski commented Sep 22, 2024

This would be great to have as currently navigating back is jarring compared to navigating forward

Should this have its own config flag to enable this behavior?

Not a decision maker but I guess that's the safest way to not change the behaviour for current users

restoreHistoryFromCache = document.startViewTransition(
() => innerRestoreHistoryFromCache()
)
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since there is no potential delay here I think this be an if/else instead of wrapping the restoreHistoryFromCache function: pass it directly to startViewTransition else invoke it

}
const shouldTransition = htmx.config.globalViewTransitions
if (shouldTransition &&
// @ts-ignore experimental feature atm
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should probably trigger the htmx:beforeTransition event to allow users to cancel if they want to, see the other place where we are using the Vue transitions API:

... && triggerEvent(elt, 'htmx:beforeTransition', responseInfo) && ...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants