@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.
Files changed (52) hide show
  1. package/dist/esm/client/hydrateStart.d.ts +13 -1
  2. package/dist/esm/client/hydrateStart.js +20 -1
  3. package/dist/esm/client/hydrateStart.js.map +1 -1
  4. package/dist/esm/client/index.js +2 -2
  5. package/dist/esm/hydration/condition.d.ts +5 -0
  6. package/dist/esm/hydration/condition.js +16 -0
  7. package/dist/esm/hydration/condition.js.map +1 -0
  8. package/dist/esm/hydration/constants.d.ts +3 -0
  9. package/dist/esm/hydration/constants.js +8 -0
  10. package/dist/esm/hydration/constants.js.map +1 -0
  11. package/dist/esm/hydration/idle.d.ts +7 -0
  12. package/dist/esm/hydration/idle.js +22 -0
  13. package/dist/esm/hydration/idle.js.map +1 -0
  14. package/dist/esm/hydration/interaction.d.ts +8 -0
  15. package/dist/esm/hydration/interaction.js +221 -0
  16. package/dist/esm/hydration/interaction.js.map +1 -0
  17. package/dist/esm/hydration/load.d.ts +4 -0
  18. package/dist/esm/hydration/load.js +16 -0
  19. package/dist/esm/hydration/load.js.map +1 -0
  20. package/dist/esm/hydration/media.d.ts +4 -0
  21. package/dist/esm/hydration/media.js +23 -0
  22. package/dist/esm/hydration/media.js.map +1 -0
  23. package/dist/esm/hydration/never.d.ts +4 -0
  24. package/dist/esm/hydration/never.js +13 -0
  25. package/dist/esm/hydration/never.js.map +1 -0
  26. package/dist/esm/hydration/renderer.d.ts +5 -0
  27. package/dist/esm/hydration/renderer.js +9 -0
  28. package/dist/esm/hydration/renderer.js.map +1 -0
  29. package/dist/esm/hydration/runtime.d.ts +23 -0
  30. package/dist/esm/hydration/runtime.js +129 -0
  31. package/dist/esm/hydration/runtime.js.map +1 -0
  32. package/dist/esm/hydration/types.d.ts +38 -0
  33. package/dist/esm/hydration/visible.d.ts +8 -0
  34. package/dist/esm/hydration/visible.js +67 -0
  35. package/dist/esm/hydration/visible.js.map +1 -0
  36. package/dist/esm/hydration.d.ts +18 -0
  37. package/dist/esm/hydration.js +16 -0
  38. package/dist/esm/hydration.js.map +1 -0
  39. package/package.json +24 -3
  40. package/src/client/hydrateStart.ts +48 -2
  41. package/src/hydration/condition.ts +20 -0
  42. package/src/hydration/constants.ts +4 -0
  43. package/src/hydration/idle.ts +35 -0
  44. package/src/hydration/interaction.ts +342 -0
  45. package/src/hydration/load.ts +16 -0
  46. package/src/hydration/media.ts +25 -0
  47. package/src/hydration/never.ts +13 -0
  48. package/src/hydration/renderer.ts +21 -0
  49. package/src/hydration/runtime.ts +191 -0
  50. package/src/hydration/types.ts +90 -0
  51. package/src/hydration/visible.ts +90 -0
  52. 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
+ }
@@ -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'