@rangojs/router 0.0.0-experimental.13 → 0.0.0-experimental.131
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/AGENTS.md +9 -0
- package/README.md +1040 -5
- 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 +1712 -212
- 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/{src/browser/react/use-client-cache.ts → dist/browser/react/use-client-cache.js} +9 -26
- 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/{src/handles/index.ts → dist/handles/index.js} +1 -1
- 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/{src/href-context.ts → dist/href-context.d.ts} +7 -11
- 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/testing/vitest.js +82 -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 +6263 -2733
- package/dist/vite/index.js.bak +5448 -0
- package/dist/vite/index.js.map +1 -0
- package/dist/vite/package-resolution.d.ts +43 -0
- package/dist/vite/package-resolution.d.ts.map +1 -0
- package/{src/vite/package-resolution.ts → dist/vite/package-resolution.js} +53 -66
- package/dist/vite/package-resolution.js.map +1 -0
- package/dist/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/dist/vite/virtual-entries.d.ts +25 -0
- package/dist/vite/virtual-entries.d.ts.map +1 -0
- package/{src/vite/virtual-entries.ts → dist/vite/virtual-entries.js} +12 -16
- package/dist/vite/virtual-entries.js.map +1 -0
- package/package.json +123 -68
- package/skills/api-client/SKILL.md +211 -0
- package/skills/breadcrumbs/SKILL.md +312 -0
- package/skills/bundle-analysis/SKILL.md +159 -0
- package/skills/cache-guide/SKILL.md +486 -0
- package/skills/caching/SKILL.md +349 -24
- package/skills/composability/SKILL.md +197 -0
- package/skills/css/SKILL.md +76 -0
- package/skills/debug-manifest/SKILL.md +12 -8
- package/skills/document-cache/SKILL.md +87 -62
- package/skills/fonts/SKILL.md +6 -4
- package/skills/handler-use/SKILL.md +364 -0
- package/skills/hooks/SKILL.md +557 -79
- package/skills/host-router/SKILL.md +278 -0
- package/skills/i18n/SKILL.md +276 -0
- package/skills/intercept/SKILL.md +175 -8
- package/skills/layout/SKILL.md +128 -5
- package/skills/links/SKILL.md +304 -25
- package/skills/loader/SKILL.md +604 -54
- package/skills/middleware/SKILL.md +213 -37
- package/skills/migrate-nextjs/SKILL.md +584 -0
- package/skills/migrate-react-router/SKILL.md +769 -0
- package/skills/mime-routes/SKILL.md +41 -10
- package/skills/observability/SKILL.md +172 -0
- package/skills/parallel/SKILL.md +276 -3
- package/skills/prerender/SKILL.md +432 -52
- package/skills/rango/SKILL.md +313 -21
- package/skills/react-compiler/SKILL.md +168 -0
- package/skills/response-routes/SKILL.md +248 -120
- package/skills/route/SKILL.md +287 -21
- package/skills/router-setup/SKILL.md +231 -33
- package/skills/server-actions/SKILL.md +775 -0
- package/skills/streams-and-websockets/SKILL.md +283 -0
- package/skills/tailwind/SKILL.md +27 -3
- package/skills/testing/SKILL.md +129 -0
- package/skills/testing/bindings.md +89 -0
- package/skills/testing/cache-prerender.md +124 -0
- package/skills/testing/client-components.md +122 -0
- package/skills/testing/e2e-parity.md +125 -0
- package/skills/testing/flight.md +92 -0
- package/skills/testing/handles.md +129 -0
- package/skills/testing/loader.md +128 -0
- package/skills/testing/middleware.md +99 -0
- package/skills/testing/render-handler.md +121 -0
- package/skills/testing/response-routes.md +95 -0
- package/skills/testing/reverse-and-types.md +84 -0
- package/skills/testing/server-actions.md +107 -0
- package/skills/testing/server-tree.md +128 -0
- package/skills/testing/setup.md +120 -0
- package/skills/theme/SKILL.md +9 -8
- package/skills/typesafety/SKILL.md +547 -107
- package/skills/use-cache/SKILL.md +355 -0
- package/skills/view-transitions/SKILL.md +294 -0
- package/src/__augment-tests__/augment.ts +81 -0
- package/src/__augment-tests__/augmented.check.ts +116 -0
- package/src/__internal.ts +77 -44
- package/src/bin/rango.ts +312 -15
- package/src/browser/action-coordinator.ts +114 -0
- package/src/browser/action-fence.ts +47 -0
- package/src/browser/app-shell.ts +39 -0
- package/src/browser/app-version.ts +14 -0
- package/src/browser/cookie-name.ts +140 -0
- package/src/browser/event-controller.ts +162 -200
- package/src/browser/history-state.ts +101 -0
- package/src/browser/index.ts +3 -3
- package/src/browser/intercept-utils.ts +52 -0
- package/src/browser/invalidate-client-cache.ts +52 -0
- package/src/browser/link-interceptor.ts +24 -4
- package/src/browser/logging.ts +11 -0
- package/src/browser/merge-segment-loaders.ts +20 -12
- package/src/browser/navigation-bridge.ts +323 -563
- package/src/browser/navigation-client.ts +219 -75
- package/src/browser/navigation-store-handle.ts +38 -0
- package/src/browser/navigation-store.ts +104 -112
- package/src/browser/navigation-transaction.ts +247 -0
- package/src/browser/network-error-handler.ts +61 -0
- package/src/browser/partial-update.ts +328 -348
- package/src/browser/prefetch/cache.ts +324 -0
- package/src/browser/prefetch/fetch.ts +357 -0
- package/src/browser/prefetch/observer.ts +65 -0
- package/src/browser/prefetch/policy.ts +48 -0
- package/src/browser/prefetch/queue.ts +194 -0
- package/src/browser/prefetch/resource-ready.ts +77 -0
- package/src/browser/rango-state.ts +194 -0
- package/src/browser/react/Link.tsx +253 -71
- package/src/browser/react/NavigationProvider.tsx +155 -34
- package/src/browser/react/ScrollRestoration.tsx +10 -6
- package/src/browser/react/context.ts +11 -0
- package/src/browser/react/filter-segment-order.ts +53 -0
- package/src/browser/react/index.ts +0 -48
- package/src/browser/react/location-state-shared.ts +260 -60
- package/src/browser/react/location-state.ts +90 -20
- package/src/browser/react/mount-context.ts +6 -1
- package/src/browser/react/nonce-context.ts +23 -0
- package/src/browser/react/shallow-equal.ts +27 -0
- package/src/browser/react/use-action.ts +35 -66
- package/src/browser/react/use-handle.ts +39 -126
- package/src/browser/react/use-link-status.ts +6 -9
- package/src/browser/react/use-navigation.ts +44 -68
- package/src/browser/react/use-params.ts +75 -0
- package/src/browser/react/use-pathname.ts +47 -0
- package/src/browser/react/use-reverse.ts +106 -0
- package/src/browser/react/use-router.ts +98 -0
- package/src/browser/react/use-search-params.ts +51 -0
- package/src/browser/react/use-segments.ts +72 -99
- package/src/browser/response-adapter.ts +124 -0
- package/src/browser/rsc-router.tsx +290 -72
- package/src/browser/scroll-restoration.ts +132 -49
- package/src/browser/segment-reconciler.ts +243 -0
- package/src/browser/segment-structure-assert.ts +17 -1
- package/src/browser/server-action-bridge.ts +621 -613
- package/src/browser/types.ts +175 -50
- package/src/browser/validate-redirect-origin.ts +56 -0
- package/src/build/collect-fallback-refs.ts +107 -0
- package/src/build/generate-manifest.ts +123 -56
- package/src/build/generate-route-types.ts +41 -1038
- package/src/build/index.ts +9 -6
- package/src/build/prefix-tree-utils.ts +123 -0
- package/src/build/route-trie.ts +165 -34
- package/src/build/route-types/ast-helpers.ts +25 -0
- package/src/build/route-types/ast-route-extraction.ts +98 -0
- package/src/build/route-types/codegen.ts +113 -0
- package/src/build/route-types/include-resolution.ts +418 -0
- package/src/build/route-types/param-extraction.ts +51 -0
- package/src/build/route-types/per-module-writer.ts +131 -0
- package/src/build/route-types/router-processing.ts +651 -0
- package/src/build/route-types/scan-filter.ts +85 -0
- package/src/build/route-types/source-scan.ts +118 -0
- package/src/build/runtime-discovery.ts +220 -0
- package/src/cache/background-task.ts +34 -0
- package/src/cache/cache-error.ts +104 -0
- package/src/cache/cache-key-utils.ts +44 -0
- package/src/cache/cache-policy.ts +165 -0
- package/src/cache/cache-runtime.ts +444 -0
- package/src/cache/cache-scope.ts +231 -325
- package/src/cache/cache-tag.ts +98 -0
- package/src/cache/cf/cf-cache-store.ts +2644 -75
- package/src/cache/cf/index.ts +17 -17
- package/src/cache/document-cache.ts +172 -92
- package/src/cache/handle-capture.ts +81 -0
- package/src/cache/handle-snapshot.ts +104 -0
- package/src/cache/index.ts +11 -35
- package/src/cache/memory-segment-store.ts +307 -30
- package/src/cache/profile-registry.ts +49 -0
- package/src/cache/read-through-swr.ts +164 -0
- package/src/cache/segment-codec.ts +240 -0
- package/src/cache/tag-invalidation.ts +230 -0
- package/src/cache/taint.ts +153 -0
- package/src/cache/types.ts +94 -211
- package/src/client.rsc.tsx +8 -21
- package/src/client.tsx +123 -347
- package/src/cloudflare/index.ts +11 -0
- package/src/cloudflare/tracing.ts +109 -0
- package/src/component-utils.ts +23 -4
- package/src/components/DefaultDocument.tsx +5 -1
- package/src/context-var.ts +168 -0
- package/src/debug.ts +19 -9
- package/src/decode-loader-results.ts +36 -0
- package/src/defer.ts +196 -0
- package/src/deps/ssr.ts +0 -1
- package/src/errors.ts +106 -10
- package/src/handle.ts +76 -23
- package/src/handles/MetaTags.tsx +73 -34
- package/src/handles/breadcrumbs.ts +77 -0
- package/src/handles/meta.ts +30 -52
- package/src/host/cookie-handler.ts +21 -51
- package/src/host/errors.ts +8 -32
- package/src/host/index.ts +12 -9
- package/src/host/pattern-matcher.ts +34 -77
- package/src/host/router.ts +151 -121
- package/src/host/testing.ts +45 -32
- package/src/host/types.ts +52 -11
- package/src/host/utils.ts +2 -2
- package/src/href-client.ts +192 -57
- package/src/index.rsc.ts +174 -34
- package/src/index.ts +241 -73
- package/src/internal-debug.ts +8 -4
- package/src/loader-store.ts +500 -0
- package/src/loader.rsc.ts +31 -99
- package/src/loader.ts +30 -12
- package/src/missing-id-error.ts +68 -0
- package/src/network-error-thrower.tsx +4 -7
- package/src/outlet-context.ts +1 -1
- package/src/outlet-provider.tsx +41 -0
- package/src/prerender/param-hash.ts +14 -13
- package/src/prerender/store.ts +121 -21
- package/src/prerender.ts +445 -24
- package/src/redirect-origin.ts +100 -0
- package/src/response-utils.ts +37 -0
- package/src/reverse.ts +198 -128
- package/src/root-error-boundary.tsx +42 -48
- package/src/route-content-wrapper.tsx +10 -72
- package/src/route-definition/dsl-helpers.ts +1116 -0
- package/src/route-definition/helper-factories.ts +90 -0
- package/src/route-definition/helpers-types.ts +506 -0
- package/src/route-definition/index.ts +55 -0
- package/src/route-definition/redirect.ts +135 -0
- package/src/route-definition/resolve-handler-use.ts +161 -0
- package/src/route-definition/use-item-types.ts +32 -0
- package/src/route-definition.ts +1 -1450
- package/src/route-map-builder.ts +82 -144
- package/src/route-name.ts +53 -0
- package/src/route-types.ts +72 -41
- package/src/router/basename.ts +14 -0
- package/src/router/content-negotiation.ts +215 -0
- package/src/router/debug-manifest.ts +72 -0
- package/src/router/error-handling.ts +22 -26
- package/src/router/find-match.ts +181 -0
- package/src/router/handler-context.ts +372 -125
- package/src/router/instrument.ts +346 -0
- package/src/router/intercept-resolution.ts +34 -27
- package/src/router/lazy-includes.ts +200 -0
- package/src/router/loader-resolution.ts +381 -147
- package/src/router/logging.ts +106 -6
- package/src/router/manifest.ts +88 -51
- package/src/router/match-api.ts +162 -245
- package/src/router/match-context.ts +4 -24
- package/src/router/match-handlers.ts +440 -0
- package/src/router/match-middleware/background-revalidation.ts +90 -89
- package/src/router/match-middleware/cache-lookup.ts +297 -150
- package/src/router/match-middleware/cache-store.ts +75 -33
- package/src/router/match-middleware/intercept-resolution.ts +44 -43
- package/src/router/match-middleware/segment-resolution.ts +64 -22
- package/src/router/match-pipelines.ts +11 -87
- package/src/router/match-result.ts +121 -50
- package/src/router/metrics.ts +219 -28
- package/src/router/middleware-types.ts +93 -0
- package/src/router/middleware.ts +421 -413
- package/src/router/navigation-snapshot.ts +131 -0
- package/src/router/params-util.ts +23 -0
- package/src/router/pattern-matching.ts +263 -79
- package/src/router/prerender-match.ts +541 -0
- package/src/router/preview-match.ts +100 -0
- package/src/router/request-classification.ts +276 -0
- package/src/router/revalidation.ts +143 -44
- package/src/router/route-snapshot.ts +244 -0
- package/src/router/router-context.ts +41 -47
- package/src/router/router-interfaces.ts +525 -0
- package/src/router/router-options.ts +726 -0
- package/src/router/router-registry.ts +21 -0
- package/src/router/segment-resolution/fresh.ts +747 -0
- package/src/router/segment-resolution/helpers.ts +314 -0
- package/src/router/segment-resolution/loader-cache.ts +207 -0
- package/src/router/segment-resolution/revalidation.ts +1322 -0
- package/src/router/segment-resolution/static-store.ts +81 -0
- package/src/router/segment-resolution/streamed-handler-telemetry.ts +52 -0
- package/src/router/segment-resolution/view-transition-default.ts +36 -0
- package/src/router/segment-resolution.ts +24 -1354
- package/src/router/segment-wrappers.ts +289 -0
- package/src/router/state-cookie-name.ts +33 -0
- package/src/router/substitute-pattern-params.ts +56 -0
- package/src/router/telemetry-otel.ts +261 -0
- package/src/router/telemetry.ts +377 -0
- package/src/router/timeout.ts +128 -0
- package/src/router/tracing.ts +206 -0
- package/src/router/trie-matching.ts +172 -60
- package/src/router/types.ts +23 -70
- package/src/router/url-params.ts +44 -0
- package/src/router.ts +748 -2376
- package/src/rsc/handler-context.ts +46 -0
- package/src/rsc/handler.ts +861 -1141
- package/src/rsc/helpers.ts +269 -19
- package/src/rsc/index.ts +1 -21
- package/src/rsc/json-route-result.ts +38 -0
- package/src/rsc/loader-fetch.ts +235 -0
- package/src/rsc/manifest-init.ts +77 -0
- package/src/rsc/nonce.ts +14 -0
- package/src/rsc/origin-guard.ts +155 -0
- package/src/rsc/progressive-enhancement.ts +413 -0
- package/src/rsc/redirect-guard.ts +99 -0
- package/src/rsc/response-error.ts +104 -0
- package/src/rsc/response-route-handler.ts +374 -0
- package/src/rsc/rsc-rendering.ts +261 -0
- package/src/rsc/runtime-warnings.ts +55 -0
- package/src/rsc/server-action.ts +376 -0
- package/src/rsc/ssr-setup.ts +144 -0
- package/src/rsc/types.ts +58 -12
- package/src/runtime-env.ts +18 -0
- package/src/search-params.ts +70 -74
- package/src/segment-content-promise.ts +67 -0
- package/src/segment-loader-promise.ts +134 -0
- package/src/segment-system.tsx +292 -134
- package/src/serialize.ts +243 -0
- package/src/server/context.ts +439 -85
- package/src/server/cookie-store.ts +265 -0
- package/src/server/fetchable-loader-store.ts +11 -6
- package/src/server/handle-store.ts +112 -31
- package/src/server/loader-registry.ts +23 -82
- package/src/server/request-context.ts +724 -143
- package/src/server.ts +26 -164
- package/src/ssr/index.tsx +113 -36
- package/src/static-handler.ts +45 -18
- package/src/testing/cache-status.ts +162 -0
- package/src/testing/collect-handle.ts +40 -0
- package/src/testing/dispatch.ts +618 -0
- package/src/testing/dom.entry.ts +22 -0
- package/src/testing/e2e/fixture.ts +188 -0
- package/src/testing/e2e/index.ts +128 -0
- package/src/testing/e2e/matchers.ts +35 -0
- package/src/testing/e2e/page-helpers.ts +272 -0
- package/src/testing/e2e/parity.ts +387 -0
- package/src/testing/e2e/server.ts +195 -0
- package/src/testing/flight-matchers.ts +97 -0
- package/src/testing/flight-normalize.ts +11 -0
- package/src/testing/flight-runtime.d.ts +57 -0
- package/src/testing/flight-tree.ts +682 -0
- package/src/testing/flight.entry.ts +52 -0
- package/src/testing/flight.ts +232 -0
- package/src/testing/generated-routes.ts +183 -0
- package/src/testing/index.ts +99 -0
- package/src/testing/internal/context.ts +348 -0
- package/src/testing/internal/flight-client-globals.ts +30 -0
- package/src/testing/internal/seed-vars.ts +54 -0
- package/src/testing/render-handler.ts +330 -0
- package/src/testing/render-route.tsx +566 -0
- package/src/testing/run-loader.ts +378 -0
- package/src/testing/run-middleware.ts +205 -0
- package/src/testing/vitest-stubs/cloudflare-email.ts +9 -0
- package/src/testing/vitest-stubs/cloudflare-workers.ts +21 -0
- package/src/testing/vitest-stubs/plugin-rsc.ts +16 -0
- package/src/testing/vitest-stubs/version.ts +5 -0
- package/src/testing/vitest.ts +305 -0
- package/src/theme/ThemeProvider.tsx +21 -67
- package/src/theme/ThemeScript.tsx +5 -11
- package/src/theme/constants.ts +5 -14
- package/src/theme/index.ts +3 -20
- package/src/theme/theme-context.ts +5 -35
- package/src/theme/theme-script.ts +21 -32
- package/src/theme/use-theme.ts +0 -3
- package/src/types/boundaries.ts +123 -0
- package/src/types/cache-types.ts +207 -0
- package/src/types/error-types.ts +132 -0
- package/src/types/global-namespace.ts +113 -0
- package/src/types/handler-context.ts +839 -0
- package/src/types/index.ts +79 -0
- package/src/types/loader-types.ts +212 -0
- package/src/types/request-scope.ts +107 -0
- package/src/types/route-config.ts +126 -0
- package/src/types/route-entry.ts +114 -0
- package/src/types/segments.ts +171 -0
- package/src/types.ts +1 -1795
- package/src/urls/include-helper.ts +160 -0
- package/src/urls/index.ts +43 -0
- package/src/urls/path-helper-types.ts +386 -0
- package/src/urls/path-helper.ts +275 -0
- package/src/urls/pattern-types.ts +124 -0
- package/src/urls/response-types.ts +109 -0
- package/src/urls/type-extraction.ts +291 -0
- package/src/urls/urls-function.ts +81 -0
- package/src/urls.ts +1 -1323
- package/src/use-loader.tsx +406 -141
- package/src/vite/debug.ts +185 -0
- package/src/vite/discovery/bundle-postprocess.ts +182 -0
- package/src/vite/discovery/discover-routers.ts +389 -0
- package/src/vite/discovery/discovery-errors.ts +194 -0
- package/src/vite/discovery/gate-state.ts +171 -0
- package/src/vite/discovery/prerender-collection.ts +467 -0
- package/src/vite/discovery/route-types-writer.ts +214 -0
- package/src/vite/discovery/self-gen-tracking.ts +73 -0
- package/src/vite/discovery/state.ts +161 -0
- package/src/vite/discovery/virtual-module-codegen.ts +183 -0
- package/src/vite/index.ts +17 -2259
- package/src/vite/plugin-types.ts +221 -0
- package/src/vite/plugins/cjs-to-esm.ts +83 -0
- package/src/vite/plugins/client-ref-dedup.ts +120 -0
- package/src/vite/plugins/client-ref-hashing.ts +118 -0
- package/src/vite/plugins/cloudflare-protocol-loader-hook.d.mts +23 -0
- package/src/vite/plugins/cloudflare-protocol-loader-hook.mjs +76 -0
- package/src/vite/plugins/cloudflare-protocol-stub.ts +194 -0
- package/src/vite/{expose-action-id.ts → plugins/expose-action-id.ts} +88 -110
- package/src/vite/{expose-id-utils.ts → plugins/expose-id-utils.ts} +13 -87
- package/src/vite/plugins/expose-ids/export-analysis.ts +338 -0
- package/src/vite/plugins/expose-ids/handler-transform.ts +141 -0
- package/src/vite/plugins/expose-ids/loader-transform.ts +57 -0
- package/src/vite/plugins/expose-ids/router-transform.ts +124 -0
- package/src/vite/plugins/expose-ids/types.ts +45 -0
- package/src/vite/plugins/expose-internal-ids.ts +806 -0
- package/src/vite/plugins/performance-tracks.ts +89 -0
- package/src/vite/plugins/refresh-cmd.ts +127 -0
- package/src/vite/plugins/use-cache-transform.ts +313 -0
- package/src/vite/plugins/version-injector.ts +79 -0
- package/src/vite/plugins/version-plugin.ts +275 -0
- package/src/vite/plugins/virtual-entries.ts +108 -0
- package/src/vite/plugins/virtual-stub-plugin.ts +29 -0
- package/src/vite/rango.ts +444 -0
- package/src/vite/router-discovery.ts +1581 -0
- package/src/vite/{ast-handler-extract.ts → utils/ast-handler-extract.ts} +193 -37
- package/src/vite/utils/banner.ts +36 -0
- package/src/vite/utils/bundle-analysis.ts +132 -0
- package/src/vite/utils/client-chunks.ts +184 -0
- package/src/vite/utils/forward-user-plugins.ts +171 -0
- package/src/vite/utils/manifest-utils.ts +15 -0
- package/src/vite/utils/package-resolution.ts +89 -0
- package/src/vite/utils/prerender-utils.ts +223 -0
- package/src/vite/utils/shared-utils.ts +219 -0
- package/CLAUDE.md +0 -43
- package/src/browser/lru-cache.ts +0 -69
- package/src/browser/request-controller.ts +0 -164
- package/src/browser/shallow.ts +0 -35
- package/src/cache/memory-store.ts +0 -253
- package/src/router.gen.ts +0 -6
- package/src/static-handler.gen.ts +0 -5
- package/src/urls.gen.ts +0 -8
- package/src/vite/expose-internal-ids.ts +0 -1167
- /package/src/vite/{version.d.ts → plugins/version.d.ts} +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: prerender
|
|
3
|
-
description: Pre-render route segments at build time with Prerender and
|
|
3
|
+
description: Pre-render route segments at build time with Prerender and Passthrough live fallback
|
|
4
4
|
argument-hint: [passthrough]
|
|
5
5
|
---
|
|
6
6
|
|
|
@@ -51,8 +51,14 @@ path("/blog/:slug", BlogPost, { name: "blog.post" })
|
|
|
51
51
|
|
|
52
52
|
### With Passthrough (live fallback for unknown params)
|
|
53
53
|
|
|
54
|
+
Wrap a `Prerender` definition with `Passthrough()` to add a separate live handler
|
|
55
|
+
for unknown params at runtime. The build handler runs at build time, the live
|
|
56
|
+
handler runs at request time.
|
|
57
|
+
|
|
54
58
|
```typescript
|
|
55
|
-
|
|
59
|
+
import { Prerender, Passthrough } from "@rangojs/router";
|
|
60
|
+
|
|
61
|
+
export const ProductPageDef = Prerender(
|
|
56
62
|
async () => {
|
|
57
63
|
const top = await db.query("SELECT id FROM products WHERE featured");
|
|
58
64
|
return top.map(p => ({ id: p.id }));
|
|
@@ -61,30 +67,42 @@ export const ProductPage = Prerender(
|
|
|
61
67
|
const product = await db.query("SELECT * FROM products WHERE id = ?", ctx.params.id);
|
|
62
68
|
return <Product data={product} />;
|
|
63
69
|
},
|
|
64
|
-
{
|
|
70
|
+
{ concurrency: 4 }
|
|
65
71
|
);
|
|
72
|
+
|
|
73
|
+
// In route definition:
|
|
74
|
+
path("/products/:id", Passthrough(ProductPageDef, async (ctx) => {
|
|
75
|
+
const product = await ctx.env.DB.query("SELECT * FROM products WHERE id = ?", ctx.params.id);
|
|
76
|
+
return <Product data={product} />;
|
|
77
|
+
}), { name: "product" })
|
|
66
78
|
```
|
|
67
79
|
|
|
68
|
-
## Passthrough
|
|
80
|
+
## Passthrough Wrapper
|
|
69
81
|
|
|
70
|
-
|
|
82
|
+
`Passthrough(prerenderDef, liveHandler)` wraps a `Prerender` definition with a
|
|
83
|
+
separate handler for runtime fallback. The build and live handlers are separate
|
|
84
|
+
functions — no `ctx.build` branching needed.
|
|
71
85
|
|
|
72
|
-
|
|
|
73
|
-
|
|
74
|
-
| Known params
|
|
75
|
-
| Unknown params
|
|
76
|
-
|
|
|
77
|
-
|
|
|
78
|
-
| `
|
|
86
|
+
| | Plain `Prerender` (no wrapper) | `Passthrough(def, liveHandler)` |
|
|
87
|
+
| ------------------- | --------------------------------------- | ---------------------------------------- |
|
|
88
|
+
| Known params | Served from pre-rendered Flight payload | Served from pre-rendered Flight payload |
|
|
89
|
+
| Unknown params | Handler evicted, no live fallback | Live handler runs at request time |
|
|
90
|
+
| `ctx.passthrough()` | Throws (not on Passthrough route) | Skips artifact, defers to live handler |
|
|
91
|
+
| Bundle size | Build handler code + imports removed | Build handler evicted, live handler kept |
|
|
92
|
+
| `revalidate()` | Not allowed (handler gone) | Allowed (live handler can re-render) |
|
|
93
|
+
| `loading()` | Ignored (segments fully resolved) | Works for live fallback renders |
|
|
79
94
|
|
|
80
|
-
### When to use
|
|
95
|
+
### When to use Passthrough
|
|
96
|
+
|
|
97
|
+
Use `Passthrough()` when:
|
|
81
98
|
|
|
82
|
-
Use `passthrough: true` when:
|
|
83
99
|
- The route has a large or open-ended param space (e.g., user profiles, product pages)
|
|
84
100
|
- You want to pre-render popular/known params for speed but still serve unknown params live
|
|
85
101
|
- You need `revalidate()` on the route
|
|
102
|
+
- The live handler needs runtime bindings (e.g., `ctx.env.DB`)
|
|
103
|
+
|
|
104
|
+
Use plain `Prerender` (no wrapper) when:
|
|
86
105
|
|
|
87
|
-
Use `passthrough: false` (default) when:
|
|
88
106
|
- All possible params are known at build time (e.g., markdown files, config-driven pages)
|
|
89
107
|
- You want maximum bundle size reduction (handler code + node:fs imports removed)
|
|
90
108
|
- The route uses build-only APIs (node:fs, local files) not available at runtime
|
|
@@ -95,18 +113,58 @@ Handlers receive `BuildContext` at build time, a subset of the runtime `HandlerC
|
|
|
95
113
|
|
|
96
114
|
```typescript
|
|
97
115
|
interface BuildContext<TParams> {
|
|
98
|
-
params: TParams;
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
116
|
+
params: TParams; // From getParams
|
|
117
|
+
build: true; // Always true at build time
|
|
118
|
+
dev: boolean; // true in Vite dev mode, false during production build
|
|
119
|
+
use: <T>(handle: Handle<T>) => (data: T) => void; // Push handle data
|
|
120
|
+
url: URL; // Synthetic URL from pattern + params
|
|
121
|
+
pathname: string; // Pathname from synthetic URL
|
|
122
|
+
set(key: string, value: any): void; // Set context variable (string key)
|
|
123
|
+
set<T>(contextVar: ContextVar<T>, value: T): void; // Set typed context variable
|
|
124
|
+
get(key: string): any; // Read context variable (string key)
|
|
125
|
+
get<T>(contextVar: ContextVar<T>): T | undefined; // Read typed context variable
|
|
126
|
+
reverse(
|
|
127
|
+
name: string,
|
|
128
|
+
params?: Record<string, string>,
|
|
129
|
+
search?: Record<string, unknown>,
|
|
130
|
+
): string; // URL generation
|
|
131
|
+
passthrough(): PrerenderPassthroughResult; // Skip local artifact (Passthrough routes only)
|
|
132
|
+
env: DefaultEnv; // Available when buildEnv is configured in rango() (throws otherwise)
|
|
133
|
+
// NOT available: request, headers, cookies (always throw)
|
|
103
134
|
}
|
|
104
135
|
```
|
|
105
136
|
|
|
137
|
+
Use `createVar<T>()` to share typed data from a Prerender handler to child layouts:
|
|
138
|
+
|
|
139
|
+
```typescript
|
|
140
|
+
import { Prerender, createVar } from "@rangojs/router";
|
|
141
|
+
|
|
142
|
+
interface PaginationData { current: number; total: number; }
|
|
143
|
+
export const Pagination = createVar<PaginationData>();
|
|
144
|
+
|
|
145
|
+
export const ArticleList = Prerender<{ page: string }>(
|
|
146
|
+
async () => [{ page: "1" }, { page: "2" }],
|
|
147
|
+
async (ctx) => {
|
|
148
|
+
ctx.set(Pagination, { current: Number(ctx.params.page), total: 2 });
|
|
149
|
+
return <Articles />;
|
|
150
|
+
},
|
|
151
|
+
);
|
|
152
|
+
```
|
|
153
|
+
|
|
106
154
|
All items inside the path's use() callback (child layouts, parallels) also receive
|
|
107
155
|
`BuildContext` during pre-rendering. Loaders are the exception -- they run at
|
|
108
156
|
request time with full server context.
|
|
109
157
|
|
|
158
|
+
This is one reason prerender is a good fit for handler-first composition:
|
|
159
|
+
the handler and its child layouts/parallels participate in the same full
|
|
160
|
+
render pass, so data set with `ctx.set()` is available downstream via
|
|
161
|
+
`ctx.get()`.
|
|
162
|
+
|
|
163
|
+
At runtime, partial action revalidation follows a narrower rule: only
|
|
164
|
+
revalidated segments are recomputed. If a child segment depends on data
|
|
165
|
+
established by an outer handler/layout, that outer segment must also be
|
|
166
|
+
revalidated, or the child must load/guard the data independently.
|
|
167
|
+
|
|
110
168
|
## Supported Export Patterns
|
|
111
169
|
|
|
112
170
|
All of the following are equivalent and fully supported by the Vite transform:
|
|
@@ -139,15 +197,17 @@ In production builds, `Prerender` exports are replaced with stubs:
|
|
|
139
197
|
// Original
|
|
140
198
|
export const BlogPost = Prerender(getParams, handler);
|
|
141
199
|
|
|
142
|
-
// Stubbed (
|
|
143
|
-
export const BlogPost = {
|
|
200
|
+
// Stubbed (all Prerender handlers are evicted)
|
|
201
|
+
export const BlogPost = {
|
|
202
|
+
__brand: "prerenderHandler",
|
|
203
|
+
$$id: "abc123#BlogPost",
|
|
204
|
+
};
|
|
144
205
|
```
|
|
145
206
|
|
|
146
|
-
|
|
147
|
-
|
|
207
|
+
All Prerender handlers are evicted in production. The live handler for
|
|
208
|
+
`Passthrough()` routes lives in the urls module and is not evicted.
|
|
148
209
|
|
|
149
|
-
In client and SSR environments, ALL prerender handlers are always stubbed
|
|
150
|
-
(passthrough only affects the RSC server bundle).
|
|
210
|
+
In client and SSR environments, ALL prerender handlers are always stubbed.
|
|
151
211
|
|
|
152
212
|
## Sub-use Semantics
|
|
153
213
|
|
|
@@ -181,22 +241,36 @@ path("/blog/:slug", BlogPost, { name: "blog.post" }, () => [
|
|
|
181
241
|
|
|
182
242
|
## Interaction with DSL Items
|
|
183
243
|
|
|
184
|
-
| DSL item | Behavior with Prerender
|
|
185
|
-
|
|
186
|
-
| `loader()` | Live at runtime, bundled normally. Use `cache()` for caching.
|
|
187
|
-
| `revalidate()` | Not allowed without
|
|
188
|
-
| `cache()` | Orthogonal -- use on parent layouts and loaders.
|
|
189
|
-
| `layout()` | Child layouts inside path are pre-rendered. Parent layouts are live.
|
|
190
|
-
| `parallel()` | Parallel slots inside path are pre-rendered.
|
|
191
|
-
| `middleware()`
|
|
192
|
-
| `loading()` | Ignored without
|
|
193
|
-
| `intercept()` |
|
|
244
|
+
| DSL item | Behavior with Prerender |
|
|
245
|
+
| -------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
246
|
+
| `loader()` | Live at runtime, bundled normally. Use `cache()` for caching. |
|
|
247
|
+
| `revalidate()` | Not allowed without Passthrough. Allowed with Passthrough. |
|
|
248
|
+
| `cache()` | Orthogonal -- use on parent layouts and loaders. |
|
|
249
|
+
| `layout()` | Child layouts inside path are pre-rendered. Parent layouts are live. |
|
|
250
|
+
| `parallel()` | Parallel slots inside path are pre-rendered. |
|
|
251
|
+
| `middleware()` | Skipped during pre-render (no request). Runs at request time for loaders. |
|
|
252
|
+
| `loading()` | Ignored without Passthrough. Works for live fallback with Passthrough. |
|
|
253
|
+
| `intercept()` | Pre-rendered at build time. Intercept variant stored under `/i` key alongside main segments. At runtime, the correct variant is served based on `ctx.isIntercept`. `when()` conditions are skipped at build time (all intercepts are pre-rendered unconditionally). |
|
|
254
|
+
|
|
255
|
+
When Passthrough revalidation is enabled, remember that revalidation is
|
|
256
|
+
still partial: opting a child segment into revalidation does not
|
|
257
|
+
implicitly re-run outer prerender-derived handlers/layouts.
|
|
194
258
|
|
|
195
259
|
## Dev Mode
|
|
196
260
|
|
|
197
|
-
In dev mode
|
|
198
|
-
|
|
199
|
-
|
|
261
|
+
In dev mode there is no production-style prerender build pass and no handler
|
|
262
|
+
stubbing.
|
|
263
|
+
|
|
264
|
+
**Node.js dev server** — `Prerender` acts as a normal handler. Routes render
|
|
265
|
+
live on every request with full runtime context (`ctx.build === false`).
|
|
266
|
+
|
|
267
|
+
**Non-Node runtimes (Cloudflare workerd, Deno workers)** — Handlers that
|
|
268
|
+
depend on Node APIs (e.g. `node:fs`) cannot run in-process. The Vite plugin
|
|
269
|
+
can intercept these requests and resolve them via the `/__rsc_prerender`
|
|
270
|
+
endpoint, which runs `matchForPrerender` in a Node.js temp server. In this
|
|
271
|
+
path the handler receives `BuildContext` (`ctx.build === true`) and segments
|
|
272
|
+
are resolved identically to production prerendering, then served on-demand.
|
|
273
|
+
This only applies when `__PRERENDER_DEV_URL` is set by the plugin.
|
|
200
274
|
|
|
201
275
|
## Storage Layout
|
|
202
276
|
|
|
@@ -212,41 +286,249 @@ dist/static/__<hash>/
|
|
|
212
286
|
_.flight # static route, no params
|
|
213
287
|
```
|
|
214
288
|
|
|
289
|
+
## Concurrency
|
|
290
|
+
|
|
291
|
+
Prerender handlers can specify how many param sets render in parallel:
|
|
292
|
+
|
|
293
|
+
```typescript
|
|
294
|
+
export const BlogPost = Prerender(
|
|
295
|
+
async () => posts.map(p => ({ slug: p.slug })),
|
|
296
|
+
async (ctx) => <PostPage slug={ctx.params.slug} />,
|
|
297
|
+
{ concurrency: 4 },
|
|
298
|
+
);
|
|
299
|
+
```
|
|
300
|
+
|
|
301
|
+
Default is `1` (sequential). Only `Prerender` supports concurrency; `Static` handlers
|
|
302
|
+
always render sequentially.
|
|
303
|
+
|
|
304
|
+
## Skipping Entries with Skip
|
|
305
|
+
|
|
306
|
+
Throw `Skip` inside a Prerender or Static handler to skip an individual entry
|
|
307
|
+
without failing the build:
|
|
308
|
+
|
|
309
|
+
```typescript
|
|
310
|
+
import { Prerender, Skip } from "@rangojs/router";
|
|
311
|
+
|
|
312
|
+
export const BlogPost = Prerender(
|
|
313
|
+
async () => [{ slug: "published" }, { slug: "draft" }],
|
|
314
|
+
async (ctx) => {
|
|
315
|
+
if (ctx.params.slug === "draft") {
|
|
316
|
+
throw new Skip("Draft articles are not pre-rendered");
|
|
317
|
+
}
|
|
318
|
+
return <PostPage slug={ctx.params.slug} />;
|
|
319
|
+
},
|
|
320
|
+
);
|
|
321
|
+
|
|
322
|
+
// Wrap with Passthrough to serve skipped params live at runtime
|
|
323
|
+
export const BlogPost = Passthrough(BlogPostDef, async (ctx) => {
|
|
324
|
+
if (ctx.params.slug === "draft") {
|
|
325
|
+
throw new Skip("Draft articles are not pre-rendered");
|
|
326
|
+
}
|
|
327
|
+
return <PostPage slug={ctx.params.slug} />;
|
|
328
|
+
});
|
|
329
|
+
```
|
|
330
|
+
|
|
331
|
+
Skipped entries are excluded from the build output. With `Passthrough()`,
|
|
332
|
+
the live handler serves skipped params at request time.
|
|
333
|
+
|
|
334
|
+
`Skip` also works in `Static` handlers:
|
|
335
|
+
|
|
336
|
+
```typescript
|
|
337
|
+
import { Static, Skip } from "@rangojs/router";
|
|
338
|
+
|
|
339
|
+
export const TocSidebar = Static(() => {
|
|
340
|
+
throw new Skip("Not ready for pre-rendering");
|
|
341
|
+
});
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
### Error behavior at build time
|
|
345
|
+
|
|
346
|
+
When a render throws a non-`Skip` error, it is **surfaced to the build** — never
|
|
347
|
+
baked into a frozen error page served as a 200 (issue #587). What happens next is
|
|
348
|
+
controlled by `prerender.onError` in your `rango()` options:
|
|
349
|
+
|
|
350
|
+
```ts
|
|
351
|
+
rango({ prerender: { onError: "warn" } }); // default is "fail"
|
|
352
|
+
```
|
|
353
|
+
|
|
354
|
+
| Handler outcome | `onError: "fail"` (default) | `onError: "warn"` |
|
|
355
|
+
| --------------------------- | -------------------------------------------- | -------------------------------- |
|
|
356
|
+
| JSX / `null` | Normal prerender entry, log OK | Normal prerender entry, log OK |
|
|
357
|
+
| `return ctx.passthrough()` | Skip entry, log PASS (Passthrough routes) | Skip entry, log PASS |
|
|
358
|
+
| `throw new Skip("reason")` | Skip entry, log SKIP, continue | Skip entry, log SKIP, continue |
|
|
359
|
+
| `throw new Error("reason")` | Log FAIL, stop ALL pre-rendering, fail build | Log WARN, skip the URL, continue |
|
|
360
|
+
|
|
361
|
+
With `"warn"` the errored entry is logged and left un-baked (never served as a baked
|
|
362
|
+
200 error page). `"warn"` is a build-unblock, not a runtime contract: the route falls
|
|
363
|
+
through to normal resolution — it may render live (its handler is still bundled) or
|
|
364
|
+
404 (once other baked entries trigger prerender handler eviction), so the outcome
|
|
365
|
+
depends on the rest of the build, and a skipped `Static()` handler's evicted code can
|
|
366
|
+
surface as an error. For DEFINED runtime behavior reach for `Passthrough()` (a live
|
|
367
|
+
fallback) or `throw new Skip()` (an intentional skip — works in the render fn, not
|
|
368
|
+
only `getParams()`); otherwise prefer the default `"fail"`.
|
|
369
|
+
|
|
370
|
+
Both `Skip` and hard errors propagate to the router's `onError` callback with phase
|
|
371
|
+
`"prerender"` or `"static"`.
|
|
372
|
+
|
|
373
|
+
### Build logs
|
|
374
|
+
|
|
375
|
+
The build produces per-URL timing logs:
|
|
376
|
+
|
|
377
|
+
```
|
|
378
|
+
[rango] Pre-rendering 12 URL(s) (concurrency: 4)...
|
|
379
|
+
[rango] OK /articles/hello (42ms)
|
|
380
|
+
[rango] PASS /articles/remote-only (5ms) - live fallback
|
|
381
|
+
[rango] SKIP /articles/draft-post (3ms) - Article is a draft
|
|
382
|
+
[rango] Pre-render complete: 11 done, 1 skipped (1204ms total)
|
|
383
|
+
|
|
384
|
+
[rango] Rendering 3 static handler(s)...
|
|
385
|
+
[rango] OK DocsLayout (28ms)
|
|
386
|
+
[rango] SKIP TocSidebar (1ms) - Not ready
|
|
387
|
+
[rango] Static render complete: 2 done, 1 skipped (120ms total)
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
A `FAIL` line is logged per-URL when a handler throws a non-Skip error (with the
|
|
391
|
+
default `prerender.onError: "fail"`). The error is re-thrown immediately, so no
|
|
392
|
+
summary line is printed — the build stops at the first failure. Under
|
|
393
|
+
`prerender.onError: "warn"` the same case logs a `WARN` line, skips that URL, and
|
|
394
|
+
the build continues.
|
|
395
|
+
|
|
396
|
+
### Dev mode behavior
|
|
397
|
+
|
|
398
|
+
**Node.js dev server** — `Skip` behaves like a regular runtime error because
|
|
399
|
+
the handler runs live with `ctx.build === false`.
|
|
400
|
+
|
|
401
|
+
**Non-Node runtimes using `/__rsc_prerender`** — `Skip` participates in the
|
|
402
|
+
on-demand prerender path, so build-style skip logic does run for that request.
|
|
403
|
+
The dev prerender endpoint treats it like a prerender miss and the request
|
|
404
|
+
falls back according to normal dev/runtime behavior.
|
|
405
|
+
|
|
406
|
+
## Per-Param Passthrough with ctx.passthrough()
|
|
407
|
+
|
|
408
|
+
On routes wrapped with `Passthrough()`, the build handler can return
|
|
409
|
+
`ctx.passthrough()` to skip writing a local prerender artifact for a specific
|
|
410
|
+
param set. At runtime, the missing entry falls through to the live handler.
|
|
411
|
+
|
|
412
|
+
```typescript
|
|
413
|
+
export const BlogPostDef = Prerender(
|
|
414
|
+
async () => [{ slug: "a" }, { slug: "b" }, { slug: "c" }],
|
|
415
|
+
async (ctx) => {
|
|
416
|
+
const post = await getPost(ctx.params.slug);
|
|
417
|
+
if (!post) return ctx.passthrough();
|
|
418
|
+
return <article>{post.content}</article>;
|
|
419
|
+
},
|
|
420
|
+
);
|
|
421
|
+
|
|
422
|
+
export const BlogPost = Passthrough(BlogPostDef, async (ctx) => {
|
|
423
|
+
const post = await getPost(ctx.params.slug);
|
|
424
|
+
return <article>{post.content}</article>;
|
|
425
|
+
});
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
### Semantics
|
|
429
|
+
|
|
430
|
+
- JSX or `null` from the build handler produces a normal prerender entry.
|
|
431
|
+
- `ctx.passthrough()` returns a sentinel that signals "no local artifact".
|
|
432
|
+
The build skips the manifest entry for that param set.
|
|
433
|
+
- `ctx.passthrough()` on a route not wrapped with `Passthrough()` throws.
|
|
434
|
+
- `ctx.passthrough()` at runtime (`ctx.build === false`) also throws.
|
|
435
|
+
It is a build-time-only control flow.
|
|
436
|
+
- `getParams()` still enumerates the param set; the build handler decides
|
|
437
|
+
per-param whether to produce an artifact or defer to the live handler.
|
|
438
|
+
|
|
439
|
+
### Difference from Skip
|
|
440
|
+
|
|
441
|
+
| Mechanism | Effect on build | Runtime behavior |
|
|
442
|
+
| ------------------- | ---------------------- | ------------------------------------------------------ |
|
|
443
|
+
| `throw new Skip()` | Skips entry, logs SKIP | No artifact, no live fallback unless Passthrough route |
|
|
444
|
+
| `ctx.passthrough()` | Skips entry, logs PASS | Always defers to live handler (requires Passthrough) |
|
|
445
|
+
|
|
446
|
+
Use `ctx.passthrough()` when you want the live handler to run at request time
|
|
447
|
+
for specific params. Use `Skip` when you want to exclude params entirely.
|
|
448
|
+
|
|
449
|
+
### Use case: Remote storage
|
|
450
|
+
|
|
451
|
+
`ctx.passthrough()` enables a pattern where build-time data is stored in a
|
|
452
|
+
remote KV store instead of the local prerender manifest. The build handler
|
|
453
|
+
pre-computes data during `getParams`, pushes it to KV, then calls
|
|
454
|
+
`ctx.passthrough()` so the local build skips the artifact. At runtime,
|
|
455
|
+
the Passthrough live handler reads from KV:
|
|
456
|
+
|
|
457
|
+
```typescript
|
|
458
|
+
export const ProductDef = Prerender(
|
|
459
|
+
async () => {
|
|
460
|
+
const products = await db.getFeaturedProducts();
|
|
461
|
+
for (const p of products) {
|
|
462
|
+
await kv.put(`product:${p.id}`, await renderProduct(p));
|
|
463
|
+
}
|
|
464
|
+
return products.map(p => ({ id: p.id }));
|
|
465
|
+
},
|
|
466
|
+
async (ctx) => {
|
|
467
|
+
// At build time: skip local artifact, data is in KV
|
|
468
|
+
return ctx.passthrough();
|
|
469
|
+
},
|
|
470
|
+
);
|
|
471
|
+
|
|
472
|
+
export const Product = Passthrough(ProductDef, async (ctx) => {
|
|
473
|
+
// At runtime: read from KV, fall back to DB
|
|
474
|
+
const cached = await kv.get(`product:${ctx.params.id}`);
|
|
475
|
+
if (cached) return cached;
|
|
476
|
+
return <Product data={await ctx.env.DB.getProduct(ctx.params.id)} />;
|
|
477
|
+
});
|
|
478
|
+
```
|
|
479
|
+
|
|
480
|
+
### Build logs
|
|
481
|
+
|
|
482
|
+
Passthrough entries are logged distinctly:
|
|
483
|
+
|
|
484
|
+
```
|
|
485
|
+
[rango] OK /blog/a (42ms)
|
|
486
|
+
[rango] PASS /blog/b (3ms) - live fallback
|
|
487
|
+
[rango] OK /blog/c (38ms)
|
|
488
|
+
```
|
|
489
|
+
|
|
215
490
|
## Edge Cases and Constraints
|
|
216
491
|
|
|
217
492
|
### Loaders are always live
|
|
493
|
+
|
|
218
494
|
Loaders on pre-rendered routes run at request time. They are bundled normally
|
|
219
495
|
and need `cache()` for caching. Do not use build-only APIs in loaders.
|
|
220
496
|
|
|
221
497
|
### Handle data is frozen
|
|
498
|
+
|
|
222
499
|
Handle values pushed via `ctx.use()` during pre-rendering are baked into the
|
|
223
500
|
Flight payload. They do not update at request time.
|
|
224
501
|
|
|
225
502
|
### Server actions work normally
|
|
503
|
+
|
|
226
504
|
Actions do not re-render the B segment. The pre-rendered handler output stays
|
|
227
|
-
frozen. Loaders are live and can be revalidated by actions. With `
|
|
228
|
-
and `revalidate()`, the handler
|
|
505
|
+
frozen. Loaders are live and can be revalidated by actions. With `Passthrough()`
|
|
506
|
+
and `revalidate()`, the live handler can re-render.
|
|
229
507
|
|
|
230
508
|
### Empty getParams
|
|
509
|
+
|
|
231
510
|
If `getParams` returns an empty array, no Flight payloads are written. No error.
|
|
232
511
|
|
|
233
512
|
### Route name is required
|
|
513
|
+
|
|
234
514
|
Routes using `Prerender` must have a `name` in path options.
|
|
235
515
|
The name is used as the storage key for Flight payloads.
|
|
236
516
|
|
|
237
|
-
### No revalidate without
|
|
238
|
-
|
|
517
|
+
### No revalidate without Passthrough
|
|
518
|
+
|
|
519
|
+
Using `revalidate()` without `Passthrough()` produces a build-time warning.
|
|
239
520
|
The handler is evicted -- there is nothing to re-render.
|
|
240
521
|
|
|
241
|
-
### loading() is ignored without
|
|
522
|
+
### loading() is ignored without Passthrough
|
|
523
|
+
|
|
242
524
|
Pre-rendered segments are fully resolved at build time and never suspend.
|
|
243
|
-
With `
|
|
525
|
+
With `Passthrough()`, `loading()` works for live fallback renders.
|
|
244
526
|
|
|
245
527
|
## Complete Example
|
|
246
528
|
|
|
247
529
|
```typescript
|
|
248
530
|
// pages/guides-handler.tsx
|
|
249
|
-
import { Prerender } from "@rangojs/router";
|
|
531
|
+
import { Prerender, Passthrough } from "@rangojs/router";
|
|
250
532
|
import { Link } from "@rangojs/router/client";
|
|
251
533
|
import { href } from "../router.js";
|
|
252
534
|
|
|
@@ -255,7 +537,7 @@ const knownGuides: Record<string, string> = {
|
|
|
255
537
|
caching: "Caching Guide",
|
|
256
538
|
};
|
|
257
539
|
|
|
258
|
-
export const
|
|
540
|
+
export const GuidesDetailDef = Prerender<{ slug: string }>(
|
|
259
541
|
async () => Object.keys(knownGuides).map((slug) => ({ slug })),
|
|
260
542
|
async (ctx) => {
|
|
261
543
|
const title = knownGuides[ctx.params.slug] ?? `Guide: ${ctx.params.slug}`;
|
|
@@ -271,9 +553,23 @@ export const GuidesDetail = Prerender<{ slug: string }>(
|
|
|
271
553
|
</div>
|
|
272
554
|
);
|
|
273
555
|
},
|
|
274
|
-
{ passthrough: true },
|
|
275
556
|
);
|
|
276
557
|
|
|
558
|
+
export const GuidesDetail = Passthrough(GuidesDetailDef, async (ctx) => {
|
|
559
|
+
const title = knownGuides[ctx.params.slug] ?? `Guide: ${ctx.params.slug}`;
|
|
560
|
+
return (
|
|
561
|
+
<div>
|
|
562
|
+
<h1>{title}</h1>
|
|
563
|
+
<p>Slug: {ctx.params.slug}</p>
|
|
564
|
+
<nav>
|
|
565
|
+
<Link to={href("guides.detail", { slug: "routing" })}>Routing</Link>
|
|
566
|
+
{" | "}
|
|
567
|
+
<Link to={href("guides.detail", { slug: "dynamic-test" })}>Dynamic</Link>
|
|
568
|
+
</nav>
|
|
569
|
+
</div>
|
|
570
|
+
);
|
|
571
|
+
});
|
|
572
|
+
|
|
277
573
|
// pages/guides.tsx
|
|
278
574
|
import { urls } from "@rangojs/router";
|
|
279
575
|
import { GuidesDetail } from "./guides-handler.js";
|
|
@@ -283,23 +579,107 @@ export const guidesPatterns = urls(({ path }) => [
|
|
|
283
579
|
]);
|
|
284
580
|
|
|
285
581
|
// urls.tsx
|
|
286
|
-
import { urls
|
|
582
|
+
import { urls } from "@rangojs/router";
|
|
287
583
|
import { guidesPatterns } from "./pages/guides.js";
|
|
288
584
|
|
|
289
|
-
export const urlpatterns = urls(({ path }) => [
|
|
585
|
+
export const urlpatterns = urls(({ path, include }) => [
|
|
290
586
|
path("/", HomePage, { name: "home" }),
|
|
291
587
|
include("/guides", guidesPatterns, { name: "guides" }),
|
|
292
588
|
]);
|
|
293
589
|
```
|
|
294
590
|
|
|
591
|
+
## Interaction with intercept()
|
|
592
|
+
|
|
593
|
+
When a pre-rendered route is also the target of an `intercept()`, the build system
|
|
594
|
+
resolves the intercept handler at build time and stores a combined entry (main
|
|
595
|
+
segments + intercept segments) under an `/i`-suffixed key alongside the main entry:
|
|
596
|
+
|
|
597
|
+
```
|
|
598
|
+
prerender store keys:
|
|
599
|
+
"blog.post/a1b2c3" -> main segments (full page)
|
|
600
|
+
"blog.post/a1b2c3/i" -> main segments + intercept segments (modal variant)
|
|
601
|
+
```
|
|
602
|
+
|
|
603
|
+
At runtime, the cache-lookup middleware checks `ctx.isIntercept`:
|
|
604
|
+
|
|
605
|
+
- **Intercept navigation**: looks up `paramHash/i` first. If found, yields
|
|
606
|
+
the combined entry. `handleCacheHitIntercept()` extracts intercept segments
|
|
607
|
+
(filtered by `namespace?.startsWith("intercept:")`) and sets up slots.
|
|
608
|
+
- **Direct navigation**: looks up `paramHash` (no suffix). Standard prerender path.
|
|
609
|
+
- **Intercept miss (no `/i` entry)**: falls through to the normal pipeline so
|
|
610
|
+
intercept-resolution middleware runs live. This handles `when()` conditions
|
|
611
|
+
that prevented pre-rendering.
|
|
612
|
+
|
|
613
|
+
The `when()` callback receives an `InterceptSelectorContext` with `from.pathname`
|
|
614
|
+
which is unknown at build time. All intercepts are pre-rendered unconditionally;
|
|
615
|
+
`when()` is evaluated at runtime by the intercept-resolution middleware.
|
|
616
|
+
|
|
617
|
+
### Example: Pre-rendered route with intercept
|
|
618
|
+
|
|
619
|
+
```typescript
|
|
620
|
+
// Route handler is pre-rendered at build time
|
|
621
|
+
export const ProductDetail = Prerender(
|
|
622
|
+
async () => [{ slug: "shoes" }, { slug: "jacket" }],
|
|
623
|
+
async (ctx) => <ProductPage slug={ctx.params.slug} />,
|
|
624
|
+
);
|
|
625
|
+
|
|
626
|
+
// urls.tsx
|
|
627
|
+
layout(ShopLayout, () => [
|
|
628
|
+
path("/:slug", ProductDetail, { name: "detail" }, () => [
|
|
629
|
+
loader(ProductLoader),
|
|
630
|
+
]),
|
|
631
|
+
|
|
632
|
+
// Intercept detail from shop index into a modal.
|
|
633
|
+
// At build time, this is resolved and stored under the /i key.
|
|
634
|
+
intercept("@modal", ".detail", <ProductModal />, () => [
|
|
635
|
+
when(({ from }) => from.pathname === "/shop"),
|
|
636
|
+
loader(ProductLoader),
|
|
637
|
+
]),
|
|
638
|
+
])
|
|
639
|
+
```
|
|
640
|
+
|
|
641
|
+
Both `ProductPage` (main) and `ProductModal` (intercept) are frozen at build time.
|
|
642
|
+
Loaders run fresh at request time for both variants.
|
|
643
|
+
|
|
295
644
|
## Trie Flags
|
|
296
645
|
|
|
297
646
|
Pre-rendered routes set flags on the route trie leaf at build time:
|
|
298
647
|
|
|
299
648
|
- `pr: true` -- route has pre-rendered B segment data
|
|
300
|
-
- `pt: true` --
|
|
649
|
+
- `pt: true` -- route wrapped with `Passthrough()` (live handler available)
|
|
301
650
|
|
|
302
651
|
At runtime, the cache-lookup middleware uses these flags:
|
|
652
|
+
|
|
303
653
|
- `pr + hit` -- serve pre-rendered Flight payload
|
|
304
|
-
- `pr + pt + miss` -- fall through to live handler
|
|
654
|
+
- `pr + pt + miss` -- fall through to Passthrough live handler
|
|
305
655
|
- `pr + miss` (no pt) -- fall through (handler stubbed, no live render)
|
|
656
|
+
|
|
657
|
+
## Contributor Checklist
|
|
658
|
+
|
|
659
|
+
Before changing prerender behavior, run these tests.
|
|
660
|
+
|
|
661
|
+
### Tests to run
|
|
662
|
+
|
|
663
|
+
```bash
|
|
664
|
+
# Core prerender e2e (Passthrough, eviction, loaders, sub-use, intercept)
|
|
665
|
+
pnpm --filter @rangojs/router exec playwright test prerender
|
|
666
|
+
|
|
667
|
+
# Prerender-specific unit test
|
|
668
|
+
pnpm --filter @rangojs/router run test:unit -- prerender-passthrough
|
|
669
|
+
|
|
670
|
+
# Semantic matrix (prerender rows cover intercept + ctx propagation)
|
|
671
|
+
pnpm --filter @rangojs/router exec playwright test semantic-matrix
|
|
672
|
+
|
|
673
|
+
# Handler-first (ctx.set/get visibility with prerender handlers)
|
|
674
|
+
pnpm --filter @rangojs/router exec playwright test handler-first
|
|
675
|
+
```
|
|
676
|
+
|
|
677
|
+
### Dev-only vs build-parity
|
|
678
|
+
|
|
679
|
+
- Prerender e2e tests run against a real production build by default (the
|
|
680
|
+
fixture builds the test app). Dev-mode prerender behavior is tested via
|
|
681
|
+
`/__rsc_prerender` endpoint tests and node.js dev-server fallback.
|
|
682
|
+
- Log-based assertions (build output lines, debug cache logs) are inherently
|
|
683
|
+
dev/build-only and do not need a production counterpart.
|
|
684
|
+
- Behavioral assertions (rendered content, loader freshness, Passthrough
|
|
685
|
+
fallback, intercept variant selection) must work in the production build.
|