@rangojs/router 0.0.0-experimental.debug-cache-fix → 0.0.0-experimental.dfa55db4
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/README.md +76 -18
- 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 +130 -47
- 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 +687 -231
- package/dist/vite/index.js.bak +5448 -0
- 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 +2 -2
- package/skills/cache-guide/SKILL.md +32 -0
- package/skills/caching/SKILL.md +8 -0
- package/skills/links/SKILL.md +3 -1
- package/skills/loader/SKILL.md +53 -43
- package/skills/middleware/SKILL.md +2 -0
- package/skills/prerender/SKILL.md +110 -68
- package/skills/route/SKILL.md +31 -0
- package/skills/router-setup/SKILL.md +87 -2
- package/skills/typesafety/SKILL.md +10 -0
- package/src/__internal.ts +1 -1
- package/src/browser/app-version.ts +14 -0
- package/src/browser/navigation-bridge.ts +16 -3
- package/src/browser/navigation-client.ts +64 -40
- package/src/browser/navigation-store.ts +43 -8
- package/src/browser/partial-update.ts +27 -5
- package/src/browser/prefetch/fetch.ts +8 -2
- package/src/browser/prefetch/queue.ts +61 -29
- package/src/browser/prefetch/resource-ready.ts +77 -0
- package/src/browser/react/Link.tsx +44 -8
- package/src/browser/react/NavigationProvider.tsx +13 -4
- package/src/browser/react/context.ts +7 -2
- package/src/browser/react/use-handle.ts +9 -58
- package/src/browser/react/use-router.ts +21 -8
- package/src/browser/rsc-router.tsx +26 -3
- package/src/browser/scroll-restoration.ts +10 -8
- package/src/browser/server-action-bridge.ts +8 -6
- package/src/browser/types.ts +27 -5
- package/src/build/generate-manifest.ts +6 -6
- package/src/build/generate-route-types.ts +3 -0
- package/src/build/route-types/include-resolution.ts +8 -1
- package/src/build/route-types/router-processing.ts +211 -72
- package/src/build/route-types/scan-filter.ts +8 -1
- package/src/cache/cache-scope.ts +12 -14
- package/src/cache/taint.ts +55 -0
- package/src/client.tsx +2 -56
- package/src/context-var.ts +72 -2
- package/src/handle.ts +40 -0
- package/src/index.rsc.ts +3 -1
- package/src/index.ts +12 -0
- package/src/prerender/store.ts +5 -4
- package/src/prerender.ts +138 -77
- package/src/reverse.ts +22 -1
- package/src/route-definition/dsl-helpers.ts +42 -19
- package/src/route-definition/helpers-types.ts +10 -6
- package/src/route-definition/index.ts +3 -0
- package/src/route-definition/redirect.ts +9 -1
- package/src/route-definition/resolve-handler-use.ts +149 -0
- package/src/route-types.ts +11 -0
- package/src/router/content-negotiation.ts +100 -1
- package/src/router/handler-context.ts +79 -23
- package/src/router/intercept-resolution.ts +9 -4
- package/src/router/loader-resolution.ts +156 -21
- package/src/router/match-api.ts +124 -189
- package/src/router/match-middleware/cache-lookup.ts +26 -7
- package/src/router/match-middleware/segment-resolution.ts +53 -0
- package/src/router/middleware-types.ts +6 -8
- package/src/router/middleware.ts +2 -5
- package/src/router/navigation-snapshot.ts +182 -0
- package/src/router/prerender-match.ts +110 -10
- package/src/router/preview-match.ts +30 -102
- package/src/router/request-classification.ts +310 -0
- package/src/router/route-snapshot.ts +245 -0
- package/src/router/router-interfaces.ts +36 -4
- package/src/router/router-options.ts +37 -11
- package/src/router/segment-resolution/fresh.ts +75 -9
- package/src/router/segment-resolution/helpers.ts +29 -24
- package/src/router/segment-resolution/revalidation.ts +84 -7
- package/src/router/types.ts +1 -0
- package/src/router.ts +54 -5
- package/src/rsc/handler.ts +464 -368
- package/src/rsc/loader-fetch.ts +23 -3
- package/src/rsc/manifest-init.ts +5 -1
- package/src/rsc/progressive-enhancement.ts +14 -2
- package/src/rsc/rsc-rendering.ts +10 -1
- package/src/rsc/server-action.ts +8 -0
- package/src/rsc/ssr-setup.ts +2 -2
- package/src/rsc/types.ts +9 -1
- package/src/server/context.ts +50 -1
- package/src/server/handle-store.ts +19 -0
- package/src/server/loader-registry.ts +9 -8
- package/src/server/request-context.ts +175 -15
- package/src/ssr/index.tsx +3 -0
- package/src/static-handler.ts +18 -6
- package/src/types/cache-types.ts +4 -4
- package/src/types/handler-context.ts +37 -19
- package/src/types/loader-types.ts +36 -9
- package/src/types/route-entry.ts +1 -1
- package/src/urls/path-helper-types.ts +9 -2
- package/src/urls/path-helper.ts +47 -12
- package/src/urls/pattern-types.ts +12 -0
- package/src/urls/response-types.ts +16 -6
- package/src/use-loader.tsx +73 -4
- package/src/vite/discovery/bundle-postprocess.ts +30 -33
- package/src/vite/discovery/discover-routers.ts +5 -1
- package/src/vite/discovery/prerender-collection.ts +128 -74
- package/src/vite/discovery/state.ts +13 -4
- package/src/vite/index.ts +4 -0
- package/src/vite/plugin-types.ts +60 -5
- package/src/vite/plugins/expose-ids/handler-transform.ts +30 -0
- package/src/vite/plugins/expose-internal-ids.ts +231 -39
- package/src/vite/plugins/performance-tracks.ts +88 -0
- package/src/vite/plugins/refresh-cmd.ts +88 -26
- package/src/vite/rango.ts +19 -2
- package/src/vite/router-discovery.ts +178 -37
- package/src/vite/utils/prerender-utils.ts +18 -0
- package/src/vite/utils/shared-utils.ts +3 -2
package/src/rsc/handler.ts
CHANGED
|
@@ -14,10 +14,10 @@ import {
|
|
|
14
14
|
runWithRequestContext,
|
|
15
15
|
setRequestContextParams,
|
|
16
16
|
requireRequestContext,
|
|
17
|
+
getRequestContext,
|
|
17
18
|
createRequestContext,
|
|
18
19
|
} from "../server/request-context.js";
|
|
19
20
|
import * as rscDeps from "@vitejs/plugin-rsc/rsc";
|
|
20
|
-
|
|
21
21
|
import type {
|
|
22
22
|
RscPayload,
|
|
23
23
|
CreateRSCHandlerOptions,
|
|
@@ -82,6 +82,11 @@ import {
|
|
|
82
82
|
mayNeedSSR,
|
|
83
83
|
SSR_SETUP_VAR,
|
|
84
84
|
} from "./ssr-setup.js";
|
|
85
|
+
import {
|
|
86
|
+
classifyRequest,
|
|
87
|
+
type RequestPlan,
|
|
88
|
+
type ExecutableRequestPlan,
|
|
89
|
+
} from "../router/request-classification.js";
|
|
85
90
|
|
|
86
91
|
/**
|
|
87
92
|
* Create an RSC request handler.
|
|
@@ -452,6 +457,9 @@ export function createRSCHandler<
|
|
|
452
457
|
// - Server components during rendering
|
|
453
458
|
// - Error boundaries
|
|
454
459
|
// - Streaming
|
|
460
|
+
// Store basename on request context (scoped per-request via existing ALS)
|
|
461
|
+
requestContext._basename = router.basename;
|
|
462
|
+
|
|
455
463
|
return runWithRequestContext(requestContext, async () => {
|
|
456
464
|
// Core handler logic (wrapped by middleware)
|
|
457
465
|
const coreHandler = async (): Promise<Response> => {
|
|
@@ -527,7 +535,9 @@ export function createRSCHandler<
|
|
|
527
535
|
});
|
|
528
536
|
};
|
|
529
537
|
|
|
530
|
-
// Core request handling logic (separated for middleware wrapping)
|
|
538
|
+
// Core request handling logic (separated for middleware wrapping).
|
|
539
|
+
// Uses the classify → execute model: classifyRequest produces a RequestPlan,
|
|
540
|
+
// then execution dispatches on the plan mode.
|
|
531
541
|
async function coreRequestHandler(
|
|
532
542
|
request: Request,
|
|
533
543
|
env: TEnv,
|
|
@@ -535,71 +545,112 @@ export function createRSCHandler<
|
|
|
535
545
|
variables: Record<string, any>,
|
|
536
546
|
nonce: string | undefined,
|
|
537
547
|
): Promise<Response> {
|
|
538
|
-
const previewStart = performance.now();
|
|
539
|
-
const preview = await router.previewMatch(request, { env });
|
|
540
|
-
const previewDur = performance.now() - previewStart;
|
|
541
548
|
const handlerTiming: string[] = variables.__handlerTiming || [];
|
|
542
|
-
|
|
543
|
-
//
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
549
|
+
|
|
550
|
+
// Debug manifest endpoint: handled before classification since it
|
|
551
|
+
// doesn't need a route match and needs trie access from the closure.
|
|
552
|
+
const isDev = process.env.NODE_ENV !== "production";
|
|
553
|
+
if (
|
|
554
|
+
url.searchParams.has("__debug_manifest") &&
|
|
555
|
+
(isDev || router.allowDebugManifest)
|
|
556
|
+
) {
|
|
557
|
+
const trie = getRouterTrie(router.id) ?? getRouteTrie();
|
|
558
|
+
const routeManifest = getRequiredRouteMap();
|
|
559
|
+
const { extractAncestryFromTrie } =
|
|
560
|
+
await import("../build/route-trie.js");
|
|
561
|
+
return new Response(
|
|
562
|
+
JSON.stringify(
|
|
563
|
+
{
|
|
564
|
+
routerId: router.id,
|
|
565
|
+
routeManifest,
|
|
566
|
+
routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
|
|
567
|
+
routeTrie: trie,
|
|
568
|
+
precomputedEntries: getPrecomputedEntries(),
|
|
569
|
+
},
|
|
570
|
+
null,
|
|
571
|
+
2,
|
|
553
572
|
),
|
|
554
|
-
|
|
555
|
-
|
|
573
|
+
{
|
|
574
|
+
headers: { "Content-Type": "application/json" },
|
|
575
|
+
},
|
|
556
576
|
);
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
577
|
+
}
|
|
578
|
+
|
|
579
|
+
// ---- 1. Classify ----
|
|
580
|
+
// classifyRequest may throw RouteNotFoundError for unknown routes.
|
|
581
|
+
// In that case, fall through to a full-render plan so the pipeline
|
|
582
|
+
// can render the 404 page via the existing error handling path.
|
|
583
|
+
const classifyStart = performance.now();
|
|
584
|
+
let plan: RequestPlan<TEnv>;
|
|
585
|
+
try {
|
|
586
|
+
plan = await classifyRequest<TEnv>(request, url, {
|
|
587
|
+
findMatch: router.findMatch,
|
|
588
|
+
routerVersion: version,
|
|
589
|
+
routerId: router.id,
|
|
590
|
+
});
|
|
591
|
+
} catch (error) {
|
|
592
|
+
if (
|
|
593
|
+
error instanceof RouteNotFoundError ||
|
|
594
|
+
(error instanceof Error && error.name === "RouteNotFoundError")
|
|
595
|
+
) {
|
|
596
|
+
// Let the render path handle 404 — match()/matchPartial() will
|
|
597
|
+
// re-throw RouteNotFoundError and the catch block in
|
|
598
|
+
// executeRenderWithMiddleware renders the not-found page.
|
|
599
|
+
plan = {
|
|
600
|
+
mode: "full-render",
|
|
601
|
+
route: {
|
|
602
|
+
matched: null as any,
|
|
603
|
+
manifestEntry: null as any,
|
|
604
|
+
entries: [],
|
|
605
|
+
routeKey: "",
|
|
606
|
+
localRouteName: "",
|
|
607
|
+
params: {},
|
|
608
|
+
routeMiddleware: [],
|
|
609
|
+
cacheScope: null,
|
|
610
|
+
isPassthrough: false,
|
|
611
|
+
},
|
|
612
|
+
negotiated: false,
|
|
613
|
+
};
|
|
614
|
+
} else {
|
|
615
|
+
throw error;
|
|
616
|
+
}
|
|
617
|
+
}
|
|
618
|
+
const classifyDur = performance.now() - classifyStart;
|
|
619
|
+
handlerTiming.push(`handler-classify;dur=${classifyDur.toFixed(2)}`);
|
|
620
|
+
|
|
621
|
+
// ---- 2. Terminal plans (no execution needed) ----
|
|
622
|
+
if (plan.mode === "redirect") {
|
|
623
|
+
// Redirects are handled by the pipeline (match/matchPartial),
|
|
624
|
+
// but for partial requests we short-circuit with a Flight redirect.
|
|
625
|
+
if (url.searchParams.has("_rsc_partial")) {
|
|
626
|
+
return createRedirectFlightResponse(plan.redirectUrl);
|
|
566
627
|
}
|
|
567
|
-
|
|
628
|
+
// Full requests: let the pipeline handle the redirect via match()
|
|
629
|
+
// which returns { redirect: url }. Fall through to full-render.
|
|
568
630
|
}
|
|
569
631
|
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
if (mayNeedSSR(request, url)) {
|
|
574
|
-
variables[SSR_SETUP_VAR] = startSSRSetup(
|
|
575
|
-
handlerCtx,
|
|
576
|
-
request,
|
|
577
|
-
env,
|
|
578
|
-
url,
|
|
579
|
-
router.debugPerformance
|
|
580
|
-
? () => requireRequestContext()._metricsStore
|
|
581
|
-
: undefined,
|
|
632
|
+
if (plan.mode === "version-mismatch") {
|
|
633
|
+
console.log(
|
|
634
|
+
`[RSC] Version mismatch: client=${url.searchParams.get("_rsc_v")}, server=${version}. Forcing reload.`,
|
|
582
635
|
);
|
|
636
|
+
return createResponseWithMergedHeaders(null, {
|
|
637
|
+
status: 200,
|
|
638
|
+
headers: {
|
|
639
|
+
"X-RSC-Reload": plan.reloadUrl,
|
|
640
|
+
"content-type": "text/x-component;charset=utf-8",
|
|
641
|
+
},
|
|
642
|
+
});
|
|
583
643
|
}
|
|
584
644
|
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
// PE form submissions before any execution. Regular page navigations
|
|
595
|
-
// (GET without _rsc_loader/_rsc_action) are not affected.
|
|
596
|
-
const originPhase: OriginCheckPhase | null = isAction
|
|
597
|
-
? "action"
|
|
598
|
-
: isLoaderFetch
|
|
599
|
-
? "loader"
|
|
600
|
-
: request.method === "POST"
|
|
601
|
-
? "pe-form"
|
|
602
|
-
: null;
|
|
645
|
+
// ---- 3. Origin guard (gate for action/loader/PE modes) ----
|
|
646
|
+
const originPhase: OriginCheckPhase | null =
|
|
647
|
+
plan.mode === "action"
|
|
648
|
+
? "action"
|
|
649
|
+
: plan.mode === "loader"
|
|
650
|
+
? "loader"
|
|
651
|
+
: plan.mode === "pe-render"
|
|
652
|
+
? "pe-form"
|
|
653
|
+
: null;
|
|
603
654
|
if (originPhase) {
|
|
604
655
|
const originResult = await checkRequestOrigin(
|
|
605
656
|
request,
|
|
@@ -649,13 +700,33 @@ export function createRSCHandler<
|
|
|
649
700
|
}
|
|
650
701
|
}
|
|
651
702
|
|
|
652
|
-
//
|
|
703
|
+
// ---- 4. Execute ----
|
|
704
|
+
return executeRequest(
|
|
705
|
+
plan as ExecutableRequestPlan<TEnv>,
|
|
706
|
+
request,
|
|
707
|
+
env,
|
|
708
|
+
url,
|
|
709
|
+
variables,
|
|
710
|
+
nonce,
|
|
711
|
+
);
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
// Execute a classified request plan. Dispatches to the appropriate handler
|
|
715
|
+
// based on plan.mode. Lives in the createRSCHandler closure for access to
|
|
716
|
+
// handlerCtx, router, callOnError, etc.
|
|
717
|
+
// Only receives executable plans (version-mismatch is handled above).
|
|
718
|
+
async function executeRequest(
|
|
719
|
+
plan: ExecutableRequestPlan<TEnv>,
|
|
720
|
+
request: Request,
|
|
721
|
+
env: TEnv,
|
|
722
|
+
url: URL,
|
|
723
|
+
variables: Record<string, any>,
|
|
724
|
+
nonce: string | undefined,
|
|
725
|
+
): Promise<Response> {
|
|
726
|
+
// Common setup
|
|
653
727
|
const handleStore = requireRequestContext()._handleStore;
|
|
654
728
|
|
|
655
729
|
// Wire up error reporting for late streaming-handle failures
|
|
656
|
-
// (LateHandlePushError: handle pushed after stream completion).
|
|
657
|
-
// Without this, these errors are only caught by React's error boundary
|
|
658
|
-
// and never reach the router's onError callback or telemetry.
|
|
659
730
|
handleStore.onError = (error: Error) => {
|
|
660
731
|
const reqCtx = requireRequestContext();
|
|
661
732
|
callOnError(error, "handler", {
|
|
@@ -685,37 +756,106 @@ export function createRSCHandler<
|
|
|
685
756
|
};
|
|
686
757
|
|
|
687
758
|
// Set route params early so all execution paths can access ctx.params.
|
|
688
|
-
|
|
689
|
-
|
|
759
|
+
// Also store the classified snapshot so match/matchPartial can reuse it
|
|
760
|
+
// instead of calling resolveRoute again.
|
|
761
|
+
if (plan.mode !== "redirect") {
|
|
762
|
+
setRequestContextParams(plan.route.params, plan.route.routeKey);
|
|
763
|
+
requireRequestContext()._classifiedRoute = plan.route;
|
|
690
764
|
}
|
|
691
765
|
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
//
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
routeMiddleware:
|
|
766
|
+
const routeReverse = createReverseFunction(getRequiredRouteMap());
|
|
767
|
+
|
|
768
|
+
// ---- Response route: skip entire RSC pipeline ----
|
|
769
|
+
if (plan.mode === "response") {
|
|
770
|
+
// Build ResponseRouteMatch from plan fields. handleResponseRoute
|
|
771
|
+
// expects a flat object with params at the top level.
|
|
772
|
+
const responseMatch: ResponseRouteMatch = {
|
|
773
|
+
responseType: plan.responseType,
|
|
774
|
+
handler: plan.handler,
|
|
775
|
+
params: plan.route.params,
|
|
776
|
+
negotiated: plan.negotiated,
|
|
777
|
+
manifestEntry: plan.manifestEntry,
|
|
778
|
+
routeMiddleware: plan.routeMiddleware,
|
|
779
|
+
};
|
|
780
|
+
const responseOutcome = await withTimeout(
|
|
781
|
+
handleResponseRoute(
|
|
782
|
+
handlerCtx,
|
|
783
|
+
responseMatch,
|
|
784
|
+
request,
|
|
785
|
+
env,
|
|
786
|
+
url,
|
|
787
|
+
variables,
|
|
788
|
+
),
|
|
789
|
+
router.timeouts.renderStartMs,
|
|
790
|
+
"render-start",
|
|
791
|
+
);
|
|
792
|
+
if (responseOutcome.timedOut) {
|
|
793
|
+
return handleTimeoutResponse(
|
|
794
|
+
request,
|
|
795
|
+
env,
|
|
796
|
+
url,
|
|
797
|
+
"render-start",
|
|
798
|
+
responseOutcome.durationMs,
|
|
799
|
+
plan.route.routeKey,
|
|
800
|
+
);
|
|
801
|
+
}
|
|
802
|
+
const response = responseOutcome.result;
|
|
803
|
+
if (plan.negotiated) {
|
|
804
|
+
response.headers.append("Vary", "Accept");
|
|
805
|
+
}
|
|
806
|
+
return response;
|
|
807
|
+
}
|
|
808
|
+
|
|
809
|
+
// SSR setup: kick off in parallel for modes that need HTML rendering.
|
|
810
|
+
// Placed after response-route short-circuit so response/mime routes
|
|
811
|
+
// never pay for SSR work.
|
|
812
|
+
if (plan.mode !== "loader" && mayNeedSSR(request, url)) {
|
|
813
|
+
variables[SSR_SETUP_VAR] = startSSRSetup(
|
|
814
|
+
handlerCtx,
|
|
815
|
+
request,
|
|
816
|
+
env,
|
|
817
|
+
url,
|
|
818
|
+
router.debugPerformance
|
|
819
|
+
? () => requireRequestContext()._metricsStore
|
|
820
|
+
: undefined,
|
|
821
|
+
);
|
|
822
|
+
}
|
|
823
|
+
|
|
824
|
+
// ---- Loader fetch ----
|
|
825
|
+
if (plan.mode === "loader") {
|
|
826
|
+
return handleLoaderFetch(
|
|
827
|
+
handlerCtx,
|
|
828
|
+
request,
|
|
829
|
+
env,
|
|
830
|
+
url,
|
|
705
831
|
variables,
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
832
|
+
plan.route.params,
|
|
833
|
+
);
|
|
834
|
+
}
|
|
835
|
+
|
|
836
|
+
// ---- Progressive enhancement ----
|
|
837
|
+
if (plan.mode === "pe-render") {
|
|
838
|
+
const peResult = await handleProgressiveEnhancement(
|
|
839
|
+
handlerCtx,
|
|
840
|
+
request,
|
|
841
|
+
env,
|
|
842
|
+
url,
|
|
843
|
+
false, // isAction = false for PE
|
|
844
|
+
handleStore,
|
|
845
|
+
nonce,
|
|
846
|
+
{
|
|
847
|
+
routeMiddleware: plan.route.routeMiddleware,
|
|
848
|
+
variables,
|
|
849
|
+
routeReverse,
|
|
850
|
+
},
|
|
851
|
+
);
|
|
852
|
+
if (peResult) return peResult;
|
|
853
|
+
// PE handler returned null (not a PE form) — fall through to render
|
|
711
854
|
}
|
|
712
855
|
|
|
713
|
-
//
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
// the revalidation pass (identical to a normal render).
|
|
717
|
-
let actionContinuation: ActionContinuation | undefined;
|
|
718
|
-
if (isAction && actionId) {
|
|
856
|
+
// ---- Action: execute action, then revalidate wrapped in route middleware ----
|
|
857
|
+
if (plan.mode === "action") {
|
|
858
|
+
let actionContinuation: ActionContinuation | undefined;
|
|
719
859
|
try {
|
|
720
860
|
const actionOutcome = await withTimeout(
|
|
721
861
|
executeServerAction(
|
|
@@ -723,7 +863,7 @@ export function createRSCHandler<
|
|
|
723
863
|
request,
|
|
724
864
|
env,
|
|
725
865
|
url,
|
|
726
|
-
actionId,
|
|
866
|
+
plan.actionId,
|
|
727
867
|
handleStore,
|
|
728
868
|
),
|
|
729
869
|
router.timeouts.actionMs,
|
|
@@ -736,8 +876,8 @@ export function createRSCHandler<
|
|
|
736
876
|
url,
|
|
737
877
|
"action",
|
|
738
878
|
actionOutcome.durationMs,
|
|
739
|
-
|
|
740
|
-
actionId,
|
|
879
|
+
plan.route.routeKey,
|
|
880
|
+
plan.actionId,
|
|
741
881
|
);
|
|
742
882
|
}
|
|
743
883
|
const result = actionOutcome.result;
|
|
@@ -749,341 +889,297 @@ export function createRSCHandler<
|
|
|
749
889
|
request,
|
|
750
890
|
url,
|
|
751
891
|
env,
|
|
752
|
-
actionId,
|
|
892
|
+
actionId: plan.actionId,
|
|
753
893
|
handledByBoundary: false,
|
|
754
894
|
});
|
|
755
895
|
console.error(`[RSC] Action error:`, error);
|
|
756
896
|
throw error;
|
|
757
897
|
}
|
|
758
|
-
}
|
|
759
898
|
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
899
|
+
// Revalidation render wrapped in route middleware.
|
|
900
|
+
// Actions from client-side navigation include _rsc_partial — preserve
|
|
901
|
+
// the partial flag so the revalidation returns a Flight stream, not HTML.
|
|
902
|
+
// App-switch is already excluded by classifyRequest (would be full-render).
|
|
903
|
+
const isPartialAction = url.searchParams.has("_rsc_partial");
|
|
904
|
+
return executeRenderWithMiddleware(
|
|
905
|
+
plan.route.routeMiddleware,
|
|
906
|
+
plan.negotiated,
|
|
907
|
+
plan.route.routeKey,
|
|
908
|
+
routeReverse,
|
|
764
909
|
request,
|
|
765
910
|
env,
|
|
766
911
|
url,
|
|
767
912
|
variables,
|
|
768
913
|
nonce,
|
|
769
|
-
preview?.params,
|
|
770
|
-
preview?.routeKey,
|
|
771
914
|
handleStore,
|
|
915
|
+
isPartialAction,
|
|
772
916
|
actionContinuation,
|
|
773
917
|
);
|
|
774
|
-
|
|
775
|
-
response.headers.append("Vary", "Accept");
|
|
776
|
-
}
|
|
777
|
-
return response;
|
|
778
|
-
};
|
|
779
|
-
|
|
780
|
-
// Wrap the render path (with or without route middleware) in a
|
|
781
|
-
// renderStartMs timeout so slow renders are caught before output.
|
|
782
|
-
const executeRender = async (): Promise<Response> => {
|
|
783
|
-
if (preview?.routeMiddleware && preview.routeMiddleware.length > 0) {
|
|
784
|
-
const mwResponse = await executeMiddleware(
|
|
785
|
-
buildRouteMiddlewareEntries<TEnv>(preview.routeMiddleware),
|
|
786
|
-
request,
|
|
787
|
-
env,
|
|
788
|
-
variables,
|
|
789
|
-
renderHandler,
|
|
790
|
-
routeReverse,
|
|
791
|
-
);
|
|
792
|
-
|
|
793
|
-
if (
|
|
794
|
-
url.searchParams.has("_rsc_partial") ||
|
|
795
|
-
url.searchParams.has("_rsc_action")
|
|
796
|
-
) {
|
|
797
|
-
const intercepted = interceptRedirectForPartial(
|
|
798
|
-
mwResponse,
|
|
799
|
-
createRedirectFlightResponse,
|
|
800
|
-
);
|
|
801
|
-
if (intercepted) return intercepted;
|
|
802
|
-
}
|
|
803
|
-
|
|
804
|
-
return finalizeResponse(mwResponse);
|
|
805
|
-
}
|
|
918
|
+
}
|
|
806
919
|
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
920
|
+
// ---- Full render / Partial render (or PE that fell through) ----
|
|
921
|
+
if (plan.mode === "full-render" || plan.mode === "partial-render") {
|
|
922
|
+
const isPartial = plan.mode === "partial-render";
|
|
923
|
+
return executeRenderWithMiddleware(
|
|
924
|
+
plan.route.routeMiddleware,
|
|
925
|
+
plan.negotiated,
|
|
926
|
+
plan.route.routeKey,
|
|
927
|
+
routeReverse,
|
|
928
|
+
request,
|
|
929
|
+
env,
|
|
930
|
+
url,
|
|
931
|
+
variables,
|
|
932
|
+
nonce,
|
|
933
|
+
handleStore,
|
|
934
|
+
isPartial,
|
|
935
|
+
);
|
|
936
|
+
}
|
|
810
937
|
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
938
|
+
// PE that fell through (handleProgressiveEnhancement returned null)
|
|
939
|
+
// falls back to full render
|
|
940
|
+
if (plan.mode === "pe-render") {
|
|
941
|
+
return executeRenderWithMiddleware(
|
|
942
|
+
plan.route.routeMiddleware,
|
|
943
|
+
false,
|
|
944
|
+
plan.route.routeKey,
|
|
945
|
+
routeReverse,
|
|
818
946
|
request,
|
|
819
947
|
env,
|
|
820
948
|
url,
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
949
|
+
variables,
|
|
950
|
+
nonce,
|
|
951
|
+
handleStore,
|
|
952
|
+
false,
|
|
824
953
|
);
|
|
825
954
|
}
|
|
826
|
-
|
|
955
|
+
|
|
956
|
+
// Redirect plan that wasn't handled above (full-page redirect — let
|
|
957
|
+
// the pipeline handle it via match() which returns { redirect: url })
|
|
958
|
+
return executeRenderWithMiddleware(
|
|
959
|
+
plan.route.routeMiddleware,
|
|
960
|
+
false,
|
|
961
|
+
plan.route.routeKey,
|
|
962
|
+
routeReverse,
|
|
963
|
+
request,
|
|
964
|
+
env,
|
|
965
|
+
url,
|
|
966
|
+
variables,
|
|
967
|
+
nonce,
|
|
968
|
+
handleStore,
|
|
969
|
+
false,
|
|
970
|
+
);
|
|
827
971
|
}
|
|
828
972
|
|
|
829
|
-
//
|
|
830
|
-
//
|
|
831
|
-
//
|
|
832
|
-
async function
|
|
973
|
+
// Shared render execution: wraps handleRscRendering (or revalidateAfterAction)
|
|
974
|
+
// in route middleware and timeout handling. Consolidates the pattern used by
|
|
975
|
+
// action-revalidate, full-render, and partial-render modes.
|
|
976
|
+
async function executeRenderWithMiddleware(
|
|
977
|
+
routeMiddleware: import("../router/middleware-types.js").CollectedMiddleware[],
|
|
978
|
+
negotiated: boolean,
|
|
979
|
+
routeKey: string,
|
|
980
|
+
routeReverse: ReturnType<typeof createReverseFunction>,
|
|
833
981
|
request: Request,
|
|
834
982
|
env: TEnv,
|
|
835
983
|
url: URL,
|
|
836
984
|
variables: Record<string, any>,
|
|
837
985
|
nonce: string | undefined,
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
handleStore?: ReturnType<typeof requireRequestContext>["_handleStore"],
|
|
986
|
+
handleStore: ReturnType<typeof requireRequestContext>["_handleStore"],
|
|
987
|
+
isPartial: boolean,
|
|
841
988
|
actionContinuation?: ActionContinuation,
|
|
842
989
|
): Promise<Response> {
|
|
843
|
-
const
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
990
|
+
const renderHandler = async (): Promise<Response> => {
|
|
991
|
+
try {
|
|
992
|
+
let response: Response;
|
|
993
|
+
if (actionContinuation) {
|
|
994
|
+
response = await revalidateAfterAction(
|
|
995
|
+
handlerCtx,
|
|
996
|
+
request,
|
|
997
|
+
env,
|
|
998
|
+
url,
|
|
999
|
+
handleStore,
|
|
1000
|
+
actionContinuation,
|
|
1001
|
+
);
|
|
1002
|
+
} else {
|
|
1003
|
+
response = await handleRscRendering(
|
|
1004
|
+
handlerCtx,
|
|
1005
|
+
request,
|
|
1006
|
+
env,
|
|
1007
|
+
url,
|
|
1008
|
+
isPartial,
|
|
1009
|
+
handleStore,
|
|
1010
|
+
nonce,
|
|
1011
|
+
);
|
|
1012
|
+
}
|
|
1013
|
+
if (negotiated) {
|
|
1014
|
+
response.headers.append("Vary", "Accept");
|
|
1015
|
+
}
|
|
1016
|
+
return response;
|
|
1017
|
+
} catch (error) {
|
|
1018
|
+
// Check if middleware/handler returned Response
|
|
1019
|
+
if (error instanceof Response) {
|
|
1020
|
+
// During partial (client-side navigation), a 200 Response from a handler
|
|
1021
|
+
// means the route serves raw content (JSON, text, etc.), not JSX.
|
|
1022
|
+
// Signal the browser to hard-navigate so it renders the raw response.
|
|
1023
|
+
if (isPartial && error.status === 200) {
|
|
1024
|
+
console.warn(
|
|
1025
|
+
`[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
|
|
1026
|
+
`Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
|
|
1027
|
+
);
|
|
1028
|
+
return createResponseWithMergedHeaders(null, {
|
|
1029
|
+
status: 200,
|
|
1030
|
+
headers: {
|
|
1031
|
+
"X-RSC-Reload": stripInternalParams(url).toString(),
|
|
1032
|
+
"content-type": "text/x-component;charset=utf-8",
|
|
1033
|
+
},
|
|
1034
|
+
});
|
|
1035
|
+
}
|
|
854
1036
|
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
if (referer) {
|
|
862
|
-
try {
|
|
863
|
-
const refererUrl = new URL(referer);
|
|
864
|
-
if (refererUrl.origin === url.origin) {
|
|
865
|
-
reloadUrl = referer;
|
|
866
|
-
}
|
|
867
|
-
} catch {
|
|
868
|
-
// Malformed referer, fall back to cleanUrl
|
|
1037
|
+
if (isPartial) {
|
|
1038
|
+
const intercepted = interceptRedirectForPartial(
|
|
1039
|
+
error,
|
|
1040
|
+
createRedirectFlightResponse,
|
|
1041
|
+
);
|
|
1042
|
+
if (intercepted) return intercepted;
|
|
869
1043
|
}
|
|
1044
|
+
|
|
1045
|
+
return error;
|
|
870
1046
|
}
|
|
871
|
-
}
|
|
872
1047
|
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
const isDev = process.env.NODE_ENV !== "production";
|
|
885
|
-
if (
|
|
886
|
-
url.searchParams.has("__debug_manifest") &&
|
|
887
|
-
(isDev || router.allowDebugManifest)
|
|
888
|
-
) {
|
|
889
|
-
const trie = getRouterTrie(router.id) ?? getRouteTrie();
|
|
890
|
-
const routeManifest = getRequiredRouteMap();
|
|
891
|
-
const { extractAncestryFromTrie } =
|
|
892
|
-
await import("../build/route-trie.js");
|
|
893
|
-
return new Response(
|
|
894
|
-
JSON.stringify(
|
|
895
|
-
{
|
|
896
|
-
routerId: router.id,
|
|
897
|
-
routeManifest,
|
|
898
|
-
routeAncestry: trie ? extractAncestryFromTrie(trie) : {},
|
|
899
|
-
routeTrie: trie,
|
|
900
|
-
precomputedEntries: getPrecomputedEntries(),
|
|
901
|
-
},
|
|
902
|
-
null,
|
|
903
|
-
2,
|
|
904
|
-
),
|
|
905
|
-
{
|
|
906
|
-
headers: { "Content-Type": "application/json" },
|
|
907
|
-
},
|
|
908
|
-
);
|
|
909
|
-
}
|
|
1048
|
+
// Render 404 page for unmatched routes
|
|
1049
|
+
const isRouteNotFound =
|
|
1050
|
+
error instanceof RouteNotFoundError ||
|
|
1051
|
+
(error instanceof Error && error.name === "RouteNotFoundError");
|
|
1052
|
+
if (isRouteNotFound) {
|
|
1053
|
+
callOnError(error, "routing", {
|
|
1054
|
+
request,
|
|
1055
|
+
url,
|
|
1056
|
+
env,
|
|
1057
|
+
handledByBoundary: true,
|
|
1058
|
+
});
|
|
910
1059
|
|
|
911
|
-
|
|
1060
|
+
const notFoundOption = router.notFound;
|
|
1061
|
+
const notFoundComponent =
|
|
1062
|
+
typeof notFoundOption === "function"
|
|
1063
|
+
? notFoundOption({ pathname: url.pathname })
|
|
1064
|
+
: (notFoundOption ?? createElement("h1", null, "Not Found"));
|
|
1065
|
+
|
|
1066
|
+
const notFoundSegment = {
|
|
1067
|
+
id: "notFound",
|
|
1068
|
+
namespace: "notFound",
|
|
1069
|
+
type: "route" as const,
|
|
1070
|
+
index: 0,
|
|
1071
|
+
component: notFoundComponent,
|
|
1072
|
+
params: {},
|
|
1073
|
+
};
|
|
1074
|
+
|
|
1075
|
+
const payload: RscPayload = {
|
|
1076
|
+
metadata: {
|
|
1077
|
+
pathname: url.pathname,
|
|
1078
|
+
routerId: router.id,
|
|
1079
|
+
basename: router.basename,
|
|
1080
|
+
segments: [notFoundSegment],
|
|
1081
|
+
matched: [],
|
|
1082
|
+
diff: [],
|
|
1083
|
+
isPartial: false,
|
|
1084
|
+
rootLayout: router.rootLayout,
|
|
1085
|
+
handles: handleStore.stream(),
|
|
1086
|
+
version,
|
|
1087
|
+
themeConfig: router.themeConfig,
|
|
1088
|
+
warmupEnabled: router.warmupEnabled,
|
|
1089
|
+
initialTheme: requireRequestContext().theme,
|
|
1090
|
+
},
|
|
1091
|
+
};
|
|
912
1092
|
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
}
|
|
1093
|
+
const rscStream = renderToReadableStream(payload, {
|
|
1094
|
+
onError: (error: unknown) => {
|
|
1095
|
+
callOnError(error, "rendering", { request, url, env });
|
|
1096
|
+
},
|
|
1097
|
+
});
|
|
919
1098
|
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
handlerCtx,
|
|
926
|
-
request,
|
|
927
|
-
env,
|
|
928
|
-
url,
|
|
929
|
-
store,
|
|
930
|
-
actionContinuation,
|
|
931
|
-
);
|
|
932
|
-
}
|
|
1099
|
+
const isRscRequest =
|
|
1100
|
+
isPartial ||
|
|
1101
|
+
(!request.headers.get("accept")?.includes("text/html") &&
|
|
1102
|
+
!url.searchParams.has("__html")) ||
|
|
1103
|
+
url.searchParams.has("__rsc");
|
|
933
1104
|
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
handlerCtx,
|
|
941
|
-
request,
|
|
942
|
-
env,
|
|
943
|
-
url,
|
|
944
|
-
variables,
|
|
945
|
-
routeParams,
|
|
946
|
-
);
|
|
947
|
-
}
|
|
1105
|
+
if (isRscRequest) {
|
|
1106
|
+
return createResponseWithMergedHeaders(rscStream, {
|
|
1107
|
+
status: 404,
|
|
1108
|
+
headers: { "content-type": "text/x-component;charset=utf-8" },
|
|
1109
|
+
});
|
|
1110
|
+
}
|
|
948
1111
|
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
request,
|
|
956
|
-
env,
|
|
957
|
-
url,
|
|
958
|
-
isPartial,
|
|
959
|
-
store,
|
|
960
|
-
nonce,
|
|
961
|
-
);
|
|
962
|
-
} catch (error) {
|
|
963
|
-
// Check if middleware/handler returned Response
|
|
964
|
-
if (error instanceof Response) {
|
|
965
|
-
// During partial (client-side navigation), a 200 Response from a handler
|
|
966
|
-
// means the route serves raw content (JSON, text, etc.), not JSX.
|
|
967
|
-
// Signal the browser to hard-navigate so it renders the raw response.
|
|
968
|
-
// Only for 200 — redirects (3xx) work already because the browser follows
|
|
969
|
-
// them automatically to a URL that serves Flight data.
|
|
970
|
-
if (isPartial && error.status === 200) {
|
|
971
|
-
console.warn(
|
|
972
|
-
`[RSC] Route handler at ${url.pathname} returned a Response during client-side navigation. ` +
|
|
973
|
-
`Falling back to hard navigation. Use data-external on the <Link> to avoid the extra round-trip.`,
|
|
1112
|
+
const [ssrModule, streamMode] = await getSSRSetup(
|
|
1113
|
+
handlerCtx,
|
|
1114
|
+
request,
|
|
1115
|
+
env,
|
|
1116
|
+
url,
|
|
1117
|
+
requireRequestContext()._metricsStore,
|
|
974
1118
|
);
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
"X-RSC-Reload": stripInternalParams(url).toString(),
|
|
979
|
-
"content-type": "text/x-component;charset=utf-8",
|
|
980
|
-
},
|
|
1119
|
+
const htmlStream = await ssrModule.renderHTML(rscStream, {
|
|
1120
|
+
nonce,
|
|
1121
|
+
streamMode,
|
|
981
1122
|
});
|
|
982
|
-
}
|
|
983
1123
|
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
);
|
|
989
|
-
if (intercepted) return intercepted;
|
|
1124
|
+
return createResponseWithMergedHeaders(htmlStream, {
|
|
1125
|
+
status: 404,
|
|
1126
|
+
headers: { "content-type": "text/html;charset=utf-8" },
|
|
1127
|
+
});
|
|
990
1128
|
}
|
|
991
1129
|
|
|
992
|
-
|
|
993
|
-
}
|
|
994
|
-
|
|
995
|
-
// Render 404 page for unmatched routes
|
|
996
|
-
// Check both instanceof and error.name for cross-bundle compatibility
|
|
997
|
-
const isRouteNotFound =
|
|
998
|
-
error instanceof RouteNotFoundError ||
|
|
999
|
-
(error instanceof Error && error.name === "RouteNotFoundError");
|
|
1000
|
-
if (isRouteNotFound) {
|
|
1130
|
+
// Report unhandled errors
|
|
1001
1131
|
callOnError(error, "routing", {
|
|
1002
1132
|
request,
|
|
1003
1133
|
url,
|
|
1004
1134
|
env,
|
|
1005
|
-
handledByBoundary:
|
|
1135
|
+
handledByBoundary: false,
|
|
1006
1136
|
});
|
|
1137
|
+
console.error(`[RSC] Error:`, error);
|
|
1138
|
+
throw error;
|
|
1139
|
+
}
|
|
1140
|
+
};
|
|
1007
1141
|
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
: (notFoundOption ?? createElement("h1", null, "Not Found"));
|
|
1014
|
-
|
|
1015
|
-
// Create a simple segment for the 404 page
|
|
1016
|
-
const notFoundSegment = {
|
|
1017
|
-
id: "notFound",
|
|
1018
|
-
namespace: "notFound",
|
|
1019
|
-
type: "route" as const,
|
|
1020
|
-
index: 0,
|
|
1021
|
-
component: notFoundComponent,
|
|
1022
|
-
params: {},
|
|
1023
|
-
};
|
|
1024
|
-
|
|
1025
|
-
const payload: RscPayload = {
|
|
1026
|
-
metadata: {
|
|
1027
|
-
pathname: url.pathname,
|
|
1028
|
-
segments: [notFoundSegment],
|
|
1029
|
-
matched: [],
|
|
1030
|
-
diff: [],
|
|
1031
|
-
isPartial: false,
|
|
1032
|
-
rootLayout: router.rootLayout,
|
|
1033
|
-
handles: store.stream(),
|
|
1034
|
-
version,
|
|
1035
|
-
themeConfig: router.themeConfig,
|
|
1036
|
-
warmupEnabled: router.warmupEnabled,
|
|
1037
|
-
initialTheme: requireRequestContext().theme,
|
|
1038
|
-
// No routeName for not-found routes
|
|
1039
|
-
},
|
|
1040
|
-
};
|
|
1041
|
-
|
|
1042
|
-
const rscStream = renderToReadableStream(payload);
|
|
1043
|
-
|
|
1044
|
-
// Determine if this is an RSC request or HTML request.
|
|
1045
|
-
// Partial requests are always RSC (see main isRscRequest comment).
|
|
1046
|
-
const isRscRequest =
|
|
1047
|
-
isPartial ||
|
|
1048
|
-
(!request.headers.get("accept")?.includes("text/html") &&
|
|
1049
|
-
!url.searchParams.has("__html")) ||
|
|
1050
|
-
url.searchParams.has("__rsc");
|
|
1051
|
-
|
|
1052
|
-
if (isRscRequest) {
|
|
1053
|
-
return createResponseWithMergedHeaders(rscStream, {
|
|
1054
|
-
status: 404,
|
|
1055
|
-
headers: { "content-type": "text/x-component;charset=utf-8" },
|
|
1056
|
-
});
|
|
1057
|
-
}
|
|
1058
|
-
|
|
1059
|
-
// Delegate to SSR for HTML response (reuse early setup if available)
|
|
1060
|
-
const [ssrModule, streamMode] = await getSSRSetup(
|
|
1061
|
-
handlerCtx,
|
|
1142
|
+
// Wrap the render path in a renderStartMs timeout
|
|
1143
|
+
const executeRender = async (): Promise<Response> => {
|
|
1144
|
+
if (routeMiddleware.length > 0) {
|
|
1145
|
+
const mwResponse = await executeMiddleware(
|
|
1146
|
+
buildRouteMiddlewareEntries<TEnv>(routeMiddleware),
|
|
1062
1147
|
request,
|
|
1063
1148
|
env,
|
|
1064
|
-
|
|
1065
|
-
|
|
1149
|
+
variables,
|
|
1150
|
+
renderHandler,
|
|
1151
|
+
routeReverse,
|
|
1066
1152
|
);
|
|
1067
|
-
const htmlStream = await ssrModule.renderHTML(rscStream, {
|
|
1068
|
-
nonce,
|
|
1069
|
-
streamMode,
|
|
1070
|
-
});
|
|
1071
1153
|
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1154
|
+
if (isPartial || actionContinuation) {
|
|
1155
|
+
const intercepted = interceptRedirectForPartial(
|
|
1156
|
+
mwResponse,
|
|
1157
|
+
createRedirectFlightResponse,
|
|
1158
|
+
);
|
|
1159
|
+
if (intercepted) return intercepted;
|
|
1160
|
+
}
|
|
1161
|
+
|
|
1162
|
+
return finalizeResponse(mwResponse);
|
|
1076
1163
|
}
|
|
1077
1164
|
|
|
1078
|
-
|
|
1079
|
-
|
|
1165
|
+
return renderHandler();
|
|
1166
|
+
};
|
|
1167
|
+
|
|
1168
|
+
const renderOutcome = await withTimeout(
|
|
1169
|
+
executeRender(),
|
|
1170
|
+
router.timeouts.renderStartMs,
|
|
1171
|
+
"render-start",
|
|
1172
|
+
);
|
|
1173
|
+
if (renderOutcome.timedOut) {
|
|
1174
|
+
return handleTimeoutResponse(
|
|
1080
1175
|
request,
|
|
1081
|
-
url,
|
|
1082
1176
|
env,
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1177
|
+
url,
|
|
1178
|
+
"render-start",
|
|
1179
|
+
renderOutcome.durationMs,
|
|
1180
|
+
routeKey,
|
|
1181
|
+
);
|
|
1087
1182
|
}
|
|
1183
|
+
return renderOutcome.result;
|
|
1088
1184
|
}
|
|
1089
1185
|
}
|