@rangojs/router 0.0.0-experimental.debug-cache-fix → 0.0.0-experimental.df410dd5
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 +196 -43
- 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 +269 -96
- 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/testing/vitest.js +48 -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 +2659 -883
- 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/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/dist/vite/virtual-entries.js +110 -0
- package/dist/vite/virtual-entries.js.map +1 -0
- package/package.json +57 -11
- package/skills/breadcrumbs/SKILL.md +3 -1
- package/skills/bundle-analysis/SKILL.md +159 -0
- package/skills/cache-guide/SKILL.md +243 -21
- package/skills/caching/SKILL.md +118 -2
- package/skills/composability/SKILL.md +27 -2
- package/skills/document-cache/SKILL.md +78 -55
- package/skills/handler-use/SKILL.md +364 -0
- package/skills/hooks/SKILL.md +229 -20
- package/skills/host-router/SKILL.md +45 -20
- package/skills/i18n/SKILL.md +276 -0
- package/skills/intercept/SKILL.md +46 -4
- package/skills/layout/SKILL.md +28 -7
- package/skills/links/SKILL.md +249 -17
- package/skills/loader/SKILL.md +273 -53
- package/skills/middleware/SKILL.md +49 -12
- package/skills/migrate-nextjs/SKILL.md +562 -0
- package/skills/migrate-react-router/SKILL.md +769 -0
- package/skills/mime-routes/SKILL.md +27 -0
- package/skills/observability/SKILL.md +137 -0
- package/skills/parallel/SKILL.md +71 -6
- package/skills/prerender/SKILL.md +123 -100
- package/skills/rango/SKILL.md +242 -22
- package/skills/react-compiler/SKILL.md +168 -0
- package/skills/response-routes/SKILL.md +66 -9
- package/skills/route/SKILL.md +88 -4
- package/skills/router-setup/SKILL.md +90 -5
- package/skills/server-actions/SKILL.md +751 -0
- package/skills/streams-and-websockets/SKILL.md +283 -0
- package/skills/testing/SKILL.md +776 -0
- package/skills/typesafety/SKILL.md +329 -27
- package/skills/use-cache/SKILL.md +34 -5
- package/skills/view-transitions/SKILL.md +294 -0
- package/src/__augment-tests__/augment.ts +81 -0
- package/src/__augment-tests__/augmented.check.ts +117 -0
- package/src/__internal.ts +1 -1
- package/src/browser/action-coordinator.ts +53 -36
- package/src/browser/app-shell.ts +52 -0
- package/src/browser/app-version.ts +14 -0
- package/src/browser/event-controller.ts +86 -70
- package/src/browser/history-state.ts +21 -0
- package/src/browser/index.ts +3 -3
- package/src/browser/navigation-bridge.ts +101 -13
- package/src/browser/navigation-client.ts +125 -53
- package/src/browser/navigation-store.ts +75 -17
- package/src/browser/navigation-transaction.ts +10 -28
- package/src/browser/partial-update.ts +90 -30
- package/src/browser/prefetch/cache.ts +129 -21
- package/src/browser/prefetch/fetch.ts +156 -18
- package/src/browser/prefetch/queue.ts +92 -29
- package/src/browser/prefetch/resource-ready.ts +77 -0
- package/src/browser/rango-state.ts +53 -13
- package/src/browser/react/Link.tsx +72 -8
- package/src/browser/react/NavigationProvider.tsx +83 -33
- package/src/browser/react/context.ts +7 -2
- package/src/browser/react/filter-segment-order.ts +51 -7
- package/src/browser/react/index.ts +3 -0
- package/src/browser/react/location-state-shared.ts +175 -4
- package/src/browser/react/location-state.ts +39 -13
- package/src/browser/react/use-handle.ts +23 -64
- package/src/browser/react/use-navigation.ts +22 -2
- package/src/browser/react/use-params.ts +20 -8
- package/src/browser/react/use-reverse.ts +106 -0
- package/src/browser/react/use-router.ts +43 -10
- package/src/browser/react/use-segments.ts +11 -8
- package/src/browser/response-adapter.ts +25 -0
- package/src/browser/rsc-router.tsx +87 -22
- package/src/browser/scroll-restoration.ts +29 -19
- package/src/browser/segment-reconciler.ts +36 -14
- package/src/browser/segment-structure-assert.ts +2 -2
- package/src/browser/server-action-bridge.ts +31 -36
- package/src/browser/types.ts +48 -5
- package/src/build/collect-fallback-refs.ts +107 -0
- package/src/build/generate-manifest.ts +65 -40
- package/src/build/generate-route-types.ts +5 -0
- package/src/build/index.ts +2 -0
- package/src/build/route-trie.ts +52 -25
- package/src/build/route-types/codegen.ts +4 -4
- package/src/build/route-types/include-resolution.ts +9 -2
- package/src/build/route-types/per-module-writer.ts +7 -4
- package/src/build/route-types/router-processing.ts +266 -86
- package/src/build/route-types/scan-filter.ts +9 -2
- package/src/build/route-types/source-scan.ts +118 -0
- package/src/build/runtime-discovery.ts +9 -20
- package/src/cache/cache-scope.ts +40 -56
- package/src/cache/cf/cf-cache-store.ts +54 -13
- package/src/cache/taint.ts +55 -0
- package/src/client.rsc.tsx +3 -0
- package/src/client.tsx +94 -238
- package/src/context-var.ts +72 -2
- package/src/decode-loader-results.ts +36 -0
- package/src/errors.ts +30 -1
- package/src/handle.ts +65 -12
- package/src/host/index.ts +2 -2
- package/src/host/router.ts +129 -57
- package/src/host/types.ts +31 -2
- package/src/host/utils.ts +1 -1
- package/src/href-client.ts +140 -20
- package/src/index.rsc.ts +12 -5
- package/src/index.ts +61 -11
- package/src/loader-store.ts +500 -0
- package/src/loader.rsc.ts +21 -6
- package/src/loader.ts +3 -10
- package/src/missing-id-error.ts +68 -0
- package/src/outlet-context.ts +1 -1
- package/src/prerender/store.ts +5 -4
- package/src/prerender.ts +141 -80
- package/src/response-utils.ts +37 -0
- package/src/reverse.ts +65 -15
- package/src/route-content-wrapper.tsx +6 -28
- package/src/route-definition/dsl-helpers.ts +411 -261
- package/src/route-definition/helper-factories.ts +29 -139
- package/src/route-definition/helpers-types.ts +110 -34
- package/src/route-definition/index.ts +3 -0
- package/src/route-definition/redirect.ts +9 -1
- package/src/route-definition/resolve-handler-use.ts +155 -0
- package/src/route-definition/use-item-types.ts +32 -0
- package/src/route-types.ts +37 -41
- package/src/router/basename.ts +14 -0
- package/src/router/content-negotiation.ts +113 -1
- package/src/router/error-handling.ts +1 -1
- package/src/router/handler-context.ts +77 -38
- package/src/router/intercept-resolution.ts +13 -22
- package/src/router/lazy-includes.ts +8 -8
- package/src/router/loader-resolution.ts +174 -22
- package/src/router/manifest.ts +22 -13
- package/src/router/match-api.ts +128 -192
- package/src/router/match-handlers.ts +63 -20
- package/src/router/match-middleware/cache-lookup.ts +70 -97
- package/src/router/match-middleware/cache-store.ts +3 -2
- package/src/router/match-middleware/segment-resolution.ts +53 -0
- package/src/router/match-result.ts +103 -4
- package/src/router/metrics.ts +1 -1
- package/src/router/middleware-types.ts +21 -34
- package/src/router/middleware.ts +101 -89
- package/src/router/navigation-snapshot.ts +182 -0
- package/src/router/pattern-matching.ts +101 -17
- package/src/router/prerender-match.ts +110 -10
- package/src/router/preview-match.ts +32 -102
- package/src/router/request-classification.ts +286 -0
- package/src/router/revalidation.ts +58 -2
- package/src/router/route-snapshot.ts +245 -0
- package/src/router/router-interfaces.ts +77 -28
- package/src/router/router-options.ts +76 -11
- package/src/router/router-registry.ts +2 -5
- package/src/router/segment-resolution/fresh.ts +105 -13
- package/src/router/segment-resolution/helpers.ts +29 -24
- package/src/router/segment-resolution/revalidation.ts +236 -112
- package/src/router/segment-resolution/view-transition-default.ts +36 -0
- package/src/router/substitute-pattern-params.ts +56 -0
- package/src/router/telemetry.ts +99 -0
- package/src/router/trie-matching.ts +18 -13
- package/src/router/types.ts +9 -0
- package/src/router/url-params.ts +49 -0
- package/src/router.ts +86 -22
- package/src/rsc/handler-context.ts +2 -2
- package/src/rsc/handler.ts +440 -381
- package/src/rsc/helpers.ts +91 -43
- package/src/rsc/index.ts +1 -1
- package/src/rsc/loader-fetch.ts +23 -3
- package/src/rsc/manifest-init.ts +5 -1
- package/src/rsc/origin-guard.ts +28 -10
- package/src/rsc/progressive-enhancement.ts +18 -2
- package/src/rsc/response-route-handler.ts +46 -53
- package/src/rsc/rsc-rendering.ts +41 -48
- package/src/rsc/runtime-warnings.ts +9 -10
- package/src/rsc/server-action.ts +25 -37
- package/src/rsc/ssr-setup.ts +18 -2
- package/src/rsc/types.ts +17 -3
- package/src/search-params.ts +4 -4
- package/src/segment-content-promise.ts +67 -0
- package/src/segment-loader-promise.ts +122 -0
- package/src/segment-system.tsx +132 -116
- package/src/serialize.ts +243 -0
- package/src/server/context.ts +190 -51
- package/src/server/cookie-store.ts +28 -4
- package/src/server/handle-store.ts +19 -0
- package/src/server/loader-registry.ts +9 -8
- package/src/server/request-context.ts +195 -57
- package/src/ssr/index.tsx +8 -1
- package/src/static-handler.ts +19 -7
- package/src/testing/cache-status.ts +166 -0
- package/src/testing/collect-handle.ts +63 -0
- package/src/testing/dispatch.ts +440 -0
- package/src/testing/dom.entry.ts +22 -0
- package/src/testing/e2e/fixture.ts +154 -0
- package/src/testing/e2e/index.ts +149 -0
- package/src/testing/e2e/matchers.ts +51 -0
- package/src/testing/e2e/page-helpers.ts +272 -0
- package/src/testing/e2e/parity.ts +306 -0
- package/src/testing/e2e/server.ts +183 -0
- package/src/testing/flight-matchers.ts +104 -0
- package/src/testing/flight-runtime.d.ts +57 -0
- package/src/testing/flight-tree.ts +309 -0
- package/src/testing/flight.entry.ts +39 -0
- package/src/testing/flight.ts +197 -0
- package/src/testing/generated-routes.ts +223 -0
- package/src/testing/index.ts +106 -0
- package/src/testing/internal/context.ts +304 -0
- package/src/testing/internal/flight-client-globals.ts +30 -0
- package/src/testing/render-route.tsx +565 -0
- package/src/testing/run-loader.ts +341 -0
- package/src/testing/run-middleware.ts +179 -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 +185 -0
- package/src/types/cache-types.ts +4 -4
- package/src/types/global-namespace.ts +39 -26
- package/src/types/handler-context.ts +103 -67
- package/src/types/index.ts +1 -0
- package/src/types/loader-types.ts +41 -15
- package/src/types/request-scope.ts +126 -0
- package/src/types/route-entry.ts +12 -1
- package/src/types/segments.ts +36 -2
- package/src/urls/include-helper.ts +34 -67
- package/src/urls/index.ts +0 -3
- package/src/urls/path-helper-types.ts +50 -9
- package/src/urls/path-helper.ts +63 -63
- package/src/urls/pattern-types.ts +48 -19
- package/src/urls/response-types.ts +25 -22
- package/src/urls/type-extraction.ts +26 -116
- package/src/urls/urls-function.ts +1 -5
- package/src/use-loader.tsx +487 -44
- package/src/vite/debug.ts +185 -0
- package/src/vite/discovery/bundle-postprocess.ts +34 -37
- package/src/vite/discovery/discover-routers.ts +105 -51
- 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 +188 -93
- package/src/vite/discovery/route-types-writer.ts +40 -84
- package/src/vite/discovery/self-gen-tracking.ts +27 -1
- package/src/vite/discovery/state.ts +46 -4
- package/src/vite/discovery/virtual-module-codegen.ts +13 -23
- package/src/vite/index.ts +6 -0
- package/src/vite/plugin-types.ts +126 -4
- package/src/vite/plugins/cjs-to-esm.ts +8 -7
- package/src/vite/plugins/client-ref-dedup.ts +16 -0
- package/src/vite/plugins/client-ref-hashing.ts +28 -5
- 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 +214 -0
- package/src/vite/plugins/expose-action-id.ts +54 -30
- package/src/vite/plugins/expose-id-utils.ts +24 -8
- package/src/vite/plugins/expose-ids/export-analysis.ts +100 -20
- package/src/vite/plugins/expose-ids/handler-transform.ts +12 -35
- package/src/vite/plugins/expose-ids/loader-transform.ts +3 -5
- package/src/vite/plugins/expose-ids/router-transform.ts +20 -3
- package/src/vite/plugins/expose-internal-ids.ts +544 -317
- package/src/vite/plugins/performance-tracks.ts +92 -0
- package/src/vite/plugins/refresh-cmd.ts +88 -26
- package/src/vite/plugins/use-cache-transform.ts +65 -50
- package/src/vite/plugins/version-injector.ts +39 -23
- package/src/vite/plugins/version-plugin.ts +59 -2
- package/src/vite/plugins/virtual-entries.ts +2 -2
- package/src/vite/rango.ts +130 -26
- package/src/vite/router-discovery.ts +920 -129
- package/src/vite/utils/ast-handler-extract.ts +15 -15
- package/src/vite/utils/banner.ts +1 -1
- package/src/vite/utils/bundle-analysis.ts +4 -2
- package/src/vite/utils/client-chunks.ts +190 -0
- package/src/vite/utils/forward-user-plugins.ts +193 -0
- package/src/vite/utils/manifest-utils.ts +21 -5
- package/src/vite/utils/package-resolution.ts +41 -1
- package/src/vite/utils/prerender-utils.ts +38 -5
- package/src/vite/utils/shared-utils.ts +109 -27
- package/src/browser/action-response-classifier.ts +0 -99
|
@@ -0,0 +1,341 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* runLoader — unit-test a loader function in isolation.
|
|
3
|
+
*
|
|
4
|
+
* Pass the RAW async loader body `(ctx) => ...`, or a registered `createLoader()`
|
|
5
|
+
* handle (its fn is recovered from the fetchable registry by `$$id`). The raw
|
|
6
|
+
* body needs no build step; the handle works because `createLoader` assigns a
|
|
7
|
+
* runtime-fallback `$$id` and registers its fn even without the Vite plugin (when
|
|
8
|
+
* imported through the server build — the consumer's `@rangojs/router` under the
|
|
9
|
+
* `rangoTestConfig()` preset). Either way the function is invoked directly with a
|
|
10
|
+
* constructed LoaderContext.
|
|
11
|
+
*
|
|
12
|
+
* The LoaderContext mirrors the canonical shape the router builds at runtime
|
|
13
|
+
* (see createUseFunction in server/request-context.ts). The loader runs inside
|
|
14
|
+
* runWithRequestContext so getRequestContext(), cookie reads, and header
|
|
15
|
+
* mutations resolve exactly as in production.
|
|
16
|
+
*
|
|
17
|
+
* Limitations (v1):
|
|
18
|
+
* - `ctx.rendered()` is not available — it requires the DSL render barrier,
|
|
19
|
+
* which only exists inside a full match. Calling it throws.
|
|
20
|
+
* - `ctx.reverse()` throws unless `routeMap` is provided (it does NOT fall back
|
|
21
|
+
* to the global route map — that would leak whichever routes another test
|
|
22
|
+
* registered).
|
|
23
|
+
* - `ctx.use(handle)` follows the production rule: reading a handle before
|
|
24
|
+
* `await ctx.rendered()` throws (pass `rendered` to mock the barrier).
|
|
25
|
+
* - `use cache` functions only cache (and only fire their taint/profile guards)
|
|
26
|
+
* when a `cacheStore` is provided — without one, registerCachedFunction
|
|
27
|
+
* bypasses (it checks for a store first). Pass `cacheStore`/`cacheProfiles`
|
|
28
|
+
* to exercise cached loaders; otherwise such a call runs uncached, like an
|
|
29
|
+
* app with no cache configured.
|
|
30
|
+
* - `formData` is exposed verbatim; no multipart parsing is performed.
|
|
31
|
+
* - Scoped dot-local reverse (`.sibling`) uses only the supplied `routeMap`;
|
|
32
|
+
* the production root-scoping signal (derived from the global registry) is
|
|
33
|
+
* not modeled, so a dotted name resolves against `routeMap` as given.
|
|
34
|
+
*/
|
|
35
|
+
|
|
36
|
+
import {
|
|
37
|
+
runWithRequestContext,
|
|
38
|
+
type RequestContext,
|
|
39
|
+
} from "../server/request-context.js";
|
|
40
|
+
import { createReverseFunction } from "../router/handler-context.js";
|
|
41
|
+
import { getFetchableLoader } from "../server/fetchable-loader-store.js";
|
|
42
|
+
import type { LoaderContext, LoaderDefinition } from "../types.js";
|
|
43
|
+
import type { ContextVar } from "../context-var.js";
|
|
44
|
+
import { isHandle, type Handle } from "../handle.js";
|
|
45
|
+
import type { ThemeConfig } from "../theme/types.js";
|
|
46
|
+
import type { SegmentCacheStore } from "../cache/types.js";
|
|
47
|
+
import type { CacheProfile } from "../cache/profile-registry.js";
|
|
48
|
+
import {
|
|
49
|
+
createTestRequestContext,
|
|
50
|
+
type CreateTestContextOptions,
|
|
51
|
+
type VarsInit,
|
|
52
|
+
} from "./internal/context.js";
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* The loader context surfaced to a `runLoader` body. It mirrors the runtime
|
|
56
|
+
* LoaderContext but RELAXES the two members that are otherwise bound to the
|
|
57
|
+
* app's global route/var augmentation, because in a unit test they are driven by
|
|
58
|
+
* the `routeMap` / `vars` options instead:
|
|
59
|
+
* - `reverse` accepts any route name (the names come from `routeMap`, not the
|
|
60
|
+
* registered route map), and
|
|
61
|
+
* - `get` accepts any string key or ContextVar (keys come from `vars`).
|
|
62
|
+
*/
|
|
63
|
+
export type TestLoaderContext<TEnv = any> = Omit<
|
|
64
|
+
LoaderContext<any, TEnv>,
|
|
65
|
+
"reverse" | "get"
|
|
66
|
+
> & {
|
|
67
|
+
reverse: (
|
|
68
|
+
name: string,
|
|
69
|
+
params?: Record<string, string>,
|
|
70
|
+
search?: Record<string, unknown>,
|
|
71
|
+
) => string;
|
|
72
|
+
get: {
|
|
73
|
+
<T>(contextVar: ContextVar<T>): T | undefined;
|
|
74
|
+
<T = unknown>(key: string): T | undefined;
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* A resolver for `ctx.use(OtherLoader)` composition. Receives the dependency
|
|
80
|
+
* loader definition and returns its data (or a promise of it). When omitted,
|
|
81
|
+
* `ctx.use` delegates to the real request-context use(), which executes the
|
|
82
|
+
* dependency's own `fn` if present.
|
|
83
|
+
*/
|
|
84
|
+
export type UseResolver = <T>(
|
|
85
|
+
loader: LoaderDefinition<T, any>,
|
|
86
|
+
) => Promise<T> | T;
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Options for runLoader.
|
|
90
|
+
*/
|
|
91
|
+
export interface RunLoaderOptions<TEnv = any> {
|
|
92
|
+
/** Route params surfaced as `ctx.params` and `ctx.routeParams`. */
|
|
93
|
+
params?: Record<string, string>;
|
|
94
|
+
/** Search params; merged into the request URL so `ctx.searchParams` reflects them. */
|
|
95
|
+
search?: Record<string, string>;
|
|
96
|
+
/**
|
|
97
|
+
* The TYPED `ctx.search` object a route's search schema would produce. Distinct
|
|
98
|
+
* from `search` (which sets the raw `ctx.searchParams`): a loader on a typed
|
|
99
|
+
* search route reads `ctx.search`, which is otherwise `{}` in a test.
|
|
100
|
+
*/
|
|
101
|
+
searchData?: Record<string, unknown>;
|
|
102
|
+
/** Router basename surfaced on the context (drives redirect() prefixing). */
|
|
103
|
+
basename?: string;
|
|
104
|
+
/**
|
|
105
|
+
* Theme config in the same shape `createRouter({ theme })` takes (e.g. `true`
|
|
106
|
+
* or `{ themes: [...] }`). Without it `ctx.theme`/`ctx.setTheme` are inert.
|
|
107
|
+
*/
|
|
108
|
+
theme?: ThemeConfig | true;
|
|
109
|
+
/** Environment bindings surfaced as `ctx.env`. */
|
|
110
|
+
env?: TEnv;
|
|
111
|
+
/** Override the backing Request (string or Request). Defaults to a localhost GET. */
|
|
112
|
+
request?: Request | string;
|
|
113
|
+
/** Variables a prior middleware would have set (object or [key, value] list). */
|
|
114
|
+
vars?: VarsInit;
|
|
115
|
+
/** Route name -> pattern map enabling `ctx.reverse()`. */
|
|
116
|
+
routeMap?: Record<string, string>;
|
|
117
|
+
/** Matched route name for scoped `.name` reverse resolution. */
|
|
118
|
+
routeName?: string;
|
|
119
|
+
/** HTTP method surfaced as `ctx.method`. Defaults to "GET". */
|
|
120
|
+
method?: string;
|
|
121
|
+
/** Request body surfaced as `ctx.body`. */
|
|
122
|
+
body?: unknown;
|
|
123
|
+
/** Form data surfaced as `ctx.formData`. */
|
|
124
|
+
formData?: FormData;
|
|
125
|
+
/** Resolver for `ctx.use(OtherLoader)` composition. */
|
|
126
|
+
use?: UseResolver;
|
|
127
|
+
/**
|
|
128
|
+
* Cache store backing `use cache` functions the loader invokes. Without it,
|
|
129
|
+
* a cached function bypasses (registerCachedFunction checks for a store
|
|
130
|
+
* first) and runs uncached — its taint/profile guards never fire. Pass one
|
|
131
|
+
* (e.g. `new MemorySegmentCacheStore()`) to test a cached loader.
|
|
132
|
+
*/
|
|
133
|
+
cacheStore?: SegmentCacheStore;
|
|
134
|
+
/** Cache profiles (the `createRouter({ cacheProfiles })` shape). */
|
|
135
|
+
cacheProfiles?: Record<string, CacheProfile>;
|
|
136
|
+
/**
|
|
137
|
+
* Mock the `ctx.rendered()` render barrier so a loader that does
|
|
138
|
+
* `await ctx.rendered()` (to read handle data pushed during render) can be
|
|
139
|
+
* unit-tested. By default `ctx.rendered()` throws, because the real barrier
|
|
140
|
+
* only exists during a full route match. Pass `true` to resolve it
|
|
141
|
+
* immediately, or a function to control its timing/side effects.
|
|
142
|
+
*
|
|
143
|
+
* This tests the loader's POST-barrier compute logic against the seeded
|
|
144
|
+
* `handles` below — it does NOT exercise the real push -> accumulate -> barrier
|
|
145
|
+
* wiring (that stays e2e). Pair with `handles` to feed `ctx.use(SomeHandle)`.
|
|
146
|
+
*/
|
|
147
|
+
rendered?: boolean | (() => void | Promise<void>);
|
|
148
|
+
/**
|
|
149
|
+
* Seed the values `ctx.use(SomeHandle)` returns — the ACCUMULATED handle data a
|
|
150
|
+
* loader reads after `await ctx.rendered()`. Matched by handle reference, so a
|
|
151
|
+
* real handle works regardless of its (build-injected) `$$id`.
|
|
152
|
+
*
|
|
153
|
+
* @example
|
|
154
|
+
* await runLoader(livePricesBody, {
|
|
155
|
+
* rendered: true,
|
|
156
|
+
* handles: [[RenderedProducts, ["widget-a", "widget-b"]]],
|
|
157
|
+
* });
|
|
158
|
+
*/
|
|
159
|
+
handles?: ReadonlyArray<readonly [Handle<any, any>, unknown]>;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* Merge `search` into a request's URL, returning a value `toRequest` can build.
|
|
164
|
+
* Keeps the original method/headers/body when a Request was passed.
|
|
165
|
+
*/
|
|
166
|
+
function withSearch(
|
|
167
|
+
request: Request | string | undefined,
|
|
168
|
+
search: Record<string, string> | undefined,
|
|
169
|
+
): Request | string | undefined {
|
|
170
|
+
if (!search) return request;
|
|
171
|
+
const DEFAULT_ORIGIN = "http://localhost/";
|
|
172
|
+
if (request instanceof Request) {
|
|
173
|
+
const url = new URL(request.url);
|
|
174
|
+
for (const [key, value] of Object.entries(search)) {
|
|
175
|
+
url.searchParams.set(key, value);
|
|
176
|
+
}
|
|
177
|
+
return new Request(url, request);
|
|
178
|
+
}
|
|
179
|
+
const url = new URL(request ?? DEFAULT_ORIGIN, DEFAULT_ORIGIN);
|
|
180
|
+
for (const [key, value] of Object.entries(search)) {
|
|
181
|
+
url.searchParams.set(key, value);
|
|
182
|
+
}
|
|
183
|
+
return url.toString();
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
/** A raw loader body, or a registered `createLoader()` handle (its fn is recovered). */
|
|
187
|
+
export type RunnableLoader<T> =
|
|
188
|
+
| ((ctx: TestLoaderContext) => Promise<T> | T)
|
|
189
|
+
| LoaderDefinition<T, any>;
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* Resolve the function to run from either a raw body or a `createLoader()` handle.
|
|
193
|
+
*
|
|
194
|
+
* A handle carries no inline body (`createLoader` registers it in the fetchable
|
|
195
|
+
* registry by `$$id`), so recover it from there — `def.fn` first (a hand-built
|
|
196
|
+
* def), then the registry. This works when the handle resolves through the
|
|
197
|
+
* SERVER build (the consumer's `@rangojs/router` under `rangoTestConfig`, which
|
|
198
|
+
* registers the fn); the CLIENT stub drops the body, so a handle imported that
|
|
199
|
+
* way is unrecoverable and we say so explicitly.
|
|
200
|
+
*/
|
|
201
|
+
function resolveLoaderFn<T>(
|
|
202
|
+
loader: RunnableLoader<T>,
|
|
203
|
+
): (ctx: TestLoaderContext) => Promise<T> | T {
|
|
204
|
+
if (typeof loader === "function") {
|
|
205
|
+
return loader as (ctx: TestLoaderContext) => Promise<T> | T;
|
|
206
|
+
}
|
|
207
|
+
const def = loader as LoaderDefinition<T, any>;
|
|
208
|
+
const fn = def.fn ?? getFetchableLoader(def.$$id)?.fn;
|
|
209
|
+
if (!fn) {
|
|
210
|
+
throw new Error(
|
|
211
|
+
`runLoader() received a createLoader() handle whose function could not be ` +
|
|
212
|
+
`recovered (id "${def.$$id || "<empty>"}"). The loader was likely imported ` +
|
|
213
|
+
`through the CLIENT build, which drops the body. Either import it through ` +
|
|
214
|
+
`@rangojs/router with the rangoTestConfig() preset (resolves to the server ` +
|
|
215
|
+
`build that registers the fn), or pass the raw loader body directly: ` +
|
|
216
|
+
`runLoader((ctx) => ...).`,
|
|
217
|
+
);
|
|
218
|
+
}
|
|
219
|
+
return fn as (ctx: TestLoaderContext) => Promise<T> | T;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
/**
|
|
223
|
+
* Run a loader and return its resolved data. Pass the RAW loader body, or a
|
|
224
|
+
* registered `createLoader()` handle (its fn is recovered from the registry).
|
|
225
|
+
*
|
|
226
|
+
* @example
|
|
227
|
+
* ```ts
|
|
228
|
+
* // raw body
|
|
229
|
+
* const a = await runLoader(
|
|
230
|
+
* async (ctx) => ({ id: ctx.params.id, user: ctx.get("user") }),
|
|
231
|
+
* { params: { id: "42" }, vars: { user: { name: "Ada" } } },
|
|
232
|
+
* );
|
|
233
|
+
* // registered createLoader() handle (recovered from the registry)
|
|
234
|
+
* const b = await runLoader(ProductLoader, { params: { id: "42" } });
|
|
235
|
+
* ```
|
|
236
|
+
*/
|
|
237
|
+
export async function runLoader<T>(
|
|
238
|
+
loader: RunnableLoader<T>,
|
|
239
|
+
opts: RunLoaderOptions = {},
|
|
240
|
+
): Promise<T> {
|
|
241
|
+
const loaderFn = resolveLoaderFn(loader);
|
|
242
|
+
const ctxOpts: CreateTestContextOptions<any> = {
|
|
243
|
+
env: opts.env,
|
|
244
|
+
// Bake opts.search into the request URL itself so ctx.request.url, ctx.url,
|
|
245
|
+
// and ctx.searchParams all agree (production carries the query string on the
|
|
246
|
+
// real request — a loader reading ctx.request.url must see it too).
|
|
247
|
+
request: withSearch(opts.request, opts.search),
|
|
248
|
+
requestInit: opts.method ? { method: opts.method } : undefined,
|
|
249
|
+
vars: opts.vars,
|
|
250
|
+
routeMap: opts.routeMap,
|
|
251
|
+
routeName: opts.routeName,
|
|
252
|
+
params: opts.params,
|
|
253
|
+
basename: opts.basename,
|
|
254
|
+
theme: opts.theme,
|
|
255
|
+
cacheStore: opts.cacheStore,
|
|
256
|
+
cacheProfiles: opts.cacheProfiles,
|
|
257
|
+
};
|
|
258
|
+
|
|
259
|
+
const { ctx } = createTestRequestContext(ctxOpts);
|
|
260
|
+
|
|
261
|
+
const reqCtx = ctx as RequestContext<any>;
|
|
262
|
+
|
|
263
|
+
// Seed values for ctx.use(SomeHandle), matched by handle reference (so a real
|
|
264
|
+
// handle resolves regardless of its build-injected $$id).
|
|
265
|
+
const handleSeeds = new Map<unknown, unknown>(opts.handles ?? []);
|
|
266
|
+
|
|
267
|
+
// Tracks whether the mocked render barrier has settled. ctx.use(handle)
|
|
268
|
+
// reads are gated on this, matching production (loader-resolution.ts).
|
|
269
|
+
let renderedResolved = false;
|
|
270
|
+
|
|
271
|
+
return runWithRequestContext(reqCtx, () => {
|
|
272
|
+
const reverse = opts.routeMap
|
|
273
|
+
? createReverseFunction(opts.routeMap, opts.routeName, opts.params ?? {})
|
|
274
|
+
: ((() => {
|
|
275
|
+
// Documented contract: reverse requires routeMap. Do NOT fall back to
|
|
276
|
+
// reqCtx.reverse (the global route map) — that leaks whichever routes
|
|
277
|
+
// another test registered and contradicts the documented behavior.
|
|
278
|
+
throw new Error(
|
|
279
|
+
"ctx.reverse() requires the `routeMap` option in runLoader(). " +
|
|
280
|
+
"Pass { routeMap: { name: pattern, ... } } to enable reverse().",
|
|
281
|
+
);
|
|
282
|
+
}) as TestLoaderContext["reverse"]);
|
|
283
|
+
|
|
284
|
+
const loaderCtx: TestLoaderContext = {
|
|
285
|
+
params: opts.params ?? {},
|
|
286
|
+
routeParams: (opts.params ?? {}) as Record<string, string>,
|
|
287
|
+
request: reqCtx.request,
|
|
288
|
+
searchParams: ctx.searchParams,
|
|
289
|
+
search: opts.searchData ?? {},
|
|
290
|
+
pathname: reqCtx.pathname,
|
|
291
|
+
url: reqCtx.url,
|
|
292
|
+
originalUrl: reqCtx.originalUrl,
|
|
293
|
+
env: reqCtx.env,
|
|
294
|
+
waitUntil: reqCtx.waitUntil.bind(reqCtx),
|
|
295
|
+
executionContext: reqCtx.executionContext,
|
|
296
|
+
get: reqCtx.get as TestLoaderContext["get"],
|
|
297
|
+
use: ((dep: LoaderDefinition<any, any> | Handle<any, any>) => {
|
|
298
|
+
// Match production (loader-resolution.ts): reading a handle in a loader
|
|
299
|
+
// requires the render barrier to have settled. Gate BEFORE returning a
|
|
300
|
+
// seed, so a loader that forgets `await ctx.rendered()` fails in the
|
|
301
|
+
// test exactly as it would at runtime.
|
|
302
|
+
if (isHandle(dep) && !renderedResolved) {
|
|
303
|
+
throw new Error(
|
|
304
|
+
`ctx.use(handle) in a loader requires "await ctx.rendered()" first. ` +
|
|
305
|
+
`Handle "${(dep as Handle<any, any>).$$id}" cannot be read until ` +
|
|
306
|
+
`the render tree has settled.`,
|
|
307
|
+
);
|
|
308
|
+
}
|
|
309
|
+
// Handle reads (ctx.use(SomeHandle)) resolve from the seeded map first.
|
|
310
|
+
if (handleSeeds.has(dep)) return handleSeeds.get(dep);
|
|
311
|
+
if (opts.use) return opts.use(dep as LoaderDefinition<any, any>);
|
|
312
|
+
return reqCtx.use(dep as LoaderDefinition<any, any>);
|
|
313
|
+
}) as LoaderContext<any, any>["use"],
|
|
314
|
+
method: opts.method ?? "GET",
|
|
315
|
+
body: opts.body,
|
|
316
|
+
formData: opts.formData,
|
|
317
|
+
reverse: reverse as TestLoaderContext["reverse"],
|
|
318
|
+
rendered:
|
|
319
|
+
opts.rendered !== undefined && opts.rendered !== false
|
|
320
|
+
? async () => {
|
|
321
|
+
if (typeof opts.rendered === "function") {
|
|
322
|
+
await opts.rendered();
|
|
323
|
+
}
|
|
324
|
+
// Barrier has settled: subsequent ctx.use(handle) reads resolve.
|
|
325
|
+
renderedResolved = true;
|
|
326
|
+
}
|
|
327
|
+
: () => {
|
|
328
|
+
throw new Error(
|
|
329
|
+
"ctx.rendered() is not available in runLoader() by default. It " +
|
|
330
|
+
"requires the DSL render barrier, which only exists during a " +
|
|
331
|
+
"full route match. To unit-test a loader's post-barrier logic, " +
|
|
332
|
+
"pass { rendered: true } to mock the barrier and { handles: " +
|
|
333
|
+
"[[SomeHandle, accumulatedData]] } to seed ctx.use(SomeHandle). " +
|
|
334
|
+
"For the real push/accumulate/barrier wiring, use an e2e test.",
|
|
335
|
+
);
|
|
336
|
+
},
|
|
337
|
+
};
|
|
338
|
+
|
|
339
|
+
return Promise.resolve(loaderFn(loaderCtx));
|
|
340
|
+
});
|
|
341
|
+
}
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* runMiddleware — unit-test one or more middleware functions in isolation.
|
|
3
|
+
*
|
|
4
|
+
* Executes the middleware chain via the SAME executeLoaderMiddleware the router
|
|
5
|
+
* uses, so ordering, `next()`, short-circuit (return OR throw Response),
|
|
6
|
+
* double-next guards, and header/cookie merging behave identically to
|
|
7
|
+
* production. The chain runs inside runWithRequestContext, so cookie/header
|
|
8
|
+
* mutations and getRequestContext() resolve.
|
|
9
|
+
*
|
|
10
|
+
* The returned `ctx` is the underlying RequestContext (not the per-middleware
|
|
11
|
+
* MiddlewareContext), exposing `ctx.cookies()`, `ctx.get()`, and
|
|
12
|
+
* `ctx.res.headers` for assertions on what the chain produced.
|
|
13
|
+
*
|
|
14
|
+
* `nextCalled` counts how many times the terminal `next()` (the finalHandler)
|
|
15
|
+
* ran: 0 when the chain short-circuited, 1 when it ran to completion.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
import {
|
|
19
|
+
runWithRequestContext,
|
|
20
|
+
type RequestContext,
|
|
21
|
+
} from "../server/request-context.js";
|
|
22
|
+
import { executeLoaderMiddleware } from "../router/middleware.js";
|
|
23
|
+
import { createReverseFunction } from "../router/handler-context.js";
|
|
24
|
+
import type { MiddlewareFn } from "../router/middleware-types.js";
|
|
25
|
+
import {
|
|
26
|
+
createTestRequestContext,
|
|
27
|
+
snapshotRunEffects,
|
|
28
|
+
type CreateTestContextOptions,
|
|
29
|
+
type VarsInit,
|
|
30
|
+
} from "./internal/context.js";
|
|
31
|
+
import type { ThemeConfig } from "../theme/types.js";
|
|
32
|
+
import type { SegmentCacheStore } from "../cache/types.js";
|
|
33
|
+
import type { CacheProfile } from "../cache/profile-registry.js";
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Options for runMiddleware.
|
|
37
|
+
*/
|
|
38
|
+
export interface RunMiddlewareOptions<TEnv = any> {
|
|
39
|
+
/** Environment bindings surfaced as `ctx.env`. */
|
|
40
|
+
env?: TEnv;
|
|
41
|
+
/** Route params surfaced as `ctx.params`. */
|
|
42
|
+
params?: Record<string, string>;
|
|
43
|
+
/** Variables a prior middleware would have set (object or [key, value] list). */
|
|
44
|
+
vars?: VarsInit;
|
|
45
|
+
/** Route name -> pattern map enabling `ctx.reverse()`. */
|
|
46
|
+
routeMap?: Record<string, string>;
|
|
47
|
+
/** Matched route name for scoped `.name` reverse resolution. */
|
|
48
|
+
routeName?: string;
|
|
49
|
+
/** Router basename surfaced on the context (drives redirect() prefixing). */
|
|
50
|
+
basename?: string;
|
|
51
|
+
/** Theme config in the `createRouter({ theme })` shape (enables ctx.theme). */
|
|
52
|
+
theme?: ThemeConfig | true;
|
|
53
|
+
/**
|
|
54
|
+
* Terminal handler invoked when the chain calls `next()` all the way through.
|
|
55
|
+
* Defaults to a 200 empty Response. Use this to model the downstream
|
|
56
|
+
* route/handler response.
|
|
57
|
+
*/
|
|
58
|
+
next?: () => Promise<Response>;
|
|
59
|
+
/**
|
|
60
|
+
* Cache store backing any `use cache` function a middleware invokes. Without
|
|
61
|
+
* it, registerCachedFunction bypasses (it checks for a store first), so the
|
|
62
|
+
* cached function runs uncached and its taint/profile guards never fire.
|
|
63
|
+
*/
|
|
64
|
+
cacheStore?: SegmentCacheStore;
|
|
65
|
+
/** Cache profiles (the `createRouter({ cacheProfiles })` shape). */
|
|
66
|
+
cacheProfiles?: Record<string, CacheProfile>;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Result of runMiddleware.
|
|
71
|
+
*/
|
|
72
|
+
export interface RunMiddlewareResult<TEnv = any> {
|
|
73
|
+
/** The final Response (downstream response, or a middleware short-circuit). */
|
|
74
|
+
response: Response;
|
|
75
|
+
/**
|
|
76
|
+
* The underlying RequestContext. Read `ctx.cookies()`, `ctx.get(...)`, and
|
|
77
|
+
* `ctx.res.headers` to assert on the chain's effects. (This is always the
|
|
78
|
+
* RequestContext the chain ran under — not a per-middleware MiddlewareContext —
|
|
79
|
+
* so `ctx.cookies()` and the other RequestContext accessors are available.)
|
|
80
|
+
*/
|
|
81
|
+
ctx: RequestContext<TEnv>;
|
|
82
|
+
/** Number of times the terminal handler ran (0 = short-circuited, 1 = passed through). */
|
|
83
|
+
nextCalled: number;
|
|
84
|
+
/**
|
|
85
|
+
* The effective cookie view after the chain ran: request cookies merged with
|
|
86
|
+
* anything the chain set or deleted (last-write-wins), as `{ name: value }`.
|
|
87
|
+
* The public way to assert a cookie a middleware set, without casting through
|
|
88
|
+
* the `@internal` `ctx.cookies()`. Set-Cookie headers are also on `response`.
|
|
89
|
+
*/
|
|
90
|
+
cookies: Record<string, string>;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* Run a middleware chain and return the response plus observable context.
|
|
95
|
+
*
|
|
96
|
+
* @example
|
|
97
|
+
* ```ts
|
|
98
|
+
* const { response, ctx, nextCalled } = await runMiddleware(
|
|
99
|
+
* async (ctx, next) => {
|
|
100
|
+
* if (!ctx.get("user")) return new Response(null, { status: 401 });
|
|
101
|
+
* return next();
|
|
102
|
+
* },
|
|
103
|
+
* "/dashboard",
|
|
104
|
+
* { vars: [["user", { id: 1 }]] },
|
|
105
|
+
* );
|
|
106
|
+
* // nextCalled === 1, response.status === 200
|
|
107
|
+
* ```
|
|
108
|
+
*/
|
|
109
|
+
export async function runMiddleware<TEnv = any>(
|
|
110
|
+
mw: MiddlewareFn<TEnv> | MiddlewareFn<TEnv>[],
|
|
111
|
+
request: Request | string,
|
|
112
|
+
opts: RunMiddlewareOptions<TEnv> = {},
|
|
113
|
+
): Promise<RunMiddlewareResult<TEnv>> {
|
|
114
|
+
const mwArray = Array.isArray(mw) ? mw : [mw];
|
|
115
|
+
|
|
116
|
+
const ctxOpts: CreateTestContextOptions<TEnv> = {
|
|
117
|
+
env: opts.env,
|
|
118
|
+
request,
|
|
119
|
+
vars: opts.vars,
|
|
120
|
+
routeMap: opts.routeMap,
|
|
121
|
+
routeName: opts.routeName,
|
|
122
|
+
params: opts.params,
|
|
123
|
+
basename: opts.basename,
|
|
124
|
+
theme: opts.theme,
|
|
125
|
+
cacheStore: opts.cacheStore,
|
|
126
|
+
cacheProfiles: opts.cacheProfiles,
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
const {
|
|
130
|
+
ctx,
|
|
131
|
+
request: builtRequest,
|
|
132
|
+
variables,
|
|
133
|
+
} = createTestRequestContext<TEnv>(ctxOpts);
|
|
134
|
+
|
|
135
|
+
let nextCalled = 0;
|
|
136
|
+
const finalHandler = async (): Promise<Response> => {
|
|
137
|
+
nextCalled++;
|
|
138
|
+
return opts.next?.() ?? new Response(null, { status: 200 });
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
// Match production: app/response middleware receive ctx.reverse built from the
|
|
142
|
+
// route map ALONE (no matched route name or current params), so reversing a
|
|
143
|
+
// parameterized route without explicit params does NOT auto-fill from the
|
|
144
|
+
// current request. Passing routeName/params here would recreate the
|
|
145
|
+
// false-confidence class fixed in dispatch.
|
|
146
|
+
const reverse = opts.routeMap
|
|
147
|
+
? (createReverseFunction(opts.routeMap) as (
|
|
148
|
+
name: string,
|
|
149
|
+
params?: Record<string, string>,
|
|
150
|
+
search?: Record<string, unknown>,
|
|
151
|
+
) => string)
|
|
152
|
+
: undefined;
|
|
153
|
+
|
|
154
|
+
// Keep the RETURNED ctx.reverse consistent with the map-only reverse the
|
|
155
|
+
// chain receives. createTestRequestContext installs an auto-fill reverse
|
|
156
|
+
// (correct for the loader phase) when routeName/params are passed, but
|
|
157
|
+
// production app/response middleware see a map-only reverse. Without this,
|
|
158
|
+
// a middleware reading getRequestContext().reverse — or a consumer asserting
|
|
159
|
+
// on result.ctx.reverse — would observe auto-fill that production never does.
|
|
160
|
+
if (reverse) {
|
|
161
|
+
(ctx as RequestContext<TEnv>).reverse =
|
|
162
|
+
reverse as RequestContext<TEnv>["reverse"];
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
const response = await runWithRequestContext(ctx, () =>
|
|
166
|
+
executeLoaderMiddleware<TEnv>(
|
|
167
|
+
mwArray,
|
|
168
|
+
builtRequest,
|
|
169
|
+
(opts.env ?? {}) as TEnv,
|
|
170
|
+
opts.params ?? {},
|
|
171
|
+
variables,
|
|
172
|
+
finalHandler,
|
|
173
|
+
reverse,
|
|
174
|
+
),
|
|
175
|
+
);
|
|
176
|
+
|
|
177
|
+
const { cookies } = snapshotRunEffects(ctx);
|
|
178
|
+
return { response, ctx, nextCalled, cookies };
|
|
179
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// Stub for the `cloudflare:email` runtime virtual, shipped for Cloudflare
|
|
2
|
+
// consumers (enable via `rangoTestAliases({ cloudflare: true })`).
|
|
3
|
+
export class EmailMessage {
|
|
4
|
+
constructor(
|
|
5
|
+
public from: string,
|
|
6
|
+
public to: string,
|
|
7
|
+
public raw: unknown,
|
|
8
|
+
) {}
|
|
9
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Stub for the `cloudflare:workers` runtime virtual, shipped for Cloudflare
|
|
2
|
+
// consumers (enable via `rangoTestAliases({ cloudflare: true })`). A CF app's
|
|
3
|
+
// route tree commonly imports `cloudflare:workers` (e.g. `import { env } from
|
|
4
|
+
// "cloudflare:workers"`), which does not resolve in a bare Vitest process.
|
|
5
|
+
export const env: Record<string, unknown> = {};
|
|
6
|
+
|
|
7
|
+
export class DurableObject<Env = unknown> {
|
|
8
|
+
constructor(
|
|
9
|
+
public ctx: unknown,
|
|
10
|
+
public env: Env,
|
|
11
|
+
) {}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export class WorkerEntrypoint<Env = unknown> {
|
|
15
|
+
constructor(
|
|
16
|
+
public ctx: unknown,
|
|
17
|
+
public env: Env,
|
|
18
|
+
) {}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export class RpcTarget {}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// Stub for `@vitejs/plugin-rsc/rsc`, shipped so consumers do not have to write a
|
|
2
|
+
// per-file `vi.mock(...)`. Importing a router internal transitively pulls this
|
|
3
|
+
// module, whose real top-level body imports Vite virtuals that do not resolve in
|
|
4
|
+
// plain node. The unit/integration primitives (dispatch/runLoader/runMiddleware)
|
|
5
|
+
// never render RSC, so empty fns suffice.
|
|
6
|
+
export const createFromReadableStream = (): never => {
|
|
7
|
+
throw new Error("plugin-rsc stub: createFromReadableStream not available");
|
|
8
|
+
};
|
|
9
|
+
export const renderToReadableStream = (): never => {
|
|
10
|
+
throw new Error("plugin-rsc stub: renderToReadableStream not available");
|
|
11
|
+
};
|
|
12
|
+
export const loadServerAction = (): undefined => undefined;
|
|
13
|
+
export const decodeReply = (): undefined => undefined;
|
|
14
|
+
export const decodeAction = (): undefined => undefined;
|
|
15
|
+
export const decodeFormState = (): undefined => undefined;
|
|
16
|
+
export const createTemporaryReferenceSet = (): Record<string, never> => ({});
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
// Stub for the build-only `@rangojs/router:version` virtual module, shipped so
|
|
2
|
+
// consumers do not have to author it. The rango Vite plugin injects this at
|
|
3
|
+
// build time; in a bare Vitest process it must be aliased to a stub. Empty
|
|
4
|
+
// string keeps generated URLs free of a version path segment.
|
|
5
|
+
export const VERSION = "";
|