diff --git a/src/platform/StackedRouter.tsx b/src/platform/StackedRouter.tsx index df3d522..fbfc713 100644 --- a/src/platform/StackedRouter.tsx +++ b/src/platform/StackedRouter.tsx @@ -15,6 +15,8 @@ import { useContext, onCleanup, type Accessor, + useTransition, + getOwner, } from "solid-js"; import { createStore, unwrap } from "solid-js/store"; import "./StackedRouter.css"; @@ -79,8 +81,8 @@ export type NewFrameOptions = (T extends undefined export type FramePusher = T[K] extends | undefined | any - ? (path: K, state?: Readonly>) => Readonly - : (path: K, state: Readonly>) => Readonly; + ? (path: K, state?: Readonly>) => Promise> + : (path: K, state: Readonly>) => Promise>; export type Navigator> = { frames: readonly StackFrame[]; @@ -465,6 +467,8 @@ const StackedRouter: Component = (oprops) => { const [stack, mutStack] = createStore([] as StackFrame[], { name: "stack" }); const windowSize = useWindowSize(); + const [, startTransition] = useTransition(); + if (import.meta.hot) { const saveStack = () => { import.meta.hot!.data[$StackedRouterSavedStack] = unwrap(stack); @@ -488,8 +492,8 @@ const StackedRouter: Component = (oprops) => { }); } - const pushFrame = (path: string, opts?: Readonly>) => - untrack(() => { + const pushFrame = async (path: string, opts?: Readonly>) => + await untrack(async () => { const frame = { path, state: opts?.state, @@ -499,14 +503,17 @@ const StackedRouter: Component = (oprops) => { }; const replace = opts?.replace; - if (replace === "all" || stack.length === 0) { - mutStack([frame]); - } else if (replace) { - const idx = stack.length - 1; - mutStack(idx, frame); - } else { - mutStack(stack.length, frame); - } + const length = stack.length; + await startTransition(() => { + if (replace === "all" || length === 0) { + mutStack([frame]); + } else if (replace) { + const idx = length - 1; + mutStack(idx, frame); + } else { + mutStack(length, frame); + } + }); const savedStack = serializableStack(stack); @@ -515,6 +522,7 @@ const StackedRouter: Component = (oprops) => { } else { window.history.pushState(savedStack, "", path); } + return frame; });