stroid 0.1.4 → 0.1.5

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 (150) hide show
  1. package/CHANGELOG.md +148 -34
  2. package/README.md +124 -17
  3. package/dist/async-internal.d.ts +30 -0
  4. package/dist/async.d.ts +7 -12
  5. package/dist/async.js +1 -1
  6. package/dist/chunk-4C666HHU.js +2 -0
  7. package/dist/chunk-4D6OA3DD.js +2 -0
  8. package/dist/chunk-6IBJ7CIK.js +14 -0
  9. package/dist/chunk-BWNLQKTY.js +2 -0
  10. package/dist/chunk-E33L4MII.js +2 -0
  11. package/dist/chunk-FSNVSMAV.js +2 -0
  12. package/dist/chunk-GZQGU64H.js +2 -0
  13. package/dist/chunk-LWUT37FW.js +13 -0
  14. package/dist/chunk-NFT6AZXY.js +2 -0
  15. package/dist/chunk-PHE2BCFG.js +2 -0
  16. package/dist/chunk-SF6EP56S.js +2 -0
  17. package/dist/chunk-WE3ZR6OG.js +2 -0
  18. package/dist/chunk-WXJ3IREA.js +2 -0
  19. package/dist/chunk-X2MKRN7O.js +14 -0
  20. package/dist/chunk-Y54SMROI.js +2 -0
  21. package/dist/computed.d.ts +6 -5
  22. package/dist/computed.js +1 -1
  23. package/dist/core-internal.d.ts +23 -0
  24. package/dist/core.d.ts +3 -2
  25. package/dist/core.js +1 -1
  26. package/dist/devtools-internal.d.ts +26 -0
  27. package/dist/devtools.d.ts +4 -25
  28. package/dist/devtools.js +1 -1
  29. package/dist/feature.d.ts +9 -2
  30. package/dist/feature.js +1 -1
  31. package/dist/fetch-4RH6MPY3.js +2 -0
  32. package/dist/graph-D28.d.ts +20 -0
  33. package/dist/helpers.d.ts +2 -1
  34. package/dist/helpers.js +1 -1
  35. package/dist/index-internal.d.ts +19 -19
  36. package/dist/index.d.cts +40 -22
  37. package/dist/index.d.ts +40 -22
  38. package/dist/index.js +1 -1
  39. package/dist/install.d.ts +16 -4
  40. package/dist/install.js +1 -1
  41. package/dist/metrics.d.ts +13 -0
  42. package/dist/persist.d.ts +3 -1
  43. package/dist/persist.js +1 -1
  44. package/dist/psr.d.ts +7 -8
  45. package/dist/psr.js +1 -1
  46. package/dist/query.d.ts +17 -0
  47. package/dist/query.js +2 -0
  48. package/dist/react/index.d.ts +10 -3
  49. package/dist/react/index.js +5 -5
  50. package/dist/registry.d.ts +22 -14
  51. package/dist/runtime-admin.js +1 -1
  52. package/dist/runtime-tools.d.ts +38 -65
  53. package/dist/runtime-tools.js +1 -1
  54. package/dist/selectors.d.ts +1 -1
  55. package/dist/selectors.js +1 -1
  56. package/dist/server/portable.d.ts +27 -0
  57. package/dist/server/portable.js +2 -0
  58. package/dist/server.d.ts +9 -20
  59. package/dist/server.js +1 -1
  60. package/dist/shared.d.ts +36 -0
  61. package/dist/store-registry.d.ts +3 -1
  62. package/dist/sync.d.ts +10 -1
  63. package/dist/sync.js +1 -1
  64. package/dist/testing.d.ts +1 -0
  65. package/dist/testing.js +1 -1
  66. package/dist/tsdoc-metadata.json +11 -0
  67. package/dist/types-internal-2.d.ts +168 -0
  68. package/dist/{computed-types.d.ts → types-internal-3.d.ts} +1 -1
  69. package/dist/{options.d.ts → types-internal.d.ts} +25 -9
  70. package/dist/types.d.ts +12 -2
  71. package/package.json +80 -26
  72. package/dist/chunk-645IESIU.js +0 -2
  73. package/dist/chunk-6ELWGQ4Q.js +0 -2
  74. package/dist/chunk-BW32TJGE.js +0 -13
  75. package/dist/chunk-FOQKGHPS.js +0 -26
  76. package/dist/chunk-KQCSFGHJ.js +0 -2
  77. package/dist/chunk-M2NJVI36.js +0 -2
  78. package/dist/chunk-PVATWAY4.js +0 -2
  79. package/dist/chunk-X3JR32JD.js +0 -2
  80. package/dist/computed-types.js +0 -2
  81. package/dist/types/adapters/options.d.ts +0 -335
  82. package/dist/types/async/cache.d.ts +0 -40
  83. package/dist/types/async/clone.d.ts +0 -10
  84. package/dist/types/async/errors.d.ts +0 -3
  85. package/dist/types/async/fetch.d.ts +0 -37
  86. package/dist/types/async/inflight.d.ts +0 -30
  87. package/dist/types/async/rate.d.ts +0 -5
  88. package/dist/types/async/registry.d.ts +0 -117
  89. package/dist/types/async/request.d.ts +0 -11
  90. package/dist/types/async/retry.d.ts +0 -10
  91. package/dist/types/async.d.ts +0 -10
  92. package/dist/types/computed/computed-graph.d.ts +0 -33
  93. package/dist/types/computed/index.d.ts +0 -21
  94. package/dist/types/computed/types.d.ts +0 -40
  95. package/dist/types/config.d.ts +0 -10
  96. package/dist/types/core/index.d.ts +0 -11
  97. package/dist/types/core/lifecycle-hooks.d.ts +0 -16
  98. package/dist/types/core/runtime-patch.d.ts +0 -67
  99. package/dist/types/core/store-admin-impl.d.ts +0 -9
  100. package/dist/types/core/store-admin.d.ts +0 -9
  101. package/dist/types/core/store-core.d.ts +0 -13
  102. package/dist/types/core/store-create.d.ts +0 -16
  103. package/dist/types/core/store-hydrate-impl.d.ts +0 -35
  104. package/dist/types/core/store-hydrate.d.ts +0 -9
  105. package/dist/types/core/store-lifecycle/hooks.d.ts +0 -20
  106. package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
  107. package/dist/types/core/store-lifecycle/registry.d.ts +0 -54
  108. package/dist/types/core/store-lifecycle/types.d.ts +0 -67
  109. package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
  110. package/dist/types/core/store-name.d.ts +0 -28
  111. package/dist/types/core/store-notify.d.ts +0 -13
  112. package/dist/types/core/store-read.d.ts +0 -18
  113. package/dist/types/core/store-registry.d.ts +0 -115
  114. package/dist/types/core/store-replace-impl.d.ts +0 -11
  115. package/dist/types/core/store-replace.d.ts +0 -9
  116. package/dist/types/core/store-set-impl.d.ts +0 -13
  117. package/dist/types/core/store-set.d.ts +0 -9
  118. package/dist/types/core/store-shared/core.d.ts +0 -13
  119. package/dist/types/core/store-shared/notify.d.ts +0 -12
  120. package/dist/types/core/store-transaction.d.ts +0 -28
  121. package/dist/types/core/store-write-shared.d.ts +0 -25
  122. package/dist/types/core/store-write.d.ts +0 -13
  123. package/dist/types/features/feature-registry.d.ts +0 -91
  124. package/dist/types/features/lifecycle.d.ts +0 -40
  125. package/dist/types/index.d.ts +0 -17
  126. package/dist/types/integrations/query.d.ts +0 -8
  127. package/dist/types/internals/computed-order.d.ts +0 -3
  128. package/dist/types/internals/config.d.ts +0 -116
  129. package/dist/types/internals/diagnostics.d.ts +0 -21
  130. package/dist/types/internals/reporting.d.ts +0 -9
  131. package/dist/types/internals/store-admin.d.ts +0 -7
  132. package/dist/types/internals/store-ops.d.ts +0 -13
  133. package/dist/types/internals/test-reset.d.ts +0 -2
  134. package/dist/types/internals/write-context.d.ts +0 -20
  135. package/dist/types/notification/delivery.d.ts +0 -3
  136. package/dist/types/notification/index.d.ts +0 -10
  137. package/dist/types/notification/metrics.d.ts +0 -12
  138. package/dist/types/notification/priority.d.ts +0 -9
  139. package/dist/types/notification/scheduler.d.ts +0 -11
  140. package/dist/types/notification/snapshot.d.ts +0 -8
  141. package/dist/types/runtime-admin/index.d.ts +0 -2
  142. package/dist/types/runtime-tools/index.d.ts +0 -63
  143. package/dist/types/store.d.ts +0 -16
  144. package/dist/types/types/utility.d.ts +0 -17
  145. package/dist/types/utils/clone.d.ts +0 -4
  146. package/dist/types/utils/devfreeze.d.ts +0 -2
  147. package/dist/types/utils/hash.d.ts +0 -8
  148. package/dist/types/utils/path.d.ts +0 -5
  149. package/dist/types/utils/validation.d.ts +0 -14
  150. package/dist/types/utils.d.ts +0 -13
package/README.md CHANGED
@@ -1,7 +1,7 @@
1
1
  <div align="center">
2
2
 
3
3
  <img src="https://img.shields.io/npm/v/stroid?color=7F77DD&label=stroid&style=flat-square" alt="npm version" />
4
- <img src="https://img.shields.io/bundlephobia/minzip/stroid?color=1D9E75&label=minzipped&style=flat-square" alt="bundle size" />
4
+ <img src="https://img.shields.io/badge/tree--shakeable-subpaths-0F766E?style=flat-square" alt="tree-shakeable via subpaths" />
5
5
  <img src="https://img.shields.io/npm/types/stroid?color=4A90E2&style=flat-square" alt="types" />
6
6
  <img src="https://img.shields.io/npm/l/stroid?color=3B8BD4&style=flat-square" alt="license" />
7
7
  <img src="https://img.shields.io/github/actions/workflow/status/Himesh-Bhattarai/stroid/ci.yml?color=639922&label=tests&style=flat-square" alt="tests" />
@@ -12,18 +12,28 @@
12
12
  <img src="https://img.shields.io/github/stars/Himesh-Bhattarai/stroid?style=flat-square&label=stars" alt="stars" />
13
13
  <img src="https://img.shields.io/github/contributors/Himesh-Bhattarai/stroid?style=flat-square" alt="contributors" />
14
14
  <img src="https://img.shields.io/github/issues/Himesh-Bhattarai/stroid?style=flat-square" alt="issues" />
15
- <img src="https://img.shields.io/snyk/vulnerabilities/github/Himesh-Bhattarai/stroid?style=flat-square" alt="vulnerabilities" />
15
+
16
16
  <!-- <a href="https://your-demo-link.com">
17
17
  <img src="https://img.shields.io/badge/demo-live-ff69b4?style=flat-square" alt="live demo" />
18
18
  </a> -->
19
19
  <br /><br />
20
20
 
21
+ **Stroid is the only state management library with a theoretical correctness argument, a matching implementation, and a certified benchmark suite proving it holds under production-grade concurrent SSR conditions.**
22
+ <br /><br />
23
+
21
24
  # 🟣 Stroid - State Engine for TypeScript and React
22
25
  **Named-store state engine for TypeScript and React.**
23
26
 
24
- Every store has a name. Write to it from anywhere: hooks, utilities, server, tests. Optional layers add persistence, sync, async fetch, SSR isolation, and devtools without coupling to core logic.
27
+ Every store has a name. Write to it from anywhere: hooks, utilities, server, tests. Optional layers add persistence, sync, async fetch, SSR isolation, post-hydration consistency controls, and devtools without coupling to core logic.
25
28
  <br />
