@wandelbots/nova-js 3.2.0 → 3.3.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.
Files changed (104) hide show
  1. package/README.md +32 -136
  2. package/dist/AutoReconnectingWebsocket-Qcrbm3Kb.d.cts +69 -0
  3. package/dist/AutoReconnectingWebsocket-Qcrbm3Kb.d.cts.map +1 -0
  4. package/dist/AutoReconnectingWebsocket-dHe-kceU.d.mts +69 -0
  5. package/dist/AutoReconnectingWebsocket-dHe-kceU.d.mts.map +1 -0
  6. package/dist/LoginWithAuth0-CBD9BXXz.cjs +264 -0
  7. package/dist/LoginWithAuth0-CBD9BXXz.cjs.map +1 -0
  8. package/dist/LoginWithAuth0-wQB-Sol1.mjs +217 -0
  9. package/dist/LoginWithAuth0-wQB-Sol1.mjs.map +1 -0
  10. package/dist/NovaClient-B8XM3OPO.mjs +2057 -0
  11. package/dist/NovaClient-B8XM3OPO.mjs.map +1 -0
  12. package/dist/NovaClient-CV7ooIkD.d.cts +349 -0
  13. package/dist/NovaClient-CV7ooIkD.d.cts.map +1 -0
  14. package/dist/NovaClient-D2EItmiH.cjs +2137 -0
  15. package/dist/NovaClient-D2EItmiH.cjs.map +1 -0
  16. package/dist/NovaClient-qJnHcx2s.d.mts +349 -0
  17. package/dist/NovaClient-qJnHcx2s.d.mts.map +1 -0
  18. package/dist/index.cjs +42 -386
  19. package/dist/index.cjs.map +1 -1
  20. package/dist/index.d.cts +73 -0
  21. package/dist/index.d.cts.map +1 -0
  22. package/dist/index.d.mts +73 -0
  23. package/dist/index.d.mts.map +1 -0
  24. package/dist/index.mjs +36 -0
  25. package/dist/index.mjs.map +1 -0
  26. package/dist/lib/v1/index.cjs +190 -2940
  27. package/dist/lib/v1/index.cjs.map +1 -1
  28. package/dist/lib/v1/index.d.cts +62 -0
  29. package/dist/lib/v1/index.d.cts.map +1 -0
  30. package/dist/lib/v1/index.d.mts +62 -0
  31. package/dist/lib/v1/index.d.mts.map +1 -0
  32. package/dist/lib/v1/index.mjs +182 -0
  33. package/dist/lib/v1/index.mjs.map +1 -0
  34. package/dist/lib/v2/index.cjs +1821 -1468
  35. package/dist/lib/v2/index.cjs.map +1 -1
  36. package/dist/lib/v2/index.d.cts +118 -0
  37. package/dist/lib/v2/index.d.cts.map +1 -0
  38. package/dist/lib/v2/index.d.mts +118 -0
  39. package/dist/lib/v2/index.d.mts.map +1 -0
  40. package/dist/lib/v2/index.mjs +1822 -0
  41. package/dist/lib/v2/index.mjs.map +1 -0
  42. package/package.json +21 -19
  43. package/src/LoginWithAuth0.ts +12 -12
  44. package/src/index.ts +2 -0
  45. package/src/lib/converters.ts +5 -23
  46. package/src/lib/v1/MotionStreamConnection.ts +0 -1
  47. package/src/lib/v1/NovaClient.ts +18 -0
  48. package/src/lib/v1/index.ts +6 -0
  49. package/src/lib/v1/mock/MockNovaInstance.ts +0 -1
  50. package/src/lib/v1/wandelscriptUtils.ts +22 -0
  51. package/src/lib/v2/NovaClient.ts +14 -7
  52. package/src/lib/v2/index.ts +1 -0
  53. package/src/lib/v2/mock/MockNovaInstance.ts +411 -21
  54. package/src/lib/v2/wandelscriptUtils.ts +27 -0
  55. package/dist/LoginWithAuth0.d.ts +0 -7
  56. package/dist/LoginWithAuth0.d.ts.map +0 -1
  57. package/dist/chunk-B2C22PTK.js +0 -53
  58. package/dist/chunk-B2C22PTK.js.map +0 -1
  59. package/dist/chunk-I3PUV6ZD.js +0 -286
  60. package/dist/chunk-I3PUV6ZD.js.map +0 -1
  61. package/dist/index.d.ts +0 -6
  62. package/dist/index.d.ts.map +0 -1
  63. package/dist/index.js +0 -60
  64. package/dist/index.js.map +0 -1
  65. package/dist/lib/AutoReconnectingWebsocket.d.ts +0 -43
  66. package/dist/lib/AutoReconnectingWebsocket.d.ts.map +0 -1
  67. package/dist/lib/availableStorage.d.ts +0 -15
  68. package/dist/lib/availableStorage.d.ts.map +0 -1
  69. package/dist/lib/converters.d.ts +0 -26
  70. package/dist/lib/converters.d.ts.map +0 -1
  71. package/dist/lib/errorHandling.d.ts +0 -15
  72. package/dist/lib/errorHandling.d.ts.map +0 -1
  73. package/dist/lib/v1/ConnectedMotionGroup.d.ts +0 -77
  74. package/dist/lib/v1/ConnectedMotionGroup.d.ts.map +0 -1
  75. package/dist/lib/v1/JoggerConnection.d.ts +0 -94
  76. package/dist/lib/v1/JoggerConnection.d.ts.map +0 -1
  77. package/dist/lib/v1/MotionStreamConnection.d.ts +0 -26
  78. package/dist/lib/v1/MotionStreamConnection.d.ts.map +0 -1
  79. package/dist/lib/v1/NovaCellAPIClient.d.ts +0 -68
  80. package/dist/lib/v1/NovaCellAPIClient.d.ts.map +0 -1
  81. package/dist/lib/v1/NovaClient.d.ts +0 -67
  82. package/dist/lib/v1/NovaClient.d.ts.map +0 -1
  83. package/dist/lib/v1/ProgramStateConnection.d.ts +0 -57
  84. package/dist/lib/v1/ProgramStateConnection.d.ts.map +0 -1
  85. package/dist/lib/v1/getLatestTrajectories.d.ts +0 -4
  86. package/dist/lib/v1/getLatestTrajectories.d.ts.map +0 -1
  87. package/dist/lib/v1/index.d.ts +0 -9
  88. package/dist/lib/v1/index.d.ts.map +0 -1
  89. package/dist/lib/v1/index.js +0 -2653
  90. package/dist/lib/v1/index.js.map +0 -1
  91. package/dist/lib/v1/mock/MockNovaInstance.d.ts +0 -13
  92. package/dist/lib/v1/mock/MockNovaInstance.d.ts.map +0 -1
  93. package/dist/lib/v1/motionStateUpdate.d.ts +0 -4
  94. package/dist/lib/v1/motionStateUpdate.d.ts.map +0 -1
  95. package/dist/lib/v2/NovaCellAPIClient.d.ts +0 -62
  96. package/dist/lib/v2/NovaCellAPIClient.d.ts.map +0 -1
  97. package/dist/lib/v2/NovaClient.d.ts +0 -60
  98. package/dist/lib/v2/NovaClient.d.ts.map +0 -1
  99. package/dist/lib/v2/index.d.ts +0 -4
  100. package/dist/lib/v2/index.d.ts.map +0 -1
  101. package/dist/lib/v2/index.js +0 -1196
  102. package/dist/lib/v2/index.js.map +0 -1
  103. package/dist/lib/v2/mock/MockNovaInstance.d.ts +0 -13
  104. package/dist/lib/v2/mock/MockNovaInstance.d.ts.map +0 -1
