@powerhousedao/reactor-browser 6.0.2-staging.6 → 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.
@@ -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 { PropagationMode as a, PhDocumentFieldsFragment as i, ReactorGraphQLClient as n, GetDocumentOperationsQuery as r, createClient as t };
782
- //# sourceMappingURL=client-K2ycBgUP.d.ts.map
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 = Promise.all(currentPromises);
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 === "fulfilled")) {
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 = Promise.all(currentPromises);
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 { uploadOperations as C, queueOperations as S, clearGlobal as _, setDocumentCache as a, dispatchActions as b, useDocuments as c, useGetDocuments as d, DocumentCache as f, getAnalyticsStore as g, createAnalyticsStore as h, addDocumentCacheEventHandler as i, useGetDocument as l, readPromiseState as m, useDocumentsByIds as n, useDocument as o, addPromiseState as p, useDispatch as r, useDocumentCache as s, useDocumentById as t, useGetDocumentAsync as u, getGlobal as v, queueActions as x, setGlobal as y };
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-CDLUqru5.js.map
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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"}