@tanstack/router-core 1.163.3 → 1.166.4
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/cjs/load-matches.cjs +187 -96
- package/dist/cjs/load-matches.cjs.map +1 -1
- package/dist/cjs/load-matches.d.cts +1 -0
- package/dist/cjs/router.cjs +2 -0
- package/dist/cjs/router.cjs.map +1 -1
- package/dist/cjs/ssr/ssr-client.cjs +15 -17
- package/dist/cjs/ssr/ssr-client.cjs.map +1 -1
- package/dist/cjs/ssr/ssr-server.cjs +3 -0
- package/dist/cjs/ssr/ssr-server.cjs.map +1 -1
- package/dist/cjs/ssr/types.d.cts +1 -0
- package/dist/esm/load-matches.d.ts +1 -0
- package/dist/esm/load-matches.js +187 -96
- package/dist/esm/load-matches.js.map +1 -1
- package/dist/esm/router.js +2 -0
- package/dist/esm/router.js.map +1 -1
- package/dist/esm/ssr/ssr-client.js +15 -17
- package/dist/esm/ssr/ssr-client.js.map +1 -1
- package/dist/esm/ssr/ssr-server.js +3 -0
- package/dist/esm/ssr/ssr-server.js.map +1 -1
- package/dist/esm/ssr/types.d.ts +1 -0
- package/package.json +1 -1
- package/src/load-matches.ts +285 -133
- package/src/router.ts +2 -0
- package/src/ssr/ssr-client.ts +20 -17
- package/src/ssr/ssr-server.ts +3 -0
- package/src/ssr/types.ts +1 -0
package/src/ssr/ssr-client.ts
CHANGED
|
@@ -28,6 +28,14 @@ function hydrateMatch(
|
|
|
28
28
|
match.ssr = deyhydratedMatch.ssr
|
|
29
29
|
match.updatedAt = deyhydratedMatch.u
|
|
30
30
|
match.error = deyhydratedMatch.e
|
|
31
|
+
// Only hydrate global-not-found when a defined value is present in the
|
|
32
|
+
// dehydrated payload. If omitted, preserve the value computed from the
|
|
33
|
+
// current client location (important for SPA fallback HTML served at unknown
|
|
34
|
+
// URLs, where dehydrated matches may come from `/` but client matching marks
|
|
35
|
+
// root as globalNotFound).
|
|
36
|
+
if (deyhydratedMatch.g !== undefined) {
|
|
37
|
+
match.globalNotFound = deyhydratedMatch.g
|
|
38
|
+
}
|
|
31
39
|
}
|
|
32
40
|
|
|
33
41
|
export async function hydrate(router: AnyRouter): Promise<any> {
|
|
@@ -82,10 +90,9 @@ export async function hydrate(router: AnyRouter): Promise<any> {
|
|
|
82
90
|
|
|
83
91
|
// kick off loading the route chunks
|
|
84
92
|
const routeChunkPromise = Promise.all(
|
|
85
|
-
matches.map((match) =>
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}),
|
|
93
|
+
matches.map((match) =>
|
|
94
|
+
router.loadRouteChunk(router.looseRoutesById[match.routeId]!),
|
|
95
|
+
),
|
|
89
96
|
)
|
|
90
97
|
|
|
91
98
|
function setMatchForcePending(match: AnyRouteMatch) {
|
|
@@ -146,12 +153,10 @@ export async function hydrate(router: AnyRouter): Promise<any> {
|
|
|
146
153
|
}
|
|
147
154
|
})
|
|
148
155
|
|
|
149
|
-
router.__store.setState((s) => {
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
}
|
|
154
|
-
})
|
|
156
|
+
router.__store.setState((s) => ({
|
|
157
|
+
...s,
|
|
158
|
+
matches,
|
|
159
|
+
}))
|
|
155
160
|
|
|
156
161
|
// Allow the user to handle custom hydration data
|
|
157
162
|
await router.options.hydrate?.(dehydratedData)
|
|
@@ -277,13 +282,11 @@ export async function hydrate(router: AnyRouter): Promise<any> {
|
|
|
277
282
|
}))
|
|
278
283
|
}
|
|
279
284
|
// hide the pending component once the load is finished
|
|
280
|
-
router.updateMatch(match.id, (prev) => {
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
}
|
|
286
|
-
})
|
|
285
|
+
router.updateMatch(match.id, (prev) => ({
|
|
286
|
+
...prev,
|
|
287
|
+
_displayPending: undefined,
|
|
288
|
+
displayPendingPromise: undefined,
|
|
289
|
+
}))
|
|
287
290
|
})
|
|
288
291
|
})
|
|
289
292
|
}
|
package/src/ssr/ssr-server.ts
CHANGED