vinext 0.0.50 → 0.0.51
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/build/google-fonts/fallback-metrics-data.js +14031 -0
- package/dist/build/google-fonts/fallback-metrics-data.js.map +1 -0
- package/dist/build/google-fonts/fallback-metrics.d.ts +13 -0
- package/dist/build/google-fonts/fallback-metrics.js +46 -0
- package/dist/build/google-fonts/fallback-metrics.js.map +1 -0
- package/dist/build/precompress.d.ts +13 -2
- package/dist/build/precompress.js +12 -3
- package/dist/build/precompress.js.map +1 -1
- package/dist/build/prerender.d.ts +1 -1
- package/dist/build/prerender.js +44 -14
- package/dist/build/prerender.js.map +1 -1
- package/dist/build/report.d.ts +5 -4
- package/dist/build/report.js +196 -348
- package/dist/build/report.js.map +1 -1
- package/dist/check.js +1 -0
- package/dist/check.js.map +1 -1
- package/dist/cli.js +60 -3
- package/dist/cli.js.map +1 -1
- package/dist/client/window-next.d.ts +3 -1
- package/dist/client/window-next.js.map +1 -1
- package/dist/config/dotenv.d.ts +11 -1
- package/dist/config/dotenv.js.map +1 -1
- package/dist/config/next-config.d.ts +87 -3
- package/dist/config/next-config.js +222 -6
- package/dist/config/next-config.js.map +1 -1
- package/dist/config/tsconfig-paths.d.ts +13 -0
- package/dist/config/tsconfig-paths.js +117 -0
- package/dist/config/tsconfig-paths.js.map +1 -0
- package/dist/deploy.js +3 -2
- package/dist/deploy.js.map +1 -1
- package/dist/entries/app-browser-entry.d.ts +2 -2
- package/dist/entries/app-browser-entry.js +26 -1
- package/dist/entries/app-browser-entry.js.map +1 -1
- package/dist/entries/app-rsc-entry.d.ts +19 -1
- package/dist/entries/app-rsc-entry.js +38 -12
- package/dist/entries/app-rsc-entry.js.map +1 -1
- package/dist/entries/app-rsc-manifest.d.ts +9 -0
- package/dist/entries/app-rsc-manifest.js +4 -1
- package/dist/entries/app-rsc-manifest.js.map +1 -1
- package/dist/entries/pages-client-entry.js +3 -5
- package/dist/entries/pages-client-entry.js.map +1 -1
- package/dist/entries/pages-server-entry.js +19 -1
- package/dist/entries/pages-server-entry.js.map +1 -1
- package/dist/index.js +130 -37
- package/dist/index.js.map +1 -1
- package/dist/plugins/client-reference-dedup.d.ts +15 -2
- package/dist/plugins/client-reference-dedup.js +138 -16
- package/dist/plugins/client-reference-dedup.js.map +1 -1
- package/dist/plugins/fonts.d.ts +2 -2
- package/dist/plugins/fonts.js +15 -6
- package/dist/plugins/fonts.js.map +1 -1
- package/dist/plugins/sass.d.ts +34 -0
- package/dist/plugins/sass.js +22 -0
- package/dist/plugins/sass.js.map +1 -0
- package/dist/routing/app-route-graph.d.ts +31 -2
- package/dist/routing/app-route-graph.js +82 -10
- package/dist/routing/app-route-graph.js.map +1 -1
- package/dist/routing/route-pattern.d.ts +56 -1
- package/dist/routing/route-pattern.js +60 -1
- package/dist/routing/route-pattern.js.map +1 -1
- package/dist/server/app-browser-action-result.d.ts +27 -2
- package/dist/server/app-browser-action-result.js +63 -2
- package/dist/server/app-browser-action-result.js.map +1 -1
- package/dist/server/app-browser-entry.js +262 -108
- package/dist/server/app-browser-entry.js.map +1 -1
- package/dist/server/app-browser-hydration.d.ts +13 -1
- package/dist/server/app-browser-hydration.js +9 -1
- package/dist/server/app-browser-hydration.js.map +1 -1
- package/dist/server/app-browser-navigation-controller.d.ts +14 -1
- package/dist/server/app-browser-navigation-controller.js +28 -9
- package/dist/server/app-browser-navigation-controller.js.map +1 -1
- package/dist/server/app-browser-popstate.d.ts +16 -0
- package/dist/server/app-browser-popstate.js +17 -0
- package/dist/server/app-browser-popstate.js.map +1 -0
- package/dist/server/app-browser-rsc-redirect.d.ts +28 -0
- package/dist/server/app-browser-rsc-redirect.js +37 -0
- package/dist/server/app-browser-rsc-redirect.js.map +1 -0
- package/dist/server/app-browser-state.d.ts +11 -7
- package/dist/server/app-browser-state.js +45 -27
- package/dist/server/app-browser-state.js.map +1 -1
- package/dist/server/app-browser-stream.d.ts +5 -4
- package/dist/server/app-browser-stream.js +5 -6
- package/dist/server/app-browser-stream.js.map +1 -1
- package/dist/server/app-browser-visible-commit.d.ts +5 -0
- package/dist/server/app-browser-visible-commit.js +38 -5
- package/dist/server/app-browser-visible-commit.js.map +1 -1
- package/dist/server/app-elements-wire.d.ts +38 -6
- package/dist/server/app-elements-wire.js +106 -6
- package/dist/server/app-elements-wire.js.map +1 -1
- package/dist/server/app-elements.d.ts +2 -2
- package/dist/server/app-elements.js +2 -2
- package/dist/server/app-elements.js.map +1 -1
- package/dist/server/app-fallback-renderer.d.ts +10 -1
- package/dist/server/app-fallback-renderer.js +37 -1
- package/dist/server/app-fallback-renderer.js.map +1 -1
- package/dist/server/app-history-state.d.ts +26 -0
- package/dist/server/app-history-state.js +53 -0
- package/dist/server/app-history-state.js.map +1 -0
- package/dist/server/app-page-boundary-render.d.ts +10 -1
- package/dist/server/app-page-boundary-render.js +13 -6
- package/dist/server/app-page-boundary-render.js.map +1 -1
- package/dist/server/app-page-boundary.js +3 -2
- package/dist/server/app-page-boundary.js.map +1 -1
- package/dist/server/app-page-cache.d.ts +13 -0
- package/dist/server/app-page-cache.js +25 -8
- package/dist/server/app-page-cache.js.map +1 -1
- package/dist/server/app-page-dispatch.d.ts +5 -0
- package/dist/server/app-page-dispatch.js +68 -11
- package/dist/server/app-page-dispatch.js.map +1 -1
- package/dist/server/app-page-element-builder.d.ts +7 -0
- package/dist/server/app-page-element-builder.js +32 -4
- package/dist/server/app-page-element-builder.js.map +1 -1
- package/dist/server/app-page-execution.js +2 -3
- package/dist/server/app-page-execution.js.map +1 -1
- package/dist/server/app-page-head.d.ts +7 -0
- package/dist/server/app-page-head.js +2 -1
- package/dist/server/app-page-head.js.map +1 -1
- package/dist/server/app-page-probe.d.ts +23 -1
- package/dist/server/app-page-probe.js +29 -1
- package/dist/server/app-page-probe.js.map +1 -1
- package/dist/server/app-page-render-observation.d.ts +35 -0
- package/dist/server/app-page-render-observation.js +68 -0
- package/dist/server/app-page-render-observation.js.map +1 -0
- package/dist/server/app-page-render.d.ts +5 -1
- package/dist/server/app-page-render.js +79 -3
- package/dist/server/app-page-render.js.map +1 -1
- package/dist/server/app-page-request.d.ts +1 -0
- package/dist/server/app-page-request.js.map +1 -1
- package/dist/server/app-page-response.js +3 -2
- package/dist/server/app-page-response.js.map +1 -1
- package/dist/server/app-page-route-wiring.d.ts +3 -1
- package/dist/server/app-page-route-wiring.js +42 -14
- package/dist/server/app-page-route-wiring.js.map +1 -1
- package/dist/server/app-page-stream.d.ts +2 -0
- package/dist/server/app-page-stream.js +1 -0
- package/dist/server/app-page-stream.js.map +1 -1
- package/dist/server/app-router-entry.js +1 -13
- package/dist/server/app-router-entry.js.map +1 -1
- package/dist/server/app-rsc-cache-busting.d.ts +19 -1
- package/dist/server/app-rsc-cache-busting.js +36 -1
- package/dist/server/app-rsc-cache-busting.js.map +1 -1
- package/dist/server/app-rsc-embedded-chunks.d.ts +9 -0
- package/dist/server/app-rsc-embedded-chunks.js +34 -0
- package/dist/server/app-rsc-embedded-chunks.js.map +1 -0
- package/dist/server/app-rsc-errors.d.ts +4 -1
- package/dist/server/app-rsc-errors.js +1 -1
- package/dist/server/app-rsc-errors.js.map +1 -1
- package/dist/server/app-rsc-handler.d.ts +12 -4
- package/dist/server/app-rsc-handler.js +6 -1
- package/dist/server/app-rsc-handler.js.map +1 -1
- package/dist/server/app-rsc-route-matching.d.ts +23 -0
- package/dist/server/app-rsc-route-matching.js +45 -23
- package/dist/server/app-rsc-route-matching.js.map +1 -1
- package/dist/server/app-server-action-execution.d.ts +35 -3
- package/dist/server/app-server-action-execution.js +87 -33
- package/dist/server/app-server-action-execution.js.map +1 -1
- package/dist/server/app-ssr-entry.d.ts +1 -0
- package/dist/server/app-ssr-entry.js +37 -13
- package/dist/server/app-ssr-entry.js.map +1 -1
- package/dist/server/app-ssr-error-meta.d.ts +14 -0
- package/dist/server/app-ssr-error-meta.js +50 -0
- package/dist/server/app-ssr-error-meta.js.map +1 -0
- package/dist/server/app-ssr-stream.d.ts +1 -1
- package/dist/server/app-ssr-stream.js +9 -12
- package/dist/server/app-ssr-stream.js.map +1 -1
- package/dist/server/artifact-compatibility.d.ts +12 -2
- package/dist/server/artifact-compatibility.js +12 -8
- package/dist/server/artifact-compatibility.js.map +1 -1
- package/dist/server/cache-proof.d.ts +124 -5
- package/dist/server/cache-proof.js +416 -18
- package/dist/server/cache-proof.js.map +1 -1
- package/dist/server/dev-lockfile.d.ts +110 -0
- package/dist/server/dev-lockfile.js +180 -0
- package/dist/server/dev-lockfile.js.map +1 -0
- package/dist/server/dev-server.js +15 -5
- package/dist/server/dev-server.js.map +1 -1
- package/dist/server/file-based-metadata.d.ts +13 -0
- package/dist/server/file-based-metadata.js +49 -2
- package/dist/server/file-based-metadata.js.map +1 -1
- package/dist/server/headers.d.ts +3 -1
- package/dist/server/headers.js +5 -2
- package/dist/server/headers.js.map +1 -1
- package/dist/server/html.js +1 -1
- package/dist/server/html.js.map +1 -1
- package/dist/server/http-error-responses.d.ts +10 -0
- package/dist/server/http-error-responses.js +11 -1
- package/dist/server/http-error-responses.js.map +1 -1
- package/dist/server/isr-cache.d.ts +2 -1
- package/dist/server/isr-cache.js +4 -2
- package/dist/server/isr-cache.js.map +1 -1
- package/dist/server/metadata-route-response.js +22 -5
- package/dist/server/metadata-route-response.js.map +1 -1
- package/dist/server/metadata-routes.js +27 -8
- package/dist/server/metadata-routes.js.map +1 -1
- package/dist/server/middleware-runtime.js +1 -0
- package/dist/server/middleware-runtime.js.map +1 -1
- package/dist/server/middleware.d.ts +12 -0
- package/dist/server/middleware.js +12 -0
- package/dist/server/middleware.js.map +1 -1
- package/dist/server/navigation-planner.d.ts +19 -5
- package/dist/server/navigation-planner.js +278 -17
- package/dist/server/navigation-planner.js.map +1 -1
- package/dist/server/navigation-trace.d.ts +8 -1
- package/dist/server/navigation-trace.js +7 -0
- package/dist/server/navigation-trace.js.map +1 -1
- package/dist/server/normalize-path.d.ts +2 -1
- package/dist/server/normalize-path.js +4 -1
- package/dist/server/normalize-path.js.map +1 -1
- package/dist/server/pages-api-route.js +1 -0
- package/dist/server/pages-api-route.js.map +1 -1
- package/dist/server/pages-page-data.d.ts +3 -2
- package/dist/server/pages-page-data.js +22 -3
- package/dist/server/pages-page-data.js.map +1 -1
- package/dist/server/pages-page-response.js +1 -1
- package/dist/server/prod-server.d.ts +28 -1
- package/dist/server/prod-server.js +62 -9
- package/dist/server/prod-server.js.map +1 -1
- package/dist/server/server-action-not-found.d.ts +16 -3
- package/dist/server/server-action-not-found.js +19 -1
- package/dist/server/server-action-not-found.js.map +1 -1
- package/dist/server/server-globals.d.ts +5 -0
- package/dist/server/server-globals.js +37 -0
- package/dist/server/server-globals.js.map +1 -0
- package/dist/server/static-file-cache.js +1 -1
- package/dist/server/static-file-cache.js.map +1 -1
- package/dist/shims/cache-runtime.d.ts +19 -2
- package/dist/shims/cache-runtime.js +67 -11
- package/dist/shims/cache-runtime.js.map +1 -1
- package/dist/shims/cache.d.ts +5 -18
- package/dist/shims/cache.js +2 -0
- package/dist/shims/cache.js.map +1 -1
- package/dist/shims/error-boundary.js +6 -8
- package/dist/shims/error-boundary.js.map +1 -1
- package/dist/shims/error.d.ts +18 -1
- package/dist/shims/error.js +56 -1
- package/dist/shims/error.js.map +1 -1
- package/dist/shims/fetch-cache.d.ts +4 -1
- package/dist/shims/fetch-cache.js +40 -5
- package/dist/shims/fetch-cache.js.map +1 -1
- package/dist/shims/font-google-base.d.ts +22 -8
- package/dist/shims/font-google-base.js +41 -71
- package/dist/shims/font-google-base.js.map +1 -1
- package/dist/shims/font-local.d.ts +3 -20
- package/dist/shims/font-local.js +23 -75
- package/dist/shims/font-local.js.map +1 -1
- package/dist/shims/font-utils.d.ts +51 -0
- package/dist/shims/font-utils.js +97 -0
- package/dist/shims/font-utils.js.map +1 -0
- package/dist/shims/hash-scroll.d.ts +7 -0
- package/dist/shims/hash-scroll.js +30 -0
- package/dist/shims/hash-scroll.js.map +1 -0
- package/dist/shims/headers.d.ts +8 -11
- package/dist/shims/headers.js +22 -2
- package/dist/shims/headers.js.map +1 -1
- package/dist/shims/image.d.ts +1 -0
- package/dist/shims/image.js +144 -78
- package/dist/shims/image.js.map +1 -1
- package/dist/shims/internal/app-router-context.d.ts +6 -6
- package/dist/shims/internal/app-router-context.js +17 -6
- package/dist/shims/internal/app-router-context.js.map +1 -1
- package/dist/shims/link-prefetch.d.ts +9 -1
- package/dist/shims/link-prefetch.js +11 -6
- package/dist/shims/link-prefetch.js.map +1 -1
- package/dist/shims/link.d.ts +12 -2
- package/dist/shims/link.js +78 -32
- package/dist/shims/link.js.map +1 -1
- package/dist/shims/metadata.d.ts +16 -30
- package/dist/shims/metadata.js +87 -28
- package/dist/shims/metadata.js.map +1 -1
- package/dist/shims/navigation.d.ts +158 -17
- package/dist/shims/navigation.js +324 -74
- package/dist/shims/navigation.js.map +1 -1
- package/dist/shims/navigation.react-server.d.ts +3 -2
- package/dist/shims/navigation.react-server.js +5 -2
- package/dist/shims/navigation.react-server.js.map +1 -1
- package/dist/shims/pages-router-runtime.d.ts +7 -0
- package/dist/shims/pages-router-runtime.js +16 -0
- package/dist/shims/pages-router-runtime.js.map +1 -0
- package/dist/shims/router.d.ts +32 -6
- package/dist/shims/router.js +197 -242
- package/dist/shims/router.js.map +1 -1
- package/dist/shims/script.js +110 -32
- package/dist/shims/script.js.map +1 -1
- package/dist/shims/server.js +2 -1
- package/dist/shims/server.js.map +1 -1
- package/dist/shims/slot.d.ts +1 -0
- package/dist/shims/slot.js +41 -1
- package/dist/shims/slot.js.map +1 -1
- package/dist/shims/unified-request-context.js +2 -0
- package/dist/shims/unified-request-context.js.map +1 -1
- package/dist/shims/unrecognized-action-error.d.ts +35 -0
- package/dist/shims/unrecognized-action-error.js +41 -0
- package/dist/shims/unrecognized-action-error.js.map +1 -0
- package/dist/shims/url-utils.d.ts +21 -1
- package/dist/shims/url-utils.js +67 -3
- package/dist/shims/url-utils.js.map +1 -1
- package/dist/utils/asset-prefix.d.ts +69 -0
- package/dist/utils/asset-prefix.js +91 -0
- package/dist/utils/asset-prefix.js.map +1 -0
- package/dist/utils/base-path.d.ts +7 -1
- package/dist/utils/base-path.js +10 -1
- package/dist/utils/base-path.js.map +1 -1
- package/dist/utils/navigation-signal.d.ts +1 -2
- package/dist/utils/navigation-signal.js +1 -1
- package/dist/utils/navigation-signal.js.map +1 -1
- package/dist/utils/sorted-array.d.ts +9 -0
- package/dist/utils/sorted-array.js +22 -0
- package/dist/utils/sorted-array.js.map +1 -0
- package/package.json +3 -3
|
@@ -87,7 +87,66 @@ function matchRoutePattern(urlParts, patternParts) {
|
|
|
87
87
|
decodeMatchedParams(params);
|
|
88
88
|
return params;
|
|
89
89
|
}
|
|
90
|
+
function matchRoutePatternPrefix(pathParts, patternParts) {
|
|
91
|
+
let pathIndex = 0;
|
|
92
|
+
for (let patternIndex = 0; patternIndex < patternParts.length; patternIndex++) {
|
|
93
|
+
const patternPart = patternParts[patternIndex];
|
|
94
|
+
const isTerminal = patternIndex === patternParts.length - 1;
|
|
95
|
+
if (patternPart.startsWith(":") && patternPart.endsWith("+")) return isTerminal && pathParts.length - pathIndex >= 1;
|
|
96
|
+
if (patternPart.startsWith(":") && patternPart.endsWith("*")) return isTerminal;
|
|
97
|
+
if (pathIndex >= pathParts.length) return false;
|
|
98
|
+
if (patternPart.startsWith(":")) {
|
|
99
|
+
pathIndex++;
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
if (pathParts[pathIndex] !== patternPart) return false;
|
|
103
|
+
pathIndex++;
|
|
104
|
+
}
|
|
105
|
+
return true;
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Strip query string and a single trailing slash from a pathname.
|
|
109
|
+
*
|
|
110
|
+
* Mirrors the Next.js `removeTrailingSlash` helper used in
|
|
111
|
+
* `.nextjs-ref/packages/next/src/build/static-paths/pages.ts`. Kept here so
|
|
112
|
+
* both the build-time prerender and the request-time matchers normalize the
|
|
113
|
+
* same way.
|
|
114
|
+
*/
|
|
115
|
+
function normalizeStaticPathname(pathname) {
|
|
116
|
+
const noQuery = pathname.split("?")[0];
|
|
117
|
+
return noQuery === "/" ? "/" : noQuery.replace(/\/$/, "");
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Normalize a single `getStaticPaths` entry into a `{ params }` object.
|
|
121
|
+
*
|
|
122
|
+
* Handles both Next.js-supported shapes:
|
|
123
|
+
* - For a string entry, match it against `routePattern` to extract params,
|
|
124
|
+
* mirroring `_routeMatcher(cleanedEntry)` in
|
|
125
|
+
* `.nextjs-ref/packages/next/src/build/static-paths/pages.ts`. If the
|
|
126
|
+
* string does not match the pattern, Next.js throws; we return an
|
|
127
|
+
* `{ error }` result so the caller can record a per-route error instead
|
|
128
|
+
* of crashing the build.
|
|
129
|
+
* - For an object entry, require a `params` key (Next.js raises
|
|
130
|
+
* "A required parameter (X) was not provided..." otherwise).
|
|
131
|
+
*
|
|
132
|
+
* Note: this intentionally does NOT strip a locale prefix. The build pipeline
|
|
133
|
+
* currently passes empty `locales` to `getStaticPaths`, so locale-prefixed
|
|
134
|
+
* string entries are not produced. If/when i18n is wired through prerender,
|
|
135
|
+
* locale handling should be added here, not duplicated at call sites.
|
|
136
|
+
*/
|
|
137
|
+
function normalizeStaticPathsEntry(entry, routePattern) {
|
|
138
|
+
if (entry === null || entry === void 0) return { error: `getStaticPaths returned a ${entry === null ? "null" : "undefined"} entry` };
|
|
139
|
+
if (typeof entry === "string") {
|
|
140
|
+
const matched = matchRoutePattern(normalizeStaticPathname(entry).split("/").filter(Boolean), routePattern.split("/").filter(Boolean));
|
|
141
|
+
if (!matched) return { error: `The provided path \`${entry}\` from getStaticPaths does not match the route pattern \`${routePattern}\`.` };
|
|
142
|
+
return { params: matched };
|
|
143
|
+
}
|
|
144
|
+
if (typeof entry !== "object") return { error: `getStaticPaths entry must be a string or an object, got ${typeof entry}` };
|
|
145
|
+
const { params } = entry;
|
|
146
|
+
if (params === void 0 || params === null) return { error: `getStaticPaths entry is missing the \`params\` key for pattern \`${routePattern}\`. Return either a string path or { params: { ... } }.` };
|
|
147
|
+
return { params };
|
|
148
|
+
}
|
|
90
149
|
//#endregion
|
|
91
|
-
export { fillRoutePatternSegments, matchRoutePattern, routePattern, routePatternParts };
|
|
150
|
+
export { fillRoutePatternSegments, matchRoutePattern, matchRoutePatternPrefix, normalizeStaticPathname, normalizeStaticPathsEntry, routePattern, routePatternParts };
|
|
92
151
|
|
|
93
152
|
//# sourceMappingURL=route-pattern.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"route-pattern.js","names":[],"sources":["../../src/routing/route-pattern.ts"],"sourcesContent":["import { decodeMatchedParams } from \"./utils\";\n\nexport type RoutePatternParams = Record<string, string | string[]>;\n\nfunction routePatternPart(segment: string): string {\n if (segment.startsWith(\"[[...\") && segment.endsWith(\"]]\")) {\n return `:${segment.slice(5, -2)}*`;\n }\n if (segment.startsWith(\"[...\") && segment.endsWith(\"]\")) {\n return `:${segment.slice(4, -1)}+`;\n }\n if (segment.startsWith(\"[\") && segment.endsWith(\"]\")) {\n return `:${segment.slice(1, -1)}`;\n }\n return segment;\n}\n\nexport function routePatternParts(pathname: string): string[] {\n return pathname.split(\"/\").filter(Boolean).map(routePatternPart);\n}\n\nexport function routePattern(pathname: string): string {\n const parts = routePatternParts(pathname);\n return parts.length > 0 ? `/${parts.join(\"/\")}` : \"\";\n}\n\nfunction appendParamValue(target: string[], value: string | string[]): void {\n if (Array.isArray(value)) {\n for (const entry of value) {\n target.push(entry);\n }\n return;\n }\n\n target.push(value);\n}\n\nexport function fillRoutePatternSegments(\n pathname: string,\n params: RoutePatternParams,\n): string | null {\n const segments = pathname.split(\"/\").filter(Boolean);\n const resolvedSegments: string[] = [];\n\n for (const segment of segments) {\n if (segment.startsWith(\"[[...\") && segment.endsWith(\"]]\")) {\n const paramName = segment.slice(5, -2);\n const value = params[paramName];\n if (value !== undefined && value !== \"\") {\n if (Array.isArray(value) && value.length === 0) {\n continue;\n }\n appendParamValue(resolvedSegments, value);\n }\n continue;\n }\n\n if (segment.startsWith(\"[...\") && segment.endsWith(\"]\")) {\n const paramName = segment.slice(4, -1);\n const value = params[paramName];\n if (value === undefined || (Array.isArray(value) ? value.length === 0 : value === \"\")) {\n return null;\n }\n appendParamValue(resolvedSegments, value);\n continue;\n }\n\n if (segment.startsWith(\"[\") && segment.endsWith(\"]\")) {\n const paramName = segment.slice(1, -1);\n const value = params[paramName];\n if (typeof value === \"string\") {\n resolvedSegments.push(value);\n continue;\n }\n if (Array.isArray(value) && value.length > 0) {\n if (value.length > 1) {\n return null;\n }\n resolvedSegments.push(value[0]);\n continue;\n }\n return null;\n }\n\n resolvedSegments.push(segment);\n }\n\n return resolvedSegments.length > 0 ? `/${resolvedSegments.join(\"/\")}` : \"/\";\n}\n\nexport function matchRoutePattern(\n urlParts: readonly string[],\n patternParts: readonly string[],\n): RoutePatternParams | null {\n const params: RoutePatternParams = Object.create(null);\n\n function matchFrom(urlIndex: number, patternIndex: number): boolean {\n if (patternIndex === patternParts.length) {\n return urlIndex === urlParts.length;\n }\n\n const patternPart = patternParts[patternIndex];\n if (patternPart.startsWith(\":\") && (patternPart.endsWith(\"+\") || patternPart.endsWith(\"*\"))) {\n const paramName = patternPart.slice(1, -1);\n const minLength = patternPart.endsWith(\"+\") ? 1 : 0;\n for (let endIndex = urlIndex + minLength; endIndex <= urlParts.length; endIndex++) {\n const value = urlParts.slice(urlIndex, endIndex);\n if (value.length > 0) {\n params[paramName] = value;\n } else {\n delete params[paramName];\n }\n if (matchFrom(endIndex, patternIndex + 1)) {\n return true;\n }\n }\n delete params[paramName];\n return false;\n }\n\n if (patternPart.startsWith(\":\")) {\n if (urlIndex >= urlParts.length) {\n return false;\n }\n const paramName = patternPart.slice(1);\n params[paramName] = urlParts[urlIndex];\n if (matchFrom(urlIndex + 1, patternIndex + 1)) {\n return true;\n }\n delete params[paramName];\n return false;\n }\n\n if (urlIndex >= urlParts.length || urlParts[urlIndex] !== patternPart) {\n return false;\n }\n return matchFrom(urlIndex + 1, patternIndex + 1);\n }\n\n if (!matchFrom(0, 0)) return null;\n decodeMatchedParams(params);\n return params;\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"route-pattern.js","names":[],"sources":["../../src/routing/route-pattern.ts"],"sourcesContent":["import { decodeMatchedParams } from \"./utils\";\n\nexport type RoutePatternParams = Record<string, string | string[]>;\n\nfunction routePatternPart(segment: string): string {\n if (segment.startsWith(\"[[...\") && segment.endsWith(\"]]\")) {\n return `:${segment.slice(5, -2)}*`;\n }\n if (segment.startsWith(\"[...\") && segment.endsWith(\"]\")) {\n return `:${segment.slice(4, -1)}+`;\n }\n if (segment.startsWith(\"[\") && segment.endsWith(\"]\")) {\n return `:${segment.slice(1, -1)}`;\n }\n return segment;\n}\n\nexport function routePatternParts(pathname: string): string[] {\n return pathname.split(\"/\").filter(Boolean).map(routePatternPart);\n}\n\nexport function routePattern(pathname: string): string {\n const parts = routePatternParts(pathname);\n return parts.length > 0 ? `/${parts.join(\"/\")}` : \"\";\n}\n\nfunction appendParamValue(target: string[], value: string | string[]): void {\n if (Array.isArray(value)) {\n for (const entry of value) {\n target.push(entry);\n }\n return;\n }\n\n target.push(value);\n}\n\nexport function fillRoutePatternSegments(\n pathname: string,\n params: RoutePatternParams,\n): string | null {\n const segments = pathname.split(\"/\").filter(Boolean);\n const resolvedSegments: string[] = [];\n\n for (const segment of segments) {\n if (segment.startsWith(\"[[...\") && segment.endsWith(\"]]\")) {\n const paramName = segment.slice(5, -2);\n const value = params[paramName];\n if (value !== undefined && value !== \"\") {\n if (Array.isArray(value) && value.length === 0) {\n continue;\n }\n appendParamValue(resolvedSegments, value);\n }\n continue;\n }\n\n if (segment.startsWith(\"[...\") && segment.endsWith(\"]\")) {\n const paramName = segment.slice(4, -1);\n const value = params[paramName];\n if (value === undefined || (Array.isArray(value) ? value.length === 0 : value === \"\")) {\n return null;\n }\n appendParamValue(resolvedSegments, value);\n continue;\n }\n\n if (segment.startsWith(\"[\") && segment.endsWith(\"]\")) {\n const paramName = segment.slice(1, -1);\n const value = params[paramName];\n if (typeof value === \"string\") {\n resolvedSegments.push(value);\n continue;\n }\n if (Array.isArray(value) && value.length > 0) {\n if (value.length > 1) {\n return null;\n }\n resolvedSegments.push(value[0]);\n continue;\n }\n return null;\n }\n\n resolvedSegments.push(segment);\n }\n\n return resolvedSegments.length > 0 ? `/${resolvedSegments.join(\"/\")}` : \"/\";\n}\n\nexport function matchRoutePattern(\n urlParts: readonly string[],\n patternParts: readonly string[],\n): RoutePatternParams | null {\n const params: RoutePatternParams = Object.create(null);\n\n function matchFrom(urlIndex: number, patternIndex: number): boolean {\n if (patternIndex === patternParts.length) {\n return urlIndex === urlParts.length;\n }\n\n const patternPart = patternParts[patternIndex];\n if (patternPart.startsWith(\":\") && (patternPart.endsWith(\"+\") || patternPart.endsWith(\"*\"))) {\n const paramName = patternPart.slice(1, -1);\n const minLength = patternPart.endsWith(\"+\") ? 1 : 0;\n for (let endIndex = urlIndex + minLength; endIndex <= urlParts.length; endIndex++) {\n const value = urlParts.slice(urlIndex, endIndex);\n if (value.length > 0) {\n params[paramName] = value;\n } else {\n delete params[paramName];\n }\n if (matchFrom(endIndex, patternIndex + 1)) {\n return true;\n }\n }\n delete params[paramName];\n return false;\n }\n\n if (patternPart.startsWith(\":\")) {\n if (urlIndex >= urlParts.length) {\n return false;\n }\n const paramName = patternPart.slice(1);\n params[paramName] = urlParts[urlIndex];\n if (matchFrom(urlIndex + 1, patternIndex + 1)) {\n return true;\n }\n delete params[paramName];\n return false;\n }\n\n if (urlIndex >= urlParts.length || urlParts[urlIndex] !== patternPart) {\n return false;\n }\n return matchFrom(urlIndex + 1, patternIndex + 1);\n }\n\n if (!matchFrom(0, 0)) return null;\n decodeMatchedParams(params);\n return params;\n}\n\nexport function matchRoutePatternPrefix(\n pathParts: readonly string[],\n patternParts: readonly string[],\n): boolean {\n let pathIndex = 0;\n for (let patternIndex = 0; patternIndex < patternParts.length; patternIndex++) {\n const patternPart = patternParts[patternIndex];\n const isTerminal = patternIndex === patternParts.length - 1;\n\n if (patternPart.startsWith(\":\") && patternPart.endsWith(\"+\")) {\n return isTerminal && pathParts.length - pathIndex >= 1;\n }\n if (patternPart.startsWith(\":\") && patternPart.endsWith(\"*\")) {\n return isTerminal;\n }\n if (pathIndex >= pathParts.length) return false;\n if (patternPart.startsWith(\":\")) {\n pathIndex++;\n continue;\n }\n if (pathParts[pathIndex] !== patternPart) return false;\n pathIndex++;\n }\n\n return true;\n}\n\n/**\n * A single entry from `getStaticPaths().paths`.\n *\n * Next.js allows both shapes:\n * - a raw string path, e.g. `\"/blog/hello\"`\n * - an object `{ params, locale? }`\n *\n * See:\n * https://nextjs.org/docs/pages/api-reference/functions/get-static-paths\n * .nextjs-ref/packages/next/src/build/static-paths/pages.ts (the\n * `typeof entry === 'string'` branch around line 89, and the object\n * branch around line 132)\n */\nexport type StaticPathsEntry =\n | string\n | { params?: RoutePatternParams; locale?: string }\n | null\n | undefined;\n\n/**\n * Result of {@link normalizeStaticPathsEntry}: either a params object, or a\n * descriptive error string the caller can surface as a per-route error result.\n */\ntype NormalizedStaticPathsEntry = { params: RoutePatternParams } | { error: string };\n\n/**\n * Strip query string and a single trailing slash from a pathname.\n *\n * Mirrors the Next.js `removeTrailingSlash` helper used in\n * `.nextjs-ref/packages/next/src/build/static-paths/pages.ts`. Kept here so\n * both the build-time prerender and the request-time matchers normalize the\n * same way.\n */\nexport function normalizeStaticPathname(pathname: string): string {\n const noQuery = pathname.split(\"?\")[0];\n return noQuery === \"/\" ? \"/\" : noQuery.replace(/\\/$/, \"\");\n}\n\n/**\n * Normalize a single `getStaticPaths` entry into a `{ params }` object.\n *\n * Handles both Next.js-supported shapes:\n * - For a string entry, match it against `routePattern` to extract params,\n * mirroring `_routeMatcher(cleanedEntry)` in\n * `.nextjs-ref/packages/next/src/build/static-paths/pages.ts`. If the\n * string does not match the pattern, Next.js throws; we return an\n * `{ error }` result so the caller can record a per-route error instead\n * of crashing the build.\n * - For an object entry, require a `params` key (Next.js raises\n * \"A required parameter (X) was not provided...\" otherwise).\n *\n * Note: this intentionally does NOT strip a locale prefix. The build pipeline\n * currently passes empty `locales` to `getStaticPaths`, so locale-prefixed\n * string entries are not produced. If/when i18n is wired through prerender,\n * locale handling should be added here, not duplicated at call sites.\n */\nexport function normalizeStaticPathsEntry(\n entry: StaticPathsEntry,\n routePattern: string,\n): NormalizedStaticPathsEntry {\n if (entry === null || entry === undefined) {\n return {\n error: `getStaticPaths returned a ${entry === null ? \"null\" : \"undefined\"} entry`,\n };\n }\n\n if (typeof entry === \"string\") {\n const trimmed = normalizeStaticPathname(entry);\n const urlParts = trimmed.split(\"/\").filter(Boolean);\n const patternParts = routePattern.split(\"/\").filter(Boolean);\n const matched = matchRoutePattern(urlParts, patternParts);\n if (!matched) {\n return {\n error: `The provided path \\`${entry}\\` from getStaticPaths does not match the route pattern \\`${routePattern}\\`.`,\n };\n }\n return { params: matched };\n }\n\n if (typeof entry !== \"object\") {\n return {\n error: `getStaticPaths entry must be a string or an object, got ${typeof entry}`,\n };\n }\n\n const { params } = entry;\n if (params === undefined || params === null) {\n return {\n error:\n `getStaticPaths entry is missing the \\`params\\` key for pattern \\`${routePattern}\\`. ` +\n `Return either a string path or { params: { ... } }.`,\n };\n }\n\n return { params };\n}\n"],"mappings":";;AAIA,SAAS,iBAAiB,SAAyB;CACjD,IAAI,QAAQ,WAAW,QAAQ,IAAI,QAAQ,SAAS,KAAK,EACvD,OAAO,IAAI,QAAQ,MAAM,GAAG,GAAG,CAAC;CAElC,IAAI,QAAQ,WAAW,OAAO,IAAI,QAAQ,SAAS,IAAI,EACrD,OAAO,IAAI,QAAQ,MAAM,GAAG,GAAG,CAAC;CAElC,IAAI,QAAQ,WAAW,IAAI,IAAI,QAAQ,SAAS,IAAI,EAClD,OAAO,IAAI,QAAQ,MAAM,GAAG,GAAG;CAEjC,OAAO;;AAGT,SAAgB,kBAAkB,UAA4B;CAC5D,OAAO,SAAS,MAAM,IAAI,CAAC,OAAO,QAAQ,CAAC,IAAI,iBAAiB;;AAGlE,SAAgB,aAAa,UAA0B;CACrD,MAAM,QAAQ,kBAAkB,SAAS;CACzC,OAAO,MAAM,SAAS,IAAI,IAAI,MAAM,KAAK,IAAI,KAAK;;AAGpD,SAAS,iBAAiB,QAAkB,OAAgC;CAC1E,IAAI,MAAM,QAAQ,MAAM,EAAE;EACxB,KAAK,MAAM,SAAS,OAClB,OAAO,KAAK,MAAM;EAEpB;;CAGF,OAAO,KAAK,MAAM;;AAGpB,SAAgB,yBACd,UACA,QACe;CACf,MAAM,WAAW,SAAS,MAAM,IAAI,CAAC,OAAO,QAAQ;CACpD,MAAM,mBAA6B,EAAE;CAErC,KAAK,MAAM,WAAW,UAAU;EAC9B,IAAI,QAAQ,WAAW,QAAQ,IAAI,QAAQ,SAAS,KAAK,EAAE;GAEzD,MAAM,QAAQ,OADI,QAAQ,MAAM,GAAG,GACL;GAC9B,IAAI,UAAU,KAAA,KAAa,UAAU,IAAI;IACvC,IAAI,MAAM,QAAQ,MAAM,IAAI,MAAM,WAAW,GAC3C;IAEF,iBAAiB,kBAAkB,MAAM;;GAE3C;;EAGF,IAAI,QAAQ,WAAW,OAAO,IAAI,QAAQ,SAAS,IAAI,EAAE;GAEvD,MAAM,QAAQ,OADI,QAAQ,MAAM,GAAG,GACL;GAC9B,IAAI,UAAU,KAAA,MAAc,MAAM,QAAQ,MAAM,GAAG,MAAM,WAAW,IAAI,UAAU,KAChF,OAAO;GAET,iBAAiB,kBAAkB,MAAM;GACzC;;EAGF,IAAI,QAAQ,WAAW,IAAI,IAAI,QAAQ,SAAS,IAAI,EAAE;GAEpD,MAAM,QAAQ,OADI,QAAQ,MAAM,GAAG,GACL;GAC9B,IAAI,OAAO,UAAU,UAAU;IAC7B,iBAAiB,KAAK,MAAM;IAC5B;;GAEF,IAAI,MAAM,QAAQ,MAAM,IAAI,MAAM,SAAS,GAAG;IAC5C,IAAI,MAAM,SAAS,GACjB,OAAO;IAET,iBAAiB,KAAK,MAAM,GAAG;IAC/B;;GAEF,OAAO;;EAGT,iBAAiB,KAAK,QAAQ;;CAGhC,OAAO,iBAAiB,SAAS,IAAI,IAAI,iBAAiB,KAAK,IAAI,KAAK;;AAG1E,SAAgB,kBACd,UACA,cAC2B;CAC3B,MAAM,SAA6B,OAAO,OAAO,KAAK;CAEtD,SAAS,UAAU,UAAkB,cAA+B;EAClE,IAAI,iBAAiB,aAAa,QAChC,OAAO,aAAa,SAAS;EAG/B,MAAM,cAAc,aAAa;EACjC,IAAI,YAAY,WAAW,IAAI,KAAK,YAAY,SAAS,IAAI,IAAI,YAAY,SAAS,IAAI,GAAG;GAC3F,MAAM,YAAY,YAAY,MAAM,GAAG,GAAG;GAC1C,MAAM,YAAY,YAAY,SAAS,IAAI,GAAG,IAAI;GAClD,KAAK,IAAI,WAAW,WAAW,WAAW,YAAY,SAAS,QAAQ,YAAY;IACjF,MAAM,QAAQ,SAAS,MAAM,UAAU,SAAS;IAChD,IAAI,MAAM,SAAS,GACjB,OAAO,aAAa;SAEpB,OAAO,OAAO;IAEhB,IAAI,UAAU,UAAU,eAAe,EAAE,EACvC,OAAO;;GAGX,OAAO,OAAO;GACd,OAAO;;EAGT,IAAI,YAAY,WAAW,IAAI,EAAE;GAC/B,IAAI,YAAY,SAAS,QACvB,OAAO;GAET,MAAM,YAAY,YAAY,MAAM,EAAE;GACtC,OAAO,aAAa,SAAS;GAC7B,IAAI,UAAU,WAAW,GAAG,eAAe,EAAE,EAC3C,OAAO;GAET,OAAO,OAAO;GACd,OAAO;;EAGT,IAAI,YAAY,SAAS,UAAU,SAAS,cAAc,aACxD,OAAO;EAET,OAAO,UAAU,WAAW,GAAG,eAAe,EAAE;;CAGlD,IAAI,CAAC,UAAU,GAAG,EAAE,EAAE,OAAO;CAC7B,oBAAoB,OAAO;CAC3B,OAAO;;AAGT,SAAgB,wBACd,WACA,cACS;CACT,IAAI,YAAY;CAChB,KAAK,IAAI,eAAe,GAAG,eAAe,aAAa,QAAQ,gBAAgB;EAC7E,MAAM,cAAc,aAAa;EACjC,MAAM,aAAa,iBAAiB,aAAa,SAAS;EAE1D,IAAI,YAAY,WAAW,IAAI,IAAI,YAAY,SAAS,IAAI,EAC1D,OAAO,cAAc,UAAU,SAAS,aAAa;EAEvD,IAAI,YAAY,WAAW,IAAI,IAAI,YAAY,SAAS,IAAI,EAC1D,OAAO;EAET,IAAI,aAAa,UAAU,QAAQ,OAAO;EAC1C,IAAI,YAAY,WAAW,IAAI,EAAE;GAC/B;GACA;;EAEF,IAAI,UAAU,eAAe,aAAa,OAAO;EACjD;;CAGF,OAAO;;;;;;;;;;AAoCT,SAAgB,wBAAwB,UAA0B;CAChE,MAAM,UAAU,SAAS,MAAM,IAAI,CAAC;CACpC,OAAO,YAAY,MAAM,MAAM,QAAQ,QAAQ,OAAO,GAAG;;;;;;;;;;;;;;;;;;;;AAqB3D,SAAgB,0BACd,OACA,cAC4B;CAC5B,IAAI,UAAU,QAAQ,UAAU,KAAA,GAC9B,OAAO,EACL,OAAO,6BAA6B,UAAU,OAAO,SAAS,YAAY,SAC3E;CAGH,IAAI,OAAO,UAAU,UAAU;EAI7B,MAAM,UAAU,kBAHA,wBAAwB,MAChB,CAAC,MAAM,IAAI,CAAC,OAAO,QAED,EADrB,aAAa,MAAM,IAAI,CAAC,OAAO,QACI,CAAC;EACzD,IAAI,CAAC,SACH,OAAO,EACL,OAAO,uBAAuB,MAAM,4DAA4D,aAAa,MAC9G;EAEH,OAAO,EAAE,QAAQ,SAAS;;CAG5B,IAAI,OAAO,UAAU,UACnB,OAAO,EACL,OAAO,2DAA2D,OAAO,SAC1E;CAGH,MAAM,EAAE,WAAW;CACnB,IAAI,WAAW,KAAA,KAAa,WAAW,MACrC,OAAO,EACL,OACE,oEAAoE,aAAa,0DAEpF;CAGH,OAAO,EAAE,QAAQ"}
|
|
@@ -6,6 +6,13 @@ type AppBrowserServerActionResult<TRoot> = {
|
|
|
6
6
|
data: unknown;
|
|
7
7
|
};
|
|
8
8
|
};
|
|
9
|
+
type ServerActionRevalidationKind = "dynamicOnly" | "none" | "staticAndDynamic";
|
|
10
|
+
type ServerActionInitiationSnapshot<TRouterState> = {
|
|
11
|
+
href: string;
|
|
12
|
+
navigationId: number;
|
|
13
|
+
path: string;
|
|
14
|
+
routerState: TRouterState;
|
|
15
|
+
};
|
|
9
16
|
/**
|
|
10
17
|
* Structural discriminator: matches on `"returnValue"` or `"root"` keys.
|
|
11
18
|
* This is safe because {@link AppWireElements} keys are prefixed (`route:`,
|
|
@@ -13,7 +20,25 @@ type AppBrowserServerActionResult<TRoot> = {
|
|
|
13
20
|
* If the wire format ever adds a `"root"` key, this guard must be updated.
|
|
14
21
|
*/
|
|
15
22
|
declare function isServerActionResult<TRoot>(value: unknown): value is AppBrowserServerActionResult<TRoot>;
|
|
16
|
-
declare function shouldClearClientNavigationCachesForServerActionResult<TRoot>(result: AppBrowserServerActionResult<TRoot> | TRoot): boolean;
|
|
23
|
+
declare function shouldClearClientNavigationCachesForServerActionResult<TRoot>(result: AppBrowserServerActionResult<TRoot> | TRoot, revalidation?: ServerActionRevalidationKind): boolean;
|
|
24
|
+
declare function parseServerActionRevalidationHeader(headers: Pick<Headers, "get">): ServerActionRevalidationKind;
|
|
25
|
+
declare function shouldScheduleRefreshForDiscardedServerAction(revalidation: ServerActionRevalidationKind): boolean;
|
|
26
|
+
declare function createServerActionInitiationSnapshot<TRouterState>(options: {
|
|
27
|
+
href: string;
|
|
28
|
+
navigationId: number;
|
|
29
|
+
origin?: string;
|
|
30
|
+
routerState: TRouterState;
|
|
31
|
+
}): ServerActionInitiationSnapshot<TRouterState>;
|
|
32
|
+
type DiscardedServerActionRefreshScheduler = {
|
|
33
|
+
markNavigationSettled(): void;
|
|
34
|
+
markNavigationStart(): void;
|
|
35
|
+
schedule(): void;
|
|
36
|
+
};
|
|
37
|
+
type DiscardedServerActionRefreshSchedulerOptions = {
|
|
38
|
+
queueTask?: (callback: () => void) => void;
|
|
39
|
+
runRefresh: () => void;
|
|
40
|
+
};
|
|
41
|
+
declare function createDiscardedServerActionRefreshScheduler(options: DiscardedServerActionRefreshSchedulerOptions): DiscardedServerActionRefreshScheduler;
|
|
17
42
|
//#endregion
|
|
18
|
-
export { AppBrowserServerActionResult, isServerActionResult, shouldClearClientNavigationCachesForServerActionResult };
|
|
43
|
+
export { AppBrowserServerActionResult, ServerActionRevalidationKind, createDiscardedServerActionRefreshScheduler, createServerActionInitiationSnapshot, isServerActionResult, parseServerActionRevalidationHeader, shouldClearClientNavigationCachesForServerActionResult, shouldScheduleRefreshForDiscardedServerAction };
|
|
19
44
|
//# sourceMappingURL=app-browser-action-result.d.ts.map
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import { ACTION_REVALIDATED_HEADER } from "./headers.js";
|
|
1
2
|
//#region src/server/app-browser-action-result.ts
|
|
3
|
+
const ACTION_DID_REVALIDATE_STATIC_AND_DYNAMIC = 1;
|
|
4
|
+
const ACTION_DID_REVALIDATE_DYNAMIC_ONLY = 2;
|
|
2
5
|
/**
|
|
3
6
|
* Structural discriminator: matches on `"returnValue"` or `"root"` keys.
|
|
4
7
|
* This is safe because {@link AppWireElements} keys are prefixed (`route:`,
|
|
@@ -8,11 +11,69 @@
|
|
|
8
11
|
function isServerActionResult(value) {
|
|
9
12
|
return !!value && typeof value === "object" && ("returnValue" in value || "root" in value);
|
|
10
13
|
}
|
|
11
|
-
function shouldClearClientNavigationCachesForServerActionResult(result) {
|
|
14
|
+
function shouldClearClientNavigationCachesForServerActionResult(result, revalidation = "none") {
|
|
15
|
+
if (revalidation !== "none") return true;
|
|
12
16
|
if (!isServerActionResult(result)) return true;
|
|
13
17
|
return result.root !== void 0;
|
|
14
18
|
}
|
|
19
|
+
function parseServerActionRevalidationHeader(headers) {
|
|
20
|
+
const value = headers.get(ACTION_REVALIDATED_HEADER);
|
|
21
|
+
if (!value) return "none";
|
|
22
|
+
let parsed;
|
|
23
|
+
try {
|
|
24
|
+
parsed = JSON.parse(value);
|
|
25
|
+
} catch {
|
|
26
|
+
return "none";
|
|
27
|
+
}
|
|
28
|
+
switch (parsed) {
|
|
29
|
+
case ACTION_DID_REVALIDATE_STATIC_AND_DYNAMIC: return "staticAndDynamic";
|
|
30
|
+
case ACTION_DID_REVALIDATE_DYNAMIC_ONLY: return "dynamicOnly";
|
|
31
|
+
default: return "none";
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function shouldScheduleRefreshForDiscardedServerAction(revalidation) {
|
|
35
|
+
return revalidation !== "none";
|
|
36
|
+
}
|
|
37
|
+
function createServerActionInitiationSnapshot(options) {
|
|
38
|
+
const url = options.origin === void 0 ? new URL(options.href) : new URL(options.href, options.origin);
|
|
39
|
+
return {
|
|
40
|
+
href: url.href,
|
|
41
|
+
navigationId: options.navigationId,
|
|
42
|
+
path: url.pathname + url.search,
|
|
43
|
+
routerState: options.routerState
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
function createDiscardedServerActionRefreshScheduler(options) {
|
|
47
|
+
const queueTask = options.queueTask ?? queueMicrotask;
|
|
48
|
+
let activeNavigationCount = 0;
|
|
49
|
+
let flushQueued = false;
|
|
50
|
+
let refreshPending = false;
|
|
51
|
+
function flush() {
|
|
52
|
+
flushQueued = false;
|
|
53
|
+
if (!refreshPending || activeNavigationCount > 0) return;
|
|
54
|
+
refreshPending = false;
|
|
55
|
+
options.runRefresh();
|
|
56
|
+
}
|
|
57
|
+
function queueFlush() {
|
|
58
|
+
if (flushQueued) return;
|
|
59
|
+
flushQueued = true;
|
|
60
|
+
queueTask(flush);
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
markNavigationSettled() {
|
|
64
|
+
if (activeNavigationCount > 0) activeNavigationCount -= 1;
|
|
65
|
+
queueFlush();
|
|
66
|
+
},
|
|
67
|
+
markNavigationStart() {
|
|
68
|
+
activeNavigationCount += 1;
|
|
69
|
+
},
|
|
70
|
+
schedule() {
|
|
71
|
+
refreshPending = true;
|
|
72
|
+
queueFlush();
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}
|
|
15
76
|
//#endregion
|
|
16
|
-
export { isServerActionResult, shouldClearClientNavigationCachesForServerActionResult };
|
|
77
|
+
export { createDiscardedServerActionRefreshScheduler, createServerActionInitiationSnapshot, isServerActionResult, parseServerActionRevalidationHeader, shouldClearClientNavigationCachesForServerActionResult, shouldScheduleRefreshForDiscardedServerAction };
|
|
17
78
|
|
|
18
79
|
//# sourceMappingURL=app-browser-action-result.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app-browser-action-result.js","names":[],"sources":["../../src/server/app-browser-action-result.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"file":"app-browser-action-result.js","names":[],"sources":["../../src/server/app-browser-action-result.ts"],"sourcesContent":["import { ACTION_REVALIDATED_HEADER } from \"./headers.js\";\n\nexport type AppBrowserServerActionResult<TRoot> = {\n root?: TRoot;\n returnValue?: {\n ok: boolean;\n data: unknown;\n };\n};\n\nexport type ServerActionRevalidationKind = \"dynamicOnly\" | \"none\" | \"staticAndDynamic\";\n\nconst ACTION_DID_REVALIDATE_STATIC_AND_DYNAMIC = 1;\nconst ACTION_DID_REVALIDATE_DYNAMIC_ONLY = 2;\n\ntype ServerActionInitiationSnapshot<TRouterState> = {\n href: string;\n navigationId: number;\n path: string;\n routerState: TRouterState;\n};\n\n/**\n * Structural discriminator: matches on `\"returnValue\"` or `\"root\"` keys.\n * This is safe because {@link AppWireElements} keys are prefixed (`route:`,\n * `slot:`, `__route`, etc.) and will never collide with these property names.\n * If the wire format ever adds a `\"root\"` key, this guard must be updated.\n */\nexport function isServerActionResult<TRoot>(\n value: unknown,\n): value is AppBrowserServerActionResult<TRoot> {\n return !!value && typeof value === \"object\" && (\"returnValue\" in value || \"root\" in value);\n}\n\nexport function shouldClearClientNavigationCachesForServerActionResult<TRoot>(\n result: AppBrowserServerActionResult<TRoot> | TRoot,\n revalidation: ServerActionRevalidationKind = \"none\",\n): boolean {\n if (revalidation !== \"none\") {\n return true;\n }\n\n if (!isServerActionResult<TRoot>(result)) {\n return true;\n }\n\n return result.root !== undefined;\n}\n\nexport function parseServerActionRevalidationHeader(\n headers: Pick<Headers, \"get\">,\n): ServerActionRevalidationKind {\n const value = headers.get(ACTION_REVALIDATED_HEADER);\n if (!value) return \"none\";\n\n let parsed: unknown;\n try {\n parsed = JSON.parse(value);\n } catch {\n return \"none\";\n }\n\n switch (parsed) {\n case ACTION_DID_REVALIDATE_STATIC_AND_DYNAMIC:\n return \"staticAndDynamic\";\n case ACTION_DID_REVALIDATE_DYNAMIC_ONLY:\n return \"dynamicOnly\";\n default:\n return \"none\";\n }\n}\n\nexport function shouldScheduleRefreshForDiscardedServerAction(\n revalidation: ServerActionRevalidationKind,\n): boolean {\n return revalidation !== \"none\";\n}\n\nexport function createServerActionInitiationSnapshot<TRouterState>(options: {\n href: string;\n navigationId: number;\n origin?: string;\n routerState: TRouterState;\n}): ServerActionInitiationSnapshot<TRouterState> {\n const url =\n options.origin === undefined ? new URL(options.href) : new URL(options.href, options.origin);\n return {\n href: url.href,\n navigationId: options.navigationId,\n path: url.pathname + url.search,\n routerState: options.routerState,\n };\n}\n\ntype DiscardedServerActionRefreshScheduler = {\n markNavigationSettled(): void;\n markNavigationStart(): void;\n schedule(): void;\n};\n\ntype DiscardedServerActionRefreshSchedulerOptions = {\n queueTask?: (callback: () => void) => void;\n runRefresh: () => void;\n};\n\nexport function createDiscardedServerActionRefreshScheduler(\n options: DiscardedServerActionRefreshSchedulerOptions,\n): DiscardedServerActionRefreshScheduler {\n const queueTask = options.queueTask ?? queueMicrotask;\n let activeNavigationCount = 0;\n let flushQueued = false;\n let refreshPending = false;\n\n function flush(): void {\n flushQueued = false;\n if (!refreshPending || activeNavigationCount > 0) return;\n\n refreshPending = false;\n options.runRefresh();\n }\n\n function queueFlush(): void {\n if (flushQueued) return;\n flushQueued = true;\n queueTask(flush);\n }\n\n return {\n markNavigationSettled() {\n if (activeNavigationCount > 0) {\n activeNavigationCount -= 1;\n }\n queueFlush();\n },\n markNavigationStart() {\n activeNavigationCount += 1;\n },\n schedule() {\n refreshPending = true;\n queueFlush();\n },\n };\n}\n"],"mappings":";;AAYA,MAAM,2CAA2C;AACjD,MAAM,qCAAqC;;;;;;;AAe3C,SAAgB,qBACd,OAC8C;CAC9C,OAAO,CAAC,CAAC,SAAS,OAAO,UAAU,aAAa,iBAAiB,SAAS,UAAU;;AAGtF,SAAgB,uDACd,QACA,eAA6C,QACpC;CACT,IAAI,iBAAiB,QACnB,OAAO;CAGT,IAAI,CAAC,qBAA4B,OAAO,EACtC,OAAO;CAGT,OAAO,OAAO,SAAS,KAAA;;AAGzB,SAAgB,oCACd,SAC8B;CAC9B,MAAM,QAAQ,QAAQ,IAAI,0BAA0B;CACpD,IAAI,CAAC,OAAO,OAAO;CAEnB,IAAI;CACJ,IAAI;EACF,SAAS,KAAK,MAAM,MAAM;SACpB;EACN,OAAO;;CAGT,QAAQ,QAAR;EACE,KAAK,0CACH,OAAO;EACT,KAAK,oCACH,OAAO;EACT,SACE,OAAO;;;AAIb,SAAgB,8CACd,cACS;CACT,OAAO,iBAAiB;;AAG1B,SAAgB,qCAAmD,SAKlB;CAC/C,MAAM,MACJ,QAAQ,WAAW,KAAA,IAAY,IAAI,IAAI,QAAQ,KAAK,GAAG,IAAI,IAAI,QAAQ,MAAM,QAAQ,OAAO;CAC9F,OAAO;EACL,MAAM,IAAI;EACV,cAAc,QAAQ;EACtB,MAAM,IAAI,WAAW,IAAI;EACzB,aAAa,QAAQ;EACtB;;AAcH,SAAgB,4CACd,SACuC;CACvC,MAAM,YAAY,QAAQ,aAAa;CACvC,IAAI,wBAAwB;CAC5B,IAAI,cAAc;CAClB,IAAI,iBAAiB;CAErB,SAAS,QAAc;EACrB,cAAc;EACd,IAAI,CAAC,kBAAkB,wBAAwB,GAAG;EAElD,iBAAiB;EACjB,QAAQ,YAAY;;CAGtB,SAAS,aAAmB;EAC1B,IAAI,aAAa;EACjB,cAAc;EACd,UAAU,MAAM;;CAGlB,OAAO;EACL,wBAAwB;GACtB,IAAI,wBAAwB,GAC1B,yBAAyB;GAE3B,YAAY;;EAEd,sBAAsB;GACpB,yBAAyB;;EAE3B,WAAW;GACT,iBAAiB;GACjB,YAAY;;EAEf"}
|