cli-jaw 2.0.1 → 2.0.2
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.ko.md +3 -2
- package/README.md +41 -12
- package/dist/bin/_http-client.js +34 -0
- package/dist/bin/_http-client.js.map +1 -0
- package/dist/bin/cli-jaw.js +10 -5
- package/dist/bin/cli-jaw.js.map +1 -1
- package/dist/bin/commands/browser-web-ai.js +155 -38
- package/dist/bin/commands/browser-web-ai.js.map +1 -1
- package/dist/bin/commands/browser.js +265 -37
- package/dist/bin/commands/browser.js.map +1 -1
- package/dist/bin/commands/chat.js +18 -14
- package/dist/bin/commands/chat.js.map +1 -1
- package/dist/bin/commands/clone.js +3 -2
- package/dist/bin/commands/clone.js.map +1 -1
- package/dist/bin/commands/dashboard.js +22 -18
- package/dist/bin/commands/dashboard.js.map +1 -1
- package/dist/bin/commands/dispatch.js +9 -11
- package/dist/bin/commands/dispatch.js.map +1 -1
- package/dist/bin/commands/doctor.js +26 -14
- package/dist/bin/commands/doctor.js.map +1 -1
- package/dist/bin/commands/employee.js +12 -7
- package/dist/bin/commands/employee.js.map +1 -1
- package/dist/bin/commands/init.js +9 -9
- package/dist/bin/commands/init.js.map +1 -1
- package/dist/bin/commands/launchd.js +17 -7
- package/dist/bin/commands/launchd.js.map +1 -1
- package/dist/bin/commands/mcp.js +7 -4
- package/dist/bin/commands/mcp.js.map +1 -1
- package/dist/bin/commands/memory.js +7 -5
- package/dist/bin/commands/memory.js.map +1 -1
- package/dist/bin/commands/orchestrate.js +6 -3
- package/dist/bin/commands/orchestrate.js.map +1 -1
- package/dist/bin/commands/reset.js +4 -3
- package/dist/bin/commands/reset.js.map +1 -1
- package/dist/bin/commands/serve.js +3 -2
- package/dist/bin/commands/serve.js.map +1 -1
- package/dist/bin/commands/service.js +2 -2
- package/dist/bin/commands/service.js.map +1 -1
- package/dist/bin/commands/status.js +10 -9
- package/dist/bin/commands/status.js.map +1 -1
- package/dist/bin/commands/tui/api.js +26 -18
- package/dist/bin/commands/tui/api.js.map +1 -1
- package/dist/bin/commands/tui/overlays.js +3 -1
- package/dist/bin/commands/tui/overlays.js.map +1 -1
- package/dist/bin/commands/tui/simple-mode.js +1 -1
- package/dist/bin/commands/tui/simple-mode.js.map +1 -1
- package/dist/bin/commands/tui/types.js.map +1 -1
- package/dist/bin/postinstall.js +153 -65
- package/dist/bin/postinstall.js.map +1 -1
- package/dist/bin/star-prompt.js +4 -3
- package/dist/bin/star-prompt.js.map +1 -1
- package/dist/lib/mcp/format-converters.js +15 -10
- package/dist/lib/mcp/format-converters.js.map +1 -1
- package/dist/lib/mcp/mcp-install.js +2 -2
- package/dist/lib/mcp/mcp-install.js.map +1 -1
- package/dist/lib/mcp/skills-distribution.js +2 -2
- package/dist/lib/mcp/skills-distribution.js.map +1 -1
- package/dist/lib/mcp/skills-reset.js +5 -4
- package/dist/lib/mcp/skills-reset.js.map +1 -1
- package/dist/lib/mcp/skills-symlinks.js +9 -9
- package/dist/lib/mcp/skills-symlinks.js.map +1 -1
- package/dist/lib/mcp/skills-utils.js +5 -4
- package/dist/lib/mcp/skills-utils.js.map +1 -1
- package/dist/lib/mcp/unified-config.js +3 -2
- package/dist/lib/mcp/unified-config.js.map +1 -1
- package/dist/lib/mime-detect.js +65 -0
- package/dist/lib/mime-detect.js.map +1 -0
- package/dist/lib/quota-copilot.js +12 -10
- package/dist/lib/quota-copilot.js.map +1 -1
- package/dist/lib/stt.js +3 -3
- package/dist/lib/stt.js.map +1 -1
- package/dist/lib/upload.js +14 -5
- package/dist/lib/upload.js.map +1 -1
- package/dist/scripts/i18n-registry.js +4 -4
- package/dist/scripts/i18n-registry.js.map +1 -1
- package/dist/server.js +61 -57
- package/dist/server.js.map +1 -1
- package/dist/src/agent/alert-escalation.js +61 -0
- package/dist/src/agent/alert-escalation.js.map +1 -0
- package/dist/src/agent/args.js +71 -2
- package/dist/src/agent/args.js.map +1 -1
- package/dist/src/agent/error-classifier.js +9 -4
- package/dist/src/agent/error-classifier.js.map +1 -1
- package/dist/src/agent/events.js +130 -101
- package/dist/src/agent/events.js.map +1 -1
- package/dist/src/agent/lifecycle-handler.js +44 -19
- package/dist/src/agent/lifecycle-handler.js.map +1 -1
- package/dist/src/agent/live-run-state.js +7 -3
- package/dist/src/agent/live-run-state.js.map +1 -1
- package/dist/src/agent/memory-flush-controller.js +6 -4
- package/dist/src/agent/memory-flush-controller.js.map +1 -1
- package/dist/src/agent/opencode-diagnostics.js +7 -6
- package/dist/src/agent/opencode-diagnostics.js.map +1 -1
- package/dist/src/agent/session-persistence.js +1 -1
- package/dist/src/agent/session-persistence.js.map +1 -1
- package/dist/src/agent/spawn-env.js +33 -16
- package/dist/src/agent/spawn-env.js.map +1 -1
- package/dist/src/agent/spawn.js +176 -110
- package/dist/src/agent/spawn.js.map +1 -1
- package/dist/src/agent/watchdog.js +56 -0
- package/dist/src/agent/watchdog.js.map +1 -0
- package/dist/src/browser/actions.js +179 -70
- package/dist/src/browser/actions.js.map +1 -1
- package/dist/src/browser/connection.js +296 -19
- package/dist/src/browser/connection.js.map +1 -1
- package/dist/src/browser/index.js +4 -1
- package/dist/src/browser/index.js.map +1 -1
- package/dist/src/browser/launch-policy.js +1 -1
- package/dist/src/browser/launch-policy.js.map +1 -1
- package/dist/src/browser/primitives.js +11 -7
- package/dist/src/browser/primitives.js.map +1 -1
- package/dist/src/browser/runtime-diagnostics.js +45 -0
- package/dist/src/browser/runtime-diagnostics.js.map +1 -0
- package/dist/src/browser/runtime-orphans.js +127 -0
- package/dist/src/browser/runtime-orphans.js.map +1 -0
- package/dist/src/browser/runtime-owner-store.js +51 -0
- package/dist/src/browser/runtime-owner-store.js.map +1 -0
- package/dist/src/browser/runtime-owner.js +2 -2
- package/dist/src/browser/runtime-owner.js.map +1 -1
- package/dist/src/browser/tab-lifecycle.js +157 -0
- package/dist/src/browser/tab-lifecycle.js.map +1 -0
- package/dist/src/browser/vision.js +35 -11
- package/dist/src/browser/vision.js.map +1 -1
- package/dist/src/browser/web-ai/action-breadth.js +56 -0
- package/dist/src/browser/web-ai/action-breadth.js.map +1 -0
- package/dist/src/browser/web-ai/action-cache.js +9 -8
- package/dist/src/browser/web-ai/action-cache.js.map +1 -1
- package/dist/src/browser/web-ai/action-intent.js +64 -0
- package/dist/src/browser/web-ai/action-intent.js.map +1 -0
- package/dist/src/browser/web-ai/action-memory.js +82 -0
- package/dist/src/browser/web-ai/action-memory.js.map +1 -0
- package/dist/src/browser/web-ai/action-trace.js +11 -6
- package/dist/src/browser/web-ai/action-trace.js.map +1 -1
- package/dist/src/browser/web-ai/annotated-screenshot.js +2 -1
- package/dist/src/browser/web-ai/annotated-screenshot.js.map +1 -1
- package/dist/src/browser/web-ai/answer-artifact.js +97 -0
- package/dist/src/browser/web-ai/answer-artifact.js.map +1 -0
- package/dist/src/browser/web-ai/ax-snapshot.js +3 -2
- package/dist/src/browser/web-ai/ax-snapshot.js.map +1 -1
- package/dist/src/browser/web-ai/browser-primitives.js +10 -7
- package/dist/src/browser/web-ai/browser-primitives.js.map +1 -1
- package/dist/src/browser/web-ai/capability-registry.js +1 -1
- package/dist/src/browser/web-ai/capability-registry.js.map +1 -1
- package/dist/src/browser/web-ai/chatgpt-composer.js +12 -12
- package/dist/src/browser/web-ai/chatgpt-composer.js.map +1 -1
- package/dist/src/browser/web-ai/chatgpt-model.js +469 -50
- package/dist/src/browser/web-ai/chatgpt-model.js.map +1 -1
- package/dist/src/browser/web-ai/chatgpt-response.js +82 -10
- package/dist/src/browser/web-ai/chatgpt-response.js.map +1 -1
- package/dist/src/browser/web-ai/chatgpt.js +325 -49
- package/dist/src/browser/web-ai/chatgpt.js.map +1 -1
- package/dist/src/browser/web-ai/churn-log.js +1 -1
- package/dist/src/browser/web-ai/churn-log.js.map +1 -1
- package/dist/src/browser/web-ai/cli-sessions.js +42 -26
- package/dist/src/browser/web-ai/cli-sessions.js.map +1 -1
- package/dist/src/browser/web-ai/context-pack/builder.js +1 -1
- package/dist/src/browser/web-ai/context-pack/builder.js.map +1 -1
- package/dist/src/browser/web-ai/context-pack/file-selector.js +2 -2
- package/dist/src/browser/web-ai/context-pack/file-selector.js.map +1 -1
- package/dist/src/browser/web-ai/context-pack/report.js +1 -1
- package/dist/src/browser/web-ai/context-pack/report.js.map +1 -1
- package/dist/src/browser/web-ai/copy-markdown.js +25 -5
- package/dist/src/browser/web-ai/copy-markdown.js.map +1 -1
- package/dist/src/browser/web-ai/diagnostics.js +17 -14
- package/dist/src/browser/web-ai/diagnostics.js.map +1 -1
- package/dist/src/browser/web-ai/doctor.js +10 -6
- package/dist/src/browser/web-ai/doctor.js.map +1 -1
- package/dist/src/browser/web-ai/dom-hash.js.map +1 -1
- package/dist/src/browser/web-ai/errors.js +5 -22
- package/dist/src/browser/web-ai/errors.js.map +1 -1
- package/dist/src/browser/web-ai/gemini-live.js +7 -6
- package/dist/src/browser/web-ai/gemini-live.js.map +1 -1
- package/dist/src/browser/web-ai/grok-live.js +9 -5
- package/dist/src/browser/web-ai/grok-live.js.map +1 -1
- package/dist/src/browser/web-ai/index.js +5 -0
- package/dist/src/browser/web-ai/index.js.map +1 -1
- package/dist/src/browser/web-ai/observation-bundle.js +90 -0
- package/dist/src/browser/web-ai/observation-bundle.js.map +1 -0
- package/dist/src/browser/web-ai/observe-actions.js +186 -0
- package/dist/src/browser/web-ai/observe-actions.js.map +1 -0
- package/dist/src/browser/web-ai/observe-targets.js +6 -1
- package/dist/src/browser/web-ai/observe-targets.js.map +1 -1
- package/dist/src/browser/web-ai/planner-contract.js +18 -0
- package/dist/src/browser/web-ai/planner-contract.js.map +1 -0
- package/dist/src/browser/web-ai/post-action-assert.js +8 -7
- package/dist/src/browser/web-ai/post-action-assert.js.map +1 -1
- package/dist/src/browser/web-ai/product-surfaces.js +2 -1
- package/dist/src/browser/web-ai/product-surfaces.js.map +1 -1
- package/dist/src/browser/web-ai/provider-adapter.js.map +1 -1
- package/dist/src/browser/web-ai/question.js +14 -7
- package/dist/src/browser/web-ai/question.js.map +1 -1
- package/dist/src/browser/web-ai/ref-registry.js.map +1 -1
- package/dist/src/browser/web-ai/self-heal.js +20 -14
- package/dist/src/browser/web-ai/self-heal.js.map +1 -1
- package/dist/src/browser/web-ai/session-store.js +61 -1
- package/dist/src/browser/web-ai/session-store.js.map +1 -1
- package/dist/src/browser/web-ai/session.js +43 -2
- package/dist/src/browser/web-ai/session.js.map +1 -1
- package/dist/src/browser/web-ai/source-audit.js +116 -0
- package/dist/src/browser/web-ai/source-audit.js.map +1 -0
- package/dist/src/browser/web-ai/tab-finalizer.js +18 -0
- package/dist/src/browser/web-ai/tab-finalizer.js.map +1 -0
- package/dist/src/browser/web-ai/tab-lease-store.js +390 -0
- package/dist/src/browser/web-ai/tab-lease-store.js.map +1 -0
- package/dist/src/browser/web-ai/tab-pool.js +44 -0
- package/dist/src/browser/web-ai/tab-pool.js.map +1 -0
- package/dist/src/browser/web-ai/target-resolver.js +31 -0
- package/dist/src/browser/web-ai/target-resolver.js.map +1 -0
- package/dist/src/browser/web-ai/trace-persistence.js +4 -2
- package/dist/src/browser/web-ai/trace-persistence.js.map +1 -1
- package/dist/src/browser/web-ai/vendor-editor-contract.js.map +1 -1
- package/dist/src/browser/web-ai/watcher.js +8 -7
- package/dist/src/browser/web-ai/watcher.js.map +1 -1
- package/dist/src/cli/acp-client.js +40 -26
- package/dist/src/cli/acp-client.js.map +1 -1
- package/dist/src/cli/command-context.js +3 -3
- package/dist/src/cli/command-context.js.map +1 -1
- package/dist/src/cli/commands.js +25 -16
- package/dist/src/cli/commands.js.map +1 -1
- package/dist/src/cli/compact.js.map +1 -1
- package/dist/src/cli/handlers-completions.js +6 -4
- package/dist/src/cli/handlers-completions.js.map +1 -1
- package/dist/src/cli/handlers-runtime.js +45 -38
- package/dist/src/cli/handlers-runtime.js.map +1 -1
- package/dist/src/cli/handlers.js +44 -36
- package/dist/src/cli/handlers.js.map +1 -1
- package/dist/src/cli/readiness.js +3 -1
- package/dist/src/cli/readiness.js.map +1 -1
- package/dist/src/cli/registry.js +1 -1
- package/dist/src/cli/registry.js.map +1 -1
- package/dist/src/cli/tui/overlay.js +4 -1
- package/dist/src/cli/tui/overlay.js.map +1 -1
- package/dist/src/cli/types.js +4 -0
- package/dist/src/cli/types.js.map +1 -0
- package/dist/src/command-contract/catalog.js +1 -1
- package/dist/src/command-contract/catalog.js.map +1 -1
- package/dist/src/command-contract/help-renderer.js +1 -1
- package/dist/src/command-contract/help-renderer.js.map +1 -1
- package/dist/src/core/browser-open-default.js +13 -0
- package/dist/src/core/browser-open-default.js.map +1 -0
- package/dist/src/core/browser-open.js +41 -0
- package/dist/src/core/browser-open.js.map +1 -0
- package/dist/src/core/bus.js +13 -2
- package/dist/src/core/bus.js.map +1 -1
- package/dist/src/core/compact.js +5 -4
- package/dist/src/core/compact.js.map +1 -1
- package/dist/src/core/config.js +51 -52
- package/dist/src/core/config.js.map +1 -1
- package/dist/src/core/db.js +48 -6
- package/dist/src/core/db.js.map +1 -1
- package/dist/src/core/employees.js +9 -8
- package/dist/src/core/employees.js.map +1 -1
- package/dist/src/core/instance.js +7 -6
- package/dist/src/core/instance.js.map +1 -1
- package/dist/src/core/logger.js +1 -1
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/main-session.js +7 -7
- package/dist/src/core/main-session.js.map +1 -1
- package/dist/src/core/path-expand.js +10 -0
- package/dist/src/core/path-expand.js.map +1 -0
- package/dist/src/core/runtime-path.js +1 -1
- package/dist/src/core/runtime-path.js.map +1 -1
- package/dist/src/core/runtime-settings.js +13 -13
- package/dist/src/core/runtime-settings.js.map +1 -1
- package/dist/src/core/settings-merge.js +14 -14
- package/dist/src/core/settings-merge.js.map +1 -1
- package/dist/src/core/strip-undefined.js +13 -0
- package/dist/src/core/strip-undefined.js.map +1 -0
- package/dist/src/core/tcc.js +1 -1
- package/dist/src/core/tcc.js.map +1 -1
- package/dist/src/discord/bot.js +19 -18
- package/dist/src/discord/bot.js.map +1 -1
- package/dist/src/discord/channel-types.js +14 -0
- package/dist/src/discord/channel-types.js.map +1 -0
- package/dist/src/discord/commands.js +7 -6
- package/dist/src/discord/commands.js.map +1 -1
- package/dist/src/discord/discord-file.js.map +1 -1
- package/dist/src/discord/forwarder.js +3 -3
- package/dist/src/discord/forwarder.js.map +1 -1
- package/dist/src/http/error-middleware.js +3 -3
- package/dist/src/http/error-middleware.js.map +1 -1
- package/dist/src/http/response.js +2 -2
- package/dist/src/http/response.js.map +1 -1
- package/dist/src/ide/diff.js +7 -7
- package/dist/src/ide/diff.js.map +1 -1
- package/dist/src/manager/board/routes.js +28 -27
- package/dist/src/manager/board/routes.js.map +1 -1
- package/dist/src/manager/dashboard-home.js +3 -5
- package/dist/src/manager/dashboard-home.js.map +1 -1
- package/dist/src/manager/dashboard-service.js +2 -2
- package/dist/src/manager/dashboard-service.js.map +1 -1
- package/dist/src/manager/health-history.js +10 -9
- package/dist/src/manager/health-history.js.map +1 -1
- package/dist/src/manager/launchd-service.js +2 -2
- package/dist/src/manager/launchd-service.js.map +1 -1
- package/dist/src/manager/lifecycle-helpers.js +7 -6
- package/dist/src/manager/lifecycle-helpers.js.map +1 -1
- package/dist/src/manager/lifecycle.js +7 -6
- package/dist/src/manager/lifecycle.js.map +1 -1
- package/dist/src/manager/logs.js +18 -18
- package/dist/src/manager/logs.js.map +1 -1
- package/dist/src/manager/metadata.js +10 -2
- package/dist/src/manager/metadata.js.map +1 -1
- package/dist/src/manager/notes/assets.js +216 -0
- package/dist/src/manager/notes/assets.js.map +1 -0
- package/dist/src/manager/notes/capabilities.js +56 -0
- package/dist/src/manager/notes/capabilities.js.map +1 -0
- package/dist/src/manager/notes/constants.js +11 -0
- package/dist/src/manager/notes/constants.js.map +1 -0
- package/dist/src/manager/notes/frontmatter.js +120 -0
- package/dist/src/manager/notes/frontmatter.js.map +1 -0
- package/dist/src/manager/notes/link-resolver.js +96 -0
- package/dist/src/manager/notes/link-resolver.js.map +1 -0
- package/dist/src/manager/notes/path-guards.js +4 -0
- package/dist/src/manager/notes/path-guards.js.map +1 -1
- package/dist/src/manager/notes/remote-assets.js +128 -0
- package/dist/src/manager/notes/remote-assets.js.map +1 -0
- package/dist/src/manager/notes/routes.js +63 -13
- package/dist/src/manager/notes/routes.js.map +1 -1
- package/dist/src/manager/notes/store.js +3 -2
- package/dist/src/manager/notes/store.js.map +1 -1
- package/dist/src/manager/notes/system-trash.js +3 -3
- package/dist/src/manager/notes/system-trash.js.map +1 -1
- package/dist/src/manager/notes/vault-index.js +220 -0
- package/dist/src/manager/notes/vault-index.js.map +1 -0
- package/dist/src/manager/notes/watcher.js +27 -0
- package/dist/src/manager/notes/watcher.js.map +1 -0
- package/dist/src/manager/notes/wiki-links.js +109 -0
- package/dist/src/manager/notes/wiki-links.js.map +1 -0
- package/dist/src/manager/process-verify.js +29 -0
- package/dist/src/manager/process-verify.js.map +1 -1
- package/dist/src/manager/profiles.js +3 -2
- package/dist/src/manager/profiles.js.map +1 -1
- package/dist/src/manager/registry.js +60 -58
- package/dist/src/manager/registry.js.map +1 -1
- package/dist/src/manager/routes/electron-metrics.js +22 -22
- package/dist/src/manager/routes/electron-metrics.js.map +1 -1
- package/dist/src/manager/scan.js +2 -2
- package/dist/src/manager/scan.js.map +1 -1
- package/dist/src/manager/schedule/routes.js +24 -23
- package/dist/src/manager/schedule/routes.js.map +1 -1
- package/dist/src/manager/server.js +28 -28
- package/dist/src/manager/server.js.map +1 -1
- package/dist/src/manager/systemd-service.js +1 -1
- package/dist/src/manager/systemd-service.js.map +1 -1
- package/dist/src/memory/bootstrap.js +5 -4
- package/dist/src/memory/bootstrap.js.map +1 -1
- package/dist/src/memory/heartbeat-schedule.js +10 -10
- package/dist/src/memory/heartbeat-schedule.js.map +1 -1
- package/dist/src/memory/heartbeat.js +23 -22
- package/dist/src/memory/heartbeat.js.map +1 -1
- package/dist/src/memory/indexing.js.map +1 -1
- package/dist/src/memory/keyword-expand.js +1 -1
- package/dist/src/memory/keyword-expand.js.map +1 -1
- package/dist/src/memory/memory.js +2 -2
- package/dist/src/memory/memory.js.map +1 -1
- package/dist/src/memory/runtime.js +6 -5
- package/dist/src/memory/runtime.js.map +1 -1
- package/dist/src/memory/shared.js +2 -1
- package/dist/src/memory/shared.js.map +1 -1
- package/dist/src/memory/worklog.js +1 -1
- package/dist/src/memory/worklog.js.map +1 -1
- package/dist/src/messaging/runtime.js +13 -10
- package/dist/src/messaging/runtime.js.map +1 -1
- package/dist/src/messaging/send.js +16 -15
- package/dist/src/messaging/send.js.map +1 -1
- package/dist/src/orchestrator/collect.js +6 -6
- package/dist/src/orchestrator/collect.js.map +1 -1
- package/dist/src/orchestrator/distribute.js +112 -77
- package/dist/src/orchestrator/distribute.js.map +1 -1
- package/dist/src/orchestrator/gateway.js +6 -5
- package/dist/src/orchestrator/gateway.js.map +1 -1
- package/dist/src/orchestrator/pipeline.js +42 -42
- package/dist/src/orchestrator/pipeline.js.map +1 -1
- package/dist/src/orchestrator/state-machine.js +3 -3
- package/dist/src/orchestrator/state-machine.js.map +1 -1
- package/dist/src/orchestrator/worker-registry.js +4 -3
- package/dist/src/orchestrator/worker-registry.js.map +1 -1
- package/dist/src/prompt/builder.js +24 -19
- package/dist/src/prompt/builder.js.map +1 -1
- package/dist/src/prompt/templates/a1-system.md +15 -10
- package/dist/src/prompt/templates/control-system.md +9 -7
- package/dist/src/prompt/templates/employee.md +5 -4
- package/dist/src/prompt/templates/vision-click.md +1 -1
- package/dist/src/routes/_http-error.js +15 -0
- package/dist/src/routes/_http-error.js.map +1 -0
- package/dist/src/routes/avatar.js +6 -5
- package/dist/src/routes/avatar.js.map +1 -1
- package/dist/src/routes/browser.js +132 -45
- package/dist/src/routes/browser.js.map +1 -1
- package/dist/src/routes/employees.js +28 -21
- package/dist/src/routes/employees.js.map +1 -1
- package/dist/src/routes/heartbeat.js +12 -9
- package/dist/src/routes/heartbeat.js.map +1 -1
- package/dist/src/routes/i18n.js +13 -7
- package/dist/src/routes/i18n.js.map +1 -1
- package/dist/src/routes/jaw-memory.js +15 -11
- package/dist/src/routes/jaw-memory.js.map +1 -1
- package/dist/src/routes/memory.js +25 -20
- package/dist/src/routes/memory.js.map +1 -1
- package/dist/src/routes/messaging.js +50 -29
- package/dist/src/routes/messaging.js.map +1 -1
- package/dist/src/routes/orchestrate.js +38 -24
- package/dist/src/routes/orchestrate.js.map +1 -1
- package/dist/src/routes/quota.js +81 -17
- package/dist/src/routes/quota.js.map +1 -1
- package/dist/src/routes/settings.js +28 -18
- package/dist/src/routes/settings.js.map +1 -1
- package/dist/src/routes/skills.js +22 -13
- package/dist/src/routes/skills.js.map +1 -1
- package/dist/src/routes/traces.js +77 -0
- package/dist/src/routes/traces.js.map +1 -0
- package/dist/src/security/path-guards.js +2 -1
- package/dist/src/security/path-guards.js.map +1 -1
- package/dist/src/shared/tool-log-sanitize.js +191 -0
- package/dist/src/shared/tool-log-sanitize.js.map +1 -0
- package/dist/src/telegram/bot.js +65 -55
- package/dist/src/telegram/bot.js.map +1 -1
- package/dist/src/telegram/forwarder.js +5 -9
- package/dist/src/telegram/forwarder.js.map +1 -1
- package/dist/src/telegram/telegram-file.js +28 -24
- package/dist/src/telegram/telegram-file.js.map +1 -1
- package/dist/src/telegram/voice.js +4 -3
- package/dist/src/telegram/voice.js.map +1 -1
- package/dist/src/trace/redact.js +50 -0
- package/dist/src/trace/redact.js.map +1 -0
- package/dist/src/trace/store.js +162 -0
- package/dist/src/trace/store.js.map +1 -0
- package/dist/src/trace/types.js +2 -0
- package/dist/src/trace/types.js.map +1 -0
- package/dist/src/types/cli-engine.js +34 -0
- package/dist/src/types/cli-engine.js.map +1 -0
- package/dist/src/types/cli-events.js +31 -0
- package/dist/src/types/cli-events.js.map +1 -0
- package/package.json +22 -2
- package/public/css/tool-ui.css +3 -1
- package/public/css/trace-drawer.css +48 -0
- package/public/dist/assets/{AdvancedExport-3WAYIabE.js → AdvancedExport-DJZ2VmBR.js} +1 -1
- package/public/dist/assets/Agent-CgpLT8IY.js +1 -0
- package/public/dist/assets/Browser-CrkiQoB8.js +1 -0
- package/public/dist/assets/{ChannelsDiscord-UzFPlWT4.js → ChannelsDiscord-CVUC22D4.js} +1 -1
- package/public/dist/assets/{ChannelsTelegram-DNWtPX0w.js → ChannelsTelegram-DEatIQNM.js} +1 -1
- package/public/dist/assets/{DashboardMeta-Y_6nVeJO.js → DashboardMeta-BKoxRc7i.js} +1 -1
- package/public/dist/assets/{Display-D8vGOl4s.js → Display-DnNGV9Km.js} +1 -1
- package/public/dist/assets/{Employees-YR_sIRK4.js → Employees-DZ2iJYKy.js} +1 -1
- package/public/dist/assets/{HealthBadge-CPePajyU.js → HealthBadge-Cq2c7G9s.js} +1 -1
- package/public/dist/assets/{Heartbeat-DTpAULQR.js → Heartbeat-BML6eTXZ.js} +1 -1
- package/public/dist/assets/{Mcp-DM-PgG6z.js → Mcp-BlEviQ3h.js} +1 -1
- package/public/dist/assets/{Memory-C_LvJnkn.js → Memory-BRyH80He.js} +1 -1
- package/public/dist/assets/MilkdownWysiwygEditor-Cm3uXfWf.js +52 -0
- package/public/dist/assets/ModelProvider-DxyR7EL9.js +1 -0
- package/public/dist/assets/Network-DDOOESh1.js +1 -0
- package/public/dist/assets/{Permissions-B1naJjjw.js → Permissions-Br0eSbKb.js} +1 -1
- package/public/dist/assets/{Permissions-BKffrMJD.js → Permissions-QHkzStqQ.js} +1 -1
- package/public/dist/assets/{Profile-DIqjSe2C.js → Profile-C79NKumk.js} +1 -1
- package/public/dist/assets/{Prompts-BMfbV6Y4.js → Prompts-BmiIDiXW.js} +1 -1
- package/public/dist/assets/{SpeechKeys-DjiQTzSL.js → SpeechKeys-B8304XJK.js} +1 -1
- package/public/dist/assets/app-Be58Cs3Y.js +32 -0
- package/public/dist/assets/{app-BzvwJJiv.css → app-CphocJzo.css} +1 -1
- package/public/dist/assets/{dist-DTvxN3ux.js → dist-BD0UXfgF2.js} +1 -1
- package/public/dist/assets/{dist-CASeq-Tl.js → dist-BNfXO3Yr.js} +1 -1
- package/public/dist/assets/{dist-BMPiaUzF.js → dist-BUnPYbK3.js} +1 -1
- package/public/dist/assets/{dist-CT_X3hVT.js → dist-BZosRD2u.js} +1 -1
- package/public/dist/assets/{dist-4J6YbNXv.js → dist-Bd9PlnQm.js} +1 -1
- package/public/dist/assets/{dist-BcZjyn5g.js → dist-BsT5UdNP.js} +1 -1
- package/public/dist/assets/{dist-BfBhOPR-.js → dist-CIuXW-sc.js} +1 -1
- package/public/dist/assets/{dist-BMiCig3A2.js → dist-CL4PTYWf.js} +1 -1
- package/public/dist/assets/{dist-VyP6-HLb.js → dist-Ch5VAlV9.js} +1 -1
- package/public/dist/assets/dist-ClqO40BE.js +1 -0
- package/public/dist/assets/{dist-c98Tp7bP.js → dist-Cp42cMcI.js} +1 -1
- package/public/dist/assets/{dist-CIlYL1qe.js → dist-CpUK8ypo.js} +1 -1
- package/public/dist/assets/dist-CxeLAw2Y.js +1 -0
- package/public/dist/assets/dist-D2SH8nxa.js +1 -0
- package/public/dist/assets/{dist-84fwQ7bO.js → dist-D6cUXP7K.js} +1 -1
- package/public/dist/assets/{dist-BOCcQAyF.js → dist-D7bCuS3f.js} +1 -1
- package/public/dist/assets/{dist-DMmpfLVP.js → dist-DFYRUAjN.js} +1 -1
- package/public/dist/assets/{dist-DdY6pTJr.js → dist-DZsFVYF4.js} +1 -1
- package/public/dist/assets/{dist-B0p3Eyme.js → dist-Db16ogVk.js} +1 -1
- package/public/dist/assets/{dist-DlnNtr6L.js → dist-DfodGES_.js} +1 -1
- package/public/dist/assets/{dist-DO9so2a2.js → dist-SU-YTAIg.js} +1 -1
- package/public/dist/assets/{dist-DUjXiMLP.js → dist-UYn7T-GH.js} +1 -1
- package/public/dist/assets/{dist-BW1409rz.js → dist-W51oDoeA.js} +1 -1
- package/public/dist/assets/{dist-BimBQZx1.js → dist-eU7TyC86.js} +1 -1
- package/public/dist/assets/dist-l9HH00ip.js +1 -0
- package/public/dist/assets/{dist-BrOPNxdH.js → dist-urPTQzXL.js} +1 -1
- package/public/dist/assets/{dist-AloEV3J52.js → dist-yHP6L0Ty.js} +1 -1
- package/public/dist/assets/{employees-Bbabvbyx.js → employees-CxdghzoD.js} +7 -7
- package/public/dist/assets/{error-normalize-DdvKGLt_.js → error-normalize-5n-zlEQ3.js} +1 -1
- package/public/dist/assets/insert-image-markdown-DIEa-zjk.js +22 -0
- package/public/dist/assets/{manager-DyB2ZUr9.css → manager-DEiyrWDP.css} +1 -1
- package/public/dist/assets/manager-UEXd1_9T.js +25 -0
- package/public/dist/assets/{memory-B_plvcuQ.js → memory-CsMNkYtv.js} +9 -9
- package/public/dist/assets/memory-DXad_DPO.js +1 -0
- package/public/dist/assets/{page-shell-DML_HneX.js → page-shell-D5tbivHH.js} +1 -1
- package/public/dist/assets/{render-DEhbfUAW.js → render-DGQX46ei.js} +2 -2
- package/public/dist/assets/{settings-D7F-_kYG.js → settings-BH213Yv3.js} +14 -14
- package/public/dist/assets/settings-DXT87G2U.js +1 -0
- package/public/dist/assets/settings-client-ajlwI-oK.js +1 -0
- package/public/dist/assets/skills-5o_1v0nz.js +1 -0
- package/public/dist/assets/{skills-DoGJOc0D.js → skills-CQtCtHPA.js} +6 -6
- package/public/dist/assets/slash-commands-D4-hrrmh.js +1 -0
- package/public/dist/assets/{slash-commands-khNFPOyF.js → slash-commands-Dzk1xHWS.js} +1 -1
- package/public/dist/assets/trace-drawer-SRKcfm2S.js +15 -0
- package/public/dist/assets/ui-CdRKN2S6.js +141 -0
- package/public/dist/assets/ui-n43jmg_f.js +1 -0
- package/public/dist/assets/{ws-B2aJ-nD2.js → ws-CTHQFzM1.js} +8 -8
- package/public/dist/index.html +2 -2
- package/public/dist/manager/index.html +2 -2
- package/public/index.html +1 -0
- package/public/js/constants.ts +5 -5
- package/public/js/diagram/iframe-renderer.ts +11 -11
- package/public/js/features/chat.ts +1 -1
- package/public/js/features/memory.ts +10 -10
- package/public/js/features/pending-queue.ts +2 -2
- package/public/js/features/process-block.ts +257 -29
- package/public/js/features/process-step-match.ts +18 -0
- package/public/js/features/settings-cli-status.ts +1 -1
- package/public/js/features/settings-stt.ts +37 -11
- package/public/js/features/settings-templates.ts +2 -2
- package/public/js/features/slash-commands.ts +1 -1
- package/public/js/features/tool-ui.ts +13 -7
- package/public/js/features/trace-drawer.ts +122 -0
- package/public/js/icons.ts +1 -1
- package/public/js/main.ts +28 -28
- package/public/js/provider-icons.ts +1 -1
- package/public/js/render.ts +29 -27
- package/public/js/sanitizer.ts +4 -0
- package/public/js/ui.ts +234 -68
- package/public/js/virtual-scroll.ts +19 -33
- package/public/js/ws.ts +22 -10
- package/public/manager/src/App.tsx +34 -6
- package/public/manager/src/api.ts +55 -1
- package/public/manager/src/components/ActivityTimeline.tsx +1 -1
- package/public/manager/src/components/InstanceDetailPanel.tsx +2 -2
- package/public/manager/src/components/InstanceGroups.tsx +5 -5
- package/public/manager/src/components/InstanceListContent.tsx +1 -1
- package/public/manager/src/dashboard-features.ts +1 -1
- package/public/manager/src/manager-notes.css +49 -2
- package/public/manager/src/notes/MarkdownEditor.tsx +7 -3
- package/public/manager/src/notes/NotesFileTree.tsx +45 -6
- package/public/manager/src/notes/NotesSidebar.tsx +24 -55
- package/public/manager/src/notes/NotesWorkspace.tsx +50 -3
- package/public/manager/src/notes/image-assets/clipboard-images.ts +100 -0
- package/public/manager/src/notes/image-assets/insert-image-markdown.ts +85 -0
- package/public/manager/src/notes/notes-api.ts +2 -0
- package/public/manager/src/notes/notes-types.ts +8 -1
- package/public/manager/src/notes/rendering/MarkdownRenderer.tsx +6 -0
- package/public/manager/src/notes/rendering/markdown-render-security.ts +19 -1
- package/public/manager/src/notes/rich-markdown/paste-policy.ts +6 -2
- package/public/manager/src/notes/rich-markdown/rich-markdown-extension.ts +5 -5
- package/public/manager/src/notes/rich-markdown/rich-widget.ts +8 -8
- package/public/manager/src/notes/useNotesExternalSync.ts +37 -0
- package/public/manager/src/notes/useNotesModel.ts +91 -0
- package/public/manager/src/notes/wysiwyg/MilkdownWysiwygEditor.tsx +157 -17
- package/public/manager/src/notes/wysiwyg/milkdown-block-keymap.ts +14 -2
- package/public/manager/src/notes/wysiwyg/milkdown-code-block-view.ts +20 -20
- package/public/manager/src/notes/wysiwyg/milkdown-heading-source-view.ts +8 -8
- package/public/manager/src/notes/wysiwyg/milkdown-math.ts +25 -25
- package/public/manager/src/settings/pages/Browser.tsx +38 -20
- package/public/manager/src/settings/pages/ModelProvider.tsx +11 -9
- package/public/manager/src/settings/pages/Network.tsx +10 -10
- package/public/manager/src/settings/pages/components/HealthBadge.tsx +12 -12
- package/public/manager/src/settings/pages/components/agent/runtime-employees-helpers.ts +12 -10
- package/public/manager/src/settings/pages/components/employees-helpers.ts +9 -9
- package/public/manager/src/settings/pages/components/heartbeat-helpers.ts +13 -13
- package/public/manager/src/settings/pages/components/memory-helpers.ts +4 -4
- package/public/manager/src/settings/pages/mcp-helpers.ts +7 -7
- package/public/manager/src/settings/settings-client.ts +4 -3
- package/public/manager/src/sync/IframeBridge.tsx +29 -0
- package/public/manager/src/sync/VisibilityBridge.tsx +24 -0
- package/public/manager/src/sync/invalidation-bus.ts +30 -0
- package/public/manager/src/sync/useInvalidationSubscription.ts +19 -0
- package/public/manager/src/types.ts +101 -0
- package/scripts/check-strict-baseline.mjs +255 -0
- package/scripts/claim-audit.mjs +159 -0
- package/scripts/i18n-registry.ts +4 -4
- package/scripts/install-officecli.sh +2 -2
- package/scripts/install-wsl.sh +2 -1
- package/scripts/release-gates.mjs +347 -0
- package/scripts/release-preview.sh +3 -0
- package/scripts/release.sh +4 -0
- package/scripts/smoke/opencode-external-dir-smoke.ts +14 -5
- package/public/dist/assets/Agent-BYdzZwD0.js +0 -1
- package/public/dist/assets/Browser-CkGeczuN.js +0 -1
- package/public/dist/assets/MilkdownWysiwygEditor-B7k9bAey.js +0 -52
- package/public/dist/assets/ModelProvider-CX3Qhowu.js +0 -1
- package/public/dist/assets/Network-DfPLFAvw.js +0 -1
- package/public/dist/assets/app-DLYoRkU9.js +0 -32
- package/public/dist/assets/dist-8zNAQAIa.js +0 -1
- package/public/dist/assets/dist-BgeY6nvK.js +0 -1
- package/public/dist/assets/dist-BzDGGxHQ.js +0 -1
- package/public/dist/assets/dist-D3YKbVi-.js +0 -1
- package/public/dist/assets/manager-CUSgFbMO.js +0 -25
- package/public/dist/assets/markdown-render-security-DJfJPWO-.js +0 -22
- package/public/dist/assets/memory-DQ6dU0qs.js +0 -1
- package/public/dist/assets/settings-DxLPUbpj.js +0 -1
- package/public/dist/assets/settings-client-CGf3uPPf.js +0 -1
- package/public/dist/assets/skills-yMfNYJ8m.js +0 -1
- package/public/dist/assets/slash-commands-CZcwr1W6.js +0 -1
- package/public/dist/assets/ui-04YlOMgn.js +0 -136
- package/public/dist/assets/ui-D6hlMjRq.js +0 -1
- /package/public/dist/assets/{InlineWarn-CqgWEC41.js → InlineWarn-BooBRm7o.js} +0 -0
- /package/public/dist/assets/{agent-meta-puNn13DV.js → agent-meta-DHddpWHQ.js} +0 -0
- /package/public/dist/assets/{fields-DH9JS3mb.js → fields-BtncIZYA.js} +0 -0
- /package/public/dist/assets/{mermaid-loader-6XC0y10y.js → mermaid-loader-BEFIOoJn.js} +0 -0
- /package/public/dist/assets/{path-utils-CtsDDGZg.js → path-utils-BuEEtj9w.js} +0 -0
- /package/public/dist/assets/{w3c-keyname-VSld09PZ.js → w3c-keyname-IiiZScED.js} +0 -0
package/public/js/ui.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// ── UI Utilities ──
|
|
2
2
|
import { state } from './state.js';
|
|
3
|
-
import { renderMarkdown, escapeHtml, stripOrchestration, linkifyFilePaths } from './render.js';
|
|
3
|
+
import { renderMarkdown, escapeHtml, sanitizeHtml, stripOrchestration, linkifyFilePaths } from './render.js';
|
|
4
4
|
import { renderMermaidBlocks } from './render.js';
|
|
5
5
|
import { generateId } from './uuid.js';
|
|
6
6
|
import { getAppName } from './features/appname.js';
|
|
@@ -15,6 +15,13 @@ import { activateWidgets } from './diagram/iframe-renderer.js';
|
|
|
15
15
|
import { renderLiveToolActivity, cleanupToolElements, bindToolItemInteractions, type ToolLogEntry } from './features/tool-ui.js';
|
|
16
16
|
import { ICONS, emojiToIcon, emojiToStatus, isCompletionEmoji } from './icons.js';
|
|
17
17
|
import { providerIcon } from './provider-icons.js';
|
|
18
|
+
import { findRunningProcessStepMatch } from './features/process-step-match.js';
|
|
19
|
+
import {
|
|
20
|
+
parseToolLogBounded,
|
|
21
|
+
sanitizeToolLogForDurableStorage,
|
|
22
|
+
serializeSanitizedToolLog,
|
|
23
|
+
type SanitizedToolLogEntry,
|
|
24
|
+
} from '../../src/shared/tool-log-sanitize.js';
|
|
18
25
|
import {
|
|
19
26
|
createProcessBlock,
|
|
20
27
|
addStep,
|
|
@@ -24,10 +31,14 @@ import {
|
|
|
24
31
|
stopBlockTicker,
|
|
25
32
|
buildProcessBlockHtml,
|
|
26
33
|
bindProcessBlockInteractions,
|
|
34
|
+
getStoredProcessStepDetail,
|
|
35
|
+
mergeStoredProcessStepDetail,
|
|
36
|
+
processStepMetaFromStore,
|
|
37
|
+
releaseProcessBlockDetails,
|
|
27
38
|
type ProcessStep,
|
|
28
39
|
type ProcessBlockState,
|
|
29
40
|
} from './features/process-block.js';
|
|
30
|
-
interface MessageItem { role: string; content: string; tool_log?: string | null; cli?: string | null; }
|
|
41
|
+
interface MessageItem { role: string; content: string; tool_log?: string | null; trace_run_id?: string | null; cli?: string | null; }
|
|
31
42
|
interface QueuedOverlayItem { id: string; prompt: string; source?: string; ts?: number; }
|
|
32
43
|
interface ActiveRunSnapshot { running?: boolean; cli?: string; text?: string; toolLog?: ToolLogEntry[]; startedAt?: number; }
|
|
33
44
|
|
|
@@ -37,14 +48,27 @@ function processStepType(toolType?: string): ProcessStep['type'] {
|
|
|
37
48
|
: 'tool';
|
|
38
49
|
}
|
|
39
50
|
|
|
51
|
+
function processStepStatus(status?: string): ProcessStep['status'] {
|
|
52
|
+
return status === 'running' || status === 'done' || status === 'error' ? status : 'done';
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function fallbackToolLabel(tool: ToolLogEntry): string {
|
|
56
|
+
if (tool.label) return tool.label;
|
|
57
|
+
const named = tool as ToolLogEntry & { name?: unknown };
|
|
58
|
+
return typeof named.name === 'string' && named.name ? named.name : 'tool';
|
|
59
|
+
}
|
|
60
|
+
|
|
40
61
|
function parseToolLog(toolLog?: string | null): ToolLogEntry[] {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
62
|
+
return parseToolLogBounded(toolLog) as ToolLogEntry[];
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function sanitizedToolLogJson(toolLog?: string | null): string | null {
|
|
66
|
+
return serializeSanitizedToolLog(parseToolLog(toolLog));
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
function normalizeMessageToolLog<T extends MessageItem>(message: T): T {
|
|
70
|
+
if (message.role !== 'assistant' || !message.tool_log) return { ...message, tool_log: null };
|
|
71
|
+
return { ...message, tool_log: sanitizedToolLogJson(message.tool_log) };
|
|
48
72
|
}
|
|
49
73
|
|
|
50
74
|
function getAgentIcon(_cli?: string | null): string {
|
|
@@ -53,15 +77,20 @@ function getAgentIcon(_cli?: string | null): string {
|
|
|
53
77
|
|
|
54
78
|
function toProcessSteps(tools: ToolLogEntry[], runStartedAt?: number): ProcessStep[] {
|
|
55
79
|
const baseTime = runStartedAt && runStartedAt > 0 ? runStartedAt : Date.now();
|
|
56
|
-
return tools.map((tool
|
|
80
|
+
return tools.map((tool) => ({
|
|
57
81
|
id: generateId(),
|
|
58
82
|
icon: tool.icon ? emojiToIcon(tool.icon) : ICONS.tool,
|
|
59
83
|
rawIcon: tool.rawIcon || tool.icon || '',
|
|
60
|
-
label: tool
|
|
84
|
+
label: fallbackToolLabel(tool),
|
|
61
85
|
type: processStepType(tool.toolType),
|
|
62
86
|
detail: tool.detail || '',
|
|
63
87
|
stepRef: tool.stepRef || '',
|
|
64
|
-
|
|
88
|
+
traceRunId: tool.traceRunId || '',
|
|
89
|
+
traceSeq: tool.traceSeq,
|
|
90
|
+
detailAvailable: tool.detailAvailable,
|
|
91
|
+
detailBytes: tool.detailBytes,
|
|
92
|
+
rawRetentionStatus: tool.rawRetentionStatus,
|
|
93
|
+
status: processStepStatus(tool.status),
|
|
65
94
|
startTime: baseTime,
|
|
66
95
|
}));
|
|
67
96
|
}
|
|
@@ -102,7 +131,10 @@ function normalizeAgentToolBlocks(agentMsg: HTMLElement): void {
|
|
|
102
131
|
}
|
|
103
132
|
|
|
104
133
|
for (const block of blocks) {
|
|
105
|
-
if (block !== keep)
|
|
134
|
+
if (block !== keep) {
|
|
135
|
+
releaseProcessBlockDetails(block);
|
|
136
|
+
block.remove();
|
|
137
|
+
}
|
|
106
138
|
}
|
|
107
139
|
}
|
|
108
140
|
|
|
@@ -121,21 +153,34 @@ function processStepStatusFromDom(status?: string): ProcessStep['status'] {
|
|
|
121
153
|
}
|
|
122
154
|
|
|
123
155
|
function processStepFromDom(row: HTMLElement): ProcessStep | null {
|
|
124
|
-
const id = row.dataset
|
|
156
|
+
const id = row.dataset['stepId'] || '';
|
|
125
157
|
if (!id) return null;
|
|
158
|
+
const storedMeta = processStepMetaFromStore(id);
|
|
126
159
|
const label = row.querySelector('.process-step-label')?.textContent?.trim() || '';
|
|
127
|
-
const
|
|
160
|
+
const pre = row.querySelector('.process-step-full') as HTMLElement | null;
|
|
161
|
+
const detail = pre?.dataset['detailLazy'] === 'true'
|
|
162
|
+
? getStoredProcessStepDetail(id) || storedMeta?.preview || ''
|
|
163
|
+
: pre?.textContent || getStoredProcessStepDetail(id) || storedMeta?.preview || '';
|
|
128
164
|
const iconEl = row.querySelector('.process-step-icon') as HTMLElement | null;
|
|
129
165
|
const icon = iconEl?.innerHTML || ICONS.tool;
|
|
130
|
-
const startTime = Number(row.dataset
|
|
166
|
+
const startTime = Number(row.dataset['startTime'] || '');
|
|
131
167
|
return {
|
|
132
168
|
id,
|
|
133
|
-
type: processStepTypeFromDom(row.dataset
|
|
134
|
-
icon,
|
|
135
|
-
|
|
169
|
+
type: storedMeta?.type || processStepTypeFromDom(row.dataset['type']),
|
|
170
|
+
icon: storedMeta?.icon || icon,
|
|
171
|
+
rawIcon: storedMeta?.rawIcon,
|
|
172
|
+
label: storedMeta?.label || label,
|
|
136
173
|
detail,
|
|
137
|
-
|
|
138
|
-
|
|
174
|
+
detailPreview: storedMeta?.preview,
|
|
175
|
+
detailLength: storedMeta?.detailLength,
|
|
176
|
+
detailTruncated: storedMeta?.detailTruncated,
|
|
177
|
+
stepRef: storedMeta?.stepRef || row.dataset['stepRef'] || '',
|
|
178
|
+
traceRunId: storedMeta?.traceRunId || row.dataset['traceRunId'] || '',
|
|
179
|
+
traceSeq: storedMeta?.traceSeq || Number(row.dataset['traceSeq'] || 0) || undefined,
|
|
180
|
+
detailAvailable: storedMeta?.detailAvailable,
|
|
181
|
+
detailBytes: storedMeta?.detailBytes,
|
|
182
|
+
rawRetentionStatus: storedMeta?.rawRetentionStatus,
|
|
183
|
+
status: storedMeta?.status || processStepStatusFromDom(row.dataset['status']),
|
|
139
184
|
startTime: Number.isFinite(startTime) && startTime > 0 ? startTime : Date.now(),
|
|
140
185
|
};
|
|
141
186
|
}
|
|
@@ -153,25 +198,118 @@ function currentProcessBlockFromDom(agentMsg: HTMLElement): ProcessBlockState |
|
|
|
153
198
|
};
|
|
154
199
|
}
|
|
155
200
|
|
|
156
|
-
function
|
|
157
|
-
const
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
201
|
+
function processStepToToolLog(step: ProcessStep, finalize = false): ToolLogEntry {
|
|
202
|
+
const detail = getStoredProcessStepDetail(step.id) || step.detail || step.detailPreview || '';
|
|
203
|
+
const status = finalize && step.status === 'running' ? 'done' : step.status;
|
|
204
|
+
return {
|
|
205
|
+
icon: step.rawIcon || step.icon || ICONS.tool,
|
|
206
|
+
rawIcon: step.rawIcon || step.icon || '',
|
|
207
|
+
label: step.label || 'tool',
|
|
208
|
+
detail,
|
|
209
|
+
toolType: step.type,
|
|
210
|
+
stepRef: step.stepRef || '',
|
|
211
|
+
status,
|
|
212
|
+
traceRunId: step.traceRunId || '',
|
|
213
|
+
traceSeq: step.traceSeq,
|
|
214
|
+
detailAvailable: step.detailAvailable,
|
|
215
|
+
detailBytes: step.detailBytes,
|
|
216
|
+
rawRetentionStatus: step.rawRetentionStatus,
|
|
217
|
+
};
|
|
162
218
|
}
|
|
163
219
|
|
|
164
|
-
function
|
|
165
|
-
const
|
|
166
|
-
if (
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
220
|
+
function processStepFromMeta(stepId: string, finalize = false): ToolLogEntry | null {
|
|
221
|
+
const meta = processStepMetaFromStore(stepId);
|
|
222
|
+
if (!meta) return null;
|
|
223
|
+
const status = finalize && meta.status === 'running' ? 'done' : meta.status;
|
|
224
|
+
return {
|
|
225
|
+
icon: meta.rawIcon || meta.icon || ICONS.tool,
|
|
226
|
+
rawIcon: meta.rawIcon || meta.icon || '',
|
|
227
|
+
label: meta.label || 'tool',
|
|
228
|
+
detail: getStoredProcessStepDetail(stepId) || meta.preview || '',
|
|
229
|
+
toolType: meta.type,
|
|
230
|
+
stepRef: meta.stepRef || '',
|
|
231
|
+
status,
|
|
232
|
+
traceRunId: meta.traceRunId || '',
|
|
233
|
+
traceSeq: meta.traceSeq,
|
|
234
|
+
detailAvailable: meta.detailAvailable,
|
|
235
|
+
detailBytes: meta.detailBytes,
|
|
236
|
+
rawRetentionStatus: meta.rawRetentionStatus,
|
|
237
|
+
};
|
|
171
238
|
}
|
|
172
239
|
|
|
240
|
+
function serializeProcessStepsForToolLog(source: ProcessBlockState | HTMLElement | null, finalize = false): ToolLogEntry[] {
|
|
241
|
+
if (!source) return [];
|
|
242
|
+
if ('steps' in source) return source.steps.map(step => processStepToToolLog(step, finalize));
|
|
243
|
+
|
|
244
|
+
const ids = new Set<string>();
|
|
245
|
+
source.querySelectorAll<HTMLElement>('.process-block[data-process-step-ids]').forEach(block => {
|
|
246
|
+
(block.dataset['processStepIds'] || '').split(/\s+/).filter(Boolean).forEach(id => ids.add(id));
|
|
247
|
+
});
|
|
248
|
+
source.querySelectorAll<HTMLElement>('.process-step[data-step-id]').forEach(row => {
|
|
249
|
+
const id = row.dataset['stepId'];
|
|
250
|
+
if (id) ids.add(id);
|
|
251
|
+
});
|
|
252
|
+
const entries: ToolLogEntry[] = [];
|
|
253
|
+
ids.forEach(id => {
|
|
254
|
+
const fromMeta = processStepFromMeta(id, finalize);
|
|
255
|
+
if (fromMeta) {
|
|
256
|
+
entries.push(fromMeta);
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
const row = source.querySelector<HTMLElement>(`.process-step[data-step-id="${CSS.escape(id)}"]`);
|
|
260
|
+
const step = row ? processStepFromDom(row) : null;
|
|
261
|
+
if (step) entries.push(processStepToToolLog(step, finalize));
|
|
262
|
+
});
|
|
263
|
+
return entries;
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
function identityKey(entry: ToolLogEntry, ordinal: number): string {
|
|
267
|
+
const stepRef = String(entry.stepRef || '').trim();
|
|
268
|
+
if (stepRef) return `ref:${stepRef}`;
|
|
269
|
+
return `ord:${entry.toolType || 'tool'}:${entry.label || 'tool'}:${ordinal}`;
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
function mergeExplicitAndLiveToolLogs(explicit: ToolLogEntry[], live: ToolLogEntry[]): ToolLogEntry[] {
|
|
273
|
+
if (explicit.length === 0) return live;
|
|
274
|
+
const merged = new Map<string, ToolLogEntry>();
|
|
275
|
+
const ordinalCounts = new Map<string, number>();
|
|
276
|
+
const keyFor = (entry: ToolLogEntry): string => {
|
|
277
|
+
const base = `${entry.toolType || 'tool'}:${entry.label || 'tool'}`;
|
|
278
|
+
const next = (ordinalCounts.get(base) || 0) + 1;
|
|
279
|
+
ordinalCounts.set(base, next);
|
|
280
|
+
return identityKey(entry, next);
|
|
281
|
+
};
|
|
282
|
+
live.forEach(entry => merged.set(keyFor(entry), entry));
|
|
283
|
+
ordinalCounts.clear();
|
|
284
|
+
explicit.forEach(entry => {
|
|
285
|
+
const key = keyFor(entry);
|
|
286
|
+
const liveEntry = merged.get(key);
|
|
287
|
+
const liveDetail = liveEntry?.detail || '';
|
|
288
|
+
const explicitDetail = entry.detail || '';
|
|
289
|
+
merged.set(key, {
|
|
290
|
+
...(liveEntry || {}),
|
|
291
|
+
...entry,
|
|
292
|
+
detail: explicitDetail.length >= liveDetail.length ? explicitDetail : liveDetail,
|
|
293
|
+
status: entry.status || liveEntry?.status || 'done',
|
|
294
|
+
});
|
|
295
|
+
});
|
|
296
|
+
return Array.from(merged.values());
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
function sanitizedToolLogEntries(entries: ToolLogEntry[]): ToolLogEntry[] {
|
|
300
|
+
return sanitizeToolLogForDurableStorage(entries) as ToolLogEntry[];
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
function sanitizedToolLogJsonFromEntries(entries: ToolLogEntry[]): string | null {
|
|
304
|
+
return serializeSanitizedToolLog(entries);
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
|
|
173
308
|
function removeAgentToolBlocks(agentMsg: HTMLElement): void {
|
|
174
|
-
for (const block of agentToolBlocks(agentMsg))
|
|
309
|
+
for (const block of agentToolBlocks(agentMsg)) {
|
|
310
|
+
releaseProcessBlockDetails(block);
|
|
311
|
+
block.remove();
|
|
312
|
+
}
|
|
175
313
|
}
|
|
176
314
|
|
|
177
315
|
export function setStatus(s: string): void {
|
|
@@ -240,7 +378,7 @@ export function addSystemMsg(text: string, extraClass?: string, type?: string):
|
|
|
240
378
|
const div = document.createElement('div');
|
|
241
379
|
const typeClass = type ? ` msg-type-${type}` : '';
|
|
242
380
|
div.className = 'msg msg-system' + typeClass + (extraClass ? ' ' + extraClass : '');
|
|
243
|
-
div.innerHTML = text;
|
|
381
|
+
div.innerHTML = sanitizeHtml(text);
|
|
244
382
|
if (vs.active) {
|
|
245
383
|
vs.appendLiveItem(div);
|
|
246
384
|
} else {
|
|
@@ -250,6 +388,8 @@ export function addSystemMsg(text: string, extraClass?: string, type?: string):
|
|
|
250
388
|
}
|
|
251
389
|
|
|
252
390
|
export function cleanupToolActivity(): void {
|
|
391
|
+
if (state.currentProcessBlock) releaseProcessBlockDetails(state.currentProcessBlock);
|
|
392
|
+
if (state.currentAgentDiv instanceof HTMLElement) releaseProcessBlockDetails(state.currentAgentDiv);
|
|
253
393
|
cleanupToolElements();
|
|
254
394
|
stopBlockTicker();
|
|
255
395
|
state.currentAgentDiv = null;
|
|
@@ -295,15 +435,14 @@ export function showProcessStep(step: ProcessStep): void {
|
|
|
295
435
|
const match = findRunningProcessStepMatch(state.currentProcessBlock.steps, step);
|
|
296
436
|
if (match) {
|
|
297
437
|
step.icon = emojiToIcon(step.icon);
|
|
298
|
-
const
|
|
299
|
-
? (match.detail ? `${match.detail}\n${step.detail}` : step.detail)
|
|
300
|
-
: match.detail;
|
|
438
|
+
const mergedPreview = mergeStoredProcessStepDetail(match.id, step.detail);
|
|
301
439
|
replaceStep(state.currentProcessBlock, match.id, {
|
|
302
440
|
...match,
|
|
303
441
|
...step,
|
|
304
442
|
id: match.id,
|
|
305
443
|
rawIcon,
|
|
306
|
-
detail:
|
|
444
|
+
detail: mergedPreview,
|
|
445
|
+
detailPreview: mergedPreview,
|
|
307
446
|
label: step.label || match.label,
|
|
308
447
|
status: resolvedStatus,
|
|
309
448
|
});
|
|
@@ -321,7 +460,7 @@ export function showProcessStep(step: ProcessStep): void {
|
|
|
321
460
|
id: existingDone.id,
|
|
322
461
|
rawIcon,
|
|
323
462
|
status: resolvedStatus,
|
|
324
|
-
detail: step.detail,
|
|
463
|
+
detail: mergeStoredProcessStepDetail(existingDone.id, step.detail),
|
|
325
464
|
});
|
|
326
465
|
scrollToBottom();
|
|
327
466
|
return;
|
|
@@ -391,11 +530,12 @@ export function hydrateActiveRun(snapshot?: ActiveRunSnapshot | null): void {
|
|
|
391
530
|
state.currentAgentDiv = ensureActiveRunMessage(snapshot.cli || null);
|
|
392
531
|
state.currentProcessBlock = null;
|
|
393
532
|
const body = state.currentAgentDiv.querySelector('.agent-body') as HTMLElement | null;
|
|
394
|
-
|
|
533
|
+
const snapshotToolLog = sanitizedToolLogEntries(snapshot.toolLog || []);
|
|
534
|
+
if (body && snapshotToolLog.length) {
|
|
395
535
|
normalizeAgentToolBlocks(state.currentAgentDiv);
|
|
396
536
|
removeAgentToolBlocks(state.currentAgentDiv);
|
|
397
537
|
const pb = createProcessBlock(body);
|
|
398
|
-
for (const tool of toProcessSteps(
|
|
538
|
+
for (const tool of toProcessSteps(snapshotToolLog, snapshot.startedAt)) addStep(pb, tool);
|
|
399
539
|
state.currentProcessBlock = pb;
|
|
400
540
|
} else {
|
|
401
541
|
normalizeAgentToolBlocks(state.currentAgentDiv);
|
|
@@ -426,8 +566,8 @@ let lastFinalizeTs = 0;
|
|
|
426
566
|
|
|
427
567
|
function clearMermaidTransientState(root: HTMLElement): void {
|
|
428
568
|
root.querySelectorAll<HTMLElement>('.mermaid-pending').forEach(el => {
|
|
429
|
-
delete el.dataset
|
|
430
|
-
delete el.dataset
|
|
569
|
+
delete el.dataset['mermaidQueued'];
|
|
570
|
+
delete el.dataset['mermaidQueuedAt'];
|
|
431
571
|
});
|
|
432
572
|
}
|
|
433
573
|
|
|
@@ -439,6 +579,15 @@ export function finalizeAgent(text: string, toolLog?: ToolLogEntry[]): void {
|
|
|
439
579
|
cleanupToolElements();
|
|
440
580
|
removeSkeleton();
|
|
441
581
|
if (state.currentAgentDiv) normalizeAgentToolBlocks(state.currentAgentDiv);
|
|
582
|
+
const liveToolLog = serializeProcessStepsForToolLog(
|
|
583
|
+
state.currentProcessBlock ?? state.currentAgentDiv,
|
|
584
|
+
true,
|
|
585
|
+
);
|
|
586
|
+
const explicitToolLog = Array.isArray(toolLog) ? toolLog : [];
|
|
587
|
+
const durableToolLog = sanitizedToolLogEntries(
|
|
588
|
+
mergeExplicitAndLiveToolLogs(explicitToolLog, liveToolLog),
|
|
589
|
+
);
|
|
590
|
+
const durableToolLogJson = sanitizedToolLogJsonFromEntries(durableToolLog);
|
|
442
591
|
const hadProcessBlock =
|
|
443
592
|
Boolean(state.currentProcessBlock) ||
|
|
444
593
|
Boolean(state.currentAgentDiv && hasAgentToolBlock(state.currentAgentDiv));
|
|
@@ -446,7 +595,7 @@ export function finalizeAgent(text: string, toolLog?: ToolLogEntry[]): void {
|
|
|
446
595
|
collapseBlock(state.currentProcessBlock);
|
|
447
596
|
state.currentProcessBlock = null;
|
|
448
597
|
}
|
|
449
|
-
const hasTools =
|
|
598
|
+
const hasTools = durableToolLog.length > 0;
|
|
450
599
|
if (text || hasTools) {
|
|
451
600
|
if (!state.currentAgentDiv || !state.currentAgentDiv.isConnected) {
|
|
452
601
|
state.currentAgentDiv = addMessage('agent', '');
|
|
@@ -463,7 +612,7 @@ export function finalizeAgent(text: string, toolLog?: ToolLogEntry[]): void {
|
|
|
463
612
|
if (contentEl) {
|
|
464
613
|
contentEl.insertAdjacentHTML(
|
|
465
614
|
'beforebegin',
|
|
466
|
-
buildProcessBlockHtml(toProcessSteps(
|
|
615
|
+
buildProcessBlockHtml(toProcessSteps(durableToolLog), true),
|
|
467
616
|
);
|
|
468
617
|
}
|
|
469
618
|
}
|
|
@@ -490,14 +639,24 @@ export function finalizeAgent(text: string, toolLog?: ToolLogEntry[]): void {
|
|
|
490
639
|
const div = state.currentAgentDiv;
|
|
491
640
|
clearMermaidTransientState(div);
|
|
492
641
|
div.querySelectorAll('.diagram-widget').forEach(widget => {
|
|
493
|
-
const encoded = (widget as HTMLElement).dataset
|
|
642
|
+
const encoded = (widget as HTMLElement).dataset['widgetHtml'];
|
|
494
643
|
if (!encoded) return;
|
|
495
644
|
const pending = document.createElement('div');
|
|
496
645
|
pending.className = 'diagram-widget-pending';
|
|
497
|
-
pending.dataset
|
|
646
|
+
pending.dataset['diagramHtml'] = encoded;
|
|
498
647
|
widget.replaceWith(pending);
|
|
499
648
|
});
|
|
500
|
-
|
|
649
|
+
if (durableToolLogJson) {
|
|
650
|
+
vs.appendItem(buildLazyVirtualMessageItem({
|
|
651
|
+
role: 'assistant',
|
|
652
|
+
content: finalText,
|
|
653
|
+
cli: null,
|
|
654
|
+
tool_log: durableToolLogJson,
|
|
655
|
+
}));
|
|
656
|
+
releaseProcessBlockDetails(div);
|
|
657
|
+
} else {
|
|
658
|
+
vs.appendLiveItem(div);
|
|
659
|
+
}
|
|
501
660
|
div.remove();
|
|
502
661
|
}
|
|
503
662
|
|
|
@@ -505,7 +664,7 @@ export function finalizeAgent(text: string, toolLog?: ToolLogEntry[]): void {
|
|
|
505
664
|
if (finalText) upsertMessage({
|
|
506
665
|
role: 'assistant',
|
|
507
666
|
content: finalText,
|
|
508
|
-
tool_log:
|
|
667
|
+
tool_log: durableToolLogJson,
|
|
509
668
|
timestamp: Date.now(),
|
|
510
669
|
}).catch(() => {});
|
|
511
670
|
}
|
|
@@ -663,7 +822,7 @@ export function showChatRestoreIndicator(reason: string): void {
|
|
|
663
822
|
indicator.innerHTML = '<span class="chat-restore-dot"></span><span class="chat-restore-text">Restoring</span>';
|
|
664
823
|
host.appendChild(indicator);
|
|
665
824
|
}
|
|
666
|
-
indicator.dataset
|
|
825
|
+
indicator.dataset['restoreReason'] = reason;
|
|
667
826
|
}
|
|
668
827
|
|
|
669
828
|
export function hideChatRestoreIndicator(): void {
|
|
@@ -768,21 +927,26 @@ export async function loadStats(): Promise<void> {
|
|
|
768
927
|
|
|
769
928
|
// ── Virtual scroll bootstrap helpers ──
|
|
770
929
|
|
|
771
|
-
function
|
|
772
|
-
return msgs.map((m) => {
|
|
930
|
+
function buildLazyVirtualMessageItem(m: MessageItem): VirtualItem {
|
|
773
931
|
const role = m.role === 'assistant' ? 'agent' : m.role;
|
|
774
932
|
const rawContent = stripOrchestration(
|
|
775
933
|
role === 'user' ? formatUserPrompt(m.content) : m.content,
|
|
776
934
|
);
|
|
777
935
|
const label = escapeHtml(role === 'user' ? t('msg.you') : getAppName());
|
|
778
|
-
const
|
|
936
|
+
const sanitizedToolLog = m.role === 'assistant' && m.tool_log
|
|
937
|
+
? sanitizedToolLogJson(m.tool_log)
|
|
938
|
+
: null;
|
|
939
|
+
const rawToolLog = sanitizedToolLog ? escapeHtml(sanitizedToolLog) : '';
|
|
779
940
|
const toolAttr = rawToolLog ? ` data-tool-log="${rawToolLog}"` : '';
|
|
780
941
|
const contentHtml = `<div class="msg-content lazy-pending" data-raw="${escapeHtml(rawContent)}"></div>`;
|
|
781
942
|
const html = role === 'agent'
|
|
782
943
|
? `<div class="msg msg-agent"><div class="agent-icon" aria-hidden="true">${getAgentIcon(m.cli)}</div><div class="agent-body"${toolAttr}>${contentHtml}<button class="msg-copy" title="Copy" aria-label="Copy message"></button></div></div>`
|
|
783
944
|
: `<div class="msg msg-${role}"><div class="user-body"><div class="msg-label">${label}</div>${contentHtml}<button class="msg-copy" title="Copy" aria-label="Copy message"></button></div><div class="user-icon" aria-hidden="true">${getUserAvatarMarkup()}</div></div>`;
|
|
784
|
-
return { id: generateId(), html, height: 80 };
|
|
785
|
-
|
|
945
|
+
return { id: generateId(), html, height: 80, rehydratesProcessDetails: Boolean(rawToolLog) };
|
|
946
|
+
}
|
|
947
|
+
|
|
948
|
+
function buildVirtualHistoryItems(msgs: MessageItem[]): VirtualItem[] {
|
|
949
|
+
return msgs.map((m) => buildLazyVirtualMessageItem(normalizeMessageToolLog(m)));
|
|
786
950
|
}
|
|
787
951
|
|
|
788
952
|
function registerVirtualScrollCallbacks(vs: ReturnType<typeof getVirtualScroll>): void {
|
|
@@ -792,7 +956,7 @@ function registerVirtualScrollCallbacks(vs: ReturnType<typeof getVirtualScroll>)
|
|
|
792
956
|
const raw = el.getAttribute('data-raw') || '';
|
|
793
957
|
const msgEl = el.closest('.msg-agent') as HTMLElement | null;
|
|
794
958
|
const body = msgEl?.querySelector('.agent-body') as HTMLElement | null;
|
|
795
|
-
const rawToolLog = body?.dataset
|
|
959
|
+
const rawToolLog = body?.dataset['toolLog'] || '';
|
|
796
960
|
if (msgEl && body && rawToolLog && !hasAgentToolBlock(msgEl)) {
|
|
797
961
|
const tools = parseToolLog(rawToolLog);
|
|
798
962
|
if (tools.length > 0) {
|
|
@@ -801,7 +965,7 @@ function registerVirtualScrollCallbacks(vs: ReturnType<typeof getVirtualScroll>)
|
|
|
801
965
|
buildProcessBlockHtml(toProcessSteps(tools), true),
|
|
802
966
|
);
|
|
803
967
|
}
|
|
804
|
-
delete body.dataset
|
|
968
|
+
delete body.dataset['toolLog'];
|
|
805
969
|
normalizeAgentToolBlocks(msgEl);
|
|
806
970
|
}
|
|
807
971
|
el.innerHTML = raw ? renderMarkdown(raw) : '';
|
|
@@ -845,15 +1009,16 @@ export async function loadMessages(): Promise<void> {
|
|
|
845
1009
|
const msgs = await api<MessageItem[]>('/api/messages');
|
|
846
1010
|
|
|
847
1011
|
if (msgs !== null) {
|
|
1012
|
+
const safeMsgs = msgs.map(normalizeMessageToolLog);
|
|
848
1013
|
// Successful fetch — clear DOM and render (even if empty array after /clear)
|
|
849
1014
|
vs.clear();
|
|
850
1015
|
if (chatEl) chatEl.innerHTML = '';
|
|
851
1016
|
|
|
852
|
-
if (
|
|
853
|
-
const vsItems = buildVirtualHistoryItems(
|
|
1017
|
+
if (safeMsgs.length >= VS_THRESHOLD) {
|
|
1018
|
+
const vsItems = buildVirtualHistoryItems(safeMsgs);
|
|
854
1019
|
bootstrapVirtualHistory(vsItems, makeBootstrapDeps(vs));
|
|
855
1020
|
} else {
|
|
856
|
-
|
|
1021
|
+
safeMsgs.forEach(m => {
|
|
857
1022
|
const div = addMessage(m.role === 'assistant' ? 'agent' : m.role, m.content, m.cli);
|
|
858
1023
|
if (m.role === 'assistant') {
|
|
859
1024
|
const tools = parseToolLog(m.tool_log);
|
|
@@ -869,10 +1034,10 @@ export async function loadMessages(): Promise<void> {
|
|
|
869
1034
|
});
|
|
870
1035
|
}
|
|
871
1036
|
// Sync to IndexedDB (full replace — server is source of truth)
|
|
872
|
-
cacheMessages(
|
|
1037
|
+
cacheMessages(safeMsgs.map(m => ({
|
|
873
1038
|
role: m.role, content: m.content, cli: m.cli ?? null, tool_log: m.tool_log ?? null, timestamp: Date.now(),
|
|
874
1039
|
}))).catch(() => {});
|
|
875
|
-
updateStatMsgs(
|
|
1040
|
+
updateStatMsgs(safeMsgs.length);
|
|
876
1041
|
showEmptyState();
|
|
877
1042
|
return;
|
|
878
1043
|
}
|
|
@@ -885,11 +1050,12 @@ export async function loadMessages(): Promise<void> {
|
|
|
885
1050
|
// DOM empty + server down — try IndexedDB cache
|
|
886
1051
|
const cached = await getScopedMessages();
|
|
887
1052
|
if (cached.length > 0) {
|
|
888
|
-
|
|
889
|
-
|
|
1053
|
+
const safeCached = (cached as MessageItem[]).map(normalizeMessageToolLog);
|
|
1054
|
+
if (safeCached.length >= VS_THRESHOLD) {
|
|
1055
|
+
const vsItems = buildVirtualHistoryItems(safeCached);
|
|
890
1056
|
bootstrapVirtualHistory(vsItems, makeBootstrapDeps(vs));
|
|
891
1057
|
} else {
|
|
892
|
-
|
|
1058
|
+
safeCached.forEach(m => {
|
|
893
1059
|
const div = addMessage(m.role === 'assistant' ? 'agent' : m.role, m.content, m.cli);
|
|
894
1060
|
if (m.role === 'assistant' && m.tool_log) {
|
|
895
1061
|
const tools = parseToolLog(m.tool_log);
|
|
@@ -905,7 +1071,7 @@ export async function loadMessages(): Promise<void> {
|
|
|
905
1071
|
});
|
|
906
1072
|
}
|
|
907
1073
|
addSystemMsg(`${ICONS.warning} ${t('ui.offline.banner')}`);
|
|
908
|
-
updateStatMsgs(
|
|
1074
|
+
updateStatMsgs(safeCached.length);
|
|
909
1075
|
}
|
|
910
1076
|
showEmptyState();
|
|
911
1077
|
}
|