@rpcbase/client 0.381.0 → 0.382.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -4
- package/dist/index.js.map +1 -1
- package/dist/initWithRoutes.d.ts.map +1 -1
- package/dist/rts/index.d.ts +1 -1
- package/dist/rts/index.d.ts.map +1 -1
- package/dist/rts/index.js +2 -3
- package/dist/rts/ssrHydration.d.ts +2 -6
- package/dist/rts/ssrHydration.d.ts.map +1 -1
- package/dist/rts/useQuery.d.ts.map +1 -1
- package/dist/rts/wsClient.d.ts +1 -0
- package/dist/rts/wsClient.d.ts.map +1 -1
- package/dist/{useQuery-n0OatV-X.js → useQuery-CalZ2p2a.js} +22 -44
- package/dist/useQuery-CalZ2p2a.js.map +1 -0
- package/package.json +1 -1
- package/dist/useQuery-n0OatV-X.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"initWithRoutes.d.ts","sourceRoot":"","sources":["../src/initWithRoutes.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAmC,MAAM,OAAO,CAAA;AAClE,OAAO,EAEL,wBAAwB,EAGzB,MAAM,iBAAiB,CAAA;AAQxB,OAAO,EAGL,oBAAoB,EACrB,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"initWithRoutes.d.ts","sourceRoot":"","sources":["../src/initWithRoutes.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAmC,MAAM,OAAO,CAAA;AAClE,OAAO,EAEL,wBAAwB,EAGzB,MAAM,iBAAiB,CAAA;AAQxB,OAAO,EAGL,oBAAoB,EACrB,MAAM,iBAAiB,CAAA;AA0GxB,KAAK,qBAAqB,GAAG;IAC3B,0BAA0B,CAAC,EAAE,OAAO,CAAA;IACpC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,SAAS,CAAA;CAC9D,CAAA;AAED,KAAK,aAAa,GAAG,UAAU,CAAC,OAAO,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAA;AA0CnE,eAAO,MAAM,cAAc,GACzB,eAAe,aAAa,EAC5B,OAAO,qBAAqB,kBAsF7B,CAAA"}
|
package/dist/rts/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export { configureRtsPouchStore, destroyAllCollections, destroyCollection, deleteDocs, getCollection, resetRtsPouchStore, runQuery, updateDocs, type RtsPouchQueryContext, type RtsPouchQueryOptions, type RtsPouchStoreConfig, } from './pouchStore';
|
|
2
2
|
export { addLocalTxn, connect, disconnect, onMessage, reconnect, registerQuery, sendMessage, syncRtsChanges, type RtsConnectOptions, type RtsQueryContext, type RtsQueryOptions, } from './wsClient';
|
|
3
|
-
export { hydrateRtsFromWindow, clearHydratedRtsQueryData, peekHydratedRtsQueryData,
|
|
3
|
+
export { hydrateRtsFromWindow, clearHydratedRtsQueryData, peekHydratedRtsQueryData, RtsSsrRuntimeProvider, STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY, type RtsSsrHydrationQueryData, type RtsSsrQueryRegistration, type RtsSsrRuntime, type StaticRpcbaseRtsHydrationData, } from './ssrHydration';
|
|
4
4
|
export { type RtsModelMap, type RtsModelName, } from './modelTypes';
|
|
5
5
|
export { useQuery, type UseRtsQueryOptions, type UseRtsQueryResult, } from './useQuery';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/rts/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rts/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,iBAAiB,EACjB,UAAU,EACV,aAAa,EACb,kBAAkB,EAClB,QAAQ,EACR,UAAU,EACV,KAAK,oBAAoB,EACzB,KAAK,oBAAoB,EACzB,KAAK,mBAAmB,GACzB,MAAM,cAAc,CAAA;AAErB,OAAO,EACL,WAAW,EACX,OAAO,EACP,UAAU,EACV,SAAS,EACT,SAAS,EACT,aAAa,EACb,WAAW,EACX,cAAc,EACd,KAAK,iBAAiB,EACtB,KAAK,eAAe,EACpB,KAAK,eAAe,GACrB,MAAM,YAAY,CAAA;AAEnB,OAAO,EACL,oBAAoB,EACpB,yBAAyB,EACzB,wBAAwB,EACxB
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rts/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,iBAAiB,EACjB,UAAU,EACV,aAAa,EACb,kBAAkB,EAClB,QAAQ,EACR,UAAU,EACV,KAAK,oBAAoB,EACzB,KAAK,oBAAoB,EACzB,KAAK,mBAAmB,GACzB,MAAM,cAAc,CAAA;AAErB,OAAO,EACL,WAAW,EACX,OAAO,EACP,UAAU,EACV,SAAS,EACT,SAAS,EACT,aAAa,EACb,WAAW,EACX,cAAc,EACd,KAAK,iBAAiB,EACtB,KAAK,eAAe,EACpB,KAAK,eAAe,GACrB,MAAM,YAAY,CAAA;AAEnB,OAAO,EACL,oBAAoB,EACpB,yBAAyB,EACzB,wBAAwB,EACxB,qBAAqB,EACrB,qCAAqC,EACrC,KAAK,wBAAwB,EAC7B,KAAK,uBAAuB,EAC5B,KAAK,aAAa,EAClB,KAAK,6BAA6B,GACnC,MAAM,gBAAgB,CAAA;AAEvB,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,YAAY,GAClB,MAAM,cAAc,CAAA;AAErB,OAAO,EACL,QAAQ,EACR,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,GACvB,MAAM,YAAY,CAAA"}
|
package/dist/rts/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { R, S, f, n, c, h, b, d, a, i, g, m, o, p, j, k, r,
|
|
1
|
+
import { R, S, f, n, c, h, b, d, a, i, g, m, o, p, j, k, r, e, s, l, u, q } from "../useQuery-CalZ2p2a.js";
|
|
2
2
|
export {
|
|
3
3
|
R as RtsSsrRuntimeProvider,
|
|
4
4
|
S as STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY,
|
|
@@ -17,11 +17,10 @@ export {
|
|
|
17
17
|
j as reconnect,
|
|
18
18
|
k as registerQuery,
|
|
19
19
|
r as resetRtsPouchStore,
|
|
20
|
-
q as resolveRtsHydrationIdentityFromStaticRouterData,
|
|
21
20
|
e as runQuery,
|
|
22
21
|
s as sendMessage,
|
|
23
22
|
l as syncRtsChanges,
|
|
24
23
|
u as updateDocs,
|
|
25
|
-
|
|
24
|
+
q as useQuery
|
|
26
25
|
};
|
|
27
26
|
//# sourceMappingURL=index.js.map
|
|
@@ -14,10 +14,6 @@ export type StaticRpcbaseRtsHydrationData = {
|
|
|
14
14
|
uid: string | null;
|
|
15
15
|
queries: RtsSsrHydrationQueryData[];
|
|
16
16
|
};
|
|
17
|
-
export type RtsSsrIdentity = {
|
|
18
|
-
tenantId: string | null;
|
|
19
|
-
uid: string | null;
|
|
20
|
-
};
|
|
21
17
|
export type RtsSsrQueryRegistration = {
|
|
22
18
|
modelName: RtsModelName;
|
|
23
19
|
query: JsonObject;
|
|
@@ -28,10 +24,10 @@ export type RtsSsrRuntime = {
|
|
|
28
24
|
registerQuery: (query: RtsSsrQueryRegistration) => void;
|
|
29
25
|
getQueryData: (modelName: RtsModelName, queryKey: string) => unknown[] | undefined;
|
|
30
26
|
};
|
|
31
|
-
export declare const hydrateRtsFromWindow: (
|
|
27
|
+
export declare const hydrateRtsFromWindow: () => void;
|
|
32
28
|
export declare const peekHydratedRtsQueryData: (modelName: RtsModelName, queryKey: string) => unknown[] | undefined;
|
|
29
|
+
export declare const consumeHydratedRtsQueryData: (modelName: RtsModelName, queryKey: string) => void;
|
|
33
30
|
export declare const clearHydratedRtsQueryData: () => void;
|
|
34
|
-
export declare const resolveRtsHydrationIdentityFromStaticRouterData: () => RtsSsrIdentity;
|
|
35
31
|
export declare const RtsSsrRuntimeProvider: ({ value, children, }: {
|
|
36
32
|
value: RtsSsrRuntime;
|
|
37
33
|
children: ReactNode;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ssrHydration.d.ts","sourceRoot":"","sources":["../../src/rts/ssrHydration.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAGjD,KAAK,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEzC,eAAO,MAAM,qCAAqC,oCAAoC,CAAA;AAEtF,MAAM,MAAM,wBAAwB,GAAG;IACrC,SAAS,EAAE,YAAY,CAAA;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,OAAO,EAAE,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,6BAA6B,GAAG;IAC1C,CAAC,EAAE,CAAC,CAAA;IACJ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IAClB,OAAO,EAAE,wBAAwB,EAAE,CAAA;CACpC,CAAA;AAED,MAAM,MAAM,
|
|
1
|
+
{"version":3,"file":"ssrHydration.d.ts","sourceRoot":"","sources":["../../src/rts/ssrHydration.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAGjD,KAAK,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEzC,eAAO,MAAM,qCAAqC,oCAAoC,CAAA;AAEtF,MAAM,MAAM,wBAAwB,GAAG;IACrC,SAAS,EAAE,YAAY,CAAA;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,OAAO,EAAE,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,6BAA6B,GAAG;IAC1C,CAAC,EAAE,CAAC,CAAA;IACJ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IAClB,OAAO,EAAE,wBAAwB,EAAE,CAAA;CACpC,CAAA;AAED,MAAM,MAAM,uBAAuB,GAAG;IACpC,SAAS,EAAE,YAAY,CAAA;IACvB,KAAK,EAAE,UAAU,CAAA;IACjB,OAAO,EAAE,eAAe,CAAA;IACxB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,aAAa,EAAE,CAAC,KAAK,EAAE,uBAAuB,KAAK,IAAI,CAAA;IACvD,YAAY,EAAE,CAAC,SAAS,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,KAAK,OAAO,EAAE,GAAG,SAAS,CAAA;CACnF,CAAA;AAyDD,eAAO,MAAM,oBAAoB,QAAO,IAcvC,CAAA;AAED,eAAO,MAAM,wBAAwB,GACnC,WAAW,YAAY,EACvB,UAAU,MAAM,KACf,OAAO,EAAE,GAAG,SAEd,CAAA;AAED,eAAO,MAAM,2BAA2B,GACtC,WAAW,YAAY,EACvB,UAAU,MAAM,KACf,IAEF,CAAA;AAED,eAAO,MAAM,yBAAyB,QAAO,IAE5C,CAAA;AAED,eAAO,MAAM,qBAAqB,GAAI,sBAGnC;IACD,KAAK,EAAE,aAAa,CAAA;IACpB,QAAQ,EAAE,SAAS,CAAA;CACpB,4CAMA,CAAA;AAED,eAAO,MAAM,gBAAgB,QAAO,aAAa,GAAG,IAEnD,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useQuery.d.ts","sourceRoot":"","sources":["../../src/rts/useQuery.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAGhD,OAAO,KAAK,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAIlE,KAAK,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEzC,MAAM,MAAM,kBAAkB,GAAG,eAAe,GAAG;IACjD,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IACtB,cAAc,CAAC,EAAE,OAAO,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI;IACjC,IAAI,EAAE,CAAC,EAAE,GAAG,SAAS,CAAA;IACrB,MAAM,EAAE,eAAe,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAA;IAC7C,KAAK,EAAE,OAAO,GAAG,SAAS,CAAA;IAC1B,OAAO,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClF,WAAW,YAAY,EACvB,QAAO,UAAe,EACtB,UAAS,kBAAuB,KAC/B,iBAAiB,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"useQuery.d.ts","sourceRoot":"","sources":["../../src/rts/useQuery.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAGhD,OAAO,KAAK,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAIlE,KAAK,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEzC,MAAM,MAAM,kBAAkB,GAAG,eAAe,GAAG;IACjD,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IACtB,cAAc,CAAC,EAAE,OAAO,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI;IACjC,IAAI,EAAE,CAAC,EAAE,GAAG,SAAS,CAAA;IACrB,MAAM,EAAE,eAAe,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAA;IAC7C,KAAK,EAAE,OAAO,GAAG,SAAS,CAAA;IAC1B,OAAO,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClF,WAAW,YAAY,EACvB,QAAO,UAAe,EACtB,UAAS,kBAAuB,KAC/B,iBAAiB,CAAC,CAAC,CA6KrB,CAAA"}
|
package/dist/rts/wsClient.d.ts
CHANGED
|
@@ -48,6 +48,7 @@ export declare const disconnect: () => void;
|
|
|
48
48
|
export declare const reconnect: (tenantId: string, uid: string, options?: RtsConnectOptions) => Promise<void>;
|
|
49
49
|
export declare const registerQuery: (modelName: RtsModelName, query: JsonObject, optionsOrCallback?: RtsQueryOptions | QueryCallback, callbackMaybe?: QueryCallback, behavior?: {
|
|
50
50
|
runInitialNetworkQuery?: boolean;
|
|
51
|
+
runInitialLocalQuery?: boolean;
|
|
51
52
|
}) => (() => void) | undefined;
|
|
52
53
|
export declare const sendMessage: (event: string, payload?: unknown) => void;
|
|
53
54
|
export declare const onMessage: (event: string, callback: (payload: unknown) => void) => (() => void);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wsClient.d.ts","sourceRoot":"","sources":["../../src/rts/wsClient.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAIhD,KAAK,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEzC,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,GAAG,UAAU,CAAA;IAC5B,KAAK,CAAC,EAAE,UAAU,CAAA;IAClB,OAAO,CAAC,EAAE;QACR,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;QAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;KACf,CAAA;IACD,QAAQ,CAAC,EAAE,iBAAiB,CAAA;CAC7B,CAAA;AAED,MAAM,MAAM,iBAAiB,GACzB,MAAM,GACN,iBAAiB,GACjB,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC,CAAA;AAErC,MAAM,MAAM,sBAAsB,GAAG;IACnC,MAAM,EAAE,SAAS,CAAA;IACjB,OAAO,EAAE,OAAO,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAA;AAED,MAAM,MAAM,oBAAoB,GAAG;IACjC,MAAM,EAAE,OAAO,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,eAAe,GAAG,sBAAsB,GAAG,oBAAoB,CAAA;AAE3E,MAAM,MAAM,eAAe,GAAG;IAC5B,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;IAClC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,iBAAiB,CAAA;CAC7B,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,CAAC,EAAE;QACV,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,UAAU,CAAC,EAAE,MAAM,CAAA;KACpB,CAAA;CACF,CAAA;AAED,KAAK,aAAa,GAAG,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,eAAe,KAAK,IAAI,CAAA;AA+M7F,eAAO,MAAM,WAAW,GAAI,OAAO,MAAM,KAAG,IAM3C,CAAA;AA8DD,eAAO,MAAM,cAAc,GAAU,UAAU,MAAM,EAAE,KAAK,MAAM,EAAE,UAAS,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAM,KAAG,OAAO,CAAC,IAAI,CAmElI,CAAA;AA0FD,eAAO,MAAM,OAAO,GAAI,UAAU,MAAM,EAAE,KAAK,MAAM,EAAE,UAAS,iBAAsB,KAAG,OAAO,CAAC,IAAI,CAEpG,CAAA;AAED,eAAO,MAAM,UAAU,QAAO,IAc7B,CAAA;AAED,eAAO,MAAM,SAAS,GAAI,UAAU,MAAM,EAAE,KAAK,MAAM,EAAE,UAAS,iBAAsB,KAAG,OAAO,CAAC,IAAI,CActG,CAAA;AAED,eAAO,MAAM,aAAa,GACxB,WAAW,YAAY,EACvB,OAAO,UAAU,EACjB,oBAAoB,eAAe,GAAG,aAAa,EACnD,gBAAgB,aAAa,EAC7B,WAAW;IACT,sBAAsB,CAAC,EAAE,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"wsClient.d.ts","sourceRoot":"","sources":["../../src/rts/wsClient.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { createContext, useContext, useId, useState, useRef, useEffect
|
|
1
|
+
import { createContext, useContext, useId, useMemo, useState, useRef, useEffect } from "react";
|
|
2
2
|
import { jsx } from "react/jsx-runtime";
|
|
3
3
|
const STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY = "__staticRpcbaseRtsHydrationData";
|
|
4
4
|
const RtsSsrRuntimeContext = createContext(null);
|
|
@@ -35,16 +35,13 @@ const parseHydrationData = (value) => {
|
|
|
35
35
|
queries
|
|
36
36
|
};
|
|
37
37
|
};
|
|
38
|
-
const hydrateRtsFromWindow = (
|
|
38
|
+
const hydrateRtsFromWindow = () => {
|
|
39
39
|
if (typeof window === "undefined") return;
|
|
40
40
|
const browserWindow = window;
|
|
41
41
|
const raw = browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY];
|
|
42
42
|
delete browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY];
|
|
43
43
|
const parsed = parseHydrationData(raw);
|
|
44
44
|
if (!parsed) return;
|
|
45
|
-
if (parsed.tenantId !== identity.tenantId || parsed.uid !== identity.uid) {
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
45
|
hydrationDataStore.clear();
|
|
49
46
|
for (const query of parsed.queries) {
|
|
50
47
|
hydrationDataStore.set(makeStoreKey(query.modelName, query.queryKey), query.data);
|
|
@@ -53,41 +50,12 @@ const hydrateRtsFromWindow = (identity) => {
|
|
|
53
50
|
const peekHydratedRtsQueryData = (modelName, queryKey) => {
|
|
54
51
|
return hydrationDataStore.get(makeStoreKey(modelName, queryKey));
|
|
55
52
|
};
|
|
53
|
+
const consumeHydratedRtsQueryData = (modelName, queryKey) => {
|
|
54
|
+
hydrationDataStore.delete(makeStoreKey(modelName, queryKey));
|
|
55
|
+
};
|
|
56
56
|
const clearHydratedRtsQueryData = () => {
|
|
57
57
|
hydrationDataStore.clear();
|
|
58
58
|
};
|
|
59
|
-
const readRootLikeLoaderData = () => {
|
|
60
|
-
if (typeof window === "undefined") return null;
|
|
61
|
-
const hydration = window.__staticRouterHydrationData;
|
|
62
|
-
if (!hydration || typeof hydration !== "object") return null;
|
|
63
|
-
const loaderData = hydration.loaderData;
|
|
64
|
-
if (!loaderData || typeof loaderData !== "object") return null;
|
|
65
|
-
const entries = Object.entries(loaderData);
|
|
66
|
-
let fallback = null;
|
|
67
|
-
for (const [routeId, data] of entries) {
|
|
68
|
-
if (!data || typeof data !== "object" || Array.isArray(data)) continue;
|
|
69
|
-
const obj = data;
|
|
70
|
-
const hasTenantId = Object.prototype.hasOwnProperty.call(obj, "tenantId");
|
|
71
|
-
const hasUser = Object.prototype.hasOwnProperty.call(obj, "user");
|
|
72
|
-
if (!hasTenantId && !hasUser) continue;
|
|
73
|
-
if (routeId === "root") return obj;
|
|
74
|
-
if (!fallback) fallback = obj;
|
|
75
|
-
}
|
|
76
|
-
return fallback;
|
|
77
|
-
};
|
|
78
|
-
const resolveRtsHydrationIdentityFromStaticRouterData = () => {
|
|
79
|
-
const rootData = readRootLikeLoaderData();
|
|
80
|
-
if (!rootData) {
|
|
81
|
-
return { tenantId: null, uid: null };
|
|
82
|
-
}
|
|
83
|
-
const tenantId = normalizeStringOrNull(rootData.tenantId);
|
|
84
|
-
const user = rootData.user;
|
|
85
|
-
const userId = user && typeof user === "object" ? normalizeStringOrNull(user.id) : null;
|
|
86
|
-
return {
|
|
87
|
-
tenantId,
|
|
88
|
-
uid: userId
|
|
89
|
-
};
|
|
90
|
-
};
|
|
91
59
|
const RtsSsrRuntimeProvider = ({
|
|
92
60
|
value,
|
|
93
61
|
children
|
|
@@ -780,11 +748,13 @@ const registerQuery = (modelName, query, optionsOrCallback, callbackMaybe, behav
|
|
|
780
748
|
const queryKey = computeRtsQueryKey(query, options);
|
|
781
749
|
const cbKey = `${modelName}.${queryKey}`;
|
|
782
750
|
const runInitialNetworkQuery = behavior?.runInitialNetworkQuery !== false;
|
|
751
|
+
const runInitialLocalQuery = behavior?.runInitialLocalQuery !== false;
|
|
752
|
+
const hasPopulate = Boolean(options.populate);
|
|
783
753
|
const set = queryCallbacks.get(cbKey) ?? /* @__PURE__ */ new Set();
|
|
784
754
|
set.add(callback);
|
|
785
755
|
queryCallbacks.set(cbKey, set);
|
|
786
756
|
subscriptions.set(cbKey, { modelName, query, options, queryKey, runInitialNetworkQuery });
|
|
787
|
-
if (currentUid) {
|
|
757
|
+
if (currentUid && runInitialLocalQuery && !hasPopulate) {
|
|
788
758
|
void runQuery({
|
|
789
759
|
modelName,
|
|
790
760
|
query,
|
|
@@ -837,6 +807,7 @@ const useQuery = (modelName, query = {}, options = {}) => {
|
|
|
837
807
|
const sortJson = options.sort ? JSON.stringify(options.sort) : "";
|
|
838
808
|
const limitStr = typeof options.limit === "number" ? String(options.limit) : "";
|
|
839
809
|
const populateJson = options.populate ? JSON.stringify(options.populate) : "";
|
|
810
|
+
const hasPopulate = Boolean(options.populate);
|
|
840
811
|
const queryKey = computeRtsQueryKey(query, {
|
|
841
812
|
key,
|
|
842
813
|
projection: options.projection,
|
|
@@ -859,7 +830,10 @@ const useQuery = (modelName, query = {}, options = {}) => {
|
|
|
859
830
|
queryKey
|
|
860
831
|
});
|
|
861
832
|
}
|
|
862
|
-
const seedDataRaw =
|
|
833
|
+
const seedDataRaw = useMemo(
|
|
834
|
+
() => enabled && ssrEnabled ? ssrRuntime ? ssrRuntime.getQueryData(modelName, queryKey) : peekHydratedRtsQueryData(modelName, queryKey) : void 0,
|
|
835
|
+
[enabled, ssrEnabled, ssrRuntime, modelName, queryKey]
|
|
836
|
+
);
|
|
863
837
|
const hasSeedData = Array.isArray(seedDataRaw);
|
|
864
838
|
const seedData = hasSeedData ? seedDataRaw : void 0;
|
|
865
839
|
const seedJson = (() => {
|
|
@@ -878,6 +852,9 @@ const useQuery = (modelName, query = {}, options = {}) => {
|
|
|
878
852
|
const hasNetworkReply = useRef(false);
|
|
879
853
|
const lastDataJsonRef = useRef("");
|
|
880
854
|
useEffect(() => {
|
|
855
|
+
if (!ssrRuntime && enabled && ssrEnabled && hasSeedData) {
|
|
856
|
+
consumeHydratedRtsQueryData(modelName, queryKey);
|
|
857
|
+
}
|
|
881
858
|
hasFirstReply.current = hasSeedData;
|
|
882
859
|
hasNetworkReply.current = false;
|
|
883
860
|
lastDataJsonRef.current = seedJson;
|
|
@@ -895,10 +872,11 @@ const useQuery = (modelName, query = {}, options = {}) => {
|
|
|
895
872
|
return;
|
|
896
873
|
}
|
|
897
874
|
setLoading(true);
|
|
898
|
-
}, [enabled, modelName, queryKey, hasSeedData, seedData, seedJson]);
|
|
875
|
+
}, [enabled, ssrEnabled, ssrRuntime, modelName, queryKey, hasSeedData, seedData, seedJson]);
|
|
899
876
|
useEffect(() => {
|
|
900
877
|
if (!enabled) return;
|
|
901
878
|
const runInitialNetworkQuery = refreshOnMount || !hasSeedData;
|
|
879
|
+
const runInitialLocalQuery = !hasSeedData && !hasPopulate;
|
|
902
880
|
const unsubscribe = registerQuery(
|
|
903
881
|
modelName,
|
|
904
882
|
query,
|
|
@@ -939,7 +917,8 @@ const useQuery = (modelName, query = {}, options = {}) => {
|
|
|
939
917
|
setData(result);
|
|
940
918
|
},
|
|
941
919
|
{
|
|
942
|
-
runInitialNetworkQuery
|
|
920
|
+
runInitialNetworkQuery,
|
|
921
|
+
runInitialLocalQuery
|
|
943
922
|
}
|
|
944
923
|
);
|
|
945
924
|
return () => {
|
|
@@ -975,10 +954,9 @@ export {
|
|
|
975
954
|
clearHydratedRtsQueryData as n,
|
|
976
955
|
onMessage as o,
|
|
977
956
|
peekHydratedRtsQueryData as p,
|
|
978
|
-
|
|
957
|
+
useQuery as q,
|
|
979
958
|
resetRtsPouchStore as r,
|
|
980
959
|
sendMessage as s,
|
|
981
|
-
useQuery as t,
|
|
982
960
|
updateDocs as u
|
|
983
961
|
};
|
|
984
|
-
//# sourceMappingURL=useQuery-
|
|
962
|
+
//# sourceMappingURL=useQuery-CalZ2p2a.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useQuery-CalZ2p2a.js","sources":["../src/rts/ssrHydration.tsx","../src/rts/pouchStore.ts","../src/rts/queryKey.ts","../src/rts/wsClient.ts","../src/rts/useQuery.ts"],"sourcesContent":["import { createContext, useContext, type ReactNode } from \"react\"\n\nimport type { RtsModelName } from \"./modelTypes\"\nimport type { RtsQueryOptions } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport const STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY = \"__staticRpcbaseRtsHydrationData\"\n\nexport type RtsSsrHydrationQueryData = {\n modelName: RtsModelName\n queryKey: string\n data: unknown[]\n}\n\nexport type StaticRpcbaseRtsHydrationData = {\n v: 1\n tenantId: string | null\n uid: string | null\n queries: RtsSsrHydrationQueryData[]\n}\n\nexport type RtsSsrQueryRegistration = {\n modelName: RtsModelName\n query: JsonObject\n options: RtsQueryOptions\n queryKey: string\n}\n\nexport type RtsSsrRuntime = {\n registerQuery: (query: RtsSsrQueryRegistration) => void\n getQueryData: (modelName: RtsModelName, queryKey: string) => unknown[] | undefined\n}\n\nconst RtsSsrRuntimeContext = createContext<RtsSsrRuntime | null>(null)\n\nconst hydrationDataStore = new Map<string, unknown[]>()\n\nconst makeStoreKey = (modelName: string, queryKey: string): string => `${modelName}.${queryKey}`\n\nconst normalizeStringOrNull = (value: unknown): string | null => {\n if (typeof value !== \"string\") return null\n const normalized = value.trim()\n return normalized ? normalized : null\n}\n\nconst parseHydrationData = (value: unknown): StaticRpcbaseRtsHydrationData | null => {\n if (!value || typeof value !== \"object\") return null\n\n const raw = value as {\n v?: unknown\n tenantId?: unknown\n uid?: unknown\n queries?: unknown\n }\n\n if (raw.v !== 1) return null\n if (!Array.isArray(raw.queries)) return null\n\n const queries: RtsSsrHydrationQueryData[] = []\n for (const entry of raw.queries) {\n if (!entry || typeof entry !== \"object\") continue\n\n const query = entry as {\n modelName?: unknown\n queryKey?: unknown\n data?: unknown\n }\n\n const modelName = normalizeStringOrNull(query.modelName)\n const queryKey = normalizeStringOrNull(query.queryKey)\n if (!modelName || !queryKey) continue\n if (!Array.isArray(query.data)) continue\n\n queries.push({\n modelName: modelName as RtsModelName,\n queryKey,\n data: query.data,\n })\n }\n\n return {\n v: 1,\n tenantId: normalizeStringOrNull(raw.tenantId),\n uid: normalizeStringOrNull(raw.uid),\n queries,\n }\n}\n\nexport const hydrateRtsFromWindow = (): void => {\n if (typeof window === \"undefined\") return\n\n const browserWindow = window as unknown as Record<string, unknown>\n const raw = browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY]\n delete browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY]\n\n const parsed = parseHydrationData(raw)\n if (!parsed) return\n\n hydrationDataStore.clear()\n for (const query of parsed.queries) {\n hydrationDataStore.set(makeStoreKey(query.modelName, query.queryKey), query.data)\n }\n}\n\nexport const peekHydratedRtsQueryData = (\n modelName: RtsModelName,\n queryKey: string,\n): unknown[] | undefined => {\n return hydrationDataStore.get(makeStoreKey(modelName, queryKey))\n}\n\nexport const consumeHydratedRtsQueryData = (\n modelName: RtsModelName,\n queryKey: string,\n): void => {\n hydrationDataStore.delete(makeStoreKey(modelName, queryKey))\n}\n\nexport const clearHydratedRtsQueryData = (): void => {\n hydrationDataStore.clear()\n}\n\nexport const RtsSsrRuntimeProvider = ({\n value,\n children,\n}: {\n value: RtsSsrRuntime\n children: ReactNode\n}) => {\n return (\n <RtsSsrRuntimeContext.Provider value={value}>\n {children}\n </RtsSsrRuntimeContext.Provider>\n )\n}\n\nexport const useRtsSsrRuntime = (): RtsSsrRuntime | null => {\n return useContext(RtsSsrRuntimeContext)\n}\n","type PouchDbStatic = {\n plugin: (plugin: unknown) => void\n prefix?: string\n defaults?: (options: Record<string, unknown>) => PouchDbStatic\n new (name: string, options?: Record<string, unknown>): PouchDbDatabase\n}\n\ntype PouchDbDatabase = {\n find: (options: Record<string, unknown>) => Promise<{ docs: Record<string, unknown>[] }>\n bulkDocs: (docs: Record<string, unknown>[]) => Promise<unknown>\n destroy: () => Promise<unknown>\n}\n\nexport type RtsPouchStoreConfig = {\n tenantId: string\n appName?: string\n prefix?: string\n}\n\nexport type RtsPouchQueryOptions = {\n uid: string\n projection?: Record<string, 0 | 1>\n sort?: Record<string, 1 | -1>\n limit?: number\n}\n\nexport type RtsPouchQueryContext = {\n source: \"cache\"\n}\n\nconst UNDERSCORE_PREFIX = \"$_\"\nconst DEFAULT_FIND_LIMIT = 4096\n\nlet storeConfig: RtsPouchStoreConfig | null = null\n\nlet pouchDbPromise: Promise<PouchDbStatic> | null = null\nlet lastAppliedPrefix: string | null = null\n\nconst collections = new Map<string, PouchDbDatabase>()\nconst dbNamesByPrefix = new Map<string, Set<string>>()\n\nconst unwrapDefault = (mod: unknown): unknown => {\n if (!mod || typeof mod !== \"object\") return mod\n const maybe = mod as { default?: unknown }\n return maybe.default ?? mod\n}\n\nconst ensureBrowser = () => {\n if (typeof window === \"undefined\") {\n throw new Error(\"RTS PouchDB store can only be used in the browser\")\n }\n}\n\nconst computeBasePrefix = ({ tenantId, appName }: { tenantId: string; appName?: string }): string => {\n let prefix = \"rb/\"\n if (appName) prefix += `${appName}/`\n prefix += `${tenantId}/`\n return prefix\n}\n\nconst getDbNamesKey = (prefix: string): string => `rb:rts:pouchDbs:${prefix}`\n\nconst getPrefixOverrideKey = ({ tenantId, appName }: { tenantId: string; appName?: string }): string =>\n `rb:rts:pouchPrefix:${appName ?? \"\"}:${tenantId}`\n\nconst readPrefixOverride = ({ tenantId, appName }: { tenantId: string; appName?: string }): string | null => {\n try {\n const value = window.localStorage.getItem(getPrefixOverrideKey({ tenantId, appName }))\n if (!value) return null\n if (!value.endsWith(\"/\")) return `${value}/`\n return value\n } catch {\n return null\n }\n}\n\nconst getPrefix = (): string => {\n if (!storeConfig) {\n throw new Error(\"RTS PouchDB store is not configured\")\n }\n\n if (storeConfig.prefix) return storeConfig.prefix\n\n const basePrefix = computeBasePrefix({ tenantId: storeConfig.tenantId, appName: storeConfig.appName })\n const override = readPrefixOverride({ tenantId: storeConfig.tenantId, appName: storeConfig.appName })\n return override ?? basePrefix\n}\n\nconst loadDbNames = (prefix: string): Set<string> => {\n const existing = dbNamesByPrefix.get(prefix)\n if (existing) return existing\n\n const names = new Set<string>()\n try {\n const raw = window.localStorage.getItem(getDbNamesKey(prefix))\n if (raw) {\n const parsed = JSON.parse(raw) as unknown\n if (Array.isArray(parsed)) {\n for (const value of parsed) {\n if (typeof value === \"string\" && value) names.add(value)\n }\n }\n }\n } catch {\n return names\n }\n\n dbNamesByPrefix.set(prefix, names)\n return names\n}\n\nconst persistDbNames = (prefix: string, names: Set<string>): void => {\n try {\n if (!names.size) {\n window.localStorage.removeItem(getDbNamesKey(prefix))\n dbNamesByPrefix.delete(prefix)\n return\n }\n\n window.localStorage.setItem(getDbNamesKey(prefix), JSON.stringify(Array.from(names)))\n dbNamesByPrefix.set(prefix, names)\n } catch {\n return\n }\n}\n\nconst registerDbName = (prefix: string, dbName: string): void => {\n if (!prefix || !dbName) return\n const names = loadDbNames(prefix)\n if (names.has(dbName)) return\n names.add(dbName)\n persistDbNames(prefix, names)\n}\n\nconst unregisterDbName = (prefix: string, dbName: string): void => {\n if (!prefix || !dbName) return\n const names = loadDbNames(prefix)\n if (!names.delete(dbName)) return\n persistDbNames(prefix, names)\n}\n\nconst getPouchDb = async (): Promise<PouchDbStatic> => {\n ensureBrowser()\n\n if (!pouchDbPromise) {\n pouchDbPromise = (async () => {\n const [core, indexedDbAdapter, findPlugin] = await Promise.all([\n import(\"pouchdb-core\"),\n import(\"pouchdb-adapter-indexeddb\"),\n import(\"pouchdb-find\"),\n ])\n\n const PouchDB = unwrapDefault(core) as PouchDbStatic\n PouchDB.plugin(unwrapDefault(indexedDbAdapter))\n PouchDB.plugin(unwrapDefault(findPlugin))\n\n return PouchDB\n })()\n }\n\n return pouchDbPromise\n}\n\nconst applyPrefix = (PouchDB: PouchDbStatic) => {\n const prefix = getPrefix()\n if (prefix === lastAppliedPrefix) return\n PouchDB.prefix = prefix\n lastAppliedPrefix = prefix\n}\n\nexport const configureRtsPouchStore = (config: RtsPouchStoreConfig | null) => {\n storeConfig = config\n lastAppliedPrefix = null\n collections.clear()\n}\n\nexport const getCollection = async (modelName: string, options: { uid: string }): Promise<PouchDbDatabase> => {\n const PouchDB = await getPouchDb()\n applyPrefix(PouchDB)\n\n const prefix = getPrefix()\n const dbName = `${options.uid}/${modelName}`\n const dbKey = `${prefix}${dbName}`\n\n const existing = collections.get(dbKey)\n if (existing) return existing\n\n registerDbName(prefix, dbName)\n const db = new PouchDB(dbName, { adapter: \"indexeddb\", revs_limit: 1 }) as PouchDbDatabase\n collections.set(dbKey, db)\n return db\n}\n\nconst replaceQueryKeys = (value: unknown, replaceKey: (key: string) => string): unknown => {\n if (typeof value !== \"object\" || value === null) {\n return value\n }\n\n if (Array.isArray(value)) {\n return value.map((item) => replaceQueryKeys(item, replaceKey))\n }\n\n const obj = value as Record<string, unknown>\n const next: Record<string, unknown> = Object.create(Object.getPrototypeOf(obj))\n\n for (const key of Object.keys(obj)) {\n if (/^\\$/.test(key) || /\\.\\d+$/.test(key)) {\n throw new Error(`replaceQueryKeys: Unexpected key format: ${key}`)\n }\n\n const newKey = replaceKey(key)\n next[newKey] = replaceQueryKeys(obj[key], replaceKey)\n }\n\n return next\n}\n\nconst getKeys = (obj: Record<string, unknown>, parentKey = \"\"): string[] => {\n const keys: string[] = []\n\n for (const key of Object.keys(obj)) {\n const nextKey = parentKey ? `${parentKey}.${key}` : key\n const value = obj[key]\n\n if (typeof value === \"object\" && value !== null && !Array.isArray(value)) {\n keys.push(...getKeys(value as Record<string, unknown>, nextKey))\n } else {\n keys.push(nextKey)\n }\n }\n\n return keys\n}\n\nconst satisfiesProjection = (doc: Record<string, unknown>, projection: Record<string, 0 | 1>): boolean => {\n const docKeys = new Set(getKeys(doc))\n const projectionKeys = new Set(Object.keys(projection).filter((key) => projection[key] === 1))\n\n if (!projectionKeys.has(\"_id\")) {\n docKeys.delete(\"_id\")\n }\n\n if (projectionKeys.size > docKeys.size) return false\n for (const key of projectionKeys) {\n if (!docKeys.has(key)) return false\n }\n return true\n}\n\nconst remapDocFromStorage = (doc: Record<string, unknown>): Record<string, unknown> => {\n const next: Record<string, unknown> = {}\n\n for (const [key, value] of Object.entries(doc)) {\n const newKey = key.startsWith(UNDERSCORE_PREFIX) ? key.replace(/^\\$_/, \"\") : key\n next[newKey] = value\n }\n\n return next\n}\n\nexport const runQuery = async <T extends Record<string, unknown>>({\n modelName,\n query = {},\n options,\n}: {\n modelName: string\n query?: Record<string, unknown>\n options: RtsPouchQueryOptions\n}): Promise<{ data: T[]; context: RtsPouchQueryContext }> => {\n const collection = await getCollection(modelName, { uid: options.uid })\n\n const replacedQuery = replaceQueryKeys(query, (key) =>\n key.startsWith(\"_\") && key !== \"_id\" ? `${UNDERSCORE_PREFIX}${key}` : key,\n ) as Record<string, unknown>\n\n const limit = typeof options.limit === \"number\" ? Math.abs(options.limit) : DEFAULT_FIND_LIMIT\n\n const { docs } = await collection.find({\n selector: replacedQuery,\n limit,\n })\n\n let mappedDocs: T[] = docs.map(({ _rev: _revIgnored, ...rest }) => remapDocFromStorage(rest) as T)\n\n if (options.projection) {\n mappedDocs = mappedDocs.filter((doc) => satisfiesProjection(doc, options.projection!))\n }\n\n if (options.sort) {\n mappedDocs = mappedDocs.sort((a, b) => {\n for (const key of Object.keys(options.sort!)) {\n if (!Object.hasOwn(a, key) || !Object.hasOwn(b, key)) continue\n\n const dir = options.sort![key]\n const aVal = a[key]\n const bVal = b[key]\n\n if (typeof aVal === \"number\" && typeof bVal === \"number\") {\n if (aVal < bVal) return -1 * dir\n if (aVal > bVal) return 1 * dir\n continue\n }\n\n if (typeof aVal === \"string\" && typeof bVal === \"string\") {\n if (aVal < bVal) return -1 * dir\n if (aVal > bVal) return 1 * dir\n continue\n }\n }\n return 0\n })\n }\n\n return { data: mappedDocs, context: { source: \"cache\" } }\n}\n\nexport const updateDocs = async (\n modelName: string,\n data: Array<Record<string, unknown> & { _id: string }>,\n uid: string,\n): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n\n const allIds = data.map((doc) => doc._id).filter(Boolean)\n if (!allIds.length) return\n\n const { docs: currentDocs } = await collection.find({\n selector: { _id: { $in: allIds } },\n fields: [\"_id\", \"_rev\"],\n limit: allIds.length,\n })\n\n const currentDocsById = currentDocs.reduce<Record<string, Record<string, unknown>>>((acc, doc) => {\n const id = String(doc._id ?? \"\")\n if (id) acc[id] = doc\n return acc\n }, {})\n\n const newDocs = data.map((mongoDoc) => {\n const currentDoc = currentDocsById[mongoDoc._id] ?? { _id: mongoDoc._id }\n const nextDoc = Object.entries(mongoDoc).reduce<Record<string, unknown>>((acc, [key, value]) => {\n const newKey = key !== \"_id\" && key.startsWith(\"_\") ? `${UNDERSCORE_PREFIX}${key}` : key\n acc[newKey] = value\n return acc\n }, { ...currentDoc })\n\n const rev = currentDoc._rev\n if (typeof rev === \"string\" && rev) {\n nextDoc._rev = rev\n } else {\n delete nextDoc._rev\n }\n\n return nextDoc\n })\n\n await collection.bulkDocs(newDocs)\n}\n\nexport const deleteDocs = async (modelName: string, ids: string[], uid: string): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n\n const allIds = ids.map((id) => String(id ?? \"\")).filter(Boolean)\n if (!allIds.length) return\n\n const { docs: currentDocs } = await collection.find({\n selector: { _id: { $in: allIds } },\n fields: [\"_id\", \"_rev\"],\n limit: allIds.length,\n })\n\n const deletions = currentDocs\n .map((doc) => ({\n _id: String((doc as { _id?: unknown })?._id ?? \"\"),\n _rev: (doc as { _rev?: unknown })?._rev,\n _deleted: true,\n }))\n .filter((doc) => doc._id && typeof doc._rev === \"string\" && doc._rev)\n\n if (!deletions.length) return\n await collection.bulkDocs(deletions)\n}\n\nexport const destroyCollection = async (modelName: string, uid: string): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n const prefix = getPrefix()\n const dbName = `${uid}/${modelName}`\n collections.delete(`${prefix}${dbName}`)\n unregisterDbName(prefix, dbName)\n await collection.destroy()\n}\n\nexport const resetRtsPouchStore = ({ tenantId, appName }: { tenantId: string; appName?: string }): string => {\n ensureBrowser()\n const basePrefix = computeBasePrefix({ tenantId, appName })\n const oldPrefix = readPrefixOverride({ tenantId, appName }) ?? basePrefix\n const dbNames = Array.from(loadDbNames(oldPrefix))\n const openDbs = Array.from(collections.entries())\n .filter(([key]) => key.startsWith(oldPrefix))\n .map(([, db]) => db)\n\n void (async () => {\n const remaining = new Set(dbNames)\n\n await Promise.all(openDbs.map((db) => db.destroy().catch(() => {})))\n\n if (remaining.size) {\n const PouchDB = await getPouchDb()\n const PouchDBForPrefix = (PouchDB.defaults?.({}) ?? PouchDB) as PouchDbStatic\n PouchDBForPrefix.prefix = oldPrefix\n\n await Promise.all(Array.from(remaining).map(async (name) => {\n const db = new PouchDBForPrefix(name, { adapter: \"indexeddb\", revs_limit: 1 }) as PouchDbDatabase\n await db.destroy().then(() => {\n remaining.delete(name)\n }).catch(() => {})\n }))\n }\n\n if (remaining.size) {\n persistDbNames(oldPrefix, remaining)\n } else {\n persistDbNames(oldPrefix, new Set())\n }\n })()\n\n const newPrefix = `${basePrefix}reset-${Date.now().toString(16)}/`\n try {\n window.localStorage.setItem(getPrefixOverrideKey({ tenantId, appName }), newPrefix)\n } catch {\n return newPrefix\n }\n\n lastAppliedPrefix = null\n collections.clear()\n return newPrefix\n}\n\nexport const destroyAllCollections = async (): Promise<void> => {\n const dbs = Array.from(collections.values())\n await Promise.all(dbs.map((db) => db.destroy()))\n collections.clear()\n}\n","import type { RtsQueryOptions } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport const computeRtsQueryKey = (query: JsonObject, options: RtsQueryOptions): string => {\n const key = options.key ?? \"\"\n const projection = options.projection ? JSON.stringify(options.projection) : \"\"\n const sort = options.sort ? JSON.stringify(options.sort) : \"\"\n const limit = typeof options.limit === \"number\" ? String(options.limit) : \"\"\n const populate = options.populate ? JSON.stringify(options.populate) : \"\"\n return `${key}${JSON.stringify(query)}${projection}${sort}${limit}${populate}`\n}\n","import { configureRtsPouchStore, deleteDocs, destroyCollection, resetRtsPouchStore, runQuery, updateDocs } from \"./pouchStore\"\nimport type { RtsModelName } from \"./modelTypes\"\nimport { computeRtsQueryKey } from \"./queryKey\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport type RtsPopulateObject = {\n path: string\n model?: string\n select?: string | JsonObject\n match?: JsonObject\n options?: {\n sort?: Record<string, 1 | -1>\n limit?: number\n }\n populate?: RtsPopulateOption\n}\n\nexport type RtsPopulateOption =\n | string\n | RtsPopulateObject\n | Array<string | RtsPopulateObject>\n\nexport type RtsNetworkQueryContext = {\n source: \"network\"\n isLocal: boolean\n txnId?: string\n}\n\nexport type RtsCacheQueryContext = {\n source: \"cache\"\n}\n\nexport type RtsQueryContext = RtsNetworkQueryContext | RtsCacheQueryContext\n\nexport type RtsQueryOptions = {\n key?: string\n projection?: Record<string, 0 | 1>\n sort?: Record<string, 1 | -1>\n limit?: number\n populate?: RtsPopulateOption\n}\n\nexport type RtsConnectOptions = {\n url?: string\n path?: string\n appName?: string\n configureStore?: boolean\n syncChanges?: boolean\n reconnect?: {\n attempts?: number\n delayMs?: number\n delayMaxMs?: number\n }\n}\n\ntype QueryCallback = (error: unknown | null, data: unknown, context: RtsQueryContext) => void\n\ntype QuerySubscription = {\n modelName: RtsModelName\n query: JsonObject\n options: RtsQueryOptions\n queryKey: string\n runInitialNetworkQuery: boolean\n}\n\ntype ServerMessage =\n | { type: \"query-payload\"; modelName: string; queryKey: string; data?: unknown; error?: string; txnId?: string }\n | { type: \"event\"; event: string; payload?: unknown }\n\ntype ClientMessage =\n | { type: \"run-query\"; modelName: string; queryKey: string; query: JsonObject; options?: RtsQueryOptions }\n | {\n type: \"register-query\"\n modelName: string\n queryKey: string\n query: JsonObject\n options?: RtsQueryOptions\n runInitialQuery?: boolean\n }\n | { type: \"remove-query\"; modelName: string; queryKey: string }\n | { type: \"event\"; event: string; payload?: unknown }\n\ntype DocWithId = Record<string, unknown> & { _id: string }\ntype SyncChangesPayload = {\n ok?: unknown\n latestSeq?: unknown\n needsFullResync?: unknown\n changes?: unknown\n}\ntype RawSyncChangeRecord = {\n seq?: unknown\n modelName?: unknown\n op?: unknown\n docId?: unknown\n}\n\nconst TENANT_ID_QUERY_PARAM = \"rb-tenant-id\"\nconst RTS_CHANGES_ROUTE = \"/api/rb/rts/changes\"\nconst MAX_TXN_BUF = 2048\nconst SERVER_RECONNECT_DELAY_MIN_MS = 10_000\nconst SERVER_RECONNECT_DELAY_MAX_MS = 15_000\n\nlet socket: WebSocket | null = null\nlet connectPromise: Promise<void> | null = null\nlet explicitDisconnect = false\n\nlet currentTenantId: string | null = null\nlet currentUid: string | null = null\nlet connectOptions: RtsConnectOptions = {}\n\nconst localTxnBuf: string[] = []\n\nconst queryCallbacks = new Map<string, Set<QueryCallback>>()\nconst subscriptions = new Map<string, QuerySubscription>()\nconst messageCallbacks = new Map<string, Set<(payload: unknown) => void>>()\n\nlet reconnectTimer: number | null = null\nlet reconnectAttempts = 0\nlet hasEstablishedConnection = false\nlet pendingServerReconnectJitter = false\n\nlet syncPromise: Promise<void> | null = null\nlet syncKey: string | null = null\n\nconst ensureBrowser = () => {\n if (typeof window === \"undefined\") {\n throw new Error(\"RTS websocket client can only be used in the browser\")\n }\n}\n\nconst buildSocketUrl = (tenantId: string, _uid: string, options: RtsConnectOptions): string => {\n if (options.url) {\n const url = new URL(options.url)\n url.searchParams.set(TENANT_ID_QUERY_PARAM, tenantId)\n return url.toString()\n }\n\n const base = new URL(window.location.href)\n base.protocol = base.protocol === \"https:\" ? \"wss:\" : \"ws:\"\n base.pathname = options.path ?? \"/rts\"\n base.search = \"\"\n base.hash = \"\"\n base.searchParams.set(TENANT_ID_QUERY_PARAM, tenantId)\n return base.toString()\n}\n\nconst sendToServer = (message: ClientMessage): void => {\n if (!socket) return\n if (socket.readyState !== WebSocket.OPEN) return\n socket.send(JSON.stringify(message))\n}\n\nconst resubscribeAll = ({ forceInitialQuery }: { forceInitialQuery: boolean }): void => {\n for (const sub of subscriptions.values()) {\n const runInitialQuery = forceInitialQuery || sub.runInitialNetworkQuery\n sendToServer({\n type: \"register-query\",\n modelName: sub.modelName,\n queryKey: sub.queryKey,\n query: sub.query,\n options: sub.options,\n runInitialQuery,\n })\n }\n}\n\nconst clearReconnectTimer = () => {\n if (reconnectTimer === null) return\n if (typeof window !== \"undefined\") {\n window.clearTimeout(reconnectTimer)\n }\n reconnectTimer = null\n}\n\nconst scheduleReconnect = () => {\n clearReconnectTimer()\n if (explicitDisconnect) {\n pendingServerReconnectJitter = false\n return\n }\n if (!currentTenantId || !currentUid) return\n\n const cfg = connectOptions.reconnect ?? {}\n const maxAttempts = cfg.attempts ?? 128\n const delayMs = cfg.delayMs ?? 400\n const delayMaxMs = cfg.delayMaxMs ?? 10_000\n\n if (reconnectAttempts >= maxAttempts) return\n\n let delay = Math.min(delayMaxMs, delayMs * Math.pow(2, reconnectAttempts))\n if (pendingServerReconnectJitter) {\n const span = SERVER_RECONNECT_DELAY_MAX_MS - SERVER_RECONNECT_DELAY_MIN_MS\n delay = SERVER_RECONNECT_DELAY_MIN_MS + Math.floor(Math.random() * (span + 1))\n pendingServerReconnectJitter = false\n }\n reconnectAttempts += 1\n reconnectTimer = window.setTimeout(() => {\n void connectInternal(currentTenantId!, currentUid!, connectOptions, { resetReconnectAttempts: false })\n }, delay)\n}\n\nconst isDocWithId = (doc: unknown): doc is DocWithId => {\n if (!doc || typeof doc !== \"object\") return false\n return typeof (doc as { _id?: unknown })._id === \"string\"\n}\n\nconst handleQueryPayload = (payload: Extract<ServerMessage, { type: \"query-payload\" }>) => {\n const { modelName, queryKey, data, error, txnId } = payload\n const cbKey = `${modelName}.${queryKey}`\n const callbacks = queryCallbacks.get(cbKey)\n if (!callbacks || !callbacks.size) return\n const subscription = subscriptions.get(cbKey)\n const hasPopulate = Boolean(subscription?.options?.populate)\n\n const isLocal = !!(txnId && localTxnBuf.includes(txnId))\n const context: RtsNetworkQueryContext = { source: \"network\", isLocal, txnId }\n\n if (error) {\n for (const cb of callbacks) cb(error, undefined, context)\n return\n }\n\n for (const cb of callbacks) cb(null, data, context)\n\n if (!currentUid) return\n\n const docs = Array.isArray(data) ? data.filter(isDocWithId) : []\n\n if (!docs.length) return\n if (hasPopulate) return\n\n void updateDocs(modelName, docs, currentUid)\n .catch(() => {})\n}\n\nconst handleEvent = (payload: Extract<ServerMessage, { type: \"event\" }>) => {\n const callbacks = messageCallbacks.get(payload.event)\n if (!callbacks || !callbacks.size) return\n for (const cb of callbacks) cb(payload.payload)\n}\n\nconst handleMessage = (event: MessageEvent) => {\n let parsed: unknown\n try {\n parsed = JSON.parse(typeof event.data === \"string\" ? event.data : String(event.data))\n } catch {\n return\n }\n\n if (!parsed || typeof parsed !== \"object\") return\n const message = parsed as ServerMessage\n\n if (message.type === \"query-payload\") {\n handleQueryPayload(message)\n return\n }\n\n if (message.type === \"event\") {\n handleEvent(message)\n }\n}\n\nexport const addLocalTxn = (txnId: string): void => {\n if (!txnId) return\n localTxnBuf.push(txnId)\n if (localTxnBuf.length > MAX_TXN_BUF) {\n localTxnBuf.shift()\n }\n}\n\ntype RtsChangeRecord = {\n seq: number\n modelName: string\n op: \"delete\" | \"reset_model\"\n docId?: string\n}\n\nconst getSyncStorageKey = ({ tenantId, uid, appName }: { tenantId: string; uid: string; appName?: string }): string =>\n `rb:rts:changesSeq:${appName ?? \"\"}:${tenantId}:${uid}`\n\nconst readStoredSeq = (key: string): number => {\n try {\n const raw = window.localStorage.getItem(key)\n const num = raw ? Number(raw) : 0\n return Number.isFinite(num) && num >= 0 ? Math.floor(num) : 0\n } catch {\n return 0\n }\n}\n\nconst writeStoredSeq = (key: string, value: number): void => {\n try {\n window.localStorage.setItem(key, String(Math.max(0, Math.floor(value))))\n } catch {\n return\n }\n}\n\nconst applyChangeBatch = async (changes: RtsChangeRecord[], uid: string): Promise<void> => {\n const resetModels = new Set<string>()\n const deletesByModel = new Map<string, string[]>()\n\n for (const change of changes) {\n const modelName = typeof change.modelName === \"string\" ? change.modelName : \"\"\n if (!modelName) continue\n\n if (change.op === \"reset_model\") {\n resetModels.add(modelName)\n continue\n }\n\n if (change.op === \"delete\") {\n const docId = typeof change.docId === \"string\" ? change.docId : \"\"\n if (!docId) continue\n const existing = deletesByModel.get(modelName) ?? []\n existing.push(docId)\n deletesByModel.set(modelName, existing)\n }\n }\n\n for (const modelName of resetModels) {\n await destroyCollection(modelName, uid).catch(() => {})\n }\n\n for (const [modelName, ids] of deletesByModel.entries()) {\n if (resetModels.has(modelName)) continue\n await deleteDocs(modelName, ids, uid).catch(() => {})\n }\n}\n\nexport const syncRtsChanges = async (tenantId: string, uid: string, options: Pick<RtsConnectOptions, \"appName\"> = {}): Promise<void> => {\n ensureBrowser()\n if (!tenantId || !uid) return\n\n const storageKey = getSyncStorageKey({ tenantId, uid, appName: options.appName })\n let sinceSeq = readStoredSeq(storageKey)\n\n for (let i = 0; i < 32; i += 1) {\n const url = `${RTS_CHANGES_ROUTE}?${TENANT_ID_QUERY_PARAM}=${encodeURIComponent(tenantId)}`\n const response = await fetch(url, {\n method: \"POST\",\n credentials: \"include\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ sinceSeq, limit: 2000 }),\n })\n\n if (!response.ok) return\n\n const payload: unknown = await response.json().catch(() => null)\n if (!payload || typeof payload !== \"object\") return\n const payloadObj = payload as SyncChangesPayload\n const ok = payloadObj.ok\n if (ok !== true) return\n\n const latestSeq = Number(payloadObj.latestSeq ?? 0)\n const needsFullResync = Boolean(payloadObj.needsFullResync)\n\n if (needsFullResync) {\n resetRtsPouchStore({ tenantId, appName: options.appName })\n writeStoredSeq(storageKey, latestSeq)\n return\n }\n\n const changesRaw = payloadObj.changes\n const changes = Array.isArray(changesRaw) ? changesRaw : []\n const normalized = changes\n .map((c): RtsChangeRecord | null => {\n if (!c || typeof c !== \"object\") return null\n const obj = c as RawSyncChangeRecord\n\n const seq = Number(obj.seq ?? 0)\n const modelName = typeof obj.modelName === \"string\" ? obj.modelName : String(obj.modelName ?? \"\")\n const op = obj.op === \"reset_model\" ? \"reset_model\" : \"delete\"\n const docId = typeof obj.docId === \"string\" && obj.docId ? obj.docId : obj.docId ? String(obj.docId) : undefined\n\n return { seq, modelName, op, ...(docId ? { docId } : {}) }\n })\n .filter((c): c is RtsChangeRecord => c !== null)\n .filter((c: RtsChangeRecord) =>\n Number.isFinite(c.seq) && c.seq > 0 && c.modelName && (c.op === \"reset_model\" || !!c.docId),\n )\n\n if (!normalized.length) {\n writeStoredSeq(storageKey, latestSeq)\n return\n }\n\n await applyChangeBatch(normalized, uid)\n\n const lastSeq = normalized.reduce((max, c) => (c.seq > max ? c.seq : max), sinceSeq)\n sinceSeq = lastSeq\n writeStoredSeq(storageKey, sinceSeq)\n\n if (latestSeq > 0 && sinceSeq >= latestSeq) {\n return\n }\n }\n}\n\nconst ensureSynced = (tenantId: string, uid: string, options: RtsConnectOptions): void => {\n if (options.syncChanges === false) return\n const key = `${options.appName ?? \"\"}:${tenantId}:${uid}`\n if (syncPromise && syncKey === key) return\n\n syncKey = key\n syncPromise = syncRtsChanges(tenantId, uid, { appName: options.appName })\n .catch(() => {})\n .finally(() => {\n if (syncKey === key) {\n syncPromise = null\n }\n })\n}\n\nconst connectInternal = (\n tenantId: string,\n uid: string,\n options: RtsConnectOptions,\n { resetReconnectAttempts }: { resetReconnectAttempts: boolean },\n): Promise<void> => {\n ensureBrowser()\n\n if (!tenantId) return Promise.resolve()\n if (!uid) throw new Error(\"Missing uid\")\n\n currentTenantId = tenantId\n currentUid = uid\n connectOptions = options\n\n if (options.configureStore !== false) {\n configureRtsPouchStore({ tenantId, appName: options.appName })\n }\n ensureSynced(tenantId, uid, options)\n\n if (socket && (socket.readyState === WebSocket.OPEN || socket.readyState === WebSocket.CONNECTING)) {\n return connectPromise ?? Promise.resolve()\n }\n\n explicitDisconnect = false\n clearReconnectTimer()\n\n const url = buildSocketUrl(tenantId, uid, options)\n\n connectPromise = new Promise((resolve, reject) => {\n if (resetReconnectAttempts) reconnectAttempts = 0\n\n let opened = false\n let settled = false\n socket = new WebSocket(url)\n\n socket.addEventListener(\"open\", () => {\n opened = true\n settled = true\n reconnectAttempts = 0\n pendingServerReconnectJitter = false\n const forceInitialQuery = hasEstablishedConnection\n resubscribeAll({ forceInitialQuery })\n hasEstablishedConnection = true\n resolve()\n })\n\n socket.addEventListener(\"message\", handleMessage)\n\n socket.addEventListener(\"close\", (event) => {\n if (!opened && !settled) {\n settled = true\n reject(new Error(`RTS WebSocket closed before opening (code=${event.code})`))\n }\n if (!explicitDisconnect) {\n pendingServerReconnectJitter = opened\n }\n\n socket = null\n connectPromise = null\n scheduleReconnect()\n })\n\n socket.addEventListener(\"error\", (err) => {\n if (settled) return\n settled = true\n reject(err instanceof Error ? err : new Error(\"RTS WebSocket error\"))\n })\n })\n\n return connectPromise\n}\n\nexport const connect = (tenantId: string, uid: string, options: RtsConnectOptions = {}): Promise<void> => {\n return connectInternal(tenantId, uid, options, { resetReconnectAttempts: true })\n}\n\nexport const disconnect = (): void => {\n explicitDisconnect = true\n clearReconnectTimer()\n hasEstablishedConnection = false\n pendingServerReconnectJitter = false\n if (socket) {\n try {\n socket.close()\n } catch {\n // ignore\n }\n }\n socket = null\n connectPromise = null\n}\n\nexport const reconnect = (tenantId: string, uid: string, options: RtsConnectOptions = {}): Promise<void> => {\n explicitDisconnect = true\n clearReconnectTimer()\n pendingServerReconnectJitter = false\n if (socket) {\n try {\n socket.close()\n } catch {\n // ignore\n }\n }\n socket = null\n connectPromise = null\n return connect(tenantId, uid, options)\n}\n\nexport const registerQuery = (\n modelName: RtsModelName,\n query: JsonObject,\n optionsOrCallback?: RtsQueryOptions | QueryCallback,\n callbackMaybe?: QueryCallback,\n behavior?: {\n runInitialNetworkQuery?: boolean\n runInitialLocalQuery?: boolean\n },\n): (() => void) | undefined => {\n let options: RtsQueryOptions\n let callback: QueryCallback | undefined\n\n if (typeof optionsOrCallback === \"function\") {\n options = {}\n callback = optionsOrCallback\n } else {\n options = optionsOrCallback ?? {}\n callback = callbackMaybe\n }\n\n if (!callback) return undefined\n if (typeof modelName !== \"string\" || modelName.trim().length === 0) {\n throw new Error(\"registerQuery: modelName must be a non-empty string\")\n }\n\n const queryKey = computeRtsQueryKey(query, options)\n const cbKey = `${modelName}.${queryKey}`\n const runInitialNetworkQuery = behavior?.runInitialNetworkQuery !== false\n const runInitialLocalQuery = behavior?.runInitialLocalQuery !== false\n const hasPopulate = Boolean(options.populate)\n\n const set = queryCallbacks.get(cbKey) ?? new Set<QueryCallback>()\n set.add(callback)\n queryCallbacks.set(cbKey, set)\n\n subscriptions.set(cbKey, { modelName, query, options, queryKey, runInitialNetworkQuery })\n\n if (currentUid && runInitialLocalQuery && !hasPopulate) {\n void runQuery({\n modelName,\n query,\n options: {\n uid: currentUid,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n },\n }).then(({ data, context }) => {\n callback?.(null, data, context)\n }).catch(() => {\n // ignore\n })\n }\n\n sendToServer({ type: \"register-query\", modelName, queryKey, query, options, runInitialQuery: runInitialNetworkQuery })\n\n return () => {\n sendToServer({ type: \"remove-query\", modelName, queryKey })\n\n const callbacks = queryCallbacks.get(cbKey)\n callbacks?.delete(callback!)\n if (callbacks && callbacks.size === 0) {\n queryCallbacks.delete(cbKey)\n subscriptions.delete(cbKey)\n }\n }\n}\n\nexport const sendMessage = (event: string, payload?: unknown): void => {\n sendToServer({ type: \"event\", event, payload })\n}\n\nexport const onMessage = (event: string, callback: (payload: unknown) => void): (() => void) => {\n const set = messageCallbacks.get(event) ?? new Set()\n set.add(callback)\n messageCallbacks.set(event, set)\n\n return () => {\n const callbacks = messageCallbacks.get(event)\n callbacks?.delete(callback)\n if (callbacks && callbacks.size === 0) messageCallbacks.delete(event)\n }\n}\n","import { useEffect, useId, useMemo, useRef, useState } from \"react\"\n\nimport type { RtsModelName } from \"./modelTypes\"\nimport { computeRtsQueryKey } from \"./queryKey\"\nimport { consumeHydratedRtsQueryData, peekHydratedRtsQueryData, useRtsSsrRuntime } from \"./ssrHydration\"\nimport type { RtsQueryContext, RtsQueryOptions } from \"./wsClient\"\nimport { registerQuery } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport type UseRtsQueryOptions = RtsQueryOptions & {\n enabled?: boolean\n skipLocal?: boolean\n ssr?: \"auto\" | boolean\n refreshOnMount?: boolean\n}\n\nexport type UseRtsQueryResult<T> = {\n data: T[] | undefined\n source: RtsQueryContext[\"source\"] | undefined\n error: unknown | undefined\n loading: boolean\n}\n\nexport const useQuery = <T extends Record<string, unknown> = Record<string, unknown>>(\n modelName: RtsModelName,\n query: JsonObject = {},\n options: UseRtsQueryOptions = {},\n): UseRtsQueryResult<T> => {\n if (typeof modelName !== \"string\" || modelName.trim().length === 0) {\n throw new Error(\"useQuery: modelName must be a non-empty string\")\n }\n\n const id = useId()\n\n const enabled = options.enabled ?? true\n const ssrEnabled = options.ssr !== false\n const refreshOnMount = options.refreshOnMount === true\n const key = options.key ?? id\n const queryJson = JSON.stringify(query)\n const projectionJson = options.projection ? JSON.stringify(options.projection) : \"\"\n const sortJson = options.sort ? JSON.stringify(options.sort) : \"\"\n const limitStr = typeof options.limit === \"number\" ? String(options.limit) : \"\"\n const populateJson = options.populate ? JSON.stringify(options.populate) : \"\"\n const hasPopulate = Boolean(options.populate)\n const queryKey = computeRtsQueryKey(query, {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n })\n\n const ssrRuntime = useRtsSsrRuntime()\n if (enabled && ssrEnabled && ssrRuntime) {\n ssrRuntime.registerQuery({\n modelName,\n query,\n options: {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n },\n queryKey,\n })\n }\n\n const seedDataRaw = useMemo(\n () => (\n enabled && ssrEnabled\n ? ssrRuntime\n ? ssrRuntime.getQueryData(modelName, queryKey)\n : peekHydratedRtsQueryData(modelName, queryKey)\n : undefined\n ),\n [enabled, ssrEnabled, ssrRuntime, modelName, queryKey],\n )\n\n const hasSeedData = Array.isArray(seedDataRaw)\n const seedData = hasSeedData ? seedDataRaw as T[] : undefined\n const seedJson = (() => {\n if (!hasSeedData) return \"\"\n try {\n return JSON.stringify(seedDataRaw)\n } catch {\n return \"\"\n }\n })()\n\n const [data, setData] = useState<T[] | undefined>(() => seedData)\n const [source, setSource] = useState<RtsQueryContext[\"source\"] | undefined>(() => (hasSeedData ? \"cache\" : undefined))\n const [error, setError] = useState<unknown | undefined>(undefined)\n const [loading, setLoading] = useState<boolean>(enabled && !hasSeedData)\n\n const hasFirstReply = useRef(false)\n const hasNetworkReply = useRef(false)\n const lastDataJsonRef = useRef<string>(\"\")\n\n useEffect(() => {\n if (!ssrRuntime && enabled && ssrEnabled && hasSeedData) {\n consumeHydratedRtsQueryData(modelName, queryKey)\n }\n\n hasFirstReply.current = hasSeedData\n hasNetworkReply.current = false\n lastDataJsonRef.current = seedJson\n setError(undefined)\n\n if (!enabled) {\n setLoading(false)\n setData(undefined)\n setSource(undefined)\n return\n }\n\n if (hasSeedData) {\n setLoading(false)\n setData(seedData)\n setSource(\"cache\")\n return\n }\n\n setLoading(true)\n }, [enabled, ssrEnabled, ssrRuntime, modelName, queryKey, hasSeedData, seedData, seedJson])\n\n useEffect(() => {\n if (!enabled) return\n\n const runInitialNetworkQuery = refreshOnMount || !hasSeedData\n const runInitialLocalQuery = !hasSeedData && !hasPopulate\n\n const unsubscribe = registerQuery(\n modelName,\n query,\n {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n },\n (err, result, context) => {\n if (context.source === \"cache\" && hasNetworkReply.current) return\n\n if (context.source === \"network\") {\n hasNetworkReply.current = true\n }\n\n setLoading(false)\n\n if (err) {\n setError(err)\n return\n }\n\n if (!Array.isArray(result)) return\n\n if (context.source === \"network\" && context.isLocal && options.skipLocal && hasFirstReply.current) {\n return\n }\n\n hasFirstReply.current = true\n\n let nextJson = \"\"\n try {\n nextJson = JSON.stringify(result)\n } catch {\n nextJson = \"\"\n }\n\n if (nextJson && nextJson === lastDataJsonRef.current) {\n setSource(context.source)\n return\n }\n\n lastDataJsonRef.current = nextJson\n setSource(context.source)\n setData(result as T[])\n },\n {\n runInitialNetworkQuery,\n runInitialLocalQuery,\n },\n )\n\n return () => {\n unsubscribe?.()\n }\n }, [enabled, modelName, queryKey, queryJson, projectionJson, sortJson, limitStr, populateJson, hasSeedData, refreshOnMount])\n\n return useMemo(\n () => ({\n data,\n source,\n error,\n loading,\n }),\n [data, source, error, loading],\n )\n}\n"],"names":["ensureBrowser"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useQuery-n0OatV-X.js","sources":["../src/rts/ssrHydration.tsx","../src/rts/pouchStore.ts","../src/rts/queryKey.ts","../src/rts/wsClient.ts","../src/rts/useQuery.ts"],"sourcesContent":["import { createContext, useContext, type ReactNode } from \"react\"\n\nimport type { RtsModelName } from \"./modelTypes\"\nimport type { RtsQueryOptions } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport const STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY = \"__staticRpcbaseRtsHydrationData\"\n\nexport type RtsSsrHydrationQueryData = {\n modelName: RtsModelName\n queryKey: string\n data: unknown[]\n}\n\nexport type StaticRpcbaseRtsHydrationData = {\n v: 1\n tenantId: string | null\n uid: string | null\n queries: RtsSsrHydrationQueryData[]\n}\n\nexport type RtsSsrIdentity = {\n tenantId: string | null\n uid: string | null\n}\n\nexport type RtsSsrQueryRegistration = {\n modelName: RtsModelName\n query: JsonObject\n options: RtsQueryOptions\n queryKey: string\n}\n\nexport type RtsSsrRuntime = {\n registerQuery: (query: RtsSsrQueryRegistration) => void\n getQueryData: (modelName: RtsModelName, queryKey: string) => unknown[] | undefined\n}\n\nconst RtsSsrRuntimeContext = createContext<RtsSsrRuntime | null>(null)\n\nconst hydrationDataStore = new Map<string, unknown[]>()\n\nconst makeStoreKey = (modelName: string, queryKey: string): string => `${modelName}.${queryKey}`\n\nconst normalizeStringOrNull = (value: unknown): string | null => {\n if (typeof value !== \"string\") return null\n const normalized = value.trim()\n return normalized ? normalized : null\n}\n\nconst parseHydrationData = (value: unknown): StaticRpcbaseRtsHydrationData | null => {\n if (!value || typeof value !== \"object\") return null\n\n const raw = value as {\n v?: unknown\n tenantId?: unknown\n uid?: unknown\n queries?: unknown\n }\n\n if (raw.v !== 1) return null\n if (!Array.isArray(raw.queries)) return null\n\n const queries: RtsSsrHydrationQueryData[] = []\n for (const entry of raw.queries) {\n if (!entry || typeof entry !== \"object\") continue\n\n const query = entry as {\n modelName?: unknown\n queryKey?: unknown\n data?: unknown\n }\n\n const modelName = normalizeStringOrNull(query.modelName)\n const queryKey = normalizeStringOrNull(query.queryKey)\n if (!modelName || !queryKey) continue\n if (!Array.isArray(query.data)) continue\n\n queries.push({\n modelName: modelName as RtsModelName,\n queryKey,\n data: query.data,\n })\n }\n\n return {\n v: 1,\n tenantId: normalizeStringOrNull(raw.tenantId),\n uid: normalizeStringOrNull(raw.uid),\n queries,\n }\n}\n\nexport const hydrateRtsFromWindow = (identity: RtsSsrIdentity): void => {\n if (typeof window === \"undefined\") return\n\n const browserWindow = window as unknown as Record<string, unknown>\n const raw = browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY]\n delete browserWindow[STATIC_RPCBASE_RTS_HYDRATION_DATA_KEY]\n\n const parsed = parseHydrationData(raw)\n if (!parsed) return\n\n if (parsed.tenantId !== identity.tenantId || parsed.uid !== identity.uid) {\n return\n }\n\n hydrationDataStore.clear()\n for (const query of parsed.queries) {\n hydrationDataStore.set(makeStoreKey(query.modelName, query.queryKey), query.data)\n }\n}\n\nexport const peekHydratedRtsQueryData = (\n modelName: RtsModelName,\n queryKey: string,\n): unknown[] | undefined => {\n return hydrationDataStore.get(makeStoreKey(modelName, queryKey))\n}\n\nexport const clearHydratedRtsQueryData = (): void => {\n hydrationDataStore.clear()\n}\n\nconst readRootLikeLoaderData = (): Record<string, unknown> | null => {\n if (typeof window === \"undefined\") return null\n\n const hydration = (window as { __staticRouterHydrationData?: unknown }).__staticRouterHydrationData\n if (!hydration || typeof hydration !== \"object\") return null\n\n const loaderData = (hydration as { loaderData?: unknown }).loaderData\n if (!loaderData || typeof loaderData !== \"object\") return null\n\n const entries = Object.entries(loaderData as Record<string, unknown>)\n let fallback: Record<string, unknown> | null = null\n\n for (const [routeId, data] of entries) {\n if (!data || typeof data !== \"object\" || Array.isArray(data)) continue\n const obj = data as Record<string, unknown>\n const hasTenantId = Object.prototype.hasOwnProperty.call(obj, \"tenantId\")\n const hasUser = Object.prototype.hasOwnProperty.call(obj, \"user\")\n if (!hasTenantId && !hasUser) continue\n\n if (routeId === \"root\") return obj\n if (!fallback) fallback = obj\n }\n\n return fallback\n}\n\nexport const resolveRtsHydrationIdentityFromStaticRouterData = (): RtsSsrIdentity => {\n const rootData = readRootLikeLoaderData()\n if (!rootData) {\n return { tenantId: null, uid: null }\n }\n\n const tenantId = normalizeStringOrNull(rootData.tenantId)\n\n const user = rootData.user\n const userId = user && typeof user === \"object\"\n ? normalizeStringOrNull((user as Record<string, unknown>).id)\n : null\n\n return {\n tenantId,\n uid: userId,\n }\n}\n\nexport const RtsSsrRuntimeProvider = ({\n value,\n children,\n}: {\n value: RtsSsrRuntime\n children: ReactNode\n}) => {\n return (\n <RtsSsrRuntimeContext.Provider value={value}>\n {children}\n </RtsSsrRuntimeContext.Provider>\n )\n}\n\nexport const useRtsSsrRuntime = (): RtsSsrRuntime | null => {\n return useContext(RtsSsrRuntimeContext)\n}\n","type PouchDbStatic = {\n plugin: (plugin: unknown) => void\n prefix?: string\n defaults?: (options: Record<string, unknown>) => PouchDbStatic\n new (name: string, options?: Record<string, unknown>): PouchDbDatabase\n}\n\ntype PouchDbDatabase = {\n find: (options: Record<string, unknown>) => Promise<{ docs: Record<string, unknown>[] }>\n bulkDocs: (docs: Record<string, unknown>[]) => Promise<unknown>\n destroy: () => Promise<unknown>\n}\n\nexport type RtsPouchStoreConfig = {\n tenantId: string\n appName?: string\n prefix?: string\n}\n\nexport type RtsPouchQueryOptions = {\n uid: string\n projection?: Record<string, 0 | 1>\n sort?: Record<string, 1 | -1>\n limit?: number\n}\n\nexport type RtsPouchQueryContext = {\n source: \"cache\"\n}\n\nconst UNDERSCORE_PREFIX = \"$_\"\nconst DEFAULT_FIND_LIMIT = 4096\n\nlet storeConfig: RtsPouchStoreConfig | null = null\n\nlet pouchDbPromise: Promise<PouchDbStatic> | null = null\nlet lastAppliedPrefix: string | null = null\n\nconst collections = new Map<string, PouchDbDatabase>()\nconst dbNamesByPrefix = new Map<string, Set<string>>()\n\nconst unwrapDefault = (mod: unknown): unknown => {\n if (!mod || typeof mod !== \"object\") return mod\n const maybe = mod as { default?: unknown }\n return maybe.default ?? mod\n}\n\nconst ensureBrowser = () => {\n if (typeof window === \"undefined\") {\n throw new Error(\"RTS PouchDB store can only be used in the browser\")\n }\n}\n\nconst computeBasePrefix = ({ tenantId, appName }: { tenantId: string; appName?: string }): string => {\n let prefix = \"rb/\"\n if (appName) prefix += `${appName}/`\n prefix += `${tenantId}/`\n return prefix\n}\n\nconst getDbNamesKey = (prefix: string): string => `rb:rts:pouchDbs:${prefix}`\n\nconst getPrefixOverrideKey = ({ tenantId, appName }: { tenantId: string; appName?: string }): string =>\n `rb:rts:pouchPrefix:${appName ?? \"\"}:${tenantId}`\n\nconst readPrefixOverride = ({ tenantId, appName }: { tenantId: string; appName?: string }): string | null => {\n try {\n const value = window.localStorage.getItem(getPrefixOverrideKey({ tenantId, appName }))\n if (!value) return null\n if (!value.endsWith(\"/\")) return `${value}/`\n return value\n } catch {\n return null\n }\n}\n\nconst getPrefix = (): string => {\n if (!storeConfig) {\n throw new Error(\"RTS PouchDB store is not configured\")\n }\n\n if (storeConfig.prefix) return storeConfig.prefix\n\n const basePrefix = computeBasePrefix({ tenantId: storeConfig.tenantId, appName: storeConfig.appName })\n const override = readPrefixOverride({ tenantId: storeConfig.tenantId, appName: storeConfig.appName })\n return override ?? basePrefix\n}\n\nconst loadDbNames = (prefix: string): Set<string> => {\n const existing = dbNamesByPrefix.get(prefix)\n if (existing) return existing\n\n const names = new Set<string>()\n try {\n const raw = window.localStorage.getItem(getDbNamesKey(prefix))\n if (raw) {\n const parsed = JSON.parse(raw) as unknown\n if (Array.isArray(parsed)) {\n for (const value of parsed) {\n if (typeof value === \"string\" && value) names.add(value)\n }\n }\n }\n } catch {\n return names\n }\n\n dbNamesByPrefix.set(prefix, names)\n return names\n}\n\nconst persistDbNames = (prefix: string, names: Set<string>): void => {\n try {\n if (!names.size) {\n window.localStorage.removeItem(getDbNamesKey(prefix))\n dbNamesByPrefix.delete(prefix)\n return\n }\n\n window.localStorage.setItem(getDbNamesKey(prefix), JSON.stringify(Array.from(names)))\n dbNamesByPrefix.set(prefix, names)\n } catch {\n return\n }\n}\n\nconst registerDbName = (prefix: string, dbName: string): void => {\n if (!prefix || !dbName) return\n const names = loadDbNames(prefix)\n if (names.has(dbName)) return\n names.add(dbName)\n persistDbNames(prefix, names)\n}\n\nconst unregisterDbName = (prefix: string, dbName: string): void => {\n if (!prefix || !dbName) return\n const names = loadDbNames(prefix)\n if (!names.delete(dbName)) return\n persistDbNames(prefix, names)\n}\n\nconst getPouchDb = async (): Promise<PouchDbStatic> => {\n ensureBrowser()\n\n if (!pouchDbPromise) {\n pouchDbPromise = (async () => {\n const [core, indexedDbAdapter, findPlugin] = await Promise.all([\n import(\"pouchdb-core\"),\n import(\"pouchdb-adapter-indexeddb\"),\n import(\"pouchdb-find\"),\n ])\n\n const PouchDB = unwrapDefault(core) as PouchDbStatic\n PouchDB.plugin(unwrapDefault(indexedDbAdapter))\n PouchDB.plugin(unwrapDefault(findPlugin))\n\n return PouchDB\n })()\n }\n\n return pouchDbPromise\n}\n\nconst applyPrefix = (PouchDB: PouchDbStatic) => {\n const prefix = getPrefix()\n if (prefix === lastAppliedPrefix) return\n PouchDB.prefix = prefix\n lastAppliedPrefix = prefix\n}\n\nexport const configureRtsPouchStore = (config: RtsPouchStoreConfig | null) => {\n storeConfig = config\n lastAppliedPrefix = null\n collections.clear()\n}\n\nexport const getCollection = async (modelName: string, options: { uid: string }): Promise<PouchDbDatabase> => {\n const PouchDB = await getPouchDb()\n applyPrefix(PouchDB)\n\n const prefix = getPrefix()\n const dbName = `${options.uid}/${modelName}`\n const dbKey = `${prefix}${dbName}`\n\n const existing = collections.get(dbKey)\n if (existing) return existing\n\n registerDbName(prefix, dbName)\n const db = new PouchDB(dbName, { adapter: \"indexeddb\", revs_limit: 1 }) as PouchDbDatabase\n collections.set(dbKey, db)\n return db\n}\n\nconst replaceQueryKeys = (value: unknown, replaceKey: (key: string) => string): unknown => {\n if (typeof value !== \"object\" || value === null) {\n return value\n }\n\n if (Array.isArray(value)) {\n return value.map((item) => replaceQueryKeys(item, replaceKey))\n }\n\n const obj = value as Record<string, unknown>\n const next: Record<string, unknown> = Object.create(Object.getPrototypeOf(obj))\n\n for (const key of Object.keys(obj)) {\n if (/^\\$/.test(key) || /\\.\\d+$/.test(key)) {\n throw new Error(`replaceQueryKeys: Unexpected key format: ${key}`)\n }\n\n const newKey = replaceKey(key)\n next[newKey] = replaceQueryKeys(obj[key], replaceKey)\n }\n\n return next\n}\n\nconst getKeys = (obj: Record<string, unknown>, parentKey = \"\"): string[] => {\n const keys: string[] = []\n\n for (const key of Object.keys(obj)) {\n const nextKey = parentKey ? `${parentKey}.${key}` : key\n const value = obj[key]\n\n if (typeof value === \"object\" && value !== null && !Array.isArray(value)) {\n keys.push(...getKeys(value as Record<string, unknown>, nextKey))\n } else {\n keys.push(nextKey)\n }\n }\n\n return keys\n}\n\nconst satisfiesProjection = (doc: Record<string, unknown>, projection: Record<string, 0 | 1>): boolean => {\n const docKeys = new Set(getKeys(doc))\n const projectionKeys = new Set(Object.keys(projection).filter((key) => projection[key] === 1))\n\n if (!projectionKeys.has(\"_id\")) {\n docKeys.delete(\"_id\")\n }\n\n if (projectionKeys.size > docKeys.size) return false\n for (const key of projectionKeys) {\n if (!docKeys.has(key)) return false\n }\n return true\n}\n\nconst remapDocFromStorage = (doc: Record<string, unknown>): Record<string, unknown> => {\n const next: Record<string, unknown> = {}\n\n for (const [key, value] of Object.entries(doc)) {\n const newKey = key.startsWith(UNDERSCORE_PREFIX) ? key.replace(/^\\$_/, \"\") : key\n next[newKey] = value\n }\n\n return next\n}\n\nexport const runQuery = async <T extends Record<string, unknown>>({\n modelName,\n query = {},\n options,\n}: {\n modelName: string\n query?: Record<string, unknown>\n options: RtsPouchQueryOptions\n}): Promise<{ data: T[]; context: RtsPouchQueryContext }> => {\n const collection = await getCollection(modelName, { uid: options.uid })\n\n const replacedQuery = replaceQueryKeys(query, (key) =>\n key.startsWith(\"_\") && key !== \"_id\" ? `${UNDERSCORE_PREFIX}${key}` : key,\n ) as Record<string, unknown>\n\n const limit = typeof options.limit === \"number\" ? Math.abs(options.limit) : DEFAULT_FIND_LIMIT\n\n const { docs } = await collection.find({\n selector: replacedQuery,\n limit,\n })\n\n let mappedDocs: T[] = docs.map(({ _rev: _revIgnored, ...rest }) => remapDocFromStorage(rest) as T)\n\n if (options.projection) {\n mappedDocs = mappedDocs.filter((doc) => satisfiesProjection(doc, options.projection!))\n }\n\n if (options.sort) {\n mappedDocs = mappedDocs.sort((a, b) => {\n for (const key of Object.keys(options.sort!)) {\n if (!Object.hasOwn(a, key) || !Object.hasOwn(b, key)) continue\n\n const dir = options.sort![key]\n const aVal = a[key]\n const bVal = b[key]\n\n if (typeof aVal === \"number\" && typeof bVal === \"number\") {\n if (aVal < bVal) return -1 * dir\n if (aVal > bVal) return 1 * dir\n continue\n }\n\n if (typeof aVal === \"string\" && typeof bVal === \"string\") {\n if (aVal < bVal) return -1 * dir\n if (aVal > bVal) return 1 * dir\n continue\n }\n }\n return 0\n })\n }\n\n return { data: mappedDocs, context: { source: \"cache\" } }\n}\n\nexport const updateDocs = async (\n modelName: string,\n data: Array<Record<string, unknown> & { _id: string }>,\n uid: string,\n): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n\n const allIds = data.map((doc) => doc._id).filter(Boolean)\n if (!allIds.length) return\n\n const { docs: currentDocs } = await collection.find({\n selector: { _id: { $in: allIds } },\n fields: [\"_id\", \"_rev\"],\n limit: allIds.length,\n })\n\n const currentDocsById = currentDocs.reduce<Record<string, Record<string, unknown>>>((acc, doc) => {\n const id = String(doc._id ?? \"\")\n if (id) acc[id] = doc\n return acc\n }, {})\n\n const newDocs = data.map((mongoDoc) => {\n const currentDoc = currentDocsById[mongoDoc._id] ?? { _id: mongoDoc._id }\n const nextDoc = Object.entries(mongoDoc).reduce<Record<string, unknown>>((acc, [key, value]) => {\n const newKey = key !== \"_id\" && key.startsWith(\"_\") ? `${UNDERSCORE_PREFIX}${key}` : key\n acc[newKey] = value\n return acc\n }, { ...currentDoc })\n\n const rev = currentDoc._rev\n if (typeof rev === \"string\" && rev) {\n nextDoc._rev = rev\n } else {\n delete nextDoc._rev\n }\n\n return nextDoc\n })\n\n await collection.bulkDocs(newDocs)\n}\n\nexport const deleteDocs = async (modelName: string, ids: string[], uid: string): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n\n const allIds = ids.map((id) => String(id ?? \"\")).filter(Boolean)\n if (!allIds.length) return\n\n const { docs: currentDocs } = await collection.find({\n selector: { _id: { $in: allIds } },\n fields: [\"_id\", \"_rev\"],\n limit: allIds.length,\n })\n\n const deletions = currentDocs\n .map((doc) => ({\n _id: String((doc as { _id?: unknown })?._id ?? \"\"),\n _rev: (doc as { _rev?: unknown })?._rev,\n _deleted: true,\n }))\n .filter((doc) => doc._id && typeof doc._rev === \"string\" && doc._rev)\n\n if (!deletions.length) return\n await collection.bulkDocs(deletions)\n}\n\nexport const destroyCollection = async (modelName: string, uid: string): Promise<void> => {\n const collection = await getCollection(modelName, { uid })\n const prefix = getPrefix()\n const dbName = `${uid}/${modelName}`\n collections.delete(`${prefix}${dbName}`)\n unregisterDbName(prefix, dbName)\n await collection.destroy()\n}\n\nexport const resetRtsPouchStore = ({ tenantId, appName }: { tenantId: string; appName?: string }): string => {\n ensureBrowser()\n const basePrefix = computeBasePrefix({ tenantId, appName })\n const oldPrefix = readPrefixOverride({ tenantId, appName }) ?? basePrefix\n const dbNames = Array.from(loadDbNames(oldPrefix))\n const openDbs = Array.from(collections.entries())\n .filter(([key]) => key.startsWith(oldPrefix))\n .map(([, db]) => db)\n\n void (async () => {\n const remaining = new Set(dbNames)\n\n await Promise.all(openDbs.map((db) => db.destroy().catch(() => {})))\n\n if (remaining.size) {\n const PouchDB = await getPouchDb()\n const PouchDBForPrefix = (PouchDB.defaults?.({}) ?? PouchDB) as PouchDbStatic\n PouchDBForPrefix.prefix = oldPrefix\n\n await Promise.all(Array.from(remaining).map(async (name) => {\n const db = new PouchDBForPrefix(name, { adapter: \"indexeddb\", revs_limit: 1 }) as PouchDbDatabase\n await db.destroy().then(() => {\n remaining.delete(name)\n }).catch(() => {})\n }))\n }\n\n if (remaining.size) {\n persistDbNames(oldPrefix, remaining)\n } else {\n persistDbNames(oldPrefix, new Set())\n }\n })()\n\n const newPrefix = `${basePrefix}reset-${Date.now().toString(16)}/`\n try {\n window.localStorage.setItem(getPrefixOverrideKey({ tenantId, appName }), newPrefix)\n } catch {\n return newPrefix\n }\n\n lastAppliedPrefix = null\n collections.clear()\n return newPrefix\n}\n\nexport const destroyAllCollections = async (): Promise<void> => {\n const dbs = Array.from(collections.values())\n await Promise.all(dbs.map((db) => db.destroy()))\n collections.clear()\n}\n","import type { RtsQueryOptions } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport const computeRtsQueryKey = (query: JsonObject, options: RtsQueryOptions): string => {\n const key = options.key ?? \"\"\n const projection = options.projection ? JSON.stringify(options.projection) : \"\"\n const sort = options.sort ? JSON.stringify(options.sort) : \"\"\n const limit = typeof options.limit === \"number\" ? String(options.limit) : \"\"\n const populate = options.populate ? JSON.stringify(options.populate) : \"\"\n return `${key}${JSON.stringify(query)}${projection}${sort}${limit}${populate}`\n}\n","import { configureRtsPouchStore, deleteDocs, destroyCollection, resetRtsPouchStore, runQuery, updateDocs } from \"./pouchStore\"\nimport type { RtsModelName } from \"./modelTypes\"\nimport { computeRtsQueryKey } from \"./queryKey\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport type RtsPopulateObject = {\n path: string\n model?: string\n select?: string | JsonObject\n match?: JsonObject\n options?: {\n sort?: Record<string, 1 | -1>\n limit?: number\n }\n populate?: RtsPopulateOption\n}\n\nexport type RtsPopulateOption =\n | string\n | RtsPopulateObject\n | Array<string | RtsPopulateObject>\n\nexport type RtsNetworkQueryContext = {\n source: \"network\"\n isLocal: boolean\n txnId?: string\n}\n\nexport type RtsCacheQueryContext = {\n source: \"cache\"\n}\n\nexport type RtsQueryContext = RtsNetworkQueryContext | RtsCacheQueryContext\n\nexport type RtsQueryOptions = {\n key?: string\n projection?: Record<string, 0 | 1>\n sort?: Record<string, 1 | -1>\n limit?: number\n populate?: RtsPopulateOption\n}\n\nexport type RtsConnectOptions = {\n url?: string\n path?: string\n appName?: string\n configureStore?: boolean\n syncChanges?: boolean\n reconnect?: {\n attempts?: number\n delayMs?: number\n delayMaxMs?: number\n }\n}\n\ntype QueryCallback = (error: unknown | null, data: unknown, context: RtsQueryContext) => void\n\ntype QuerySubscription = {\n modelName: RtsModelName\n query: JsonObject\n options: RtsQueryOptions\n queryKey: string\n runInitialNetworkQuery: boolean\n}\n\ntype ServerMessage =\n | { type: \"query-payload\"; modelName: string; queryKey: string; data?: unknown; error?: string; txnId?: string }\n | { type: \"event\"; event: string; payload?: unknown }\n\ntype ClientMessage =\n | { type: \"run-query\"; modelName: string; queryKey: string; query: JsonObject; options?: RtsQueryOptions }\n | {\n type: \"register-query\"\n modelName: string\n queryKey: string\n query: JsonObject\n options?: RtsQueryOptions\n runInitialQuery?: boolean\n }\n | { type: \"remove-query\"; modelName: string; queryKey: string }\n | { type: \"event\"; event: string; payload?: unknown }\n\ntype DocWithId = Record<string, unknown> & { _id: string }\ntype SyncChangesPayload = {\n ok?: unknown\n latestSeq?: unknown\n needsFullResync?: unknown\n changes?: unknown\n}\ntype RawSyncChangeRecord = {\n seq?: unknown\n modelName?: unknown\n op?: unknown\n docId?: unknown\n}\n\nconst TENANT_ID_QUERY_PARAM = \"rb-tenant-id\"\nconst RTS_CHANGES_ROUTE = \"/api/rb/rts/changes\"\nconst MAX_TXN_BUF = 2048\nconst SERVER_RECONNECT_DELAY_MIN_MS = 10_000\nconst SERVER_RECONNECT_DELAY_MAX_MS = 15_000\n\nlet socket: WebSocket | null = null\nlet connectPromise: Promise<void> | null = null\nlet explicitDisconnect = false\n\nlet currentTenantId: string | null = null\nlet currentUid: string | null = null\nlet connectOptions: RtsConnectOptions = {}\n\nconst localTxnBuf: string[] = []\n\nconst queryCallbacks = new Map<string, Set<QueryCallback>>()\nconst subscriptions = new Map<string, QuerySubscription>()\nconst messageCallbacks = new Map<string, Set<(payload: unknown) => void>>()\n\nlet reconnectTimer: number | null = null\nlet reconnectAttempts = 0\nlet hasEstablishedConnection = false\nlet pendingServerReconnectJitter = false\n\nlet syncPromise: Promise<void> | null = null\nlet syncKey: string | null = null\n\nconst ensureBrowser = () => {\n if (typeof window === \"undefined\") {\n throw new Error(\"RTS websocket client can only be used in the browser\")\n }\n}\n\nconst buildSocketUrl = (tenantId: string, _uid: string, options: RtsConnectOptions): string => {\n if (options.url) {\n const url = new URL(options.url)\n url.searchParams.set(TENANT_ID_QUERY_PARAM, tenantId)\n return url.toString()\n }\n\n const base = new URL(window.location.href)\n base.protocol = base.protocol === \"https:\" ? \"wss:\" : \"ws:\"\n base.pathname = options.path ?? \"/rts\"\n base.search = \"\"\n base.hash = \"\"\n base.searchParams.set(TENANT_ID_QUERY_PARAM, tenantId)\n return base.toString()\n}\n\nconst sendToServer = (message: ClientMessage): void => {\n if (!socket) return\n if (socket.readyState !== WebSocket.OPEN) return\n socket.send(JSON.stringify(message))\n}\n\nconst resubscribeAll = ({ forceInitialQuery }: { forceInitialQuery: boolean }): void => {\n for (const sub of subscriptions.values()) {\n const runInitialQuery = forceInitialQuery || sub.runInitialNetworkQuery\n sendToServer({\n type: \"register-query\",\n modelName: sub.modelName,\n queryKey: sub.queryKey,\n query: sub.query,\n options: sub.options,\n runInitialQuery,\n })\n }\n}\n\nconst clearReconnectTimer = () => {\n if (reconnectTimer === null) return\n if (typeof window !== \"undefined\") {\n window.clearTimeout(reconnectTimer)\n }\n reconnectTimer = null\n}\n\nconst scheduleReconnect = () => {\n clearReconnectTimer()\n if (explicitDisconnect) {\n pendingServerReconnectJitter = false\n return\n }\n if (!currentTenantId || !currentUid) return\n\n const cfg = connectOptions.reconnect ?? {}\n const maxAttempts = cfg.attempts ?? 128\n const delayMs = cfg.delayMs ?? 400\n const delayMaxMs = cfg.delayMaxMs ?? 10_000\n\n if (reconnectAttempts >= maxAttempts) return\n\n let delay = Math.min(delayMaxMs, delayMs * Math.pow(2, reconnectAttempts))\n if (pendingServerReconnectJitter) {\n const span = SERVER_RECONNECT_DELAY_MAX_MS - SERVER_RECONNECT_DELAY_MIN_MS\n delay = SERVER_RECONNECT_DELAY_MIN_MS + Math.floor(Math.random() * (span + 1))\n pendingServerReconnectJitter = false\n }\n reconnectAttempts += 1\n reconnectTimer = window.setTimeout(() => {\n void connectInternal(currentTenantId!, currentUid!, connectOptions, { resetReconnectAttempts: false })\n }, delay)\n}\n\nconst isDocWithId = (doc: unknown): doc is DocWithId => {\n if (!doc || typeof doc !== \"object\") return false\n return typeof (doc as { _id?: unknown })._id === \"string\"\n}\n\nconst handleQueryPayload = (payload: Extract<ServerMessage, { type: \"query-payload\" }>) => {\n const { modelName, queryKey, data, error, txnId } = payload\n const cbKey = `${modelName}.${queryKey}`\n const callbacks = queryCallbacks.get(cbKey)\n if (!callbacks || !callbacks.size) return\n const subscription = subscriptions.get(cbKey)\n const hasPopulate = Boolean(subscription?.options?.populate)\n\n const isLocal = !!(txnId && localTxnBuf.includes(txnId))\n const context: RtsNetworkQueryContext = { source: \"network\", isLocal, txnId }\n\n if (error) {\n for (const cb of callbacks) cb(error, undefined, context)\n return\n }\n\n for (const cb of callbacks) cb(null, data, context)\n\n if (!currentUid) return\n\n const docs = Array.isArray(data) ? data.filter(isDocWithId) : []\n\n if (!docs.length) return\n if (hasPopulate) return\n\n void updateDocs(modelName, docs, currentUid)\n .catch(() => {})\n}\n\nconst handleEvent = (payload: Extract<ServerMessage, { type: \"event\" }>) => {\n const callbacks = messageCallbacks.get(payload.event)\n if (!callbacks || !callbacks.size) return\n for (const cb of callbacks) cb(payload.payload)\n}\n\nconst handleMessage = (event: MessageEvent) => {\n let parsed: unknown\n try {\n parsed = JSON.parse(typeof event.data === \"string\" ? event.data : String(event.data))\n } catch {\n return\n }\n\n if (!parsed || typeof parsed !== \"object\") return\n const message = parsed as ServerMessage\n\n if (message.type === \"query-payload\") {\n handleQueryPayload(message)\n return\n }\n\n if (message.type === \"event\") {\n handleEvent(message)\n }\n}\n\nexport const addLocalTxn = (txnId: string): void => {\n if (!txnId) return\n localTxnBuf.push(txnId)\n if (localTxnBuf.length > MAX_TXN_BUF) {\n localTxnBuf.shift()\n }\n}\n\ntype RtsChangeRecord = {\n seq: number\n modelName: string\n op: \"delete\" | \"reset_model\"\n docId?: string\n}\n\nconst getSyncStorageKey = ({ tenantId, uid, appName }: { tenantId: string; uid: string; appName?: string }): string =>\n `rb:rts:changesSeq:${appName ?? \"\"}:${tenantId}:${uid}`\n\nconst readStoredSeq = (key: string): number => {\n try {\n const raw = window.localStorage.getItem(key)\n const num = raw ? Number(raw) : 0\n return Number.isFinite(num) && num >= 0 ? Math.floor(num) : 0\n } catch {\n return 0\n }\n}\n\nconst writeStoredSeq = (key: string, value: number): void => {\n try {\n window.localStorage.setItem(key, String(Math.max(0, Math.floor(value))))\n } catch {\n return\n }\n}\n\nconst applyChangeBatch = async (changes: RtsChangeRecord[], uid: string): Promise<void> => {\n const resetModels = new Set<string>()\n const deletesByModel = new Map<string, string[]>()\n\n for (const change of changes) {\n const modelName = typeof change.modelName === \"string\" ? change.modelName : \"\"\n if (!modelName) continue\n\n if (change.op === \"reset_model\") {\n resetModels.add(modelName)\n continue\n }\n\n if (change.op === \"delete\") {\n const docId = typeof change.docId === \"string\" ? change.docId : \"\"\n if (!docId) continue\n const existing = deletesByModel.get(modelName) ?? []\n existing.push(docId)\n deletesByModel.set(modelName, existing)\n }\n }\n\n for (const modelName of resetModels) {\n await destroyCollection(modelName, uid).catch(() => {})\n }\n\n for (const [modelName, ids] of deletesByModel.entries()) {\n if (resetModels.has(modelName)) continue\n await deleteDocs(modelName, ids, uid).catch(() => {})\n }\n}\n\nexport const syncRtsChanges = async (tenantId: string, uid: string, options: Pick<RtsConnectOptions, \"appName\"> = {}): Promise<void> => {\n ensureBrowser()\n if (!tenantId || !uid) return\n\n const storageKey = getSyncStorageKey({ tenantId, uid, appName: options.appName })\n let sinceSeq = readStoredSeq(storageKey)\n\n for (let i = 0; i < 32; i += 1) {\n const url = `${RTS_CHANGES_ROUTE}?${TENANT_ID_QUERY_PARAM}=${encodeURIComponent(tenantId)}`\n const response = await fetch(url, {\n method: \"POST\",\n credentials: \"include\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ sinceSeq, limit: 2000 }),\n })\n\n if (!response.ok) return\n\n const payload: unknown = await response.json().catch(() => null)\n if (!payload || typeof payload !== \"object\") return\n const payloadObj = payload as SyncChangesPayload\n const ok = payloadObj.ok\n if (ok !== true) return\n\n const latestSeq = Number(payloadObj.latestSeq ?? 0)\n const needsFullResync = Boolean(payloadObj.needsFullResync)\n\n if (needsFullResync) {\n resetRtsPouchStore({ tenantId, appName: options.appName })\n writeStoredSeq(storageKey, latestSeq)\n return\n }\n\n const changesRaw = payloadObj.changes\n const changes = Array.isArray(changesRaw) ? changesRaw : []\n const normalized = changes\n .map((c): RtsChangeRecord | null => {\n if (!c || typeof c !== \"object\") return null\n const obj = c as RawSyncChangeRecord\n\n const seq = Number(obj.seq ?? 0)\n const modelName = typeof obj.modelName === \"string\" ? obj.modelName : String(obj.modelName ?? \"\")\n const op = obj.op === \"reset_model\" ? \"reset_model\" : \"delete\"\n const docId = typeof obj.docId === \"string\" && obj.docId ? obj.docId : obj.docId ? String(obj.docId) : undefined\n\n return { seq, modelName, op, ...(docId ? { docId } : {}) }\n })\n .filter((c): c is RtsChangeRecord => c !== null)\n .filter((c: RtsChangeRecord) =>\n Number.isFinite(c.seq) && c.seq > 0 && c.modelName && (c.op === \"reset_model\" || !!c.docId),\n )\n\n if (!normalized.length) {\n writeStoredSeq(storageKey, latestSeq)\n return\n }\n\n await applyChangeBatch(normalized, uid)\n\n const lastSeq = normalized.reduce((max, c) => (c.seq > max ? c.seq : max), sinceSeq)\n sinceSeq = lastSeq\n writeStoredSeq(storageKey, sinceSeq)\n\n if (latestSeq > 0 && sinceSeq >= latestSeq) {\n return\n }\n }\n}\n\nconst ensureSynced = (tenantId: string, uid: string, options: RtsConnectOptions): void => {\n if (options.syncChanges === false) return\n const key = `${options.appName ?? \"\"}:${tenantId}:${uid}`\n if (syncPromise && syncKey === key) return\n\n syncKey = key\n syncPromise = syncRtsChanges(tenantId, uid, { appName: options.appName })\n .catch(() => {})\n .finally(() => {\n if (syncKey === key) {\n syncPromise = null\n }\n })\n}\n\nconst connectInternal = (\n tenantId: string,\n uid: string,\n options: RtsConnectOptions,\n { resetReconnectAttempts }: { resetReconnectAttempts: boolean },\n): Promise<void> => {\n ensureBrowser()\n\n if (!tenantId) return Promise.resolve()\n if (!uid) throw new Error(\"Missing uid\")\n\n currentTenantId = tenantId\n currentUid = uid\n connectOptions = options\n\n if (options.configureStore !== false) {\n configureRtsPouchStore({ tenantId, appName: options.appName })\n }\n ensureSynced(tenantId, uid, options)\n\n if (socket && (socket.readyState === WebSocket.OPEN || socket.readyState === WebSocket.CONNECTING)) {\n return connectPromise ?? Promise.resolve()\n }\n\n explicitDisconnect = false\n clearReconnectTimer()\n\n const url = buildSocketUrl(tenantId, uid, options)\n\n connectPromise = new Promise((resolve, reject) => {\n if (resetReconnectAttempts) reconnectAttempts = 0\n\n let opened = false\n let settled = false\n socket = new WebSocket(url)\n\n socket.addEventListener(\"open\", () => {\n opened = true\n settled = true\n reconnectAttempts = 0\n pendingServerReconnectJitter = false\n const forceInitialQuery = hasEstablishedConnection\n resubscribeAll({ forceInitialQuery })\n hasEstablishedConnection = true\n resolve()\n })\n\n socket.addEventListener(\"message\", handleMessage)\n\n socket.addEventListener(\"close\", (event) => {\n if (!opened && !settled) {\n settled = true\n reject(new Error(`RTS WebSocket closed before opening (code=${event.code})`))\n }\n if (!explicitDisconnect) {\n pendingServerReconnectJitter = opened\n }\n\n socket = null\n connectPromise = null\n scheduleReconnect()\n })\n\n socket.addEventListener(\"error\", (err) => {\n if (settled) return\n settled = true\n reject(err instanceof Error ? err : new Error(\"RTS WebSocket error\"))\n })\n })\n\n return connectPromise\n}\n\nexport const connect = (tenantId: string, uid: string, options: RtsConnectOptions = {}): Promise<void> => {\n return connectInternal(tenantId, uid, options, { resetReconnectAttempts: true })\n}\n\nexport const disconnect = (): void => {\n explicitDisconnect = true\n clearReconnectTimer()\n hasEstablishedConnection = false\n pendingServerReconnectJitter = false\n if (socket) {\n try {\n socket.close()\n } catch {\n // ignore\n }\n }\n socket = null\n connectPromise = null\n}\n\nexport const reconnect = (tenantId: string, uid: string, options: RtsConnectOptions = {}): Promise<void> => {\n explicitDisconnect = true\n clearReconnectTimer()\n pendingServerReconnectJitter = false\n if (socket) {\n try {\n socket.close()\n } catch {\n // ignore\n }\n }\n socket = null\n connectPromise = null\n return connect(tenantId, uid, options)\n}\n\nexport const registerQuery = (\n modelName: RtsModelName,\n query: JsonObject,\n optionsOrCallback?: RtsQueryOptions | QueryCallback,\n callbackMaybe?: QueryCallback,\n behavior?: {\n runInitialNetworkQuery?: boolean\n },\n): (() => void) | undefined => {\n let options: RtsQueryOptions\n let callback: QueryCallback | undefined\n\n if (typeof optionsOrCallback === \"function\") {\n options = {}\n callback = optionsOrCallback\n } else {\n options = optionsOrCallback ?? {}\n callback = callbackMaybe\n }\n\n if (!callback) return undefined\n if (typeof modelName !== \"string\" || modelName.trim().length === 0) {\n throw new Error(\"registerQuery: modelName must be a non-empty string\")\n }\n\n const queryKey = computeRtsQueryKey(query, options)\n const cbKey = `${modelName}.${queryKey}`\n const runInitialNetworkQuery = behavior?.runInitialNetworkQuery !== false\n\n const set = queryCallbacks.get(cbKey) ?? new Set<QueryCallback>()\n set.add(callback)\n queryCallbacks.set(cbKey, set)\n\n subscriptions.set(cbKey, { modelName, query, options, queryKey, runInitialNetworkQuery })\n\n if (currentUid) {\n void runQuery({\n modelName,\n query,\n options: {\n uid: currentUid,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n },\n }).then(({ data, context }) => {\n callback?.(null, data, context)\n }).catch(() => {\n // ignore\n })\n }\n\n sendToServer({ type: \"register-query\", modelName, queryKey, query, options, runInitialQuery: runInitialNetworkQuery })\n\n return () => {\n sendToServer({ type: \"remove-query\", modelName, queryKey })\n\n const callbacks = queryCallbacks.get(cbKey)\n callbacks?.delete(callback!)\n if (callbacks && callbacks.size === 0) {\n queryCallbacks.delete(cbKey)\n subscriptions.delete(cbKey)\n }\n }\n}\n\nexport const sendMessage = (event: string, payload?: unknown): void => {\n sendToServer({ type: \"event\", event, payload })\n}\n\nexport const onMessage = (event: string, callback: (payload: unknown) => void): (() => void) => {\n const set = messageCallbacks.get(event) ?? new Set()\n set.add(callback)\n messageCallbacks.set(event, set)\n\n return () => {\n const callbacks = messageCallbacks.get(event)\n callbacks?.delete(callback)\n if (callbacks && callbacks.size === 0) messageCallbacks.delete(event)\n }\n}\n","import { useEffect, useId, useMemo, useRef, useState } from \"react\"\n\nimport type { RtsModelName } from \"./modelTypes\"\nimport { computeRtsQueryKey } from \"./queryKey\"\nimport { peekHydratedRtsQueryData, useRtsSsrRuntime } from \"./ssrHydration\"\nimport type { RtsQueryContext, RtsQueryOptions } from \"./wsClient\"\nimport { registerQuery } from \"./wsClient\"\n\n\ntype JsonObject = Record<string, unknown>\n\nexport type UseRtsQueryOptions = RtsQueryOptions & {\n enabled?: boolean\n skipLocal?: boolean\n ssr?: \"auto\" | boolean\n refreshOnMount?: boolean\n}\n\nexport type UseRtsQueryResult<T> = {\n data: T[] | undefined\n source: RtsQueryContext[\"source\"] | undefined\n error: unknown | undefined\n loading: boolean\n}\n\nexport const useQuery = <T extends Record<string, unknown> = Record<string, unknown>>(\n modelName: RtsModelName,\n query: JsonObject = {},\n options: UseRtsQueryOptions = {},\n): UseRtsQueryResult<T> => {\n if (typeof modelName !== \"string\" || modelName.trim().length === 0) {\n throw new Error(\"useQuery: modelName must be a non-empty string\")\n }\n\n const id = useId()\n\n const enabled = options.enabled ?? true\n const ssrEnabled = options.ssr !== false\n const refreshOnMount = options.refreshOnMount === true\n const key = options.key ?? id\n const queryJson = JSON.stringify(query)\n const projectionJson = options.projection ? JSON.stringify(options.projection) : \"\"\n const sortJson = options.sort ? JSON.stringify(options.sort) : \"\"\n const limitStr = typeof options.limit === \"number\" ? String(options.limit) : \"\"\n const populateJson = options.populate ? JSON.stringify(options.populate) : \"\"\n const queryKey = computeRtsQueryKey(query, {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n })\n\n const ssrRuntime = useRtsSsrRuntime()\n if (enabled && ssrEnabled && ssrRuntime) {\n ssrRuntime.registerQuery({\n modelName,\n query,\n options: {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n },\n queryKey,\n })\n }\n\n const seedDataRaw = enabled && ssrEnabled\n ? ssrRuntime\n ? ssrRuntime.getQueryData(modelName, queryKey)\n : peekHydratedRtsQueryData(modelName, queryKey)\n : undefined\n\n const hasSeedData = Array.isArray(seedDataRaw)\n const seedData = hasSeedData ? seedDataRaw as T[] : undefined\n const seedJson = (() => {\n if (!hasSeedData) return \"\"\n try {\n return JSON.stringify(seedDataRaw)\n } catch {\n return \"\"\n }\n })()\n\n const [data, setData] = useState<T[] | undefined>(() => seedData)\n const [source, setSource] = useState<RtsQueryContext[\"source\"] | undefined>(() => (hasSeedData ? \"cache\" : undefined))\n const [error, setError] = useState<unknown | undefined>(undefined)\n const [loading, setLoading] = useState<boolean>(enabled && !hasSeedData)\n\n const hasFirstReply = useRef(false)\n const hasNetworkReply = useRef(false)\n const lastDataJsonRef = useRef<string>(\"\")\n\n useEffect(() => {\n hasFirstReply.current = hasSeedData\n hasNetworkReply.current = false\n lastDataJsonRef.current = seedJson\n setError(undefined)\n\n if (!enabled) {\n setLoading(false)\n setData(undefined)\n setSource(undefined)\n return\n }\n\n if (hasSeedData) {\n setLoading(false)\n setData(seedData)\n setSource(\"cache\")\n return\n }\n\n setLoading(true)\n }, [enabled, modelName, queryKey, hasSeedData, seedData, seedJson])\n\n useEffect(() => {\n if (!enabled) return\n\n const runInitialNetworkQuery = refreshOnMount || !hasSeedData\n\n const unsubscribe = registerQuery(\n modelName,\n query,\n {\n key,\n projection: options.projection,\n sort: options.sort,\n limit: options.limit,\n populate: options.populate,\n },\n (err, result, context) => {\n if (context.source === \"cache\" && hasNetworkReply.current) return\n\n if (context.source === \"network\") {\n hasNetworkReply.current = true\n }\n\n setLoading(false)\n\n if (err) {\n setError(err)\n return\n }\n\n if (!Array.isArray(result)) return\n\n if (context.source === \"network\" && context.isLocal && options.skipLocal && hasFirstReply.current) {\n return\n }\n\n hasFirstReply.current = true\n\n let nextJson = \"\"\n try {\n nextJson = JSON.stringify(result)\n } catch {\n nextJson = \"\"\n }\n\n if (nextJson && nextJson === lastDataJsonRef.current) {\n setSource(context.source)\n return\n }\n\n lastDataJsonRef.current = nextJson\n setSource(context.source)\n setData(result as T[])\n },\n {\n runInitialNetworkQuery,\n },\n )\n\n return () => {\n unsubscribe?.()\n }\n }, [enabled, modelName, queryKey, queryJson, projectionJson, sortJson, limitStr, populateJson, hasSeedData, refreshOnMount])\n\n return useMemo(\n () => ({\n data,\n source,\n error,\n loading,\n }),\n [data, source, error, loading],\n )\n}\n"],"names":["ensureBrowser"],"mappings":"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"}
|