@@ -0,0 +1,182 @@
1
+ import "../../LoginWithAuth0-wQB-Sol1.mjs";
2
+ import { a as ConnectedMotionGroup, f as tryParseJson, i as JoggerConnection, n as NovaCellAPIClient, o as poseToWandelscriptString, r as MotionStreamConnection, t as NovaClient } from "../../NovaClient-B8XM3OPO.mjs";
3
+ import { AxiosError } from "axios";
4
+ import { makeAutoObservable, runInAction } from "mobx";
5
+
6
+ export * from "@wandelbots/nova-api/v1"
7
+
8
+ //#region src/lib/v1/getLatestTrajectories.ts
9
+ let lastMotionIds = /* @__PURE__ */ new Set();
10
+ async function getLatestTrajectories(apiClient, sampleTime = 50, responsesCoordinateSystem) {
11
+ const newTrajectories = [];
12
+ try {
13
+ const motions = await apiClient.motion.listMotions();
14
+ const currentMotionIds = new Set(motions.motions);
15
+ const newMotionIds = Array.from(currentMotionIds).filter((id) => !lastMotionIds.has(id));
16
+ for (const motionId of newMotionIds) {
17
+ const trajectory = await apiClient.motion.getMotionTrajectory(motionId, sampleTime, responsesCoordinateSystem);
18
+ newTrajectories.push(trajectory);
19
+ }
20
+ lastMotionIds = currentMotionIds;
21
+ } catch (error) {
22
+ console.error("Failed to get latest trajectories:", error);
23
+ }
24
+ return newTrajectories;
25
+ }
26
+
27
+ //#endregion
28
+ //#region src/lib/v1/ProgramStateConnection.ts
29
+ let ProgramState = /* @__PURE__ */ function(ProgramState$1) {
30
+ ProgramState$1["NotStarted"] = "not started";
31
+ ProgramState$1["Running"] = "running";
32
+ ProgramState$1["Stopped"] = "stopped";
33
+ ProgramState$1["Failed"] = "failed";
34
+ ProgramState$1["Completed"] = "completed";
35
+ return ProgramState$1;
36
+ }({});
37
+ /**
38
+ * Interface for running Wandelscript programs on the Nova instance and
39
+ * tracking their progress and output
40
+ */
41
+ var ProgramStateConnection = class {
42
+ constructor(nova) {
43
+ this.nova = nova;
44
+ this.currentProgram = {};
45
+ this.logs = [];
46
+ this.executionState = "idle";
47
+ this.currentlyExecutingProgramRunnerId = null;
48
+ makeAutoObservable(this, {}, { autoBind: true });
49
+ this.programStateSocket = nova.openReconnectingWebsocket(`/programs/state`);
50
+ this.programStateSocket.addEventListener("message", (ev) => {
51
+ const msg = tryParseJson(ev.data);
52
+ if (!msg) {
53
+ console.error("Failed to parse program state message", ev.data);
54
+ return;
55
+ }
56
+ if (msg.type === "update") this.handleProgramStateMessage(msg);
57
+ });
58
+ }
59
+ /** Handle a program state update from the backend */
60
+ async handleProgramStateMessage(msg) {
61
+ const { runner } = msg;
62
+ if (runner.id !== this.currentlyExecutingProgramRunnerId) return;
63
+ if (runner.state === ProgramState.Failed) {
64
+ try {
65
+ const runnerState = await this.nova.api.program.getProgramRunner(runner.id);
66
+ const stdout = runnerState.stdout;
67
+ if (stdout) this.log(stdout);
68
+ this.logError(`Program runner ${runner.id} failed with error: ${runnerState.error}\n${runnerState.traceback}`);
69
+ } catch (err) {
70
+ this.logError(`Failed to retrieve results for program ${runner.id}: ${err}`);
71
+ }
72
+ this.currentProgram.state = ProgramState.Failed;
73
+ this.gotoIdleState();
74
+ } else if (runner.state === ProgramState.Stopped) {
75
+ try {
76
+ const stdout = (await this.nova.api.program.getProgramRunner(runner.id)).stdout;
77
+ if (stdout) this.log(stdout);
78
+ this.currentProgram.state = ProgramState.Stopped;
79
+ this.log(`Program runner ${runner.id} stopped`);
80
+ } catch (err) {
81
+ this.logError(`Failed to retrieve results for program ${runner.id}: ${err}`);
82
+ }
83
+ this.gotoIdleState();
84
+ } else if (runner.state === ProgramState.Completed) {
85
+ try {
86
+ const stdout = (await this.nova.api.program.getProgramRunner(runner.id)).stdout;
87
+ if (stdout) this.log(stdout);
88
+ this.log(`Program runner ${runner.id} finished successfully in ${runner.execution_time?.toFixed(2)} seconds`);
89
+ this.currentProgram.state = ProgramState.Completed;
90
+ } catch (err) {
91
+ this.logError(`Failed to retrieve results for program ${runner.id}: ${err}`);
92
+ }
93
+ this.gotoIdleState();
94
+ } else if (runner.state === ProgramState.Running) {
95
+ this.currentProgram.state = ProgramState.Running;
96
+ this.log(`Program runner ${runner.id} now running`);
97
+ } else if (runner.state !== ProgramState.NotStarted) {
98
+ console.error(runner);
99
+ this.logError(`Program runner ${runner.id} entered unexpected state: ${runner.state}`);
100
+ this.currentProgram.state = ProgramState.NotStarted;
101
+ this.gotoIdleState();
102
+ }
103
+ }
104
+ /** Call when a program is no longer executing */
105
+ gotoIdleState() {
106
+ runInAction(() => {
107
+ this.executionState = "idle";
108
+ });
109
+ this.currentlyExecutingProgramRunnerId = null;
110
+ }
111
+ async executeProgram(wandelscript, initial_state, activeRobot) {
112
+ this.currentProgram = {
113
+ wandelscript,
114
+ state: ProgramState.NotStarted
115
+ };
116
+ const { currentProgram: openProgram } = this;
117
+ if (!openProgram) return;
118
+ runInAction(() => {
119
+ this.executionState = "starting";
120
+ });
121
+ if (activeRobot) try {
122
+ await this.nova.api.motionGroupJogging.stopJogging(activeRobot.motionGroupId);
123
+ } catch (err) {
124
+ console.error(err);
125
+ }
126
+ const trimmedCode = openProgram.wandelscript.replaceAll(/^\s*$/gm, "");
127
+ try {
128
+ const programRunnerRef = await this.nova.api.program.createProgramRunner({
129
+ code: trimmedCode,
130
+ initial_state,
131
+ default_robot: activeRobot?.wandelscriptIdentifier
132
+ }, { headers: { "Content-Type": "application/json" } });
133
+ this.log(`Created program runner ${programRunnerRef.id}"`);
134
+ runInAction(() => {
135
+ this.executionState = "executing";
136
+ });
137
+ this.currentlyExecutingProgramRunnerId = programRunnerRef.id;
138
+ } catch (error) {
139
+ if (error instanceof AxiosError && error.response && error.request) this.logError(`${error.response.status} ${error.response.statusText} from ${error.response.config.url} ${JSON.stringify(error.response.data)}`);
140
+ else this.logError(JSON.stringify(error));
141
+ runInAction(() => {
142
+ this.executionState = "idle";
143
+ });
144
+ }
145
+ }
146
+ async stopProgram() {
147
+ if (!this.currentlyExecutingProgramRunnerId) return;
148
+ runInAction(() => {
149
+ this.executionState = "stopping";
150
+ });
151
+ try {
152
+ await this.nova.api.program.stopProgramRunner(this.currentlyExecutingProgramRunnerId);
153
+ } catch (err) {
154
+ runInAction(() => {
155
+ this.executionState = "executing";
156
+ });
157
+ throw err;
158
+ }
159
+ }
160
+ reset() {
161
+ this.currentProgram = {};
162
+ }
163
+ log(message) {
164
+ console.log(message);
165
+ this.logs.push({
166
+ timestamp: Date.now(),
167
+ message
168
+ });
169
+ }
170
+ logError(message) {
171
+ console.log(message);
172
+ this.logs.push({
173
+ timestamp: Date.now(),
174
+ message,
175
+ level: "error"
176
+ });
177
+ }
178
+ };
179
+
180
+ //#endregion
181
+ export { ConnectedMotionGroup, JoggerConnection, MotionStreamConnection, NovaCellAPIClient, NovaClient, ProgramState, ProgramStateConnection, getLatestTrajectories, poseToWandelscriptString };
182
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":["lastMotionIds: Set<string>","newTrajectories: GetTrajectoryResponse[]","nova: NovaClient"],"sources":["../../../src/lib/v1/getLatestTrajectories.ts","../../../src/lib/v1/ProgramStateConnection.ts"],"sourcesContent":["import type { GetTrajectoryResponse } from \"@wandelbots/nova-api/v1\"\nimport type { NovaCellAPIClient } from \"./NovaCellAPIClient\"\n\nlet lastMotionIds: Set<string> = new Set()\n\nexport async function getLatestTrajectories(\n apiClient: NovaCellAPIClient,\n sampleTime: number = 50,\n responsesCoordinateSystem?: string,\n): Promise<GetTrajectoryResponse[]> {\n const newTrajectories: GetTrajectoryResponse[] = []\n\n try {\n const motions = await apiClient.motion.listMotions()\n const currentMotionIds = new Set(motions.motions)\n\n const newMotionIds = Array.from(currentMotionIds).filter(\n (id) => !lastMotionIds.has(id),\n )\n\n for (const motionId of newMotionIds) {\n const trajectory = await apiClient.motion.getMotionTrajectory(\n motionId,\n sampleTime,\n responsesCoordinateSystem,\n )\n newTrajectories.push(trajectory)\n }\n\n lastMotionIds = currentMotionIds\n } catch (error) {\n console.error(\"Failed to get latest trajectories:\", error)\n }\n\n return newTrajectories\n}\n","/** biome-ignore-all lint/style/noNonNullAssertion: legacy code */\nimport type { CollectionValue } from \"@wandelbots/nova-api/v1\"\nimport { AxiosError } from \"axios\"\nimport { makeAutoObservable, runInAction } from \"mobx\"\nimport type { AutoReconnectingWebsocket } from \"../AutoReconnectingWebsocket\"\nimport { tryParseJson } from \"../converters\"\nimport type { MotionStreamConnection } from \"./MotionStreamConnection\"\nimport type { NovaClient } from \"./NovaClient\"\n\nexport type ProgramRunnerLogEntry = {\n timestamp: number\n message: string\n level?: \"warn\" | \"error\"\n}\n\nexport enum ProgramState {\n NotStarted = \"not started\",\n Running = \"running\",\n Stopped = \"stopped\",\n Failed = \"failed\",\n Completed = \"completed\",\n}\n\nexport type CurrentProgram = {\n id?: string\n wandelscript?: string\n state?: ProgramState\n}\n\ntype ProgramStateMessage = {\n type: string\n runner: {\n id: string\n state: ProgramState\n start_time?: number | null\n execution_time?: number | null\n }\n}\n\n/**\n * Interface for running Wandelscript programs on the Nova instance and\n * tracking their progress and output\n */\nexport class ProgramStateConnection {\n currentProgram: CurrentProgram = {}\n logs: ProgramRunnerLogEntry[] = []\n\n executionState = \"idle\" as \"idle\" | \"starting\" | \"executing\" | \"stopping\"\n currentlyExecutingProgramRunnerId = null as string | null\n\n programStateSocket: AutoReconnectingWebsocket\n\n constructor(readonly nova: NovaClient) {\n makeAutoObservable(this, {}, { autoBind: true })\n\n this.programStateSocket = nova.openReconnectingWebsocket(`/programs/state`)\n\n this.programStateSocket.addEventListener(\"message\", (ev) => {\n const msg = tryParseJson(ev.data)\n\n if (!msg) {\n console.error(\"Failed to parse program state message\", ev.data)\n return\n }\n if (msg.type === \"update\") {\n this.handleProgramStateMessage(msg)\n }\n })\n }\n\n /** Handle a program state update from the backend */\n async handleProgramStateMessage(msg: ProgramStateMessage) {\n const { runner } = msg\n\n // Ignoring other programs for now\n // TODO - show if execution state is busy from another source\n if (runner.id !== this.currentlyExecutingProgramRunnerId) return\n\n if (runner.state === ProgramState.Failed) {\n try {\n const runnerState = await this.nova.api.program.getProgramRunner(\n runner.id,\n )\n\n // TODO - wandelengine should send print statements in real time over\n // websocket as well, rather than at the end\n const stdout = runnerState.stdout\n if (stdout) {\n this.log(stdout)\n }\n this.logError(\n `Program runner ${runner.id} failed with error: ${runnerState.error}\\n${runnerState.traceback}`,\n )\n } catch (err) {\n this.logError(\n `Failed to retrieve results for program ${runner.id}: ${err}`,\n )\n }\n\n this.currentProgram.state = ProgramState.Failed\n\n this.gotoIdleState()\n } else if (runner.state === ProgramState.Stopped) {\n try {\n const runnerState = await this.nova.api.program.getProgramRunner(\n runner.id,\n )\n\n const stdout = runnerState.stdout\n if (stdout) {\n this.log(stdout)\n }\n\n this.currentProgram.state = ProgramState.Stopped\n this.log(`Program runner ${runner.id} stopped`)\n } catch (err) {\n this.logError(\n `Failed to retrieve results for program ${runner.id}: ${err}`,\n )\n }\n\n this.gotoIdleState()\n } else if (runner.state === ProgramState.Completed) {\n try {\n const runnerState = await this.nova.api.program.getProgramRunner(\n runner.id,\n )\n\n const stdout = runnerState.stdout\n if (stdout) {\n this.log(stdout)\n }\n this.log(\n `Program runner ${runner.id} finished successfully in ${runner.execution_time?.toFixed(2)} seconds`,\n )\n\n this.currentProgram.state = ProgramState.Completed\n } catch (err) {\n this.logError(\n `Failed to retrieve results for program ${runner.id}: ${err}`,\n )\n }\n\n this.gotoIdleState()\n } else if (runner.state === ProgramState.Running) {\n this.currentProgram.state = ProgramState.Running\n this.log(`Program runner ${runner.id} now running`)\n } else if (runner.state !== ProgramState.NotStarted) {\n console.error(runner)\n this.logError(\n `Program runner ${runner.id} entered unexpected state: ${runner.state}`,\n )\n this.currentProgram.state = ProgramState.NotStarted\n this.gotoIdleState()\n }\n }\n\n /** Call when a program is no longer executing */\n gotoIdleState() {\n runInAction(() => {\n this.executionState = \"idle\"\n })\n this.currentlyExecutingProgramRunnerId = null\n }\n\n async executeProgram(\n wandelscript: string,\n initial_state?: { [key: string]: CollectionValue },\n activeRobot?: MotionStreamConnection,\n ) {\n this.currentProgram = {\n wandelscript: wandelscript,\n state: ProgramState.NotStarted,\n }\n\n const { currentProgram: openProgram } = this\n if (!openProgram) return\n runInAction(() => {\n this.executionState = \"starting\"\n })\n\n // Jogging can cause program execution to fail for some time after\n // So we need to explicitly stop jogging before running a program\n if (activeRobot) {\n try {\n await this.nova.api.motionGroupJogging.stopJogging(\n activeRobot.motionGroupId,\n )\n } catch (err) {\n console.error(err)\n }\n }\n\n // WOS-1539: Wandelengine parser currently breaks if there are empty lines with indentation\n const trimmedCode = openProgram.wandelscript!.replaceAll(/^\\s*$/gm, \"\")\n\n try {\n const programRunnerRef = await this.nova.api.program.createProgramRunner(\n {\n code: trimmedCode,\n initial_state: initial_state,\n // @ts-expect-error legacy code - check if param still used\n default_robot: activeRobot?.wandelscriptIdentifier,\n },\n {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n },\n )\n\n this.log(`Created program runner ${programRunnerRef.id}\"`)\n runInAction(() => {\n this.executionState = \"executing\"\n })\n this.currentlyExecutingProgramRunnerId = programRunnerRef.id\n } catch (error) {\n if (error instanceof AxiosError && error.response && error.request) {\n this.logError(\n `${error.response.status} ${error.response.statusText} from ${error.response.config.url} ${JSON.stringify(error.response.data)}`,\n )\n } else {\n this.logError(JSON.stringify(error))\n }\n runInAction(() => {\n this.executionState = \"idle\"\n })\n }\n }\n\n async stopProgram() {\n if (!this.currentlyExecutingProgramRunnerId) return\n runInAction(() => {\n this.executionState = \"stopping\"\n })\n\n try {\n await this.nova.api.program.stopProgramRunner(\n this.currentlyExecutingProgramRunnerId,\n )\n } catch (err) {\n // Reactivate the stop button so user can try again\n runInAction(() => {\n this.executionState = \"executing\"\n })\n throw err\n }\n }\n\n reset() {\n this.currentProgram = {}\n }\n\n log(message: string) {\n console.log(message)\n this.logs.push({\n timestamp: Date.now(),\n message,\n })\n }\n\n logError(message: string) {\n console.log(message)\n this.logs.push({\n timestamp: Date.now(),\n message,\n level: \"error\",\n })\n }\n}\n"],"mappings":"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"}