@particle-academy/agent-integrations 0.7.2 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bridges/artboard.d.cts +3 -3
- package/dist/bridges/artboard.d.ts +3 -3
- package/dist/bridges/charts.d.cts +3 -3
- package/dist/bridges/charts.d.ts +3 -3
- package/dist/bridges/code.d.cts +3 -3
- package/dist/bridges/code.d.ts +3 -3
- package/dist/bridges/flow.d.cts +3 -3
- package/dist/bridges/flow.d.ts +3 -3
- package/dist/bridges/forms.d.cts +3 -3
- package/dist/bridges/forms.d.ts +3 -3
- package/dist/bridges/scene.d.cts +3 -3
- package/dist/bridges/scene.d.ts +3 -3
- package/dist/bridges/screens.d.cts +3 -3
- package/dist/bridges/screens.d.ts +3 -3
- package/dist/bridges/sheets.d.cts +3 -3
- package/dist/bridges/sheets.d.ts +3 -3
- package/dist/bridges/slides.d.cts +4 -3
- package/dist/bridges/slides.d.ts +4 -3
- package/dist/bridges/whiteboard.d.cts +3 -3
- package/dist/bridges/whiteboard.d.ts +3 -3
- package/dist/bridges-artboard.cjs +15 -54
- package/dist/bridges-artboard.cjs.map +1 -1
- package/dist/bridges-artboard.js +3 -3
- package/dist/bridges-charts.cjs +3 -5
- package/dist/bridges-charts.cjs.map +1 -1
- package/dist/bridges-charts.js +3 -3
- package/dist/bridges-code.cjs +3 -5
- package/dist/bridges-code.cjs.map +1 -1
- package/dist/bridges-code.js +3 -3
- package/dist/bridges-flow.cjs +3 -5
- package/dist/bridges-flow.cjs.map +1 -1
- package/dist/bridges-flow.js +2 -2
- package/dist/bridges-forms.cjs +3 -5
- package/dist/bridges-forms.cjs.map +1 -1
- package/dist/bridges-forms.js +3 -3
- package/dist/bridges-scene.cjs +3 -5
- package/dist/bridges-scene.cjs.map +1 -1
- package/dist/bridges-scene.js +3 -3
- package/dist/bridges-screens.cjs +3 -5
- package/dist/bridges-screens.cjs.map +1 -1
- package/dist/bridges-screens.js +3 -3
- package/dist/bridges-sheets.cjs +3 -5
- package/dist/bridges-sheets.cjs.map +1 -1
- package/dist/bridges-sheets.js +3 -3
- package/dist/bridges-slides.cjs +24 -5
- package/dist/bridges-slides.cjs.map +1 -1
- package/dist/bridges-slides.js +3 -3
- package/dist/bridges-whiteboard.cjs +10 -49
- package/dist/bridges-whiteboard.cjs.map +1 -1
- package/dist/bridges-whiteboard.js +4 -4
- package/dist/{chunk-3KSZNGNW.js → chunk-3QJSOS7G.js} +4 -4
- package/dist/{chunk-3KSZNGNW.js.map → chunk-3QJSOS7G.js.map} +1 -1
- package/dist/{chunk-4BL5M3U3.js → chunk-5AD35HS5.js} +3 -3
- package/dist/{chunk-4BL5M3U3.js.map → chunk-5AD35HS5.js.map} +1 -1
- package/dist/chunk-C3TYI5TJ.js +3 -0
- package/dist/chunk-C3TYI5TJ.js.map +1 -0
- package/dist/{chunk-57ZDHD53.js → chunk-CKK4QKD2.js} +3 -3
- package/dist/{chunk-57ZDHD53.js.map → chunk-CKK4QKD2.js.map} +1 -1
- package/dist/{chunk-LVQXIUJH.js → chunk-CPNOF4HI.js} +3 -3
- package/dist/{chunk-LVQXIUJH.js.map → chunk-CPNOF4HI.js.map} +1 -1
- package/dist/{chunk-HSTW7ZNO.js → chunk-FYGMFIY5.js} +3 -3
- package/dist/{chunk-HSTW7ZNO.js.map → chunk-FYGMFIY5.js.map} +1 -1
- package/dist/{chunk-RGO42EQ6.js → chunk-GHY3PBPN.js} +3 -3
- package/dist/{chunk-RGO42EQ6.js.map → chunk-GHY3PBPN.js.map} +1 -1
- package/dist/{chunk-IANI25IT.js → chunk-GSVVIT2O.js} +3 -3
- package/dist/{chunk-IANI25IT.js.map → chunk-GSVVIT2O.js.map} +1 -1
- package/dist/{chunk-ZHAK2DQR.js → chunk-J5KYPEYB.js} +3 -3
- package/dist/{chunk-ZHAK2DQR.js.map → chunk-J5KYPEYB.js.map} +1 -1
- package/dist/{chunk-5XELJIJR.js → chunk-KHKSQEMC.js} +3 -3
- package/dist/{chunk-5XELJIJR.js.map → chunk-KHKSQEMC.js.map} +1 -1
- package/dist/{chunk-GQ7XXK7G.js → chunk-KJ5AOOV7.js} +5 -46
- package/dist/chunk-KJ5AOOV7.js.map +1 -0
- package/dist/{chunk-7X5ZAU4P.js → chunk-R5OA26MJ.js} +26 -4
- package/dist/chunk-R5OA26MJ.js.map +1 -0
- package/dist/{chunk-NTDZWGYB.js → chunk-SJ7H242B.js} +3 -3
- package/dist/{chunk-NTDZWGYB.js.map → chunk-SJ7H242B.js.map} +1 -1
- package/dist/{chunk-X66JWQBB.js → chunk-UCKJAUBY.js} +3 -3
- package/dist/{chunk-X66JWQBB.js.map → chunk-UCKJAUBY.js.map} +1 -1
- package/dist/{chunk-52S7XYZK.js → chunk-ULJL53DL.js} +3 -3
- package/dist/{chunk-52S7XYZK.js.map → chunk-ULJL53DL.js.map} +1 -1
- package/dist/{chunk-XRAJSOPS.js → chunk-VUMFO2UW.js} +3 -3
- package/dist/{chunk-XRAJSOPS.js.map → chunk-VUMFO2UW.js.map} +1 -1
- package/dist/components/SharedWhiteboard/index.d.cts +3 -3
- package/dist/components/SharedWhiteboard/index.d.ts +3 -3
- package/dist/components-shared-whiteboard.cjs +13 -79
- package/dist/components-shared-whiteboard.cjs.map +1 -1
- package/dist/components-shared-whiteboard.js +6 -6
- package/dist/index.cjs +82 -102
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +16 -15
- package/dist/index.d.ts +16 -15
- package/dist/index.js +17 -17
- package/dist/mcp/index.d.cts +5 -5
- package/dist/mcp/index.d.ts +5 -5
- package/dist/presence/index.d.cts +10 -64
- package/dist/presence/index.d.ts +10 -64
- package/dist/presence.cjs +21 -37
- package/dist/presence.cjs.map +1 -1
- package/dist/presence.js +3 -3
- package/dist/registry-TFWVXQOU.js +3 -0
- package/dist/{registry-2DRURS6U.js.map → registry-TFWVXQOU.js.map} +1 -1
- package/dist/{server-C2OpfPEo.d.cts → server-BsSwfemr.d.cts} +3 -3
- package/dist/{server-CKAqFTyc.d.ts → server-Du3-IGqM.d.ts} +3 -3
- package/dist/sharing/index.d.cts +4 -4
- package/dist/sharing/index.d.ts +4 -4
- package/dist/sharing.cjs +6 -34
- package/dist/sharing.cjs.map +1 -1
- package/dist/sharing.js +1 -1
- package/dist/sheets-adapter.cjs +2 -9
- package/dist/sheets-adapter.cjs.map +1 -1
- package/dist/sheets-adapter.d.cts +3 -3
- package/dist/sheets-adapter.d.ts +3 -3
- package/dist/sheets-adapter.js +2 -2
- package/dist/{token-C1O22GxJ.d.ts → token-CrJF76oH.d.cts} +1 -1
- package/dist/{token-C1O22GxJ.d.cts → token-CrJF76oH.d.ts} +1 -1
- package/dist/{tool-host-CX3WFXgh.d.cts → tool-host-BQuUygLF.d.cts} +1 -1
- package/dist/{tool-host-DldwGNqR.d.ts → tool-host-C8JMMGYq.d.ts} +1 -1
- package/dist/{types-Cq5u8MJ8.d.cts → types-CCSBGW9T.d.cts} +1 -1
- package/dist/{types-DyaHnqNC.d.ts → types-DIVNcIQO.d.ts} +1 -1
- package/dist/{types-C2zdUpzn.d.cts → types-aOQLTW0E.d.cts} +1 -1
- package/dist/{types-C2zdUpzn.d.ts → types-aOQLTW0E.d.ts} +1 -1
- package/dist/undo/index.d.cts +6 -43
- package/dist/undo/index.d.ts +6 -43
- package/dist/undo.cjs +31 -53
- package/dist/undo.cjs.map +1 -1
- package/dist/undo.js +2 -2
- package/package.json +188 -51
- package/dist/chunk-7X5ZAU4P.js.map +0 -1
- package/dist/chunk-GQ7XXK7G.js.map +0 -1
- package/dist/chunk-JU2N4KK6.js +0 -34
- package/dist/chunk-JU2N4KK6.js.map +0 -1
- package/dist/registry-2DRURS6U.js +0 -3
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ShareControls, AgentCursor, AgentActivityHighlight, AgentPanel } from './chunk-
|
|
2
|
-
import { createSessionDescriptor, attachSseRelay } from './chunk-
|
|
1
|
+
import { ShareControls, AgentCursor, AgentActivityHighlight, AgentPanel } from './chunk-J5KYPEYB.js';
|
|
2
|
+
import { createSessionDescriptor, attachSseRelay } from './chunk-CPNOF4HI.js';
|
|
3
3
|
import { attachInProcess } from './chunk-AFUULW5E.js';
|
|
4
|
-
import { registerWhiteboardBridge } from './chunk-
|
|
5
|
-
import './chunk-
|
|
6
|
-
import './chunk-
|
|
7
|
-
import './chunk-
|
|
4
|
+
import { registerWhiteboardBridge } from './chunk-3QJSOS7G.js';
|
|
5
|
+
import './chunk-KJ5AOOV7.js';
|
|
6
|
+
import './chunk-ULJL53DL.js';
|
|
7
|
+
import './chunk-C3TYI5TJ.js';
|
|
8
8
|
import { MicroMcpServer } from './chunk-4KAIV6OD.js';
|
|
9
9
|
import { useState, useRef, useEffect, useCallback, useMemo } from 'react';
|
|
10
10
|
import { Board, Connector, Shape, StickyNote, CursorLayer } from '@particle-academy/fancy-whiteboard';
|
package/dist/index.cjs
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var fancyAutoCommon = require('@particle-academy/fancy-auto-common');
|
|
3
4
|
var react = require('react');
|
|
4
5
|
var fancySlides = require('@particle-academy/fancy-slides');
|
|
5
6
|
var jsxRuntime = require('react/jsx-runtime');
|
|
@@ -17,43 +18,13 @@ var __export = (target, all) => {
|
|
|
17
18
|
// src/presence/registry.ts
|
|
18
19
|
var registry_exports = {};
|
|
19
20
|
__export(registry_exports, {
|
|
20
|
-
emitActivity: () => emitActivity,
|
|
21
|
-
onActivity: () => onActivity,
|
|
22
|
-
readActivityHistory: () => readActivityHistory,
|
|
23
|
-
resetActivityRegistry: () => resetActivityRegistry
|
|
21
|
+
emitActivity: () => fancyAutoCommon.emitActivity,
|
|
22
|
+
onActivity: () => fancyAutoCommon.onActivity,
|
|
23
|
+
readActivityHistory: () => fancyAutoCommon.readActivityHistory,
|
|
24
|
+
resetActivityRegistry: () => fancyAutoCommon.resetActivityRegistry
|
|
24
25
|
});
|
|
25
|
-
function emitActivity(event) {
|
|
26
|
-
history.push(event);
|
|
27
|
-
if (history.length > HISTORY_CAP) history.splice(0, history.length - HISTORY_CAP);
|
|
28
|
-
for (const l of listeners) l(event);
|
|
29
|
-
}
|
|
30
|
-
function onActivity(listener, filter) {
|
|
31
|
-
const wrapped = filter ? (e) => {
|
|
32
|
-
if (matches(e, filter)) listener(e);
|
|
33
|
-
} : listener;
|
|
34
|
-
listeners.add(wrapped);
|
|
35
|
-
return () => listeners.delete(wrapped);
|
|
36
|
-
}
|
|
37
|
-
function readActivityHistory(filter) {
|
|
38
|
-
if (!filter) return history.slice();
|
|
39
|
-
return history.filter((e) => matches(e, filter));
|
|
40
|
-
}
|
|
41
|
-
function resetActivityRegistry() {
|
|
42
|
-
listeners.clear();
|
|
43
|
-
history.length = 0;
|
|
44
|
-
}
|
|
45
|
-
function matches(e, f) {
|
|
46
|
-
if (f.agentId !== void 0 && e.agentId !== f.agentId) return false;
|
|
47
|
-
if (f.screenId !== void 0 && e.target.screenId !== f.screenId) return false;
|
|
48
|
-
if (f.kind !== void 0 && e.target.kind !== f.kind) return false;
|
|
49
|
-
return true;
|
|
50
|
-
}
|
|
51
|
-
var HISTORY_CAP, listeners, history;
|
|
52
26
|
var init_registry = __esm({
|
|
53
27
|
"src/presence/registry.ts"() {
|
|
54
|
-
HISTORY_CAP = 200;
|
|
55
|
-
listeners = /* @__PURE__ */ new Set();
|
|
56
|
-
history = [];
|
|
57
28
|
}
|
|
58
29
|
});
|
|
59
30
|
|
|
@@ -288,7 +259,7 @@ function wrapToolWithActivity(handler, options) {
|
|
|
288
259
|
target = { kind: options.kind, screenId: options.screenId };
|
|
289
260
|
}
|
|
290
261
|
if (!target) return result;
|
|
291
|
-
emitActivity({
|
|
262
|
+
fancyAutoCommon.emitActivity({
|
|
292
263
|
agentId: options.agent.id,
|
|
293
264
|
agentName: options.agent.name,
|
|
294
265
|
agentColor: options.agent.color,
|
|
@@ -775,7 +746,7 @@ function useSheetsActivityHighlights(options = {}) {
|
|
|
775
746
|
const [, force] = react.useState(0);
|
|
776
747
|
const hitsRef = react.useRef(/* @__PURE__ */ new Map());
|
|
777
748
|
react.useEffect(() => {
|
|
778
|
-
const off = onActivity((event) => {
|
|
749
|
+
const off = fancyAutoCommon.onActivity((event) => {
|
|
779
750
|
if (event.target?.kind !== "sheet") return;
|
|
780
751
|
if (screenId && event.target.screenId && event.target.screenId !== screenId) return;
|
|
781
752
|
const elementId = event.target.elementId;
|
|
@@ -1617,6 +1588,28 @@ function registerSlidesBridge(host, options) {
|
|
|
1617
1588
|
true,
|
|
1618
1589
|
deckTarget
|
|
1619
1590
|
);
|
|
1591
|
+
reg(
|
|
1592
|
+
"deck_set",
|
|
1593
|
+
"Replace the entire deck atomically \u2014 stream a full presentation in. Pass a complete Deck object ({ id, title, theme, slides }). Validated + migrated before it lands; the prior deck is the undo snapshot.",
|
|
1594
|
+
{ deck: { description: "A complete Deck object." } },
|
|
1595
|
+
["deck"],
|
|
1596
|
+
(args) => {
|
|
1597
|
+
const incoming = args.deck;
|
|
1598
|
+
if (!incoming || typeof incoming !== "object") {
|
|
1599
|
+
return errorResult("deck must be a complete Deck object ({ id, title, theme, slides }).");
|
|
1600
|
+
}
|
|
1601
|
+
let deck;
|
|
1602
|
+
try {
|
|
1603
|
+
deck = fancySlides.parseDeck(incoming);
|
|
1604
|
+
} catch (e) {
|
|
1605
|
+
return errorResult(e instanceof Error ? e.message : String(e));
|
|
1606
|
+
}
|
|
1607
|
+
adapter.apply({ kind: "deck_set", deck });
|
|
1608
|
+
return textResult(`Loaded deck "${deck.title}" (${deck.slides.length} slides)`, { id: deck.id, slides: deck.slides.length });
|
|
1609
|
+
},
|
|
1610
|
+
true,
|
|
1611
|
+
deckTarget
|
|
1612
|
+
);
|
|
1620
1613
|
reg(
|
|
1621
1614
|
"slide_add",
|
|
1622
1615
|
"Insert a slide at `index` (defaults to end). Returns the new slide's id. Accepts a partial slide payload.",
|
|
@@ -2106,7 +2099,7 @@ init_registry();
|
|
|
2106
2099
|
function ScreensActivityBridge({ system, fadeMs = 1500 }) {
|
|
2107
2100
|
react.useEffect(() => {
|
|
2108
2101
|
const fadeTimers = /* @__PURE__ */ new Map();
|
|
2109
|
-
const off = onActivity((event) => {
|
|
2102
|
+
const off = fancyAutoCommon.onActivity((event) => {
|
|
2110
2103
|
const screenId = event.target.screenId;
|
|
2111
2104
|
if (!screenId) return;
|
|
2112
2105
|
if (!system.registry.has(screenId)) return;
|
|
@@ -2319,10 +2312,10 @@ init_registry();
|
|
|
2319
2312
|
init_registry();
|
|
2320
2313
|
function useAgentActivity(filter, options = {}) {
|
|
2321
2314
|
const cap = options.capacity ?? 50;
|
|
2322
|
-
const [events, setEvents] = react.useState(() => readActivityHistory(filter).slice(-cap));
|
|
2315
|
+
const [events, setEvents] = react.useState(() => fancyAutoCommon.readActivityHistory(filter).slice(-cap));
|
|
2323
2316
|
react.useEffect(() => {
|
|
2324
|
-
setEvents(readActivityHistory(filter).slice(-cap));
|
|
2325
|
-
return onActivity((event) => {
|
|
2317
|
+
setEvents(fancyAutoCommon.readActivityHistory(filter).slice(-cap));
|
|
2318
|
+
return fancyAutoCommon.onActivity((event) => {
|
|
2326
2319
|
setEvents((prev) => {
|
|
2327
2320
|
const next = prev.length >= cap ? prev.slice(prev.length - cap + 1) : prev.slice();
|
|
2328
2321
|
next.push(event);
|
|
@@ -2348,49 +2341,6 @@ function useAgentActivityForScreen(screenId, options = {}) {
|
|
|
2348
2341
|
return { events, latest, isAgentActive };
|
|
2349
2342
|
}
|
|
2350
2343
|
|
|
2351
|
-
// src/undo/undo-stack.ts
|
|
2352
|
-
var stacks = /* @__PURE__ */ new Map();
|
|
2353
|
-
var CAP = 200;
|
|
2354
|
-
function getStack(agentId) {
|
|
2355
|
-
let s = stacks.get(agentId);
|
|
2356
|
-
if (!s) {
|
|
2357
|
-
s = { past: [], future: [] };
|
|
2358
|
-
stacks.set(agentId, s);
|
|
2359
|
-
}
|
|
2360
|
-
return s;
|
|
2361
|
-
}
|
|
2362
|
-
function pushUndoEntry(agentId, entry) {
|
|
2363
|
-
const s = getStack(agentId);
|
|
2364
|
-
s.past.push(entry);
|
|
2365
|
-
if (s.past.length > CAP) s.past.splice(0, s.past.length - CAP);
|
|
2366
|
-
s.future.length = 0;
|
|
2367
|
-
}
|
|
2368
|
-
async function undoOne(agentId) {
|
|
2369
|
-
const s = getStack(agentId);
|
|
2370
|
-
const entry = s.past.pop();
|
|
2371
|
-
if (!entry) return null;
|
|
2372
|
-
await entry.undo();
|
|
2373
|
-
s.future.push(entry);
|
|
2374
|
-
return entry;
|
|
2375
|
-
}
|
|
2376
|
-
async function redoOne(agentId) {
|
|
2377
|
-
const s = getStack(agentId);
|
|
2378
|
-
const entry = s.future.pop();
|
|
2379
|
-
if (!entry) return null;
|
|
2380
|
-
await entry.redo();
|
|
2381
|
-
s.past.push(entry);
|
|
2382
|
-
return entry;
|
|
2383
|
-
}
|
|
2384
|
-
function readHistory(agentId) {
|
|
2385
|
-
return getStack(agentId).past.slice();
|
|
2386
|
-
}
|
|
2387
|
-
function clearStack(agentId) {
|
|
2388
|
-
stacks.delete(agentId);
|
|
2389
|
-
}
|
|
2390
|
-
function resetAllUndoStacks() {
|
|
2391
|
-
stacks.clear();
|
|
2392
|
-
}
|
|
2393
|
-
|
|
2394
2344
|
// src/undo/undo-tools.ts
|
|
2395
2345
|
var installedHosts = /* @__PURE__ */ new WeakSet();
|
|
2396
2346
|
function ensureUndoToolsRegistered(host, options = {}) {
|
|
@@ -2414,7 +2364,7 @@ function registerUndoTools(host, options = {}) {
|
|
|
2414
2364
|
}
|
|
2415
2365
|
},
|
|
2416
2366
|
async (args) => {
|
|
2417
|
-
const entry = await undoOne(agentOf(args));
|
|
2367
|
+
const entry = await fancyAutoCommon.undoOne(agentOf(args));
|
|
2418
2368
|
if (!entry) return errorResult("Nothing to undo.");
|
|
2419
2369
|
return textResult(`Undid: ${entry.label}`, { entry: serialize(entry) });
|
|
2420
2370
|
}
|
|
@@ -2432,7 +2382,7 @@ function registerUndoTools(host, options = {}) {
|
|
|
2432
2382
|
}
|
|
2433
2383
|
},
|
|
2434
2384
|
async (args) => {
|
|
2435
|
-
const entry = await redoOne(agentOf(args));
|
|
2385
|
+
const entry = await fancyAutoCommon.redoOne(agentOf(args));
|
|
2436
2386
|
if (!entry) return errorResult("Nothing to redo.");
|
|
2437
2387
|
return textResult(`Redid: ${entry.label}`, { entry: serialize(entry) });
|
|
2438
2388
|
}
|
|
@@ -2450,9 +2400,9 @@ function registerUndoTools(host, options = {}) {
|
|
|
2450
2400
|
}
|
|
2451
2401
|
},
|
|
2452
2402
|
async (args) => {
|
|
2453
|
-
const
|
|
2454
|
-
const text =
|
|
2455
|
-
return textResult(text || "(empty)",
|
|
2403
|
+
const history = fancyAutoCommon.readHistory(agentOf(args)).map(serialize);
|
|
2404
|
+
const text = history.map((e) => `${new Date(e.timestamp).toISOString()} ${e.bridgeId} ${e.action}: ${e.label}`).join("\n");
|
|
2405
|
+
return textResult(text || "(empty)", history);
|
|
2456
2406
|
}
|
|
2457
2407
|
)
|
|
2458
2408
|
);
|
|
@@ -2467,12 +2417,12 @@ function serialize(entry) {
|
|
|
2467
2417
|
};
|
|
2468
2418
|
}
|
|
2469
2419
|
function useUndoStack(agentId, intervalMs = 500) {
|
|
2470
|
-
const [
|
|
2420
|
+
const [history, setHistory] = react.useState(() => fancyAutoCommon.readHistory(agentId));
|
|
2471
2421
|
react.useEffect(() => {
|
|
2472
2422
|
let cancelled = false;
|
|
2473
2423
|
const tick = () => {
|
|
2474
2424
|
if (cancelled) return;
|
|
2475
|
-
setHistory(readHistory(agentId));
|
|
2425
|
+
setHistory(fancyAutoCommon.readHistory(agentId));
|
|
2476
2426
|
};
|
|
2477
2427
|
const id = setInterval(tick, intervalMs);
|
|
2478
2428
|
tick();
|
|
@@ -2481,8 +2431,8 @@ function useUndoStack(agentId, intervalMs = 500) {
|
|
|
2481
2431
|
clearInterval(id);
|
|
2482
2432
|
};
|
|
2483
2433
|
}, [agentId, intervalMs]);
|
|
2484
|
-
const refresh = react.useCallback(() => setHistory(readHistory(agentId)), [agentId]);
|
|
2485
|
-
return { history
|
|
2434
|
+
const refresh = react.useCallback(() => setHistory(fancyAutoCommon.readHistory(agentId)), [agentId]);
|
|
2435
|
+
return { history, refresh };
|
|
2486
2436
|
}
|
|
2487
2437
|
|
|
2488
2438
|
// src/sharing/sse-relay.ts
|
|
@@ -2598,6 +2548,46 @@ function attachSseRelay(server, options) {
|
|
|
2598
2548
|
return transport;
|
|
2599
2549
|
}
|
|
2600
2550
|
|
|
2551
|
+
Object.defineProperty(exports, "clearUndoStack", {
|
|
2552
|
+
enumerable: true,
|
|
2553
|
+
get: function () { return fancyAutoCommon.clearStack; }
|
|
2554
|
+
});
|
|
2555
|
+
Object.defineProperty(exports, "emitActivity", {
|
|
2556
|
+
enumerable: true,
|
|
2557
|
+
get: function () { return fancyAutoCommon.emitActivity; }
|
|
2558
|
+
});
|
|
2559
|
+
Object.defineProperty(exports, "onActivity", {
|
|
2560
|
+
enumerable: true,
|
|
2561
|
+
get: function () { return fancyAutoCommon.onActivity; }
|
|
2562
|
+
});
|
|
2563
|
+
Object.defineProperty(exports, "pushUndoEntry", {
|
|
2564
|
+
enumerable: true,
|
|
2565
|
+
get: function () { return fancyAutoCommon.pushUndoEntry; }
|
|
2566
|
+
});
|
|
2567
|
+
Object.defineProperty(exports, "readActivityHistory", {
|
|
2568
|
+
enumerable: true,
|
|
2569
|
+
get: function () { return fancyAutoCommon.readActivityHistory; }
|
|
2570
|
+
});
|
|
2571
|
+
Object.defineProperty(exports, "readUndoHistory", {
|
|
2572
|
+
enumerable: true,
|
|
2573
|
+
get: function () { return fancyAutoCommon.readHistory; }
|
|
2574
|
+
});
|
|
2575
|
+
Object.defineProperty(exports, "redoOne", {
|
|
2576
|
+
enumerable: true,
|
|
2577
|
+
get: function () { return fancyAutoCommon.redoOne; }
|
|
2578
|
+
});
|
|
2579
|
+
Object.defineProperty(exports, "resetActivityRegistry", {
|
|
2580
|
+
enumerable: true,
|
|
2581
|
+
get: function () { return fancyAutoCommon.resetActivityRegistry; }
|
|
2582
|
+
});
|
|
2583
|
+
Object.defineProperty(exports, "resetAllUndoStacks", {
|
|
2584
|
+
enumerable: true,
|
|
2585
|
+
get: function () { return fancyAutoCommon.resetAllUndoStacks; }
|
|
2586
|
+
});
|
|
2587
|
+
Object.defineProperty(exports, "undoOne", {
|
|
2588
|
+
enumerable: true,
|
|
2589
|
+
get: function () { return fancyAutoCommon.undoOne; }
|
|
2590
|
+
});
|
|
2601
2591
|
exports.AgentActivityHighlight = AgentActivityHighlight;
|
|
2602
2592
|
exports.AgentCursor = AgentCursor;
|
|
2603
2593
|
exports.AgentPanel = AgentPanel;
|
|
@@ -2615,18 +2605,11 @@ exports.attachRelay = attachRelay;
|
|
|
2615
2605
|
exports.attachSseRelay = attachSseRelay;
|
|
2616
2606
|
exports.buildShareConfig = buildShareConfig;
|
|
2617
2607
|
exports.buildShareUrl = buildShareUrl;
|
|
2618
|
-
exports.clearUndoStack = clearStack;
|
|
2619
2608
|
exports.createSessionDescriptor = createSessionDescriptor;
|
|
2620
2609
|
exports.describeSession = describeSession;
|
|
2621
|
-
exports.emitActivity = emitActivity;
|
|
2622
2610
|
exports.ensureUndoToolsRegistered = ensureUndoToolsRegistered;
|
|
2623
2611
|
exports.errorResult = errorResult;
|
|
2624
|
-
exports.onActivity = onActivity;
|
|
2625
|
-
exports.pushUndoEntry = pushUndoEntry;
|
|
2626
|
-
exports.readActivityHistory = readActivityHistory;
|
|
2627
2612
|
exports.readSessionFromUrl = readSessionFromUrl;
|
|
2628
|
-
exports.readUndoHistory = readHistory;
|
|
2629
|
-
exports.redoOne = redoOne;
|
|
2630
2613
|
exports.registerChartsBridge = registerChartsBridge;
|
|
2631
2614
|
exports.registerCodeBridge = registerCodeBridge;
|
|
2632
2615
|
exports.registerFormBridge = registerFormBridge;
|
|
@@ -2635,11 +2618,8 @@ exports.registerScreensBridge = registerScreensBridge;
|
|
|
2635
2618
|
exports.registerSheetsBridge = registerSheetsBridge;
|
|
2636
2619
|
exports.registerSlidesBridge = registerSlidesBridge;
|
|
2637
2620
|
exports.registerUndoTools = registerUndoTools;
|
|
2638
|
-
exports.resetActivityRegistry = resetActivityRegistry;
|
|
2639
|
-
exports.resetAllUndoStacks = resetAllUndoStacks;
|
|
2640
2621
|
exports.rpcError = rpcError;
|
|
2641
2622
|
exports.textResult = textResult;
|
|
2642
|
-
exports.undoOne = undoOne;
|
|
2643
2623
|
exports.useAgentActivity = useAgentActivity;
|
|
2644
2624
|
exports.useAgentActivityForScreen = useAgentActivityForScreen;
|
|
2645
2625
|
exports.useSheetsActivityHighlights = useSheetsActivityHighlights;
|