@tanstack/react-router 1.15.13 → 1.15.15
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/awaited.cjs +41 -17
- package/dist/cjs/awaited.cjs.map +1 -1
- package/dist/cjs/createServerFn.cjs +16 -2
- package/dist/cjs/createServerFn.cjs.map +1 -1
- package/dist/cjs/createServerFn.d.cts +10 -3
- package/dist/cjs/defer.cjs.map +1 -1
- package/dist/cjs/defer.d.cts +3 -0
- package/dist/cjs/fileRoute.d.cts +6 -0
- package/dist/cjs/index.cjs +3 -1
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/link.cjs +7 -12
- package/dist/cjs/link.cjs.map +1 -1
- package/dist/cjs/route.cjs.map +1 -1
- package/dist/cjs/route.d.cts +3 -0
- package/dist/cjs/router.cjs +23 -1
- package/dist/cjs/router.cjs.map +1 -1
- package/dist/cjs/router.d.cts +10 -0
- package/dist/esm/awaited.js +41 -17
- package/dist/esm/awaited.js.map +1 -1
- package/dist/esm/createServerFn.d.ts +10 -3
- package/dist/esm/createServerFn.js +17 -3
- package/dist/esm/createServerFn.js.map +1 -1
- package/dist/esm/defer.d.ts +3 -0
- package/dist/esm/defer.js.map +1 -1
- package/dist/esm/fileRoute.d.ts +6 -0
- package/dist/esm/index.js +4 -2
- package/dist/esm/link.js +7 -12
- package/dist/esm/link.js.map +1 -1
- package/dist/esm/route.d.ts +3 -0
- package/dist/esm/route.js.map +1 -1
- package/dist/esm/router.d.ts +10 -0
- package/dist/esm/router.js +23 -1
- package/dist/esm/router.js.map +1 -1
- package/package.json +1 -1
- package/src/awaited.tsx +58 -25
- package/src/createServerFn.ts +32 -3
- package/src/defer.ts +6 -1
- package/src/link.tsx +9 -13
- package/src/route.ts +3 -0
- package/src/router.ts +45 -0
package/src/link.tsx
CHANGED
|
@@ -448,25 +448,24 @@ export function useLinkProps<
|
|
|
448
448
|
}
|
|
449
449
|
}
|
|
450
450
|
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
if (preload) {
|
|
451
|
+
const doPreload = () => {
|
|
452
|
+
React.startTransition(() => {
|
|
454
453
|
router.preloadRoute(dest as any).catch((err) => {
|
|
455
454
|
console.warn(err)
|
|
456
455
|
console.warn(preloadWarning)
|
|
457
456
|
})
|
|
458
|
-
}
|
|
457
|
+
})
|
|
459
458
|
}
|
|
460
459
|
|
|
461
|
-
|
|
460
|
+
// The click handler
|
|
461
|
+
const handleFocus = (e: MouseEvent) => {
|
|
462
462
|
if (preload) {
|
|
463
|
-
|
|
464
|
-
console.warn(err)
|
|
465
|
-
console.warn(preloadWarning)
|
|
466
|
-
})
|
|
463
|
+
doPreload()
|
|
467
464
|
}
|
|
468
465
|
}
|
|
469
466
|
|
|
467
|
+
const handleTouchStart = handleFocus
|
|
468
|
+
|
|
470
469
|
const handleEnter = (e: MouseEvent) => {
|
|
471
470
|
const target = (e.target || {}) as LinkCurrentTargetElement
|
|
472
471
|
|
|
@@ -477,10 +476,7 @@ export function useLinkProps<
|
|
|
477
476
|
|
|
478
477
|
target.preloadTimeout = setTimeout(() => {
|
|
479
478
|
target.preloadTimeout = null
|
|
480
|
-
|
|
481
|
-
console.warn(err)
|
|
482
|
-
console.warn(preloadWarning)
|
|
483
|
-
})
|
|
479
|
+
doPreload()
|
|
484
480
|
}, preloadDelay)
|
|
485
481
|
}
|
|
486
482
|
}
|
package/src/route.ts
CHANGED
|
@@ -220,6 +220,9 @@ export type UpdatableRouteOptions<
|
|
|
220
220
|
| Promise<JSX.IntrinsicElements['meta'][]>
|
|
221
221
|
links?: () => JSX.IntrinsicElements['link'][]
|
|
222
222
|
scripts?: () => JSX.IntrinsicElements['script'][]
|
|
223
|
+
headers?: (ctx: {
|
|
224
|
+
loaderData: TLoaderData
|
|
225
|
+
}) => Promise<Record<string, string>> | Record<string, string>
|
|
223
226
|
} & UpdatableStaticRouteOption
|
|
224
227
|
|
|
225
228
|
export type UpdatableStaticRouteOption =
|
package/src/router.ts
CHANGED
|
@@ -67,6 +67,14 @@ import { isRedirect } from './redirects'
|
|
|
67
67
|
import { NotFoundError, isNotFound } from './not-found'
|
|
68
68
|
import { ResolveRelativePath, ToOptions } from './link'
|
|
69
69
|
import { NoInfer } from '@tanstack/react-store'
|
|
70
|
+
import warning from 'tiny-warning'
|
|
71
|
+
import {
|
|
72
|
+
DeferredPromise,
|
|
73
|
+
DeferredPromiseState,
|
|
74
|
+
defaultDeserializeError,
|
|
75
|
+
isDehydratedDeferred,
|
|
76
|
+
isServerSideError,
|
|
77
|
+
} from '.'
|
|
70
78
|
// import warning from 'tiny-warning'
|
|
71
79
|
|
|
72
80
|
//
|
|
@@ -304,6 +312,10 @@ export class Router<
|
|
|
304
312
|
parseSearch: options?.parseSearch ?? defaultParseSearch,
|
|
305
313
|
transformer: options?.transformer ?? JSON,
|
|
306
314
|
})
|
|
315
|
+
|
|
316
|
+
if (typeof document !== 'undefined') {
|
|
317
|
+
;(window as any).__TSR__ROUTER__ = this
|
|
318
|
+
}
|
|
307
319
|
}
|
|
308
320
|
|
|
309
321
|
// These are default implementations that can optionally be overridden
|
|
@@ -719,6 +731,7 @@ export class Router<
|
|
|
719
731
|
path: route.fullPath,
|
|
720
732
|
params: routeParams,
|
|
721
733
|
})
|
|
734
|
+
|
|
722
735
|
const matchId =
|
|
723
736
|
interpolatePath({
|
|
724
737
|
path: route.id,
|
|
@@ -743,6 +756,7 @@ export class Router<
|
|
|
743
756
|
isGlobalNotFound && route.id === rootRouteId
|
|
744
757
|
? { global: true }
|
|
745
758
|
: undefined,
|
|
759
|
+
params: routeParams,
|
|
746
760
|
}
|
|
747
761
|
: {
|
|
748
762
|
id: matchId,
|
|
@@ -1706,7 +1720,30 @@ export class Router<
|
|
|
1706
1720
|
this.injectedHtml.push(html)
|
|
1707
1721
|
}
|
|
1708
1722
|
|
|
1723
|
+
// We use a token -> weak map to keep track of deferred promises
|
|
1724
|
+
// that are registered on the server and need to be resolved
|
|
1725
|
+
registeredDeferredsIds = new Map<string, {}>()
|
|
1726
|
+
registeredDeferreds = new WeakMap<{}, DeferredPromiseState<any>>()
|
|
1727
|
+
|
|
1728
|
+
getDeferred = (uid: string) => {
|
|
1729
|
+
const token = this.registeredDeferredsIds.get(uid)
|
|
1730
|
+
|
|
1731
|
+
if (!token) {
|
|
1732
|
+
return undefined
|
|
1733
|
+
}
|
|
1734
|
+
|
|
1735
|
+
return this.registeredDeferreds.get(token)
|
|
1736
|
+
}
|
|
1737
|
+
|
|
1738
|
+
/**
|
|
1739
|
+
* @deprecated Please inject your own html using the `injectHtml` method
|
|
1740
|
+
*/
|
|
1709
1741
|
dehydrateData = <T>(key: any, getData: T | (() => Promise<T> | T)) => {
|
|
1742
|
+
warning(
|
|
1743
|
+
false,
|
|
1744
|
+
`The dehydrateData method is deprecated. Please use the injectHtml method to inject your own data.`,
|
|
1745
|
+
)
|
|
1746
|
+
|
|
1710
1747
|
if (typeof document === 'undefined') {
|
|
1711
1748
|
const strKey = typeof key === 'string' ? key : JSON.stringify(key)
|
|
1712
1749
|
|
|
@@ -1727,7 +1764,15 @@ export class Router<
|
|
|
1727
1764
|
return () => undefined
|
|
1728
1765
|
}
|
|
1729
1766
|
|
|
1767
|
+
/**
|
|
1768
|
+
* @deprecated Please extract your own data from scripts injected using the `injectHtml` method
|
|
1769
|
+
*/
|
|
1730
1770
|
hydrateData = <T extends any = unknown>(key: any) => {
|
|
1771
|
+
warning(
|
|
1772
|
+
false,
|
|
1773
|
+
`The hydrateData method is deprecated. Please use the extractHtml method to extract your own data.`,
|
|
1774
|
+
)
|
|
1775
|
+
|
|
1731
1776
|
if (typeof document !== 'undefined') {
|
|
1732
1777
|
const strKey = typeof key === 'string' ? key : JSON.stringify(key)
|
|
1733
1778
|
|