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.
- package/CHANGELOG.md +148 -34
- package/README.md +124 -17
- package/dist/async-internal.d.ts +30 -0
- package/dist/async.d.ts +7 -12
- package/dist/async.js +1 -1
- package/dist/chunk-4C666HHU.js +2 -0
- package/dist/chunk-4D6OA3DD.js +2 -0
- package/dist/chunk-6IBJ7CIK.js +14 -0
- package/dist/chunk-BWNLQKTY.js +2 -0
- package/dist/chunk-E33L4MII.js +2 -0
- package/dist/chunk-FSNVSMAV.js +2 -0
- package/dist/chunk-GZQGU64H.js +2 -0
- package/dist/chunk-LWUT37FW.js +13 -0
- package/dist/chunk-NFT6AZXY.js +2 -0
- package/dist/chunk-PHE2BCFG.js +2 -0
- package/dist/chunk-SF6EP56S.js +2 -0
- package/dist/chunk-WE3ZR6OG.js +2 -0
- package/dist/chunk-WXJ3IREA.js +2 -0
- package/dist/chunk-X2MKRN7O.js +14 -0
- package/dist/chunk-Y54SMROI.js +2 -0
- package/dist/computed.d.ts +6 -5
- package/dist/computed.js +1 -1
- package/dist/core-internal.d.ts +23 -0
- package/dist/core.d.ts +3 -2
- package/dist/core.js +1 -1
- package/dist/devtools-internal.d.ts +26 -0
- package/dist/devtools.d.ts +4 -25
- package/dist/devtools.js +1 -1
- package/dist/feature.d.ts +9 -2
- package/dist/feature.js +1 -1
- package/dist/fetch-4RH6MPY3.js +2 -0
- package/dist/graph-D28.d.ts +20 -0
- package/dist/helpers.d.ts +2 -1
- package/dist/helpers.js +1 -1
- package/dist/index-internal.d.ts +19 -19
- package/dist/index.d.cts +40 -22
- package/dist/index.d.ts +40 -22
- package/dist/index.js +1 -1
- package/dist/install.d.ts +16 -4
- package/dist/install.js +1 -1
- package/dist/metrics.d.ts +13 -0
- package/dist/persist.d.ts +3 -1
- package/dist/persist.js +1 -1
- package/dist/psr.d.ts +7 -8
- package/dist/psr.js +1 -1
- package/dist/query.d.ts +17 -0
- package/dist/query.js +2 -0
- package/dist/react/index.d.ts +10 -3
- package/dist/react/index.js +5 -5
- package/dist/registry.d.ts +22 -14
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-tools.d.ts +38 -65
- package/dist/runtime-tools.js +1 -1
- package/dist/selectors.d.ts +1 -1
- package/dist/selectors.js +1 -1
- package/dist/server/portable.d.ts +27 -0
- package/dist/server/portable.js +2 -0
- package/dist/server.d.ts +9 -20
- package/dist/server.js +1 -1
- package/dist/shared.d.ts +36 -0
- package/dist/store-registry.d.ts +3 -1
- package/dist/sync.d.ts +10 -1
- package/dist/sync.js +1 -1
- package/dist/testing.d.ts +1 -0
- package/dist/testing.js +1 -1
- package/dist/tsdoc-metadata.json +11 -0
- package/dist/types-internal-2.d.ts +168 -0
- package/dist/{computed-types.d.ts → types-internal-3.d.ts} +1 -1
- package/dist/{options.d.ts → types-internal.d.ts} +25 -9
- package/dist/types.d.ts +12 -2
- package/package.json +80 -26
- package/dist/chunk-645IESIU.js +0 -2
- package/dist/chunk-6ELWGQ4Q.js +0 -2
- package/dist/chunk-BW32TJGE.js +0 -13
- package/dist/chunk-FOQKGHPS.js +0 -26
- package/dist/chunk-KQCSFGHJ.js +0 -2
- package/dist/chunk-M2NJVI36.js +0 -2
- package/dist/chunk-PVATWAY4.js +0 -2
- package/dist/chunk-X3JR32JD.js +0 -2
- package/dist/computed-types.js +0 -2
- package/dist/types/adapters/options.d.ts +0 -335
- package/dist/types/async/cache.d.ts +0 -40
- package/dist/types/async/clone.d.ts +0 -10
- package/dist/types/async/errors.d.ts +0 -3
- package/dist/types/async/fetch.d.ts +0 -37
- package/dist/types/async/inflight.d.ts +0 -30
- package/dist/types/async/rate.d.ts +0 -5
- package/dist/types/async/registry.d.ts +0 -117
- package/dist/types/async/request.d.ts +0 -11
- package/dist/types/async/retry.d.ts +0 -10
- package/dist/types/async.d.ts +0 -10
- package/dist/types/computed/computed-graph.d.ts +0 -33
- package/dist/types/computed/index.d.ts +0 -21
- package/dist/types/computed/types.d.ts +0 -40
- package/dist/types/config.d.ts +0 -10
- package/dist/types/core/index.d.ts +0 -11
- package/dist/types/core/lifecycle-hooks.d.ts +0 -16
- package/dist/types/core/runtime-patch.d.ts +0 -67
- package/dist/types/core/store-admin-impl.d.ts +0 -9
- package/dist/types/core/store-admin.d.ts +0 -9
- package/dist/types/core/store-core.d.ts +0 -13
- package/dist/types/core/store-create.d.ts +0 -16
- package/dist/types/core/store-hydrate-impl.d.ts +0 -35
- package/dist/types/core/store-hydrate.d.ts +0 -9
- package/dist/types/core/store-lifecycle/hooks.d.ts +0 -20
- package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
- package/dist/types/core/store-lifecycle/registry.d.ts +0 -54
- package/dist/types/core/store-lifecycle/types.d.ts +0 -67
- package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
- package/dist/types/core/store-name.d.ts +0 -28
- package/dist/types/core/store-notify.d.ts +0 -13
- package/dist/types/core/store-read.d.ts +0 -18
- package/dist/types/core/store-registry.d.ts +0 -115
- package/dist/types/core/store-replace-impl.d.ts +0 -11
- package/dist/types/core/store-replace.d.ts +0 -9
- package/dist/types/core/store-set-impl.d.ts +0 -13
- package/dist/types/core/store-set.d.ts +0 -9
- package/dist/types/core/store-shared/core.d.ts +0 -13
- package/dist/types/core/store-shared/notify.d.ts +0 -12
- package/dist/types/core/store-transaction.d.ts +0 -28
- package/dist/types/core/store-write-shared.d.ts +0 -25
- package/dist/types/core/store-write.d.ts +0 -13
- package/dist/types/features/feature-registry.d.ts +0 -91
- package/dist/types/features/lifecycle.d.ts +0 -40
- package/dist/types/index.d.ts +0 -17
- package/dist/types/integrations/query.d.ts +0 -8
- package/dist/types/internals/computed-order.d.ts +0 -3
- package/dist/types/internals/config.d.ts +0 -116
- package/dist/types/internals/diagnostics.d.ts +0 -21
- package/dist/types/internals/reporting.d.ts +0 -9
- package/dist/types/internals/store-admin.d.ts +0 -7
- package/dist/types/internals/store-ops.d.ts +0 -13
- package/dist/types/internals/test-reset.d.ts +0 -2
- package/dist/types/internals/write-context.d.ts +0 -20
- package/dist/types/notification/delivery.d.ts +0 -3
- package/dist/types/notification/index.d.ts +0 -10
- package/dist/types/notification/metrics.d.ts +0 -12
- package/dist/types/notification/priority.d.ts +0 -9
- package/dist/types/notification/scheduler.d.ts +0 -11
- package/dist/types/notification/snapshot.d.ts +0 -8
- package/dist/types/runtime-admin/index.d.ts +0 -2
- package/dist/types/runtime-tools/index.d.ts +0 -63
- package/dist/types/store.d.ts +0 -16
- package/dist/types/types/utility.d.ts +0 -17
- package/dist/types/utils/clone.d.ts +0 -4
- package/dist/types/utils/devfreeze.d.ts +0 -2
- package/dist/types/utils/hash.d.ts +0 -8
- package/dist/types/utils/path.d.ts +0 -5
- package/dist/types/utils/validation.d.ts +0 -14
- 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/
|
|
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
|
-
|
|
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(
|
|
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 (
|
|
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 {
|
|
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
|
-
|
|
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,
|
|
37
|
+
export { FetchInput, FetchOptions, _resetAsyncStateForTests, enableRevalidateOnFocus, fetchStore, refetchStore };
|
package/dist/async.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import'./chunk-YU5GMPCC.js';export{
|
|
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 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
|
+
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
|