@nice-code/action 0.14.0 → 0.16.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/README.md +582 -582
- package/build/{ActionDevtoolsCore-CCRLYASa.d.cts → ActionDevtoolsCore-B3JwSaRH.d.cts} +3 -3
- package/build/{ActionDevtoolsCore-9PsnscvK.mjs → ActionDevtoolsCore-BcItqP-C.mjs} +7 -7
- package/build/ActionDevtoolsCore-BcItqP-C.mjs.map +1 -0
- package/build/{ActionDevtoolsCore-CYGD2o6C.d.mts → ActionDevtoolsCore-C4TDUY7-.d.mts} +3 -3
- package/build/{ActionDevtoolsCore-DtgXwPBZ.cjs → ActionDevtoolsCore-Cb_QR44N.cjs} +7 -7
- package/build/ActionDevtoolsCore-Cb_QR44N.cjs.map +1 -0
- package/build/{ActionPayload.types-BN-rXFBK.d.cts → ActionPayload.types-CO_hXlBc.d.cts} +1452 -941
- package/build/{ActionPayload.types-D28ELKXC.d.mts → ActionPayload.types-fieMKAgt.d.mts} +1452 -941
- package/build/devtools/browser/index.cjs +5 -5
- package/build/devtools/browser/index.cjs.map +1 -1
- package/build/devtools/browser/index.d.cts +1 -1
- package/build/devtools/browser/index.d.mts +1 -1
- package/build/devtools/browser/index.mjs +5 -5
- package/build/devtools/browser/index.mjs.map +1 -1
- package/build/devtools/server/index.cjs +1 -1
- package/build/devtools/server/index.cjs.map +1 -1
- package/build/devtools/server/index.d.cts +1 -1
- package/build/devtools/server/index.d.mts +1 -1
- package/build/devtools/server/index.mjs +1 -1
- package/build/devtools/server/index.mjs.map +1 -1
- package/build/index.cjs +2733 -1963
- package/build/index.cjs.map +1 -1
- package/build/index.d.cts +2 -2
- package/build/index.d.mts +2 -2
- package/build/index.mjs +2706 -1950
- package/build/index.mjs.map +1 -1
- package/build/react-query/index.cjs.map +1 -1
- package/build/react-query/index.d.cts +1 -1
- package/build/react-query/index.d.mts +1 -1
- package/build/react-query/index.mjs.map +1 -1
- package/package.json +4 -4
- package/build/ActionDevtoolsCore-9PsnscvK.mjs.map +0 -1
- package/build/ActionDevtoolsCore-DtgXwPBZ.cjs.map +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { _ as TActionProgress, yr as IRuntimeCoordinate } from "./ActionPayload.types-CO_hXlBc.cjs";
|
|
2
2
|
//#region ../nice-devtools-shared/src/components/PanelChrome.d.ts
|
|
3
3
|
/** Where a devtools panel is docked. */
|
|
4
4
|
type TDevtoolsPosition = "dock-bottom" | "dock-top" | "dock-left" | "dock-right";
|
|
@@ -7,7 +7,7 @@ type TDevtoolsPosition = "dock-bottom" | "dock-top" | "dock-left" | "dock-right"
|
|
|
7
7
|
type TDevtoolsActionStatus = "running" | "success" | "action-error" | "failed" | "aborted";
|
|
8
8
|
interface IDevtoolsRouteItem {
|
|
9
9
|
runtime: IRuntimeCoordinate;
|
|
10
|
-
handlerType: "local" | "
|
|
10
|
+
handlerType: "local" | "peer";
|
|
11
11
|
handlerClient?: {
|
|
12
12
|
envId: string;
|
|
13
13
|
perId?: string;
|
|
@@ -76,4 +76,4 @@ declare class ActionDevtoolsCore {
|
|
|
76
76
|
}
|
|
77
77
|
//#endregion
|
|
78
78
|
export { TDevtoolsActionStatus as a, IDevtoolsObservableDomain as i, IActionDevtoolsCoreOptions as n, TDevtoolsListener as o, IDevtoolsActionEntry as r, TDevtoolsPosition as s, ActionDevtoolsCore as t };
|
|
79
|
-
//# sourceMappingURL=ActionDevtoolsCore-
|
|
79
|
+
//# sourceMappingURL=ActionDevtoolsCore-B3JwSaRH.d.cts.map
|
|
@@ -7,22 +7,22 @@ function serializeErrorForDisplay(error) {
|
|
|
7
7
|
function extractRouting(context) {
|
|
8
8
|
return (context?.routing ?? []).map((item) => {
|
|
9
9
|
const handler = item.handler;
|
|
10
|
-
const
|
|
10
|
+
const isPeer = handler?.type === "peer";
|
|
11
11
|
return {
|
|
12
12
|
runtime: {
|
|
13
13
|
envId: item.runtime?.envId ?? "unknown",
|
|
14
14
|
perId: item.runtime?.perId,
|
|
15
15
|
insId: item.runtime?.insId
|
|
16
16
|
},
|
|
17
|
-
handlerType:
|
|
18
|
-
handlerClient:
|
|
17
|
+
handlerType: isPeer ? "peer" : "local",
|
|
18
|
+
handlerClient: isPeer && handler.client != null ? {
|
|
19
19
|
envId: handler.client.envId ?? "unknown",
|
|
20
20
|
perId: handler.client.perId,
|
|
21
21
|
insId: handler.client.insId
|
|
22
22
|
} : void 0,
|
|
23
|
-
transport:
|
|
24
|
-
transportSummary:
|
|
25
|
-
transportUrl:
|
|
23
|
+
transport: isPeer ? handler.transInfo?.carrierLabel ?? handler.transShape : void 0,
|
|
24
|
+
transportSummary: isPeer ? handler.transInfo?.summary : void 0,
|
|
25
|
+
transportUrl: isPeer ? handler.transInfo?.url : void 0,
|
|
26
26
|
time: item.time
|
|
27
27
|
};
|
|
28
28
|
});
|
|
@@ -151,4 +151,4 @@ var ActionDevtoolsCore = class {
|
|
|
151
151
|
//#endregion
|
|
152
152
|
export { ActionDevtoolsCore as t };
|
|
153
153
|
|
|
154
|
-
//# sourceMappingURL=ActionDevtoolsCore-
|
|
154
|
+
//# sourceMappingURL=ActionDevtoolsCore-BcItqP-C.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActionDevtoolsCore-BcItqP-C.mjs","names":[],"sources":["../src/devtools/core/ActionDevtoolsCore.ts"],"sourcesContent":["import {\r\n ERunningActionFinishedType,\r\n ERunningActionUpdateType,\r\n} from \"../../ActionDefinition/Action/RunningAction.types\";\r\nimport type {\r\n IDevtoolsActionEntry,\r\n IDevtoolsActionMeta,\r\n IDevtoolsObservableDomain,\r\n IDevtoolsRouteItem,\r\n TDevtoolsListener,\r\n} from \"./ActionDevtools.types\";\r\n\r\nexport interface IActionDevtoolsCoreOptions {\r\n /** Max root entries to retain. Older entries (and their children) are evicted. */\r\n maxEntries?: number;\r\n}\r\n\r\nfunction serializeErrorForDisplay(error: unknown): unknown {\r\n if (\r\n error != null &&\r\n typeof error === \"object\" &&\r\n (error as any).name === \"NiceError\" &&\r\n typeof (error as any).toJsonObject === \"function\"\r\n ) {\r\n return (error as any).toJsonObject();\r\n }\r\n return error;\r\n}\r\n\r\nfunction extractRouting(context: any): IDevtoolsRouteItem[] {\r\n return (context?.routing ?? []).map((item: any): IDevtoolsRouteItem => {\r\n const handler = item.handler;\r\n const isPeer = handler?.type === \"peer\";\r\n return {\r\n runtime: {\r\n envId: item.runtime?.envId ?? \"unknown\",\r\n perId: item.runtime?.perId,\r\n insId: item.runtime?.insId,\r\n },\r\n handlerType: isPeer ? \"peer\" : \"local\",\r\n handlerClient:\r\n isPeer && handler.client != null\r\n ? {\r\n envId: handler.client.envId ?? \"unknown\",\r\n perId: handler.client.perId,\r\n insId: handler.client.insId,\r\n }\r\n : undefined,\r\n transport: isPeer ? (handler.transInfo?.carrierLabel ?? handler.transShape) : undefined,\r\n transportSummary: isPeer ? handler.transInfo?.summary : undefined,\r\n transportUrl: isPeer ? handler.transInfo?.url : undefined,\r\n time: item.time,\r\n };\r\n });\r\n}\r\n\r\nfunction extractMeta(context: any): IDevtoolsActionMeta {\r\n return {\r\n timeCreated: context?.timeCreated ?? Date.now(),\r\n originClient: {\r\n envId: context?.originClient?.envId ?? \"unknown\",\r\n perId: context?.originClient?.perId,\r\n insId: context?.originClient?.insId,\r\n },\r\n routing: extractRouting(context),\r\n };\r\n}\r\n\r\nexport class ActionDevtoolsCore {\r\n private _entries: IDevtoolsActionEntry[] = [];\r\n private _listeners: Set<TDevtoolsListener> = new Set();\r\n private readonly _maxEntries: number;\r\n\r\n constructor(options: IActionDevtoolsCoreOptions = {}) {\r\n this._maxEntries = options.maxEntries ?? 500;\r\n }\r\n\r\n attachToDomain(domain: IDevtoolsObservableDomain): () => void {\r\n return domain.addActionListener((update) => {\r\n const { runningAction, type, time } = update;\r\n\r\n if (type === ERunningActionUpdateType.started) {\r\n const entry: IDevtoolsActionEntry = {\r\n cuid: runningAction.cuid,\r\n actionId: runningAction.id,\r\n domain: runningAction.domain,\r\n allDomains: [...runningAction.allDomains],\r\n status: \"running\",\r\n startTime: time,\r\n input: runningAction.state?.request?.input,\r\n inputHash: runningAction.state?.request?.inputHash,\r\n progressUpdates: [],\r\n meta: extractMeta(runningAction.context),\r\n parentCuid: runningAction.parentCuid,\r\n callSite: runningAction.callSite,\r\n };\r\n this._entries = [entry, ...this._entries];\r\n // Bound retention: entries are newest-first, so the oldest fall off the tail.\r\n // Grouping already renders any child whose parent is gone as its own root, so\r\n // dropping an old parent never breaks the surviving children's display.\r\n if (this._entries.length > this._maxEntries) {\r\n this._entries.length = this._maxEntries;\r\n }\r\n this._notify();\r\n } else if (type === ERunningActionUpdateType.progress) {\r\n this._updateEntry(runningAction.cuid, (e) => ({\r\n ...e,\r\n progressUpdates: [...e.progressUpdates, update.progress],\r\n }));\r\n } else if (type === ERunningActionUpdateType.finished) {\r\n this._updateEntry(runningAction.cuid, (e) => {\r\n // On success the result payload's context may carry the full routing from the handling\r\n // runtime (including backend hops) — richer than the local context, which only has this\r\n // side's outgoing hops. Prefer it *only when it's actually richer*: the optimized binary\r\n // WS session strips routing from the wire and reconstructs an empty array, so an empty\r\n // response routing must never clobber the real local hops (otherwise the entry renders as\r\n // \"call\"/\"local\" instead of \"→ ws → backend\").\r\n const responseRouting = extractRouting((update as any).response?.context);\r\n const localRouting = extractRouting(runningAction.context);\r\n const routing =\r\n responseRouting.length >= localRouting.length ? responseRouting : localRouting;\r\n const base: IDevtoolsActionEntry = {\r\n ...e,\r\n endTime: time,\r\n meta: { ...e.meta, routing },\r\n };\r\n const finishType: string = update.finishType;\r\n\r\n if (finishType === ERunningActionFinishedType.success) {\r\n const result = update.response?.result;\r\n const outputHash: string | undefined = update.response?.outputHash;\r\n if (result != null && !result.ok) {\r\n const rawError = result.error;\r\n const errorStack = rawError instanceof Error ? rawError.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"action-error\",\r\n outputHash,\r\n error: serializeErrorForDisplay(rawError),\r\n errorStack,\r\n };\r\n }\r\n return { ...base, status: \"success\", output: result?.output, outputHash };\r\n }\r\n if (finishType === ERunningActionFinishedType.failed) {\r\n const rawError = (update as any).error;\r\n const errorStack = rawError instanceof Error ? rawError.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"failed\",\r\n error: serializeErrorForDisplay(rawError),\r\n errorStack,\r\n };\r\n }\r\n const abortReason = update.reason;\r\n const errorStack = abortReason instanceof Error ? abortReason.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"aborted\",\r\n abortReason: serializeErrorForDisplay(abortReason),\r\n errorStack,\r\n };\r\n });\r\n }\r\n });\r\n }\r\n\r\n getEntries(): readonly IDevtoolsActionEntry[] {\r\n return this._entries;\r\n }\r\n\r\n subscribe(listener: TDevtoolsListener): () => void {\r\n this._listeners.add(listener);\r\n listener(this._entries);\r\n return () => {\r\n this._listeners.delete(listener);\r\n };\r\n }\r\n\r\n clear(): void {\r\n this._entries = [];\r\n this._notify();\r\n }\r\n\r\n private _updateEntry(\r\n cuid: string,\r\n updater: (entry: IDevtoolsActionEntry) => IDevtoolsActionEntry,\r\n ): void {\r\n this._entries = this._entries.map((e) => (e.cuid === cuid ? updater(e) : e));\r\n this._notify();\r\n }\r\n\r\n private _notify(): void {\r\n const snapshot = this._entries;\r\n for (const listener of this._listeners) listener(snapshot);\r\n }\r\n}\r\n"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { _ as TActionProgress, yr as IRuntimeCoordinate } from "./ActionPayload.types-fieMKAgt.mjs";
|
|
2
2
|
//#region ../nice-devtools-shared/src/components/PanelChrome.d.ts
|
|
3
3
|
/** Where a devtools panel is docked. */
|
|
4
4
|
type TDevtoolsPosition = "dock-bottom" | "dock-top" | "dock-left" | "dock-right";
|
|
@@ -7,7 +7,7 @@ type TDevtoolsPosition = "dock-bottom" | "dock-top" | "dock-left" | "dock-right"
|
|
|
7
7
|
type TDevtoolsActionStatus = "running" | "success" | "action-error" | "failed" | "aborted";
|
|
8
8
|
interface IDevtoolsRouteItem {
|
|
9
9
|
runtime: IRuntimeCoordinate;
|
|
10
|
-
handlerType: "local" | "
|
|
10
|
+
handlerType: "local" | "peer";
|
|
11
11
|
handlerClient?: {
|
|
12
12
|
envId: string;
|
|
13
13
|
perId?: string;
|
|
@@ -76,4 +76,4 @@ declare class ActionDevtoolsCore {
|
|
|
76
76
|
}
|
|
77
77
|
//#endregion
|
|
78
78
|
export { TDevtoolsActionStatus as a, IDevtoolsObservableDomain as i, IActionDevtoolsCoreOptions as n, TDevtoolsListener as o, IDevtoolsActionEntry as r, TDevtoolsPosition as s, ActionDevtoolsCore as t };
|
|
79
|
-
//# sourceMappingURL=ActionDevtoolsCore-
|
|
79
|
+
//# sourceMappingURL=ActionDevtoolsCore-C4TDUY7-.d.mts.map
|
|
@@ -7,22 +7,22 @@ function serializeErrorForDisplay(error) {
|
|
|
7
7
|
function extractRouting(context) {
|
|
8
8
|
return (context?.routing ?? []).map((item) => {
|
|
9
9
|
const handler = item.handler;
|
|
10
|
-
const
|
|
10
|
+
const isPeer = handler?.type === "peer";
|
|
11
11
|
return {
|
|
12
12
|
runtime: {
|
|
13
13
|
envId: item.runtime?.envId ?? "unknown",
|
|
14
14
|
perId: item.runtime?.perId,
|
|
15
15
|
insId: item.runtime?.insId
|
|
16
16
|
},
|
|
17
|
-
handlerType:
|
|
18
|
-
handlerClient:
|
|
17
|
+
handlerType: isPeer ? "peer" : "local",
|
|
18
|
+
handlerClient: isPeer && handler.client != null ? {
|
|
19
19
|
envId: handler.client.envId ?? "unknown",
|
|
20
20
|
perId: handler.client.perId,
|
|
21
21
|
insId: handler.client.insId
|
|
22
22
|
} : void 0,
|
|
23
|
-
transport:
|
|
24
|
-
transportSummary:
|
|
25
|
-
transportUrl:
|
|
23
|
+
transport: isPeer ? handler.transInfo?.carrierLabel ?? handler.transShape : void 0,
|
|
24
|
+
transportSummary: isPeer ? handler.transInfo?.summary : void 0,
|
|
25
|
+
transportUrl: isPeer ? handler.transInfo?.url : void 0,
|
|
26
26
|
time: item.time
|
|
27
27
|
};
|
|
28
28
|
});
|
|
@@ -156,4 +156,4 @@ Object.defineProperty(exports, "ActionDevtoolsCore", {
|
|
|
156
156
|
}
|
|
157
157
|
});
|
|
158
158
|
|
|
159
|
-
//# sourceMappingURL=ActionDevtoolsCore-
|
|
159
|
+
//# sourceMappingURL=ActionDevtoolsCore-Cb_QR44N.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActionDevtoolsCore-Cb_QR44N.cjs","names":[],"sources":["../src/devtools/core/ActionDevtoolsCore.ts"],"sourcesContent":["import {\r\n ERunningActionFinishedType,\r\n ERunningActionUpdateType,\r\n} from \"../../ActionDefinition/Action/RunningAction.types\";\r\nimport type {\r\n IDevtoolsActionEntry,\r\n IDevtoolsActionMeta,\r\n IDevtoolsObservableDomain,\r\n IDevtoolsRouteItem,\r\n TDevtoolsListener,\r\n} from \"./ActionDevtools.types\";\r\n\r\nexport interface IActionDevtoolsCoreOptions {\r\n /** Max root entries to retain. Older entries (and their children) are evicted. */\r\n maxEntries?: number;\r\n}\r\n\r\nfunction serializeErrorForDisplay(error: unknown): unknown {\r\n if (\r\n error != null &&\r\n typeof error === \"object\" &&\r\n (error as any).name === \"NiceError\" &&\r\n typeof (error as any).toJsonObject === \"function\"\r\n ) {\r\n return (error as any).toJsonObject();\r\n }\r\n return error;\r\n}\r\n\r\nfunction extractRouting(context: any): IDevtoolsRouteItem[] {\r\n return (context?.routing ?? []).map((item: any): IDevtoolsRouteItem => {\r\n const handler = item.handler;\r\n const isPeer = handler?.type === \"peer\";\r\n return {\r\n runtime: {\r\n envId: item.runtime?.envId ?? \"unknown\",\r\n perId: item.runtime?.perId,\r\n insId: item.runtime?.insId,\r\n },\r\n handlerType: isPeer ? \"peer\" : \"local\",\r\n handlerClient:\r\n isPeer && handler.client != null\r\n ? {\r\n envId: handler.client.envId ?? \"unknown\",\r\n perId: handler.client.perId,\r\n insId: handler.client.insId,\r\n }\r\n : undefined,\r\n transport: isPeer ? (handler.transInfo?.carrierLabel ?? handler.transShape) : undefined,\r\n transportSummary: isPeer ? handler.transInfo?.summary : undefined,\r\n transportUrl: isPeer ? handler.transInfo?.url : undefined,\r\n time: item.time,\r\n };\r\n });\r\n}\r\n\r\nfunction extractMeta(context: any): IDevtoolsActionMeta {\r\n return {\r\n timeCreated: context?.timeCreated ?? Date.now(),\r\n originClient: {\r\n envId: context?.originClient?.envId ?? \"unknown\",\r\n perId: context?.originClient?.perId,\r\n insId: context?.originClient?.insId,\r\n },\r\n routing: extractRouting(context),\r\n };\r\n}\r\n\r\nexport class ActionDevtoolsCore {\r\n private _entries: IDevtoolsActionEntry[] = [];\r\n private _listeners: Set<TDevtoolsListener> = new Set();\r\n private readonly _maxEntries: number;\r\n\r\n constructor(options: IActionDevtoolsCoreOptions = {}) {\r\n this._maxEntries = options.maxEntries ?? 500;\r\n }\r\n\r\n attachToDomain(domain: IDevtoolsObservableDomain): () => void {\r\n return domain.addActionListener((update) => {\r\n const { runningAction, type, time } = update;\r\n\r\n if (type === ERunningActionUpdateType.started) {\r\n const entry: IDevtoolsActionEntry = {\r\n cuid: runningAction.cuid,\r\n actionId: runningAction.id,\r\n domain: runningAction.domain,\r\n allDomains: [...runningAction.allDomains],\r\n status: \"running\",\r\n startTime: time,\r\n input: runningAction.state?.request?.input,\r\n inputHash: runningAction.state?.request?.inputHash,\r\n progressUpdates: [],\r\n meta: extractMeta(runningAction.context),\r\n parentCuid: runningAction.parentCuid,\r\n callSite: runningAction.callSite,\r\n };\r\n this._entries = [entry, ...this._entries];\r\n // Bound retention: entries are newest-first, so the oldest fall off the tail.\r\n // Grouping already renders any child whose parent is gone as its own root, so\r\n // dropping an old parent never breaks the surviving children's display.\r\n if (this._entries.length > this._maxEntries) {\r\n this._entries.length = this._maxEntries;\r\n }\r\n this._notify();\r\n } else if (type === ERunningActionUpdateType.progress) {\r\n this._updateEntry(runningAction.cuid, (e) => ({\r\n ...e,\r\n progressUpdates: [...e.progressUpdates, update.progress],\r\n }));\r\n } else if (type === ERunningActionUpdateType.finished) {\r\n this._updateEntry(runningAction.cuid, (e) => {\r\n // On success the result payload's context may carry the full routing from the handling\r\n // runtime (including backend hops) — richer than the local context, which only has this\r\n // side's outgoing hops. Prefer it *only when it's actually richer*: the optimized binary\r\n // WS session strips routing from the wire and reconstructs an empty array, so an empty\r\n // response routing must never clobber the real local hops (otherwise the entry renders as\r\n // \"call\"/\"local\" instead of \"→ ws → backend\").\r\n const responseRouting = extractRouting((update as any).response?.context);\r\n const localRouting = extractRouting(runningAction.context);\r\n const routing =\r\n responseRouting.length >= localRouting.length ? responseRouting : localRouting;\r\n const base: IDevtoolsActionEntry = {\r\n ...e,\r\n endTime: time,\r\n meta: { ...e.meta, routing },\r\n };\r\n const finishType: string = update.finishType;\r\n\r\n if (finishType === ERunningActionFinishedType.success) {\r\n const result = update.response?.result;\r\n const outputHash: string | undefined = update.response?.outputHash;\r\n if (result != null && !result.ok) {\r\n const rawError = result.error;\r\n const errorStack = rawError instanceof Error ? rawError.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"action-error\",\r\n outputHash,\r\n error: serializeErrorForDisplay(rawError),\r\n errorStack,\r\n };\r\n }\r\n return { ...base, status: \"success\", output: result?.output, outputHash };\r\n }\r\n if (finishType === ERunningActionFinishedType.failed) {\r\n const rawError = (update as any).error;\r\n const errorStack = rawError instanceof Error ? rawError.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"failed\",\r\n error: serializeErrorForDisplay(rawError),\r\n errorStack,\r\n };\r\n }\r\n const abortReason = update.reason;\r\n const errorStack = abortReason instanceof Error ? abortReason.stack : undefined;\r\n return {\r\n ...base,\r\n status: \"aborted\",\r\n abortReason: serializeErrorForDisplay(abortReason),\r\n errorStack,\r\n };\r\n });\r\n }\r\n });\r\n }\r\n\r\n getEntries(): readonly IDevtoolsActionEntry[] {\r\n return this._entries;\r\n }\r\n\r\n subscribe(listener: TDevtoolsListener): () => void {\r\n this._listeners.add(listener);\r\n listener(this._entries);\r\n return () => {\r\n this._listeners.delete(listener);\r\n };\r\n }\r\n\r\n clear(): void {\r\n this._entries = [];\r\n this._notify();\r\n }\r\n\r\n private _updateEntry(\r\n cuid: string,\r\n updater: (entry: IDevtoolsActionEntry) => IDevtoolsActionEntry,\r\n ): void {\r\n this._entries = this._entries.map((e) => (e.cuid === cuid ? updater(e) : e));\r\n this._notify();\r\n }\r\n\r\n private _notify(): void {\r\n const snapshot = this._entries;\r\n for (const listener of this._listeners) listener(snapshot);\r\n }\r\n}\r\n"],"mappings":"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"}
|