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
|
@@ -1,33 +1,51 @@
|
|
|
1
|
-
// ── Process Block ──
|
|
2
|
-
// Collapsible panel showing tool/thinking activity during agent responses.
|
|
3
|
-
|
|
4
1
|
import { escapeHtml } from '../render.js';
|
|
5
2
|
import { ICONS } from '../icons.js';
|
|
6
|
-
|
|
7
3
|
export interface ProcessStep {
|
|
8
4
|
id: string;
|
|
9
5
|
type: 'tool' | 'thinking' | 'search' | 'subagent';
|
|
10
6
|
icon: string;
|
|
11
|
-
rawIcon?: string;
|
|
7
|
+
rawIcon?: string | undefined;
|
|
12
8
|
label: string;
|
|
13
9
|
detail?: string;
|
|
14
|
-
|
|
10
|
+
detailPreview?: string | undefined;
|
|
11
|
+
detailLength?: number | undefined;
|
|
12
|
+
detailTruncated?: boolean | undefined;
|
|
13
|
+
stepRef?: string | undefined;
|
|
14
|
+
traceRunId?: string | undefined; traceSeq?: number | undefined; detailAvailable?: boolean | undefined; detailBytes?: number | undefined; rawRetentionStatus?: string | undefined;
|
|
15
15
|
status: 'running' | 'done' | 'error';
|
|
16
16
|
startTime: number;
|
|
17
17
|
}
|
|
18
|
-
|
|
19
18
|
export interface ProcessBlockState {
|
|
20
19
|
element: HTMLElement;
|
|
21
20
|
steps: ProcessStep[];
|
|
22
21
|
collapsed: boolean;
|
|
23
22
|
_durationEl?: HTMLElement | null;
|
|
24
23
|
}
|
|
25
|
-
|
|
26
|
-
// ── Duration ticker ──
|
|
27
|
-
// Single module-level interval; runs only while a block has running steps.
|
|
28
|
-
// 3s cadence — one textContent write per tick, no DOM queries beyond cached ref.
|
|
29
24
|
let _tickerHandle: ReturnType<typeof setInterval> | null = null;
|
|
30
25
|
let _tickerBlock: ProcessBlockState | null = null;
|
|
26
|
+
const PROCESS_DETAIL_PREVIEW_CHARS = 160;
|
|
27
|
+
const PROCESS_DETAIL_RETAIN_CHARS = 3000;
|
|
28
|
+
const PROCESS_DETAIL_COLLAPSE_CLEAR_CHARS = 1000;
|
|
29
|
+
const PROCESS_BLOCK_MAX_RENDERED_STEPS = 80;
|
|
30
|
+
const PROCESS_BLOCK_HEAD_STEPS = 24;
|
|
31
|
+
const PROCESS_BLOCK_TAIL_STEPS = 24;
|
|
32
|
+
|
|
33
|
+
export interface StoredProcessStepMeta {
|
|
34
|
+
id: string;
|
|
35
|
+
type: ProcessStep['type'];
|
|
36
|
+
icon: string;
|
|
37
|
+
rawIcon?: string | undefined;
|
|
38
|
+
label: string;
|
|
39
|
+
stepRef?: string | undefined;
|
|
40
|
+
traceRunId?: string | undefined; traceSeq?: number | undefined; detailAvailable?: boolean | undefined; detailBytes?: number | undefined; rawRetentionStatus?: string | undefined;
|
|
41
|
+
status: ProcessStep['status'];
|
|
42
|
+
startTime: number;
|
|
43
|
+
preview: string;
|
|
44
|
+
detailLength: number;
|
|
45
|
+
detailTruncated: boolean;
|
|
46
|
+
}
|
|
47
|
+
const processDetailStore = new Map<string, { detail: string; originalLength: number; truncated: boolean }>();
|
|
48
|
+
const processStepMetaStore = new Map<string, StoredProcessStepMeta>();
|
|
31
49
|
|
|
32
50
|
function tickDuration(): void {
|
|
33
51
|
const pb = _tickerBlock;
|
|
@@ -37,7 +55,6 @@ function tickDuration(): void {
|
|
|
37
55
|
const elapsed = Math.round((Date.now() - pb.steps[0].startTime) / 1000);
|
|
38
56
|
el.textContent = elapsed > 0 ? `${elapsed}s` : '';
|
|
39
57
|
}
|
|
40
|
-
|
|
41
58
|
function ensureTicker(pb: ProcessBlockState): void {
|
|
42
59
|
if (_tickerHandle && _tickerBlock === pb) return;
|
|
43
60
|
stopBlockTicker();
|
|
@@ -49,7 +66,6 @@ export function stopBlockTicker(): void {
|
|
|
49
66
|
if (_tickerHandle) { clearInterval(_tickerHandle); _tickerHandle = null; }
|
|
50
67
|
_tickerBlock = null;
|
|
51
68
|
}
|
|
52
|
-
|
|
53
69
|
function buildSummaryText(steps: ProcessStep[]): string {
|
|
54
70
|
const counts: Record<string, number> = {};
|
|
55
71
|
for (const s of steps) {
|
|
@@ -70,6 +86,114 @@ function previewText(text: string, max = 120): string {
|
|
|
70
86
|
return singleLine.length > max ? `${singleLine.slice(0, max - 1)}…` : singleLine;
|
|
71
87
|
}
|
|
72
88
|
|
|
89
|
+
function retainedDetail(text: string): { detail: string; truncated: boolean } {
|
|
90
|
+
if (text.length <= PROCESS_DETAIL_RETAIN_CHARS) return { detail: text, truncated: false };
|
|
91
|
+
const notice = `\n[detail truncated: kept ${PROCESS_DETAIL_RETAIN_CHARS} of ${text.length} chars]`;
|
|
92
|
+
return {
|
|
93
|
+
detail: `${text.slice(0, Math.max(0, PROCESS_DETAIL_RETAIN_CHARS - notice.length))}${notice}`,
|
|
94
|
+
truncated: true,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
export function getStoredProcessStepDetail(stepId: string): string {
|
|
99
|
+
return processDetailStore.get(stepId)?.detail || '';
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
export function compactProcessStepForStorage(step: ProcessStep): ProcessStep {
|
|
103
|
+
const storedDetail = getStoredProcessStepDetail(step.id);
|
|
104
|
+
const fullDetail = storedDetail || step.detail || '';
|
|
105
|
+
const retained = retainedDetail(fullDetail);
|
|
106
|
+
const preview = step.detailPreview || previewText(fullDetail, PROCESS_DETAIL_PREVIEW_CHARS);
|
|
107
|
+
if (fullDetail) {
|
|
108
|
+
processDetailStore.set(step.id, {
|
|
109
|
+
detail: retained.detail,
|
|
110
|
+
originalLength: fullDetail.length,
|
|
111
|
+
truncated: retained.truncated,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
processStepMetaStore.set(step.id, {
|
|
115
|
+
id: step.id,
|
|
116
|
+
type: step.type,
|
|
117
|
+
icon: step.icon,
|
|
118
|
+
rawIcon: step.rawIcon,
|
|
119
|
+
label: step.label,
|
|
120
|
+
stepRef: step.stepRef,
|
|
121
|
+
traceRunId: step.traceRunId, traceSeq: step.traceSeq, detailAvailable: step.detailAvailable,
|
|
122
|
+
detailBytes: step.detailBytes, rawRetentionStatus: step.rawRetentionStatus,
|
|
123
|
+
status: step.status,
|
|
124
|
+
startTime: step.startTime,
|
|
125
|
+
preview,
|
|
126
|
+
detailLength: fullDetail.length,
|
|
127
|
+
detailTruncated: retained.truncated,
|
|
128
|
+
});
|
|
129
|
+
return {
|
|
130
|
+
...step,
|
|
131
|
+
detail: preview,
|
|
132
|
+
detailPreview: preview,
|
|
133
|
+
detailLength: fullDetail.length,
|
|
134
|
+
detailTruncated: retained.truncated,
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
export function mergeStoredProcessStepDetail(stepId: string, incomingDetail?: string): string {
|
|
139
|
+
const incoming = incomingDetail || '';
|
|
140
|
+
const existing = getStoredProcessStepDetail(stepId);
|
|
141
|
+
const merged = existing && incoming ? `${existing}\n${incoming}` : incoming || existing;
|
|
142
|
+
const retained = retainedDetail(merged);
|
|
143
|
+
if (merged) {
|
|
144
|
+
processDetailStore.set(stepId, {
|
|
145
|
+
detail: retained.detail,
|
|
146
|
+
originalLength: merged.length,
|
|
147
|
+
truncated: retained.truncated,
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
const meta = processStepMetaStore.get(stepId);
|
|
151
|
+
if (meta) {
|
|
152
|
+
meta.preview = previewText(merged, PROCESS_DETAIL_PREVIEW_CHARS);
|
|
153
|
+
meta.detailLength = merged.length;
|
|
154
|
+
meta.detailTruncated = retained.truncated;
|
|
155
|
+
}
|
|
156
|
+
return meta?.preview || previewText(merged, PROCESS_DETAIL_PREVIEW_CHARS);
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
function updateStoredStepMeta(step: ProcessStep): void {
|
|
160
|
+
const compact = compactProcessStepForStorage(step);
|
|
161
|
+
processStepMetaStore.set(step.id, {
|
|
162
|
+
id: compact.id,
|
|
163
|
+
type: compact.type,
|
|
164
|
+
icon: compact.icon,
|
|
165
|
+
rawIcon: compact.rawIcon,
|
|
166
|
+
label: compact.label,
|
|
167
|
+
stepRef: compact.stepRef,
|
|
168
|
+
traceRunId: compact.traceRunId, traceSeq: compact.traceSeq, detailAvailable: compact.detailAvailable,
|
|
169
|
+
detailBytes: compact.detailBytes, rawRetentionStatus: compact.rawRetentionStatus,
|
|
170
|
+
status: compact.status,
|
|
171
|
+
startTime: compact.startTime,
|
|
172
|
+
preview: compact.detailPreview || compact.detail || '',
|
|
173
|
+
detailLength: compact.detailLength || 0,
|
|
174
|
+
detailTruncated: Boolean(compact.detailTruncated),
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
function updateProcessBlockDetailIndex(pb: ProcessBlockState): void {
|
|
179
|
+
pb.element.dataset['processStepIds'] = pb.steps.map(step => step.id).join(' ');
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
function visibleStepIndexes(steps: ProcessStep[]): Set<number> {
|
|
183
|
+
const indexes = new Set<number>();
|
|
184
|
+
if (steps.length <= PROCESS_BLOCK_MAX_RENDERED_STEPS) {
|
|
185
|
+
steps.forEach((_step, idx) => indexes.add(idx));
|
|
186
|
+
return indexes;
|
|
187
|
+
}
|
|
188
|
+
steps.forEach((step, idx) => {
|
|
189
|
+
if (idx < PROCESS_BLOCK_HEAD_STEPS || idx >= steps.length - PROCESS_BLOCK_TAIL_STEPS
|
|
190
|
+
|| step.status === 'running' || step.status === 'error') {
|
|
191
|
+
indexes.add(idx);
|
|
192
|
+
}
|
|
193
|
+
});
|
|
194
|
+
return indexes;
|
|
195
|
+
}
|
|
196
|
+
|
|
73
197
|
function renderTrustedIcon(icon: string | undefined): string {
|
|
74
198
|
const value = icon || ICONS.tool;
|
|
75
199
|
return value.trim().startsWith('<svg') ? value : escapeHtml(value);
|
|
@@ -81,11 +205,10 @@ function renderStep(step: ProcessStep): string {
|
|
|
81
205
|
const badgeText = step.type.toUpperCase();
|
|
82
206
|
const label = escapeHtml(step.label || step.icon || '');
|
|
83
207
|
const icon = renderTrustedIcon(step.icon);
|
|
84
|
-
const detail = step.detail || '';
|
|
208
|
+
const detail = step.detailPreview || step.detail || '';
|
|
85
209
|
const detailId = `process-detail-${step.id}`;
|
|
210
|
+
const traceButton = step.detailAvailable && step.traceRunId && step.traceSeq ? `<span class="process-step-trace" role="button" tabindex="0" title="Open full trace" aria-label="Open full trace" data-trace-run-id="${escapeHtml(step.traceRunId)}" data-trace-seq="${String(step.traceSeq)}">Trace</span>` : '';
|
|
86
211
|
|
|
87
|
-
// Always render expandable — VS (THRESHOLD=1) keeps DOM count low
|
|
88
|
-
// so the extra elements per step are negligible
|
|
89
212
|
const snippetPreview = previewText(detail, step.type === 'thinking' ? 120 : 80);
|
|
90
213
|
const snippetHtml = snippetPreview
|
|
91
214
|
? `<span class="process-step-snippet">${escapeHtml(snippetPreview)}</span>`
|
|
@@ -95,6 +218,8 @@ function renderStep(step: ProcessStep): string {
|
|
|
95
218
|
data-type="${escapeHtml(step.type)}"
|
|
96
219
|
data-status="${escapeHtml(step.status)}"
|
|
97
220
|
data-step-ref="${escapeHtml(step.stepRef || '')}"
|
|
221
|
+
data-trace-run-id="${escapeHtml(step.traceRunId || '')}"
|
|
222
|
+
data-trace-seq="${String(step.traceSeq || '')}"
|
|
98
223
|
data-start-time="${String(step.startTime || Date.now())}">
|
|
99
224
|
<button class="process-step-toggle" aria-expanded="false" aria-controls="${detailId}">
|
|
100
225
|
<span class="${dotClass}"></span>
|
|
@@ -104,14 +229,42 @@ function renderStep(step: ProcessStep): string {
|
|
|
104
229
|
<span class="process-step-label">${label}</span>
|
|
105
230
|
${snippetHtml}
|
|
106
231
|
</span>
|
|
232
|
+
${traceButton}
|
|
107
233
|
<span class="process-step-chevron">${ICONS.chevronRight}</span>
|
|
108
234
|
</button>
|
|
109
235
|
<div class="process-step-details collapsed" id="${detailId}">
|
|
110
|
-
<pre class="process-step-full"
|
|
236
|
+
<pre class="process-step-full" data-detail-lazy="true"></pre>
|
|
111
237
|
</div>
|
|
112
238
|
</div>`;
|
|
113
239
|
}
|
|
114
240
|
|
|
241
|
+
function renderOmittedStepSummary(count: number): string {
|
|
242
|
+
return `<div class="process-step process-step-omitted" aria-hidden="true">
|
|
243
|
+
<span class="process-step-snippet">${count} completed tool step${count === 1 ? '' : 's'} hidden for memory safety</span>
|
|
244
|
+
</div>`;
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
function renderSteps(steps: ProcessStep[]): string {
|
|
248
|
+
const indexes = visibleStepIndexes(steps);
|
|
249
|
+
let omitted = 0;
|
|
250
|
+
const parts: string[] = [];
|
|
251
|
+
for (let idx = 0; idx < steps.length; idx++) {
|
|
252
|
+
const step = steps[idx];
|
|
253
|
+
if (!step) continue;
|
|
254
|
+
if (indexes.has(idx)) {
|
|
255
|
+
if (omitted > 0) {
|
|
256
|
+
parts.push(renderOmittedStepSummary(omitted));
|
|
257
|
+
omitted = 0;
|
|
258
|
+
}
|
|
259
|
+
parts.push(renderStep(step));
|
|
260
|
+
} else {
|
|
261
|
+
omitted++;
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
if (omitted > 0) parts.push(renderOmittedStepSummary(omitted));
|
|
265
|
+
return parts.join('');
|
|
266
|
+
}
|
|
267
|
+
|
|
115
268
|
function blockShell(summaryText = '', collapsed = false): string {
|
|
116
269
|
return `<div class="process-block${collapsed ? ' collapsed' : ''}">
|
|
117
270
|
<button class="process-summary" aria-expanded="${collapsed ? 'false' : 'true'}">
|
|
@@ -129,9 +282,18 @@ function blockShell(summaryText = '', collapsed = false): string {
|
|
|
129
282
|
function toggleStepDetails(toggle: HTMLElement): void {
|
|
130
283
|
const wrapper = toggle.closest('.process-step');
|
|
131
284
|
const details = wrapper?.querySelector('.process-step-details') as HTMLElement | null;
|
|
285
|
+
const pre = details?.querySelector('.process-step-full') as HTMLElement | null;
|
|
132
286
|
const chevron = toggle.querySelector('.process-step-chevron');
|
|
133
287
|
if (!wrapper || !details) return;
|
|
134
288
|
const expanding = details.classList.contains('collapsed');
|
|
289
|
+
if (expanding && pre?.dataset['detailLazy'] === 'true') {
|
|
290
|
+
const detail = getStoredProcessStepDetail((wrapper as HTMLElement).dataset['stepId'] || '');
|
|
291
|
+
pre.textContent = detail || processStepMetaStore.get((wrapper as HTMLElement).dataset['stepId'] || '')?.preview || '';
|
|
292
|
+
delete pre.dataset['detailLazy'];
|
|
293
|
+
} else if (!expanding && pre && pre.textContent && pre.textContent.length > PROCESS_DETAIL_COLLAPSE_CLEAR_CHARS) {
|
|
294
|
+
pre.textContent = '';
|
|
295
|
+
pre.dataset['detailLazy'] = 'true';
|
|
296
|
+
}
|
|
135
297
|
details.classList.toggle('collapsed', !expanding);
|
|
136
298
|
wrapper.classList.toggle('expanded', expanding);
|
|
137
299
|
toggle.setAttribute('aria-expanded', expanding ? 'true' : 'false');
|
|
@@ -139,10 +301,20 @@ function toggleStepDetails(toggle: HTMLElement): void {
|
|
|
139
301
|
}
|
|
140
302
|
|
|
141
303
|
export function bindProcessBlockInteractions(root: HTMLElement): void {
|
|
142
|
-
if (root.dataset
|
|
304
|
+
if (root.dataset['processBlockBound'] === '1') return;
|
|
143
305
|
root.addEventListener('click', (event) => {
|
|
144
306
|
const target = event.target as HTMLElement | null;
|
|
145
307
|
if (!target) return;
|
|
308
|
+
const traceTrigger = target.closest('.process-step-trace') as HTMLElement | null;
|
|
309
|
+
if (traceTrigger) {
|
|
310
|
+
event.preventDefault();
|
|
311
|
+
event.stopPropagation();
|
|
312
|
+
const runId = traceTrigger.dataset['traceRunId'] || '';
|
|
313
|
+
const seq = Number(traceTrigger.dataset['traceSeq'] || 0);
|
|
314
|
+
import('./trace-drawer.js').then(m => m.openTraceDrawer(runId, seq))
|
|
315
|
+
.catch(error => console.warn('[trace-drawer] open failed:', error));
|
|
316
|
+
return;
|
|
317
|
+
}
|
|
146
318
|
|
|
147
319
|
const stepToggle = target.closest('.process-step-toggle') as HTMLElement | null;
|
|
148
320
|
if (stepToggle) {
|
|
@@ -161,19 +333,22 @@ export function bindProcessBlockInteractions(root: HTMLElement): void {
|
|
|
161
333
|
if (chevron) chevron.innerHTML = expanding ? ICONS.chevronDown : ICONS.chevronRight;
|
|
162
334
|
}
|
|
163
335
|
});
|
|
164
|
-
root.dataset
|
|
336
|
+
root.dataset['processBlockBound'] = '1';
|
|
165
337
|
}
|
|
166
338
|
|
|
167
339
|
export function buildProcessBlockHtml(steps: ProcessStep[], collapsed = true): string {
|
|
168
|
-
const
|
|
340
|
+
const compactSteps = steps.map(compactProcessStepForStorage);
|
|
341
|
+
const summaryText = buildSummaryText(compactSteps);
|
|
169
342
|
const html = blockShell(summaryText, collapsed);
|
|
170
343
|
const wrapper = document.createElement('div');
|
|
171
344
|
wrapper.innerHTML = html;
|
|
345
|
+
const block = wrapper.querySelector('.process-block') as HTMLElement | null;
|
|
346
|
+
if (block) block.dataset['processStepIds'] = compactSteps.map(step => step.id).join(' ');
|
|
172
347
|
const inner = wrapper.querySelector('.process-steps-inner');
|
|
173
|
-
if (inner) inner.innerHTML =
|
|
348
|
+
if (inner) inner.innerHTML = renderSteps(compactSteps);
|
|
174
349
|
const dot = wrapper.querySelector('.process-dot');
|
|
175
350
|
if (dot) {
|
|
176
|
-
const anyRunning =
|
|
351
|
+
const anyRunning = compactSteps.some(step => step.status === 'running');
|
|
177
352
|
dot.classList.toggle('running', anyRunning && !collapsed);
|
|
178
353
|
dot.classList.toggle('done', !anyRunning || collapsed);
|
|
179
354
|
}
|
|
@@ -214,23 +389,37 @@ export function createProcessBlock(parentEl: HTMLElement): ProcessBlockState {
|
|
|
214
389
|
}
|
|
215
390
|
|
|
216
391
|
export function addStep(pb: ProcessBlockState, step: ProcessStep): void {
|
|
217
|
-
|
|
392
|
+
const compactStep = compactProcessStepForStorage(step);
|
|
393
|
+
pb.steps.push(compactStep);
|
|
218
394
|
const inner = pb.element.querySelector('.process-steps-inner');
|
|
219
|
-
if (inner)
|
|
395
|
+
if (inner) {
|
|
396
|
+
if (pb.steps.length > PROCESS_BLOCK_MAX_RENDERED_STEPS) inner.innerHTML = renderSteps(pb.steps);
|
|
397
|
+
else inner.insertAdjacentHTML('beforeend', renderStep(compactStep));
|
|
398
|
+
}
|
|
399
|
+
updateProcessBlockDetailIndex(pb);
|
|
220
400
|
updateSummary(pb);
|
|
221
401
|
}
|
|
222
402
|
|
|
223
403
|
export function replaceStep(pb: ProcessBlockState, oldStepId: string, newStep: ProcessStep): void {
|
|
224
404
|
const idx = pb.steps.findIndex(s => s.id === oldStepId);
|
|
225
405
|
if (idx === -1) return;
|
|
226
|
-
|
|
406
|
+
if (oldStepId !== newStep.id) {
|
|
407
|
+
processDetailStore.delete(oldStepId);
|
|
408
|
+
processStepMetaStore.delete(oldStepId);
|
|
409
|
+
}
|
|
410
|
+
const compactStep = compactProcessStepForStorage(newStep);
|
|
411
|
+
pb.steps[idx] = compactStep;
|
|
227
412
|
const oldEl = pb.element.querySelector(`[data-step-id="${oldStepId}"]`);
|
|
228
413
|
if (oldEl) {
|
|
229
414
|
const temp = document.createElement('div');
|
|
230
|
-
temp.innerHTML = renderStep(
|
|
415
|
+
temp.innerHTML = renderStep(compactStep);
|
|
231
416
|
const newEl = temp.firstElementChild;
|
|
232
417
|
if (newEl) oldEl.replaceWith(newEl);
|
|
418
|
+
} else if (pb.steps.length > PROCESS_BLOCK_MAX_RENDERED_STEPS) {
|
|
419
|
+
const inner = pb.element.querySelector('.process-steps-inner');
|
|
420
|
+
if (inner) inner.innerHTML = renderSteps(pb.steps);
|
|
233
421
|
}
|
|
422
|
+
updateProcessBlockDetailIndex(pb);
|
|
234
423
|
updateSummary(pb);
|
|
235
424
|
}
|
|
236
425
|
|
|
@@ -238,15 +427,20 @@ export function updateStepStatus(pb: ProcessBlockState, stepId: string, status:
|
|
|
238
427
|
const step = pb.steps.find(s => s.id === stepId);
|
|
239
428
|
if (!step) return;
|
|
240
429
|
step.status = status;
|
|
430
|
+
updateStoredStepMeta(step);
|
|
241
431
|
const stepEl = pb.element.querySelector(`[data-step-id="${stepId}"]`);
|
|
242
432
|
if (stepEl) {
|
|
243
|
-
(stepEl as HTMLElement).dataset
|
|
433
|
+
(stepEl as HTMLElement).dataset['status'] = status;
|
|
244
434
|
const dot = stepEl.querySelector('.process-step-dot');
|
|
245
435
|
if (dot) {
|
|
246
436
|
dot.classList.remove('running', 'done', 'error');
|
|
247
437
|
dot.classList.add(status);
|
|
248
438
|
}
|
|
439
|
+
} else if (status === 'running' || status === 'error') {
|
|
440
|
+
const inner = pb.element.querySelector('.process-steps-inner');
|
|
441
|
+
if (inner) inner.innerHTML = renderSteps(pb.steps);
|
|
249
442
|
}
|
|
443
|
+
updateProcessBlockDetailIndex(pb);
|
|
250
444
|
updateSummary(pb);
|
|
251
445
|
}
|
|
252
446
|
|
|
@@ -260,13 +454,47 @@ export function collapseBlock(pb: ProcessBlockState): void {
|
|
|
260
454
|
if (chevron) chevron.innerHTML = ICONS.chevronRight;
|
|
261
455
|
|
|
262
456
|
for (const step of pb.steps) {
|
|
263
|
-
if (step.status === 'running')
|
|
457
|
+
if (step.status === 'running') {
|
|
458
|
+
step.status = 'done';
|
|
459
|
+
updateStoredStepMeta(step);
|
|
460
|
+
}
|
|
264
461
|
}
|
|
265
462
|
pb.element.querySelectorAll('.process-step-dot.running').forEach(dot => {
|
|
266
463
|
dot.classList.remove('running');
|
|
267
464
|
dot.classList.add('done');
|
|
268
465
|
const row = dot.closest('.process-step') as HTMLElement | null;
|
|
269
|
-
if (row) row.dataset
|
|
466
|
+
if (row) row.dataset['status'] = 'done';
|
|
270
467
|
});
|
|
271
468
|
updateSummary(pb);
|
|
272
469
|
}
|
|
470
|
+
|
|
471
|
+
export function releaseProcessBlockDetails(rootOrState: HTMLElement | ProcessBlockState | null | undefined): void {
|
|
472
|
+
if (!rootOrState) return;
|
|
473
|
+
const ids = new Set<string>();
|
|
474
|
+
if ('steps' in rootOrState) {
|
|
475
|
+
rootOrState.steps.forEach(step => ids.add(step.id));
|
|
476
|
+
} else {
|
|
477
|
+
if (rootOrState.classList.contains('process-block')) {
|
|
478
|
+
(rootOrState.dataset['processStepIds'] || '').split(/\s+/).filter(Boolean).forEach(id => ids.add(id));
|
|
479
|
+
}
|
|
480
|
+
rootOrState.querySelectorAll<HTMLElement>('.process-block[data-process-step-ids]').forEach(block => {
|
|
481
|
+
(block.dataset['processStepIds'] || '').split(/\s+/).filter(Boolean).forEach(id => ids.add(id));
|
|
482
|
+
});
|
|
483
|
+
if (rootOrState.classList.contains('process-step')) {
|
|
484
|
+
const id = rootOrState.dataset['stepId'];
|
|
485
|
+
if (id) ids.add(id);
|
|
486
|
+
}
|
|
487
|
+
rootOrState.querySelectorAll<HTMLElement>('.process-step[data-step-id]').forEach(row => {
|
|
488
|
+
const id = row.dataset['stepId'];
|
|
489
|
+
if (id) ids.add(id);
|
|
490
|
+
});
|
|
491
|
+
}
|
|
492
|
+
ids.forEach(id => {
|
|
493
|
+
processDetailStore.delete(id);
|
|
494
|
+
processStepMetaStore.delete(id);
|
|
495
|
+
});
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
export function processStepMetaFromStore(stepId: string): StoredProcessStepMeta | null {
|
|
499
|
+
return processStepMetaStore.get(stepId) || null;
|
|
500
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ProcessStep } from './process-block.js';
|
|
2
|
+
|
|
3
|
+
export function findLegacyRunningMatch(steps: ProcessStep[], step: ProcessStep): ProcessStep | null {
|
|
4
|
+
const matches = steps.filter(s => s.status === 'running'
|
|
5
|
+
&& !s.stepRef
|
|
6
|
+
&& s.label === step.label
|
|
7
|
+
&& s.type === step.type);
|
|
8
|
+
return matches.length === 1 ? matches[0]! : null;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function findRunningProcessStepMatch(steps: ProcessStep[], step: ProcessStep): ProcessStep | null {
|
|
12
|
+
const running = [...steps].reverse().filter(s => s.status === 'running');
|
|
13
|
+
if (step.stepRef) {
|
|
14
|
+
return running.find(s => s.stepRef === step.stepRef)
|
|
15
|
+
?? findLegacyRunningMatch(running, step);
|
|
16
|
+
}
|
|
17
|
+
return findLegacyRunningMatch(running, step);
|
|
18
|
+
}
|
|
@@ -72,7 +72,7 @@ export function normalizeQuotaWindowLabel(cliName: string, label: string): strin
|
|
|
72
72
|
export async function loadCliStatus(force = false): Promise<void> {
|
|
73
73
|
const interval = readCliStatusInterval();
|
|
74
74
|
if (!force && state.cliStatusCache && interval > 0 && (Date.now() - state.cliStatusTs) < interval * 1000) {
|
|
75
|
-
renderCliStatus({ cliStatus: (state.cliStatusCache as Record<string, unknown>)?.cliStatus as Record<string, { available: boolean }> | null, quota: (state.cliStatusCache as Record<string, unknown>)?.quota as Record<string, QuotaEntry> | null });
|
|
75
|
+
renderCliStatus({ cliStatus: (state.cliStatusCache as Record<string, unknown>)?.['cliStatus'] as Record<string, { available: boolean }> | null, quota: (state.cliStatusCache as Record<string, unknown>)?.['quota'] as Record<string, QuotaEntry> | null });
|
|
76
76
|
return;
|
|
77
77
|
}
|
|
78
78
|
|
|
@@ -2,7 +2,33 @@
|
|
|
2
2
|
import { apiJson } from '../api.js';
|
|
3
3
|
import { t } from './i18n.js';
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
type SttSettingsConfig = {
|
|
6
|
+
engine?: string;
|
|
7
|
+
geminiKeySet?: boolean;
|
|
8
|
+
geminiKeyLast4?: string;
|
|
9
|
+
geminiModel?: string;
|
|
10
|
+
whisperModel?: string;
|
|
11
|
+
openaiBaseUrl?: string;
|
|
12
|
+
openaiKeySet?: boolean;
|
|
13
|
+
openaiKeyLast4?: string;
|
|
14
|
+
openaiModel?: string;
|
|
15
|
+
vertexConfig?: string;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
type SttSettingsPatch = {
|
|
19
|
+
stt: {
|
|
20
|
+
engine: string;
|
|
21
|
+
geminiModel: string;
|
|
22
|
+
whisperModel: string;
|
|
23
|
+
openaiBaseUrl: string;
|
|
24
|
+
openaiModel: string;
|
|
25
|
+
vertexConfig: string;
|
|
26
|
+
geminiApiKey?: string;
|
|
27
|
+
openaiApiKey?: string;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export function initSttSettings(sttConfig: SttSettingsConfig): void {
|
|
6
32
|
const engine = document.getElementById('sttEngine') as HTMLSelectElement | null;
|
|
7
33
|
const geminiKey = document.getElementById('sttGeminiKey') as HTMLInputElement | null;
|
|
8
34
|
const geminiModel = document.getElementById('sttGeminiModel') as HTMLSelectElement | null;
|
|
@@ -13,19 +39,19 @@ export function initSttSettings(sttConfig: Record<string, any>): void {
|
|
|
13
39
|
const openaiModel = document.getElementById('sttOpenaiModel') as HTMLInputElement | null;
|
|
14
40
|
const vertexJson = document.getElementById('sttVertexJson') as HTMLTextAreaElement | null;
|
|
15
41
|
|
|
16
|
-
if (engine) engine.value = sttConfig
|
|
17
|
-
if (geminiKey) geminiKey.placeholder = sttConfig
|
|
42
|
+
if (engine) engine.value = sttConfig['engine'] || 'auto';
|
|
43
|
+
if (geminiKey) geminiKey.placeholder = sttConfig['geminiKeySet'] ? savedKeyPlaceholder(sttConfig['geminiKeyLast4']) : 'AIza...';
|
|
18
44
|
if (geminiModel) {
|
|
19
|
-
const saved = sttConfig
|
|
45
|
+
const saved = sttConfig['geminiModel'] || 'gemini-2.5-flash-lite';
|
|
20
46
|
const hasOption = Array.from(geminiModel.options).some(o => o.value === saved);
|
|
21
47
|
if (hasOption) { geminiModel.value = saved; }
|
|
22
48
|
else { geminiModel.value = '__custom__'; if (geminiModelCustom) { geminiModelCustom.value = saved; geminiModelCustom.style.display = ''; } }
|
|
23
49
|
}
|
|
24
|
-
if (whisperModel) whisperModel.value = sttConfig
|
|
25
|
-
if (openaiBaseUrl) openaiBaseUrl.value = sttConfig
|
|
26
|
-
if (openaiKey) openaiKey.placeholder = sttConfig
|
|
27
|
-
if (openaiModel) openaiModel.value = sttConfig
|
|
28
|
-
if (vertexJson) vertexJson.value = sttConfig
|
|
50
|
+
if (whisperModel) whisperModel.value = sttConfig['whisperModel'] || 'mlx-community/whisper-large-v3-turbo';
|
|
51
|
+
if (openaiBaseUrl) openaiBaseUrl.value = sttConfig['openaiBaseUrl'] || '';
|
|
52
|
+
if (openaiKey) openaiKey.placeholder = sttConfig['openaiKeySet'] ? savedKeyPlaceholder(sttConfig['openaiKeyLast4']) : 'sk-...';
|
|
53
|
+
if (openaiModel) openaiModel.value = sttConfig['openaiModel'] || '';
|
|
54
|
+
if (vertexJson) vertexJson.value = sttConfig['vertexConfig'] || '';
|
|
29
55
|
|
|
30
56
|
function toggleProviderFields() {
|
|
31
57
|
const v = engine?.value || 'auto';
|
|
@@ -41,7 +67,7 @@ export function initSttSettings(sttConfig: Record<string, any>): void {
|
|
|
41
67
|
toggleProviderFields();
|
|
42
68
|
|
|
43
69
|
async function saveStt() {
|
|
44
|
-
const patch:
|
|
70
|
+
const patch: SttSettingsPatch = {
|
|
45
71
|
stt: {
|
|
46
72
|
engine: engine?.value || 'auto',
|
|
47
73
|
geminiModel: (geminiModel?.value === '__custom__' ? geminiModelCustom?.value : geminiModel?.value) || 'gemini-2.5-flash-lite',
|
|
@@ -53,7 +79,7 @@ export function initSttSettings(sttConfig: Record<string, any>): void {
|
|
|
53
79
|
};
|
|
54
80
|
if (geminiKey?.value) patch.stt.geminiApiKey = geminiKey.value;
|
|
55
81
|
if (openaiKey?.value) patch.stt.openaiApiKey = openaiKey.value;
|
|
56
|
-
console.log('[stt] saving:', { engine: patch
|
|
82
|
+
console.log('[stt] saving:', { engine: patch['stt'].engine, hasGeminiKey: !!patch['stt'].geminiApiKey, hasOpenaiKey: !!patch['stt'].openaiApiKey });
|
|
57
83
|
try {
|
|
58
84
|
await apiJson('/api/settings', 'PUT', patch);
|
|
59
85
|
if (geminiKey?.value) { const l4 = geminiKey.value.slice(-4); geminiKey.value = ''; geminiKey.placeholder = savedKeyPlaceholder(l4); }
|
|
@@ -70,7 +70,7 @@ function renderTree(tree: TreeNode[]): void {
|
|
|
70
70
|
function openTemplateEditor(tmpl: TemplateInfo): void {
|
|
71
71
|
const editor = document.getElementById('templateEditor') as HTMLTextAreaElement;
|
|
72
72
|
editor.value = tmpl.content;
|
|
73
|
-
editor.dataset
|
|
73
|
+
editor.dataset['templateId'] = tmpl.id;
|
|
74
74
|
editor.readOnly = true;
|
|
75
75
|
_devMode = false;
|
|
76
76
|
const label = document.getElementById('templateEditorLabel');
|
|
@@ -106,7 +106,7 @@ export function toggleDevMode(): void {
|
|
|
106
106
|
|
|
107
107
|
export async function saveTemplateFromModal(): Promise<void> {
|
|
108
108
|
const editor = document.getElementById('templateEditor') as HTMLTextAreaElement;
|
|
109
|
-
const id = editor.dataset
|
|
109
|
+
const id = editor.dataset['templateId'];
|
|
110
110
|
if (!id) return;
|
|
111
111
|
await apiJson(`/api/prompt-templates/${id}`, 'PUT', { content: editor.value });
|
|
112
112
|
const label = document.getElementById('templateEditorLabel');
|
|
@@ -207,7 +207,7 @@ export function handleClick(e: Event): void {
|
|
|
207
207
|
const target = e.target as HTMLElement;
|
|
208
208
|
const item = target.closest('.cmd-item') as HTMLElement | null;
|
|
209
209
|
if (!item) return;
|
|
210
|
-
const idx = parseInt(item.dataset
|
|
210
|
+
const idx = parseInt(item.dataset['index'] || '-1', 10);
|
|
211
211
|
if (Number.isNaN(idx) || idx < 0) return;
|
|
212
212
|
selectedIdx = Math.min(idx, filtered.length - 1);
|
|
213
213
|
applySelection(true);
|
|
@@ -7,12 +7,18 @@ import { ICONS } from '../icons.js';
|
|
|
7
7
|
|
|
8
8
|
export interface ToolLogEntry {
|
|
9
9
|
icon: string;
|
|
10
|
-
rawIcon?: string;
|
|
10
|
+
rawIcon?: string | undefined;
|
|
11
11
|
label: string;
|
|
12
|
-
detail?: string;
|
|
13
|
-
toolType?: string;
|
|
14
|
-
stepRef?: string;
|
|
15
|
-
status?: string;
|
|
12
|
+
detail?: string | undefined;
|
|
13
|
+
toolType?: string | undefined;
|
|
14
|
+
stepRef?: string | undefined;
|
|
15
|
+
status?: string | undefined;
|
|
16
|
+
isEmployee?: boolean | undefined;
|
|
17
|
+
traceRunId?: string | undefined;
|
|
18
|
+
traceSeq?: number | undefined;
|
|
19
|
+
detailAvailable?: boolean | undefined;
|
|
20
|
+
detailBytes?: number | undefined;
|
|
21
|
+
rawRetentionStatus?: string | undefined;
|
|
16
22
|
}
|
|
17
23
|
|
|
18
24
|
function hasExpandableDetail(tl: ToolLogEntry): boolean {
|
|
@@ -78,7 +84,7 @@ export function buildToolGroupHtml(toolLog: ToolLogEntry[]): string {
|
|
|
78
84
|
|
|
79
85
|
/** Bind expand/collapse click handlers for tool items within a container */
|
|
80
86
|
export function bindToolItemInteractions(root: HTMLElement): void {
|
|
81
|
-
if (root.dataset
|
|
87
|
+
if (root.dataset['toolItemBound'] === '1') return;
|
|
82
88
|
root.addEventListener('click', (event) => {
|
|
83
89
|
const target = event.target as HTMLElement | null;
|
|
84
90
|
if (!target) return;
|
|
@@ -94,7 +100,7 @@ export function bindToolItemInteractions(root: HTMLElement): void {
|
|
|
94
100
|
toggle.setAttribute('aria-expanded', expanding ? 'true' : 'false');
|
|
95
101
|
if (chevron) chevron.innerHTML = expanding ? ICONS.chevronDown : ICONS.chevronRight;
|
|
96
102
|
});
|
|
97
|
-
root.dataset
|
|
103
|
+
root.dataset['toolItemBound'] = '1';
|
|
98
104
|
}
|
|
99
105
|
|
|
100
106
|
/** Show live tool activity indicator inside the current agent message */
|