@powerhousedao/reactor-browser 6.0.2-staging.5 → 6.0.2-staging.7
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/{client-K2ycBgUP.d.ts → client-DhQo2Vi9.d.ts} +24 -2
- package/dist/client-DhQo2Vi9.d.ts.map +1 -0
- package/dist/{document-by-id-CDLUqru5.js → document-by-id-DuujBqAQ.js} +52 -6
- package/dist/document-by-id-DuujBqAQ.js.map +1 -0
- package/dist/index.d.ts +226 -87
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +695 -151
- package/dist/index.js.map +1 -1
- package/dist/src/analytics/index.js +1 -1
- package/dist/src/graphql/client.d.ts +1 -1
- package/package.json +12 -9
- package/dist/client-K2ycBgUP.d.ts.map +0 -1
- package/dist/document-by-id-CDLUqru5.js.map +0 -1
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
1
2
|
import { GraphQLClient, RequestOptions } from "graphql-request";
|
|
2
3
|
|
|
3
4
|
//#region src/graphql/gen/schema.d.ts
|
|
@@ -758,6 +759,13 @@ declare function getSdk(client: GraphQLClient, withWrapper?: SdkFunctionWrapper)
|
|
|
758
759
|
};
|
|
759
760
|
type Sdk = ReturnType<typeof getSdk>;
|
|
760
761
|
//#endregion
|
|
762
|
+
//#region src/graphql/constants.d.ts
|
|
763
|
+
declare const DEFAULT_DRIVE_ID: "powerhouse";
|
|
764
|
+
declare const DEFAULT_SWITCHBOARD_URL: "http://localhost:4001/graphql";
|
|
765
|
+
declare const graphqlEventsToSyncDrive: readonly ["CreateEmptyDocument", "CreateDocument", "AddChildren", "RemoveChildren", "MoveChildren", "DeleteDocument", "DeleteDocuments"];
|
|
766
|
+
declare const graphqlDocumentEvents: readonly ["MutateDocument", "MutateDocumentAsync", "DeleteDocument"];
|
|
767
|
+
declare const graphqlDocumentsEvents: readonly ["DeleteDocuments"];
|
|
768
|
+
//#endregion
|
|
761
769
|
//#region src/graphql/types.d.ts
|
|
762
770
|
type DocumentOperationsPage = GetDocumentOperationsQuery["documentOperations"];
|
|
763
771
|
type DocumentResult = NonNullable<GetDocumentQuery["document"]>;
|
|
@@ -768,6 +776,20 @@ type ReactorGraphQLClient = Sdk & {
|
|
|
768
776
|
operations: DocumentOperationsPage[];
|
|
769
777
|
}>;
|
|
770
778
|
};
|
|
779
|
+
type GraphQLClientDocumentEvent = CustomEvent<{
|
|
780
|
+
identifier: string;
|
|
781
|
+
}>;
|
|
782
|
+
type GraphQLClientDocumentsEvent = CustomEvent<{
|
|
783
|
+
identifiers: string[];
|
|
784
|
+
}>;
|
|
785
|
+
type GraphQLDocumentEventOperationName = (typeof graphqlDocumentEvents)[number];
|
|
786
|
+
type GraphQLDocumentEventsOperationName = (typeof graphqlDocumentsEvents)[number];
|
|
787
|
+
type GraphQLDocumentEvents = Record<GraphQLDocumentEventOperationName, GraphQLClientDocumentEvent>;
|
|
788
|
+
type GraphQLDocumentsEvents = Record<GraphQLDocumentEventsOperationName, GraphQLClientDocumentsEvent>;
|
|
789
|
+
type GraphQLClientWindowEvents = GraphQLDocumentEvents & GraphQLDocumentsEvents;
|
|
790
|
+
type TStateSchemaZodObject = z.ZodObject<{
|
|
791
|
+
state: z.ZodObject;
|
|
792
|
+
}>;
|
|
771
793
|
//#endregion
|
|
772
794
|
//#region src/graphql/client.d.ts
|
|
773
795
|
/**
|
|
@@ -778,5 +800,5 @@ type ReactorGraphQLClient = Sdk & {
|
|
|
778
800
|
*/
|
|
779
801
|
declare function createClient(urlOrGQLClient: string | GraphQLClient, middleware?: SdkFunctionWrapper): ReactorGraphQLClient;
|
|
780
802
|
//#endregion
|
|
781
|
-
export {
|
|
782
|
-
//# sourceMappingURL=client-
|
|
803
|
+
export { PhDocumentFieldsFragment as C, MutateDocumentMutation as S, Scalars as T, DeleteDocumentMutation as _, GraphQLDocumentEventOperationName as a, GetDocumentOperationsQuery as b, GraphQLDocumentsEvents as c, DEFAULT_DRIVE_ID as d, DEFAULT_SWITCHBOARD_URL as f, CreateDocumentMutation as g, graphqlEventsToSyncDrive as h, GraphQLClientWindowEvents as i, ReactorGraphQLClient as l, graphqlDocumentsEvents as m, GraphQLClientDocumentEvent as n, GraphQLDocumentEvents as o, graphqlDocumentEvents as p, GraphQLClientDocumentsEvent as r, GraphQLDocumentEventsOperationName as s, createClient as t, TStateSchemaZodObject as u, DeleteDocumentsMutation as v, PropagationMode as w, GetDocumentWithOperationsQuery as x, FindDocumentsQuery as y };
|
|
804
|
+
//# sourceMappingURL=client-DhQo2Vi9.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-DhQo2Vi9.d.ts","names":[],"sources":["../src/graphql/gen/schema.ts","../src/graphql/constants.ts","../src/graphql/types.ts","../src/graphql/client.ts"],"mappings":"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"}
|
|
@@ -190,6 +190,20 @@ function readPromiseState(promise) {
|
|
|
190
190
|
return "status" in promise ? promise : { status: "pending" };
|
|
191
191
|
}
|
|
192
192
|
/**
|
|
193
|
+
* Resolves an array of document promises using `Promise.allSettled`,
|
|
194
|
+
* returning only the fulfilled values. A single missing/rejected
|
|
195
|
+
* document does not poison the whole batch. Rejected entries are
|
|
196
|
+
* logged at warn level so developers can see dangling references.
|
|
197
|
+
*/
|
|
198
|
+
function fulfilledOnly(promises) {
|
|
199
|
+
return Promise.allSettled(promises).then((results) => {
|
|
200
|
+
const documents = [];
|
|
201
|
+
for (const result of results) if (result.status === "fulfilled") documents.push(result.value);
|
|
202
|
+
else console.warn("[DocumentCache] Skipped unavailable document:", result.reason);
|
|
203
|
+
return documents;
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
193
207
|
* Document cache implementation that uses the new ReactorClient API.
|
|
194
208
|
*
|
|
195
209
|
* This cache subscribes to document change events via IReactorClient.subscribe()
|
|
@@ -245,7 +259,7 @@ var DocumentCache = class {
|
|
|
245
259
|
const hasDeletedDocuments = ids.some((id) => !this.documents.has(id));
|
|
246
260
|
const currentPromises = ids.map((id) => this.get(id));
|
|
247
261
|
if (hasDeletedDocuments) {
|
|
248
|
-
const batchPromise =
|
|
262
|
+
const batchPromise = fulfilledOnly(currentPromises);
|
|
249
263
|
this.batchPromises.set(key, {
|
|
250
264
|
promises: currentPromises,
|
|
251
265
|
promise: batchPromise
|
|
@@ -256,8 +270,8 @@ var DocumentCache = class {
|
|
|
256
270
|
if (currentPromises.every((p, i) => p === cached.promises[i])) return cached.promise;
|
|
257
271
|
}
|
|
258
272
|
const states = currentPromises.map((p) => readPromiseState(p));
|
|
259
|
-
if (states.every((s) => s.status
|
|
260
|
-
const values = states.map((s) => s.value);
|
|
273
|
+
if (states.every((s) => s.status !== "pending")) {
|
|
274
|
+
const values = states.filter((s) => s.status === "fulfilled").map((s) => s.value);
|
|
261
275
|
const batchPromise = Promise.resolve(values);
|
|
262
276
|
batchPromise.status = "fulfilled";
|
|
263
277
|
batchPromise.value = values;
|
|
@@ -268,7 +282,7 @@ var DocumentCache = class {
|
|
|
268
282
|
return batchPromise;
|
|
269
283
|
}
|
|
270
284
|
if (cached) return cached.promise;
|
|
271
|
-
const batchPromise =
|
|
285
|
+
const batchPromise = fulfilledOnly(currentPromises);
|
|
272
286
|
this.batchPromises.set(key, {
|
|
273
287
|
promises: currentPromises,
|
|
274
288
|
promise: batchPromise
|
|
@@ -347,6 +361,38 @@ function useDocument(id) {
|
|
|
347
361
|
return document ? use(document) : void 0;
|
|
348
362
|
}
|
|
349
363
|
/**
|
|
364
|
+
* Retrieves a document from the reactor and subscribes to changes without
|
|
365
|
+
* suspending or throwing. Use this when the ID might be stale (e.g., a
|
|
366
|
+
* previously selected node that has since been deleted) and the consumer
|
|
367
|
+
* wants to render a placeholder instead of crashing.
|
|
368
|
+
*
|
|
369
|
+
* Unlike {@link useGetDocumentAsync}, this hook subscribes to cache
|
|
370
|
+
* updates, so the returned state stays in sync with reactor changes.
|
|
371
|
+
*
|
|
372
|
+
* @param id - The document ID to retrieve, or null/undefined to skip retrieval
|
|
373
|
+
* @returns An object containing:
|
|
374
|
+
* - status: "initial" | "pending" | "success" | "error"
|
|
375
|
+
* - data: The document if successfully loaded
|
|
376
|
+
* - isPending: Whether the document is currently loading
|
|
377
|
+
* - error: Any error that occurred during loading (e.g., document not found)
|
|
378
|
+
* - reload: Function to force a refetch, or undefined when no id is supplied
|
|
379
|
+
*/
|
|
380
|
+
function useDocumentSafe(id) {
|
|
381
|
+
const documentCache = useDocumentCache();
|
|
382
|
+
const promise = useSyncExternalStore((cb) => id && documentCache ? documentCache.subscribe(id, cb) : () => {}, () => id ? documentCache?.get(id) : void 0);
|
|
383
|
+
if (!promise || !documentCache || !id) return {
|
|
384
|
+
status: "initial",
|
|
385
|
+
isPending: false,
|
|
386
|
+
error: void 0,
|
|
387
|
+
data: void 0,
|
|
388
|
+
reload: void 0
|
|
389
|
+
};
|
|
390
|
+
return {
|
|
391
|
+
...getDocumentQueryState(promise),
|
|
392
|
+
reload: () => documentCache.get(id, true)
|
|
393
|
+
};
|
|
394
|
+
}
|
|
395
|
+
/**
|
|
350
396
|
* Retrieves multiple documents from the reactor using React Suspense.
|
|
351
397
|
* This hook will suspend rendering while any of the documents are loading.
|
|
352
398
|
*
|
|
@@ -436,6 +482,6 @@ function useDocumentsByIds(ids) {
|
|
|
436
482
|
return useDocuments(ids);
|
|
437
483
|
}
|
|
438
484
|
//#endregion
|
|
439
|
-
export {
|
|
485
|
+
export { queueOperations as C, queueActions as S, getAnalyticsStore as _, setDocumentCache as a, setGlobal as b, useDocumentSafe as c, useGetDocumentAsync as d, useGetDocuments as f, createAnalyticsStore as g, readPromiseState as h, addDocumentCacheEventHandler as i, useDocuments as l, addPromiseState as m, useDocumentsByIds as n, useDocument as o, DocumentCache as p, useDispatch as r, useDocumentCache as s, useDocumentById as t, useGetDocument as u, clearGlobal as v, uploadOperations as w, dispatchActions as x, getGlobal as y };
|
|
440
486
|
|
|
441
|
-
//# sourceMappingURL=document-by-id-
|
|
487
|
+
//# sourceMappingURL=document-by-id-DuujBqAQ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"document-by-id-DuujBqAQ.js","names":[],"sources":["../src/actions/queue.ts","../src/actions/sign.ts","../src/actions/dispatch.ts","../src/global/core.ts","../src/analytics/store.ts","../src/document-cache.ts","../src/hooks/document-cache.ts","../src/hooks/dispatch.ts","../src/hooks/document-by-id.ts"],"sourcesContent":["import type { FileUploadProgressCallback } from \"@powerhousedao/reactor-browser\";\nimport type {\n Action,\n DocumentOperations,\n Operation,\n PHDocument,\n} from \"@powerhousedao/shared/document-model\";\nimport { logger } from \"document-model\";\n\nexport async function queueActions(\n document: PHDocument | undefined,\n actionOrActions: Action[] | Action | undefined,\n) {\n if (!document) {\n throw new Error(\"No document provided\");\n }\n if (!actionOrActions) {\n throw new Error(\"No actions provided\");\n }\n const actions = Array.isArray(actionOrActions)\n ? actionOrActions\n : [actionOrActions];\n\n if (actions.length === 0) {\n throw new Error(\"No actions provided\");\n }\n\n const reactorClient = window.ph?.reactorClient;\n if (!reactorClient) {\n throw new Error(\"ReactorClient not initialized\");\n }\n\n return await reactorClient.execute(document.header.id, \"main\", actions);\n}\n\nexport async function queueOperations(\n documentId: string,\n operationOrOperations: Operation[] | Operation | undefined,\n) {\n if (!documentId) {\n throw new Error(\"No documentId provided\");\n }\n if (!operationOrOperations) {\n throw new Error(\"No operations provided\");\n }\n const operations = Array.isArray(operationOrOperations)\n ? operationOrOperations\n : [operationOrOperations];\n\n if (operations.length === 0) {\n throw new Error(\"No operations provided\");\n }\n\n const reactorClient = window.ph?.reactorClient;\n if (!reactorClient) {\n throw new Error(\"ReactorClient not initialized\");\n }\n\n const actions = operations.map((op) => op.action);\n return await reactorClient.execute(documentId, \"main\", actions);\n}\n\nexport function deduplicateOperations(\n existingOperations: Record<string, Operation[]>,\n operationsToDeduplicate: Operation[],\n) {\n // make a set of all the operation indices for each scope to avoid duplicates\n const operationIndicesByScope = {} as Record<string, Set<number>>;\n for (const scope of Object.keys(existingOperations)) {\n operationIndicesByScope[scope] = new Set(\n existingOperations[scope].map((op) => op.index),\n );\n }\n\n const newOperations: Operation[] = [];\n\n for (const operation of operationsToDeduplicate) {\n const scope = operation.action.scope;\n const index = operation.index;\n if (operationIndicesByScope[scope].has(index)) {\n const duplicatedExistingOperation = existingOperations[scope].find(\n (op) => op.index === index,\n );\n const duplicatedNewOperation = newOperations.find(\n (op) => op.index === index,\n );\n console.warn(\"skipping duplicate operation\");\n if (duplicatedExistingOperation) {\n console.warn(\n \"duplicate existing operation\",\n duplicatedExistingOperation,\n );\n }\n if (duplicatedNewOperation) {\n console.warn(\"duplicate new operation\", duplicatedNewOperation);\n }\n continue;\n }\n newOperations.push(operation);\n operationIndicesByScope[scope].add(index);\n }\n\n const uniqueOperationIds = new Set<string>();\n const operationsDedupedById: Operation[] = [];\n\n for (const [scope, operations] of Object.entries(existingOperations)) {\n for (const operation of operations) {\n const id = operation.id;\n if (!id) {\n console.warn(\"skipping operation with no id\", operation);\n continue;\n }\n if (uniqueOperationIds.has(id)) {\n console.warn(\n \"skipping existing operation with duplicate id in scope\",\n scope,\n operation,\n );\n continue;\n }\n uniqueOperationIds.add(id);\n }\n }\n\n for (const operation of newOperations) {\n const id = operation.id;\n if (!id) {\n console.warn(\"skipping operation with no id\", operation);\n continue;\n }\n if (uniqueOperationIds.has(id)) {\n console.warn(\n \"skipping new operation with duplicate id in scope\",\n operation.action.scope,\n operation,\n );\n continue;\n }\n uniqueOperationIds.add(id);\n operationsDedupedById.push(operation);\n }\n return operationsDedupedById;\n}\n\nexport async function uploadOperations(\n documentId: string,\n allOperations: DocumentOperations,\n pushOperations: (\n documentId: string,\n operations: Operation[],\n ) => Promise<PHDocument | undefined>,\n options?: {\n operationsLimit?: number;\n onProgress?: FileUploadProgressCallback;\n },\n) {\n const operationsLimit = options?.operationsLimit || 50;\n const onProgress = options?.onProgress;\n\n logger.verbose(\n `uploadDocumentOperations(documentId:${documentId}, ops: ${Object.keys(allOperations).join(\",\")}, limit:${operationsLimit})`,\n );\n\n // Calculate total operations for progress tracking\n const allOperationsArray = Object.values(allOperations).filter(\n (ops): ops is Operation[] => ops !== undefined,\n );\n const totalOperations = allOperationsArray.reduce(\n (total, operations) => total + operations.length,\n 0,\n );\n let uploadedOperations = 0;\n\n for (const operations of allOperationsArray) {\n for (let i = 0; i < operations.length; i += operationsLimit) {\n logger.verbose(\n `uploadDocumentOperations:for(i:${i}, ops:${operations.length}, limit:${operationsLimit}): START`,\n );\n const chunk = operations.slice(i, i + operationsLimit);\n const operation = chunk.at(-1);\n if (!operation) {\n break;\n }\n const scope = operation.action.scope;\n\n await pushOperations(documentId, chunk);\n\n uploadedOperations += chunk.length;\n\n // Report progress\n if (onProgress) {\n const progress = Math.round(\n (uploadedOperations / totalOperations) * 100,\n );\n onProgress({\n stage: \"uploading\",\n progress,\n totalOperations,\n uploadedOperations,\n });\n }\n\n logger.verbose(\n `uploadDocumentOperations:for:waitForUpdate(${documentId}:${scope} rev ${operation.index}): NEXT`,\n );\n }\n }\n\n logger.verbose(\n `uploadDocumentOperations:for:waitForUpdate(${documentId}): END`,\n );\n}\n","import type { Action, PHDocument } from \"@powerhousedao/shared/document-model\";\nimport {\n buildSignedAction,\n type ActionSigner,\n} from \"@powerhousedao/shared/document-model\";\nimport { logger } from \"document-model\";\n\nexport async function signAction(action: Action, document: PHDocument) {\n const reactor = window.ph?.reactorClient;\n if (!reactor) return action;\n\n const documentModelModule = await reactor.getDocumentModelModule(\n document.header.documentType,\n );\n const reducer = documentModelModule.reducer;\n const renown = window.ph?.renown;\n if (!renown?.user) return action;\n if (!action.context?.signer) return action;\n\n const actionSigner = action.context.signer;\n const unsafeSignedAction = await buildSignedAction(\n action,\n reducer,\n document,\n actionSigner,\n renown.crypto.sign,\n );\n\n // TODO: this is super dangerous and is caused by the `buildSignedAction` function returning an `Operation` instead of an `Action`\n return unsafeSignedAction as unknown as Action;\n}\n\nexport function addActionContext(action: Action) {\n const renown = window.ph?.renown;\n if (!renown?.user) return action;\n\n const signer: ActionSigner = {\n app: {\n name: \"Connect\",\n key: renown.did,\n },\n user: {\n address: renown.user.address,\n networkId: renown.user.networkId,\n chainId: renown.user.chainId,\n },\n signatures: [],\n };\n\n return {\n context: { signer },\n ...action,\n };\n}\n\nasync function makeSignedActionWithContext(\n action: Action | undefined,\n document: PHDocument | undefined,\n) {\n if (!action) {\n logger.error(\"No action found\");\n return;\n }\n if (!document) {\n logger.error(\"No document found\");\n return;\n }\n const signedAction = await signAction(action, document);\n const signedActionWithContext = addActionContext(signedAction);\n return signedActionWithContext;\n}\n\nexport async function makeSignedActionsWithContext(\n actionOrActions: Action[] | Action | undefined,\n document: PHDocument | undefined,\n) {\n if (!actionOrActions) {\n logger.error(\"No actions found\");\n return;\n }\n const actions = Array.isArray(actionOrActions)\n ? actionOrActions\n : [actionOrActions];\n\n const signedActionsWithContext = await Promise.all(\n actions.map((action) => makeSignedActionWithContext(action, document)),\n );\n return signedActionsWithContext.filter((a) => a !== undefined);\n}\n","import type { Action, PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { logger } from \"document-model\";\nimport { queueActions } from \"./queue.js\";\nimport { makeSignedActionsWithContext } from \"./sign.js\";\n\nasync function getDocument(\n documentId: string,\n): Promise<PHDocument | undefined> {\n try {\n return await window.ph?.reactorClient?.get(documentId);\n } catch (error) {\n logger.debug(`Failed to get document with id ${documentId}:`, error);\n return undefined;\n }\n}\n\nfunction getActionErrors(result: PHDocument, actions: Action[]) {\n return actions.reduce((errors, a) => {\n const scopeOperations = result.operations[a.scope];\n if (!scopeOperations) {\n return errors;\n }\n const op = scopeOperations.findLast((op) => op.action.id === a.id);\n\n if (op?.error) {\n errors.push(new Error(op.error));\n }\n return errors;\n }, new Array<Error>());\n}\n\n/**\n * Dispatches actions to a document.\n * @param actionOrActions - The action or actions to dispatch.\n * @param document - The document to dispatch actions to.\n * @param onErrors - Callback invoked with any errors that occurred during action execution.\n * @returns The updated document, or undefined if the dispatch failed.\n */\nexport async function dispatchActions<TDocument = PHDocument, TAction = Action>(\n actionOrActions: TAction[] | TAction | undefined,\n document: TDocument | undefined,\n onErrors?: (errors: Error[]) => void,\n onSuccess?: (result: PHDocument) => void,\n): Promise<PHDocument | undefined>;\n/**\n * Dispatches actions to a document.\n * @param actionOrActions - The action or actions to dispatch.\n * @param documentId - The ID of the document to dispatch actions to.\n * @param onErrors - Callback invoked with any errors that occurred during action execution.\n * @returns The updated document, or undefined if the dispatch failed.\n */\nexport async function dispatchActions(\n actionOrActions: Action[] | Action | undefined,\n documentId: string,\n onErrors?: (errors: Error[]) => void,\n onSuccess?: (result: PHDocument) => void,\n): Promise<PHDocument | undefined>;\nexport async function dispatchActions(\n actionOrActions: Action[] | Action | undefined,\n documentOrDocumentId: PHDocument | string | undefined,\n onErrors?: (errors: Error[]) => void,\n onSuccess?: (result: PHDocument) => void,\n): Promise<PHDocument | undefined> {\n const document =\n typeof documentOrDocumentId === \"string\"\n ? await getDocument(documentOrDocumentId)\n : documentOrDocumentId;\n\n if (!document) {\n logger.error(\n `Document with id ${JSON.stringify(documentOrDocumentId)} not found`,\n );\n return;\n }\n\n const signedActionsWithContext = await makeSignedActionsWithContext(\n actionOrActions,\n document,\n );\n if (!signedActionsWithContext) {\n logger.error(\"No signed actions with context found\");\n return;\n }\n const result = await queueActions(document, signedActionsWithContext);\n\n if (onErrors && result) {\n const errors = getActionErrors(result, signedActionsWithContext);\n if (errors.length) {\n onErrors(errors);\n }\n }\n\n if (onSuccess && result) {\n onSuccess(result);\n }\n\n return result;\n}\n","import type { PowerhouseGlobal } from \"./types.js\";\n\nexport function getGlobal<K extends keyof PowerhouseGlobal>(\n namespace: K,\n): PowerhouseGlobal[K] | undefined {\n if (typeof window === \"undefined\") return undefined;\n return window.powerhouse?.[namespace];\n}\n\nexport function setGlobal<K extends keyof PowerhouseGlobal>(\n namespace: K,\n value: PowerhouseGlobal[K],\n): void {\n if (typeof window === \"undefined\") return;\n window.powerhouse = window.powerhouse || {};\n window.powerhouse[namespace] = value;\n}\n\nexport function clearGlobal(namespace: keyof PowerhouseGlobal): void {\n if (typeof window === \"undefined\") return;\n\n if (window.powerhouse?.[namespace]) {\n delete window.powerhouse[namespace];\n if (Object.keys(window.powerhouse).length === 0) {\n delete window.powerhouse;\n }\n }\n}\n","import type { BrowserAnalyticsStoreOptions } from \"@powerhousedao/analytics-engine-browser\";\nimport { BrowserAnalyticsStore } from \"@powerhousedao/analytics-engine-browser\";\nimport type { IAnalyticsStore } from \"@powerhousedao/analytics-engine-core\";\nimport { AnalyticsQueryEngine } from \"@powerhousedao/analytics-engine-core\";\nimport { getGlobal } from \"../global/core.js\";\n\nexport type CreateStoreOptions = BrowserAnalyticsStoreOptions;\n\nexport async function createAnalyticsStore(options: CreateStoreOptions) {\n const store = new BrowserAnalyticsStore(options);\n await store.init();\n\n const engine = new AnalyticsQueryEngine(store);\n return {\n store,\n engine,\n options,\n };\n}\n\nexport async function getAnalyticsStore(): Promise<IAnalyticsStore | null> {\n const globalAnalytics = await getGlobal(\"analytics\");\n\n return globalAnalytics?.store ?? null;\n}\n","import {\n DocumentChangeType,\n type DocumentChangeEvent,\n type IReactorClient,\n} from \"@powerhousedao/reactor\";\nimport type { PHDocument } from \"@powerhousedao/shared/document-model\";\nimport type {\n FulfilledPromise,\n IDocumentCache,\n PromiseState,\n PromiseWithState,\n RejectedPromise,\n} from \"./types/documents.js\";\n\nexport function addPromiseState<T>(promise: Promise<T>): PromiseWithState<T> {\n if (\"status\" in promise) {\n return promise as PromiseWithState<T>;\n }\n\n const promiseWithState = promise as PromiseWithState<T>;\n promiseWithState.status = \"pending\";\n promiseWithState.then(\n (value) => {\n promiseWithState.status = \"fulfilled\";\n (promiseWithState as FulfilledPromise<T>).value = value;\n },\n (reason) => {\n promiseWithState.status = \"rejected\";\n (promiseWithState as RejectedPromise<T>).reason = reason;\n // Re-throw to preserve unhandled rejection behavior\n // This allows React's error boundaries to catch the error\n throw reason;\n },\n );\n\n return promiseWithState;\n}\n\nexport function readPromiseState<T>(\n promise: Promise<T> | PromiseWithState<T>,\n): PromiseState<T> {\n return \"status\" in promise ? promise : { status: \"pending\" };\n}\n\n/**\n * Resolves an array of document promises using `Promise.allSettled`,\n * returning only the fulfilled values. A single missing/rejected\n * document does not poison the whole batch. Rejected entries are\n * logged at warn level so developers can see dangling references.\n */\nfunction fulfilledOnly(promises: Promise<PHDocument>[]): Promise<PHDocument[]> {\n return Promise.allSettled(promises).then((results) => {\n const documents: PHDocument[] = [];\n for (const result of results) {\n if (result.status === \"fulfilled\") {\n documents.push(result.value);\n } else {\n console.warn(\n \"[DocumentCache] Skipped unavailable document:\",\n result.reason,\n );\n }\n }\n return documents;\n });\n}\n\n/**\n * Document cache implementation that uses the new ReactorClient API.\n *\n * This cache subscribes to document change events via IReactorClient.subscribe()\n * and automatically updates the cache when documents are created, updated, or deleted.\n */\nexport class DocumentCache implements IDocumentCache {\n private documents = new Map<string, PromiseWithState<PHDocument>>();\n private batchPromises = new Map<\n string,\n { promises: Promise<PHDocument>[]; promise: Promise<PHDocument[]> }\n >();\n private listeners = new Map<string, (() => void)[]>();\n private unsubscribe: (() => void) | null = null;\n\n constructor(private client: IReactorClient) {\n this.unsubscribe = client.subscribe({}, (event: DocumentChangeEvent) => {\n this.handleDocumentChange(event);\n });\n }\n\n private handleDocumentChange(event: DocumentChangeEvent): void {\n if (event.type === DocumentChangeType.Deleted) {\n const documentId = event.context?.childId;\n if (documentId) {\n this.handleDocumentDeleted(documentId);\n }\n } else if (event.type === DocumentChangeType.Updated) {\n for (const doc of event.documents) {\n this.handleDocumentUpdated(doc.header.id).catch(console.warn);\n }\n }\n }\n\n private handleDocumentDeleted(documentId: string): void {\n const listeners = this.listeners.get(documentId);\n this.documents.delete(documentId);\n this.invalidateBatchesContaining(documentId);\n if (listeners) {\n listeners.forEach((listener) => listener());\n }\n this.listeners.delete(documentId);\n }\n\n private async handleDocumentUpdated(documentId: string): Promise<void> {\n if (this.documents.has(documentId)) {\n await this.get(documentId, true);\n const listeners = this.listeners.get(documentId);\n if (listeners) {\n listeners.forEach((listener) => listener());\n }\n }\n }\n\n private invalidateBatchesContaining(documentId: string): void {\n for (const key of this.batchPromises.keys()) {\n if (key.split(\",\").includes(documentId)) {\n this.batchPromises.delete(key);\n }\n }\n }\n\n get(id: string, refetch?: boolean): Promise<PHDocument> {\n const currentData = this.documents.get(id);\n if (currentData) {\n if (currentData.status === \"pending\") {\n return currentData;\n }\n if (!refetch) {\n return currentData;\n }\n }\n\n const documentPromise = this.client.get(id);\n this.documents.set(id, addPromiseState(documentPromise));\n return documentPromise;\n }\n\n getBatch(ids: string[]): Promise<PHDocument[]> {\n const key = ids.join(\",\");\n const cached = this.batchPromises.get(key);\n\n const hasDeletedDocuments = ids.some((id) => !this.documents.has(id));\n const currentPromises = ids.map((id) => this.get(id));\n\n if (hasDeletedDocuments) {\n const batchPromise = fulfilledOnly(currentPromises);\n this.batchPromises.set(key, {\n promises: currentPromises,\n promise: batchPromise,\n });\n return batchPromise;\n }\n\n if (cached) {\n const samePromises = currentPromises.every(\n (p, i) => p === cached.promises[i],\n );\n if (samePromises) {\n return cached.promise;\n }\n }\n\n const states = currentPromises.map((p) =>\n readPromiseState(p as PromiseWithState<PHDocument>),\n );\n const allSettled = states.every((s) => s.status !== \"pending\");\n\n if (allSettled) {\n const values = states\n .filter(\n (s): s is { status: \"fulfilled\"; value: PHDocument } =>\n s.status === \"fulfilled\",\n )\n .map((s) => s.value);\n const batchPromise = Promise.resolve(values) as PromiseWithState<\n PHDocument[]\n >;\n batchPromise.status = \"fulfilled\";\n (batchPromise as FulfilledPromise<PHDocument[]>).value = values;\n\n this.batchPromises.set(key, {\n promises: currentPromises,\n promise: batchPromise,\n });\n return batchPromise;\n }\n\n if (cached) {\n return cached.promise;\n }\n\n const batchPromise = fulfilledOnly(currentPromises);\n this.batchPromises.set(key, {\n promises: currentPromises,\n promise: batchPromise,\n });\n return batchPromise;\n }\n\n subscribe(id: string | string[], callback: () => void): () => void {\n const ids = Array.isArray(id) ? id : [id];\n for (const docId of ids) {\n const listeners = this.listeners.get(docId) ?? [];\n this.listeners.set(docId, [...listeners, callback]);\n }\n return () => {\n for (const docId of ids) {\n const listeners = this.listeners.get(docId) ?? [];\n this.listeners.set(\n docId,\n listeners.filter((listener) => listener !== callback),\n );\n }\n };\n }\n\n /**\n * Disposes of the cache and unsubscribes from document change events.\n */\n dispose(): void {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n }\n }\n}\n","import type { PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { use, useCallback, useSyncExternalStore } from \"react\";\nimport { readPromiseState } from \"../document-cache.js\";\nimport type { IDocumentCache } from \"../types/documents.js\";\nimport type { SetPHGlobalValue, UsePHGlobalValue } from \"../types/global.js\";\nimport { makePHEventFunctions } from \"./make-ph-event-functions.js\";\n\nconst documentEventFunctions = makePHEventFunctions(\"documentCache\");\n\n/** Returns all documents in the reactor. */\nexport const useDocumentCache: UsePHGlobalValue<IDocumentCache> =\n documentEventFunctions.useValue;\n\n/** Sets all of the documents in the reactor. */\nexport const setDocumentCache: SetPHGlobalValue<IDocumentCache> =\n documentEventFunctions.setValue;\n\n/** Adds an event handler for all of the documents in the reactor. */\nexport const addDocumentCacheEventHandler =\n documentEventFunctions.addEventHandler;\n\n/**\n * Reads the state of a document promise and converts it to a query state object.\n * @param promise - The document promise to read\n * @returns An object containing the status, data, error, and isPending flag\n */\nfunction getDocumentQueryState(promise: Promise<PHDocument>) {\n const state = readPromiseState(promise);\n switch (state.status) {\n case \"pending\":\n return {\n status: \"pending\",\n isPending: true,\n error: undefined,\n data: undefined,\n } as const;\n case \"fulfilled\":\n return {\n status: \"success\",\n isPending: false,\n error: undefined,\n data: state.value,\n } as const;\n case \"rejected\":\n return {\n status: \"error\",\n isPending: false,\n error: state.reason,\n data: undefined,\n } as const;\n }\n}\n\n/**\n * Retrieves a document from the reactor and subscribes to changes using React Suspense.\n * This hook will suspend rendering while the document is loading.\n * @param id - The document ID to retrieve, or null/undefined to skip retrieval\n * @returns The document if found, or undefined if id is null/undefined\n */\nexport function useDocument(id: string | null | undefined) {\n const documentCache = useDocumentCache();\n const document = useSyncExternalStore(\n (cb) => (id && documentCache ? documentCache.subscribe(id, cb) : () => {}),\n () => (id ? documentCache?.get(id) : undefined),\n );\n return document ? use(document) : undefined;\n}\n\n/**\n * Retrieves a document from the reactor and subscribes to changes without\n * suspending or throwing. Use this when the ID might be stale (e.g., a\n * previously selected node that has since been deleted) and the consumer\n * wants to render a placeholder instead of crashing.\n *\n * Unlike {@link useGetDocumentAsync}, this hook subscribes to cache\n * updates, so the returned state stays in sync with reactor changes.\n *\n * @param id - The document ID to retrieve, or null/undefined to skip retrieval\n * @returns An object containing:\n * - status: \"initial\" | \"pending\" | \"success\" | \"error\"\n * - data: The document if successfully loaded\n * - isPending: Whether the document is currently loading\n * - error: Any error that occurred during loading (e.g., document not found)\n * - reload: Function to force a refetch, or undefined when no id is supplied\n */\nexport function useDocumentSafe(id: string | null | undefined) {\n const documentCache = useDocumentCache();\n const promise = useSyncExternalStore(\n (cb) => (id && documentCache ? documentCache.subscribe(id, cb) : () => {}),\n () => (id ? documentCache?.get(id) : undefined),\n );\n\n if (!promise || !documentCache || !id) {\n return {\n status: \"initial\",\n isPending: false,\n error: undefined,\n data: undefined,\n reload: undefined,\n } as const;\n }\n\n const state = getDocumentQueryState(promise);\n return { ...state, reload: () => documentCache.get(id, true) } as const;\n}\n\n/**\n * Retrieves multiple documents from the reactor using React Suspense.\n * This hook will suspend rendering while any of the documents are loading.\n *\n * Uses getBatch from the document cache which handles promise caching internally,\n * ensuring stable references for useSyncExternalStore.\n *\n * @param ids - Array of document IDs to retrieve, or null/undefined to skip retrieval\n * @returns An array of documents if found, or empty array if ids is null/undefined\n */\nexport function useDocuments(ids: string[] | null | undefined) {\n const documentCache = useDocumentCache();\n\n const documents = useSyncExternalStore(\n (cb) =>\n ids?.length && documentCache\n ? documentCache.subscribe(ids, cb)\n : () => {},\n () =>\n ids?.length && documentCache ? documentCache.getBatch(ids) : undefined,\n );\n\n return documents ? use(documents) : [];\n}\n\n/**\n * Returns a function to retrieve a document from the cache.\n * The returned function fetches and returns a document by ID.\n * @returns A function that takes a document ID and returns a Promise of the document\n */\nexport function useGetDocument() {\n const documentCache = useDocumentCache();\n\n return useCallback(\n (id: string) => {\n if (!documentCache) {\n return Promise.reject(new Error(\"Document cache not initialized\"));\n }\n return documentCache.get(id);\n },\n [documentCache],\n );\n}\n\n/**\n * Returns a function to retrieve multiple documents from the cache.\n * The returned function fetches and returns documents by their IDs.\n * @returns A function that takes an array of document IDs and returns a Promise of the documents\n */\nexport function useGetDocuments() {\n const documentCache = useDocumentCache();\n\n return useCallback(\n (ids: string[]) => {\n if (!documentCache) {\n return Promise.reject(new Error(\"Document cache not initialized\"));\n }\n return documentCache.getBatch(ids);\n },\n [documentCache],\n );\n}\n\n/**\n * Retrieves a document from the reactor without suspending rendering.\n * Returns the current state of the document loading operation.\n * @param id - The document ID to retrieve, or null/undefined to skip retrieval\n * @returns An object containing:\n * - status: \"initial\" | \"pending\" | \"success\" | \"error\"\n * - data: The document if successfully loaded\n * - isPending: Boolean indicating if the document is currently loading\n * - error: Any error that occurred during loading\n * - reload: Function to force reload the document from cache\n */\nexport function useGetDocumentAsync(id: string | null | undefined) {\n const documentCache = useDocumentCache();\n if (!id || !documentCache) {\n return {\n status: \"initial\",\n data: undefined,\n isPending: false,\n error: undefined,\n reload: undefined,\n } as const;\n }\n\n const promise = documentCache.get(id);\n const state = getDocumentQueryState(promise);\n\n return { ...state, reload: () => documentCache.get(id, true) } as const;\n}\n","import type { Action, PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { logger } from \"document-model\";\nimport { dispatchActions } from \"../actions/dispatch.js\";\n\n/**\n * Returns a dispatch function for dispatching actions to a document.\n * Used internally by other hooks to provide action dispatching capabilities.\n * @param document - The document to dispatch actions to.\n * @returns A tuple containing the document and a dispatch function.\n */\nexport type DispatchFn<TAction> = (\n actionOrActions: TAction[] | TAction | undefined,\n onErrors?: (errors: Error[]) => void,\n onSuccess?: (result: PHDocument) => void,\n) => void;\n\nexport type UseDispatchResult<TDocument, TAction> = readonly [\n TDocument | undefined,\n DispatchFn<TAction>,\n];\n\nexport function useDispatch<TDocument = PHDocument, TAction = Action>(\n document: TDocument | undefined,\n): UseDispatchResult<TDocument, TAction> {\n /**\n * Dispatches actions to the document.\n * @param actionOrActions - The action or actions to dispatch.\n * @param onErrors - Callback invoked with any errors that occurred during action execution.\n */\n function dispatch(\n actionOrActions: TAction[] | TAction | undefined,\n onErrors?: (errors: Error[]) => void,\n onSuccess?: (result: PHDocument) => void,\n ) {\n dispatchActions(actionOrActions, document, onErrors, onSuccess).catch(\n logger.error,\n );\n }\n return [document, dispatch] as const;\n}\n","import type { Action, PHDocument } from \"@powerhousedao/shared/document-model\";\nimport { useDispatch, type UseDispatchResult } from \"./dispatch.js\";\nimport { useDocument, useDocuments } from \"./document-cache.js\";\n\n/** Returns a document by id. */\nexport function useDocumentById(\n id: string | null | undefined,\n): UseDispatchResult<PHDocument, Action> {\n const document = useDocument(id);\n const [, dispatch] = useDispatch<PHDocument, Action>(document);\n return [document, dispatch] as const;\n}\n\n/** Returns documents by ids. */\nexport function useDocumentsByIds(ids: string[] | null | undefined) {\n return useDocuments(ids);\n}\n"],"mappings":"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"}
|