26
29
  [**Get Started**](#30-second-quickstart) | [**Why Stroid**](#why-stroid) | [**API Reference**](#full-api-reference) | [**PSR**](#psr---write-governance) | [**DevTools**](#devtools) | [**Examples**](#real-world-examples)
30
+ <br /><br />
31
+
32
+ **Certified benchmark suite (latest rerun: `2026-04-02`)**
33
+ <br />
34
+ `0` SSR correctness violations across `2 x 1,024` burst requests, `8,192` sustained requests, and `256` concurrent React streaming SSR requests, plus `0` detached leaks in warm-container/provider-model runs and `0` React concurrency invariant violations under `useTransition` and `useDeferredValue`.
35
+ <br />
36
+ [**Benchmark Report**](./docs/STROID/BENCHMARK.md) | Run: `npm run benchmark:guarantees`
27
37
 
28
38
  </div>
29
39
 
@@ -78,6 +88,26 @@ Every store has a name. Write to it from anywhere: hooks, utilities, server, tes
78
88
  >```
79
89
  ---
80
90
 
91
+ ## Operational Notes
92
+
93
+ - Store names are runtime-validated. Avoid spaces and reserved keys like `__proto__`, `constructor`, and `prototype`.
94
+ - `useStore("name")` without a path or selector subscribes to the full store. Prefer `useSelector(...)` or path reads in hot React components.
95
+ - Hook string names are only strongly typed after `StoreStateMap` augmentation. Without it, `useStore("name")` reads are intentionally loose and typically resolve to `unknown`.
96
+ - Selector-heavy dev flows that read frozen state deep-clone by default for safe dependency tracking. If that overhead matters more than the extra safety, tune `selectorCloneFrozen`.
97
+ - `fetchStore(name, promise, ...)` accepts a direct Promise, but direct Promise inputs cannot use retries or replayable `refetchStore()` semantics. Use a URL string or factory when you need retry/backoff behavior.
98
+ - `asyncAutoCreate` is a development convenience, not a production safety feature. Leave it off in production to avoid typo-created phantom stores.
99
+ - `stroid/sync` uses same-origin `BroadcastChannel` transport. Stroid requests a fresh snapshot on startup, focus, and reconnect, but listener registration can still race under load, `policy: "insecure"` is an explicit opt-out, and open channels may reduce BFCache restores.
100
+ - `stroid/persist` relies on browser storage. `checksum: "hash"` is non-cryptographic, and Safari/WebKit can evict script-writable storage after roughly 7 days of inactivity, so persisted auth, carts, and drafts should have a server-backed recovery path.
101
+ - `hydrateStores(snapshot, options, trust, consistency?)` can add a bounded post-hydration consistency window. Stroid can defer early client writes, emit structured drift events, and reconcile per store with `server_wins`, `client_wins`, `merge`, or `invalidate_and_refetch`.
102
+ - React hooks are built on `useSyncExternalStore`; local concurrency certification now covers no-tearing invariants under `useTransition` and `useDeferredValue`.
103
+ - `stroid/server` is Node-only today because it depends on `node:async_hooks`. Edge runtimes and Workers need a different adapter.
104
+ - `stroid/server/portable` is the explicit request-scope boundary for serverless hand-offs, worker-style runtimes, and Server Actions. It does not rely on implicit async context; use the bound scope API it returns.
105
+ - Local provider-model certification now covers warm AWS Lambda-style Node handlers, Vercel render-to-action hand-off, and Cloudflare Workers-style explicit scopes, but you should still validate against your deployed provider before claiming production certification.
106
+ - Next.js Server Actions are a separate execution boundary. They do not inherit the original request carrier automatically; capture state on render and resume it with `stroid/server/portable`. The render-to-action hand-off is covered by `benchmark:next-server-actions` and [examples/next-app-router-server-actions.ts](./examples/next-app-router-server-actions.ts).
107
+ - Stroid can only guarantee request isolation for state written through Stroid APIs. Third-party singleton stores remain outside that guarantee.
108
+
109
+ ---
110
+
81
111
  ### Stroid PSR
82
112
 
83
113
  Stroid ships a native PSR contract in `stroid/psr`.
@@ -95,12 +125,14 @@ stroid <- core public runtime
95
125
  |- stroid/core <- minimal core surface
96
126
  |- stroid/psr <- native PSR contract
97
127
  |- stroid/async <- fetch/cache/revalidate
128
+ |- stroid/query <- reactQueryKey(), swrKey()
98
129
  |- stroid/selectors <- selector helpers
99
130
  |- stroid/computed <- computed stores
100
131
  |- stroid/persist <- installPersist()
101
132
  |- stroid/sync <- installSync()
102
133
  |- stroid/devtools <- installDevtools(), history API
103
134
  |- stroid/server <- SSR request-scoped registry
135
+ |- stroid/server/portable <- explicit request-scope bridge for serverless / workers / server actions
104
136
  |- stroid/helpers <- entity/list/counter helpers
105
137
  |- stroid/testing <- test helpers
106
138
  |- stroid/runtime-tools <- observability APIs
@@ -109,6 +141,9 @@ stroid <- core public runtime
109
141
  |- stroid/install <- installAllFeatures()
110
142
  ```
111
143
 
144
+ Import note:
145
+ - Prefer subpath imports and avoid defaulting to the full `stroid` root import unless you need its broader compatibility surface.
146
+
112
147
  ---
113
148
 
114
149
  <a id="why-stroid"></a>
@@ -129,20 +164,19 @@ stroid <- core public runtime
129
164
  | Race resistance proof | ✅ | ❌ | ❌ | ❌ | ❌ |
130
165
  | Determinism replay | ✅ | ❌ | ❌ | ❌ | ❌ |
131
166
  | Ring-buffer event timeline | ✅ | ❌ | ❌ | ❌ | ❌ |
132
- | Bundle size (core import closure) | 77.6kb raw / 25.1kb gzip | ~11kb | ~1kb | ~3kb | ~3kb |
133
167
  | TypeScript-first | ✅ | ✅ | ✅ | ✅ | ✅ |
134
168
 
135
- NOTE: BUNDLE SIZE: 25.1 gzip include whole "Stroid". Stroid is treeshakable so, stroid size will determine by your import.
136
-
137
169
  > ⚠️ = possible with extra setup · ❌ = not supported natively
138
170
 
139
171
  Stroid exposes governance-oriented write flows through `stroid/psr`, including committed snapshot reads, patch application APIs, runtime graph inspection, and timing contracts.
140
172
  Benchmark report: [docs/STROID/BENCHMARK.md](./docs/STROID/BENCHMARK.md).
173
+ Benchmark script layout is categorized by domain under `scripts/core`, `scripts/ssr`, `scripts/hydration`, `scripts/react`, `scripts/guarantees`, and `scripts/comparison`.
141
174
 
142
175
  Stroid is a fit when you need these together:
143
176
  - Named global stores with direct writes
144
177
  - Optional feature installs instead of mandatory side effects
145
178
  - Strict hydration trust gate (`hydrateStores(..., ..., { allowTrusted: true })`)
179
+ - Governed post-hydration drift handling with per-store consistency policies
146
180
  - Request-scoped SSR runtime (`createStoreForRequest`) with server guards
147
181
  - PSR-style patch application and runtime graph inspection (`stroid/psr`)
148
182
 
@@ -184,6 +218,7 @@ setStore("cart", (draft: any) => {
184
218
  });
185
219
  ```
186
220
  Updates existing store state by path, partial object merge, or mutator function.
221
+ The public root API intentionally does not export `replaceStore`; explicit full-store replacement is kept on the internal runtime/PSR side to reduce accidental overwrite mistakes.
187
222
 
188
223
  ---
189
224
 
@@ -221,6 +256,11 @@ resetStore("cart");
221
256
  ```
222
257
  Resets a store back to its original initial state.
223
258
 
259
+ Reset clone behavior is configurable:
260
+
261
+ - Per store: `createStore("cart", initial, { resetClone: "deep" | "shallow" | "none" })`
262
+ - Global default: `configureStroid({ resetCloneMode: "deep" | "shallow" | "none" })`
263
+
224
264
  ---
225
265
 
226
266
  ### `deleteStore`
@@ -255,16 +295,45 @@ Runs multiple synchronous writes in one transaction-style batch.
255
295
  ```ts
256
296
  import { hydrateStores } from "stroid";
257
297
 
258
- hydrateStores(
298
+ const hydration = hydrateStores(
259
299
  {
260
300
  cart: { items: [{ id: "pizza", qty: 1 }], total: 499 },
261
301
  profile: { name: "Asha" },
262
302
  },
263
303
  {},
264
- { allowTrusted: true }
304
+ { allowTrusted: true },
305
+ {
306
+ contract: {
307
+ snapshotVersion: 3,
308
+ timestamp: Date.now(),
309
+ stores: {
310
+ cart: { authority: "server-authoritative" },
311
+ profile: { authority: "client-authoritative" },
312
+ },
313
+ },
314
+ bootWindow: {
315
+ mode: "manual",
316
+ fallbackMs: 3000,
317
+ },
318
+ policyMap: {
319
+ cart: "server_wins",
320
+ profile: "client_wins",
321
+ },
322
+ }
265
323
  );
324
+
325
+ hydration.bootWindow?.close();
266
326
  ```
267
- Hydrates many stores from a trusted snapshot payload.
327
+ Hydrates many stores from a trusted snapshot payload. The optional fourth argument adds post-hydration drift controls, write deferral during the boot window, and structured drift diagnostics. Manual mode returns `hydration.bootWindow`, so your app can close the gate when its critical hydration boundary is ready.
328
+
329
+ Recommended rollout defaults:
330
+ - use `bootWindow: { mode: "manual", fallbackMs: 3000 }` when you need certification-grade control
331
+ - keep `bootWindowMs` or `bootWindow: { mode: "timer", ms: ... }` only as a compatibility fallback when you cannot close manually yet
332
+ - keep auth/session stores `server_wins`
333
+ - keep drafts/forms `client_wins`
334
+ - use `merge` for filters or preference bags and `invalidate_and_refetch` for replayable async caches
335
+
336
+ The full adoption guide, policy defaults, and runtime-tools workflow live in [Post-Hydration Consistency](./docs/STROID_SERVER/POST_HYDRATION_CONSISTENCY.md).
268
337
 
269
338
  ---
270
339
 
@@ -282,7 +351,23 @@ configureStroid({
282
351
  Sets global runtime behavior such as async and snapshot defaults.
283
352
 
284
353
  ---
285
-
354
+ >[!TIP]
355
+ >
356
+ >Stroid is NOT for:
357
+ >- small apps
358
+ >- simple UI state
359
+ >- beginners learning React
360
+ >
361
+ >Stroid is for:
362
+ >- complex apps
363
+ >- SSR-heavy systems
364
+ >- multi-source async data
365
+ >- teams that need debugging + guarantees
366
+ > *If Still want to learn, then:
367
+ > - **Beginners:** If you are building a personal portfolio or a small app, you likely only need `createStore`, `getStore`, and the basic React hooks like `useStore`. I don't want you to read whole README.
368
+ > - **Intermediate:** We recommend reading the full README to understand features like batching, persistence,SSR Isolation,Sync,and async fetching. Don't take overhead about PSR FOR NOW, THINK THAT NOT EXIST AT ALL. UNTIL, I MAKE PROPER EXPLANATION VIDEO.
369
+ > - **Advanced:** Explore the `/docs` directory for deep dives into architecture, SSR isolation, and the PSR contract, DevTools.
370
+ ---
286
371
  ## ⚛️ React Hooks - `stroid/react`
287
372
 
288
373
  ### `useStore`
@@ -350,7 +435,7 @@ import { fetchStore } from "stroid/async";
350
435
 
351
436
  function Menu() {
352
437
  useEffect(() => {
353
- void fetchStore("menu", "https://api.example.com/menu");
438
+ void fetchStore("menu", "https://api.example.com/menu", { autoCreate: true });
354
439
  }, []);
355
440
 
356
441
  const { loading, error, data } = useAsyncStore("menu");
@@ -372,7 +457,8 @@ import { useAsyncStoreSuspense } from "stroid/react";
372
457
  function MenuSuspense() {
373
458
  const menu = useAsyncStoreSuspense<Array<{ id: string; name: string }>>(
374
459
  "menu",
375
- "https://api.example.com/menu"
460
+ "https://api.example.com/menu",
461
+ { autoCreate: true }
376
462
  );
377
463
 
378
464
  return <MenuList items={menu} />;
@@ -601,6 +687,7 @@ Provides ready-made entity, list, and counter store helpers.
601
687
  ## 🧪 Testing - `stroid/testing`
602
688
 
603
689
  ```ts
690
+ import { store } from "stroid";
604
691
  import {
605
692
  createMockStore,
606
693
  resetAllStoresForTest,
@@ -615,7 +702,7 @@ withMockedTime(1700000000000, () => {
615
702
  // Date.now() is fixed in this callback
616
703
  });
617
704
 
618
- const result = benchmarkStoreSet({ name: "cart" } as any, 300);
705
+ const result = benchmarkStoreSet(store("cart"), 300);
619
706
  const avgMs = result.avgMs;
620
707
 
621
708
  resetAllStoresForTest();
@@ -650,6 +737,20 @@ const deps = getComputedDeps("deliveryFee");
650
737
  const persistDepth = getPersistQueueDepth("cart");
651
738
  ```
652
739
  Exposes runtime diagnostics for stores, metrics, health, and computed graph state.
740
+ Import only the functions you need. The internal helpers are grouped more narrowly now, but the published multi-entry build still shares runtime chunks, so the biggest remaining wins are still deeper than this surface split.
741
+
742
+ ---
743
+
744
+ ## 🗝️ Query Keys - `stroid/query`
745
+
746
+ ```ts
747
+ import { reactQueryKey, swrKey } from "stroid/query";
748
+
749
+ const tanstackKey = reactQueryKey("cart");
750
+ const swrCacheKey = swrKey("cart", "summary");
751
+ ```
752
+ Use `stroid/query` when you only need stable cache keys for TanStack Query or SWR.
753
+ The root `queryIntegrations` namespace still exists for compatibility, but `stroid/query` is the leaner path.
653
754
 
654
755
  ---
655
756
 
@@ -859,7 +960,8 @@ import { useAsyncStoreSuspense } from "stroid/react";
859
960
  function MenuList() {
860
961
  const menu = useAsyncStoreSuspense<Array<{ id: string; name: string }>>(
861
962
  "menu",
862
- "https://api.example.com/menu"
963
+ "https://api.example.com/menu",
964
+ { autoCreate: true }
863
965
  );
864
966
 
865
967
  return <ul>{menu.map((item) => <li key={item.id}>{item.name}</li>)}</ul>;
@@ -909,6 +1011,7 @@ Import from `stroid` for batching/hydration/computed plus runtime metrics and co
909
1011
  - `stroid/core`: Minimal CRUD runtime (`createStore`, `setStore`, `getStore`, `hasStore`, `resetStore`, `deleteStore`).
910
1012
  - `stroid/react`: React hooks (`useStore`, `useSelector`, `useStoreField`, `useStoreStatic`, `useAsyncStore`, `useFormStore`, `useAsyncStoreSuspense`) and `RegistryScope`.
911
1013
  - `stroid/async`: Async APIs (`fetchStore`, `refetchStore`, `enableRevalidateOnFocus`, `getAsyncMetrics`).
1014
+ - `stroid/query`: cache-key helpers (`reactQueryKey`, `swrKey`) without the fetcher helpers.
912
1015
  - `stroid/selectors`: `createSelector`, `subscribeWithSelector`.
913
1016
  - `stroid/computed`: `createComputed`, `invalidateComputed`, `deleteComputed`, `isComputedStore`.
914
1017
  - `stroid/persist`: `installPersist`.
@@ -917,7 +1020,7 @@ Import from `stroid` for batching/hydration/computed plus runtime metrics and co
917
1020
  - `stroid/server`: `createStoreForRequest`.
918
1021
  - `stroid/helpers`: `createEntityStore`, `createListStore`, `createCounterStore`.
919
1022
  - `stroid/testing`: `createMockStore`, `resetAllStoresForTest`, `withMockedTime`, `benchmarkStoreSet`.
920
- - `stroid/runtime-tools`: Store/runtime observability APIs.
1023
+ - `stroid/runtime-tools`: Store/runtime observability APIs, including hydration drift reports and counters.
921
1024
  - `stroid/runtime-admin`: `clearAllStores`, `clearStores`.
922
1025
  - `stroid/feature`: Feature registration APIs.
923
1026
  - `stroid/install`: `installPersist`, `installSync`, `installDevtools`, `installAllFeatures`.
@@ -938,11 +1041,12 @@ Import from `stroid` for batching/hydration/computed plus runtime metrics and co
938
1041
  | `resetStore(name)` | Restore initial state. |
939
1042
  | `hasStore(name)` | Check if store exists. |
940
1043
  | `setStoreBatch(fn)` | Group synchronous writes into one transaction. |
941
- | `hydrateStores(snapshot, options?, trust)` | Hydrate trusted snapshot into runtime. |
1044
+ | `hydrateStores(snapshot, options?, trust, consistency?)` | Hydrate trusted snapshot into runtime, optionally governing post-hydration drift. |
942
1045
  | `configureStroid(config)` | Configure global/runtime behavior. |
943
1046
  | `useStore(name, selectorOrPath?)` | React subscription hook. |
944
1047
  | `useSelector(name, fn, equality?)` | Fine-grained React selector hook. |
945
1048
  | `fetchStore(name, input, options?)` | Fetch remote data into store. |
1049
+ | `getAsyncMetrics(name?)` | Read global or per-store async counters. |
946
1050
  | `createComputed(name, deps, fn)` | Define computed store. |
947
1051
  | `createStoreForRequest(fn)` | Build SSR request-scoped store runtime. |
948
1052
 
@@ -978,7 +1082,7 @@ import {
978
1082
  getTimingContract,
979
1083
  } from "stroid/psr";
980
1084
 
981
- // Minimal core (bundle-size-sensitive)
1085
+ // Minimal core (subpath import)
982
1086
  import { createStore, setStore, getStore, hasStore, resetStore, deleteStore } from "stroid/core";
983
1087
 
984
1088
  // React
@@ -996,6 +1100,9 @@ import {
996
1100
  // Async
997
1101
  import { fetchStore, refetchStore, enableRevalidateOnFocus } from "stroid/async";
998
1102
 
1103
+ // Query keys only
1104
+ import { reactQueryKey, swrKey } from "stroid/query";
1105
+
999
1106
  // Selectors & Computed
1000
1107
  import { createSelector, subscribeWithSelector } from "stroid/selectors";
1001
1108
  import { createComputed, invalidateComputed, deleteComputed, isComputedStore } from "stroid/computed";
@@ -0,0 +1,30 @@
1
+ import { StoreFeatureMeta } from './feature.js';
2
+ import { g as getAsyncMetrics } from './metrics.js';
3
+ import { C as ColdStoreReport } from './core-internal.js';
4
+
5
+ declare const getAsyncInflightCount: (name: string) => number;
6
+ declare const getPersistQueueDepth: (name: string) => number;
7
+ type StoreHealthEntry = {
8
+ name: string;
9
+ meta: StoreFeatureMeta | null;
10
+ metrics: StoreFeatureMeta["metrics"] | null;
11
+ async: {
12
+ inflight: number;
13
+ lastCorrelationId: string | null;
14
+ traceContext: StoreFeatureMeta["lastTraceContext"] | null;
15
+ };
16
+ persist: {
17
+ queueDepth: number;
18
+ };
19
+ };
20
+ type StoreHealthReport = {
21
+ stores: StoreHealthEntry[];
22
+ async: ReturnType<typeof getAsyncMetrics>;
23
+ registry: {
24
+ totalStores: number;
25
+ coldStores: ColdStoreReport[];
26
+ };
27
+ };
28
+ declare const getStoreHealth: (name?: string) => StoreHealthEntry | StoreHealthReport | null;
29
+
30
+ export { type StoreHealthEntry as S, type StoreHealthReport as a, getPersistQueueDepth as b, getStoreHealth as c, getAsyncInflightCount as g };
package/dist/async.d.ts CHANGED
@@ -1,12 +1,15 @@
1
1
  import { F as FetchInput } from './cache.js';
2
- import { a as StoreDefinition, b as StoreKey, d as StoreName } from './types.js';
3
2
  import { F as FetchOptions } from './registry.js';
4
- export { a as AsyncStateAdapter, b as AsyncStateSnapshot } from './registry.js';
3
+ export { b as AsyncStateAdapter, c as AsyncStateSnapshot } from './registry.js';
4
+ import { a as StoreDefinition, b as StoreKey, d as StoreName } from './types.js';
5
+ export { g as getAsyncMetrics } from './metrics.js';
5
6
  import './utility.js';
7
+ import './types-internal-2.js';
6
8
 
7
9
  declare function fetchStore<Name extends string, State>(name: StoreDefinition<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
8
10
  declare function fetchStore<Name extends string, State>(name: StoreKey<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
9
11
  declare function fetchStore<Name extends StoreName>(name: Name, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
12
+
10
13
  declare function refetchStore<Name extends string, State>(name: StoreDefinition<Name, State>): Promise<unknown>;
11
14
  declare function refetchStore<Name extends string, State>(name: StoreKey<Name, State>): Promise<unknown>;
12
15
  declare function refetchStore<Name extends StoreName>(name: Name): Promise<unknown>;
@@ -28,15 +31,7 @@ declare function enableRevalidateOnFocus<Name extends StoreName>(name?: Name | "
28
31
  staggerMs?: number;
29
32
  priority?: "high" | "normal";
30
33
  }): (() => void);
31
- declare const getAsyncMetrics: () => {
32
- cacheHits: number;
33
- cacheMisses: number;
34
- dedupes: number;
35
- requests: number;
36
- failures: number;
37
- avgMs: number;
38
- lastMs: number;
39
- };
34
+
40
35
  declare const _resetAsyncStateForTests: () => void;
41
36
 
42
- export { FetchInput, FetchOptions, _resetAsyncStateForTests, enableRevalidateOnFocus, fetchStore, getAsyncMetrics, refetchStore };
37
+ export { FetchInput, FetchOptions, _resetAsyncStateForTests, enableRevalidateOnFocus, fetchStore, refetchStore };
package/dist/async.js CHANGED
@@ -1,2 +1,2 @@
1
- import'./chunk-YU5GMPCC.js';export{e as _resetAsyncStateForTests,c as enableRevalidateOnFocus,a as fetchStore,d as getAsyncMetrics,b as refetchStore}from'./chunk-BW32TJGE.js';import'./chunk-6ELWGQ4Q.js';import'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=async.js.map
1
+ import'./chunk-YU5GMPCC.js';export{f as _resetAsyncStateForTests,c as enableRevalidateOnFocus,a as fetchStore,e as getAsyncMetrics,b as refetchStore}from'./chunk-LWUT37FW.js';import'./chunk-E33L4MII.js';import'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=async.js.map
2
2
  //# sourceMappingURL=async.js.map
@@ -0,0 +1,2 @@
1
+ var d=Object.defineProperty;var e=(c,a)=>{for(var b in a)d(c,b,{get:a[b],enumerable:true});};export{e as a};//# sourceMappingURL=chunk-4C666HHU.js.map
2
+ //# sourceMappingURL=chunk-4C666HHU.js.map
@@ -0,0 +1,2 @@
1
+ var i=({value:e,sanitize:t,validate:r,onSanitizeError:o})=>{let a;if(t)try{a=t(e);}catch(u){return o?.(u),{ok:false}}else a=e;let n=r(a);return n.ok?{ok:true,value:n.value??a}:{ok:false}},l=({value:e,fallbackMs:t=Date.now(),onInvalid:r})=>{if(typeof e=="number")return Number.isFinite(e)?e:(r?.(),t);if(typeof e=="string"){let o=Date.parse(e);return Number.isFinite(o)?o:(r?.(),t)}return r?.(),t};export{i as a,l as b};//# sourceMappingURL=chunk-4D6OA3DD.js.map
2
+ //# sourceMappingURL=chunk-4D6OA3DD.js.map
@@ -0,0 +1,14 @@
1
+ import {d,c}from'./chunk-PHE2BCFG.js';var oe=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Le=()=>({cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}),se=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),requestSequence:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:oe(),storeCleanups:new Map,revalidateKeys:new Set,revalidateHandlers:Object.create(null),slotOwners:new Map,slotsByStore:new Map,cachePruneCounters:new Map,usageErrorEmissions:new Map,asyncMetrics:Le(),asyncMetricsByStore:new Map}),ie=e=>{e.storeCleanups.forEach(t=>{Object.values(t).forEach(n=>{n?.forEach(r=>{try{r();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.requestSequence).forEach(t=>delete e.requestSequence[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),e.storeCleanups.clear(),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.slotOwners.clear(),e.slotsByStore.clear(),e.cachePruneCounters.clear(),e.usageErrorEmissions.clear(),e.asyncMetricsByStore.clear(),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),oe().forEach((t,n)=>{e.warnedOnce.set(n,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var ae=new Map,_=(e,t,n=0)=>{!e||typeof t!="function"||ae.set(e,{name:e,order:n,fn:t});},Kt=()=>{Array.from(ae.values()).sort((t,n)=>t.order!==n.order?t.order-n.order:t.name.localeCompare(n.name,"en")).forEach(t=>t.fn());};var Ue={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},ue={logSink:Ue,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",resetCloneMode:"deep",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},I=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,resetCloneMode:e.resetCloneMode,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),F=new WeakMap,L=I(ue),le=e=>{let t=F.get(e);return t||(t=I(L),F.set(e,t)),t},de,$=false,Ye=()=>de,w=()=>le(q());var Qt=e=>{if(!e)return;let t=q(),n=le(t);if(e.logSink&&(n={...n,logSink:{log:e.logSink.log??n.logSink.log,warn:e.logSink.warn??n.logSink.warn,critical:e.logSink.critical??n.logSink.critical}}),e.flush&&(n={...n,flush:{chunkSize:Number.isFinite(e.flush.chunkSize??n.flush.chunkSize)?e.flush.chunkSize:n.flush.chunkSize,chunkDelayMs:Number.isFinite(e.flush.chunkDelayMs??n.flush.chunkDelayMs)?e.flush.chunkDelayMs:n.flush.chunkDelayMs,priorityStores:Array.isArray(e.flush.priorityStores)?e.flush.priorityStores:n.flush.priorityStores}}),e.revalidateOnFocus&&(n={...n,revalidateOnFocus:{debounceMs:Number.isFinite(e.revalidateOnFocus.debounceMs??n.revalidateOnFocus.debounceMs)?e.revalidateOnFocus.debounceMs:n.revalidateOnFocus.debounceMs,maxConcurrent:Number.isFinite(e.revalidateOnFocus.maxConcurrent??n.revalidateOnFocus.maxConcurrent)?Math.max(1,e.revalidateOnFocus.maxConcurrent):n.revalidateOnFocus.maxConcurrent,staggerMs:Number.isFinite(e.revalidateOnFocus.staggerMs??n.revalidateOnFocus.staggerMs)?Math.max(0,e.revalidateOnFocus.staggerMs):n.revalidateOnFocus.staggerMs}}),typeof e.namespace=="string"&&(n={...n,namespace:e.namespace.trim()}),typeof e.strictMissingFeatures=="boolean"&&(n={...n,strictMissingFeatures:e.strictMissingFeatures}),typeof e.strictFeatures=="boolean"&&(n={...n,strictMissingFeatures:e.strictFeatures}),typeof e.assertRuntime=="boolean"&&(n={...n,assertRuntime:e.assertRuntime}),typeof e.strictMutatorReturns=="boolean"&&(n={...n,strictMutatorReturns:e.strictMutatorReturns}),typeof e.asyncAutoCreate=="boolean"&&(n={...n,asyncAutoCreate:e.asyncAutoCreate}),typeof e.strictAsyncUsageErrors=="boolean"&&(n={...n,strictAsyncUsageErrors:e.strictAsyncUsageErrors}),typeof e.autoCorrelationIds=="boolean"&&(n={...n,autoCorrelationIds:e.autoCorrelationIds}),(e.asyncCloneResult==="none"||e.asyncCloneResult==="shallow"||e.asyncCloneResult==="deep")&&(n={...n,asyncCloneResult:e.asyncCloneResult}),(e.resetCloneMode==="none"||e.resetCloneMode==="shallow"||e.resetCloneMode==="deep")&&(n={...n,resetCloneMode:e.resetCloneMode}),typeof e.acknowledgeLooseTypes=="boolean"&&(n={...n,acknowledgeLooseTypes:e.acknowledgeLooseTypes}),typeof e.pathCacheSize=="number"&&Number.isFinite(e.pathCacheSize)&&(n={...n,pathCacheSize:Math.max(0,Math.floor(e.pathCacheSize))}),(e.snapshotStrategy==="shallow"||e.snapshotStrategy==="ref"||e.snapshotStrategy==="deep")&&(n={...n,defaultSnapshotMode:e.snapshotStrategy}),(e.defaultSnapshotMode==="shallow"||e.defaultSnapshotMode==="ref"||e.defaultSnapshotMode==="deep")&&(n={...n,defaultSnapshotMode:e.defaultSnapshotMode}),Array.isArray(e.middleware)&&(n={...n,middleware:e.middleware}),typeof e.allowUntrustedHydration=="boolean"&&(n={...n,allowUntrustedHydration:e.allowUntrustedHydration}),typeof e.allowHydration=="boolean"&&(n={...n,allowUntrustedHydration:e.allowHydration}),typeof e.allowTrustedHydration=="boolean"&&(n={...n,allowUntrustedHydration:e.allowTrustedHydration}),typeof e.mutatorProduce=="function")n={...n,mutatorProduce:e.mutatorProduce};else if(e.mutatorProduce==="immer"){let r=Ye();r?n={...n,mutatorProduce:r}:$||($=true,S(`configureStroid({ mutatorProduce: "immer" }) requires Immer's produce function.
2
+ Call registerMutatorProduce(produce) or pass mutatorProduce: produce directly.`));}typeof e.selectorCloneFrozen=="boolean"&&(n={...n,selectorCloneFrozen:e.selectorCloneFrozen}),F.set(t,n),t===ce()&&(L=I(n));},Xe=()=>{F=new WeakMap,L=I(ue),de=void 0,$=false;};_("config.reset",Xe,90);var Zt=()=>w().namespace;var Ge=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Je=(()=>{if(typeof import.meta>"u")return;let e=Reflect.get(import.meta,"env");if(!e||typeof e!="object")return;let t=Reflect.get(e,"MODE");return typeof t=="string"?t:void 0})(),fe=(()=>{if(typeof globalThis>"u")return;let e=Reflect.get(globalThis,"__STROID_DEV__");return typeof e=="boolean"?e:void 0})(),Qe="production",Ze=Ge??Je??Qe,x=typeof fe=="boolean"?fe:Ze!=="production",T=()=>x,U=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},et=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},tt=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},E=(e,t)=>{if((w().logSink.critical??et)(e,t),w().assertRuntime)throw new Error(e)},y=(e,t)=>{if(!x)return;if((w().logSink.warn??U)(e,t),w().assertRuntime)throw new Error(e)},S=(e,t)=>{if((w().logSink.warn??U)(e,t),w().assertRuntime)throw new Error(e)},R=(e,t)=>{if(x&&(w().logSink.warn??U)(e,t),E(e,t),w().assertRuntime)throw new Error(e)},nt=(e,t)=>{if(!x)return;(w().logSink.log??tt)(e,t);},pe=()=>`Functions cannot be stored in stroid.
3
+ Store data only - handle functions outside the store.`,ye=()=>`Map/Set detected. stroid converts these to plain objects.
4
+ Use arrays or plain objects for best results.`,ge=()=>`Date object detected. stroid stores it as ISO string.
5
+ Use new Date(value) to convert back when reading.`,he=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",me=()=>"Map detected; converting to plain object.",Se=()=>"Set detected; converting to array.",be=(e,t,n)=>`Path depth of ${e} exceeded maximum of ${t}.
6
+ "${n.join(".")}"
7
+ This is a data design issue. Split into separate stores:
8
+ createStore("${n[0]}", ...) and createStore("${n[1]}", ...)`,we=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
9
+ Consider splitting into separate stores for better readability.`,ke=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Re=e=>`Cannot go deeper at "${e}" - value is not an object`,Me=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Ce=e=>`Store name "${e}" contains spaces.
10
+ Use camelCase or kebab-case: "userName" or "user-name"`,Ee=e=>`Store name "${e}" is not allowed.
11
+ Reserved names: "__proto__", "constructor", "prototype".`,rt=128,ot=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=rt,st=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let n=Array.from({length:e.length+1},(o,s)=>s),r=new Array(e.length+1);for(let o=1;o<=t.length;o++){r[0]=o;for(let s=1;s<=e.length;s++)r[s]=t[o-1]===e[s-1]?n[s-1]:Math.min(n[s-1],r[s-1],n[s])+1;[n,r]=[r,n];}return n[e.length]},it=(e,t)=>{let n=t.find(r=>{let o=r.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||ot(o,s)&&st(o,s)<=2});if(n){y(`Store "${e}" not found. Did you mean "${n}"?`);return}R(`Store "${e}" not found.
12
+ Available stores: [${t.join(", ")}]
13
+ Call createStore("${e}", data) first.`);};var g=new Set(["__proto__","constructor","prototype"]),at=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let n=e.safeParse(t);return n.success?{ok:!0,data:n.data}:{ok:!1,error:n.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let n=e.validate(t);if(n===!0)return {ok:!0,data:t};if(n===!1)return {ok:!1,error:e.errors??"Schema validation failed"};if(n&&typeof n=="object"){let o=n.error,s=(()=>{if(!o||typeof o!="object")return null;let i=o.details;if(Array.isArray(i)&&i.length>0){let d=i[0];if(typeof d?.message=="string")return d.message}let a=o.message;return typeof a=="string"?a:null})()??(typeof n.message=="string"?n.message:null)??(typeof e.errors=="string"?e.errors:null);if(s)return {ok:!1,error:s};if(o)return {ok:!1,error:o}}return {ok:!1,error:e.errors??"Schema validation failed"}}if(typeof e=="function"){let n=e(t);return n===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:n===!0?t:n}}return {ok:!0,data:t}}catch(n){return {ok:false,error:n?.message??n}}};var N=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,Ae=e=>{if(!e||typeof e!="object")return null;let t=Reflect.get(globalThis,"WeakRef");return typeof t=="function"&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},ct=e=>{let t=N(e);return t==="function"?(R(pe()),false):t==="map"||t==="set"?(y(ye()),true):(t==="date"&&y(ge()),true)},K=(e,t)=>{let n=Ae(e);if(n)throw new Error(`${n} values are not supported`);let r=N(e);if(r==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(r==="bigint")throw new Error("BigInt values are not supported");if(r==="symbol")throw new Error("Symbol values are not supported");if(r==="date"||r==="map"||r==="set")return false;if(r==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o=Object.keys(e);for(let s of o){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!K(e[s],t))return false;return true}if(r==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let o=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(o)){if(!i.enumerable||g.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!K(i.value,t))return false}return true}return true},ut=e=>K(e,new WeakSet),W=(e,t)=>{let n=Ae(e);if(n)throw new Error(`${n} values are not supported`);let r=N(e);if(r==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(r==="bigint")throw new Error("BigInt values are not supported");if(r==="symbol")throw new Error("Symbol values are not supported");if(r==="date")return T()&&y(he()),e.toISOString();if(r==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),T()&&y(me());let o={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=W(i,t);}return o}if(r==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),T()&&y(Se()),Array.from(e,o=>W(o,t))}if(r==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},s=Object.getOwnPropertyDescriptors(e);for(let[i,a]of Object.entries(s))if(a.enumerable&&!g.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=W(a.value,t);}return o}if(r==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(o=>W(o,t))}return e},lt=e=>W(e,new WeakSet),dt=e=>typeof e!="string"||e.trim()===""?(R(Me(e)),false):g.has(e)?(R(Ee(e)),false):e.includes(" ")?(R(Ce(e)),false):true;var Y=null,ft=()=>{if(Y)return Y;let e,t=[];for(let n=0;n<256;n++){e=n;for(let r=0;r<8;r++)e=e&1?3988292384^e>>>1:e>>>1;t[n]=e>>>0;}return Y=t,t},ve=e=>{let t=ft(),n=-1;for(let r=0;r<e.length;r++)n=n>>>0,n=n>>>8^t[(n^e.charCodeAt(r))&255];return (n^-1)>>>0},pt=2166136261,yt=2654435761,gt=1e5,M=(e,t)=>{let n=t>>>0;e.h1=Math.imul(e.h1^n,2246822507),e.h2=Math.imul(e.h2^n,3266489909);},A=(e,t)=>{M(e,t.length);for(let n=0;n<t.length;n++)M(e,t.charCodeAt(n));},f=(e,t)=>{A(e,t);},Te=(e,t)=>{if(Number.isNaN(t)){f(e,"NaN");return}if(!Number.isFinite(t)){f(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){f(e,"-0");return}let n=t|0;if(t===n){f(e,"int"),M(e,n);return}f(e,"num"),A(e,String(t));},v=(e,t)=>{if(e.nodes++>gt){f(e,"[max]");return}if(t===null){f(e,"null");return}let n=typeof t;if(n==="string"){f(e,"string"),A(e,t);return}if(n==="number"){f(e,"number"),Te(e,t);return}if(n==="boolean"){f(e,t?"true":"false");return}if(n==="undefined"){f(e,"undefined");return}if(n==="bigint"){f(e,"bigint"),A(e,t.toString());return}if(n==="symbol"){f(e,"symbol");let c=t;A(e,Symbol.keyFor(c)??c.description??String(c));return}if(n==="function"){f(e,"function"),A(e,t.name||"anonymous");return}let r=t,o=e.seen.get(r);if(o!==void 0){f(e,"ref"),M(e,o);return}let s=e.nextId++;if(e.seen.set(r,s),Array.isArray(r)){f(e,"array"),M(e,r.length);for(let c=0;c<r.length;c++)Object.prototype.hasOwnProperty.call(r,c)?v(e,r[c]):f(e,"hole");return}if(r instanceof Date){f(e,"date"),Te(e,r.getTime());return}if(r instanceof Map){f(e,"map"),M(e,r.size),r.forEach((c,l)=>{v(e,l),v(e,c);});return}if(r instanceof Set){f(e,"set"),M(e,r.size),r.forEach(c=>{v(e,c);});return}f(e,"object");let i=Object.getPrototypeOf(r);if(i===Object.prototype||i===null){let c=[],l=Object.keys(r);for(let h of l){if(g.has(h))continue;let m=Object.getOwnPropertyDescriptor(r,h);if(m?.enumerable){if("get"in m||"set"in m){c.length=0;break}c.push([h,m.value]);}}if(c.length>0||l.length===0){M(e,c.length);for(let[h,m]of c)A(e,h),v(e,m);return}}let d=Object.getOwnPropertyDescriptors(r),u=[];for(let[c,l]of Object.entries(d))l?.enumerable&&(g.has(c)||"get"in l||"set"in l||u.push([c,l]));M(e,u.length);for(let[c,l]of u)A(e,c),v(e,l.value);},H=e=>{if(typeof e=="string")return ve(JSON.stringify(e));let t={h1:pt,h2:yt,seen:new WeakMap,nextId:1,nodes:0};v(t,e);let n=t.h1>>>0,r=t.h2>>>0;return n^=n>>>16,n=Math.imul(n,2246822507),n^=n>>>13,n=Math.imul(n,3266489909),n^=n>>>16,r^=r>>>16,r=Math.imul(r,668265261),r^=r>>>15,r=Math.imul(r,374761393),r^=r>>>16,(n&2097151)*4294967296+(r>>>0)};var ht=typeof globalThis<"u"&&typeof Reflect.get(globalThis,"structuredClone")=="function",mt=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},n=Object.getOwnPropertyDescriptors(e);return Object.entries(n).forEach(([r,o])=>{o.enumerable&&(g.has(r)||"get"in o||"set"in o||(t[r]=o.value));}),t},X=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=o=>Reflect.get(globalThis,o),n=[["WeakMap",t("WeakMap")],["WeakSet",t("WeakSet")],["WeakRef",t("WeakRef")],["Promise",t("Promise")],["ReadableStream",t("ReadableStream")],["WritableStream",t("WritableStream")],["TransformStream",t("TransformStream")],["EventTarget",t("EventTarget")]];for(let[o,s]of n)if(typeof s=="function"&&e instanceof s)return o;let r=t("Node");return typeof r=="function"&&e instanceof r?"DOM Node":null},St=e=>X(e)===null,bt=e=>{let t=X(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},O=(e,t=new WeakMap)=>{if(bt(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let o=new Map;return t.set(e,o),e.forEach((s,i)=>{o.set(O(i,t),O(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(O(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=O(s,t);}),o}let n={};t.set(e,n);let r;try{r=Object.getOwnPropertyDescriptors(e);}catch(o){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${o?.message??o}`)}return Object.entries(r).forEach(([o,s])=>{!s.enumerable||g.has(o)||"get"in s||"set"in s||(n[o]=O(s.value,t));}),n},p=e=>{if(ht)try{return structuredClone(e)}catch(t){if(!St(e)){let n=X(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${n}). Avoid storing this type in stroid state.`)}return y(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),O(e)}return O(e)},wt=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let n=e,r=t,o=Object.keys(n),s=Object.keys(r);if(o.length!==s.length)return false;for(let i of o)if(!Object.prototype.hasOwnProperty.call(r,i)||!Object.is(n[i],r[i]))return false;return true},kt=(e,t)=>{try{let n=p(e);return t(n),n}catch(n){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${n?.message??n}`)}};var Oe=10,Rt=5,Mt=1024,D=new Map,Ct=e=>{let t=[],n="",r=false;for(let o of e){if(r){n+=o,r=false;continue}if(o==="\\"){r=true;continue}if(o==="."){t.push(n),n="";continue}n+=o;}return r&&(n+="\\"),t.push(n),t},B=e=>{if(Array.isArray(e))return e;if(typeof e=="string"){let t=D.get(e);if(t)return t;let n=!e.includes(".")&&!e.includes("\\")?[e]:Ct(e);if(D.size>=Mt){let r=D.keys().next().value;r&&D.delete(r);}return D.set(e,Object.freeze(n)),n}return [String(e)]},Et=e=>{let t=B(e),n=t.length;return n>Oe?(R(be(n,Oe,t)),false):(n>Rt&&y(we(n,t)),true)},At=(e,t)=>{let n=B(t),r=e;for(let o of n){if(r==null){y(ke(n,o));return}if(typeof r!="object"){y(Re(o));return}r=r[o];}return r},Tt=(e,t,n)=>{let r=B(t);if(r.length===0)return e;for(let s of r)if(g.has(s))return E(`Blocked forbidden path segment "${String(s)}" in setStore path "${r.join(".")}".`),e;if(r.length===1){let s=r[0];if(Array.isArray(e)){let i=Number(s);if(!Number.isInteger(i)||Object.is(e[i],n))return e;let a=[...e];return a[i]=n,a}if(e&&typeof e=="object"){if(g.has(s))return E(`Blocked unsafe path segment "${String(s)}" while setting "${r.join(".")}".`),e;let i=e[s];if(Object.is(i,n))return e;let a=Object.assign({},e);return a[s]=n,a}return e}let o=(s,i)=>{let a=r[i],d=i===r.length-1;if(Array.isArray(s)){let u=Number(a);if(!Number.isInteger(u))return s;let c=[...s];return d?(c[u]=n,c):(c[u]=o(c[u],i+1),c)}if(s&&typeof s=="object"){if(g.has(a))return E(`Blocked unsafe path segment "${String(a)}" while setting "${r.join(".")}".`),s;let u=Object.assign({},s);return d?(u[a]=n,u):(u[a]=o(u[a],i+1),u)}if(s==null&&!d){let u=Number.isInteger(Number(a)),c=u?[]:{};if(u){let l=c,h=Number(a);return l[h]=o(void 0,i+1),l}return c[a]=o(void 0,i+1),c}return d?n:s};return o(e,0)};var z=["effect","storage","network","sync"];var He=e=>{if(!e||typeof e!="object"||Array.isArray(e))return false;let t=Object.getPrototypeOf(e);return t===Object.prototype||t===null},G=(e,t)=>{if(He(e)&&He(t)){let n={};return new Set([...Object.keys(e),...Object.keys(t)]).forEach(o=>{let s=Object.prototype.hasOwnProperty.call(e,o),i=Object.prototype.hasOwnProperty.call(t,o);if(s&&i){n[o]=G(e[o],t[o]);return}if(i){n[o]=p(t[o]);return}n[o]=p(e[o]);}),n}return p(t)},je=(e,t)=>e?.authority??t?.authority??"server-authoritative",xe=(e,t)=>typeof e=="string"?{policy:e}:e&&typeof e=="object"?{policy:e.policy,merge:e.merge,onInvalidate:e.onInvalidate}:t==="client-authoritative"?{policy:"client_wins"}:t==="mergeable"?{policy:"merge"}:{policy:"server_wins"},P=e=>(e.sequence>=Number.MAX_SAFE_INTEGER&&(e.sequence=0),e.sequence+=1,e.sequence),We=e=>({...e.snapshotVersion!==void 0?{snapshotVersion:e.snapshotVersion}:{},...e.timestamp!==void 0?{timestamp:e.timestamp}:{},...e.checksum!==void 0?{checksum:e.checksum}:{},...e.schemaSignature!==void 0?{schemaSignature:e.schemaSignature}:{}}),De=(e,t)=>{if(e.events.push(t),e.events.length>e.maxEvents&&e.events.splice(0,e.events.length-e.maxEvents),!!e.onDrift)try{e.onDrift(t);}catch(n){S(`hydrateStores(...) consistency.onDrift threw: ${n?.message??n}`);}},Pe=(e,t)=>{S(`hydrateStores(...) consistency invalidation handler for "${e}" threw: ${t?.message??t}`);};var Q=()=>({stores:Object.create(null),events:[],metrics:{driftEvents:0,queuedWrites:0,replayedWrites:0,reconciliations:0,invalidations:0},queue:[],onDrift:null,maxEvents:50,deferSources:new Set(z),bootWindowMode:null,bootWindowActive:false,bootWindowStartedAtMs:null,bootWindowEndsAtMs:null,bootWindowTimer:null,bootWindowToken:null,replaying:false,sequence:0}),V=e=>{e.bootWindowTimer&&(clearTimeout(e.bootWindowTimer),e.bootWindowTimer=null),Object.keys(e.stores).forEach(t=>delete e.stores[t]),e.events.length=0,e.queue.length=0,e.metrics.driftEvents=0,e.metrics.queuedWrites=0,e.metrics.replayedWrites=0,e.metrics.reconciliations=0,e.metrics.invalidations=0,e.onDrift=null,e.maxEvents=50,e.deferSources=new Set(z),e.bootWindowMode=null,e.bootWindowActive=false,e.bootWindowStartedAtMs=null,e.bootWindowEndsAtMs=null,e.bootWindowToken=null,e.replaying=false,e.sequence=0;},_e=e=>{e.bootWindowTimer&&(clearTimeout(e.bootWindowTimer),e.bootWindowTimer=null),e.bootWindowActive=false,e.bootWindowEndsAtMs=null;},vt=e=>{if(!e)return {mode:null,durationMs:null};let t=e.bootWindow;if(t===void 0){let o=Math.max(0,e.bootWindowMs??0);return {mode:o>0?"timer":null,durationMs:o>0?o:null}}let n=typeof t=="string"?{mode:t}:t;if(n.mode==="manual"){let o=typeof n.fallbackMs=="number"?Math.max(0,n.fallbackMs):null;return {mode:"manual",durationMs:o!==null&&o>0?o:null}}let r=Math.max(0,n.ms??e.bootWindowMs??0);return {mode:r>0?"timer":null,durationMs:r>0?r:null}},Fe=e=>{let t=e.hydration,n=t.bootWindowMode,r=t.bootWindowToken;return !n||r===null?null:{mode:n,get startedAtMs(){return t.bootWindowToken===r?t.bootWindowStartedAtMs:null},get endsAtMs(){return t.bootWindowToken===r?t.bootWindowEndsAtMs:null},close:()=>{t.bootWindowToken===r&&Z(e);},isActive:()=>t.bootWindowToken===r&&t.bootWindowActive}},Ot=(e,t,n)=>{let r=e.hydration;if(V(r),!n)return null;r.onDrift=n.onDrift,r.maxEvents=Math.max(1,n.maxEvents??50),r.deferSources=new Set(n.deferSources??z);let o=n.contract,s=n.policyMap??{},i=Date.now(),a=new Date(i).toISOString();Object.entries(t).forEach(([u,c])=>{let l=o?.stores?.[u],h=je(l,o),m=xe(s[u],h),j=p(c),b=H(j);r.stores[u]={store:u,authority:h,policy:m.policy,baseline:j,baselineHash:b,hydratedAt:a,hydratedAtMs:i,firstDivergedAt:null,firstDivergedAtMs:null,lastDivergedAt:null,lastDivergedAtMs:null,lastResolution:"stable",lastSource:"hydrate",driftCount:0,queuedWrites:0,replayedWrites:0,invalidatedAt:null,invalidatedAtMs:null,currentHash:b,merge:m.merge,onInvalidate:m.onInvalidate,snapshotVersion:l?.snapshotVersion??o?.snapshotVersion,timestamp:l?.timestamp??o?.timestamp,checksum:l?.checksum??o?.checksum,schemaSignature:l?.schemaSignature??o?.schemaSignature};});let d=vt(n);return d.mode?(r.bootWindowMode=d.mode,r.bootWindowActive=true,r.bootWindowStartedAtMs=i,r.bootWindowEndsAtMs=d.durationMs!==null?i+d.durationMs:null,r.bootWindowToken=P(r),d.durationMs!==null&&typeof setTimeout=="function"&&(r.bootWindowTimer=setTimeout(()=>{Z(e);},d.durationMs)),Fe(e)):null},Ht=(e,t,n)=>{let r=e.hydration;return r.replaying||!r.bootWindowActive||!r.deferSources.has(n)?false:!!r.stores[t]},jt=(e,t,n,r)=>{let o=e.hydration;o.queue.push({id:P(o),store:t,source:n,enqueuedAtMs:Date.now(),apply:r}),o.metrics.queuedWrites+=1;let s=o.stores[t];s&&(s.queuedWrites+=1,s.lastSource=n);},Z=e=>{let t=e.hydration;if(_e(t),!(t.replaying||t.queue.length===0)){t.replaying=true;try{let n=t.queue.splice(0,t.queue.length).sort((r,o)=>r.id-o.id);for(let r of n){t.metrics.replayedWrites+=1;let o=t.stores[r.store];o&&(o.replayedWrites+=1,o.lastSource=r.source),r.apply();}}finally{t.replaying=false;}}};var k=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof ArrayBuffer){let s=e.slice(0);return t.set(e,s),s}let n=globalThis.SharedArrayBuffer;if(n&&e instanceof n){let s=e,i=new n(s.byteLength);new Uint8Array(i).set(new Uint8Array(s));let a=i;return t.set(e,a),a}if(ArrayBuffer.isView(e)){if(e instanceof DataView){let a=e,d=new ArrayBuffer(a.byteLength);new Uint8Array(d).set(new Uint8Array(a.buffer,a.byteOffset,a.byteLength));let u=new DataView(d);return t.set(e,u),u}let s=e,i=new s.constructor(e);return t.set(e,i),i}if(e instanceof Date){let s=new Date(e.getTime());return t.set(e,s),s}if(e instanceof RegExp){let s=new RegExp(e.source,e.flags);return t.set(e,s),s}if(e instanceof Map){let s=new Map;return t.set(e,s),e.forEach((i,a)=>{s.set(k(a,t),k(i,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(i=>{s.add(k(i,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((i,a)=>{s[a]=k(i,t);}),s}let r=e,o=Object.create(Object.getPrototypeOf(r));return t.set(r,o),Reflect.ownKeys(r).forEach(s=>{if(typeof s=="string"&&g.has(s))return;let i=Object.getOwnPropertyDescriptor(r,s);i?.enumerable&&("get"in i||"set"in i||(o[s]=k(i.value,t)));}),o};var xt=(e,t)=>{let n=e.hydration.stores[t];return n?k(n):null},Wt=e=>Object.values(e.hydration.stores).map(t=>k(t)),Dt=(e,t)=>{let n=e.hydration.events;return (typeof t=="number"&&t>=0?n.slice(Math.max(0,n.length-t)):n).map(o=>k(o))},Pt=e=>k({...e.hydration.metrics,pendingWrites:e.hydration.queue.length,bootWindowActive:e.hydration.bootWindowActive,bootWindowMode:e.hydration.bootWindowMode,bootWindowEndsAtMs:e.hydration.bootWindowEndsAtMs,manualCloseAvailable:e.hydration.bootWindowMode==="manual"});var _t=e=>{let t=e.registry.hydration.stores[e.store];if(!t)return {value:e.value,event:null,invalidated:false,needsRefetch:false};let n=t.baselineHash,r=H(e.value);if(t.lastSource=e.source,t.currentHash=r,t.policy==="invalidate_and_refetch"&&e.source==="network")return t.baseline=p(e.value),t.baselineHash=r,t.currentHash=r,t.invalidatedAt=null,t.invalidatedAtMs=null,t.lastResolution="stable",{value:e.value,event:null,invalidated:false,needsRefetch:false};if(r===n)return t.lastResolution="stable",t.invalidatedAt=null,t.invalidatedAtMs=null,{value:e.value,event:null,invalidated:false,needsRefetch:false};let o=Date.now(),s=new Date(o).toISOString();t.firstDivergedAtMs===null&&(t.firstDivergedAtMs=o,t.firstDivergedAt=s),t.lastDivergedAtMs=o,t.lastDivergedAt=s,t.driftCount+=1,e.registry.hydration.metrics.driftEvents+=1;let i=e.value,a="client_kept",d=false,u=false;if(t.policy==="server_wins")i=p(t.baseline),a="server_reverted";else if(t.policy==="merge")try{i=t.merge?t.merge({store:e.store,baseline:p(t.baseline),live:p(e.value),source:e.source}):G(t.baseline,e.value),a="merged";}catch(b){S(`hydrateStores(...) consistency merge for "${e.store}" threw: ${b?.message??b}. Falling back to the hydrated baseline.`),i=p(t.baseline),a="server_reverted";}else t.policy==="invalidate_and_refetch"&&(d=true,u=true,t.invalidatedAtMs=o,t.invalidatedAt=s,e.registry.hydration.metrics.invalidations+=1,a="invalidated");if(e.normalize&&(a==="merged"||a==="server_reverted"))try{let b=e.normalize(i);b.ok?i=b.value:(i=p(t.baseline),a="server_reverted");}catch(b){S(`hydrateStores(...) normalization for "${e.store}" threw during reconciliation: ${b?.message??b}. Falling back to the hydrated baseline.`),i=p(t.baseline),a="server_reverted";}let c=H(i);t.currentHash=c,t.lastResolution=a,e.registry.hydration.metrics.reconciliations+=1;let l=null,h=null,m=null;T()&&(l=p(t.baseline),h=p(e.value),m=Object.is(i,e.value)?h:Object.is(i,t.baseline)?l:p(i));let j={id:`hydration-drift:${o}:${P(e.registry.hydration)}`,store:e.store,source:e.source,authority:t.authority,policy:t.policy,resolution:a,detectedAt:s,detectedAtMs:o,firstDivergedAt:t.firstDivergedAt??s,firstDivergedAtMs:t.firstDivergedAtMs??o,hydratedAt:t.hydratedAt,hydratedAtMs:t.hydratedAtMs,baselineHash:n,liveHash:r,resolvedHash:c,invalidated:d,metadata:We(t),baseline:l,live:h,resolved:m};return De(e.registry.hydration,j),{value:i,event:j,invalidated:d,needsRefetch:u}},Ft=(e,t,n,r)=>{let o=e.hydration.stores[t];if(o?.onInvalidate)try{o.onInvalidate({store:t,baseline:p(o.baseline),live:p(n),source:r});}catch(s){Pe(t,s);}};var ee=new Map,Ie=new WeakSet,It=e=>{Ie.has(e)||(Ie.add(e),d().forEach(t=>{if(!e.featureRuntimes.get(t)){let n=c(t);n&&e.featureRuntimes.set(t,n());}}));},Nt=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Ne,Be=e=>(Ne||Nt||e).replace(/\.ts(\?|$)/,".js$1"),ze=Be("stroid:default-registry"),ce=()=>Ve(ze);var Bt=()=>{Ne=void 0,ee.clear();};_("registry.scope-override",Bt,110);var zt=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Vt=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},$t=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,runtimePatches:[],failed:false,error:void 0}),qt=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,lastRuntimePatches:[],transaction:$t(),async:se(),hydration:Q(),notify:zt(),lifecycleListener:null};return It(t),t},Ve=e=>{let t=Be(e),n=ee.get(t);if(n)return n;let r=qt();return ee.set(t,r),r},Ln=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Un=(e,t)=>e.deletingStores.has(t),Kn=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(n=>{delete t[n];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.runtimePatches.length=0,e.transaction.failed=false,e.transaction.error=void 0,e.lastRuntimePatches.length=0,Vt(e.notify),ie(e.async),V(e.hydration),e.lifecycleListener=null;};var Yn=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var $e=null,Xn=e=>{$e=e;},Gn=()=>$e?.get()||null,te=null,C=[],qe={run:(e,t)=>{C.push(e);try{return t()}finally{C.pop();}},get:()=>C.length>0?C[C.length-1]:null,enterWith:e=>{if(C.length>0){C[C.length-1]=e;return}C.push(e);}},Jn=e=>{te=e;},Qn=(e,t)=>(te??qe).run(e,t),q=e=>(te??qe).get()||e||Ve(ze);var Lt=(e,t,...n)=>{if(typeof e=="function")try{e(...n);}catch(r){let o=r?.message??r;S(`${t} callback threw: ${String(o)}`);}},tr=(e,t={})=>{let{severity:n="warn",visibility:r="dev",onError:o}=t;if(Lt(o,"onError",e),n==="critical"){r==="dev"&&y(e),E(e);return}if(r==="always"){S(e);return}y(e);};export{Tt as $,Ln as A,Un as B,Kn as C,Yn as D,Xn as E,Gn as F,Jn as G,Qn as H,q as I,w as J,Qt as K,Zt as L,T as M,E as N,y as O,S as P,R as Q,nt as R,it as S,H as T,mt as U,p as V,wt as W,kt as X,B as Y,Et as Z,At as _,_ as a,Lt as aa,Kt as b,tr as ba,ie as c,Ot as d,Ht as e,jt as f,g,at as h,N as i,ct as j,ut as k,lt as l,dt as m,k as n,xt as o,Wt as p,Dt as q,Pt as r,_t as s,Ft as t,It as u,ze as v,ce as w,$t as x,qt as y,Ve as z};//# sourceMappingURL=chunk-6IBJ7CIK.js.map
14
+ //# sourceMappingURL=chunk-6IBJ7CIK.js.map
@@ -0,0 +1,2 @@
1
+ import {K,I as I$1,G as G$1,U,E,a,b}from'./chunk-X2MKRN7O.js';import {J,V,O,_ as _$1,U as U$1}from'./chunk-6IBJ7CIK.js';var R=e=>I$1(e),W=e=>K(e),A=(e,t)=>{let n=E().subscribers;return n[e]||(n[e]=new Set),n[e].add(t),()=>{n[e]?.delete(t),n[e]?.size===0&&delete n[e];}};var k=new WeakMap,T=new WeakMap,v=e=>{let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(r.has(n))continue;if(r.add(n),n.$$typeof||typeof Element<"u"&&n instanceof Element)return false;let o=Object.getPrototypeOf(n),i=o===Object.prototype||o===null;if(Array.isArray(n)){for(let c of n)c&&typeof c=="object"&&t.push(c);continue}if(!i)return false;let a=n;for(let c in a){if(!Object.prototype.hasOwnProperty.call(a,c))continue;let s=a[c];s&&typeof s=="object"&&t.push(s);}}return true},$=e=>{if(!(e instanceof TypeError))return false;let t=e?.message??String(e);return /read only|readonly|cannot assign|cannot add property|cannot delete property/i.test(t)},h=e=>{let t=G$1[e]?.options?.snapshot;return t==="shallow"||t==="ref"?t:"deep"},M=(e,t)=>e===null||typeof e!="object"||t==="ref"?e:t==="shallow"?U$1(e):V(e),q=(e,t,r)=>{let n=U(e),l=r??h(e);return M(n,l)},I=(e,t)=>{if(e===null||typeof e!="object"||t==="ref")return e;let r=e;if(t==="shallow"){let i=T.get(r);if(i)return i.frozen??U$1(e);let a$1=Object.getPrototypeOf(r);if(!(Array.isArray(r)||a$1===Object.prototype||a$1===null))return T.set(r,{frozen:null}),U$1(e);let s=U$1(e),u=a(s);return T.set(r,{frozen:u}),u}let n=k.get(r);if(n)return n.frozen??V(e);if(!v(r))return k.set(r,{frozen:null}),V(e);let l=V(e),o=b(l);return k.set(r,{frozen:o}),o},B=(e,t,r)=>{let n=U(e),l=r??h(e);return I(n,l)},G=(e,t)=>{let r=new WeakMap,n=new WeakMap,l=new Set,o="\0",i=(s,u)=>{if(!s||typeof s!="object")return s;let f=r.get(s);if(f)return f;let d=new Proxy(s,{get(p,b,O){if(typeof b!="string")return Reflect.get(p,b,O);let V=[...u,b],g=Reflect.get(p,b,O);return (!g||typeof g!="object")&&l.add(V.join(o)),i(g,V)}});return n.set(d,u.join(o)),r.set(s,d),d},a=t(i(e,[])),c=(s,u)=>{if(!s||typeof s!="object"||u.has(s))return;u.add(s);let f=n.get(s);if(f){f&&l.add(f);return}let d=s;for(let p in d)Object.prototype.hasOwnProperty.call(d,p)&&c(d[p],u);};return c(a,new WeakSet),{result:a,deps:Array.from(l,s=>s.split(o))}},H=(e,t,r)=>{let n=e!==null&&typeof e=="object",l=t!==null&&typeof t=="object",o=e,i=t;for(let a=0;a<r.length;a+=1){let c=r[a];if(c.length===1&&n&&l){let s=c[0];if(!Object.is(o[s],i[s]))return true;continue}if(!Object.is(_$1(e,c),_$1(t,c)))return true}return false},Z=(e,t)=>{let r,n,l=[];return ()=>{let o=W(e);if(o===void 0)return null;if(o===r)return n??null;if(r!==void 0&&l.length>0&&!H(r,o,l))return r=o,n??null;let i=J().selectorCloneFrozen,a=o&&typeof o=="object"&&Object.isFrozen(o)&&i?V(o):o,c=G(a,t);return r=o,l=c.deps,n=c.result,n??null}},_=(e,t,r=Object.is,n)=>{if(typeof t!="function"||typeof n!="function")return O(`subscribeWithSelector("${e}") requires selector and listener functions.`),()=>{};let l=false,o,i=false,a="deep",c=false;if(R(e)){a=h(e),c=true;try{o=t(B(e,void 0,a));}catch(u){if(!$(u))throw u;i=true,o=t(q(e,void 0,a));}l=true;}return A(e,u=>{if(u===null){l=false,o=void 0,c=false;return}if(u===void 0&&!R(e)){l=false,o=void 0,c=false;return}c||(a=h(e),c=true);let f;if(i)f=t(M(u,a));else try{f=t(I(u,a));}catch(p){if(!$(p))throw p;i=true,f=t(M(u,a));}if(!l){let p=o;l=true,o=f,n(f,p);return}if(!r(f,o)){let p=o;o=f,n(f,p);}})};export{Z as a,_ as b};//# sourceMappingURL=chunk-BWNLQKTY.js.map
2
+ //# sourceMappingURL=chunk-BWNLQKTY.js.map
@@ -0,0 +1,2 @@
1
+ import {u}from'./chunk-X2MKRN7O.js';import {I as I$1,c,g}from'./chunk-6IBJ7CIK.js';var a=()=>I$1().async;var B=100,we=100,Y=1e3,$=32,b=e=>g.has(e),p=(e,t)=>{b(t)||delete e[t];},I=(e,t)=>{if(!b(t)&&Object.prototype.hasOwnProperty.call(e,t))return e[t]},d=(e,t)=>b(t)?false:Object.prototype.hasOwnProperty.call(e,t),Q=()=>a().fetchRegistry,C=()=>a().inflight,w=()=>a().requestVersion,h=()=>a().requestSequence,R=()=>a().cacheMeta,m=()=>a().rateWindowStart,q=()=>a().rateCount;var he=()=>a().revalidateHandlers,v=()=>a().storeCleanups,D=()=>a().warnedOnce,xe=()=>a().usageErrorEmissions,Te=()=>a().revalidateKeys,Oe=()=>a().asyncMetrics,N=()=>a().asyncMetricsByStore,A=()=>a().slotOwners,y=()=>a().slotsByStore,F=()=>a().cachePruneCounters,Z=()=>({cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}),Ee=e=>{let t=N(),n=t.get(e);return n||(n=Z(),t.set(e,n)),n},_=(e,t)=>{let n=y(),r=n.get(e);r&&(r.delete(t),r.size===0&&n.delete(e)),A().delete(t);},ee=e=>{let t=C(),n=w(),r=h(),o=R(),s=m(),c=q();return d(t,e)||d(n,e)||d(r,e)||d(o,e)||d(s,e)||d(c,e)},Me=(e,t)=>{let n=A(),r=n.get(t);r&&r!==e&&_(r,t),n.set(t,e);let o=y(),s=o.get(e);s||(s=new Set,o.set(e,s)),s.add(t);},k=e=>{if(ee(e))return;let t=A().get(e);t&&_(t,e);},V=(e,t)=>t===e||t.startsWith(`${e}:`),z=e=>{let t=new Set,n=A(),r=C(),o=w(),s=h(),c=R(),l=m(),i=q();n.forEach((S,f)=>{S===e&&t.add(f);});let u=S=>{S.forEach(f=>{let W=n.get(f);if(W!==void 0){W===e&&t.add(f);return}V(e,f)&&t.add(f);});};u(Object.keys(r)),u(Object.keys(o)),u(Object.keys(s)),u(Object.keys(c)),u(Object.keys(l)),u(Object.keys(i));let g=S=>{d(S,e)&&t.add(e);};return g(r),g(o),g(s),g(c),g(l),g(i),t},Be=e=>{let t=F(),n=(t.get(e)??0)+1;return t.set(e,n),(y().get(e)?.size??0)>B||n>=$},K=e=>{F().delete(e);},te=e=>{let t=D(),n=t.get(e);return n||(n=new Set,t.set(e,n)),n},ne=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=Y))return;let n=e.values().next().value;n!==void 0&&e.delete(n);},ke=(e,t,n)=>{let r=te(e);r.has(t)||(ne(r,t),n());},O=null,E=null,M=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},re=e=>{let t=v(),n=t.get(e);return n||(n=Object.create(null),t.set(e,n)),n},L=e=>e==="revalidate"?"revalidate":"store",x=(e,t)=>t==="revalidate"?e.revalidate:e.store,se=(e,t,n)=>{t==="revalidate"?e.revalidate=n:e.store=n;},U=(e,t)=>{t==="revalidate"?e.revalidate=void 0:e.store=void 0;},X=(e,t)=>{!t.store&&!t.revalidate&&v().delete(e);},G=(e,t)=>{if(t){M(x(e,t)),U(e,t);return}M(e.store),M(e.revalidate),e.store=void 0,e.revalidate=void 0;},oe=e=>{let t=v(),n=t.get(e);n&&(G(n),t.delete(e));},Ke=e=>{let t=v();for(let[n,r]of t)x(r,e)&&(G(r,e),X(n,r));},J=()=>{if(O&&E)return;let e=t=>{oe(t),ie(t);};E||(E=u("storeDeleteCleanup",e)),O||(O=u("afterStoreDelete",e));},be=()=>{c(a());},me=(e,t)=>{if(!t)return false;let n=R(),r=I(n,e);return r?r.expiresAt!==null&&r.expiresAt<=Date.now()?(p(n,e),k(e),false):Date.now()-r.timestamp<t:false},ie=e=>{let t=Q(),n=R(),r=C(),o=w(),s=h(),c=m(),l=q(),i=D();p(t,e),i.get("noSignal")?.delete(e),i.get("shape")?.delete(e),i.get("autoCreate")?.delete(e),i.get("mutableResult")?.delete(e);let u=new Set(y().get(e)??[]);u.size===0&&z(e).forEach(g=>u.add(g)),u.add(e),u.forEach(g=>{p(r,g),p(o,g),p(s,g),p(n,g),p(c,g),p(l,g),_(e,g);}),y().delete(e),N().delete(e),K(e);},qe=e=>{let t=R(),n=w(),r=h(),o=y().get(e)??z(e),s=Date.now(),c=[];if(o.forEach(i=>{let u=I(t,i);if(u){if(u.expiresAt!==null&&u.expiresAt<=s){p(t,i),p(n,i),p(r,i),k(i);return}c.push([i,u]);}}),c.length<=B){K(e);return}c.sort((i,u)=>i[1].timestamp-u[1].timestamp);let l=c.length-B;c.slice(0,l).forEach(([i])=>{p(t,i),p(n,i),p(r,i),k(i);}),K(e);},_e=e=>{let t=C(),n=A(),r=y().get(e);if(r&&r.size>0){let s=0;return r.forEach(c=>{d(t,c)&&(s+=1);}),s}let o=0;return Object.keys(t).forEach(s=>{let c=n.get(s);if(c!==void 0){c===e&&(o+=1);return}V(e,s)&&(o+=1);}),o},We=(e,t,n="store")=>{J();let r=re(e),o=L(n),s=x(r,o);s||(s=new Set,se(r,o,s)),s.add(t);},je=(e,t,n)=>{let o=v().get(e);if(!o)return;let s=c=>{let l=x(o,c);l&&(l.delete(t),l.size===0&&U(o,c));};n?s(L(n)):(s("store"),s("revalidate")),X(e,o);},Pe=e=>{J();};export{Pe as A,a,we as b,Q as c,C as d,w as e,h as f,R as g,m as h,q as i,he as j,xe as k,Te as l,Oe as m,N as n,Ee as o,Me as p,k as q,Be as r,ke as s,Ke as t,be as u,me as v,qe as w,_e as x,We as y,je as z};//# sourceMappingURL=chunk-E33L4MII.js.map
2
+ //# sourceMappingURL=chunk-E33L4MII.js.map
@@ -0,0 +1,2 @@
1
+ var o=e=>typeof e=="string"?e:e.name,n=(e,r)=>{let t=o(e);return r!==void 0?["stroid",t,r]:["stroid",t]},i=n;export{n as a,i as b};//# sourceMappingURL=chunk-FSNVSMAV.js.map
2
+ //# sourceMappingURL=chunk-FSNVSMAV.js.map
@@ -0,0 +1,2 @@
1
+ import {b,a as a$1}from'./chunk-4D6OA3DD.js';import {f}from'./chunk-X2MKRN7O.js';import {M,P}from'./chunk-6IBJ7CIK.js';import {a}from'./chunk-PHE2BCFG.js';var w=1,L=100,ue=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,W=e=>{if(!e)return null;if(e===true)return L;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return L;if(typeof t=="object"){let o=t.windowMs;return typeof o=="number"&&Number.isFinite(o)&&o>0?o:L}return L},le=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,de=({incoming:e,accepted:t})=>{let o=t?.clock??0,i=typeof e.clock=="number"?e.clock:0;if(i!==o)return i-o;let d=e.source??"",y=t?.source??"";return d===y?0:d.localeCompare(y,"en",{sensitivity:"variant"})},ye=e=>e?.updatedAtMs??b({value:e?.updatedAt,fallbackMs:0}),fe=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"};var _=new Set,G=new Set,ge=()=>{_.clear(),G.clear();},pe=({name:e,syncChannels:t,instanceId:o,authToken:i,reportStoreError:d})=>{let y=t[e];if(y)try{let u={v:w,protocol:w,type:"sync-request",source:o,name:e,clock:0,requestedAt:Date.now()};i&&(u.token=i),y.postMessage(u);}catch(u){d(e,`Failed to request sync snapshot for "${e}": ${u?.message??u}`);}},q=({name:e,syncOption:t,syncChannels:o,syncClocks:i,syncVersions:d,syncWindowCleanup:y,instanceId:u,getMeta:v,getAcceptedSyncVersion:S,getStoreValue:b,hasStoreEntry:k,notify:n,validate:r,reportStoreError:c,warn:a,applyIncomingState:C,normalizeIncomingState:R,acceptIncomingSyncVersion:F,resolveSyncVersion:J,broadcastSync:l,markLoopGuard:f$1,hashState:p})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){c(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let g=typeof t=="object"?t.policy:void 0,K=g==="insecure"||g!=="strict"&&typeof t=="object"&&t.insecure===true,Q=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,U=typeof t=="object"&&typeof t.verify=="function",be=typeof t=="object"&&typeof t.sign=="function",X=g==="strict"||!M()&&g!=="insecure";if(X&&!K&&!Q&&!U){c(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!X&&!K&&!Q&&!U&&!_.has(e)&&(_.add(e),P(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),be&&!U&&!G.has(e)&&(G.add(e),a(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let E=typeof t=="object"?t.authToken:void 0,T=W(t),Z=false,ke=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let A=new BroadcastChannel(ke);if(o[e]=A,A.onmessage=M=>{let m=M.data;if(!m||typeof m!="object")return;let O=m;if(O.source===u||O.name!==e||o[e]!==A||!k(e)||!v(e))return;if(!fe(m)){c(e,`Sync message for "${e}" is malformed; ignoring.`);return}let s=m;if(E&&s.token!==E){Z||(c(e,`Sync message for "${e}" failed auth token verification; ignoring.`),Z=!0);return}let x=ue(s);if(x!==w){c(e,`Sync protocol mismatch for "${e}". Expected v${w} but received ${String(x??"unknown")}. Ignoring message.`);return}let ee=s.type==="sync-state";if(ee&&(typeof s.data>"u"||typeof s.clock!="number")){c(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let h=!1;try{h=!!t.verify(s);}catch(V){c(e,`Sync message verification failed for "${e}": ${V?.message??V}`);return}if(!h){c(e,`Sync message for "${e}" failed verification; ignoring.`);return}}let ve=typeof t=="object"&&t.checksum==="none"?"none":"hash";if(ee&&ve!=="none"){let h=p(s.data);if(s.checksum!==h){c(e,`Sync checksum mismatch for "${e}". Expected ${String(h)}, got ${String(s.checksum)}. Ignoring message.`);return}}if(s.type==="sync-request"){l(e);return}let ne=typeof t=="object"?t.conflictResolver:null;if(de({incoming:{clock:s.clock,source:s.source},accepted:S(e)})<=0){let h=ye(v(e)),V=typeof s.updatedAt=="number"?s.updatedAt:Date.now();if(ne){let I;try{I=ne({local:b(e),incoming:s.data,localUpdated:h,incomingUpdated:V});}catch($){c(e,`Sync conflictResolver for "${e}" failed: ${$?.message??$}`);return}if(I!==void 0){let $=R(e,I);if($===null)return;let Ae=b(e),oe=typeof t=="object"?t.resolveUpdatedAt:null,P=Math.max(Date.now(),h,V);if(oe)try{P=oe({localUpdated:h,incomingUpdated:V,now:Date.now()});}catch(re){c(e,`Sync resolveUpdatedAt for "${e}" failed: ${re?.message??re}`);return}let Me=C(e,$,P);J(e,P,typeof s.clock=="number"?s.clock:0),f(e,"sync",Ae,Me,()=>n(e),["sync"]),T&&f$1(e,T),n(e),l(e);}}return}let te=R(e,s.data);if(te===null)return;let we=b(e),Ce=C(e,te,typeof s.updatedAt=="number"?s.updatedAt:Date.now());F(e,typeof s.updatedAt=="number"?s.updatedAt:Date.now(),typeof s.clock=="number"?s.clock:0,typeof s.source=="string"?s.source:""),f(e,"sync",we,Ce,()=>n(e),["sync"]),T&&f$1(e,T),n(e);},typeof window<"u"&&typeof window.addEventListener=="function"){y[e]?.();let M=window,m=()=>{pe({name:e,syncChannels:o,instanceId:u,authToken:E,reportStoreError:c});};M.addEventListener("focus",m),M.addEventListener("online",m),y[e]=()=>{M.removeEventListener("focus",m),M.removeEventListener("online",m);};}queueMicrotask(()=>{pe({name:e,syncChannels:o,instanceId:u,authToken:E,reportStoreError:c});});}catch(A){a(`Failed to setup sync for "${e}": ${A?.message||A}`);}},D=({name:e,syncOption:t,syncChannels:o,syncClocks:i,instanceId:d,updatedAt:y,data:u,hashState:v,reportStoreError:S})=>{let b$1=o[e];if(b$1)try{let k=typeof t=="object"&&t.checksum==="none"?"none":"hash",n={v:w,protocol:w,type:"sync-state",source:d,name:e,clock:i[e]??0,updatedAt:b({value:y,fallbackMs:Date.now()}),data:u,checksum:k==="hash"?v(u):null};if(typeof t=="object"&&t.authToken&&(n.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let a=t.sign(n);if(a&&typeof a.then=="function"){S(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}a!==void 0&&(n.auth=a);}catch(a){S(e,`Failed to sign sync payload for "${e}": ${a?.message??a}`);return}let r=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,c=le(JSON.stringify(n));if(c>r){S(e,`Sync payload for "${e}" exceeds ${r} bytes (${c} bytes). Skipping BroadcastChannel sync.`);return}try{b$1.postMessage(n);}catch(a){if(a&&typeof a=="object"&&a.name==="DataCloneError"){S(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${c} bytes.`);return}throw a}}catch(k){S(e,`Failed to broadcast sync for "${e}": ${k?.message??k}`);}};var B=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),N=(e,t,o)=>(o[e]=Math.max(o[e]??0,t)+1,o[e]),Y=({name:e,syncChannels:t,syncWindowCleanup:o,syncClocks:i,syncVersions:d})=>{t[e]?.close(),delete t[e],o[e]?.(),delete o[e],delete i[e],delete d[e];},H=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(o=>{try{o();}catch{}}),Object.values(e).forEach(o=>{try{o.close();}catch{}});};var Se=false,me=()=>{let e=Object.create(null),t=Object.create(null),o=Object.create(null),i=Object.create(null),d=Object.create(null),y=new Set,u=`stroid_${Math.random().toString(16).slice(2)}`,v=(n,r)=>{o[n]={clock:t[n]??0,updatedAt:b({value:r,fallbackMs:Date.now()}),source:u};},S=(n,r)=>{B(n,t),v(n,r);},b$1=(n,r)=>{!r||!Number.isFinite(r)||(d[n]=Date.now()+r);},k=(n,r)=>{if(!r)return false;let c=d[n];return c?Date.now()>=c?(delete d[n],false):true:false};return {onStoreCreate(n){if(!n.options.sync)return;let r=n.options.sync,c=n.notify,a=typeof r=="object"?r.policy:void 0,C=a==="insecure"||a!=="strict"&&typeof r=="object"&&r.insecure===true,R=typeof r=="object"&&typeof r.authToken=="string"&&r.authToken.length>0,F=typeof r=="object"&&typeof r.verify=="function";if((a==="strict"||!n.isDev()&&a!=="insecure")&&r&&!C&&!R&&!F){n.reportStoreError(`Sync for "${n.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),n.options.sync=false;return}if(q({name:n.name,syncOption:r,syncChannels:e,syncClocks:t,syncVersions:o,syncWindowCleanup:i,instanceId:u,getMeta:n.getMeta,getAcceptedSyncVersion:l=>o[l],getStoreValue:()=>n.getStoreValue(),hasStoreEntry:()=>n.hasStore(),notify:()=>c(),validate:(l,f)=>n.validate(f),reportStoreError:(l,f)=>n.reportStoreError(f),warn:n.warn,applyIncomingState:(l,f,p)=>n.applyFeatureState(f,p,{source:"sync",validate:n.validate}),normalizeIncomingState:(l,f)=>{let p=a$1({value:f,sanitize:n.sanitize,validate:n.validate,onSanitizeError:g=>{n.reportStoreError(`Sanitize failed for incoming sync "${l}": ${g?.message??g}`);}});return p.ok?p.value:null},acceptIncomingSyncVersion:(l,f,p,g)=>{t[n.name]=Math.max(t[n.name]??0,p),o[n.name]={clock:p,updatedAt:f,source:g};},resolveSyncVersion:(l,f,p)=>{let g=N(n.name,p,t);return o[n.name]={clock:g,updatedAt:f,source:u},g},broadcastSync:()=>{let l=n.getMeta();l&&D({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:u,updatedAt:l.updatedAtMs??l.updatedAt,data:n.getStoreValue(),hashState:n.hashState,reportStoreError:(f,p)=>n.reportStoreError(p)});},markLoopGuard:b$1,hashState:n.hashState}),e[n.name]){let l=n.getMeta();v(n.name,l?.updatedAtMs??l?.updatedAt??new Date().toISOString());}},onStoreWrite(n){if(!n.options.sync)return;let r=n.getMeta();if(!r)return;let c=W(n.options.sync);if(k(n.name,c)){S(n.name,r.updatedAtMs??r.updatedAt),y.has(n.name)||(y.add(n.name),n.warn(`Sync broadcast for "${n.name}" suppressed by loopGuard to prevent feedback loops.`));return}S(n.name,r.updatedAtMs??r.updatedAt),D({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:u,updatedAt:r.updatedAtMs??r.updatedAt,data:n.next,hashState:n.hashState,reportStoreError:(a,C)=>n.reportStoreError(C)});},beforeStoreDelete(n){Y({name:n.name,syncChannels:e,syncWindowCleanup:i,syncClocks:t,syncVersions:o}),delete d[n.name],y.delete(n.name);},resetAll(){H({syncChannels:e,syncWindowCleanup:i}),Object.keys(e).forEach(n=>delete e[n]),Object.keys(t).forEach(n=>delete t[n]),Object.keys(o).forEach(n=>delete o[n]),Object.keys(i).forEach(n=>delete i[n]),Object.keys(d).forEach(n=>delete d[n]),ge(),y.clear();}}},he=()=>{Se||(Se=true,a("sync",me));},Ve=()=>{he();};export{Ve as a};//# sourceMappingURL=chunk-GZQGU64H.js.map
2
+ //# sourceMappingURL=chunk-GZQGU64H.js.map
@@ -0,0 +1,13 @@
1
+ import {g,c as c$1,m,o,s,A,v,x,b as b$1,y,z,l as l$1,j,t,n as n$1,u,p,r,w,d,a,h,i,f,e,q,k}from'./chunk-E33L4MII.js';import {c,o as o$1,l,n,x as x$1,t as t$1}from'./chunk-X2MKRN7O.js';import {Q,J,M,O,aa,N as N$1,U,V,W}from'./chunk-6IBJ7CIK.js';var tt=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?U(e):V(e);var $t=50,Dt=512,rt=e=>{let t=k(),n=t.get(e)??0;if(n>=$t)return false;if(n===0&&t.size>=Dt){let r=t.keys().next().value;r!==void 0&&t.delete(r);}return t.set(e,n+1),true};function G(e,t,n,r){if(typeof n=="function")try{n(r);}catch(o){O(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}}var b=(e,t,n)=>J().strictAsyncUsageErrors?Ft(e,t,n):(G(e,"onError",n,t),rt(t)?M()?(Q(t),null):(N$1(t),null):null),Ft=(e,t,n)=>{throw G(e,"onError",n,t),rt(t)&&(M()?Q(t):N$1(t)),new Error(t)};var nt=(e,t)=>Object.is(e,t)?true:!e||!t||typeof e!="object"||typeof t!="object"?false:W(e,t),Pt=(e,t)=>{if(!e||!t)return true;if(e.requestKind!==t.requestKind)return false;if(e.requestKind==="url"){if(e.url!==t.url)return false}else if(!Object.is(e.requestRef,t.requestRef))return false;return e.method===t.method&&e.responseType===t.responseType&&e.stateAdapter===t.stateAdapter&&nt(e.headers,t.headers)&&nt(e.body,t.body)},E=(e$1,t)=>(e()[e$1]??0)===t,ot=(e$1,t)=>{t&&p(t,e$1);let n=f(),r=e(),o=(n[e$1]??0)+1;return n[e$1]=o,r[e$1]=o,o},st=(e$1,t)=>{let n=e();n[e$1]===t&&(delete n[e$1],q(e$1));},it=(e,t,n)=>{n&&p(n,e);let r=d();r[e]=t;},at=e=>{let t=d();delete t[e],q(e);},ct=e=>!!d()[e],ut=(e,t,n,r)=>{let o$1=d()[t];if(o$1)return m().dedupes+=1,o(e).dedupes+=1,Pt(o$1.contract,n.contract)?o$1.transform!==n.transform||o$1.cloneResult!==n.cloneResult?(b(e,`fetchStore("${e}") cannot dedupe callers that use different result contracts for cacheSlot "${t}".`,r),null):o$1.promise:(b(e,`fetchStore("${e}") cannot dedupe callers that use different request or state contracts for cacheSlot "${t}".`,r),null)};var Y=1e3,Ce=100,ft=(e,t)=>{t-e.ratePruneState.lastAt<Y||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(n=>{t-(e.rateWindowStart[n]??0)>Y&&(delete e.rateWindowStart[n],delete e.rateCount[n],q(n));}));},lt=e=>{ft(a(),e);},dt=(e=Y)=>{let t=a();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,ft(t,Date.now());},e));},pt=(e,t,n)=>{n&&p(n,e);let r=h(),o=i(),s=r[e],f=o[e]??0;return s!==void 0&&t-s<Y?f>=Ce?true:(o[e]=f+1,false):(r[e]=t,o[e]=1,false)};var mt=e=>{let t={},n=(e.method??"GET").toUpperCase(),r=e.body!==void 0&&e.body!==null;return e.method&&(t.method=n),e.headers?t.headers=e.headers:(r||!["GET","HEAD","DELETE"].includes(n))&&(t.headers={"Content-Type":"application/json"}),r&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},yt=async(e,t)=>{let n=t??"auto";if(n==="json")return e.json();if(n==="text")return e.text();if(n==="arrayBuffer")return e.arrayBuffer();if(n==="blob")return e.blob();if(n==="formData")return e.formData();let r=e.headers.get("content-type")||"";return r.includes("application/json")||r.includes("+json")?e.json():r.startsWith("text/")||r.includes("xml")||r.includes("html")?e.text():r.includes("form-data")?e.formData():e.arrayBuffer()};var gt=10,Ot=10,ke=3e4,qt=8,St=(e,t)=>new Promise(n=>{if(t?.aborted){n();return}let r=setTimeout(()=>{t?.removeEventListener("abort",o),n();},e),o=()=>{clearTimeout(r),t?.removeEventListener("abort",o),n();};t?.addEventListener("abort",o,{once:true});}),ht=(e,t,n,r)=>Number.isFinite(n)?n:(O(`fetchStore("${e}") received non-finite ${t}; using ${r}.`),r),bt=(e,t,n,r)=>{let o=Number.isFinite(t)?t:t>0?gt:0,s=Math.min(gt,Math.max(0,Math.trunc(o)));Number.isFinite(t)||O(`fetchStore("${e}") received non-finite retry; using ${s}.`);let f=Math.min(ke,Math.max(Ot,ht(e,"retryDelay",n,400))),a=Math.min(qt,Math.max(1,ht(e,"retryBackoff",r,1.7)));return s!==t&&O(`fetchStore("${e}") clamped retry attempts to ${s}.`),f!==n&&O(`fetchStore("${e}") clamped retryDelay to ${f}ms.`),a!==r&&O(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:f,retryBackoff:a}};var Rt=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},ie=e=>e!==null&&(typeof e=="object"||typeof e=="function")&&typeof e.then=="function",wt=(e,t,n$1,r,o)=>{if(!o$1(e))return;let s=r.stateAdapter;if(s){try{let f=n({name:e}),a=m=>{x$1(t,m,void 0,o);};t$1(o,()=>{s({name:e,prev:f,next:n$1,set:a});});}catch(f){O(`fetchStore("${e}") stateAdapter failed: ${f?.message??f}`);}return}t$1(o,()=>{x$1(t,n$1,void 0,o);});},N=(e,t,n,r,o)=>(O(`fetchStore("${e}") aborted`),o(t,n)&&o$1(e)&&r({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function X(e,t,n$1={}){let r$1=c(e);if(!r$1||typeof r$1!="string"){Q("fetchStore requires a store name as first argument");return}let o$2={name:r$1};if(!t){Q(`fetchStore("${r$1}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s$1,onSuccess:f,onError:a,stateAdapter:m$1,method:R,headers:w$1,body:C,ttl:T,staleWhileRevalidate:j=false,dedupe:z$1=true,retry:L=0,retryDelay:W=400,retryBackoff:H=1.7,signal:d,cacheKey:g$1,responseType:h="auto"}=n$1,J$1=g(),$=c$1(),p$1=m(),S=o(r$1),A$1=(()=>{let i=n$1.correlationId,y=n$1.traceContext;return i||y?{correlationId:i,traceContext:y,sourceHint:"network"}:J().autoCorrelationIds?{correlationId:`stroid-${r$1}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:y,sourceHint:"network"}:{sourceHint:"network"}})();!d&&M()&&s("noSignal",r$1,()=>{O(`fetchStore("${r$1}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let c$2=g$1?`${r$1}:${g$1}`:r$1,l$1=i=>wt(r$1,o$2,A$1&&(A$1.correlationId||A$1.traceContext)?{...i,...A$1.correlationId?{correlationId:A$1.correlationId}:{},...A$1.traceContext?{traceContext:A$1.traceContext}:{}}:i,n$1,A$1),Ee=typeof t!="string"&&typeof t!="function"&&ie(t),he=bt(r$1,L,W,H),Te=false,xt=Ee&&L>0,$e=typeof t=="string"?{requestKind:"url",url:t,method:(R??"GET").toUpperCase(),headers:w$1,body:C,responseType:h,stateAdapter:m$1}:typeof t=="function"?{requestKind:"factory",requestRef:t,method:(R??"GET").toUpperCase(),headers:w$1,body:C,responseType:h,stateAdapter:m$1}:{requestKind:"promise",requestRef:t,stateAdapter:m$1},vt=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",Ct=n$1.autoCreate??J().asyncAutoCreate,ae=n$1.cloneResult??J().asyncCloneResult;if(m$1&&!o$1(r$1))return b(r$1,`fetchStore("${r$1}") with stateAdapter requires an existing backing store.
2
+ Call createStore("${r$1}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!o$1(r$1)&&vt)return b(r$1,`fetchStore("${r$1}") cannot create a backing store on the server in production.
3
+ Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!o$1(r$1)){if(!Ct)return b(r$1,`fetchStore("${r$1}") requires an existing backing store when autoCreate is disabled.
4
+ Call createStore("${r$1}", ...) first or enable autoCreate.`,a);if(M()&&s("autoCreate",r$1,()=>{let i=`fetchStore("${r$1}") auto-created its backing store.
5
+ Call createStore("${r$1}", ...) first to avoid typos creating phantom stores.`;aa(a,`fetchStore.onError(${r$1})`,i),O(i);}),l(r$1,{data:null,loading:false,error:null,status:"idle"}),!o$1(r$1))return b(r$1,`fetchStore("${r$1}") could not initialize its backing store.
6
+ On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,a)}if(!m$1){let i=n({name:r$1});if(i&&!Rt(i))return s("shape",r$1,()=>{}),b(r$1,`fetchStore("${r$1}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,a)}A(r$1);let Se=null,F=false,ce=()=>J$1[c$2]?.data??null;if(v(c$2,T)){if(p$1.cacheHits+=1,S.cacheHits+=1,Se=ce(),l$1({data:Se,loading:j,error:null,status:"success",cached:true,revalidating:j}),!j)return Se;F=true;}else p$1.cacheMisses+=1,S.cacheMisses+=1;if(z$1){let i=ut(r$1,c$2,{contract:$e,transform:s$1,cloneResult:ae},a);if(i!==void 0)return i}let De=Date.now();if(lt(De),dt(),pt(c$2,De,r$1))return b(r$1,`fetchStore("${r$1}") rate limited: ${Ce} requests per ${Y}ms window for store "${r$1}".`,a);if(!ct(c$2)&&x(r$1)>=b$1)return b(r$1,`fetchStore("${r$1}") exceeded ${b$1} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let k=ot(c$2,r$1);F||l$1({loading:true,error:null,status:"loading",cached:false,revalidating:false}),p$1.requests+=1,S.requests+=1;let kt=Date.now(),x$1=typeof AbortController<"u"?new AbortController:null,q=x$1?.signal??d,K=null;if(x$1&&d)if(d.aborted)x$1.abort();else {let i=()=>{x$1.signal.aborted||x$1.abort();};d.addEventListener("abort",i,{once:true}),K=()=>{d.removeEventListener("abort",i);};}let be=()=>{K&&(K(),K=null);},ue=x$1?()=>{x$1.signal.aborted||x$1.abort();}:null;ue&&y(r$1,ue),K&&y(r$1,be);let Mt=async()=>{let i=0,y=he.retryDelay;for(;;){if(q?.aborted)return N(r$1,c$2,k,l$1,E);let B=typeof t=="function"?t():t,Oe=Ee||typeof B!="string"&&ie(B),qe=Oe?{...he,retry:0}:he;Oe&&(L>0||xt)&&!Te&&(O(`fetchStore("${r$1}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),Te=true);try{let v;if(typeof B=="string"){let le=mt({...n$1,method:R,headers:w$1,body:C,signal:q}),de=await fetch(B,le);if(!de.ok)throw new Error(`HTTP ${de.status}: ${de.statusText}`);v=await yt(de,h);}else if(ie(B))v=await B;else return Q(`fetchStore("${r$1}") - second argument must be a URL string, Promise, or Promise factory.
7
+ Examples:
8
+ fetchStore("users", "https://api.example.com/users")
9
+ fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(q?.aborted)return N(r$1,c$2,k,l$1,E);let Z=s$1?s$1(v):v;if(ie(Z)){let le=`fetchStore("${r$1}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return E(c$2,k)&&l$1({data:F?ce():null,loading:!1,error:le,status:"error",cached:F,revalidating:!1}),b(r$1,le,a)}ae==="none"&&M()&&Z&&typeof Z=="object"&&s("mutableResult",r$1,()=>{O(`fetchStore("${r$1}") received a mutable object while asyncCloneResult is "none".
10
+ Async data is stored by reference; mutations will affect cache and subscribers.
11
+ Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let P=tt(Z,ae);if(q?.aborted)return N(r$1,c$2,k,l$1,E);if(!E(c$2,k))return null;J$1[c$2]={timestamp:Date.now(),expiresAt:T?Date.now()+T:null,data:P},p(r$1,c$2),r(r$1)&&w(r$1),l$1({data:P,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),G(r$1,"onSuccess",f,P);let fe=Date.now()-kt;return p$1.lastMs=fe,p$1.avgMs=(p$1.avgMs*(p$1.requests-1)+fe)/p$1.requests,S.lastMs=fe,S.avgMs=(S.avgMs*(S.requests-1)+fe)/S.requests,{raw:v,transformed:P}}catch(v){if(i+=1,v?.name==="AbortError")return N(r$1,c$2,k,l$1,E);if(i<=qe.retry){if(q?.aborted)return N(r$1,c$2,k,l$1,E);if(await St(y,q),q?.aborted)return N(r$1,c$2,k,l$1,E);y=Math.min(ke,y*qe.retryBackoff);continue}if(!E(c$2,k))return null;let P=v&&typeof v=="object"&&typeof v.message=="string"?v.message:"Something went wrong";return l$1({data:F?ce():null,loading:false,error:P,status:"error",cached:F,revalidating:false}),G(r$1,"onError",a,P),p$1.failures+=1,S.failures+=1,O(`fetchStore("${r$1}") failed: ${P}`),null}}},Q$1=null,Et=new Promise((i,y)=>{d||(Q$1=setTimeout(()=>{Q$1=null,x$1&&!x$1.signal.aborted&&x$1.abort(),y(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),Fe=Promise.race([Mt().finally(()=>{Q$1&&(clearTimeout(Q$1),Q$1=null);}),Et]).catch(i=>{let y=i&&typeof i=="object"&&typeof i.message=="string"?i.message:"Request timed out";return l$1({data:F?ce():null,loading:false,error:y,status:"error",cached:F,revalidating:false}),G(r$1,"onError",a,y),p$1.failures+=1,S.failures+=1,O(`fetchStore("${r$1}") failed: ${y}`),null}),Pe=Fe.then(i=>i?.transformed??null).finally(()=>{at(c$2),st(c$2,k),ue&&z(r$1,ue),K&&z(r$1,be),be();}),Tt=Fe.then(i=>i?.raw);return it(c$2,{promise:Pe,raw:Tt,transform:s$1,cloneResult:ae,contract:$e},r$1),typeof t=="function"?$[r$1]={kind:"factory",factory:t,options:{...n$1,cacheKey:g$1}}:typeof t=="string"?$[r$1]={kind:"url",url:t,options:{...n$1,cacheKey:g$1}}:delete $[r$1],Pe}async function At(e){let t=c(e);if(!o$1(t))return;let r=c$1()[t];if(!r){let s=`${t}:`,f=g(),a=Object.entries(f).filter(([m])=>m===t||m.startsWith(s));if(a.length>0){let[,m]=a.reduce((R,w)=>w[1].timestamp>=R[1].timestamp?w:R);return m.data}M()&&O(`refetchStore("${t}") - no previous fetch found.
12
+ Call fetchStore("${t}", url) first.`);return}let o={name:t};return r.kind==="factory"?X(o,r.factory,r.options):X(o,r.url,r.options)}function It(e,t){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let n=l$1(),r=j(),s=(e==="*"?"*":e?c(e):void 0)??"*";if(n.has(s))return r[s]??(()=>{});let f=J().revalidateOnFocus,a=Math.max(0,t?.debounceMs??f.debounceMs),m=Math.max(1,t?.maxConcurrent??f.maxConcurrent),R=Math.max(0,t?.staggerMs??f.staggerMs),w=null,C=false,T=new Set,j$1=d=>{d!==null&&(clearTimeout(d),T.delete(d));},z$1=(d,g)=>{let h=setTimeout(()=>{T.delete(h),!C&&d();},g);return T.add(h),h},L=()=>{if(C)return;let d=c$1(),g=s==="*"?Object.keys(d):[s];if(t?.priority==="high"&&s!=="*"&&(g=[s,...g.filter($=>$!==s)]),g.length===0)return;let h=0,J=()=>{if(C)return;let $=g.slice(h,h+m);if($.forEach((p,S)=>{let A=()=>{if(C)return;let l=c$1()[p];if(!l){At({name:p});return}l.kind==="factory"?X({name:p},l.factory,l.options):X({name:p},l.url,l.options);};R>0?z$1(A,S*R):A();}),h+=$.length,h<g.length){let p=R>0?R*Math.max(1,$.length):0;z$1(J,p);}};J();},W=()=>{if(!C){if(a===0){L();return}j$1(w),w=z$1(L,a);}};window.addEventListener("focus",W),window.addEventListener("online",W),n.add(s);let H=()=>{C=true,window.removeEventListener("focus",W),window.removeEventListener("online",W),j$1(w),w=null,T.forEach(d=>clearTimeout(d)),T.clear(),n.delete(s),delete r[s],z(s,H,"revalidate");};return r[s]=H,y(s,H,"revalidate"),H}var Me=()=>{t("revalidate");};function _t(e){if(!e)return {...m()};let t=n$1().get(e);return t?{...t}:null}var Tr=()=>{Me(),u();};export{X as a,At as b,It as c,Me as d,_t as e,Tr as f};//# sourceMappingURL=chunk-LWUT37FW.js.map
13
+ //# sourceMappingURL=chunk-LWUT37FW.js.map