@rangojs/router 0.0.0-experimental.19 → 0.0.0-experimental.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__internal.d.ts +83 -0
- package/dist/__internal.d.ts.map +1 -0
- package/dist/__internal.js +19 -0
- package/dist/__internal.js.map +1 -0
- package/dist/__mocks__/version.d.ts +7 -0
- package/dist/__mocks__/version.d.ts.map +1 -0
- package/dist/__mocks__/version.js +7 -0
- package/dist/__mocks__/version.js.map +1 -0
- package/dist/__tests__/client-href.test.d.ts +2 -0
- package/dist/__tests__/client-href.test.d.ts.map +1 -0
- package/dist/__tests__/client-href.test.js +74 -0
- package/dist/__tests__/client-href.test.js.map +1 -0
- package/dist/__tests__/component-utils.test.d.ts +2 -0
- package/dist/__tests__/component-utils.test.d.ts.map +1 -0
- package/dist/__tests__/component-utils.test.js +51 -0
- package/dist/__tests__/component-utils.test.js.map +1 -0
- package/dist/__tests__/event-controller.test.d.ts +2 -0
- package/dist/__tests__/event-controller.test.d.ts.map +1 -0
- package/dist/__tests__/event-controller.test.js +538 -0
- package/dist/__tests__/event-controller.test.js.map +1 -0
- package/dist/__tests__/helpers/route-tree.d.ts +118 -0
- package/dist/__tests__/helpers/route-tree.d.ts.map +1 -0
- package/dist/__tests__/helpers/route-tree.js +374 -0
- package/dist/__tests__/helpers/route-tree.js.map +1 -0
- package/dist/__tests__/match-result.test.d.ts +2 -0
- package/dist/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/__tests__/match-result.test.js +154 -0
- package/dist/__tests__/match-result.test.js.map +1 -0
- package/dist/__tests__/navigation-store.test.d.ts +2 -0
- package/dist/__tests__/navigation-store.test.d.ts.map +1 -0
- package/dist/__tests__/navigation-store.test.js +440 -0
- package/dist/__tests__/navigation-store.test.js.map +1 -0
- package/dist/__tests__/partial-update.test.d.ts +2 -0
- package/dist/__tests__/partial-update.test.d.ts.map +1 -0
- package/dist/__tests__/partial-update.test.js +1009 -0
- package/dist/__tests__/partial-update.test.js.map +1 -0
- package/dist/__tests__/reverse-types.test.d.ts +8 -0
- package/dist/__tests__/reverse-types.test.d.ts.map +1 -0
- package/dist/__tests__/reverse-types.test.js +656 -0
- package/dist/__tests__/reverse-types.test.js.map +1 -0
- package/dist/__tests__/route-definition.test.d.ts +2 -0
- package/dist/__tests__/route-definition.test.d.ts.map +1 -0
- package/dist/__tests__/route-definition.test.js +55 -0
- package/dist/__tests__/route-definition.test.js.map +1 -0
- package/dist/__tests__/router-helpers.test.d.ts +2 -0
- package/dist/__tests__/router-helpers.test.d.ts.map +1 -0
- package/dist/__tests__/router-helpers.test.js +377 -0
- package/dist/__tests__/router-helpers.test.js.map +1 -0
- package/dist/__tests__/router-integration-2.test.d.ts +2 -0
- package/dist/__tests__/router-integration-2.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration-2.test.js +426 -0
- package/dist/__tests__/router-integration-2.test.js.map +1 -0
- package/dist/__tests__/router-integration.test.d.ts +2 -0
- package/dist/__tests__/router-integration.test.d.ts.map +1 -0
- package/dist/__tests__/router-integration.test.js +1051 -0
- package/dist/__tests__/router-integration.test.js.map +1 -0
- package/dist/__tests__/search-params.test.d.ts +5 -0
- package/dist/__tests__/search-params.test.d.ts.map +1 -0
- package/dist/__tests__/search-params.test.js +306 -0
- package/dist/__tests__/search-params.test.js.map +1 -0
- package/dist/__tests__/segment-system.test.d.ts +2 -0
- package/dist/__tests__/segment-system.test.d.ts.map +1 -0
- package/dist/__tests__/segment-system.test.js +627 -0
- package/dist/__tests__/segment-system.test.js.map +1 -0
- package/dist/__tests__/static-handler-types.test.d.ts +8 -0
- package/dist/__tests__/static-handler-types.test.d.ts.map +1 -0
- package/dist/__tests__/static-handler-types.test.js +63 -0
- package/dist/__tests__/static-handler-types.test.js.map +1 -0
- package/dist/__tests__/urls.test.d.ts +2 -0
- package/dist/__tests__/urls.test.d.ts.map +1 -0
- package/dist/__tests__/urls.test.js +421 -0
- package/dist/__tests__/urls.test.js.map +1 -0
- package/dist/__tests__/use-mount.test.d.ts +2 -0
- package/dist/__tests__/use-mount.test.d.ts.map +1 -0
- package/dist/__tests__/use-mount.test.js +35 -0
- package/dist/__tests__/use-mount.test.js.map +1 -0
- package/dist/bin/rango.d.ts +2 -0
- package/dist/bin/rango.d.ts.map +1 -0
- package/dist/bin/rango.js +109 -15
- package/dist/bin/rango.js.map +1 -0
- package/dist/browser/event-controller.d.ts +191 -0
- package/dist/browser/event-controller.d.ts.map +1 -0
- package/dist/browser/event-controller.js +559 -0
- package/dist/browser/event-controller.js.map +1 -0
- package/dist/browser/index.d.ts +2 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +14 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/link-interceptor.d.ts +38 -0
- package/dist/browser/link-interceptor.d.ts.map +1 -0
- package/dist/browser/link-interceptor.js +99 -0
- package/dist/browser/link-interceptor.js.map +1 -0
- package/dist/browser/logging.d.ts +10 -0
- package/dist/browser/logging.d.ts.map +1 -0
- package/dist/browser/logging.js +29 -0
- package/dist/browser/logging.js.map +1 -0
- package/dist/browser/lru-cache.d.ts +17 -0
- package/dist/browser/lru-cache.d.ts.map +1 -0
- package/dist/browser/lru-cache.js +50 -0
- package/dist/browser/lru-cache.js.map +1 -0
- package/dist/browser/merge-segment-loaders.d.ts +39 -0
- package/dist/browser/merge-segment-loaders.d.ts.map +1 -0
- package/dist/browser/merge-segment-loaders.js +102 -0
- package/dist/browser/merge-segment-loaders.js.map +1 -0
- package/dist/browser/navigation-bridge.d.ts +102 -0
- package/dist/browser/navigation-bridge.d.ts.map +1 -0
- package/dist/browser/navigation-bridge.js +708 -0
- package/dist/browser/navigation-bridge.js.map +1 -0
- package/dist/browser/navigation-client.d.ts +25 -0
- package/dist/browser/navigation-client.d.ts.map +1 -0
- package/dist/browser/navigation-client.js +157 -0
- package/dist/browser/navigation-client.js.map +1 -0
- package/dist/browser/navigation-store.d.ts +101 -0
- package/dist/browser/navigation-store.d.ts.map +1 -0
- package/dist/browser/navigation-store.js +625 -0
- package/dist/browser/navigation-store.js.map +1 -0
- package/dist/browser/partial-update.d.ts +75 -0
- package/dist/browser/partial-update.d.ts.map +1 -0
- package/dist/browser/partial-update.js +426 -0
- package/dist/browser/partial-update.js.map +1 -0
- package/dist/browser/react/Link.d.ts +86 -0
- package/dist/browser/react/Link.d.ts.map +1 -0
- package/dist/browser/react/Link.js +128 -0
- package/dist/browser/react/Link.js.map +1 -0
- package/dist/browser/react/NavigationProvider.d.ts +63 -0
- package/dist/browser/react/NavigationProvider.d.ts.map +1 -0
- package/dist/browser/react/NavigationProvider.js +216 -0
- package/dist/browser/react/NavigationProvider.js.map +1 -0
- package/dist/browser/react/ScrollRestoration.d.ts +75 -0
- package/dist/browser/react/ScrollRestoration.d.ts.map +1 -0
- package/dist/browser/react/ScrollRestoration.js +57 -0
- package/dist/browser/react/ScrollRestoration.js.map +1 -0
- package/dist/browser/react/context.d.ts +46 -0
- package/dist/browser/react/context.d.ts.map +1 -0
- package/dist/browser/react/context.js +10 -0
- package/dist/browser/react/context.js.map +1 -0
- package/dist/browser/react/index.d.ts +11 -0
- package/dist/browser/react/index.d.ts.map +1 -0
- package/dist/browser/react/index.js +22 -0
- package/dist/browser/react/index.js.map +1 -0
- package/dist/browser/react/location-state-shared.d.ts +63 -0
- package/dist/browser/react/location-state-shared.d.ts.map +1 -0
- package/dist/browser/react/location-state-shared.js +81 -0
- package/dist/browser/react/location-state-shared.js.map +1 -0
- package/dist/browser/react/location-state.d.ts +23 -0
- package/dist/browser/react/location-state.d.ts.map +1 -0
- package/dist/browser/react/location-state.js +29 -0
- package/dist/browser/react/location-state.js.map +1 -0
- package/dist/browser/react/mount-context.d.ts +24 -0
- package/dist/browser/react/mount-context.d.ts.map +1 -0
- package/dist/browser/react/mount-context.js +24 -0
- package/dist/browser/react/mount-context.js.map +1 -0
- package/dist/browser/react/use-action.d.ts +64 -0
- package/dist/browser/react/use-action.d.ts.map +1 -0
- package/dist/browser/react/use-action.js +134 -0
- package/dist/browser/react/use-action.js.map +1 -0
- package/dist/browser/react/use-client-cache.d.ts +41 -0
- package/dist/browser/react/use-client-cache.d.ts.map +1 -0
- package/dist/browser/react/use-client-cache.js +39 -0
- package/dist/browser/react/use-client-cache.js.map +1 -0
- package/dist/browser/react/use-handle.d.ts +31 -0
- package/dist/browser/react/use-handle.d.ts.map +1 -0
- package/dist/browser/react/use-handle.js +144 -0
- package/dist/browser/react/use-handle.js.map +1 -0
- package/dist/browser/react/use-href.d.ts +33 -0
- package/dist/browser/react/use-href.d.ts.map +1 -0
- package/dist/browser/react/use-href.js +39 -0
- package/dist/browser/react/use-href.js.map +1 -0
- package/dist/browser/react/use-link-status.d.ts +37 -0
- package/dist/browser/react/use-link-status.d.ts.map +1 -0
- package/dist/browser/react/use-link-status.js +99 -0
- package/dist/browser/react/use-link-status.js.map +1 -0
- package/dist/browser/react/use-mount.d.ts +25 -0
- package/dist/browser/react/use-mount.d.ts.map +1 -0
- package/dist/browser/react/use-mount.js +30 -0
- package/dist/browser/react/use-mount.js.map +1 -0
- package/dist/browser/react/use-navigation.d.ts +27 -0
- package/dist/browser/react/use-navigation.d.ts.map +1 -0
- package/dist/browser/react/use-navigation.js +87 -0
- package/dist/browser/react/use-navigation.js.map +1 -0
- package/dist/browser/react/use-segments.d.ts +38 -0
- package/dist/browser/react/use-segments.d.ts.map +1 -0
- package/dist/browser/react/use-segments.js +130 -0
- package/dist/browser/react/use-segments.js.map +1 -0
- package/dist/browser/request-controller.d.ts +26 -0
- package/dist/browser/request-controller.d.ts.map +1 -0
- package/dist/browser/request-controller.js +147 -0
- package/dist/browser/request-controller.js.map +1 -0
- package/dist/browser/rsc-router.d.ts +129 -0
- package/dist/browser/rsc-router.d.ts.map +1 -0
- package/dist/browser/rsc-router.js +195 -0
- package/dist/browser/rsc-router.js.map +1 -0
- package/dist/browser/scroll-restoration.d.ts +93 -0
- package/dist/browser/scroll-restoration.d.ts.map +1 -0
- package/dist/browser/scroll-restoration.js +321 -0
- package/dist/browser/scroll-restoration.js.map +1 -0
- package/dist/browser/segment-structure-assert.d.ts +17 -0
- package/dist/browser/segment-structure-assert.d.ts.map +1 -0
- package/dist/browser/segment-structure-assert.js +59 -0
- package/dist/browser/segment-structure-assert.js.map +1 -0
- package/dist/browser/server-action-bridge.d.ts +26 -0
- package/dist/browser/server-action-bridge.d.ts.map +1 -0
- package/dist/browser/server-action-bridge.js +668 -0
- package/dist/browser/server-action-bridge.js.map +1 -0
- package/dist/browser/shallow.d.ts +12 -0
- package/dist/browser/shallow.d.ts.map +1 -0
- package/dist/browser/shallow.js +34 -0
- package/dist/browser/shallow.js.map +1 -0
- package/dist/browser/types.d.ts +369 -0
- package/dist/browser/types.d.ts.map +1 -0
- package/dist/browser/types.js +2 -0
- package/dist/browser/types.js.map +1 -0
- package/dist/build/__tests__/generate-cli.test.d.ts +2 -0
- package/dist/build/__tests__/generate-cli.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-cli.test.js +237 -0
- package/dist/build/__tests__/generate-cli.test.js.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/generate-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-manifest.test.js +119 -0
- package/dist/build/__tests__/generate-manifest.test.js.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts +2 -0
- package/dist/build/__tests__/generate-route-types.test.d.ts.map +1 -0
- package/dist/build/__tests__/generate-route-types.test.js +620 -0
- package/dist/build/__tests__/generate-route-types.test.js.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts +2 -0
- package/dist/build/__tests__/per-router-manifest.test.d.ts.map +1 -0
- package/dist/build/__tests__/per-router-manifest.test.js +308 -0
- package/dist/build/__tests__/per-router-manifest.test.js.map +1 -0
- package/dist/build/generate-manifest.d.ts +81 -0
- package/dist/build/generate-manifest.d.ts.map +1 -0
- package/dist/build/generate-manifest.js +276 -0
- package/dist/build/generate-manifest.js.map +1 -0
- package/dist/build/generate-route-types.d.ts +115 -0
- package/dist/build/generate-route-types.d.ts.map +1 -0
- package/dist/build/generate-route-types.js +740 -0
- package/dist/build/generate-route-types.js.map +1 -0
- package/dist/build/index.d.ts +21 -0
- package/dist/build/index.d.ts.map +1 -0
- package/dist/build/index.js +21 -0
- package/dist/build/index.js.map +1 -0
- package/dist/build/route-trie.d.ts +71 -0
- package/dist/build/route-trie.d.ts.map +1 -0
- package/dist/build/route-trie.js +175 -0
- package/dist/build/route-trie.js.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts +2 -0
- package/dist/cache/__tests__/cache-scope.test.d.ts.map +1 -0
- package/dist/cache/__tests__/cache-scope.test.js +208 -0
- package/dist/cache/__tests__/cache-scope.test.js.map +1 -0
- package/dist/cache/__tests__/document-cache.test.d.ts +2 -0
- package/dist/cache/__tests__/document-cache.test.d.ts.map +1 -0
- package/dist/cache/__tests__/document-cache.test.js +345 -0
- package/dist/cache/__tests__/document-cache.test.js.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-segment-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-segment-store.test.js +425 -0
- package/dist/cache/__tests__/memory-segment-store.test.js.map +1 -0
- package/dist/cache/__tests__/memory-store.test.d.ts +2 -0
- package/dist/cache/__tests__/memory-store.test.d.ts.map +1 -0
- package/dist/cache/__tests__/memory-store.test.js +367 -0
- package/dist/cache/__tests__/memory-store.test.js.map +1 -0
- package/dist/cache/cache-scope.d.ts +102 -0
- package/dist/cache/cache-scope.d.ts.map +1 -0
- package/dist/cache/cache-scope.js +440 -0
- package/dist/cache/cache-scope.js.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts +2 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.d.ts.map +1 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js +330 -0
- package/dist/cache/cf/__tests__/cf-cache-store.test.js.map +1 -0
- package/dist/cache/cf/cf-cache-store.d.ts +165 -0
- package/dist/cache/cf/cf-cache-store.d.ts.map +1 -0
- package/dist/cache/cf/cf-cache-store.js +242 -0
- package/dist/cache/cf/cf-cache-store.js.map +1 -0
- package/dist/cache/cf/index.d.ts +14 -0
- package/dist/cache/cf/index.d.ts.map +1 -0
- package/dist/cache/cf/index.js +17 -0
- package/dist/cache/cf/index.js.map +1 -0
- package/dist/cache/document-cache.d.ts +64 -0
- package/dist/cache/document-cache.d.ts.map +1 -0
- package/dist/cache/document-cache.js +228 -0
- package/dist/cache/document-cache.js.map +1 -0
- package/dist/cache/index.d.ts +19 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +21 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/memory-segment-store.d.ts +110 -0
- package/dist/cache/memory-segment-store.d.ts.map +1 -0
- package/dist/cache/memory-segment-store.js +117 -0
- package/dist/cache/memory-segment-store.js.map +1 -0
- package/dist/cache/memory-store.d.ts +41 -0
- package/dist/cache/memory-store.d.ts.map +1 -0
- package/dist/cache/memory-store.js +191 -0
- package/dist/cache/memory-store.js.map +1 -0
- package/dist/cache/types.d.ts +317 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +12 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/client.d.ts +248 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +367 -0
- package/dist/client.js.map +1 -0
- package/dist/client.rsc.d.ts +26 -0
- package/dist/client.rsc.d.ts.map +1 -0
- package/dist/client.rsc.js +46 -0
- package/dist/client.rsc.js.map +1 -0
- package/dist/component-utils.d.ts +36 -0
- package/dist/component-utils.d.ts.map +1 -0
- package/dist/component-utils.js +61 -0
- package/dist/component-utils.js.map +1 -0
- package/dist/components/DefaultDocument.d.ts +13 -0
- package/dist/components/DefaultDocument.d.ts.map +1 -0
- package/dist/components/DefaultDocument.js +15 -0
- package/dist/components/DefaultDocument.js.map +1 -0
- package/dist/debug.d.ts +58 -0
- package/dist/debug.d.ts.map +1 -0
- package/dist/debug.js +157 -0
- package/dist/debug.js.map +1 -0
- package/dist/default-error-boundary.d.ts +11 -0
- package/dist/default-error-boundary.d.ts.map +1 -0
- package/dist/default-error-boundary.js +45 -0
- package/dist/default-error-boundary.js.map +1 -0
- package/dist/deps/browser.d.ts +2 -0
- package/dist/deps/browser.d.ts.map +1 -0
- package/dist/deps/browser.js +3 -0
- package/dist/deps/browser.js.map +1 -0
- package/dist/deps/html-stream-client.d.ts +2 -0
- package/dist/deps/html-stream-client.d.ts.map +1 -0
- package/dist/deps/html-stream-client.js +3 -0
- package/dist/deps/html-stream-client.js.map +1 -0
- package/dist/deps/html-stream-server.d.ts +2 -0
- package/dist/deps/html-stream-server.d.ts.map +1 -0
- package/dist/deps/html-stream-server.js +3 -0
- package/dist/deps/html-stream-server.js.map +1 -0
- package/dist/deps/rsc.d.ts +2 -0
- package/dist/deps/rsc.d.ts.map +1 -0
- package/dist/deps/rsc.js +4 -0
- package/dist/deps/rsc.js.map +1 -0
- package/dist/deps/ssr.d.ts +2 -0
- package/dist/deps/ssr.d.ts.map +1 -0
- package/dist/deps/ssr.js +3 -0
- package/dist/deps/ssr.js.map +1 -0
- package/dist/errors.d.ts +174 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +241 -0
- package/dist/errors.js.map +1 -0
- package/dist/handle.d.ts +78 -0
- package/dist/handle.d.ts.map +1 -0
- package/dist/handle.js +82 -0
- package/dist/handle.js.map +1 -0
- package/dist/handles/MetaTags.d.ts +14 -0
- package/dist/handles/MetaTags.d.ts.map +1 -0
- package/dist/handles/MetaTags.js +136 -0
- package/dist/handles/MetaTags.js.map +1 -0
- package/dist/handles/index.d.ts +6 -0
- package/dist/handles/index.d.ts.map +1 -0
- package/dist/handles/index.js +6 -0
- package/dist/handles/index.js.map +1 -0
- package/dist/handles/meta.d.ts +39 -0
- package/dist/handles/meta.d.ts.map +1 -0
- package/dist/handles/meta.js +202 -0
- package/dist/handles/meta.js.map +1 -0
- package/dist/host/__tests__/errors.test.d.ts +2 -0
- package/dist/host/__tests__/errors.test.d.ts.map +1 -0
- package/dist/host/__tests__/errors.test.js +76 -0
- package/dist/host/__tests__/errors.test.js.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-comprehensive.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js +732 -0
- package/dist/host/__tests__/pattern-comprehensive.test.js.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts +2 -0
- package/dist/host/__tests__/pattern-matcher.test.d.ts.map +1 -0
- package/dist/host/__tests__/pattern-matcher.test.js +251 -0
- package/dist/host/__tests__/pattern-matcher.test.js.map +1 -0
- package/dist/host/__tests__/router.test.d.ts +2 -0
- package/dist/host/__tests__/router.test.d.ts.map +1 -0
- package/dist/host/__tests__/router.test.js +241 -0
- package/dist/host/__tests__/router.test.js.map +1 -0
- package/dist/host/__tests__/testing.test.d.ts +2 -0
- package/dist/host/__tests__/testing.test.d.ts.map +1 -0
- package/dist/host/__tests__/testing.test.js +64 -0
- package/dist/host/__tests__/testing.test.js.map +1 -0
- package/dist/host/__tests__/utils.test.d.ts +2 -0
- package/dist/host/__tests__/utils.test.d.ts.map +1 -0
- package/dist/host/__tests__/utils.test.js +29 -0
- package/dist/host/__tests__/utils.test.js.map +1 -0
- package/dist/host/cookie-handler.d.ts +34 -0
- package/dist/host/cookie-handler.d.ts.map +1 -0
- package/dist/host/cookie-handler.js +124 -0
- package/dist/host/cookie-handler.js.map +1 -0
- package/dist/host/errors.d.ts +56 -0
- package/dist/host/errors.d.ts.map +1 -0
- package/dist/host/errors.js +79 -0
- package/dist/host/errors.js.map +1 -0
- package/dist/host/index.d.ts +29 -0
- package/dist/host/index.d.ts.map +1 -0
- package/dist/host/index.js +32 -0
- package/dist/host/index.js.map +1 -0
- package/dist/host/pattern-matcher.d.ts +36 -0
- package/dist/host/pattern-matcher.d.ts.map +1 -0
- package/dist/host/pattern-matcher.js +172 -0
- package/dist/host/pattern-matcher.js.map +1 -0
- package/dist/host/router.d.ts +26 -0
- package/dist/host/router.d.ts.map +1 -0
- package/dist/host/router.js +218 -0
- package/dist/host/router.js.map +1 -0
- package/dist/host/testing.d.ts +36 -0
- package/dist/host/testing.d.ts.map +1 -0
- package/dist/host/testing.js +55 -0
- package/dist/host/testing.js.map +1 -0
- package/dist/host/types.d.ts +115 -0
- package/dist/host/types.d.ts.map +1 -0
- package/dist/host/types.js +7 -0
- package/dist/host/types.js.map +1 -0
- package/dist/host/utils.d.ts +21 -0
- package/dist/host/utils.d.ts.map +1 -0
- package/dist/host/utils.js +23 -0
- package/dist/host/utils.js.map +1 -0
- package/dist/href-client.d.ts +131 -0
- package/dist/href-client.d.ts.map +1 -0
- package/dist/href-client.js +64 -0
- package/dist/href-client.js.map +1 -0
- package/dist/href-context.d.ts +29 -0
- package/dist/href-context.d.ts.map +1 -0
- package/dist/href-context.js +21 -0
- package/dist/href-context.js.map +1 -0
- package/dist/index.d.ts +73 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +91 -0
- package/dist/index.js.map +1 -0
- package/dist/index.rsc.d.ts +32 -0
- package/dist/index.rsc.d.ts.map +1 -0
- package/dist/index.rsc.js +40 -0
- package/dist/index.rsc.js.map +1 -0
- package/dist/internal-debug.d.ts +2 -0
- package/dist/internal-debug.d.ts.map +1 -0
- package/dist/internal-debug.js +5 -0
- package/dist/internal-debug.js.map +1 -0
- package/dist/loader.d.ts +14 -0
- package/dist/loader.d.ts.map +1 -0
- package/dist/loader.js +20 -0
- package/dist/loader.js.map +1 -0
- package/dist/loader.rsc.d.ts +19 -0
- package/dist/loader.rsc.d.ts.map +1 -0
- package/dist/loader.rsc.js +99 -0
- package/dist/loader.rsc.js.map +1 -0
- package/dist/network-error-thrower.d.ts +17 -0
- package/dist/network-error-thrower.d.ts.map +1 -0
- package/dist/network-error-thrower.js +14 -0
- package/dist/network-error-thrower.js.map +1 -0
- package/dist/outlet-context.d.ts +13 -0
- package/dist/outlet-context.d.ts.map +1 -0
- package/dist/outlet-context.js +3 -0
- package/dist/outlet-context.js.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts +2 -0
- package/dist/prerender/__tests__/param-hash.test.d.ts.map +1 -0
- package/dist/prerender/__tests__/param-hash.test.js +148 -0
- package/dist/prerender/__tests__/param-hash.test.js.map +1 -0
- package/dist/prerender/param-hash.d.ts +16 -0
- package/dist/prerender/param-hash.d.ts.map +1 -0
- package/dist/prerender/param-hash.js +36 -0
- package/dist/prerender/param-hash.js.map +1 -0
- package/dist/prerender/store.d.ts +38 -0
- package/dist/prerender/store.d.ts.map +1 -0
- package/dist/prerender/store.js +61 -0
- package/dist/prerender/store.js.map +1 -0
- package/dist/prerender.d.ts +66 -0
- package/dist/prerender.d.ts.map +1 -0
- package/dist/prerender.js +57 -0
- package/dist/prerender.js.map +1 -0
- package/dist/reverse.d.ts +196 -0
- package/dist/reverse.d.ts.map +1 -0
- package/dist/reverse.js +78 -0
- package/dist/reverse.js.map +1 -0
- package/dist/root-error-boundary.d.ts +33 -0
- package/dist/root-error-boundary.d.ts.map +1 -0
- package/dist/root-error-boundary.js +165 -0
- package/dist/root-error-boundary.js.map +1 -0
- package/dist/route-content-wrapper.d.ts +46 -0
- package/dist/route-content-wrapper.d.ts.map +1 -0
- package/dist/route-content-wrapper.js +77 -0
- package/dist/route-content-wrapper.js.map +1 -0
- package/dist/route-definition.d.ts +421 -0
- package/dist/route-definition.d.ts.map +1 -0
- package/dist/route-definition.js +868 -0
- package/dist/route-definition.js.map +1 -0
- package/dist/route-map-builder.d.ts +155 -0
- package/dist/route-map-builder.d.ts.map +1 -0
- package/dist/route-map-builder.js +237 -0
- package/dist/route-map-builder.js.map +1 -0
- package/dist/route-types.d.ts +165 -0
- package/dist/route-types.d.ts.map +1 -0
- package/dist/route-types.js +7 -0
- package/dist/route-types.js.map +1 -0
- package/dist/router/__tests__/handler-context.test.d.ts +2 -0
- package/dist/router/__tests__/handler-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/handler-context.test.js +65 -0
- package/dist/router/__tests__/handler-context.test.js.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts +2 -0
- package/dist/router/__tests__/loader-cycle-detection.test.d.ts.map +1 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js +221 -0
- package/dist/router/__tests__/loader-cycle-detection.test.js.map +1 -0
- package/dist/router/__tests__/match-context.test.d.ts +2 -0
- package/dist/router/__tests__/match-context.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-context.test.js +92 -0
- package/dist/router/__tests__/match-context.test.js.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts +2 -0
- package/dist/router/__tests__/match-pipelines.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-pipelines.test.js +417 -0
- package/dist/router/__tests__/match-pipelines.test.js.map +1 -0
- package/dist/router/__tests__/match-result.test.d.ts +2 -0
- package/dist/router/__tests__/match-result.test.d.ts.map +1 -0
- package/dist/router/__tests__/match-result.test.js +457 -0
- package/dist/router/__tests__/match-result.test.js.map +1 -0
- package/dist/router/__tests__/on-error.test.d.ts +2 -0
- package/dist/router/__tests__/on-error.test.d.ts.map +1 -0
- package/dist/router/__tests__/on-error.test.js +678 -0
- package/dist/router/__tests__/on-error.test.js.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts +2 -0
- package/dist/router/__tests__/pattern-matching.test.d.ts.map +1 -0
- package/dist/router/__tests__/pattern-matching.test.js +629 -0
- package/dist/router/__tests__/pattern-matching.test.js.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts +2 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.d.ts.map +1 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js +155 -0
- package/dist/router/__tests__/segment-resolution-parallel-loading.test.js.map +1 -0
- package/dist/router/error-handling.d.ts +77 -0
- package/dist/router/error-handling.d.ts.map +1 -0
- package/dist/router/error-handling.js +202 -0
- package/dist/router/error-handling.js.map +1 -0
- package/dist/router/handler-context.d.ts +20 -0
- package/dist/router/handler-context.d.ts.map +1 -0
- package/dist/router/handler-context.js +198 -0
- package/dist/router/handler-context.js.map +1 -0
- package/dist/router/intercept-resolution.d.ts +66 -0
- package/dist/router/intercept-resolution.d.ts.map +1 -0
- package/dist/router/intercept-resolution.js +246 -0
- package/dist/router/intercept-resolution.js.map +1 -0
- package/dist/router/loader-resolution.d.ts +64 -0
- package/dist/router/loader-resolution.d.ts.map +1 -0
- package/dist/router/loader-resolution.js +284 -0
- package/dist/router/loader-resolution.js.map +1 -0
- package/dist/router/logging.d.ts +15 -0
- package/dist/router/logging.d.ts.map +1 -0
- package/dist/router/logging.js +99 -0
- package/dist/router/logging.js.map +1 -0
- package/dist/router/manifest.d.ts +22 -0
- package/dist/router/manifest.d.ts.map +1 -0
- package/dist/router/manifest.js +181 -0
- package/dist/router/manifest.js.map +1 -0
- package/dist/router/match-api.d.ts +35 -0
- package/dist/router/match-api.d.ts.map +1 -0
- package/dist/router/match-api.js +406 -0
- package/dist/router/match-api.js.map +1 -0
- package/dist/router/match-context.d.ts +206 -0
- package/dist/router/match-context.d.ts.map +1 -0
- package/dist/router/match-context.js +17 -0
- package/dist/router/match-context.js.map +1 -0
- package/dist/router/match-middleware/background-revalidation.d.ts +127 -0
- package/dist/router/match-middleware/background-revalidation.d.ts.map +1 -0
- package/dist/router/match-middleware/background-revalidation.js +75 -0
- package/dist/router/match-middleware/background-revalidation.js.map +1 -0
- package/dist/router/match-middleware/cache-lookup.d.ts +112 -0
- package/dist/router/match-middleware/cache-lookup.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-lookup.js +257 -0
- package/dist/router/match-middleware/cache-lookup.js.map +1 -0
- package/dist/router/match-middleware/cache-store.d.ts +113 -0
- package/dist/router/match-middleware/cache-store.d.ts.map +1 -0
- package/dist/router/match-middleware/cache-store.js +108 -0
- package/dist/router/match-middleware/cache-store.js.map +1 -0
- package/dist/router/match-middleware/index.d.ts +81 -0
- package/dist/router/match-middleware/index.d.ts.map +1 -0
- package/dist/router/match-middleware/index.js +80 -0
- package/dist/router/match-middleware/index.js.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts +117 -0
- package/dist/router/match-middleware/intercept-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/intercept-resolution.js +134 -0
- package/dist/router/match-middleware/intercept-resolution.js.map +1 -0
- package/dist/router/match-middleware/segment-resolution.d.ts +99 -0
- package/dist/router/match-middleware/segment-resolution.d.ts.map +1 -0
- package/dist/router/match-middleware/segment-resolution.js +53 -0
- package/dist/router/match-middleware/segment-resolution.js.map +1 -0
- package/dist/router/match-pipelines.d.ts +147 -0
- package/dist/router/match-pipelines.d.ts.map +1 -0
- package/dist/router/match-pipelines.js +82 -0
- package/dist/router/match-pipelines.js.map +1 -0
- package/dist/router/match-result.d.ts +126 -0
- package/dist/router/match-result.d.ts.map +1 -0
- package/dist/router/match-result.js +93 -0
- package/dist/router/match-result.js.map +1 -0
- package/dist/router/metrics.d.ts +20 -0
- package/dist/router/metrics.d.ts.map +1 -0
- package/dist/router/metrics.js +47 -0
- package/dist/router/metrics.js.map +1 -0
- package/dist/router/middleware.d.ts +249 -0
- package/dist/router/middleware.d.ts.map +1 -0
- package/dist/router/middleware.js +434 -0
- package/dist/router/middleware.js.map +1 -0
- package/dist/router/middleware.test.d.ts +2 -0
- package/dist/router/middleware.test.d.ts.map +1 -0
- package/dist/router/middleware.test.js +816 -0
- package/dist/router/middleware.test.js.map +1 -0
- package/dist/router/pattern-matching.d.ts +149 -0
- package/dist/router/pattern-matching.d.ts.map +1 -0
- package/dist/router/pattern-matching.js +349 -0
- package/dist/router/pattern-matching.js.map +1 -0
- package/dist/router/revalidation.d.ts +44 -0
- package/dist/router/revalidation.d.ts.map +1 -0
- package/dist/router/revalidation.js +147 -0
- package/dist/router/revalidation.js.map +1 -0
- package/dist/router/router-context.d.ts +135 -0
- package/dist/router/router-context.d.ts.map +1 -0
- package/dist/router/router-context.js +36 -0
- package/dist/router/router-context.js.map +1 -0
- package/dist/router/segment-resolution.d.ts +127 -0
- package/dist/router/segment-resolution.d.ts.map +1 -0
- package/dist/router/segment-resolution.js +919 -0
- package/dist/router/segment-resolution.js.map +1 -0
- package/dist/router/trie-matching.d.ts +40 -0
- package/dist/router/trie-matching.d.ts.map +1 -0
- package/dist/router/trie-matching.js +127 -0
- package/dist/router/trie-matching.js.map +1 -0
- package/dist/router/types.d.ts +136 -0
- package/dist/router/types.d.ts.map +1 -0
- package/dist/router/types.js +7 -0
- package/dist/router/types.js.map +1 -0
- package/dist/router.d.ts +753 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.gen.d.ts +6 -0
- package/dist/router.gen.d.ts.map +1 -0
- package/dist/router.gen.js +6 -0
- package/dist/router.gen.js.map +1 -0
- package/dist/router.js +1304 -0
- package/dist/router.js.map +1 -0
- package/dist/rsc/__tests__/helpers.test.d.ts +2 -0
- package/dist/rsc/__tests__/helpers.test.d.ts.map +1 -0
- package/dist/rsc/__tests__/helpers.test.js +140 -0
- package/dist/rsc/__tests__/helpers.test.js.map +1 -0
- package/dist/rsc/handler.d.ts +45 -0
- package/dist/rsc/handler.d.ts.map +1 -0
- package/dist/rsc/handler.js +1172 -0
- package/dist/rsc/handler.js.map +1 -0
- package/dist/rsc/helpers.d.ts +16 -0
- package/dist/rsc/helpers.d.ts.map +1 -0
- package/dist/rsc/helpers.js +55 -0
- package/dist/rsc/helpers.js.map +1 -0
- package/dist/rsc/index.d.ts +22 -0
- package/dist/rsc/index.d.ts.map +1 -0
- package/dist/rsc/index.js +23 -0
- package/dist/rsc/index.js.map +1 -0
- package/dist/rsc/nonce.d.ts +9 -0
- package/dist/rsc/nonce.d.ts.map +1 -0
- package/dist/rsc/nonce.js +18 -0
- package/dist/rsc/nonce.js.map +1 -0
- package/dist/rsc/types.d.ts +206 -0
- package/dist/rsc/types.d.ts.map +1 -0
- package/dist/rsc/types.js +8 -0
- package/dist/rsc/types.js.map +1 -0
- package/dist/search-params.d.ts +103 -0
- package/dist/search-params.d.ts.map +1 -0
- package/dist/search-params.js +74 -0
- package/dist/search-params.js.map +1 -0
- package/dist/segment-system.d.ts +75 -0
- package/dist/segment-system.d.ts.map +1 -0
- package/dist/segment-system.js +336 -0
- package/dist/segment-system.js.map +1 -0
- package/dist/server/context.d.ts +245 -0
- package/dist/server/context.d.ts.map +1 -0
- package/dist/server/context.js +197 -0
- package/dist/server/context.js.map +1 -0
- package/dist/server/fetchable-loader-store.d.ts +18 -0
- package/dist/server/fetchable-loader-store.d.ts.map +1 -0
- package/dist/server/fetchable-loader-store.js +18 -0
- package/dist/server/fetchable-loader-store.js.map +1 -0
- package/dist/server/handle-store.d.ts +85 -0
- package/dist/server/handle-store.d.ts.map +1 -0
- package/dist/server/handle-store.js +142 -0
- package/dist/server/handle-store.js.map +1 -0
- package/dist/server/loader-registry.d.ts +55 -0
- package/dist/server/loader-registry.d.ts.map +1 -0
- package/dist/server/loader-registry.js +132 -0
- package/dist/server/loader-registry.js.map +1 -0
- package/dist/server/request-context.d.ts +226 -0
- package/dist/server/request-context.d.ts.map +1 -0
- package/dist/server/request-context.js +290 -0
- package/dist/server/request-context.js.map +1 -0
- package/dist/server/root-layout.d.ts +4 -0
- package/dist/server/root-layout.d.ts.map +1 -0
- package/dist/server/root-layout.js +5 -0
- package/dist/server/root-layout.js.map +1 -0
- package/dist/server.d.ts +15 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +20 -0
- package/dist/server.js.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts +2 -0
- package/dist/ssr/__tests__/ssr-handler.test.d.ts.map +1 -0
- package/dist/ssr/__tests__/ssr-handler.test.js +132 -0
- package/dist/ssr/__tests__/ssr-handler.test.js.map +1 -0
- package/dist/ssr/index.d.ts +98 -0
- package/dist/ssr/index.d.ts.map +1 -0
- package/dist/ssr/index.js +158 -0
- package/dist/ssr/index.js.map +1 -0
- package/dist/static-handler.d.ts +50 -0
- package/dist/static-handler.d.ts.map +1 -0
- package/dist/static-handler.gen.d.ts +5 -0
- package/dist/static-handler.gen.d.ts.map +1 -0
- package/dist/static-handler.gen.js +5 -0
- package/dist/static-handler.gen.js.map +1 -0
- package/dist/static-handler.js +29 -0
- package/dist/static-handler.js.map +1 -0
- package/dist/theme/ThemeProvider.d.ts +20 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +240 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/ThemeScript.d.ts +48 -0
- package/dist/theme/ThemeScript.d.ts.map +1 -0
- package/dist/theme/ThemeScript.js +13 -0
- package/dist/theme/ThemeScript.js.map +1 -0
- package/dist/theme/__tests__/theme.test.d.ts +2 -0
- package/dist/theme/__tests__/theme.test.d.ts.map +1 -0
- package/dist/theme/__tests__/theme.test.js +103 -0
- package/dist/theme/__tests__/theme.test.js.map +1 -0
- package/dist/theme/constants.d.ts +29 -0
- package/dist/theme/constants.d.ts.map +1 -0
- package/dist/theme/constants.js +48 -0
- package/dist/theme/constants.js.map +1 -0
- package/dist/theme/index.d.ts +31 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +36 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/theme-context.d.ts +40 -0
- package/dist/theme/theme-context.d.ts.map +1 -0
- package/dist/theme/theme-context.js +60 -0
- package/dist/theme/theme-context.js.map +1 -0
- package/dist/theme/theme-script.d.ts +27 -0
- package/dist/theme/theme-script.d.ts.map +1 -0
- package/dist/theme/theme-script.js +147 -0
- package/dist/theme/theme-script.js.map +1 -0
- package/dist/theme/types.d.ts +163 -0
- package/dist/theme/types.d.ts.map +1 -0
- package/dist/theme/types.js +11 -0
- package/dist/theme/types.js.map +1 -0
- package/dist/theme/use-theme.d.ts +12 -0
- package/dist/theme/use-theme.d.ts.map +1 -0
- package/dist/theme/use-theme.js +40 -0
- package/dist/theme/use-theme.js.map +1 -0
- package/dist/types.d.ts +1479 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +10 -0
- package/dist/types.js.map +1 -0
- package/dist/urls.d.ts +441 -0
- package/dist/urls.d.ts.map +1 -0
- package/dist/urls.gen.d.ts +8 -0
- package/dist/urls.gen.d.ts.map +1 -0
- package/dist/urls.gen.js +8 -0
- package/dist/urls.gen.js.map +1 -0
- package/dist/urls.js +443 -0
- package/dist/urls.js.map +1 -0
- package/dist/use-loader.d.ts +127 -0
- package/dist/use-loader.d.ts.map +1 -0
- package/dist/use-loader.js +237 -0
- package/dist/use-loader.js.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts +2 -0
- package/dist/vite/__tests__/ast-handler-extract.test.d.ts.map +1 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js +294 -0
- package/dist/vite/__tests__/ast-handler-extract.test.js.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-id-utils.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-id-utils.test.js +224 -0
- package/dist/vite/__tests__/expose-id-utils.test.js.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-internal-ids.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js +647 -0
- package/dist/vite/__tests__/expose-internal-ids.test.js.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts +2 -0
- package/dist/vite/__tests__/expose-router-id.test.d.ts.map +1 -0
- package/dist/vite/__tests__/expose-router-id.test.js +39 -0
- package/dist/vite/__tests__/expose-router-id.test.js.map +1 -0
- package/dist/vite/ast-handler-extract.d.ts +49 -0
- package/dist/vite/ast-handler-extract.d.ts.map +1 -0
- package/dist/vite/ast-handler-extract.js +249 -0
- package/dist/vite/ast-handler-extract.js.map +1 -0
- package/dist/vite/expose-action-id.d.ts +19 -0
- package/dist/vite/expose-action-id.d.ts.map +1 -0
- package/dist/vite/expose-action-id.js +250 -0
- package/dist/vite/expose-action-id.js.map +1 -0
- package/dist/vite/expose-id-utils.d.ts +69 -0
- package/dist/vite/expose-id-utils.d.ts.map +1 -0
- package/dist/vite/expose-id-utils.js +289 -0
- package/dist/vite/expose-id-utils.js.map +1 -0
- package/dist/vite/expose-internal-ids.d.ts +22 -0
- package/dist/vite/expose-internal-ids.d.ts.map +1 -0
- package/dist/vite/expose-internal-ids.js +886 -0
- package/dist/vite/expose-internal-ids.js.map +1 -0
- package/dist/vite/index.d.ts +149 -0
- package/dist/vite/index.d.ts.map +1 -0
- package/dist/vite/index.js +166 -46
- package/dist/vite/index.js.map +1 -0
- package/dist/vite/index.named-routes.gen.ts +103 -0
- package/dist/vite/package-resolution.d.ts +43 -0
- package/dist/vite/package-resolution.d.ts.map +1 -0
- package/dist/vite/package-resolution.js +112 -0
- package/dist/vite/package-resolution.js.map +1 -0
- package/dist/vite/virtual-entries.d.ts +25 -0
- package/dist/vite/virtual-entries.d.ts.map +1 -0
- package/dist/vite/virtual-entries.js +110 -0
- package/dist/vite/virtual-entries.js.map +1 -0
- package/package.json +15 -16
- package/src/bin/rango.ts +18 -0
- package/src/browser/navigation-bridge.ts +10 -4
- package/src/browser/rsc-router.tsx +2 -1
- package/src/browser/server-action-bridge.ts +448 -432
- package/src/build/generate-route-types.ts +2 -0
- package/src/build/route-types/router-processing.ts +125 -15
- package/src/index.rsc.ts +2 -1
- package/src/server/request-context.ts +8 -5
- package/src/vite/discovery/discover-routers.ts +16 -1
- package/src/vite/plugins/client-ref-dedup.ts +115 -0
- package/src/vite/rango.ts +11 -0
- package/src/vite/router-discovery.ts +12 -0
- /package/{CLAUDE.md → AGENTS.md} +0 -0
|
@@ -99,27 +99,31 @@ export function createServerActionBridge(
|
|
|
99
99
|
interceptSourceUrl?: string | null;
|
|
100
100
|
}): Promise<void> {
|
|
101
101
|
const src = opts?.interceptSourceUrl ?? null;
|
|
102
|
-
|
|
102
|
+
const navTx = createNavigationTransaction(
|
|
103
103
|
store,
|
|
104
104
|
eventController,
|
|
105
105
|
window.location.href,
|
|
106
106
|
{ replace: true, skipLoadingState: true },
|
|
107
107
|
);
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
108
|
+
try {
|
|
109
|
+
await fetchPartialUpdate(
|
|
110
|
+
window.location.href,
|
|
111
|
+
opts?.segments ?? [],
|
|
112
|
+
false,
|
|
113
|
+
navTx.handle.signal,
|
|
114
|
+
navTx.with({
|
|
115
|
+
url: window.location.href,
|
|
116
|
+
storeOnly: true,
|
|
117
|
+
...(src ? { intercept: true, interceptSourceUrl: src } : {}),
|
|
118
|
+
}),
|
|
119
|
+
{
|
|
120
|
+
type: "action" as const,
|
|
121
|
+
...(src ? { interceptSourceUrl: src } : {}),
|
|
122
|
+
},
|
|
123
|
+
);
|
|
124
|
+
} finally {
|
|
125
|
+
navTx[Symbol.dispose]();
|
|
126
|
+
}
|
|
123
127
|
}
|
|
124
128
|
|
|
125
129
|
/**
|
|
@@ -137,440 +141,495 @@ export function createServerActionBridge(
|
|
|
137
141
|
log("action start", { id, argsCount: args.length });
|
|
138
142
|
|
|
139
143
|
// Start action in event controller - handles lifecycle tracking
|
|
140
|
-
|
|
144
|
+
const handle = eventController.startAction(id, args);
|
|
145
|
+
try {
|
|
146
|
+
const segmentState = store.getSegmentState();
|
|
147
|
+
|
|
148
|
+
// Mark cache as stale immediately when action starts
|
|
149
|
+
// This ensures SWR pattern kicks in if user navigates away during action
|
|
150
|
+
store.markCacheAsStaleAndBroadcast();
|
|
151
|
+
|
|
152
|
+
// Create temporary references for serialization
|
|
153
|
+
const temporaryReferences = deps.createTemporaryReferenceSet();
|
|
154
|
+
|
|
155
|
+
// Capture URL pathname at action start to detect navigation during action
|
|
156
|
+
// Must use window.location (not store.path) because intercepts change URL
|
|
157
|
+
// without changing store.path (e.g., /kanban -> /kanban/card/1)
|
|
158
|
+
const actionStartPathname = window.location.pathname;
|
|
159
|
+
|
|
160
|
+
// Build action request URL with current segments
|
|
161
|
+
const url = new URL(window.location.href);
|
|
162
|
+
url.searchParams.set("_rsc_action", id);
|
|
163
|
+
url.searchParams.set(
|
|
164
|
+
"_rsc_segments",
|
|
165
|
+
segmentState.currentSegmentIds.join(","),
|
|
166
|
+
);
|
|
167
|
+
// Add version param for version mismatch detection
|
|
168
|
+
if (version) {
|
|
169
|
+
url.searchParams.set("_rsc_v", version);
|
|
170
|
+
}
|
|
141
171
|
|
|
142
|
-
|
|
172
|
+
// Encode arguments
|
|
173
|
+
const encodedBody = await deps.encodeReply(args, { temporaryReferences });
|
|
143
174
|
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
175
|
+
log("sending action request", {
|
|
176
|
+
url: url.href,
|
|
177
|
+
bodyType: typeof encodedBody,
|
|
178
|
+
isFormData: encodedBody instanceof FormData,
|
|
179
|
+
segmentCount: segmentState.currentSegmentIds.length,
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
// Track when the stream completes
|
|
183
|
+
let resolveStreamComplete: () => void;
|
|
184
|
+
const streamComplete = new Promise<void>((resolve) => {
|
|
185
|
+
resolveStreamComplete = resolve;
|
|
186
|
+
});
|
|
147
187
|
|
|
148
|
-
|
|
149
|
-
|
|
188
|
+
// Get intercept source URL if in intercept context
|
|
189
|
+
const interceptSourceUrl = store.getInterceptSourceUrl();
|
|
190
|
+
|
|
191
|
+
// Track streaming token - will be set when response arrives
|
|
192
|
+
let streamingToken: { end(): void } | null = null;
|
|
193
|
+
|
|
194
|
+
// Use a dedicated abort controller for the fetch so we can cancel network
|
|
195
|
+
// I/O without disrupting the Flight stream once the response has arrived.
|
|
196
|
+
// Aborting a response mid-stream causes React's Flight decoder to throw
|
|
197
|
+
// asynchronous unhandled errors (BodyStreamBuffer was aborted).
|
|
198
|
+
const fetchAbort = new AbortController();
|
|
199
|
+
const onHandleAbort = () => fetchAbort.abort();
|
|
200
|
+
handle.signal.addEventListener("abort", onHandleAbort, { once: true });
|
|
201
|
+
|
|
202
|
+
// Send action request with stream tracking
|
|
203
|
+
const responsePromise = fetch(url, {
|
|
204
|
+
method: "POST",
|
|
205
|
+
headers: {
|
|
206
|
+
"rsc-action": id,
|
|
207
|
+
"X-RSC-Router-Client-Path": segmentState.currentUrl,
|
|
208
|
+
...(tx && { "X-RSC-Router-Request-Id": tx.requestId }),
|
|
209
|
+
// Send intercept source URL so server can maintain intercept context
|
|
210
|
+
...(interceptSourceUrl && {
|
|
211
|
+
"X-RSC-Router-Intercept-Source": interceptSourceUrl,
|
|
212
|
+
}),
|
|
213
|
+
},
|
|
214
|
+
body: encodedBody,
|
|
215
|
+
signal: fetchAbort.signal,
|
|
216
|
+
}).then(async (response) => {
|
|
217
|
+
// Response arrived — disconnect fetch abort from handle abort so
|
|
218
|
+
// abortAllActions() doesn't disrupt the in-progress Flight stream.
|
|
219
|
+
handle.signal.removeEventListener("abort", onHandleAbort);
|
|
220
|
+
|
|
221
|
+
// Check for version mismatch - server wants us to reload
|
|
222
|
+
const reload = extractRscHeaderUrl(response, "X-RSC-Reload");
|
|
223
|
+
if (reload === "blocked") {
|
|
224
|
+
resolveStreamComplete();
|
|
225
|
+
return emptyResponse();
|
|
226
|
+
}
|
|
227
|
+
if (reload) {
|
|
228
|
+
log("version mismatch on action, reloading", {
|
|
229
|
+
reloadUrl: reload.url,
|
|
230
|
+
});
|
|
231
|
+
window.location.href = reload.url;
|
|
232
|
+
return new Promise<Response>(() => {});
|
|
233
|
+
}
|
|
150
234
|
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
235
|
+
// Simple redirect from action (no state, no RSC payload).
|
|
236
|
+
// Short-circuits before createFromFetch — no Flight deserialization needed.
|
|
237
|
+
// Check handle.signal.aborted to avoid redirecting from a stale action
|
|
238
|
+
// when the user has already navigated away.
|
|
239
|
+
const redirect = extractRscHeaderUrl(response, "X-RSC-Redirect");
|
|
240
|
+
if (redirect && redirect !== "blocked" && !handle.signal.aborted) {
|
|
241
|
+
log("action simple redirect", { url: redirect.url });
|
|
242
|
+
handle.complete(undefined);
|
|
243
|
+
if (onNavigate) {
|
|
244
|
+
await onNavigate(redirect.url, {
|
|
245
|
+
replace: true,
|
|
246
|
+
_skipCache: true,
|
|
247
|
+
});
|
|
248
|
+
} else {
|
|
249
|
+
window.location.href = redirect.url;
|
|
250
|
+
}
|
|
251
|
+
return new Promise<Response>(() => {});
|
|
252
|
+
}
|
|
253
|
+
if (redirect === "blocked") {
|
|
254
|
+
resolveStreamComplete();
|
|
255
|
+
return emptyResponse();
|
|
256
|
+
}
|
|
155
257
|
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
"_rsc_segments",
|
|
161
|
-
segmentState.currentSegmentIds.join(","),
|
|
162
|
-
);
|
|
163
|
-
// Add version param for version mismatch detection
|
|
164
|
-
if (version) {
|
|
165
|
-
url.searchParams.set("_rsc_v", version);
|
|
166
|
-
}
|
|
258
|
+
// Start streaming immediately when response arrives
|
|
259
|
+
if (!handle.signal.aborted) {
|
|
260
|
+
streamingToken = handle.startStreaming();
|
|
261
|
+
}
|
|
167
262
|
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
},
|
|
210
|
-
body: encodedBody,
|
|
211
|
-
signal: fetchAbort.signal,
|
|
212
|
-
}).then(async (response) => {
|
|
213
|
-
// Response arrived — disconnect fetch abort from handle abort so
|
|
214
|
-
// abortAllActions() doesn't disrupt the in-progress Flight stream.
|
|
215
|
-
handle.signal.removeEventListener("abort", onHandleAbort);
|
|
216
|
-
|
|
217
|
-
// Check for version mismatch - server wants us to reload
|
|
218
|
-
const reload = extractRscHeaderUrl(response, "X-RSC-Reload");
|
|
219
|
-
if (reload === "blocked") {
|
|
220
|
-
resolveStreamComplete();
|
|
221
|
-
return emptyResponse();
|
|
263
|
+
return teeWithCompletion(response, () => {
|
|
264
|
+
log("stream complete");
|
|
265
|
+
streamingToken?.end();
|
|
266
|
+
resolveStreamComplete();
|
|
267
|
+
});
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
// Deserialize response (MUST use same temporaryReferences)
|
|
271
|
+
let payload: RscPayload;
|
|
272
|
+
try {
|
|
273
|
+
payload = await deps.createFromFetch<RscPayload>(responsePromise, {
|
|
274
|
+
temporaryReferences,
|
|
275
|
+
});
|
|
276
|
+
} catch (error) {
|
|
277
|
+
// Clean up streaming token on error (may be null if fetch failed before .then() ran)
|
|
278
|
+
// The token is assigned in .then() callback which runs before this catch block,
|
|
279
|
+
// but TypeScript doesn't track cross-async assignments, so use type assertion
|
|
280
|
+
(streamingToken as { end(): void } | null)?.end();
|
|
281
|
+
// resolveStreamComplete is assigned in the Promise constructor so it's safe to call
|
|
282
|
+
resolveStreamComplete!();
|
|
283
|
+
|
|
284
|
+
// Silently swallow abort errors — the action was intentionally cancelled
|
|
285
|
+
// (e.g., user navigated away or abortAllActions was called).
|
|
286
|
+
// Return undefined instead of throwing to avoid surfacing as a page error.
|
|
287
|
+
// Check both DOMException AbortError and stream-level abort messages
|
|
288
|
+
// (BodyStreamBuffer was aborted) that propagate from the aborted fetch.
|
|
289
|
+
if (handle.signal.aborted) {
|
|
290
|
+
return undefined;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
// Convert network-level errors to NetworkError for proper handling
|
|
294
|
+
const networkError = toNetworkError(error, {
|
|
295
|
+
url: url.toString(),
|
|
296
|
+
operation: "action",
|
|
297
|
+
});
|
|
298
|
+
if (networkError) {
|
|
299
|
+
handle.fail(networkError);
|
|
300
|
+
emitNetworkError(onUpdate, networkError, segmentState.currentUrl);
|
|
301
|
+
throw networkError;
|
|
302
|
+
}
|
|
303
|
+
throw error;
|
|
222
304
|
}
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
305
|
+
|
|
306
|
+
log("action response received", {
|
|
307
|
+
isPartial: payload.metadata?.isPartial,
|
|
308
|
+
isError: payload.metadata?.isError,
|
|
309
|
+
matchedCount: payload.metadata?.matched?.length ?? 0,
|
|
310
|
+
diffCount: payload.metadata?.diff?.length ?? 0,
|
|
311
|
+
});
|
|
312
|
+
|
|
313
|
+
// Guard: if the action was aborted while streaming (e.g., user navigated
|
|
314
|
+
// away or abortAllActions fired), bail out before any reconcile/render/cache
|
|
315
|
+
// writes to avoid overwriting the current UI with stale action results.
|
|
316
|
+
if (handle.signal.aborted) {
|
|
317
|
+
log("action aborted after response, skipping reconciliation");
|
|
318
|
+
return undefined;
|
|
227
319
|
}
|
|
228
320
|
|
|
229
|
-
//
|
|
230
|
-
|
|
321
|
+
// Process response
|
|
322
|
+
const { metadata, returnValue } = payload;
|
|
323
|
+
|
|
324
|
+
// Handle action redirect: server converted the redirect to a Flight payload
|
|
325
|
+
// so we can perform SPA navigation instead of a full page reload.
|
|
231
326
|
// Check handle.signal.aborted to avoid redirecting from a stale action
|
|
232
327
|
// when the user has already navigated away.
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
328
|
+
if (metadata?.redirect && !handle.signal.aborted) {
|
|
329
|
+
const redirectUrl = validateRedirectOrigin(
|
|
330
|
+
metadata.redirect.url,
|
|
331
|
+
window.location.origin,
|
|
332
|
+
);
|
|
333
|
+
if (!redirectUrl) {
|
|
334
|
+
log("blocked action redirect payload", {
|
|
335
|
+
url: metadata.redirect.url,
|
|
336
|
+
});
|
|
337
|
+
handle.complete(returnValue?.data);
|
|
338
|
+
return returnValue?.data;
|
|
339
|
+
}
|
|
340
|
+
const redirectState = metadata.locationState;
|
|
341
|
+
log("action redirect", { url: redirectUrl });
|
|
342
|
+
handle.complete(returnValue?.data);
|
|
237
343
|
if (onNavigate) {
|
|
238
|
-
await onNavigate(
|
|
344
|
+
await onNavigate(redirectUrl, {
|
|
345
|
+
state: redirectState,
|
|
239
346
|
replace: true,
|
|
240
347
|
_skipCache: true,
|
|
241
348
|
});
|
|
242
349
|
} else {
|
|
243
|
-
window.location.href =
|
|
350
|
+
window.location.href = redirectUrl;
|
|
244
351
|
}
|
|
245
|
-
return
|
|
246
|
-
}
|
|
247
|
-
if (redirect === "blocked") {
|
|
248
|
-
resolveStreamComplete();
|
|
249
|
-
return emptyResponse();
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
// Start streaming immediately when response arrives
|
|
253
|
-
if (!handle.signal.aborted) {
|
|
254
|
-
streamingToken = handle.startStreaming();
|
|
352
|
+
return returnValue?.data;
|
|
255
353
|
}
|
|
256
354
|
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
});
|
|
262
|
-
});
|
|
263
|
-
|
|
264
|
-
// Deserialize response (MUST use same temporaryReferences)
|
|
265
|
-
let payload: RscPayload;
|
|
266
|
-
try {
|
|
267
|
-
payload = await deps.createFromFetch<RscPayload>(responsePromise, {
|
|
268
|
-
temporaryReferences,
|
|
269
|
-
});
|
|
270
|
-
} catch (error) {
|
|
271
|
-
// Clean up streaming token on error (may be null if fetch failed before .then() ran)
|
|
272
|
-
// The token is assigned in .then() callback which runs before this catch block,
|
|
273
|
-
// but TypeScript doesn't track cross-async assignments, so use type assertion
|
|
274
|
-
(streamingToken as { end(): void } | null)?.end();
|
|
275
|
-
// resolveStreamComplete is assigned in the Promise constructor so it's safe to call
|
|
276
|
-
resolveStreamComplete!();
|
|
277
|
-
|
|
278
|
-
// Silently swallow abort errors — the action was intentionally cancelled
|
|
279
|
-
// (e.g., user navigated away or abortAllActions was called).
|
|
280
|
-
// Return undefined instead of throwing to avoid surfacing as a page error.
|
|
281
|
-
// Check both DOMException AbortError and stream-level abort messages
|
|
282
|
-
// (BodyStreamBuffer was aborted) that propagate from the aborted fetch.
|
|
355
|
+
// Bail out if the action was aborted after deserialization (e.g. user
|
|
356
|
+
// navigated away or abortAllActions was called while the Flight stream
|
|
357
|
+
// was being consumed). Without this check the code below would mutate
|
|
358
|
+
// the store / UI for a stale action.
|
|
283
359
|
if (handle.signal.aborted) {
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
// Convert network-level errors to NetworkError for proper handling
|
|
288
|
-
const networkError = toNetworkError(error, {
|
|
289
|
-
url: url.toString(),
|
|
290
|
-
operation: "action",
|
|
291
|
-
});
|
|
292
|
-
if (networkError) {
|
|
293
|
-
handle.fail(networkError);
|
|
294
|
-
emitNetworkError(onUpdate, networkError, segmentState.currentUrl);
|
|
295
|
-
throw networkError;
|
|
360
|
+
log("action aborted after deserialization, skipping mutations");
|
|
361
|
+
return returnValue?.data;
|
|
296
362
|
}
|
|
297
|
-
throw error;
|
|
298
|
-
}
|
|
299
363
|
|
|
300
|
-
|
|
301
|
-
isPartial: payload.metadata?.isPartial,
|
|
302
|
-
isError: payload.metadata?.isError,
|
|
303
|
-
matchedCount: payload.metadata?.matched?.length ?? 0,
|
|
304
|
-
diffCount: payload.metadata?.diff?.length ?? 0,
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
// Guard: if the action was aborted while streaming (e.g., user navigated
|
|
308
|
-
// away or abortAllActions fired), bail out before any reconcile/render/cache
|
|
309
|
-
// writes to avoid overwriting the current UI with stale action results.
|
|
310
|
-
if (handle.signal.aborted) {
|
|
311
|
-
log("action aborted after response, skipping reconciliation");
|
|
312
|
-
return undefined;
|
|
313
|
-
}
|
|
364
|
+
const { matched, diff, segments, isPartial, isError } = metadata || {};
|
|
314
365
|
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
// Handle action redirect: server converted the redirect to a Flight payload
|
|
319
|
-
// so we can perform SPA navigation instead of a full page reload.
|
|
320
|
-
// Check handle.signal.aborted to avoid redirecting from a stale action
|
|
321
|
-
// when the user has already navigated away.
|
|
322
|
-
if (metadata?.redirect && !handle.signal.aborted) {
|
|
323
|
-
const redirectUrl = validateRedirectOrigin(
|
|
324
|
-
metadata.redirect.url,
|
|
325
|
-
window.location.origin,
|
|
326
|
-
);
|
|
327
|
-
if (!redirectUrl) {
|
|
328
|
-
log("blocked action redirect payload", { url: metadata.redirect.url });
|
|
329
|
-
handle.complete(returnValue?.data);
|
|
330
|
-
return returnValue?.data;
|
|
331
|
-
}
|
|
332
|
-
const redirectState = metadata.locationState;
|
|
333
|
-
log("action redirect", { url: redirectUrl });
|
|
334
|
-
handle.complete(returnValue?.data);
|
|
335
|
-
if (onNavigate) {
|
|
336
|
-
await onNavigate(redirectUrl, {
|
|
337
|
-
state: redirectState,
|
|
338
|
-
replace: true,
|
|
339
|
-
_skipCache: true,
|
|
340
|
-
});
|
|
341
|
-
} else {
|
|
342
|
-
window.location.href = redirectUrl;
|
|
366
|
+
// Log action result
|
|
367
|
+
if (returnValue && !returnValue.ok) {
|
|
368
|
+
console.error(`[Browser] Action failed:`, returnValue.data);
|
|
343
369
|
}
|
|
344
|
-
return returnValue?.data;
|
|
345
|
-
}
|
|
346
370
|
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
// the store / UI for a stale action.
|
|
351
|
-
if (handle.signal.aborted) {
|
|
352
|
-
log("action aborted after deserialization, skipping mutations");
|
|
353
|
-
return returnValue?.data;
|
|
354
|
-
}
|
|
371
|
+
// Handle error responses with error boundary UI
|
|
372
|
+
if (isError && isPartial && segments && diff) {
|
|
373
|
+
log("processing error boundary response");
|
|
355
374
|
|
|
356
|
-
|
|
375
|
+
// Fail current handle BEFORE aborting all actions so the event controller
|
|
376
|
+
// records the error state (abortAllActions clears inflight entries)
|
|
377
|
+
if (returnValue && !returnValue.ok) {
|
|
378
|
+
handle.fail(returnValue.data);
|
|
379
|
+
}
|
|
357
380
|
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
}
|
|
381
|
+
// Abort all other pending action requests - error takes precedence
|
|
382
|
+
// This prevents other actions from completing and overwriting the error UI
|
|
383
|
+
eventController.abortAllActions();
|
|
362
384
|
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
log("processing error boundary response");
|
|
385
|
+
// Clear concurrent action tracking - no consolidation needed when showing error
|
|
386
|
+
handle.clearConsolidation();
|
|
366
387
|
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
}
|
|
388
|
+
// Get current page's cached segments
|
|
389
|
+
const currentKey = store.getHistoryKey();
|
|
390
|
+
const cached = store.getCachedSegments(currentKey);
|
|
391
|
+
const cachedSegments = cached?.segments || [];
|
|
372
392
|
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
eventController.abortAllActions();
|
|
393
|
+
// Reconcile error segments with cached tree
|
|
394
|
+
const errorResult = reconcileErrorSegments(cachedSegments, segments);
|
|
376
395
|
|
|
377
|
-
|
|
378
|
-
|
|
396
|
+
// Render the full tree with error segment merged with parent layouts
|
|
397
|
+
const errorTree = await renderSegments(errorResult.mainSegments, {
|
|
398
|
+
isAction: true,
|
|
399
|
+
interceptSegments:
|
|
400
|
+
errorResult.interceptSegments.length > 0
|
|
401
|
+
? errorResult.interceptSegments
|
|
402
|
+
: undefined,
|
|
403
|
+
});
|
|
379
404
|
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
405
|
+
// Re-check route stability after async renderSegments — user may have
|
|
406
|
+
// navigated away while the error tree was being prepared.
|
|
407
|
+
if (window.location.pathname !== actionStartPathname) {
|
|
408
|
+
log("user navigated during error render, skipping");
|
|
409
|
+
if (returnValue && !returnValue.ok) {
|
|
410
|
+
throw returnValue.data;
|
|
411
|
+
}
|
|
412
|
+
handle.complete(undefined);
|
|
413
|
+
return undefined;
|
|
414
|
+
}
|
|
415
|
+
const currentKeyNow = store.getHistoryKey();
|
|
416
|
+
if (currentKeyNow !== currentKey) {
|
|
417
|
+
log("history key changed during error render, skipping cache update");
|
|
418
|
+
if (returnValue && !returnValue.ok) {
|
|
419
|
+
throw returnValue.data;
|
|
420
|
+
}
|
|
421
|
+
handle.complete(undefined);
|
|
422
|
+
return undefined;
|
|
423
|
+
}
|
|
384
424
|
|
|
385
|
-
|
|
386
|
-
|
|
425
|
+
// Update UI with error boundary
|
|
426
|
+
startTransition(() => {
|
|
427
|
+
onUpdate({ root: errorTree, metadata: metadata! });
|
|
428
|
+
});
|
|
387
429
|
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
? errorResult.interceptSegments
|
|
394
|
-
: undefined,
|
|
395
|
-
});
|
|
430
|
+
// Update segment tracking to exclude error segment IDs
|
|
431
|
+
const errorSegmentIds = new Set(diff);
|
|
432
|
+
const segmentIdsAfterError = segmentState.currentSegmentIds.filter(
|
|
433
|
+
(id) => !errorSegmentIds.has(id),
|
|
434
|
+
);
|
|
396
435
|
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
436
|
+
// Update store state
|
|
437
|
+
store.setSegmentIds(segmentIdsAfterError);
|
|
438
|
+
const currentHandleData = eventController.getHandleState().data;
|
|
439
|
+
store.cacheSegmentsForHistory(
|
|
440
|
+
currentKey,
|
|
441
|
+
errorResult.segments,
|
|
442
|
+
currentHandleData,
|
|
443
|
+
);
|
|
444
|
+
|
|
445
|
+
// Throw the error so the action promise rejects
|
|
401
446
|
if (returnValue && !returnValue.ok) {
|
|
402
447
|
throw returnValue.data;
|
|
403
448
|
}
|
|
449
|
+
|
|
450
|
+
// No error in returnValue (shouldn't happen with isError: true)
|
|
404
451
|
handle.complete(undefined);
|
|
405
452
|
return undefined;
|
|
406
453
|
}
|
|
407
|
-
|
|
408
|
-
if (
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
454
|
+
|
|
455
|
+
if (!isPartial) {
|
|
456
|
+
// Protocol invariant: action revalidation responses MUST be partial.
|
|
457
|
+
// The server always sends isPartial: true for successful revalidation
|
|
458
|
+
// and isPartial: true + isError: true for error boundary responses.
|
|
459
|
+
// A non-partial payload here indicates a server-side bug.
|
|
460
|
+
throw new Error(
|
|
461
|
+
`[Browser] Action response missing isPartial — the server must ` +
|
|
462
|
+
`always send partial payloads for action revalidation.`,
|
|
463
|
+
);
|
|
415
464
|
}
|
|
416
465
|
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
466
|
+
log("processing partial update", {
|
|
467
|
+
serverSegments: segments?.length ?? 0,
|
|
468
|
+
diff: diff?.join(", ") ?? "",
|
|
469
|
+
matched: matched?.join(", ") ?? "",
|
|
420
470
|
});
|
|
421
471
|
|
|
422
|
-
//
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
);
|
|
472
|
+
// Record revalidated segments for concurrent action tracking
|
|
473
|
+
if (diff) {
|
|
474
|
+
handle.recordRevalidatedSegments(diff);
|
|
475
|
+
}
|
|
427
476
|
|
|
428
|
-
//
|
|
429
|
-
store.
|
|
430
|
-
const
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
477
|
+
// Get current page's cached segments for merging
|
|
478
|
+
const currentKey = store.getHistoryKey();
|
|
479
|
+
const cached = store.getCachedSegments(currentKey);
|
|
480
|
+
const cachedSegments = cached?.segments || [];
|
|
481
|
+
|
|
482
|
+
if (!matched) {
|
|
483
|
+
throw new Error("No matched segments in response");
|
|
484
|
+
}
|
|
485
|
+
|
|
486
|
+
// Reconcile server segments with cached segments (single source of truth)
|
|
487
|
+
const reconciled = reconcileSegments({
|
|
488
|
+
actor: "action",
|
|
489
|
+
matched,
|
|
490
|
+
diff: diff || [],
|
|
491
|
+
serverSegments: segments || [],
|
|
492
|
+
cachedSegments,
|
|
493
|
+
});
|
|
494
|
+
const fullSegments = reconciled.segments;
|
|
495
|
+
|
|
496
|
+
const returnData = returnValue?.data;
|
|
436
497
|
|
|
437
|
-
// Throw the error so the action promise rejects
|
|
438
498
|
if (returnValue && !returnValue.ok) {
|
|
499
|
+
handle.fail(returnValue.data);
|
|
439
500
|
throw returnValue.data;
|
|
440
501
|
}
|
|
441
502
|
|
|
442
|
-
//
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
);
|
|
456
|
-
}
|
|
503
|
+
// Classify the post-reconciliation scenario
|
|
504
|
+
const scenario = classifyActionOutcome({
|
|
505
|
+
handleId: handle.id,
|
|
506
|
+
inflightActions: eventController.getInflightActions(),
|
|
507
|
+
hadAnyConcurrentActions: eventController.hadAnyConcurrentActions(),
|
|
508
|
+
revalidatedSegments: handle.getRevalidatedSegments(),
|
|
509
|
+
actionStartPathname,
|
|
510
|
+
currentPathname: window.location.pathname,
|
|
511
|
+
actionStartLocationKey: locationKey,
|
|
512
|
+
currentLocationKey: window.history.state?.key,
|
|
513
|
+
reconciledSegmentCount: fullSegments.length,
|
|
514
|
+
matchedCount: matched.length,
|
|
515
|
+
currentInterceptSource: store.getInterceptSourceUrl(),
|
|
516
|
+
});
|
|
457
517
|
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
518
|
+
switch (scenario.type) {
|
|
519
|
+
case "navigated-away": {
|
|
520
|
+
log("user navigated away during action", {
|
|
521
|
+
from: actionStartPathname,
|
|
522
|
+
to: window.location.pathname,
|
|
523
|
+
historyKeyChanged: scenario.historyKeyChanged,
|
|
524
|
+
});
|
|
525
|
+
// Clear concurrent action tracking - don't consolidate for old route's segments
|
|
526
|
+
handle.clearConsolidation();
|
|
527
|
+
|
|
528
|
+
if (scenario.historyKeyChanged) {
|
|
529
|
+
if (!scenario.onInterceptRoute) {
|
|
530
|
+
store.markCacheAsStaleAndBroadcast();
|
|
531
|
+
refetchRoute().catch((error) => {
|
|
532
|
+
if (isBackgroundSuppressible(error)) return;
|
|
533
|
+
console.error(
|
|
534
|
+
"[Browser] Background revalidation failed:",
|
|
535
|
+
error,
|
|
536
|
+
);
|
|
537
|
+
});
|
|
538
|
+
}
|
|
539
|
+
break;
|
|
540
|
+
}
|
|
463
541
|
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
542
|
+
// Same history key but different pathname - safe to refetch current route
|
|
543
|
+
store.markCacheAsStaleAndBroadcast();
|
|
544
|
+
await refetchRoute({
|
|
545
|
+
interceptSourceUrl: store.getInterceptSourceUrl(),
|
|
546
|
+
});
|
|
547
|
+
break;
|
|
548
|
+
}
|
|
468
549
|
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
550
|
+
case "hmr-missing": {
|
|
551
|
+
console.warn(
|
|
552
|
+
`[Browser] Missing segments after action (HMR detected), refetching...`,
|
|
553
|
+
);
|
|
554
|
+
await refetchRoute({ interceptSourceUrl });
|
|
555
|
+
store.broadcastCacheInvalidation();
|
|
556
|
+
break;
|
|
557
|
+
}
|
|
473
558
|
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
559
|
+
case "consolidation-needed": {
|
|
560
|
+
log("consolidation fetch needed", {
|
|
561
|
+
segmentIds: scenario.segmentIds,
|
|
562
|
+
});
|
|
563
|
+
// Calculate segments to send (exclude the ones we want fresh)
|
|
564
|
+
const currentSegmentIds = store.getSegmentState().currentSegmentIds;
|
|
565
|
+
const segmentsToSend = currentSegmentIds.filter(
|
|
566
|
+
(sid) => !scenario.segmentIds.includes(sid),
|
|
567
|
+
);
|
|
477
568
|
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
actor: "action",
|
|
481
|
-
matched,
|
|
482
|
-
diff: diff || [],
|
|
483
|
-
serverSegments: segments || [],
|
|
484
|
-
cachedSegments,
|
|
485
|
-
});
|
|
486
|
-
const fullSegments = reconciled.segments;
|
|
487
|
-
|
|
488
|
-
const returnData = returnValue?.data;
|
|
489
|
-
|
|
490
|
-
if (returnValue && !returnValue.ok) {
|
|
491
|
-
handle.fail(returnValue.data);
|
|
492
|
-
throw returnValue.data;
|
|
493
|
-
}
|
|
569
|
+
// Clear consolidation tracking before fetch
|
|
570
|
+
handle.clearConsolidation();
|
|
494
571
|
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
currentPathname: window.location.pathname,
|
|
503
|
-
actionStartLocationKey: locationKey,
|
|
504
|
-
currentLocationKey: window.history.state?.key,
|
|
505
|
-
reconciledSegmentCount: fullSegments.length,
|
|
506
|
-
matchedCount: matched.length,
|
|
507
|
-
currentInterceptSource: store.getInterceptSourceUrl(),
|
|
508
|
-
});
|
|
509
|
-
|
|
510
|
-
switch (scenario.type) {
|
|
511
|
-
case "navigated-away": {
|
|
512
|
-
log("user navigated away during action", {
|
|
513
|
-
from: actionStartPathname,
|
|
514
|
-
to: window.location.pathname,
|
|
515
|
-
historyKeyChanged: scenario.historyKeyChanged,
|
|
516
|
-
});
|
|
517
|
-
// Clear concurrent action tracking - don't consolidate for old route's segments
|
|
518
|
-
handle.clearConsolidation();
|
|
572
|
+
await refetchRoute({
|
|
573
|
+
segments: segmentsToSend,
|
|
574
|
+
interceptSourceUrl,
|
|
575
|
+
});
|
|
576
|
+
store.broadcastCacheInvalidation();
|
|
577
|
+
break;
|
|
578
|
+
}
|
|
519
579
|
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
580
|
+
case "concurrent-skip": {
|
|
581
|
+
log("skipping UI update, other actions fetching", {
|
|
582
|
+
otherCount: scenario.otherFetchingCount,
|
|
583
|
+
});
|
|
584
|
+
// Only update store if history key hasn't changed (user didn't navigate away)
|
|
585
|
+
const currentKeyNow = store.getHistoryKey();
|
|
586
|
+
if (currentKeyNow === currentKey) {
|
|
587
|
+
store.setSegmentIds(matched);
|
|
588
|
+
const currentHandleData = eventController.getHandleState().data;
|
|
589
|
+
store.cacheSegmentsForHistory(
|
|
590
|
+
currentKey,
|
|
591
|
+
fullSegments,
|
|
592
|
+
currentHandleData,
|
|
593
|
+
);
|
|
527
594
|
}
|
|
528
595
|
break;
|
|
529
596
|
}
|
|
530
597
|
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
598
|
+
case "normal": {
|
|
599
|
+
// Prepare new tree (await loader data resolution)
|
|
600
|
+
const newTree = await renderSegments(reconciled.mainSegments, {
|
|
601
|
+
isAction: true,
|
|
602
|
+
interceptSegments:
|
|
603
|
+
reconciled.interceptSegments.length > 0
|
|
604
|
+
? reconciled.interceptSegments
|
|
605
|
+
: undefined,
|
|
606
|
+
});
|
|
538
607
|
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
store.broadcastCacheInvalidation();
|
|
545
|
-
break;
|
|
546
|
-
}
|
|
608
|
+
// Re-check if user navigated away (could happen during async renderSegments)
|
|
609
|
+
if (window.location.pathname !== actionStartPathname) {
|
|
610
|
+
log("user navigated during render, skipping");
|
|
611
|
+
break;
|
|
612
|
+
}
|
|
547
613
|
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
614
|
+
// Verify the store's current key still matches what we captured at action start
|
|
615
|
+
// If they differ, user navigated away and we should NOT cache under the old key
|
|
616
|
+
const currentKeyNow = store.getHistoryKey();
|
|
617
|
+
if (currentKeyNow !== currentKey) {
|
|
618
|
+
log("history key changed during action, skipping cache update");
|
|
619
|
+
break;
|
|
620
|
+
}
|
|
555
621
|
|
|
556
|
-
|
|
557
|
-
|
|
622
|
+
startTransition(() => {
|
|
623
|
+
onUpdate({ root: newTree, metadata: metadata! });
|
|
624
|
+
});
|
|
558
625
|
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
break;
|
|
565
|
-
}
|
|
626
|
+
// Apply server-set location state to history.state (non-redirect flow)
|
|
627
|
+
const actionLocationState = metadata?.locationState;
|
|
628
|
+
if (actionLocationState) {
|
|
629
|
+
mergeLocationState(actionLocationState);
|
|
630
|
+
}
|
|
566
631
|
|
|
567
|
-
|
|
568
|
-
log("skipping UI update, other actions fetching", {
|
|
569
|
-
otherCount: scenario.otherFetchingCount,
|
|
570
|
-
});
|
|
571
|
-
// Only update store if history key hasn't changed (user didn't navigate away)
|
|
572
|
-
const currentKeyNow = store.getHistoryKey();
|
|
573
|
-
if (currentKeyNow === currentKey) {
|
|
632
|
+
// Update store state
|
|
574
633
|
store.setSegmentIds(matched);
|
|
575
634
|
const currentHandleData = eventController.getHandleState().data;
|
|
576
635
|
store.cacheSegmentsForHistory(
|
|
@@ -578,59 +637,16 @@ export function createServerActionBridge(
|
|
|
578
637
|
fullSegments,
|
|
579
638
|
currentHandleData,
|
|
580
639
|
);
|
|
581
|
-
|
|
582
|
-
break;
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
case "normal": {
|
|
586
|
-
// Prepare new tree (await loader data resolution)
|
|
587
|
-
const newTree = await renderSegments(reconciled.mainSegments, {
|
|
588
|
-
isAction: true,
|
|
589
|
-
interceptSegments:
|
|
590
|
-
reconciled.interceptSegments.length > 0
|
|
591
|
-
? reconciled.interceptSegments
|
|
592
|
-
: undefined,
|
|
593
|
-
});
|
|
594
|
-
|
|
595
|
-
// Re-check if user navigated away (could happen during async renderSegments)
|
|
596
|
-
if (window.location.pathname !== actionStartPathname) {
|
|
597
|
-
log("user navigated during render, skipping");
|
|
598
|
-
break;
|
|
599
|
-
}
|
|
600
|
-
|
|
601
|
-
// Verify the store's current key still matches what we captured at action start
|
|
602
|
-
// If they differ, user navigated away and we should NOT cache under the old key
|
|
603
|
-
const currentKeyNow = store.getHistoryKey();
|
|
604
|
-
if (currentKeyNow !== currentKey) {
|
|
605
|
-
log("history key changed during action, skipping cache update");
|
|
640
|
+
store.markCacheAsStaleAndBroadcast();
|
|
606
641
|
break;
|
|
607
642
|
}
|
|
608
|
-
|
|
609
|
-
startTransition(() => {
|
|
610
|
-
onUpdate({ root: newTree, metadata: metadata! });
|
|
611
|
-
});
|
|
612
|
-
|
|
613
|
-
// Apply server-set location state to history.state (non-redirect flow)
|
|
614
|
-
const actionLocationState = metadata?.locationState;
|
|
615
|
-
if (actionLocationState) {
|
|
616
|
-
mergeLocationState(actionLocationState);
|
|
617
|
-
}
|
|
618
|
-
|
|
619
|
-
// Update store state
|
|
620
|
-
store.setSegmentIds(matched);
|
|
621
|
-
const currentHandleData = eventController.getHandleState().data;
|
|
622
|
-
store.cacheSegmentsForHistory(
|
|
623
|
-
currentKey,
|
|
624
|
-
fullSegments,
|
|
625
|
-
currentHandleData,
|
|
626
|
-
);
|
|
627
|
-
store.markCacheAsStaleAndBroadcast();
|
|
628
|
-
break;
|
|
629
643
|
}
|
|
630
|
-
}
|
|
631
644
|
|
|
632
|
-
|
|
633
|
-
|
|
645
|
+
handle.complete(returnData);
|
|
646
|
+
return returnData;
|
|
647
|
+
} finally {
|
|
648
|
+
handle[Symbol.dispose]();
|
|
649
|
+
}
|
|
634
650
|
}
|
|
635
651
|
|
|
636
652
|
return {
|