@tanstack/start-client-core 1.169.4 → 1.170.1
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/esm/client/hydrateStart.d.ts +13 -1
- package/dist/esm/client/hydrateStart.js +20 -1
- package/dist/esm/client/hydrateStart.js.map +1 -1
- package/dist/esm/client/index.js +2 -2
- package/dist/esm/hydration/condition.d.ts +5 -0
- package/dist/esm/hydration/condition.js +16 -0
- package/dist/esm/hydration/condition.js.map +1 -0
- package/dist/esm/hydration/constants.d.ts +3 -0
- package/dist/esm/hydration/constants.js +8 -0
- package/dist/esm/hydration/constants.js.map +1 -0
- package/dist/esm/hydration/idle.d.ts +7 -0
- package/dist/esm/hydration/idle.js +22 -0
- package/dist/esm/hydration/idle.js.map +1 -0
- package/dist/esm/hydration/interaction.d.ts +8 -0
- package/dist/esm/hydration/interaction.js +221 -0
- package/dist/esm/hydration/interaction.js.map +1 -0
- package/dist/esm/hydration/load.d.ts +4 -0
- package/dist/esm/hydration/load.js +16 -0
- package/dist/esm/hydration/load.js.map +1 -0
- package/dist/esm/hydration/media.d.ts +4 -0
- package/dist/esm/hydration/media.js +23 -0
- package/dist/esm/hydration/media.js.map +1 -0
- package/dist/esm/hydration/never.d.ts +4 -0
- package/dist/esm/hydration/never.js +13 -0
- package/dist/esm/hydration/never.js.map +1 -0
- package/dist/esm/hydration/renderer.d.ts +5 -0
- package/dist/esm/hydration/renderer.js +9 -0
- package/dist/esm/hydration/renderer.js.map +1 -0
- package/dist/esm/hydration/runtime.d.ts +23 -0
- package/dist/esm/hydration/runtime.js +129 -0
- package/dist/esm/hydration/runtime.js.map +1 -0
- package/dist/esm/hydration/types.d.ts +38 -0
- package/dist/esm/hydration/visible.d.ts +8 -0
- package/dist/esm/hydration/visible.js +67 -0
- package/dist/esm/hydration/visible.js.map +1 -0
- package/dist/esm/hydration.d.ts +18 -0
- package/dist/esm/hydration.js +16 -0
- package/dist/esm/hydration.js.map +1 -0
- package/package.json +24 -3
- package/src/client/hydrateStart.ts +48 -2
- package/src/hydration/condition.ts +20 -0
- package/src/hydration/constants.ts +4 -0
- package/src/hydration/idle.ts +35 -0
- package/src/hydration/interaction.ts +342 -0
- package/src/hydration/load.ts +16 -0
- package/src/hydration/media.ts +25 -0
- package/src/hydration/never.ts +13 -0
- package/src/hydration/renderer.ts +21 -0
- package/src/hydration/runtime.ts +191 -0
- package/src/hydration/types.ts +90 -0
- package/src/hydration/visible.ts +90 -0
- package/src/hydration.ts +50 -0
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import type { HydrationPrefetchStrategy } from './types'
|
|
2
|
+
|
|
3
|
+
const visibleType = 'visible'
|
|
4
|
+
|
|
5
|
+
export type VisibleHydrationOptions = {
|
|
6
|
+
rootMargin?: string
|
|
7
|
+
threshold?: number | Array<number>
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
type VisibleObserverEntry = {
|
|
11
|
+
key: string
|
|
12
|
+
observer: IntersectionObserver
|
|
13
|
+
elements: Map<Element, Set<() => void>>
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const observerRegistry = /* @__PURE__ */ new Map<string, VisibleObserverEntry>()
|
|
17
|
+
|
|
18
|
+
function cleanupVisibleObserverEntry(observerEntry: VisibleObserverEntry) {
|
|
19
|
+
if (observerEntry.elements.size > 0) return
|
|
20
|
+
observerEntry.observer.disconnect()
|
|
21
|
+
observerRegistry.delete(observerEntry.key)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/* @__NO_SIDE_EFFECTS__ */
|
|
25
|
+
export function visible(
|
|
26
|
+
options: VisibleHydrationOptions = {},
|
|
27
|
+
): HydrationPrefetchStrategy<typeof visibleType> {
|
|
28
|
+
const rootMargin = options.rootMargin ?? '600px'
|
|
29
|
+
const threshold = options.threshold ?? 0
|
|
30
|
+
|
|
31
|
+
return {
|
|
32
|
+
_t: visibleType,
|
|
33
|
+
_s: ({ element, gate, prefetch }) => {
|
|
34
|
+
const callback = prefetch ?? gate!.resolve
|
|
35
|
+
|
|
36
|
+
if (!element) {
|
|
37
|
+
callback()
|
|
38
|
+
return
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const key = `${rootMargin}|${
|
|
42
|
+
Array.isArray(threshold) ? threshold.join(',') : String(threshold)
|
|
43
|
+
}`
|
|
44
|
+
let observerEntry = observerRegistry.get(key)
|
|
45
|
+
|
|
46
|
+
if (!observerEntry) {
|
|
47
|
+
const entry: VisibleObserverEntry = {
|
|
48
|
+
key,
|
|
49
|
+
elements: new Map<Element, Set<() => void>>(),
|
|
50
|
+
observer: new IntersectionObserver(
|
|
51
|
+
(entries) => {
|
|
52
|
+
for (const intersectingEntry of entries) {
|
|
53
|
+
if (!intersectingEntry.isIntersecting) continue
|
|
54
|
+
|
|
55
|
+
const callbacks = entry.elements.get(intersectingEntry.target)
|
|
56
|
+
if (!callbacks) continue
|
|
57
|
+
|
|
58
|
+
callbacks.forEach((callback) => callback())
|
|
59
|
+
entry.elements.delete(intersectingEntry.target)
|
|
60
|
+
entry.observer.unobserve(intersectingEntry.target)
|
|
61
|
+
cleanupVisibleObserverEntry(entry)
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
{ rootMargin, threshold },
|
|
65
|
+
),
|
|
66
|
+
}
|
|
67
|
+
observerRegistry.set(key, entry)
|
|
68
|
+
observerEntry = entry
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
let callbacks = observerEntry.elements.get(element)
|
|
72
|
+
if (!callbacks) {
|
|
73
|
+
callbacks = new Set()
|
|
74
|
+
observerEntry.elements.set(element, callbacks)
|
|
75
|
+
observerEntry.observer.observe(element)
|
|
76
|
+
}
|
|
77
|
+
callbacks.add(callback)
|
|
78
|
+
|
|
79
|
+
return () => {
|
|
80
|
+
const currentCallbacks = observerEntry.elements.get(element)
|
|
81
|
+
currentCallbacks?.delete(callback)
|
|
82
|
+
if (currentCallbacks?.size === 0) {
|
|
83
|
+
observerEntry.elements.delete(element)
|
|
84
|
+
observerEntry.observer.unobserve(element)
|
|
85
|
+
}
|
|
86
|
+
cleanupVisibleObserverEntry(observerEntry)
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
}
|
|
90
|
+
}
|
package/src/hydration.ts
ADDED
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { hydrateIdAttribute } from './hydration/constants'
|
|
2
|
+
|
|
3
|
+
export { condition } from './hydration/condition'
|
|
4
|
+
export type { HydrationCondition } from './hydration/condition'
|
|
5
|
+
export {
|
|
6
|
+
hydrateIdAttribute,
|
|
7
|
+
hydrateInteractionEventsAttribute,
|
|
8
|
+
hydrateWhenAttribute,
|
|
9
|
+
} from './hydration/constants'
|
|
10
|
+
export const hydrateIdSelector = `[${hydrateIdAttribute}]`
|
|
11
|
+
export { idle } from './hydration/idle'
|
|
12
|
+
export type { IdleHydrationOptions } from './hydration/idle'
|
|
13
|
+
export { interaction } from './hydration/interaction'
|
|
14
|
+
export { load } from './hydration/load'
|
|
15
|
+
export { media } from './hydration/media'
|
|
16
|
+
export { never } from './hydration/never'
|
|
17
|
+
export {
|
|
18
|
+
clearResolvedGateIdsInMarker,
|
|
19
|
+
createResolvedGate,
|
|
20
|
+
getFallbackHtml,
|
|
21
|
+
getMarkerGate,
|
|
22
|
+
getOrCreateGate,
|
|
23
|
+
onGateResolve,
|
|
24
|
+
releaseGate,
|
|
25
|
+
resolveHydrationMarker,
|
|
26
|
+
runHydrationStrategyCleanup,
|
|
27
|
+
saveFallbackHtml,
|
|
28
|
+
waitForHydrationPrefetchStrategy,
|
|
29
|
+
} from './hydration/runtime'
|
|
30
|
+
export { withHydrationRenderer } from './hydration/renderer'
|
|
31
|
+
export { visible } from './hydration/visible'
|
|
32
|
+
export { listenForDelegatedHydrationIntent } from './hydration/interaction'
|
|
33
|
+
export type { VisibleHydrationOptions } from './hydration/visible'
|
|
34
|
+
export type { HydrationGateRecord } from './hydration/runtime'
|
|
35
|
+
export type { HydrationStrategyWithRenderer } from './hydration/renderer'
|
|
36
|
+
export type {
|
|
37
|
+
HydrationInteractionEvent,
|
|
38
|
+
HydrationInteractionEvents,
|
|
39
|
+
HydrationMarkerAttributes,
|
|
40
|
+
HydrationPrefetchContext,
|
|
41
|
+
HydrationPrefetchFunction,
|
|
42
|
+
HydrationPrefetchWhen,
|
|
43
|
+
HydrationPrefetchStrategy,
|
|
44
|
+
HydrationPrefetchWaitReason,
|
|
45
|
+
HydrationRuntimeContext,
|
|
46
|
+
HydrationRuntimeGate,
|
|
47
|
+
HydrationStrategy,
|
|
48
|
+
HydrationStrategyTypes,
|
|
49
|
+
HydrationWhen,
|
|
50
|
+
} from './hydration/types'
|