catui-agent 1.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +674 -0
- package/README.md +267 -0
- package/dist/build-meta.json +6 -0
- package/dist/builtin-extensions.d.ts +47 -0
- package/dist/builtin-extensions.js +1 -0
- package/dist/catui-defaults.d.ts +555 -0
- package/dist/catui-defaults.js +22 -0
- package/dist/cli/args.d.ts +70 -0
- package/dist/cli/args.js +158 -0
- package/dist/cli/config-selector.d.ts +10 -0
- package/dist/cli/config-selector.js +1 -0
- package/dist/cli/file-processor.d.ts +11 -0
- package/dist/cli/file-processor.js +6 -0
- package/dist/cli/list-models.d.ts +12 -0
- package/dist/cli/list-models.js +2 -0
- package/dist/cli/session-picker.d.ts +5 -0
- package/dist/cli/session-picker.js +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +2 -0
- package/dist/config.d.ts +103 -0
- package/dist/config.js +1 -0
- package/dist/core/agent-dir/agent-dir-context.d.ts +60 -0
- package/dist/core/agent-dir/agent-dir-context.js +1 -0
- package/dist/core/agent-dir/agent-metadata.d.ts +48 -0
- package/dist/core/agent-dir/agent-metadata.js +1 -0
- package/dist/core/agent-dir/migration-tool.d.ts +40 -0
- package/dist/core/agent-dir/migration-tool.js +7 -0
- package/dist/core/export-html/AGENT.md +12 -0
- package/dist/core/export-html/ansi-to-html.d.ts +9 -0
- package/dist/core/export-html/ansi-to-html.js +2 -0
- package/dist/core/export-html/index.d.ts +39 -0
- package/dist/core/export-html/index.js +2 -0
- package/dist/core/export-html/template.css +971 -0
- package/dist/core/export-html/template.html +54 -0
- package/dist/core/export-html/template.js +66 -0
- package/dist/core/export-html/tool-renderer.d.ts +28 -0
- package/dist/core/export-html/tool-renderer.js +1 -0
- package/dist/core/export-html/vendor/highlight.min.js +4 -0
- package/dist/core/export-html/vendor/marked.min.js +56 -0
- package/dist/core/extensions-host/index.d.ts +13 -0
- package/dist/core/extensions-host/index.js +1 -0
- package/dist/core/extensions-host/loader.d.ts +21 -0
- package/dist/core/extensions-host/loader.js +1 -0
- package/dist/core/extensions-host/runner.d.ts +233 -0
- package/dist/core/extensions-host/runner.js +3 -0
- package/dist/core/extensions-host/types.d.ts +1079 -0
- package/dist/core/extensions-host/types.js +1 -0
- package/dist/core/extensions-host/wrapper.d.ts +29 -0
- package/dist/core/extensions-host/wrapper.js +2 -0
- package/dist/core/index.d.ts +17 -0
- package/dist/core/index.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-continuations.d.ts +17 -0
- package/dist/core/lib/agent-core/src/agent-loop-continuations.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-stream-events.d.ts +19 -0
- package/dist/core/lib/agent-core/src/agent-loop-stream-events.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-results.d.ts +10 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-results.js +3 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-summaries.d.ts +22 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-summaries.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop.d.ts +26 -0
- package/dist/core/lib/agent-core/src/agent-loop.js +4 -0
- package/dist/core/lib/agent-core/src/agent-run-result.d.ts +9 -0
- package/dist/core/lib/agent-core/src/agent-run-result.js +1 -0
- package/dist/core/lib/agent-core/src/agent.d.ts +215 -0
- package/dist/core/lib/agent-core/src/agent.js +1 -0
- package/dist/core/lib/agent-core/src/errors.d.ts +62 -0
- package/dist/core/lib/agent-core/src/errors.js +1 -0
- package/dist/core/lib/agent-core/src/index.d.ts +14 -0
- package/dist/core/lib/agent-core/src/index.js +1 -0
- package/dist/core/lib/agent-core/src/proxy.d.ts +91 -0
- package/dist/core/lib/agent-core/src/proxy.js +2 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-agent-loop.d.ts +15 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-agent-loop.js +2 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-streaming-tool-executor.d.ts +33 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-streaming-tool-executor.js +1 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-tool-orchestration.d.ts +35 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-tool-orchestration.js +3 -0
- package/dist/core/lib/agent-core/src/types.d.ts +417 -0
- package/dist/core/lib/agent-core/src/types.js +1 -0
- package/dist/core/lib/ai/src/api-registry.d.ts +27 -0
- package/dist/core/lib/ai/src/api-registry.js +1 -0
- package/dist/core/lib/ai/src/config-path.d.ts +1 -0
- package/dist/core/lib/ai/src/config-path.js +1 -0
- package/dist/core/lib/ai/src/debug-logger.d.ts +94 -0
- package/dist/core/lib/ai/src/debug-logger.js +4 -0
- package/dist/core/lib/ai/src/env-api-keys.d.ts +8 -0
- package/dist/core/lib/ai/src/env-api-keys.js +1 -0
- package/dist/core/lib/ai/src/env.d.ts +7 -0
- package/dist/core/lib/ai/src/env.js +1 -0
- package/dist/core/lib/ai/src/events.d.ts +8 -0
- package/dist/core/lib/ai/src/events.js +1 -0
- package/dist/core/lib/ai/src/index.d.ts +27 -0
- package/dist/core/lib/ai/src/index.js +1 -0
- package/dist/core/lib/ai/src/json.d.ts +7 -0
- package/dist/core/lib/ai/src/json.js +1 -0
- package/dist/core/lib/ai/src/models.d.ts +31 -0
- package/dist/core/lib/ai/src/models.generated.d.ts +15315 -0
- package/dist/core/lib/ai/src/models.generated.js +1 -0
- package/dist/core/lib/ai/src/models.js +1 -0
- package/dist/core/lib/ai/src/overflow.d.ts +7 -0
- package/dist/core/lib/ai/src/overflow.js +1 -0
- package/dist/core/lib/ai/src/providers/amazon-bedrock.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/amazon-bedrock.js +1 -0
- package/dist/core/lib/ai/src/providers/anthropic.d.ts +38 -0
- package/dist/core/lib/ai/src/providers/anthropic.js +2 -0
- package/dist/core/lib/ai/src/providers/azure-openai-responses.d.ts +21 -0
- package/dist/core/lib/ai/src/providers/azure-openai-responses.js +1 -0
- package/dist/core/lib/ai/src/providers/github-copilot-headers.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/github-copilot-headers.js +1 -0
- package/dist/core/lib/ai/src/providers/google-gemini-cli.d.ts +79 -0
- package/dist/core/lib/ai/src/providers/google-gemini-cli.js +2 -0
- package/dist/core/lib/ai/src/providers/google-shared.d.ts +70 -0
- package/dist/core/lib/ai/src/providers/google-shared.js +2 -0
- package/dist/core/lib/ai/src/providers/google-vertex.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/google-vertex.js +1 -0
- package/dist/core/lib/ai/src/providers/google.d.ts +18 -0
- package/dist/core/lib/ai/src/providers/google.js +1 -0
- package/dist/core/lib/ai/src/providers/openai-codex-responses.d.ts +8 -0
- package/dist/core/lib/ai/src/providers/openai-codex-responses.js +7 -0
- package/dist/core/lib/ai/src/providers/openai-completions.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/openai-completions.js +6 -0
- package/dist/core/lib/ai/src/providers/openai-responses-shared.d.ts +22 -0
- package/dist/core/lib/ai/src/providers/openai-responses-shared.js +10 -0
- package/dist/core/lib/ai/src/providers/openai-responses.d.ts +19 -0
- package/dist/core/lib/ai/src/providers/openai-responses.js +1 -0
- package/dist/core/lib/ai/src/providers/register-builtins.d.ts +8 -0
- package/dist/core/lib/ai/src/providers/register-builtins.js +1 -0
- package/dist/core/lib/ai/src/providers/simple-options.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/simple-options.js +1 -0
- package/dist/core/lib/ai/src/providers/transform-messages.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/transform-messages.js +1 -0
- package/dist/core/lib/ai/src/registry.d.ts +8 -0
- package/dist/core/lib/ai/src/registry.js +1 -0
- package/dist/core/lib/ai/src/schema.d.ts +10 -0
- package/dist/core/lib/ai/src/schema.js +1 -0
- package/dist/core/lib/ai/src/stream.d.ts +33 -0
- package/dist/core/lib/ai/src/stream.js +1 -0
- package/dist/core/lib/ai/src/types.d.ts +331 -0
- package/dist/core/lib/ai/src/types.js +0 -0
- package/dist/core/lib/ai/src/utils/event-stream-types.d.ts +12 -0
- package/dist/core/lib/ai/src/utils/event-stream-types.js +0 -0
- package/dist/core/lib/ai/src/utils/event-stream.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/event-stream.js +1 -0
- package/dist/core/lib/ai/src/utils/http-proxy.d.ts +13 -0
- package/dist/core/lib/ai/src/utils/http-proxy.js +1 -0
- package/dist/core/lib/ai/src/utils/json-parse.d.ts +14 -0
- package/dist/core/lib/ai/src/utils/json-parse.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/anthropic.d.ts +22 -0
- package/dist/core/lib/ai/src/utils/oauth/anthropic.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/decode-credential.d.ts +12 -0
- package/dist/core/lib/ai/src/utils/oauth/decode-credential.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/github-copilot.d.ts +35 -0
- package/dist/core/lib/ai/src/utils/oauth/github-copilot.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/google-antigravity.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/oauth/google-antigravity.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/google-gemini-cli.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/oauth/google-gemini-cli.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/index.d.ts +60 -0
- package/dist/core/lib/ai/src/utils/oauth/index.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/openai-codex.d.ts +39 -0
- package/dist/core/lib/ai/src/utils/oauth/openai-codex.js +11 -0
- package/dist/core/lib/ai/src/utils/oauth/pkce.d.ts +18 -0
- package/dist/core/lib/ai/src/utils/oauth/pkce.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/types.d.ts +52 -0
- package/dist/core/lib/ai/src/utils/oauth/types.js +0 -0
- package/dist/core/lib/ai/src/utils/overflow.d.ts +57 -0
- package/dist/core/lib/ai/src/utils/overflow.js +1 -0
- package/dist/core/lib/ai/src/utils/sanitize-unicode.d.ts +16 -0
- package/dist/core/lib/ai/src/utils/sanitize-unicode.js +1 -0
- package/dist/core/lib/ai/src/utils/typebox-helpers.d.ts +22 -0
- package/dist/core/lib/ai/src/utils/typebox-helpers.js +1 -0
- package/dist/core/lib/ai/src/utils/validation.d.ts +23 -0
- package/dist/core/lib/ai/src/utils/validation.js +6 -0
- package/dist/core/lib/tui/src/autocomplete.d.ts +62 -0
- package/dist/core/lib/tui/src/autocomplete.js +2 -0
- package/dist/core/lib/tui/src/components/box.d.ts +27 -0
- package/dist/core/lib/tui/src/components/box.js +1 -0
- package/dist/core/lib/tui/src/components/cached-container.d.ts +42 -0
- package/dist/core/lib/tui/src/components/cached-container.js +1 -0
- package/dist/core/lib/tui/src/components/cancellable-loader.d.ts +27 -0
- package/dist/core/lib/tui/src/components/cancellable-loader.js +1 -0
- package/dist/core/lib/tui/src/components/editor.d.ts +222 -0
- package/dist/core/lib/tui/src/components/editor.js +21 -0
- package/dist/core/lib/tui/src/components/image.d.ts +33 -0
- package/dist/core/lib/tui/src/components/image.js +1 -0
- package/dist/core/lib/tui/src/components/input.d.ts +42 -0
- package/dist/core/lib/tui/src/components/input.js +2 -0
- package/dist/core/lib/tui/src/components/loader.d.ts +26 -0
- package/dist/core/lib/tui/src/components/loader.js +1 -0
- package/dist/core/lib/tui/src/components/markdown.d.ts +100 -0
- package/dist/core/lib/tui/src/components/markdown.js +7 -0
- package/dist/core/lib/tui/src/components/select-list.d.ts +37 -0
- package/dist/core/lib/tui/src/components/select-list.js +1 -0
- package/dist/core/lib/tui/src/components/settings-list.d.ts +55 -0
- package/dist/core/lib/tui/src/components/settings-list.js +1 -0
- package/dist/core/lib/tui/src/components/spacer.d.ts +17 -0
- package/dist/core/lib/tui/src/components/spacer.js +1 -0
- package/dist/core/lib/tui/src/components/text.d.ts +24 -0
- package/dist/core/lib/tui/src/components/text.js +1 -0
- package/dist/core/lib/tui/src/components/truncated-text.d.ts +18 -0
- package/dist/core/lib/tui/src/components/truncated-text.js +2 -0
- package/dist/core/lib/tui/src/editor-component.d.ts +51 -0
- package/dist/core/lib/tui/src/editor-component.js +0 -0
- package/dist/core/lib/tui/src/fuzzy.d.ts +32 -0
- package/dist/core/lib/tui/src/fuzzy.js +1 -0
- package/dist/core/lib/tui/src/index.d.ts +29 -0
- package/dist/core/lib/tui/src/index.js +1 -0
- package/dist/core/lib/tui/src/keybindings.d.ts +44 -0
- package/dist/core/lib/tui/src/keybindings.js +1 -0
- package/dist/core/lib/tui/src/keys.d.ts +149 -0
- package/dist/core/lib/tui/src/keys.js +5 -0
- package/dist/core/lib/tui/src/kill-ring.d.ts +33 -0
- package/dist/core/lib/tui/src/kill-ring.js +1 -0
- package/dist/core/lib/tui/src/stdin-buffer.d.ts +38 -0
- package/dist/core/lib/tui/src/stdin-buffer.js +1 -0
- package/dist/core/lib/tui/src/terminal-image.d.ts +73 -0
- package/dist/core/lib/tui/src/terminal-image.js +1 -0
- package/dist/core/lib/tui/src/terminal.d.ts +86 -0
- package/dist/core/lib/tui/src/terminal.js +1 -0
- package/dist/core/lib/tui/src/tui.d.ts +220 -0
- package/dist/core/lib/tui/src/tui.js +12 -0
- package/dist/core/lib/tui/src/undo-stack.d.ts +22 -0
- package/dist/core/lib/tui/src/undo-stack.js +1 -0
- package/dist/core/lib/tui/src/utils.d.ts +83 -0
- package/dist/core/lib/tui/src/utils.js +2 -0
- package/dist/core/mcp/figma-auth.d.ts +21 -0
- package/dist/core/mcp/figma-auth.js +22 -0
- package/dist/core/mcp/index.d.ts +11 -0
- package/dist/core/mcp/index.js +1 -0
- package/dist/core/mcp/mcp-adapter.d.ts +21 -0
- package/dist/core/mcp/mcp-adapter.js +3 -0
- package/dist/core/mcp/mcp-client.d.ts +91 -0
- package/dist/core/mcp/mcp-client.js +6 -0
- package/dist/core/mcp/mcp-config.d.ts +55 -0
- package/dist/core/mcp/mcp-config.js +1 -0
- package/dist/core/mcp/mcp-guidance.d.ts +52 -0
- package/dist/core/mcp/mcp-guidance.js +54 -0
- package/dist/core/mcp/mcp-manager.d.ts +51 -0
- package/dist/core/mcp/mcp-manager.js +1 -0
- package/dist/core/mcp/mcp-types.d.ts +62 -0
- package/dist/core/mcp/mcp-types.js +0 -0
- package/dist/core/messages.d.ts +77 -0
- package/dist/core/messages.js +17 -0
- package/dist/core/model/custom-providers.d.ts +34 -0
- package/dist/core/model/custom-providers.js +1 -0
- package/dist/core/model/discovery-cache.d.ts +65 -0
- package/dist/core/model/discovery-cache.js +1 -0
- package/dist/core/model/discovery-cache.test.d.ts +7 -0
- package/dist/core/model/discovery-cache.test.js +1 -0
- package/dist/core/model/discovery.d.ts +79 -0
- package/dist/core/model/discovery.js +1 -0
- package/dist/core/model/discovery.test.d.ts +7 -0
- package/dist/core/model/discovery.test.js +1 -0
- package/dist/core/model/index.d.ts +10 -0
- package/dist/core/model/index.js +1 -0
- package/dist/core/model/known-models.d.ts +65 -0
- package/dist/core/model/known-models.generated.d.ts +2 -0
- package/dist/core/model/known-models.generated.js +1 -0
- package/dist/core/model/known-models.js +1 -0
- package/dist/core/model/switcher.d.ts +80 -0
- package/dist/core/model/switcher.js +1 -0
- package/dist/core/model-registry.d.ts +186 -0
- package/dist/core/model-registry.js +9 -0
- package/dist/core/model-resolver.d.ts +106 -0
- package/dist/core/model-resolver.js +1 -0
- package/dist/core/package-manager.d.ts +156 -0
- package/dist/core/package-manager.js +3 -0
- package/dist/core/persona/persona-manager.d.ts +35 -0
- package/dist/core/persona/persona-manager.js +5 -0
- package/dist/core/platform/abort-slot.d.ts +26 -0
- package/dist/core/platform/abort-slot.js +1 -0
- package/dist/core/platform/config/auth-storage.d.ts +126 -0
- package/dist/core/platform/config/auth-storage.js +1 -0
- package/dist/core/platform/config/defaults.d.ts +8 -0
- package/dist/core/platform/config/defaults.js +1 -0
- package/dist/core/platform/config/diagnostics.d.ts +20 -0
- package/dist/core/platform/config/diagnostics.js +0 -0
- package/dist/core/platform/config/resolve-config-value.d.ts +12 -0
- package/dist/core/platform/config/resolve-config-value.js +1 -0
- package/dist/core/platform/config/resource-loader.d.ts +188 -0
- package/dist/core/platform/config/resource-loader.js +2 -0
- package/dist/core/platform/config/settings-manager.d.ts +314 -0
- package/dist/core/platform/config/settings-manager.js +1 -0
- package/dist/core/platform/exec/bash-executor.d.ts +41 -0
- package/dist/core/platform/exec/bash-executor.js +1 -0
- package/dist/core/platform/exec/exec.d.ts +25 -0
- package/dist/core/platform/exec/exec.js +1 -0
- package/dist/core/platform/i18n/index.d.ts +26 -0
- package/dist/core/platform/i18n/index.js +1 -0
- package/dist/core/platform/i18n/messages.d.ts +56 -0
- package/dist/core/platform/i18n/messages.js +1 -0
- package/dist/core/platform/i18n/messages.zh.d.ts +56 -0
- package/dist/core/platform/i18n/messages.zh.js +1 -0
- package/dist/core/platform/i18n/slash-commands.d.ts +53 -0
- package/dist/core/platform/i18n/slash-commands.js +1 -0
- package/dist/core/platform/i18n/slash-commands.zh.d.ts +53 -0
- package/dist/core/platform/i18n/slash-commands.zh.js +1 -0
- package/dist/core/platform/i18n/themes.d.ts +11 -0
- package/dist/core/platform/i18n/themes.js +1 -0
- package/dist/core/platform/i18n/themes.zh.d.ts +11 -0
- package/dist/core/platform/i18n/themes.zh.js +1 -0
- package/dist/core/platform/keybindings.d.ts +61 -0
- package/dist/core/platform/keybindings.js +1 -0
- package/dist/core/platform/listeners.d.ts +21 -0
- package/dist/core/platform/listeners.js +1 -0
- package/dist/core/platform/telemetry/batching-dispatcher.d.ts +41 -0
- package/dist/core/platform/telemetry/batching-dispatcher.js +1 -0
- package/dist/core/platform/telemetry/build-meta.d.ts +12 -0
- package/dist/core/platform/telemetry/build-meta.js +1 -0
- package/dist/core/platform/telemetry/caller-context.d.ts +32 -0
- package/dist/core/platform/telemetry/caller-context.js +1 -0
- package/dist/core/platform/telemetry/credentials.d.ts +27 -0
- package/dist/core/platform/telemetry/credentials.js +1 -0
- package/dist/core/platform/telemetry/ext-events.d.ts +89 -0
- package/dist/core/platform/telemetry/ext-events.js +1 -0
- package/dist/core/platform/telemetry/index.d.ts +13 -0
- package/dist/core/platform/telemetry/index.js +1 -0
- package/dist/core/platform/telemetry/insforge-base.d.ts +37 -0
- package/dist/core/platform/telemetry/insforge-base.js +1 -0
- package/dist/core/platform/telemetry/types.d.ts +33 -0
- package/dist/core/platform/telemetry/types.js +0 -0
- package/dist/core/platform/timings.d.ts +2 -0
- package/dist/core/platform/timings.js +3 -0
- package/dist/core/platform/utils/logger.d.ts +75 -0
- package/dist/core/platform/utils/logger.js +1 -0
- package/dist/core/platform/utils/shell.d.ts +25 -0
- package/dist/core/platform/utils/shell.js +9 -0
- package/dist/core/platform/utils/sleep.d.ts +7 -0
- package/dist/core/platform/utils/sleep.js +1 -0
- package/dist/core/platform/utils/tools-manager.d.ts +19 -0
- package/dist/core/platform/utils/tools-manager.js +1 -0
- package/dist/core/prompt/prompt-templates.d.ts +49 -0
- package/dist/core/prompt/prompt-templates.js +2 -0
- package/dist/core/prompt/system-prompt.d.ts +24 -0
- package/dist/core/prompt/system-prompt.js +139 -0
- package/dist/core/runtime/agent-session.d.ts +676 -0
- package/dist/core/runtime/agent-session.js +15 -0
- package/dist/core/runtime/bash-runner.d.ts +56 -0
- package/dist/core/runtime/bash-runner.js +2 -0
- package/dist/core/runtime/catui-agent.d.ts +182 -0
- package/dist/core/runtime/catui-agent.js +1 -0
- package/dist/core/runtime/compaction-controller.d.ts +43 -0
- package/dist/core/runtime/compaction-controller.js +1 -0
- package/dist/core/runtime/default-tools.d.ts +9 -0
- package/dist/core/runtime/default-tools.js +1 -0
- package/dist/core/runtime/event-bridge.d.ts +21 -0
- package/dist/core/runtime/event-bridge.js +1 -0
- package/dist/core/runtime/event-bus.d.ts +8 -0
- package/dist/core/runtime/event-bus.js +1 -0
- package/dist/core/runtime/export-bridge.d.ts +23 -0
- package/dist/core/runtime/export-bridge.js +1 -0
- package/dist/core/runtime/extension-core-bindings.d.ts +46 -0
- package/dist/core/runtime/extension-core-bindings.js +3 -0
- package/dist/core/runtime/model-controller.d.ts +84 -0
- package/dist/core/runtime/model-controller.js +1 -0
- package/dist/core/runtime/model-cycle.d.ts +20 -0
- package/dist/core/runtime/model-cycle.js +1 -0
- package/dist/core/runtime/prompt-assembly.d.ts +20 -0
- package/dist/core/runtime/prompt-assembly.js +3 -0
- package/dist/core/runtime/retry-coordinator.d.ts +84 -0
- package/dist/core/runtime/retry-coordinator.js +1 -0
- package/dist/core/runtime/sdk.d.ts +163 -0
- package/dist/core/runtime/sdk.js +1 -0
- package/dist/core/runtime/session-context.d.ts +155 -0
- package/dist/core/runtime/session-context.js +0 -0
- package/dist/core/runtime/session-lifecycle-controller.d.ts +42 -0
- package/dist/core/runtime/session-lifecycle-controller.js +1 -0
- package/dist/core/runtime/session-tree-controller.d.ts +40 -0
- package/dist/core/runtime/session-tree-controller.js +1 -0
- package/dist/core/runtime/slash-command-catalog.d.ts +27 -0
- package/dist/core/runtime/slash-command-catalog.js +1 -0
- package/dist/core/runtime/thinking-levels.d.ts +31 -0
- package/dist/core/runtime/thinking-levels.js +1 -0
- package/dist/core/runtime/tool-runtime-controller.d.ts +35 -0
- package/dist/core/runtime/tool-runtime-controller.js +1 -0
- package/dist/core/runtime/turn-context.d.ts +52 -0
- package/dist/core/runtime/turn-context.js +1 -0
- package/dist/core/session/compaction/branch-summarization.d.ts +85 -0
- package/dist/core/session/compaction/branch-summarization.js +38 -0
- package/dist/core/session/compaction/compaction.d.ts +120 -0
- package/dist/core/session/compaction/compaction.js +104 -0
- package/dist/core/session/compaction/index.d.ts +9 -0
- package/dist/core/session/compaction/index.js +1 -0
- package/dist/core/session/compaction/utils.d.ts +37 -0
- package/dist/core/session/compaction/utils.js +17 -0
- package/dist/core/session/session-manager.d.ts +359 -0
- package/dist/core/session/session-manager.js +14 -0
- package/dist/core/skills.d.ts +57 -0
- package/dist/core/skills.js +4 -0
- package/dist/core/slash-commands.d.ts +36 -0
- package/dist/core/slash-commands.js +1 -0
- package/dist/core/soul-integration.d.ts +77 -0
- package/dist/core/soul-integration.js +1 -0
- package/dist/core/soul-options-contract.d.ts +10 -0
- package/dist/core/soul-options-contract.js +0 -0
- package/dist/core/sub-agent/agent-definition-loader.d.ts +96 -0
- package/dist/core/sub-agent/agent-definition-loader.js +2 -0
- package/dist/core/sub-agent/agent-definition.d.ts +162 -0
- package/dist/core/sub-agent/agent-definition.js +6 -0
- package/dist/core/sub-agent/agent-handoff-safety.d.ts +39 -0
- package/dist/core/sub-agent/agent-handoff-safety.js +1 -0
- package/dist/core/sub-agent/agent-input-output.d.ts +143 -0
- package/dist/core/sub-agent/agent-input-output.js +1 -0
- package/dist/core/sub-agent/agent-output-persistence.d.ts +43 -0
- package/dist/core/sub-agent/agent-output-persistence.js +3 -0
- package/dist/core/sub-agent/agent-prompt-builder.d.ts +37 -0
- package/dist/core/sub-agent/agent-prompt-builder.js +2 -0
- package/dist/core/sub-agent/agent-registry.d.ts +145 -0
- package/dist/core/sub-agent/agent-registry.js +1 -0
- package/dist/core/sub-agent/agent-result-extractor.d.ts +28 -0
- package/dist/core/sub-agent/agent-result-extractor.js +3 -0
- package/dist/core/sub-agent/agent-telemetry.d.ts +71 -0
- package/dist/core/sub-agent/agent-telemetry.js +1 -0
- package/dist/core/sub-agent/agent-tool-filter.d.ts +89 -0
- package/dist/core/sub-agent/agent-tool-filter.js +2 -0
- package/dist/core/sub-agent/agent-tool.d.ts +69 -0
- package/dist/core/sub-agent/agent-tool.js +11 -0
- package/dist/core/sub-agent/index.d.ts +26 -0
- package/dist/core/sub-agent/index.js +1 -0
- package/dist/core/sub-agent/send-message-tool.d.ts +33 -0
- package/dist/core/sub-agent/send-message-tool.js +2 -0
- package/dist/core/sub-agent/sub-agent-backend.d.ts +26 -0
- package/dist/core/sub-agent/sub-agent-backend.js +7 -0
- package/dist/core/sub-agent/sub-agent-runtime.d.ts +34 -0
- package/dist/core/sub-agent/sub-agent-runtime.js +1 -0
- package/dist/core/sub-agent/sub-agent-types.d.ts +138 -0
- package/dist/core/sub-agent/sub-agent-types.js +0 -0
- package/dist/core/sub-agent/subprocess-backend.d.ts +35 -0
- package/dist/core/sub-agent/subprocess-backend.js +1 -0
- package/dist/core/sub-agent/subprocess-worker.d.ts +12 -0
- package/dist/core/sub-agent/subprocess-worker.js +1 -0
- package/dist/core/theme-contract.d.ts +32 -0
- package/dist/core/theme-contract.js +0 -0
- package/dist/core/tools/bash.d.ts +73 -0
- package/dist/core/tools/bash.js +21 -0
- package/dist/core/tools/edit-diff.d.ts +58 -0
- package/dist/core/tools/edit-diff.js +16 -0
- package/dist/core/tools/edit.d.ts +46 -0
- package/dist/core/tools/edit.js +1 -0
- package/dist/core/tools/file-state-cache.d.ts +30 -0
- package/dist/core/tools/file-state-cache.js +1 -0
- package/dist/core/tools/find.d.ts +46 -0
- package/dist/core/tools/find.js +8 -0
- package/dist/core/tools/grep.d.ts +58 -0
- package/dist/core/tools/grep.js +13 -0
- package/dist/core/tools/index.d.ts +116 -0
- package/dist/core/tools/index.js +1 -0
- package/dist/core/tools/input-validation.d.ts +13 -0
- package/dist/core/tools/input-validation.js +1 -0
- package/dist/core/tools/ls.d.ts +45 -0
- package/dist/core/tools/ls.js +4 -0
- package/dist/core/tools/orchestrator.d.ts +76 -0
- package/dist/core/tools/orchestrator.js +1 -0
- package/dist/core/tools/path-utils.d.ts +7 -0
- package/dist/core/tools/path-utils.js +1 -0
- package/dist/core/tools/pdf-extract.d.ts +11 -0
- package/dist/core/tools/pdf-extract.js +1 -0
- package/dist/core/tools/read.d.ts +46 -0
- package/dist/core/tools/read.js +11 -0
- package/dist/core/tools/source.d.ts +78 -0
- package/dist/core/tools/source.js +1 -0
- package/dist/core/tools/time.d.ts +19 -0
- package/dist/core/tools/time.js +2 -0
- package/dist/core/tools/truncate.d.ts +66 -0
- package/dist/core/tools/truncate.js +5 -0
- package/dist/core/tools/write-guard.d.ts +2 -0
- package/dist/core/tools/write-guard.js +1 -0
- package/dist/core/tools/write.d.ts +36 -0
- package/dist/core/tools/write.js +1 -0
- package/dist/core/workspace/index.d.ts +8 -0
- package/dist/core/workspace/index.js +1 -0
- package/dist/core/workspace/worktree-manager.d.ts +73 -0
- package/dist/core/workspace/worktree-manager.js +3 -0
- package/dist/extensions/builtin/AGENT.md +115 -0
- package/dist/extensions/builtin/ask-user-question/ask-user-question-tool.d.ts +9 -0
- package/dist/extensions/builtin/ask-user-question/ask-user-question-tool.js +4 -0
- package/dist/extensions/builtin/ask-user-question/index.d.ts +8 -0
- package/dist/extensions/builtin/ask-user-question/index.js +1 -0
- package/dist/extensions/builtin/ask-user-question/prompt.d.ts +14 -0
- package/dist/extensions/builtin/ask-user-question/prompt.js +30 -0
- package/dist/extensions/builtin/ask-user-question/types.d.ts +69 -0
- package/dist/extensions/builtin/ask-user-question/types.js +1 -0
- package/dist/extensions/builtin/browser/AGENT.md +17 -0
- package/dist/extensions/builtin/browser/agent-workspace/agent_helpers.py +12 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/amazon/product-search.md +198 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/archive-org/scraping.md +341 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/arxiv/scraping.md +311 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/arxiv-bulk/scraping.md +333 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/atlas/overview.md +70 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/booking-com/scraping.md +578 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/capterra/scraping.md +440 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/centilebrain/generate-estimates.md +110 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coingecko/scraping.md +325 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coinmarketcap/scraping.md +463 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coursera/scraping.md +360 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/craigslist/scraping.md +390 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/crossref/scraping.md +568 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/dev-to/scraping.md +323 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/duckduckgo/scraping.md +349 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/ebay/scraping.md +435 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/etsy/scraping.md +506 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/eventbrite/scraping.md +363 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/expedia/automation.md +168 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/facebook/groups.md +236 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/facebook/pages.md +295 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/framer/editor.md +108 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/fred/scraping.md +493 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/g2/scraping.md +580 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/genius/scraping.md +511 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/github/repo-actions.md +65 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/github/scraping.md +184 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/glassdoor/scraping.md +543 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/gmail/compose.md +122 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/goodreads/scraping.md +461 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/gutenberg/scraping.md +383 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/hackernews/scraping.md +243 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/howlongtobeat/scraping.md +473 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/imdb/scraping.md +271 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/itch-io/scraping.md +436 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/job-boards/indeed-glassdoor.md +1021 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/letterboxd/scraping.md +349 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/linkedin/invitation-manager.md +109 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/loom/folder-enumeration.md +170 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/macrotrends/scraping.md +537 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/medium/article-hydration.md +120 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/medium/scraping.md +414 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/metacritic/scraping.md +477 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/musicbrainz/scraping.md +478 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/nasa/scraping.md +339 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/news-aggregation/multi-source.md +205 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/open-library/scraping.md +472 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/openalex/scraping.md +470 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/openstreetmap/scraping.md +490 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/package-registries/npm-pypi.md +478 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/polymarket/scraping.md +234 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/producthunt/scraping.md +307 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/pubmed/scraping.md +421 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/quora/scraping.md +364 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/rawg/scraping.md +352 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/reddit/scraping.md +124 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/rest-countries/scraping.md +233 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/sec-edgar/scraping.md +361 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/README.md +36 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/embedded-apps.md +72 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/knowledge-base.md +109 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/polaris-inputs.md +137 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/soundcloud/scraping.md +362 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/spotify/scraping.md +339 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/stackoverflow/scraping.md +435 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/steam/scraping.md +575 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/substack/scraping.md +338 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/thetechgeeks/pricing.md +52 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/tiktok/upload.md +107 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/tradingview/scraping.md +309 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/trello/boards-and-lists.md +88 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/trustpilot/scraping.md +375 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/walmart/scraping.md +444 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/wayback-machine/scraping.md +306 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/weather/scraping.md +398 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/wellfound/scraping.md +596 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/world-bank/scraping.md +356 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/xiaohongshu/scraping.md +84 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/youtube/scraping.md +418 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/zillow/scraping.md +433 -0
- package/dist/extensions/builtin/browser/browser.md +73 -0
- package/dist/extensions/builtin/browser/index.d.ts +8 -0
- package/dist/extensions/builtin/browser/index.js +15 -0
- package/dist/extensions/builtin/browser/install.md +142 -0
- package/dist/extensions/builtin/browser/interaction-skills/connection.md +48 -0
- package/dist/extensions/builtin/browser/interaction-skills/cookies.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/cross-origin-iframes.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/dialogs.md +64 -0
- package/dist/extensions/builtin/browser/interaction-skills/downloads.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/drag-and-drop.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/dropdowns.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/iframes.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/network-requests.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/print-as-pdf.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/profile-sync.md +90 -0
- package/dist/extensions/builtin/browser/interaction-skills/screenshots.md +17 -0
- package/dist/extensions/builtin/browser/interaction-skills/scrolling.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/shadow-dom.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/tabs.md +69 -0
- package/dist/extensions/builtin/browser/interaction-skills/uploads.md +1 -0
- package/dist/extensions/builtin/browser/interaction-skills/viewport.md +3 -0
- package/dist/extensions/builtin/browser/src/browser_harness/AGENT.md +15 -0
- package/dist/extensions/builtin/browser/src/browser_harness/__init__.py +8 -0
- package/dist/extensions/builtin/browser/src/browser_harness/_ipc.py +90 -0
- package/dist/extensions/builtin/browser/src/browser_harness/admin.py +722 -0
- package/dist/extensions/builtin/browser/src/browser_harness/daemon.py +328 -0
- package/dist/extensions/builtin/browser/src/browser_harness/helpers.py +396 -0
- package/dist/extensions/builtin/browser/src/browser_harness/run.py +103 -0
- package/dist/extensions/builtin/btw/index.d.ts +8 -0
- package/dist/extensions/builtin/btw/index.js +15 -0
- package/dist/extensions/builtin/debug/collectors.d.ts +96 -0
- package/dist/extensions/builtin/debug/collectors.js +7 -0
- package/dist/extensions/builtin/debug/index.d.ts +8 -0
- package/dist/extensions/builtin/debug/index.js +49 -0
- package/dist/extensions/builtin/diagnostics/diagnostic-buffer.d.ts +19 -0
- package/dist/extensions/builtin/diagnostics/diagnostic-buffer.js +1 -0
- package/dist/extensions/builtin/diagnostics/index.d.ts +8 -0
- package/dist/extensions/builtin/diagnostics/index.js +1 -0
- package/dist/extensions/builtin/diagnostics/redaction.d.ts +8 -0
- package/dist/extensions/builtin/diagnostics/redaction.js +1 -0
- package/dist/extensions/builtin/diagnostics/reporter.d.ts +17 -0
- package/dist/extensions/builtin/diagnostics/reporter.js +1 -0
- package/dist/extensions/builtin/diagnostics/types.d.ts +62 -0
- package/dist/extensions/builtin/diagnostics/types.js +1 -0
- package/dist/extensions/builtin/discipline/index.d.ts +8 -0
- package/dist/extensions/builtin/discipline/index.js +7 -0
- package/dist/extensions/builtin/discipline/skills/brainstorming/SKILL.md +33 -0
- package/dist/extensions/builtin/discipline/skills/executing-plans/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/finishing-development-branch/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/receiving-code-review/SKILL.md +22 -0
- package/dist/extensions/builtin/discipline/skills/requesting-code-review/SKILL.md +31 -0
- package/dist/extensions/builtin/discipline/skills/systematic-debugging/SKILL.md +28 -0
- package/dist/extensions/builtin/discipline/skills/test-driven-development/SKILL.md +32 -0
- package/dist/extensions/builtin/discipline/skills/using-git-worktrees/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/verification-before-completion/SKILL.md +27 -0
- package/dist/extensions/builtin/discipline/skills/writing-plans/SKILL.md +26 -0
- package/dist/extensions/builtin/goal/README.md +67 -0
- package/dist/extensions/builtin/goal/goal-command.d.ts +13 -0
- package/dist/extensions/builtin/goal/goal-command.js +9 -0
- package/dist/extensions/builtin/goal/goal-controller.d.ts +143 -0
- package/dist/extensions/builtin/goal/goal-controller.js +1 -0
- package/dist/extensions/builtin/goal/goal-format.d.ts +52 -0
- package/dist/extensions/builtin/goal/goal-format.js +1 -0
- package/dist/extensions/builtin/goal/goal-parser.d.ts +27 -0
- package/dist/extensions/builtin/goal/goal-parser.js +2 -0
- package/dist/extensions/builtin/goal/goal-prompts.d.ts +15 -0
- package/dist/extensions/builtin/goal/goal-prompts.js +5 -0
- package/dist/extensions/builtin/goal/goal-store.d.ts +28 -0
- package/dist/extensions/builtin/goal/goal-store.js +1 -0
- package/dist/extensions/builtin/goal/goal-tools.d.ts +26 -0
- package/dist/extensions/builtin/goal/goal-tools.js +3 -0
- package/dist/extensions/builtin/goal/goal-types.d.ts +87 -0
- package/dist/extensions/builtin/goal/goal-types.js +1 -0
- package/dist/extensions/builtin/goal/index.d.ts +8 -0
- package/dist/extensions/builtin/goal/index.js +10 -0
- package/dist/extensions/builtin/grub/README.md +112 -0
- package/dist/extensions/builtin/grub/grub-controller.d.ts +67 -0
- package/dist/extensions/builtin/grub/grub-controller.js +1 -0
- package/dist/extensions/builtin/grub/grub-decision.d.ts +8 -0
- package/dist/extensions/builtin/grub/grub-decision.js +1 -0
- package/dist/extensions/builtin/grub/grub-feature-list.d.ts +54 -0
- package/dist/extensions/builtin/grub/grub-feature-list.js +2 -0
- package/dist/extensions/builtin/grub/grub-format.d.ts +13 -0
- package/dist/extensions/builtin/grub/grub-format.js +4 -0
- package/dist/extensions/builtin/grub/grub-harness.d.ts +9 -0
- package/dist/extensions/builtin/grub/grub-harness.js +3 -0
- package/dist/extensions/builtin/grub/grub-i18n.d.ts +166 -0
- package/dist/extensions/builtin/grub/grub-i18n.js +1 -0
- package/dist/extensions/builtin/grub/grub-parser.d.ts +24 -0
- package/dist/extensions/builtin/grub/grub-parser.js +2 -0
- package/dist/extensions/builtin/grub/grub-persistence.d.ts +17 -0
- package/dist/extensions/builtin/grub/grub-persistence.js +2 -0
- package/dist/extensions/builtin/grub/grub-prompts.d.ts +12 -0
- package/dist/extensions/builtin/grub/grub-prompts.js +97 -0
- package/dist/extensions/builtin/grub/grub-turn.d.ts +16 -0
- package/dist/extensions/builtin/grub/grub-turn.js +1 -0
- package/dist/extensions/builtin/grub/grub-types.d.ts +110 -0
- package/dist/extensions/builtin/grub/grub-types.js +1 -0
- package/dist/extensions/builtin/grub/index.d.ts +8 -0
- package/dist/extensions/builtin/grub/index.js +6 -0
- package/dist/extensions/builtin/idle-think/curiosity.d.ts +46 -0
- package/dist/extensions/builtin/idle-think/curiosity.js +2 -0
- package/dist/extensions/builtin/idle-think/idle-think-runtime.d.ts +46 -0
- package/dist/extensions/builtin/idle-think/idle-think-runtime.js +1 -0
- package/dist/extensions/builtin/idle-think/index.d.ts +15 -0
- package/dist/extensions/builtin/idle-think/index.js +1 -0
- package/dist/extensions/builtin/idle-think/insights.d.ts +27 -0
- package/dist/extensions/builtin/idle-think/insights.js +5 -0
- package/dist/extensions/builtin/idle-think/thinker.d.ts +26 -0
- package/dist/extensions/builtin/idle-think/thinker.js +9 -0
- package/dist/extensions/builtin/insights/html-report.d.ts +21 -0
- package/dist/extensions/builtin/insights/html-report.js +463 -0
- package/dist/extensions/builtin/insights/index.d.ts +24 -0
- package/dist/extensions/builtin/insights/index.js +2 -0
- package/dist/extensions/builtin/insights/insights-engine.d.ts +18 -0
- package/dist/extensions/builtin/insights/insights-engine.js +39 -0
- package/dist/extensions/builtin/insights/prompts.d.ts +17 -0
- package/dist/extensions/builtin/insights/prompts.js +180 -0
- package/dist/extensions/builtin/insights/session-scanner.d.ts +27 -0
- package/dist/extensions/builtin/insights/session-scanner.js +19 -0
- package/dist/extensions/builtin/insights/stats.d.ts +13 -0
- package/dist/extensions/builtin/insights/stats.js +1 -0
- package/dist/extensions/builtin/insights/types.d.ts +199 -0
- package/dist/extensions/builtin/insights/types.js +0 -0
- package/dist/extensions/builtin/link-world/agent-workspace/README.md +16 -0
- package/dist/extensions/builtin/link-world/index.d.ts +8 -0
- package/dist/extensions/builtin/link-world/index.js +19 -0
- package/dist/extensions/builtin/link-world/internet-search/internet-search.md +65 -0
- package/dist/extensions/builtin/link-world/link-world-agent.md +82 -0
- package/dist/extensions/builtin/link-world/linkworld.md +313 -0
- package/dist/extensions/builtin/link-world/network-routing/network-routing.md +67 -0
- package/dist/extensions/builtin/loop/README.md +92 -0
- package/dist/extensions/builtin/loop/cron/cron-parser.d.ts +56 -0
- package/dist/extensions/builtin/loop/cron/cron-parser.js +1 -0
- package/dist/extensions/builtin/loop/cron/cron-scheduler.d.ts +85 -0
- package/dist/extensions/builtin/loop/cron/cron-scheduler.js +10 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks-lock.d.ts +42 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks-lock.js +1 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks.d.ts +200 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks.js +2 -0
- package/dist/extensions/builtin/loop/cron/index.d.ts +18 -0
- package/dist/extensions/builtin/loop/cron/index.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-create-tool.d.ts +35 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-create-tool.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-delete-tool.d.ts +29 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-delete-tool.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-list-tool.d.ts +25 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-list-tool.js +2 -0
- package/dist/extensions/builtin/loop/cron-tools/index.d.ts +16 -0
- package/dist/extensions/builtin/loop/cron-tools/index.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/prompt.d.ts +35 -0
- package/dist/extensions/builtin/loop/cron-tools/prompt.js +38 -0
- package/dist/extensions/builtin/loop/index.d.ts +19 -0
- package/dist/extensions/builtin/loop/index.js +2 -0
- package/dist/extensions/builtin/loop/loop-skill.d.ts +18 -0
- package/dist/extensions/builtin/loop/loop-skill.js +58 -0
- package/dist/extensions/builtin/lsp/index.d.ts +8 -0
- package/dist/extensions/builtin/lsp/index.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-client.d.ts +22 -0
- package/dist/extensions/builtin/lsp/lsp-client.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-config.d.ts +8 -0
- package/dist/extensions/builtin/lsp/lsp-config.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-formatters.d.ts +15 -0
- package/dist/extensions/builtin/lsp/lsp-formatters.js +18 -0
- package/dist/extensions/builtin/lsp/lsp-server-instance.d.ts +24 -0
- package/dist/extensions/builtin/lsp/lsp-server-instance.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-server-manager.d.ts +21 -0
- package/dist/extensions/builtin/lsp/lsp-server-manager.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-tool.d.ts +33 -0
- package/dist/extensions/builtin/lsp/lsp-tool.js +2 -0
- package/dist/extensions/builtin/lsp/types.d.ts +31 -0
- package/dist/extensions/builtin/lsp/types.js +1 -0
- package/dist/extensions/builtin/mcp/figma-design.md +68 -0
- package/dist/extensions/builtin/mcp/index.d.ts +14 -0
- package/dist/extensions/builtin/mcp/index.js +25 -0
- package/dist/extensions/builtin/mcp/mcp-management.md +85 -0
- package/dist/extensions/builtin/plan/clear-context-state.d.ts +8 -0
- package/dist/extensions/builtin/plan/clear-context-state.js +1 -0
- package/dist/extensions/builtin/plan/enter-plan-mode-tool.d.ts +11 -0
- package/dist/extensions/builtin/plan/enter-plan-mode-tool.js +2 -0
- package/dist/extensions/builtin/plan/exit-plan-mode-tool.d.ts +18 -0
- package/dist/extensions/builtin/plan/exit-plan-mode-tool.js +13 -0
- package/dist/extensions/builtin/plan/index.d.ts +8 -0
- package/dist/extensions/builtin/plan/index.js +24 -0
- package/dist/extensions/builtin/plan/plan-agents.d.ts +23 -0
- package/dist/extensions/builtin/plan/plan-agents.js +43 -0
- package/dist/extensions/builtin/plan/plan-file-manager.d.ts +26 -0
- package/dist/extensions/builtin/plan/plan-file-manager.js +1 -0
- package/dist/extensions/builtin/plan/plan-permissions.d.ts +15 -0
- package/dist/extensions/builtin/plan/plan-permissions.js +12 -0
- package/dist/extensions/builtin/plan/plan-validation.d.ts +18 -0
- package/dist/extensions/builtin/plan/plan-validation.js +5 -0
- package/dist/extensions/builtin/plan/plan-workflow-prompt.d.ts +18 -0
- package/dist/extensions/builtin/plan/plan-workflow-prompt.js +102 -0
- package/dist/extensions/builtin/plan/teammate-approval.d.ts +49 -0
- package/dist/extensions/builtin/plan/teammate-approval.js +3 -0
- package/dist/extensions/builtin/plan/types.d.ts +133 -0
- package/dist/extensions/builtin/plan/types.js +1 -0
- package/dist/extensions/builtin/presence/index.d.ts +40 -0
- package/dist/extensions/builtin/presence/index.js +15 -0
- package/dist/extensions/builtin/presence/presence-memory.d.ts +47 -0
- package/dist/extensions/builtin/presence/presence-memory.js +1 -0
- package/dist/extensions/builtin/recap/AGENT.md +15 -0
- package/dist/extensions/builtin/recap/index.d.ts +8 -0
- package/dist/extensions/builtin/recap/index.js +1 -0
- package/dist/extensions/builtin/recap/recap-budget.d.ts +24 -0
- package/dist/extensions/builtin/recap/recap-budget.js +1 -0
- package/dist/extensions/builtin/recap/recap-extractor.d.ts +34 -0
- package/dist/extensions/builtin/recap/recap-extractor.js +3 -0
- package/dist/extensions/builtin/recap/recap-renderer.d.ts +19 -0
- package/dist/extensions/builtin/recap/recap-renderer.js +2 -0
- package/dist/extensions/builtin/recap/recap-synthesizer.d.ts +51 -0
- package/dist/extensions/builtin/recap/recap-synthesizer.js +19 -0
- package/dist/extensions/builtin/recap/recap-types.d.ts +40 -0
- package/dist/extensions/builtin/recap/recap-types.js +1 -0
- package/dist/extensions/builtin/sal/README.md +72 -0
- package/dist/extensions/builtin/sal/anchors.d.ts +46 -0
- package/dist/extensions/builtin/sal/anchors.js +1 -0
- package/dist/extensions/builtin/sal/eval/index.d.ts +18 -0
- package/dist/extensions/builtin/sal/eval/index.js +1 -0
- package/dist/extensions/builtin/sal/eval/insforge-sink.d.ts +30 -0
- package/dist/extensions/builtin/sal/eval/insforge-sink.js +1 -0
- package/dist/extensions/builtin/sal/eval/jsonl-sink.d.ts +27 -0
- package/dist/extensions/builtin/sal/eval/jsonl-sink.js +3 -0
- package/dist/extensions/builtin/sal/eval/noop-sink.d.ts +8 -0
- package/dist/extensions/builtin/sal/eval/noop-sink.js +1 -0
- package/dist/extensions/builtin/sal/eval/types.d.ts +60 -0
- package/dist/extensions/builtin/sal/eval/types.js +1 -0
- package/dist/extensions/builtin/sal/index.d.ts +12 -0
- package/dist/extensions/builtin/sal/index.js +7 -0
- package/dist/extensions/builtin/sal/sal-config.d.ts +46 -0
- package/dist/extensions/builtin/sal/sal-config.js +1 -0
- package/dist/extensions/builtin/sal/sal-context.d.ts +11 -0
- package/dist/extensions/builtin/sal/sal-context.js +2 -0
- package/dist/extensions/builtin/sal/sal-runtime.d.ts +72 -0
- package/dist/extensions/builtin/sal/sal-runtime.js +0 -0
- package/dist/extensions/builtin/sal/sal-trace.d.ts +11 -0
- package/dist/extensions/builtin/sal/sal-trace.js +1 -0
- package/dist/extensions/builtin/sal/terrain.d.ts +73 -0
- package/dist/extensions/builtin/sal/terrain.js +3 -0
- package/dist/extensions/builtin/sal/weights.d.ts +28 -0
- package/dist/extensions/builtin/sal/weights.js +1 -0
- package/dist/extensions/builtin/security-audit/README.md +289 -0
- package/dist/extensions/builtin/security-audit/engine/detector.d.ts +44 -0
- package/dist/extensions/builtin/security-audit/engine/detector.js +1 -0
- package/dist/extensions/builtin/security-audit/engine/interceptor.d.ts +61 -0
- package/dist/extensions/builtin/security-audit/engine/interceptor.js +27 -0
- package/dist/extensions/builtin/security-audit/engine/logger.d.ts +65 -0
- package/dist/extensions/builtin/security-audit/engine/logger.js +65 -0
- package/dist/extensions/builtin/security-audit/index.d.ts +13 -0
- package/dist/extensions/builtin/security-audit/index.js +49 -0
- package/dist/extensions/builtin/security-audit/interface.d.ts +167 -0
- package/dist/extensions/builtin/security-audit/interface.js +1 -0
- package/dist/extensions/builtin/soul/index.d.ts +13 -0
- package/dist/extensions/builtin/soul/index.js +1 -0
- package/dist/extensions/builtin/subagent/index.d.ts +8 -0
- package/dist/extensions/builtin/subagent/index.js +8 -0
- package/dist/extensions/builtin/subagent/subagent-parser.d.ts +30 -0
- package/dist/extensions/builtin/subagent/subagent-parser.js +15 -0
- package/dist/extensions/builtin/subagent/subagent-runner.d.ts +49 -0
- package/dist/extensions/builtin/subagent/subagent-runner.js +8 -0
- package/dist/extensions/builtin/subagent/subagent-types.d.ts +57 -0
- package/dist/extensions/builtin/subagent/subagent-types.js +0 -0
- package/dist/extensions/builtin/task/index.d.ts +8 -0
- package/dist/extensions/builtin/task/index.js +1 -0
- package/dist/extensions/builtin/task/task-store.d.ts +42 -0
- package/dist/extensions/builtin/task/task-store.js +1 -0
- package/dist/extensions/builtin/task/task-tools/task-create-tool.d.ts +37 -0
- package/dist/extensions/builtin/task/task-tools/task-create-tool.js +40 -0
- package/dist/extensions/builtin/task/task-tools/task-get-tool.d.ts +31 -0
- package/dist/extensions/builtin/task/task-tools/task-get-tool.js +23 -0
- package/dist/extensions/builtin/task/task-tools/task-list-tool.d.ts +27 -0
- package/dist/extensions/builtin/task/task-tools/task-list-tool.js +22 -0
- package/dist/extensions/builtin/task/task-tools/task-output-tool.d.ts +32 -0
- package/dist/extensions/builtin/task/task-tools/task-output-tool.js +10 -0
- package/dist/extensions/builtin/task/task-tools/task-stop-tool.d.ts +31 -0
- package/dist/extensions/builtin/task/task-tools/task-stop-tool.js +5 -0
- package/dist/extensions/builtin/task/task-tools/task-update-tool.d.ts +47 -0
- package/dist/extensions/builtin/task/task-tools/task-update-tool.js +77 -0
- package/dist/extensions/builtin/task/task-tools/tool-search-tool.d.ts +34 -0
- package/dist/extensions/builtin/task/task-tools/tool-search-tool.js +14 -0
- package/dist/extensions/builtin/task/task-types.d.ts +30 -0
- package/dist/extensions/builtin/task/task-types.js +1 -0
- package/dist/extensions/builtin/teach/README.md +197 -0
- package/dist/extensions/builtin/teach/index.d.ts +12 -0
- package/dist/extensions/builtin/teach/index.js +6 -0
- package/dist/extensions/builtin/teach/references/analogy-library.md +153 -0
- package/dist/extensions/builtin/teach/references/learning-paths.md +214 -0
- package/dist/extensions/builtin/teach/references/source-verification.md +268 -0
- package/dist/extensions/builtin/teach/references/teaching-template.md +237 -0
- package/dist/extensions/builtin/teach/teach-format.d.ts +35 -0
- package/dist/extensions/builtin/teach/teach-format.js +6 -0
- package/dist/extensions/builtin/teach/teach-i18n.d.ts +47 -0
- package/dist/extensions/builtin/teach/teach-i18n.js +1 -0
- package/dist/extensions/builtin/teach/teach-persistence.d.ts +36 -0
- package/dist/extensions/builtin/teach/teach-persistence.js +35 -0
- package/dist/extensions/builtin/teach/teach-prompts.d.ts +52 -0
- package/dist/extensions/builtin/teach/teach-prompts.js +35 -0
- package/dist/extensions/builtin/teach/teach-runtime.d.ts +93 -0
- package/dist/extensions/builtin/teach/teach-runtime.js +9 -0
- package/dist/extensions/builtin/teach/teach-types.d.ts +81 -0
- package/dist/extensions/builtin/teach/teach-types.js +0 -0
- package/dist/extensions/builtin/team/AGENT.md +112 -0
- package/dist/extensions/builtin/team/TESTING.md +299 -0
- package/dist/extensions/builtin/team/index.d.ts +26 -0
- package/dist/extensions/builtin/team/index.js +11 -0
- package/dist/extensions/builtin/team/team-dashboard.d.ts +13 -0
- package/dist/extensions/builtin/team/team-dashboard.js +1 -0
- package/dist/extensions/builtin/team/team-harness.d.ts +35 -0
- package/dist/extensions/builtin/team/team-harness.js +18 -0
- package/dist/extensions/builtin/team/team-mailbox.d.ts +50 -0
- package/dist/extensions/builtin/team/team-mailbox.js +4 -0
- package/dist/extensions/builtin/team/team-orchestrator.d.ts +39 -0
- package/dist/extensions/builtin/team/team-orchestrator.js +5 -0
- package/dist/extensions/builtin/team/team-parser.d.ts +84 -0
- package/dist/extensions/builtin/team/team-parser.js +38 -0
- package/dist/extensions/builtin/team/team-permissions.d.ts +63 -0
- package/dist/extensions/builtin/team/team-permissions.js +1 -0
- package/dist/extensions/builtin/team/team-presets.d.ts +45 -0
- package/dist/extensions/builtin/team/team-presets.js +2 -0
- package/dist/extensions/builtin/team/team-psyche.d.ts +14 -0
- package/dist/extensions/builtin/team/team-psyche.js +5 -0
- package/dist/extensions/builtin/team/team-runtime-helpers.d.ts +48 -0
- package/dist/extensions/builtin/team/team-runtime-helpers.js +2 -0
- package/dist/extensions/builtin/team/team-runtime.d.ts +91 -0
- package/dist/extensions/builtin/team/team-runtime.js +3 -0
- package/dist/extensions/builtin/team/team-state-store.d.ts +29 -0
- package/dist/extensions/builtin/team/team-state-store.js +2 -0
- package/dist/extensions/builtin/team/team-task-store.d.ts +35 -0
- package/dist/extensions/builtin/team/team-task-store.js +2 -0
- package/dist/extensions/builtin/team/team-transcript.d.ts +31 -0
- package/dist/extensions/builtin/team/team-transcript.js +2 -0
- package/dist/extensions/builtin/team/team-types.d.ts +250 -0
- package/dist/extensions/builtin/team/team-types.js +0 -0
- package/dist/extensions/builtin/team/team-ui.d.ts +50 -0
- package/dist/extensions/builtin/team/team-ui.js +2 -0
- package/dist/extensions/builtin/token-save/README.md +56 -0
- package/dist/extensions/builtin/token-save/config.d.ts +8 -0
- package/dist/extensions/builtin/token-save/config.js +1 -0
- package/dist/extensions/builtin/token-save/filters.d.ts +14 -0
- package/dist/extensions/builtin/token-save/filters.js +24 -0
- package/dist/extensions/builtin/token-save/index.d.ts +8 -0
- package/dist/extensions/builtin/token-save/index.js +4 -0
- package/dist/extensions/builtin/token-save/lexer.d.ts +11 -0
- package/dist/extensions/builtin/token-save/lexer.js +1 -0
- package/dist/extensions/builtin/token-save/recovery.d.ts +1 -0
- package/dist/extensions/builtin/token-save/recovery.js +1 -0
- package/dist/extensions/builtin/token-save/rewrite.d.ts +19 -0
- package/dist/extensions/builtin/token-save/rewrite.js +1 -0
- package/dist/extensions/builtin/token-save/runner.d.ts +14 -0
- package/dist/extensions/builtin/token-save/runner.js +3 -0
- package/dist/extensions/builtin/token-save/stream.d.ts +20 -0
- package/dist/extensions/builtin/token-save/stream.js +1 -0
- package/dist/extensions/builtin/token-save/toml-dsl.d.ts +25 -0
- package/dist/extensions/builtin/token-save/toml-dsl.js +3 -0
- package/dist/extensions/builtin/token-save/tracking.d.ts +24 -0
- package/dist/extensions/builtin/token-save/tracking.js +8 -0
- package/dist/extensions/optional/AGENT.md +11 -0
- package/dist/extensions/optional/export-html/index.d.ts +41 -0
- package/dist/extensions/optional/export-html/index.js +2 -0
- package/dist/extensions/optional/simplify/index.d.ts +35 -0
- package/dist/extensions/optional/simplify/index.js +77 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.js +1 -0
- package/dist/main.d.ts +7 -0
- package/dist/main.js +41 -0
- package/dist/migrations.d.ts +30 -0
- package/dist/migrations.js +4 -0
- package/dist/models.d.ts +7 -0
- package/dist/models.js +1 -0
- package/dist/modes/acp/acp-mode.d.ts +30 -0
- package/dist/modes/acp/acp-mode.js +25 -0
- package/dist/modes/index.d.ts +14 -0
- package/dist/modes/index.js +1 -0
- package/dist/modes/interactive/agent-loop-status.d.ts +8 -0
- package/dist/modes/interactive/agent-loop-status.js +1 -0
- package/dist/modes/interactive/components/apikey-input.d.ts +10 -0
- package/dist/modes/interactive/components/apikey-input.js +3 -0
- package/dist/modes/interactive/components/armin.d.ts +39 -0
- package/dist/modes/interactive/components/armin.js +1 -0
- package/dist/modes/interactive/components/assistant-message.d.ts +21 -0
- package/dist/modes/interactive/components/assistant-message.js +1 -0
- package/dist/modes/interactive/components/attachments-bar.d.ts +37 -0
- package/dist/modes/interactive/components/attachments-bar.js +1 -0
- package/dist/modes/interactive/components/bash-execution.d.ts +40 -0
- package/dist/modes/interactive/components/bash-execution.js +13 -0
- package/dist/modes/interactive/components/bordered-loader.d.ts +21 -0
- package/dist/modes/interactive/components/bordered-loader.js +1 -0
- package/dist/modes/interactive/components/branch-summary-message.d.ts +21 -0
- package/dist/modes/interactive/components/branch-summary-message.js +3 -0
- package/dist/modes/interactive/components/buddy/pet-sprites.d.ts +31 -0
- package/dist/modes/interactive/components/buddy/pet-sprites.js +1 -0
- package/dist/modes/interactive/components/catui-loader.d.ts +55 -0
- package/dist/modes/interactive/components/catui-loader.js +1 -0
- package/dist/modes/interactive/components/compaction-summary-message.d.ts +21 -0
- package/dist/modes/interactive/components/compaction-summary-message.js +3 -0
- package/dist/modes/interactive/components/config-selector.d.ts +76 -0
- package/dist/modes/interactive/components/config-selector.js +1 -0
- package/dist/modes/interactive/components/countdown-timer.d.ts +19 -0
- package/dist/modes/interactive/components/countdown-timer.js +1 -0
- package/dist/modes/interactive/components/custom-editor.d.ts +37 -0
- package/dist/modes/interactive/components/custom-editor.js +1 -0
- package/dist/modes/interactive/components/custom-message.d.ts +26 -0
- package/dist/modes/interactive/components/custom-message.js +2 -0
- package/dist/modes/interactive/components/daxnuts.d.ts +28 -0
- package/dist/modes/interactive/components/daxnuts.js +1 -0
- package/dist/modes/interactive/components/diff.d.ts +17 -0
- package/dist/modes/interactive/components/diff.js +3 -0
- package/dist/modes/interactive/components/dynamic-border.d.ts +20 -0
- package/dist/modes/interactive/components/dynamic-border.js +1 -0
- package/dist/modes/interactive/components/editor-buddy-layout.d.ts +17 -0
- package/dist/modes/interactive/components/editor-buddy-layout.js +1 -0
- package/dist/modes/interactive/components/extension-editor.d.ts +25 -0
- package/dist/modes/interactive/components/extension-editor.js +1 -0
- package/dist/modes/interactive/components/extension-input.d.ts +29 -0
- package/dist/modes/interactive/components/extension-input.js +2 -0
- package/dist/modes/interactive/components/extension-selector.d.ts +32 -0
- package/dist/modes/interactive/components/extension-selector.js +2 -0
- package/dist/modes/interactive/components/footer.d.ts +34 -0
- package/dist/modes/interactive/components/footer.js +1 -0
- package/dist/modes/interactive/components/index.d.ts +44 -0
- package/dist/modes/interactive/components/index.js +1 -0
- package/dist/modes/interactive/components/keybinding-hints.d.ts +46 -0
- package/dist/modes/interactive/components/keybinding-hints.js +1 -0
- package/dist/modes/interactive/components/login-dialog.d.ts +47 -0
- package/dist/modes/interactive/components/login-dialog.js +1 -0
- package/dist/modes/interactive/components/memory-stats.d.ts +14 -0
- package/dist/modes/interactive/components/memory-stats.js +2 -0
- package/dist/modes/interactive/components/model-selector.d.ts +59 -0
- package/dist/modes/interactive/components/model-selector.js +2 -0
- package/dist/modes/interactive/components/notification-queue.d.ts +49 -0
- package/dist/modes/interactive/components/notification-queue.js +1 -0
- package/dist/modes/interactive/components/oauth-selector.d.ts +30 -0
- package/dist/modes/interactive/components/oauth-selector.js +1 -0
- package/dist/modes/interactive/components/persona-selector.d.ts +24 -0
- package/dist/modes/interactive/components/persona-selector.js +1 -0
- package/dist/modes/interactive/components/plan-progress-panel.d.ts +24 -0
- package/dist/modes/interactive/components/plan-progress-panel.js +1 -0
- package/dist/modes/interactive/components/provider-selector.d.ts +25 -0
- package/dist/modes/interactive/components/provider-selector.js +1 -0
- package/dist/modes/interactive/components/raw-text.d.ts +19 -0
- package/dist/modes/interactive/components/raw-text.js +3 -0
- package/dist/modes/interactive/components/scoped-models-selector.d.ts +54 -0
- package/dist/modes/interactive/components/scoped-models-selector.js +1 -0
- package/dist/modes/interactive/components/session-selector-search.d.ts +28 -0
- package/dist/modes/interactive/components/session-selector-search.js +1 -0
- package/dist/modes/interactive/components/session-selector.d.ts +100 -0
- package/dist/modes/interactive/components/session-selector.js +2 -0
- package/dist/modes/interactive/components/settings-selector.d.ts +77 -0
- package/dist/modes/interactive/components/settings-selector.js +1 -0
- package/dist/modes/interactive/components/show-images-selector.d.ts +15 -0
- package/dist/modes/interactive/components/show-images-selector.js +1 -0
- package/dist/modes/interactive/components/skill-invocation-message.d.ts +22 -0
- package/dist/modes/interactive/components/skill-invocation-message.js +3 -0
- package/dist/modes/interactive/components/soul-stats.d.ts +15 -0
- package/dist/modes/interactive/components/soul-stats.js +2 -0
- package/dist/modes/interactive/components/sub-agent-panel.d.ts +24 -0
- package/dist/modes/interactive/components/sub-agent-panel.js +1 -0
- package/dist/modes/interactive/components/task-status-panel.d.ts +36 -0
- package/dist/modes/interactive/components/task-status-panel.js +1 -0
- package/dist/modes/interactive/components/theme-selector.d.ts +16 -0
- package/dist/modes/interactive/components/theme-selector.js +1 -0
- package/dist/modes/interactive/components/thinking-selector.d.ts +16 -0
- package/dist/modes/interactive/components/thinking-selector.js +1 -0
- package/dist/modes/interactive/components/tool-execution.d.ts +80 -0
- package/dist/modes/interactive/components/tool-execution.js +58 -0
- package/dist/modes/interactive/components/tree-selector.d.ts +73 -0
- package/dist/modes/interactive/components/tree-selector.js +1 -0
- package/dist/modes/interactive/components/user-message-selector.d.ts +35 -0
- package/dist/modes/interactive/components/user-message-selector.js +1 -0
- package/dist/modes/interactive/components/user-message.d.ts +13 -0
- package/dist/modes/interactive/components/user-message.js +1 -0
- package/dist/modes/interactive/components/visual-truncate.d.ts +29 -0
- package/dist/modes/interactive/components/visual-truncate.js +1 -0
- package/dist/modes/interactive/controllers/auth-provider-config-controller.d.ts +64 -0
- package/dist/modes/interactive/controllers/auth-provider-config-controller.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/custom-overlay-host.d.ts +38 -0
- package/dist/modes/interactive/controllers/extension-ui/custom-overlay-host.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/editor-component-adapter.d.ts +37 -0
- package/dist/modes/interactive/controllers/extension-ui/editor-component-adapter.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/persistent-surface-registry.d.ts +53 -0
- package/dist/modes/interactive/controllers/extension-ui/persistent-surface-registry.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/prompt-host.d.ts +52 -0
- package/dist/modes/interactive/controllers/extension-ui/prompt-host.js +2 -0
- package/dist/modes/interactive/controllers/image-pipeline-controller.d.ts +106 -0
- package/dist/modes/interactive/controllers/image-pipeline-controller.js +1 -0
- package/dist/modes/interactive/controllers/input-submit-controller.d.ts +80 -0
- package/dist/modes/interactive/controllers/input-submit-controller.js +2 -0
- package/dist/modes/interactive/controllers/interrupt-controller.d.ts +75 -0
- package/dist/modes/interactive/controllers/interrupt-controller.js +1 -0
- package/dist/modes/interactive/controllers/model-overlay-controller.d.ts +127 -0
- package/dist/modes/interactive/controllers/model-overlay-controller.js +3 -0
- package/dist/modes/interactive/controllers/self-update-controller.d.ts +71 -0
- package/dist/modes/interactive/controllers/self-update-controller.js +24 -0
- package/dist/modes/interactive/controllers/settings-overlay-controller.d.ts +56 -0
- package/dist/modes/interactive/controllers/settings-overlay-controller.js +2 -0
- package/dist/modes/interactive/controllers/slash-dispatcher-controller.d.ts +74 -0
- package/dist/modes/interactive/controllers/slash-dispatcher-controller.js +1 -0
- package/dist/modes/interactive/controllers/stream-render-controller.d.ts +110 -0
- package/dist/modes/interactive/controllers/stream-render-controller.js +2 -0
- package/dist/modes/interactive/controllers/tree-overlay-controller.d.ts +55 -0
- package/dist/modes/interactive/controllers/tree-overlay-controller.js +1 -0
- package/dist/modes/interactive/footer-data-provider.d.ts +32 -0
- package/dist/modes/interactive/footer-data-provider.js +1 -0
- package/dist/modes/interactive/interactive-mode.d.ts +303 -0
- package/dist/modes/interactive/interactive-mode.js +119 -0
- package/dist/modes/interactive/services/tips.d.ts +20 -0
- package/dist/modes/interactive/services/tips.js +1 -0
- package/dist/modes/interactive/slash-command-arguments.d.ts +28 -0
- package/dist/modes/interactive/slash-command-arguments.js +1 -0
- package/dist/modes/interactive/state/interactive-state.d.ts +74 -0
- package/dist/modes/interactive/state/interactive-state.js +1 -0
- package/dist/modes/interactive/theme/dark.json +85 -0
- package/dist/modes/interactive/theme/light.json +84 -0
- package/dist/modes/interactive/theme/theme-schema.json +335 -0
- package/dist/modes/interactive/theme/theme.d.ts +81 -0
- package/dist/modes/interactive/theme/theme.js +16 -0
- package/dist/modes/interactive/theme/warm.json +81 -0
- package/dist/modes/print-mode.d.ts +38 -0
- package/dist/modes/print-mode.js +2 -0
- package/dist/modes/rpc/rpc-client.d.ts +221 -0
- package/dist/modes/rpc/rpc-client.js +2 -0
- package/dist/modes/rpc/rpc-mode.d.ts +14 -0
- package/dist/modes/rpc/rpc-mode.js +1 -0
- package/dist/modes/rpc/rpc-types.d.ts +449 -0
- package/dist/modes/rpc/rpc-types.js +0 -0
- package/dist/modes/utils/agent-loop-result-format.d.ts +10 -0
- package/dist/modes/utils/agent-loop-result-format.js +1 -0
- package/dist/modes/utils/clipboard-image.d.ts +10 -0
- package/dist/modes/utils/clipboard-image.js +1 -0
- package/dist/modes/utils/clipboard-native.d.ts +11 -0
- package/dist/modes/utils/clipboard-native.js +1 -0
- package/dist/modes/utils/clipboard.d.ts +1 -0
- package/dist/modes/utils/clipboard.js +1 -0
- package/dist/modes/utils/image-convert.d.ts +8 -0
- package/dist/modes/utils/image-convert.js +1 -0
- package/dist/modes/utils/image-resize.d.ts +41 -0
- package/dist/modes/utils/image-resize.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-continuations.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-stream-events.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-tool-results.js +3 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-tool-summaries.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop.js +4 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-run-result.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/errors.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/index.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/proxy.js +2 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-agent-loop.js +2 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-streaming-tool-executor.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-tool-orchestration.js +3 -0
- package/dist/node_modules/@catui/agent-core/dist/types.js +1 -0
- package/dist/node_modules/@catui/agent-core/package.json +28 -0
- package/dist/node_modules/@catui/ai/dist/api-registry.js +1 -0
- package/dist/node_modules/@catui/ai/dist/cli.js +21 -0
- package/dist/node_modules/@catui/ai/dist/config-path.js +1 -0
- package/dist/node_modules/@catui/ai/dist/debug-logger.js +4 -0
- package/dist/node_modules/@catui/ai/dist/env-api-keys.js +1 -0
- package/dist/node_modules/@catui/ai/dist/env.js +1 -0
- package/dist/node_modules/@catui/ai/dist/events.js +1 -0
- package/dist/node_modules/@catui/ai/dist/index.js +1 -0
- package/dist/node_modules/@catui/ai/dist/json.js +1 -0
- package/dist/node_modules/@catui/ai/dist/models.generated.js +1 -0
- package/dist/node_modules/@catui/ai/dist/models.js +1 -0
- package/dist/node_modules/@catui/ai/dist/overflow.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/amazon-bedrock.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/anthropic.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/azure-openai-responses.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/github-copilot-headers.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-gemini-cli.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-shared.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-vertex.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/google.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-codex-responses.js +7 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-completions.js +6 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-responses-shared.js +10 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-responses.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/register-builtins.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/simple-options.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/transform-messages.js +1 -0
- package/dist/node_modules/@catui/ai/dist/registry.js +1 -0
- package/dist/node_modules/@catui/ai/dist/schema.js +1 -0
- package/dist/node_modules/@catui/ai/dist/stream.js +1 -0
- package/dist/node_modules/@catui/ai/dist/types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/event-stream-types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/event-stream.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/http-proxy.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/json-parse.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/anthropic.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/decode-credential.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/github-copilot.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/google-antigravity.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/google-gemini-cli.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/index.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/openai-codex.js +11 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/pkce.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/overflow.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/sanitize-unicode.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/typebox-helpers.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/validation.js +6 -0
- package/dist/node_modules/@catui/ai/package.json +106 -0
- package/dist/node_modules/@catui/tui/dist/autocomplete.js +2 -0
- package/dist/node_modules/@catui/tui/dist/components/box.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/cached-container.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/cancellable-loader.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/editor.js +21 -0
- package/dist/node_modules/@catui/tui/dist/components/image.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/input.js +2 -0
- package/dist/node_modules/@catui/tui/dist/components/loader.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/markdown.js +7 -0
- package/dist/node_modules/@catui/tui/dist/components/select-list.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/settings-list.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/spacer.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/text.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/truncated-text.js +2 -0
- package/dist/node_modules/@catui/tui/dist/editor-component.js +0 -0
- package/dist/node_modules/@catui/tui/dist/fuzzy.js +1 -0
- package/dist/node_modules/@catui/tui/dist/index.js +1 -0
- package/dist/node_modules/@catui/tui/dist/keybindings.js +1 -0
- package/dist/node_modules/@catui/tui/dist/keys.js +5 -0
- package/dist/node_modules/@catui/tui/dist/kill-ring.js +1 -0
- package/dist/node_modules/@catui/tui/dist/stdin-buffer.js +1 -0
- package/dist/node_modules/@catui/tui/dist/terminal-image.js +1 -0
- package/dist/node_modules/@catui/tui/dist/terminal.js +1 -0
- package/dist/node_modules/@catui/tui/dist/tui.js +12 -0
- package/dist/node_modules/@catui/tui/dist/undo-stack.js +1 -0
- package/dist/node_modules/@catui/tui/dist/utils.js +2 -0
- package/dist/node_modules/@catui/tui/package.json +37 -0
- package/dist/packages/mem-core/src/store.d.ts +21 -0
- package/dist/packages/mem-core/src/store.js +1 -0
- package/dist/packages/mem-core/src/types.d.ts +329 -0
- package/dist/packages/mem-core/src/types.js +0 -0
- package/dist/packages/protocol/src/commands.d.ts +33 -0
- package/dist/packages/protocol/src/commands.js +0 -0
- package/dist/packages/protocol/src/flags.d.ts +20 -0
- package/dist/packages/protocol/src/flags.js +0 -0
- package/dist/packages/protocol/src/hooks.d.ts +17 -0
- package/dist/packages/protocol/src/hooks.js +0 -0
- package/dist/packages/protocol/src/index.d.ts +15 -0
- package/dist/packages/protocol/src/index.js +1 -0
- package/dist/packages/protocol/src/lifecycle.d.ts +61 -0
- package/dist/packages/protocol/src/lifecycle.js +0 -0
- package/dist/packages/protocol/src/tools.d.ts +77 -0
- package/dist/packages/protocol/src/tools.js +0 -0
- package/dist/packages/soul-core/src/config.d.ts +20 -0
- package/dist/packages/soul-core/src/config.js +1 -0
- package/dist/packages/soul-core/src/diagnostics.d.ts +23 -0
- package/dist/packages/soul-core/src/diagnostics.js +1 -0
- package/dist/packages/soul-core/src/evolution.d.ts +75 -0
- package/dist/packages/soul-core/src/evolution.js +1 -0
- package/dist/packages/soul-core/src/index.d.ts +13 -0
- package/dist/packages/soul-core/src/index.js +1 -0
- package/dist/packages/soul-core/src/injection.d.ts +35 -0
- package/dist/packages/soul-core/src/injection.js +8 -0
- package/dist/packages/soul-core/src/manager.d.ts +101 -0
- package/dist/packages/soul-core/src/manager.js +1 -0
- package/dist/packages/soul-core/src/store.d.ts +62 -0
- package/dist/packages/soul-core/src/store.js +1 -0
- package/dist/packages/soul-core/src/types.d.ts +317 -0
- package/dist/packages/soul-core/src/types.js +0 -0
- package/dist/public-config.d.ts +12 -0
- package/dist/public-config.js +1 -0
- package/dist/runtime.d.ts +9 -0
- package/dist/runtime.js +1 -0
- package/dist/session-compaction.d.ts +7 -0
- package/dist/session-compaction.js +1 -0
- package/dist/session.d.ts +7 -0
- package/dist/session.js +1 -0
- package/dist/skills.d.ts +7 -0
- package/dist/skills.js +1 -0
- package/dist/tools.d.ts +7 -0
- package/dist/tools.js +1 -0
- package/dist/utils/changelog.d.ts +20 -0
- package/dist/utils/changelog.js +4 -0
- package/dist/utils/diagnostics.d.ts +37 -0
- package/dist/utils/diagnostics.js +1 -0
- package/dist/utils/frontmatter.d.ts +7 -0
- package/dist/utils/frontmatter.js +4 -0
- package/dist/utils/git.d.ts +25 -0
- package/dist/utils/git.js +1 -0
- package/dist/utils/mime.d.ts +1 -0
- package/dist/utils/mime.js +1 -0
- package/dist/utils/photon.d.ts +6 -0
- package/dist/utils/photon.js +1 -0
- package/dist/utils/startup-profiler.d.ts +87 -0
- package/dist/utils/startup-profiler.js +2 -0
- package/docs/codex-goal-command-impl.md +1055 -0
- package/docs/codex-goal-vs-grub.md +500 -0
- package/docs/custom-provider.md +27 -0
- package/docs/extensions.md +27 -0
- package/docs/keybindings.md +27 -0
- package/docs/loop /351/207/215/346/236/204/345/256/214/346/210/220/346/200/273/347/273/223.md" +251 -0
- package/docs/loop /351/207/215/346/236/204/345/256/214/346/210/220/346/212/245/345/221/212.md" +123 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210.md" +1222 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210/345/256/236/347/216/260/346/212/245/345/221/212.md" +158 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210/345/257/271/346/257/224/345/210/206/346/236/220.md" +128 -0
- package/docs/loop /351/207/215/346/236/204/350/256/241/345/210/222.md" +321 -0
- package/docs/loop-usage-examples.md +215 -0
- package/docs/models.md +27 -0
- package/docs/packages.md +27 -0
- package/docs/pi-design-philosophy.md +457 -0
- package/docs/planmode.md +1987 -0
- package/docs/prompt-templates.md +27 -0
- package/docs/providers.md +27 -0
- package/docs/sdk.md +27 -0
- package/docs/skills.md +27 -0
- package/docs/themes.md +27 -0
- package/docs/tui.md +27 -0
- package/package.json +191 -0
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides ModelOverlayController + ModelOverlayContext (ModelSessionPort/ModelCatalogPort/
|
|
3
|
+
* ModelSettingsPort/ProviderConfigPort/ModelOverlaySurface/ModelOverlayFooter) — interactive model selection
|
|
4
|
+
* [FROM]: Depends on @catui/ai (Model), agent-core (ThinkingLevel), core/runtime/agent-session
|
|
5
|
+
* (CycleModelError), @catui/tui (Component/TUI), core/model-resolver (resolveModelScope),
|
|
6
|
+
* components (Model/Provider/ScopedModels selectors)
|
|
7
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts (held as `this.modelOverlay`; /model, cycle keybindings,
|
|
8
|
+
* /scoped-models delegate here)
|
|
9
|
+
* [HERE]: modes/interactive/controllers/model-overlay-controller.ts — P5 model-overlay slice (UI08, hybrid)
|
|
10
|
+
*
|
|
11
|
+
* Interactive TUI orchestration of model selection (UI08). It DELEGATES the reusable model capability
|
|
12
|
+
* (set/cycle model, thinking level, scoped models) to AgentSession via ModelSessionPort — it does NOT
|
|
13
|
+
* own model switching rules, thinking clamping/persistence, API-key validation, or provider credentials.
|
|
14
|
+
* Provider configuration is consumed through ProviderConfigPort (points to mount during transition,
|
|
15
|
+
* repointed to auth/provider-config later). The context is intentionally the widest P5 controller, but
|
|
16
|
+
* grouped by capability and serving one workflow; it must not keep growing. No InteractiveMode reference.
|
|
17
|
+
*/
|
|
18
|
+
import type { Model } from "@catui/ai/types";
|
|
19
|
+
import type { ThinkingLevel } from "@catui/agent-core";
|
|
20
|
+
import type { Component, TUI } from "@catui/tui";
|
|
21
|
+
import type { ModelRegistry } from "../../../core/model-registry.js";
|
|
22
|
+
type AnyModel = Model<any>;
|
|
23
|
+
type ScopedModel = {
|
|
24
|
+
model: AnyModel;
|
|
25
|
+
thinkingLevel: ThinkingLevel;
|
|
26
|
+
};
|
|
27
|
+
/** Reusable model capability — delegated to AgentSession; model-overlay never reimplements it. */
|
|
28
|
+
export interface ModelSessionPort {
|
|
29
|
+
getModel(): AnyModel | undefined;
|
|
30
|
+
setModel(model: AnyModel): Promise<void>;
|
|
31
|
+
cycleModel(direction: "forward" | "backward"): Promise<{
|
|
32
|
+
model: AnyModel;
|
|
33
|
+
thinkingLevel: ThinkingLevel;
|
|
34
|
+
} | undefined>;
|
|
35
|
+
getThinkingLevel(): string;
|
|
36
|
+
setThinkingLevel(level: ThinkingLevel): void;
|
|
37
|
+
cycleThinkingLevel(): string | undefined;
|
|
38
|
+
getAvailableThinkingLevels(): string[];
|
|
39
|
+
getScopedModels(): ReadonlyArray<ScopedModel>;
|
|
40
|
+
setScopedModels(models: ScopedModel[]): void;
|
|
41
|
+
}
|
|
42
|
+
/** Registry/catalog access needed by interactive selection. */
|
|
43
|
+
export interface ModelCatalogPort {
|
|
44
|
+
refresh(): void;
|
|
45
|
+
getAvailable(): AnyModel[];
|
|
46
|
+
getAll(): AnyModel[];
|
|
47
|
+
find(provider: string, id: string): AnyModel | undefined;
|
|
48
|
+
appendOpenRouterModel(id: string, opts: {
|
|
49
|
+
name?: string;
|
|
50
|
+
}): void;
|
|
51
|
+
/** Credential type for a provider (to suggest /login on OAuth cycle failures). */
|
|
52
|
+
getCredentialType(provider: string): string | undefined;
|
|
53
|
+
/**
|
|
54
|
+
* The concrete ModelRegistry object — required by ModelSelectorComponent and resolveModelScope,
|
|
55
|
+
* which consume the registry directly. ModelRegistry is the catalog domain object (not AgentSession
|
|
56
|
+
* or InteractiveMode), so exposing it is allowed under UI-G2.
|
|
57
|
+
*/
|
|
58
|
+
getRegistry(): ModelRegistry;
|
|
59
|
+
}
|
|
60
|
+
/** Enabled/default model settings only — not the whole settings surface. */
|
|
61
|
+
export interface ModelSettingsPort {
|
|
62
|
+
getEnabledModels(): string[] | undefined;
|
|
63
|
+
setEnabledModels(patterns: string[] | undefined): void;
|
|
64
|
+
setDefaultModelAndProvider(provider: string, id: string): void;
|
|
65
|
+
}
|
|
66
|
+
/** Provider configuration precondition (points to mount in transition; repointed to auth/provider-config). */
|
|
67
|
+
export interface ProviderConfigPort {
|
|
68
|
+
ensureProviderConfiguredForSelection(model: AnyModel): Promise<boolean>;
|
|
69
|
+
handleProviderSelectionFromSelector(provider: string, done: () => void): Promise<void>;
|
|
70
|
+
promptForProviderApiKey(provider: string, options?: {
|
|
71
|
+
title?: string;
|
|
72
|
+
}): Promise<boolean>;
|
|
73
|
+
}
|
|
74
|
+
/** Selector/status/error/prompt/render TUI surface. */
|
|
75
|
+
export interface ModelOverlaySurface {
|
|
76
|
+
showSelector(create: (done: () => void) => {
|
|
77
|
+
component: Component;
|
|
78
|
+
focus: Component;
|
|
79
|
+
}): void;
|
|
80
|
+
showStatus(message: string): void;
|
|
81
|
+
showError(message: string): void;
|
|
82
|
+
promptInput(title: string, placeholder?: string, opts?: {
|
|
83
|
+
initialValue?: string;
|
|
84
|
+
}): Promise<string | undefined>;
|
|
85
|
+
getUi(): TUI;
|
|
86
|
+
}
|
|
87
|
+
/** Footer/editor-border refresh after selection. */
|
|
88
|
+
export interface ModelOverlayFooter {
|
|
89
|
+
invalidate(): void;
|
|
90
|
+
setAvailableProviderCount(count: number): void;
|
|
91
|
+
updateEditorBorderColor(): void;
|
|
92
|
+
}
|
|
93
|
+
export interface ModelOverlayContext {
|
|
94
|
+
modelSession: ModelSessionPort;
|
|
95
|
+
modelCatalog: ModelCatalogPort;
|
|
96
|
+
modelSettings: ModelSettingsPort;
|
|
97
|
+
providerConfig: ProviderConfigPort;
|
|
98
|
+
surface: ModelOverlaySurface;
|
|
99
|
+
footer: ModelOverlayFooter;
|
|
100
|
+
/** Interactive-only side effect after a model is applied (the daxnuts easter egg). */
|
|
101
|
+
playDaxnuts(): void;
|
|
102
|
+
}
|
|
103
|
+
export declare class ModelOverlayController {
|
|
104
|
+
private readonly ctx;
|
|
105
|
+
constructor(ctx: ModelOverlayContext);
|
|
106
|
+
cycleThinkingLevel(): void;
|
|
107
|
+
handleThinkingCommand(text: string): void;
|
|
108
|
+
cycleModel(direction: "forward" | "backward"): Promise<void>;
|
|
109
|
+
handleModelCommand(searchTerm?: string): Promise<void>;
|
|
110
|
+
showModelSelector(initialSearchInput?: string, filterByProvider?: string): void;
|
|
111
|
+
showProviderThenModelSelector(): Promise<void>;
|
|
112
|
+
showModelsSelector(): Promise<void>;
|
|
113
|
+
/** Update the footer's available provider count from current model candidates. */
|
|
114
|
+
updateAvailableProviderCount(): Promise<void>;
|
|
115
|
+
private findExactModelMatch;
|
|
116
|
+
private getModelCandidates;
|
|
117
|
+
/**
|
|
118
|
+
* Apply a chosen model: persist as default, refresh footer/border, status, daxnuts hook.
|
|
119
|
+
* Public because the provider-config path (mount, future provider-config-controller) applies a
|
|
120
|
+
* model after configuring a custom protocol provider. Selection mutation still goes through the
|
|
121
|
+
* modelSession port (AgentSession), keeping UI08's runtime-owned capability boundary.
|
|
122
|
+
*/
|
|
123
|
+
applySelectedModel(model: AnyModel): Promise<void>;
|
|
124
|
+
private selectModelWithProviderEnsure;
|
|
125
|
+
private checkDaxnutsEasterEgg;
|
|
126
|
+
}
|
|
127
|
+
export {};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
var v=Object.defineProperty;var a=(f,t)=>v(f,"name",{value:t,configurable:!0});import{CycleModelError as m}from"../../../core/runtime/agent-session.js";import{resolveModelScope as p}from"../../../core/model-resolver.js";import{ModelSelectorComponent as S}from"../components/model-selector.js";import{ProviderSelectorComponent as w}from"../components/provider-selector.js";import{ScopedModelsSelectorComponent as M}from"../components/scoped-models-selector.js";class T{static{a(this,"ModelOverlayController")}ctx;constructor(t){this.ctx=t}cycleThinkingLevel(){const t=this.ctx.modelSession.cycleThinkingLevel();t===void 0?this.ctx.surface.showStatus("Current model does not support thinking"):(this.ctx.footer.invalidate(),this.ctx.footer.updateEditorBorderColor(),this.ctx.surface.showStatus(`Thinking level: ${t}`))}handleThinkingCommand(t){const e=t.slice(9).trim().toLowerCase(),o=this.ctx.modelSession.getAvailableThinkingLevels();if(!e){this.ctx.surface.showStatus(`Thinking level: ${this.ctx.modelSession.getThinkingLevel()} (available: ${o.join(", ")})`);return}if(!o.includes(e)){this.ctx.surface.showStatus(`Unknown thinking level: ${e} (available: ${o.join(", ")})`);return}this.ctx.modelSession.setThinkingLevel(e),this.ctx.footer.invalidate(),this.ctx.footer.updateEditorBorderColor(),this.ctx.surface.showStatus(`Thinking level: ${this.ctx.modelSession.getThinkingLevel()}`)}async cycleModel(t){try{const e=await this.ctx.modelSession.cycleModel(t);if(e===void 0){const o=this.ctx.modelSession.getScopedModels().length>0?"Only one model in scope":"Only one model available";this.ctx.surface.showStatus(o)}else{this.ctx.footer.invalidate(),this.ctx.footer.updateEditorBorderColor();const o=e.model.reasoning&&e.thinkingLevel!=="off"?` (thinking: ${e.thinkingLevel})`:"";this.ctx.surface.showStatus(`Switched to ${e.model.name||e.model.id}${o}`)}}catch(e){const o=e instanceof Error?e.message:String(e);e instanceof m&&e.provider?this.ctx.modelCatalog.getCredentialType(e.provider)==="oauth"||e.code==="oauth_expired"?this.ctx.surface.showError(`${o}
|
|
2
|
+
Use /login ${e.provider} to re-authenticate.`):this.ctx.surface.showError(o):this.ctx.surface.showError(o)}}async handleModelCommand(t){if(!t){this.showProviderThenModelSelector();return}const e=await this.findExactModelMatch(t);if(e){await this.selectModelWithProviderEnsure(e);return}this.showModelSelector(t)}showModelSelector(t,e){this.ctx.surface.showSelector(o=>{const r=new S(this.ctx.surface.getUi(),this.ctx.modelSession.getModel(),this.ctx.modelCatalog.getRegistry(),this.ctx.modelSession.getScopedModels(),async i=>{o(),await this.selectModelWithProviderEnsure(i)},()=>{o(),this.ctx.surface.getUi().requestRender()},t,e,()=>{(async()=>{o();const i=await this.ctx.surface.promptInput("Add OpenRouter model","Model id (e.g. x-ai/grok-4.20)");if(!i?.trim()){this.showModelSelector(t,e);return}const s=await this.ctx.surface.promptInput("Display name (optional)","Leave empty to use model id",{initialValue:i.trim()});if(s===void 0){this.showModelSelector(t,e);return}try{this.ctx.modelCatalog.appendOpenRouterModel(i.trim(),{name:s.trim()||void 0}),this.ctx.surface.showStatus(`Added OpenRouter model ${i.trim()}`)}catch(n){this.ctx.surface.showError(n instanceof Error?n.message:String(n))}this.showModelSelector(t,e)})()},()=>{(async()=>{o();const i=e??this.ctx.modelSession.getModel()?.provider;i&&await this.ctx.providerConfig.promptForProviderApiKey(i),this.showModelSelector(t,e)})()});return{component:r,focus:r}})}async showProviderThenModelSelector(){this.ctx.modelCatalog.refresh();const t=this.ctx.modelCatalog.getAll(),e=[...new Set(t.map(o=>o.provider))].sort();if(e.length===0){this.ctx.surface.showStatus("No providers available");return}if(e.length===1){this.showModelSelector(void 0,e[0]);return}this.ctx.surface.showSelector(o=>{const r=new w(e,this.ctx.modelSession.getModel()?.provider,i=>{this.ctx.providerConfig.handleProviderSelectionFromSelector(i,o)},()=>{o(),this.ctx.surface.getUi().requestRender()});return{component:r,focus:r}})}async showModelsSelector(){this.ctx.modelCatalog.refresh();const t=this.ctx.modelCatalog.getAvailable();if(t.length===0){this.ctx.surface.showStatus("No models available");return}const e=this.ctx.modelSession.getScopedModels(),o=e.length>0,r=new Set;let i=!1;if(o){for(const l of e)r.add(`${l.model.provider}/${l.model.id}`);i=!0}else{const l=this.ctx.modelSettings.getEnabledModels();if(l!==void 0&&l.length>0){i=!0;const u=await p(l,this.ctx.modelCatalog.getRegistry());for(const c of u)r.add(`${c.model.provider}/${c.model.id}`)}}const s=new Set(r);let n=i;const h=a(async l=>{if(l.size>0&&l.size<t.length){const u=this.ctx.modelSession.getThinkingLevel(),c=await p(Array.from(l),this.ctx.modelCatalog.getRegistry());this.ctx.modelSession.setScopedModels(c.map(d=>({model:d.model,thinkingLevel:d.thinkingLevel??u})))}else this.ctx.modelSession.setScopedModels([]);await this.updateAvailableProviderCount(),this.ctx.surface.getUi().requestRender()},"updateSessionModels");this.ctx.surface.showSelector(l=>{const u=new M({allModels:t,enabledModelIds:s,hasEnabledModelsFilter:n},{onModelToggle:a(async(c,d)=>{d?s.add(c):s.delete(c),n=!0,await h(s)},"onModelToggle"),onEnableAll:a(async c=>{s.clear();for(const d of c)s.add(d);n=!1,await h(s)},"onEnableAll"),onClearAll:a(async()=>{s.clear(),n=!0,await h(s)},"onClearAll"),onToggleProvider:a(async(c,d,x)=>{for(const g of d)x?s.add(g):s.delete(g);n=!0,await h(s)},"onToggleProvider"),onPersist:a(c=>{const d=c.length===t.length?void 0:c;this.ctx.modelSettings.setEnabledModels(d),this.ctx.surface.showStatus("Model selection saved to settings")},"onPersist"),onCancel:a(()=>{l(),this.ctx.surface.getUi().requestRender()},"onCancel")});return{component:u,focus:u}})}async updateAvailableProviderCount(){const t=await this.getModelCandidates(),e=new Set(t.map(o=>o.provider));this.ctx.footer.setAvailableProviderCount(e.size)}async findExactModelMatch(t){const e=t.trim();if(!e)return;let o,r="";if(e.includes("/")){const n=e.split("/",2);o=n[0]?.trim().toLowerCase(),r=n[1]?.trim().toLowerCase()??""}else r=e.toLowerCase();if(!r)return;const s=(await this.getModelCandidates()).filter(n=>{const h=n.id.toLowerCase()===r,l=!o||n.provider.toLowerCase()===o;return h&&l});return s.length===1?s[0]:void 0}async getModelCandidates(){const t=this.ctx.modelSession.getScopedModels();if(t.length>0)return t.map(e=>e.model);this.ctx.modelCatalog.refresh();try{return this.ctx.modelCatalog.getAll()}catch{return[]}}async applySelectedModel(t){await this.ctx.modelSession.setModel(t),this.ctx.modelSettings.setDefaultModelAndProvider(t.provider,t.id),this.ctx.footer.invalidate(),this.ctx.footer.updateEditorBorderColor(),this.ctx.surface.showStatus(`Model: ${t.id}`),this.checkDaxnutsEasterEgg(t)}async selectModelWithProviderEnsure(t){try{if(!await this.ctx.providerConfig.ensureProviderConfiguredForSelection(t)){this.ctx.surface.showStatus("Configuration cancelled");return}this.ctx.modelCatalog.refresh();const o=this.ctx.modelCatalog.find(t.provider,t.id)??t;await this.applySelectedModel(o)}catch(e){const o=e instanceof Error?e.message:String(e);e instanceof m&&e.provider?this.ctx.surface.showError(`${o}
|
|
3
|
+
Use /login ${e.provider} to re-authenticate.`):this.ctx.surface.showError(o)}}checkDaxnutsEasterEgg(t){t.provider==="opencode"&&t.id.toLowerCase().includes("kimi-k2.5")&&this.ctx.playDaxnuts()}}export{T as ModelOverlayController};
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SelfUpdateController, SelfUpdateContext — version check / update / reinstall / restart
|
|
3
|
+
* [FROM]: Depends on @catui/tui (Container/Text/Spacer), config (VERSION/PACKAGE_NAME/getUpdateInstruction),
|
|
4
|
+
* theme, components/dynamic-border, node:child_process (spawn)
|
|
5
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts (constructs one, delegates /update, /reinstall, startup check)
|
|
6
|
+
* [HERE]: modes/interactive/controllers/self-update-controller.ts — P5 UI slice (UI02, 纯搬)
|
|
7
|
+
*
|
|
8
|
+
* Extracted from InteractiveMode (P5 self-update). Owns the npm-based update/reinstall workflow
|
|
9
|
+
* and the startup version check — an ops flow that happens to use the TUI for prompts. Reads chat
|
|
10
|
+
* container / render / settings / selector through a narrow SelfUpdateContext (no InteractiveMode
|
|
11
|
+
* reference). Behavior is identical to the former InteractiveMode methods. P5 keeps it inside
|
|
12
|
+
* modes/interactive; only a second mode consumer would justify moving it to modes/_shell/update.
|
|
13
|
+
*/
|
|
14
|
+
import { type Container } from "@catui/tui";
|
|
15
|
+
/** Narrow capability seam: the chat/render/settings/selector capabilities the updater needs. */
|
|
16
|
+
export interface SelfUpdateContext {
|
|
17
|
+
/** The chat container the updater renders progress/results into. */
|
|
18
|
+
getChatContainer(): Container;
|
|
19
|
+
/** Request a TUI re-render. */
|
|
20
|
+
requestRender(): void;
|
|
21
|
+
getAutoUpdate(): "always" | "prompt" | "never";
|
|
22
|
+
getSkippedVersion(): string | undefined;
|
|
23
|
+
setSkippedVersion(version: string | undefined): void;
|
|
24
|
+
setAutoUpdate(mode: "always" | "prompt" | "never"): void;
|
|
25
|
+
/** Present a selector overlay (delegates to the extension-selector UI). */
|
|
26
|
+
showSelector(title: string, options: string[]): Promise<string | undefined>;
|
|
27
|
+
}
|
|
28
|
+
export declare class SelfUpdateController {
|
|
29
|
+
private readonly ctx;
|
|
30
|
+
constructor(ctx: SelfUpdateContext);
|
|
31
|
+
private get chat();
|
|
32
|
+
private render;
|
|
33
|
+
checkForNewVersion(): Promise<string | undefined>;
|
|
34
|
+
showNewVersionNotification(newVersion: string): void;
|
|
35
|
+
handleUpdateCommand(): Promise<void>;
|
|
36
|
+
/**
|
|
37
|
+
* Handle /reinstall command - force clean reinstall.
|
|
38
|
+
*/
|
|
39
|
+
handleReinstallCommand(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Check for updates on startup if auto-update is enabled.
|
|
42
|
+
*/
|
|
43
|
+
checkAutoUpdateOnStartup(): Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* Show interactive update options when a new version is available.
|
|
46
|
+
*/
|
|
47
|
+
private showUpdateOptions;
|
|
48
|
+
/**
|
|
49
|
+
* Perform the actual npm install update.
|
|
50
|
+
*/
|
|
51
|
+
private performUpdate;
|
|
52
|
+
/**
|
|
53
|
+
* Show retry options after a failed update attempt.
|
|
54
|
+
*/
|
|
55
|
+
private showRetryOptions;
|
|
56
|
+
/**
|
|
57
|
+
* Wait for a specific key press from user.
|
|
58
|
+
* Falls back to selector UI if TTY is not available.
|
|
59
|
+
*/
|
|
60
|
+
private waitForKeyPress;
|
|
61
|
+
/**
|
|
62
|
+
* Restart Catui by spawning a new process.
|
|
63
|
+
* Tries to detect the correct command to restart.
|
|
64
|
+
*/
|
|
65
|
+
private restartCatui;
|
|
66
|
+
/**
|
|
67
|
+
* Compare two version strings (semver style).
|
|
68
|
+
* Returns: 1 if v1 > v2, -1 if v1 < v2, 0 if equal
|
|
69
|
+
*/
|
|
70
|
+
private compareVersion;
|
|
71
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
var $=Object.defineProperty;var u=(w,e)=>$(w,"name",{value:e,configurable:!0});import{spawn as g}from"node:child_process";import{Spacer as c,Text as i}from"@catui/tui";import{getUpdateInstruction as k,PACKAGE_NAME as l,VERSION as f}from"../../../config.js";import{DynamicBorder as y}from"../components/dynamic-border.js";import{theme as t}from"../theme/theme.js";function m(w){if(process.platform==="win32"){const e=["npm",...w].map(n=>n.includes(" ")?`"${n}"`:n).join(" ");return g(e,{stdio:["ignore","pipe","pipe"],env:process.env,shell:!0})}return g("npm",w,{stdio:["ignore","pipe","pipe"],env:process.env})}u(m,"spawnNpm");class A{static{u(this,"SelfUpdateController")}ctx;constructor(e){this.ctx=e}get chat(){return this.ctx.getChatContainer()}render(){this.ctx.requestRender()}async checkForNewVersion(){if(!(process.env.CATUI_SKIP_VERSION_CHECK||process.env.CATUI_OFFLINE))try{const e=await fetch(`https://registry.npmjs.org/${encodeURIComponent(l)}`,{signal:AbortSignal.timeout(1e4)});if(!e.ok)return;const n=await e.json(),s=n["dist-tags"]?.latest??n.version;return s&&this.compareVersion(s,f)>0?s:void 0}catch{return}}showNewVersionNotification(e){const n=t.fg("accent",k(l)),s=t.fg("muted",`New version ${e} is available. `)+n;this.chat.addChild(new c(1)),this.chat.addChild(new y(r=>t.fg("warning",r))),this.chat.addChild(new i(`${t.bold(t.fg("warning","Update Available"))}
|
|
2
|
+
${s}`,1,0)),this.chat.addChild(new y(r=>t.fg("warning",r))),this.render()}async handleUpdateCommand(){this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","\u{1F50D} Checking for updates..."),1,0)),this.render();try{const e=await fetch(`https://registry.npmjs.org/${encodeURIComponent(l)}`,{signal:AbortSignal.timeout(1e4)});if(!e.ok)throw new Error(`Failed to check for updates: ${e.status}`);const s=(await e.json())["dist-tags"]?.latest??"unknown",r=f,a=s!=="unknown"?this.compareVersion(s,r):0,d=[];if(d.push(t.fg("accent","\u{1F4E6} Catui Update Checker")),d.push(""),d.push(`Current version: ${t.fg("dim",r)}`),d.push(`Latest version: ${t.fg(a>0?"success":"dim",s)}`),d.push(""),s!=="unknown"&&a>0){d.push(t.fg("success",`\u2728 New version ${s} available!`)),d.push(""),this.chat.addChild(new c(1)),this.chat.addChild(new i(d.join(`
|
|
3
|
+
`),1,0)),this.render(),await this.showUpdateOptions(s);return}else s!=="unknown"&&a<0?(d.push(t.fg("success","\u2728 You're ahead!")),d.push(""),d.push(t.fg("dim","You're running a pre-release or newer version than published on npm."))):(d.push(t.fg("success","\u2728 Up to date!")),d.push(""),d.push(t.fg("dim","You're running the latest version of Catui.")));this.chat.addChild(new c(1)),this.chat.addChild(new i(d.join(`
|
|
4
|
+
`),1,0))}catch(e){this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Failed to check for updates: ${e instanceof Error?e.message:"Unknown error"}`),1,0)),this.chat.addChild(new i(t.fg("dim",`Visit https://www.npmjs.com/package/${l} to check manually`),1,0))}this.render()}handleReinstallCommand(){this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","\u{1F504} Force Reinstalling Catui..."),1,0)),this.chat.addChild(new i(t.fg("dim","This will uninstall and reinstall with cache cleared."),1,0)),this.render();const e=m(["uninstall","-g",l]);e.on("close",n=>{n!==0&&(this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Uninstall failed (exit code ${n}), continuing anyway...`),1,0)),this.render()),this.chat.addChild(new i(t.fg("dim","\u{1F9F9} Clearing npm cache..."),1,0)),this.render(),m(["cache","clean","--force"]).on("close",()=>{this.chat.addChild(new i(t.fg("dim","\u{1F4E6} Installing latest version..."),1,0)),this.render();const r=m(["install","-g","--force",`${l}@latest`]);r.on("close",a=>{a===0?(this.chat.addChild(new i(t.fg("success","\u2705 Catui reinstalled successfully!"),1,0)),this.chat.addChild(new i(t.fg("accent","Press 'R' to restart Catui"),1,0)),this.render(),u(async()=>{const o=await this.waitForKeyPress(["r","R","q","Q",""]);o==="r"||o==="R"?this.restartCatui():process.exit(0)},"waitForRestart")()):(this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Reinstall failed (exit code ${a})`),1,0)),this.chat.addChild(new i(t.fg("dim",`Try running manually: npm uninstall -g ${l} && npm install -g ${l}`),1,0)),this.render())}),r.on("error",a=>{this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Install failed: ${a.message}`),1,0)),this.render()})})}),e.on("error",n=>{this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Uninstall failed: ${n.message}`),1,0)),this.render()})}async checkAutoUpdateOnStartup(){if(this.ctx.getAutoUpdate()==="always")try{const n=await fetch(`https://registry.npmjs.org/${encodeURIComponent(l)}`,{signal:AbortSignal.timeout(5e3)});if(!n.ok)return;const r=(await n.json())["dist-tags"]?.latest;if(!r)return;const a=f;if(this.ctx.getSkippedVersion()===r)return;if(this.compareVersion(r,a)>0){const o=`${t.fg("accent","\u{1F4E6} Update Available")}
|
|
5
|
+
|
|
6
|
+
${t.fg("dim",`Current: ${a}`)}
|
|
7
|
+
${t.fg("success",`Latest: ${r}`)}
|
|
8
|
+
|
|
9
|
+
${t.fg("dim","A new version is available. Would you like to update now?")}`,h=["1. Update now and restart","2. Skip this version","3. Continue without updating"],p=await this.ctx.showSelector(o,h);if(!p)return;p.includes("Update now")?await this.performUpdate(r):p.includes("Skip")?(this.ctx.setSkippedVersion(r),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("dim",`\u23ED\uFE0F Skipped version ${r}. You won't be prompted again.`),1,0)),this.render()):p.includes("Continue")&&(this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("dim","Continuing without update..."),1,0)),this.render())}}catch{}}async showUpdateOptions(e){const n=this.ctx.getAutoUpdate();if(this.ctx.getSkippedVersion()===e){const h=`${t.fg("accent","Update Skipped")}
|
|
10
|
+
|
|
11
|
+
${t.fg("dim",`You previously chose to skip version ${e}.`)}
|
|
12
|
+
${t.fg("dim",`Current: ${f}`)}
|
|
13
|
+
${t.fg("success",`Latest: ${e}`)}
|
|
14
|
+
|
|
15
|
+
${t.fg("dim","What would you like to do?")}`,p=["1. Update now","2. Clear skip and enable auto-update","3. Continue without updating"],C=await this.ctx.showSelector(h,p);if(!C){this.chat.addChild(new i(t.fg("dim","Returning to chat..."),1,0)),this.render();return}if(C.includes("Update now")){await this.performUpdate(e);return}else if(C.includes("Clear skip")){this.ctx.setSkippedVersion(void 0),this.ctx.setAutoUpdate("always"),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("success","\u2705 Skip cleared! Auto-update enabled. Catui will check for updates on startup."),1,0)),this.render(),await this.performUpdate(e);return}this.chat.addChild(new i(t.fg("dim","Continuing without update..."),1,0)),this.render();return}const r=`${t.fg("accent","Update Available")}
|
|
16
|
+
|
|
17
|
+
${t.fg("dim",`Current: ${f}`)}
|
|
18
|
+
${t.fg("success",`Latest: ${e}`)}`,a=[];a.push("1. Update now and restart"),a.push("2. Exit and I'll update manually"),a.push("3. Skip this version"),n!=="always"?a.push("4. Enable auto-update"):a.push("4. Disable auto-update");const d=n==="always"?`
|
|
19
|
+
|
|
20
|
+
${t.fg("success","\u25CF Auto-update is enabled")}`:`
|
|
21
|
+
|
|
22
|
+
${t.fg("dim","\u25CB Auto-update is disabled")}`,o=await this.ctx.showSelector(r+d,a);if(!o){this.chat.addChild(new i(t.fg("dim","Returning to chat..."),1,0)),this.render();return}o.includes("Update now")?await this.performUpdate(e):o.includes("Exit")?(this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","\u{1F44B} Exiting. Run this command to update:"),1,0)),this.chat.addChild(new i(t.fg("dim",` npm install -g ${l}@latest`),1,0)),this.render(),await new Promise(h=>setTimeout(h,2e3)),process.exit(0)):o.includes("Skip")?(this.ctx.setSkippedVersion(e),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("dim",`\u23ED\uFE0F Skipped version ${e}. You won't be prompted for this version again.`),1,0)),this.chat.addChild(new i(t.fg("dim"," You can clear this skip later from settings."),1,0)),this.render()):o.includes("Enable auto-update")?(this.ctx.setAutoUpdate("always"),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("success","\u2705 Auto-update enabled! Catui will check for updates on startup."),1,0)),this.render(),await this.performUpdate(e)):o.includes("Disable auto-update")&&(this.ctx.setAutoUpdate("prompt"),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("dim","\u2705 Auto-update disabled. You'll be prompted when updates are available."),1,0)),this.render())}async performUpdate(e,n=0){return this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","\u{1F504} Updating Catui..."),1,0)),this.render(),new Promise(s=>{const r=m(["install","-g","--force",`${l}@latest`]);let a="";r.stderr?.on("data",d=>{a+=d.toString()}),r.on("close",async d=>{d===0?(this.chat.addChild(new i(t.fg("success",`\u2705 Successfully updated to version ${e}!`),1,0)),this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","Press 'R' to restart or Ctrl+C to exit manually"),1,0)),this.render(),u(async()=>{const h=await this.waitForKeyPress(["r","R","q","Q",""]);h==="r"||h==="R"?(this.chat.addChild(new i(t.fg("dim","\u{1F504} Restarting Catui..."),1,0)),this.render(),this.restartCatui()):process.exit(0)},"waitForRestart")().then(()=>s())):(this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Update failed (exit code ${d})`),1,0)),this.chat.addChild(new i(t.fg("dim","This may be a network issue or permissions problem."),1,0)),this.render(),s(),this.showRetryOptions(e,n))}),r.on("error",async d=>{this.chat.addChild(new i(t.fg("warning",`\u26A0\uFE0F Failed to run npm: ${d.message}`),1,0)),this.chat.addChild(new i(t.fg("dim","Make sure npm is installed and in your PATH."),1,0)),this.render(),s(),this.showRetryOptions(e,n)})})}async showRetryOptions(e,n){await new Promise(a=>setTimeout(a,500));const s=["1. Try again","2. Exit and update manually"];(await this.ctx.showSelector(`${t.fg("accent","Update Failed")}
|
|
23
|
+
|
|
24
|
+
${t.fg("dim","What would you like to do?")}`,s))?.includes("Try again")?n<3?await this.performUpdate(e,n+1):(this.chat.addChild(new i(t.fg("dim","Multiple retry attempts failed. Please try updating manually."),1,0)),this.chat.addChild(new i(t.fg("dim",` npm install -g ${l}@latest`),1,0)),this.render()):(this.chat.addChild(new c(1)),this.chat.addChild(new i(t.fg("accent","\u{1F44B} Exiting. Run this command to update:"),1,0)),this.chat.addChild(new i(t.fg("dim",` npm install -g ${l}@latest`),1,0)),this.render(),await new Promise(a=>setTimeout(a,2e3)),process.exit(0))}async waitForKeyPress(e){if(!process.stdin.isTTY){const n=e.filter(a=>a!=="").map(a=>`Press '${a}'`);n.push("Cancel");const s=await this.ctx.showSelector(t.fg("accent","Restart Options"),n);return!s||s.includes("Cancel")?"":e.find(a=>s.includes(a))??""}return new Promise(n=>{const s=process.stdin,r=s.isRaw,a=u(()=>{try{s.isTTY&&s.setRawMode(r)}catch{}s.pause(),s.removeListener("data",d)},"cleanup"),d=u(o=>{const h=o.toString();(h===""||e.includes(h))&&(a(),n(h===""?"":h))},"onData");try{s.setRawMode(!0),s.resume(),s.on("data",d)}catch{a(),n(null)}})}restartCatui(){const e=process.argv,n=e[0],s=e.slice(1);n.includes("catui")||n.includes("catui")?g(n,s,{detached:!0,stdio:"ignore"}).unref():g(process.execPath,e.slice(1),{detached:!0,stdio:"ignore"}).unref(),process.exit(0)}compareVersion(e,n){const s=e.split(".").map(Number),r=n.split(".").map(Number);for(let a=0;a<Math.max(s.length,r.length);a++){const d=s[a]??0,o=r[a]??0;if(d>o)return 1;if(d<o)return-1}return 0}}export{A as SelfUpdateController};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SettingsOverlayController + SettingsOverlayContext — interactive /settings overlay orchestration
|
|
3
|
+
* [FROM]: Depends on AgentSession, SettingsManager, SettingsSelectorComponent, interactive theme/render/editor ports
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts for the /settings command
|
|
5
|
+
* [HERE]: modes/interactive/controllers/settings-overlay-controller.ts — P5 settings-overlay slice (UI07, hybrid)
|
|
6
|
+
*
|
|
7
|
+
* Owns the interactive settings overlay wiring only. Settings persistence remains in SettingsManager,
|
|
8
|
+
* session behavior remains in AgentSession, and render/editor/buddy effects are delegated through ports.
|
|
9
|
+
*/
|
|
10
|
+
import type { Component } from "@catui/tui";
|
|
11
|
+
import type { AgentSession } from "../../../core/runtime/agent-session.js";
|
|
12
|
+
import type { SettingsManager } from "../../../core/platform/config/settings-manager.js";
|
|
13
|
+
export interface SettingsOverlaySurface {
|
|
14
|
+
showSelector(create: (done: () => void) => {
|
|
15
|
+
component: Component;
|
|
16
|
+
focus: Component;
|
|
17
|
+
}): void;
|
|
18
|
+
showStatus(message: string): void;
|
|
19
|
+
showError(message: string): void;
|
|
20
|
+
invalidateUi(): void;
|
|
21
|
+
requestRender(): void;
|
|
22
|
+
setShowHardwareCursor(enabled: boolean): void;
|
|
23
|
+
setClearOnShrink(enabled: boolean): void;
|
|
24
|
+
}
|
|
25
|
+
export interface SettingsOverlayFooterPort {
|
|
26
|
+
setAutoCompactEnabled(enabled: boolean): void;
|
|
27
|
+
setShowTokenStats(enabled: boolean): void;
|
|
28
|
+
invalidate(): void;
|
|
29
|
+
}
|
|
30
|
+
export interface SettingsOverlayEditorPort {
|
|
31
|
+
setPaddingX(padding: number): void;
|
|
32
|
+
setAutocompleteMaxVisible(maxVisible: number): void;
|
|
33
|
+
updateBorderColor(): void;
|
|
34
|
+
}
|
|
35
|
+
export interface SettingsOverlayRenderPort {
|
|
36
|
+
setToolImagesEnabled(enabled: boolean): void;
|
|
37
|
+
setAssistantThinkingHidden(hidden: boolean): void;
|
|
38
|
+
rebuildChatFromMessages(): void;
|
|
39
|
+
}
|
|
40
|
+
export interface SettingsOverlayContext {
|
|
41
|
+
session: AgentSession;
|
|
42
|
+
settingsManager: SettingsManager;
|
|
43
|
+
surface: SettingsOverlaySurface;
|
|
44
|
+
footer: SettingsOverlayFooterPort;
|
|
45
|
+
editor: SettingsOverlayEditorPort;
|
|
46
|
+
render: SettingsOverlayRenderPort;
|
|
47
|
+
getHideThinkingBlock(): boolean;
|
|
48
|
+
setHideThinkingBlock(hidden: boolean): void;
|
|
49
|
+
rebuildAutocomplete(): void;
|
|
50
|
+
syncBuddyPet(): void;
|
|
51
|
+
}
|
|
52
|
+
export declare class SettingsOverlayController {
|
|
53
|
+
private readonly ctx;
|
|
54
|
+
constructor(ctx: SettingsOverlayContext);
|
|
55
|
+
showSettingsSelector(): void;
|
|
56
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var g=Object.defineProperty;var o=(a,s)=>g(a,"name",{value:s,configurable:!0});import{getAvailableThemes as c,setTheme as i}from"../theme/theme.js";import{SettingsSelectorComponent as h}from"../components/settings-selector.js";class C{static{o(this,"SettingsOverlayController")}ctx;constructor(s){this.ctx=s}showSettingsSelector(){const{session:s,settingsManager:t}=this.ctx;this.ctx.surface.showSelector(l=>{const r=new h({autoCompact:s.autoCompactionEnabled,showImages:t.getShowImages(),autoResizeImages:t.getImageAutoResize(),blockImages:t.getBlockImages(),enableSkillCommands:t.getEnableSkillCommands(),steeringMode:s.steeringMode,followUpMode:s.followUpMode,transport:t.getTransport(),agentLoopFramework:t.getAgentLoopFramework()??"model-default",thinkingLevel:s.thinkingLevel,availableThinkingLevels:s.getAvailableThinkingLevels(),currentTheme:t.getTheme()||"dark",availableThemes:c(),hideThinkingBlock:this.ctx.getHideThinkingBlock(),collapseChangelog:t.getCollapseChangelog(),doubleEscapeAction:t.getDoubleEscapeAction(),showHardwareCursor:t.getShowHardwareCursor(),editorPaddingX:t.getEditorPaddingX(),autocompleteMaxVisible:t.getAutocompleteMaxVisible(),quietStartup:t.getQuietStartup(),clearOnShrink:t.getClearOnShrink(),showTokenStats:t.getShowTokenStats(),buddyEnabled:t.getBuddyEnabled(),buddySpecies:t.getBuddySpecies(),showWorkingTrace:t.getShowWorkingTrace(),showMemoryTrace:t.getShowMemoryTrace(),presenceEnabled:t.getPresenceEnabled()},{onAutoCompactChange:o(e=>{s.setAutoCompactionEnabled(e),this.ctx.footer.setAutoCompactEnabled(e)},"onAutoCompactChange"),onShowImagesChange:o(e=>{t.setShowImages(e),this.ctx.render.setToolImagesEnabled(e)},"onShowImagesChange"),onAutoResizeImagesChange:o(e=>{t.setImageAutoResize(e)},"onAutoResizeImagesChange"),onBlockImagesChange:o(e=>{t.setBlockImages(e)},"onBlockImagesChange"),onEnableSkillCommandsChange:o(e=>{t.setEnableSkillCommands(e),this.ctx.rebuildAutocomplete()},"onEnableSkillCommandsChange"),onSteeringModeChange:o(e=>{s.setSteeringMode(e)},"onSteeringModeChange"),onFollowUpModeChange:o(e=>{s.setFollowUpMode(e)},"onFollowUpModeChange"),onTransportChange:o(e=>{t.setTransport(e),s.agent.setTransport(e)},"onTransportChange"),onAgentLoopFrameworkChange:o(e=>{const n=e==="model-default"?void 0:e;t.setAgentLoopFramework(n),s.setAgentLoopFramework(n),this.ctx.footer.invalidate(),this.ctx.surface.showStatus(`Agent loop: ${s.agentLoopFramework}`)},"onAgentLoopFrameworkChange"),onThinkingLevelChange:o(e=>{s.setThinkingLevel(e),this.ctx.footer.invalidate(),this.ctx.editor.updateBorderColor()},"onThinkingLevelChange"),onThemeChange:o(e=>{const n=i(e,!0);t.setTheme(e),this.ctx.surface.invalidateUi(),n.success||this.ctx.surface.showError(`Failed to load theme "${e}": ${n.error}
|
|
2
|
+
Fell back to dark theme.`)},"onThemeChange"),onThemePreview:o(e=>{i(e,!0).success&&(this.ctx.surface.invalidateUi(),this.ctx.surface.requestRender())},"onThemePreview"),onHideThinkingBlockChange:o(e=>{this.ctx.setHideThinkingBlock(e),t.setHideThinkingBlock(e),this.ctx.render.setAssistantThinkingHidden(e),this.ctx.render.rebuildChatFromMessages()},"onHideThinkingBlockChange"),onCollapseChangelogChange:o(e=>{t.setCollapseChangelog(e)},"onCollapseChangelogChange"),onQuietStartupChange:o(e=>{t.setQuietStartup(e)},"onQuietStartupChange"),onShowWorkingTraceChange:o(e=>{t.setShowWorkingTrace(e)},"onShowWorkingTraceChange"),onShowMemoryTraceChange:o(e=>{t.setShowMemoryTrace(e)},"onShowMemoryTraceChange"),onDoubleEscapeActionChange:o(e=>{t.setDoubleEscapeAction(e)},"onDoubleEscapeActionChange"),onShowHardwareCursorChange:o(e=>{t.setShowHardwareCursor(e),this.ctx.surface.setShowHardwareCursor(e)},"onShowHardwareCursorChange"),onEditorPaddingXChange:o(e=>{t.setEditorPaddingX(e),this.ctx.editor.setPaddingX(e)},"onEditorPaddingXChange"),onAutocompleteMaxVisibleChange:o(e=>{t.setAutocompleteMaxVisible(e),this.ctx.editor.setAutocompleteMaxVisible(e)},"onAutocompleteMaxVisibleChange"),onClearOnShrinkChange:o(e=>{t.setClearOnShrink(e),this.ctx.surface.setClearOnShrink(e)},"onClearOnShrinkChange"),onShowTokenStatsChange:o(e=>{t.setShowTokenStats(e),this.ctx.footer.setShowTokenStats(e),this.ctx.surface.requestRender()},"onShowTokenStatsChange"),onBuddyEnabledChange:o(e=>{t.setBuddyEnabled(e),this.ctx.syncBuddyPet()},"onBuddyEnabledChange"),onBuddySpeciesChange:o(e=>{t.setBuddySpecies(e),this.ctx.syncBuddyPet()},"onBuddySpeciesChange"),onPresenceEnabledChange:o(e=>{t.setPresenceEnabled(e)},"onPresenceEnabledChange"),onCancel:o(()=>{l(),this.ctx.surface.requestRender()},"onCancel")});return{component:r,focus:r.getSettingsList()}})}}export{C as SettingsOverlayController};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SlashDispatcherController + SlashDispatcherContext — built-in slash command dispatch
|
|
3
|
+
* [FROM]: Depends on injected interactive command owner callbacks; no direct TUI/session/model owner imports
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts for built-in slash execution
|
|
5
|
+
* [HERE]: modes/interactive/controllers/slash-dispatcher-controller.ts — P5 slash-dispatcher slice (UI02, dispatch-table rewrite)
|
|
6
|
+
*
|
|
7
|
+
* Owns command-token dispatch only. Input submission rules, extension command execution, persona-in-text
|
|
8
|
+
* handling, bash mode, attachments, and streaming steer remain outside this controller.
|
|
9
|
+
*/
|
|
10
|
+
export type SlashCommandHandler = (text: string, clear: () => void) => void | Promise<void>;
|
|
11
|
+
export interface SlashDispatcherModelPort {
|
|
12
|
+
showScopedModelsSelector(): Promise<void>;
|
|
13
|
+
handleModelCommand(searchTerm?: string): Promise<void>;
|
|
14
|
+
handleThinkingCommand(text: string): void;
|
|
15
|
+
}
|
|
16
|
+
export interface SlashDispatcherAuthPort {
|
|
17
|
+
handleApiKeyCommand(): Promise<void>;
|
|
18
|
+
handleLoginCommand(text: string): Promise<void>;
|
|
19
|
+
showLogoutSelector(): void;
|
|
20
|
+
}
|
|
21
|
+
export interface SlashDispatcherTreePort {
|
|
22
|
+
showForkSelector(): void;
|
|
23
|
+
showTreeSelector(): void;
|
|
24
|
+
showSessionSelector(): void;
|
|
25
|
+
}
|
|
26
|
+
export interface SlashDispatcherSelfUpdatePort {
|
|
27
|
+
handleUpdateCommand(): void;
|
|
28
|
+
handleReinstallCommand(): void;
|
|
29
|
+
}
|
|
30
|
+
export interface SlashDispatcherCommandHandlers {
|
|
31
|
+
isExtensionCommand(text: string): boolean;
|
|
32
|
+
handleAgentLoopCommand(text: string): void | Promise<void>;
|
|
33
|
+
handleMcpCommand(text: string): Promise<void>;
|
|
34
|
+
handleExportCommand(text: string): Promise<void>;
|
|
35
|
+
handleShareCommand(): Promise<void>;
|
|
36
|
+
handleCopyCommand(): void;
|
|
37
|
+
handleStatusCommand(): Promise<void>;
|
|
38
|
+
handleUsageCommand(): Promise<void>;
|
|
39
|
+
handleNameCommand(text: string): void;
|
|
40
|
+
handleSessionCommand(): void;
|
|
41
|
+
handleChangelogCommand(): void;
|
|
42
|
+
handleHotkeysCommand(): void;
|
|
43
|
+
handleShowResourcesCommand(): void;
|
|
44
|
+
handleClearCommand(): Promise<void>;
|
|
45
|
+
handleCompactCommand(customInstructions?: string): Promise<void>;
|
|
46
|
+
handleReloadCommand(): Promise<void>;
|
|
47
|
+
handleLanguageCommand(text: string): Promise<void>;
|
|
48
|
+
handleSoulCommand(): void;
|
|
49
|
+
handlePersonaCommand(text: string): Promise<void>;
|
|
50
|
+
handleMemoryCommand(): void;
|
|
51
|
+
handleArminSaysHi(): void;
|
|
52
|
+
handleBrowserOptInCommand(): void;
|
|
53
|
+
shutdown(): Promise<void>;
|
|
54
|
+
}
|
|
55
|
+
export interface SlashDispatcherContext {
|
|
56
|
+
clearEditor(): void;
|
|
57
|
+
settings: {
|
|
58
|
+
showSettingsSelector(): void;
|
|
59
|
+
};
|
|
60
|
+
model: SlashDispatcherModelPort;
|
|
61
|
+
auth: SlashDispatcherAuthPort;
|
|
62
|
+
tree: SlashDispatcherTreePort;
|
|
63
|
+
selfUpdate: SlashDispatcherSelfUpdatePort;
|
|
64
|
+
commands: SlashDispatcherCommandHandlers;
|
|
65
|
+
}
|
|
66
|
+
export declare class SlashDispatcherController {
|
|
67
|
+
private readonly ctx;
|
|
68
|
+
private readonly builtinSlashCommands;
|
|
69
|
+
constructor(ctx: SlashDispatcherContext);
|
|
70
|
+
execute(text: string, options?: {
|
|
71
|
+
clearEditor?: boolean;
|
|
72
|
+
}): Promise<boolean>;
|
|
73
|
+
private createBuiltinSlashCommands;
|
|
74
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var i=Object.defineProperty;var s=(e,a)=>i(e,"name",{value:a,configurable:!0});class l{static{s(this,"SlashDispatcherController")}ctx;builtinSlashCommands;constructor(a){this.ctx=a,this.builtinSlashCommands=this.createBuiltinSlashCommands()}async execute(a,t){if(!a.startsWith("/"))return!1;const n=t?.clearEditor??!0,d=s(()=>{n&&this.ctx.clearEditor()},"clear"),o=a.indexOf(" "),m=o===-1?a:a.slice(0,o);if(m==="/browser"&&this.ctx.commands.isExtensionCommand(a))return!1;const c=this.builtinSlashCommands[m];return c?(await c(a,d),!0):!1}createBuiltinSlashCommands(){return{"/settings":s((a,t)=>{this.ctx.settings.showSettingsSelector(),t()},"/settings"),"/apikey":s(async(a,t)=>{await this.ctx.auth.handleApiKeyCommand(),t()},"/apikey"),"/scoped-models":s(async(a,t)=>{t(),await this.ctx.model.showScopedModelsSelector()},"/scoped-models"),"/model":s(async(a,t)=>{const n=a.startsWith("/model ")?a.slice(7).trim():void 0;t(),await this.ctx.model.handleModelCommand(n)},"/model"),"/thinking":s((a,t)=>{this.ctx.model.handleThinkingCommand(a),t()},"/thinking"),"/agent-loop":s(async(a,t)=>{await this.ctx.commands.handleAgentLoopCommand(a),t()},"/agent-loop"),"/mcp":s(async(a,t)=>{await this.ctx.commands.handleMcpCommand(a),t()},"/mcp"),"/export":s(async(a,t)=>{await this.ctx.commands.handleExportCommand(a),t()},"/export"),"/share":s(async(a,t)=>{await this.ctx.commands.handleShareCommand(),t()},"/share"),"/copy":s((a,t)=>{this.ctx.commands.handleCopyCommand(),t()},"/copy"),"/status":s(async(a,t)=>{await this.ctx.commands.handleStatusCommand(),t()},"/status"),"/usage":s(async(a,t)=>{await this.ctx.commands.handleUsageCommand(),t()},"/usage"),"/name":s((a,t)=>{this.ctx.commands.handleNameCommand(a),t()},"/name"),"/session":s((a,t)=>{this.ctx.commands.handleSessionCommand(),t()},"/session"),"/changelog":s((a,t)=>{this.ctx.commands.handleChangelogCommand(),t()},"/changelog"),"/hotkeys":s((a,t)=>{this.ctx.commands.handleHotkeysCommand(),t()},"/hotkeys"),"/resources":s((a,t)=>{this.ctx.commands.handleShowResourcesCommand(),t()},"/resources"),"/fork":s((a,t)=>{this.ctx.tree.showForkSelector(),t()},"/fork"),"/tree":s((a,t)=>{this.ctx.tree.showTreeSelector(),t()},"/tree"),"/login":s(async(a,t)=>{await this.ctx.auth.handleLoginCommand(a),t()},"/login"),"/logout":s((a,t)=>{this.ctx.auth.showLogoutSelector(),t()},"/logout"),"/new":s(async(a,t)=>{t(),await this.ctx.commands.handleClearCommand()},"/new"),"/update":s((a,t)=>{this.ctx.selfUpdate.handleUpdateCommand(),t()},"/update"),"/reinstall":s((a,t)=>{this.ctx.selfUpdate.handleReinstallCommand(),t()},"/reinstall"),"/compact":s(async(a,t)=>{const n=a.startsWith("/compact ")?a.slice(9).trim():void 0;t(),await this.ctx.commands.handleCompactCommand(n)},"/compact"),"/reload":s(async(a,t)=>{t(),await this.ctx.commands.handleReloadCommand()},"/reload"),"/language":s(async(a,t)=>{await this.ctx.commands.handleLanguageCommand(a),t()},"/language"),"/soul":s((a,t)=>{this.ctx.commands.handleSoulCommand(),t()},"/soul"),"/persona":s(async(a,t)=>{t(),await this.ctx.commands.handlePersonaCommand(a)},"/persona"),"/memory":s((a,t)=>{this.ctx.commands.handleMemoryCommand(),t()},"/memory"),"/browser":s((a,t)=>{this.ctx.commands.handleBrowserOptInCommand(),t()},"/browser"),"/arminsayshi":s((a,t)=>{this.ctx.commands.handleArminSaysHi(),t()},"/arminsayshi"),"/resume":s((a,t)=>{this.ctx.tree.showSessionSelector(),t()},"/resume"),"/quit":s(async(a,t)=>{t(),await this.ctx.commands.shutdown()},"/quit")}}}export{l as SlashDispatcherController};
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides StreamRenderController + StreamRenderContext (state/layout/loaders/toolTrace/runtime/
|
|
3
|
+
* escape/surface ports) — the interactive streaming render layer (handleEvent)
|
|
4
|
+
* [FROM]: Depends on interactive-state (shared render fields), tui (Container/Text/Spacer/TUI/MarkdownTheme),
|
|
5
|
+
* components (Assistant/Tool/CatuiLoader), theme, agent-session (AgentSessionEvent), ai (Message),
|
|
6
|
+
* agent-core (AgentMessage), extensions-host (ToolDefinition), buddy pet-sprites (BuddyState)
|
|
7
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts (held as `this.streamRender`; subscribeToAgent's
|
|
8
|
+
* handleEvent forwards here)
|
|
9
|
+
* [HERE]: modes/interactive/controllers/stream-render-controller.ts — P5 UI04 render-layer slice (scope A)
|
|
10
|
+
*
|
|
11
|
+
* Owns the AgentSession event → TUI render orchestration: run lifecycle/loader, assistant streaming,
|
|
12
|
+
* user/custom echo, tool-execution display, and the auto-compaction / auto-retry overlays. It is a render
|
|
13
|
+
* layer: it reads session events and writes components, and NEVER submits any message to AgentSession
|
|
14
|
+
* (token-neutral). Shared render state stays in the consolidated `interactive-state` holder (accessed via
|
|
15
|
+
* the `state` port — that holder's stated purpose); the auto-compaction / auto-retry loader+escape state
|
|
16
|
+
* (zero external readers) is owned privately here. The escape override during compaction/retry goes through
|
|
17
|
+
* the `escape` port — the single controlled channel onto `defaultEditor.onEscape` shared with
|
|
18
|
+
* InterruptController (whose dispatchEscape closure is what gets saved and restored).
|
|
19
|
+
* See ../../../.dev-docs/architecture-review/interactive-ui-review/handle-event-analysis.md
|
|
20
|
+
*/
|
|
21
|
+
import type { AgentMessage } from "@catui/agent-core";
|
|
22
|
+
import type { Message } from "@catui/ai/types";
|
|
23
|
+
import { type CachedContainer, type Container, type MarkdownTheme, type TUI } from "@catui/tui";
|
|
24
|
+
import type { ToolDefinition } from "../../../core/extensions-host/types.js";
|
|
25
|
+
import type { AgentSessionEvent } from "../../../core/runtime/agent-session.js";
|
|
26
|
+
import type { BuddyState } from "../components/buddy/pet-sprites.js";
|
|
27
|
+
import type { InteractiveState } from "../state/interactive-state.js";
|
|
28
|
+
export interface StreamRenderStatePort {
|
|
29
|
+
get(): InteractiveState;
|
|
30
|
+
}
|
|
31
|
+
export interface StreamRenderLayoutPort {
|
|
32
|
+
getUi(): TUI;
|
|
33
|
+
getChatContainer(): CachedContainer;
|
|
34
|
+
getStatusContainer(): Container;
|
|
35
|
+
addMessageToChat(message: AgentMessage): void;
|
|
36
|
+
updatePendingMessagesDisplay(): void;
|
|
37
|
+
rebuildChatFromMessages(): void;
|
|
38
|
+
requestRender(): void;
|
|
39
|
+
invalidateFooter(): void;
|
|
40
|
+
}
|
|
41
|
+
export interface StreamRenderLoadersPort {
|
|
42
|
+
getSessionId(): string;
|
|
43
|
+
getDefaultWorkingMessage(): string;
|
|
44
|
+
/** Localized "<key> to cancel" hint key for the interrupt action. */
|
|
45
|
+
getInterruptKeyHint(): string;
|
|
46
|
+
setBuddyPetState(state: BuddyState, speechBubble?: string, options?: {
|
|
47
|
+
resetTo?: BuddyState;
|
|
48
|
+
afterMs?: number;
|
|
49
|
+
}): void;
|
|
50
|
+
startAgentRunTimer(): void;
|
|
51
|
+
stopAgentRunTimer(): void;
|
|
52
|
+
updateWorkingMessage(options?: {
|
|
53
|
+
resetStallTimer?: boolean;
|
|
54
|
+
}): void;
|
|
55
|
+
formatElapsedSeconds(ms: number): string;
|
|
56
|
+
isInPlanMode(): boolean;
|
|
57
|
+
}
|
|
58
|
+
export interface StreamRenderToolTracePort {
|
|
59
|
+
shouldRenderToolTrace(toolName: string): boolean;
|
|
60
|
+
getRegisteredToolDefinition(toolName: string): ToolDefinition | undefined;
|
|
61
|
+
getShowImages(): boolean;
|
|
62
|
+
}
|
|
63
|
+
export interface StreamRenderRuntimePort {
|
|
64
|
+
getRetryAttempt(): number;
|
|
65
|
+
abortCompaction(): void;
|
|
66
|
+
abortRetry(): void;
|
|
67
|
+
flushCompactionQueue(options: {
|
|
68
|
+
willRetry: boolean;
|
|
69
|
+
}): void;
|
|
70
|
+
checkShutdownRequested(): Promise<void>;
|
|
71
|
+
clearAttachments(): void;
|
|
72
|
+
getAgentDir(): string;
|
|
73
|
+
}
|
|
74
|
+
/** The single controlled channel onto defaultEditor.onEscape, shared with InterruptController. */
|
|
75
|
+
export interface StreamRenderEscapePort {
|
|
76
|
+
getHandler(): (() => void) | undefined;
|
|
77
|
+
setHandler(handler: (() => void) | undefined): void;
|
|
78
|
+
}
|
|
79
|
+
export interface StreamRenderSurfacePort {
|
|
80
|
+
ensureInitialized(): Promise<void>;
|
|
81
|
+
restoreEditorFocusIfPossible(): void;
|
|
82
|
+
getUserMessageText(message: Message): string;
|
|
83
|
+
getMarkdownThemeWithSettings(): MarkdownTheme;
|
|
84
|
+
showStatus(message: string): void;
|
|
85
|
+
showError(message: string): void;
|
|
86
|
+
}
|
|
87
|
+
export interface StreamRenderContext {
|
|
88
|
+
state: StreamRenderStatePort;
|
|
89
|
+
layout: StreamRenderLayoutPort;
|
|
90
|
+
loaders: StreamRenderLoadersPort;
|
|
91
|
+
toolTrace: StreamRenderToolTracePort;
|
|
92
|
+
runtime: StreamRenderRuntimePort;
|
|
93
|
+
escape: StreamRenderEscapePort;
|
|
94
|
+
surface: StreamRenderSurfacePort;
|
|
95
|
+
}
|
|
96
|
+
export declare class StreamRenderController {
|
|
97
|
+
private readonly ctx;
|
|
98
|
+
private autoCompactionLoader;
|
|
99
|
+
private autoCompactionEscapeHandler;
|
|
100
|
+
private retryLoader;
|
|
101
|
+
private retryEscapeHandler;
|
|
102
|
+
private taskUpdateUnsubscribe;
|
|
103
|
+
private taskAutoHideTimer;
|
|
104
|
+
constructor(ctx: StreamRenderContext);
|
|
105
|
+
handle(event: AgentSessionEvent): Promise<void>;
|
|
106
|
+
/** Task tool names that should trigger a panel refresh. */
|
|
107
|
+
private static readonly TASK_TOOL_NAMES;
|
|
108
|
+
/** Refresh the task status panel from disk. */
|
|
109
|
+
private refreshTaskPanel;
|
|
110
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var A=Object.defineProperty;var u=(i,t)=>A(i,"name",{value:t,configurable:!0});import*as h from"node:fs";import*as P from"node:os";import*as f from"node:path";import{Spacer as b,Text as y}from"@catui/tui";import{AssistantMessageComponent as S}from"../components/assistant-message.js";import{CatuiLoader as g}from"../components/catui-loader.js";import{ToolExecutionComponent as x}from"../components/tool-execution.js";import{SubAgentPanelComponent as M}from"../components/sub-agent-panel.js";import{PlanProgressPanelComponent as R}from"../components/plan-progress-panel.js";import{TaskStatusPanelComponent as _}from"../components/task-status-panel.js";import{theme as l}from"../theme/theme.js";import{listTasks as T,onTasksUpdated as w,resetTaskList as E}from"../../../extensions/builtin/task/task-store.js";import{DEFAULT_TASK_LIST_ID as m}from"../../../extensions/builtin/task/task-types.js";const z=new Set(["TaskCreate","TaskUpdate","TaskList","TaskGet","TaskStop","TaskDelete"]),H=process.env.CATUI_DEBUG==="1",k=f.join(P.homedir(),".catui","agent","catui-debug.log");function C(i){if(H)try{h.mkdirSync(f.dirname(k),{recursive:!0}),h.appendFileSync(k,`[${new Date().toISOString()}] [render] ${i}
|
|
2
|
+
`)}catch{}}u(C,"dbg");const I=5e3;class Y{static{u(this,"StreamRenderController")}ctx;autoCompactionLoader=void 0;autoCompactionEscapeHandler=void 0;retryLoader=void 0;retryEscapeHandler=void 0;taskUpdateUnsubscribe=void 0;taskAutoHideTimer=void 0;constructor(t){this.ctx=t}async handle(t){C(`handle event: ${t.type}`),await this.ctx.surface.ensureInitialized(),this.ctx.layout.invalidateFooter();const e=this.ctx.state.get(),n=this.ctx.layout.getUi(),a=this.ctx.layout.getChatContainer(),o=this.ctx.layout.getStatusContainer();switch(t.type){case"agent_start":this.retryEscapeHandler&&(this.ctx.escape.setHandler(this.retryEscapeHandler),this.retryEscapeHandler=void 0),this.retryLoader&&(this.retryLoader.stop(),this.retryLoader=void 0),e.loadingAnimation&&e.loadingAnimation.stop(),o.clear(),e.loadingAnimation=new g(n,l,this.ctx.loaders.getDefaultWorkingMessage(),this.ctx.loaders.getSessionId()),o.addChild(e.loadingAnimation),this.ctx.loaders.setBuddyPetState("working","Working..."),e.pendingWorkingMessage!==void 0&&(e.workingMessageOverride=e.pendingWorkingMessage||void 0,e.pendingWorkingMessage=void 0),this.ctx.loaders.startAgentRunTimer(),this.ctx.loaders.updateWorkingMessage({resetStallTimer:!1}),this.ctx.loaders.isInPlanMode()&&(e.planProgress=L(),e.planProgressPanel=new R(n,l),o.addChild(e.planProgressPanel),e.planProgressPanel.update(e.planProgress)),this.refreshTaskPanel(e,n,o).catch(()=>{}),this.taskUpdateUnsubscribe?.(),this.taskUpdateUnsubscribe=w(()=>{this.refreshTaskPanel(e,n,o).catch(()=>{})}),this.ctx.surface.restoreEditorFocusIfPossible(),this.ctx.layout.requestRender();break;case"message_start":if(t.message.role==="custom")this.ctx.layout.addMessageToChat(t.message),this.ctx.layout.requestRender();else if(t.message.role==="user"){const s=this.ctx.surface.getUserMessageText(t.message);if(e.optimisticUserMessages.length>0&&e.optimisticUserMessages[0]?.text===s){e.optimisticUserMessages.shift(),this.ctx.layout.updatePendingMessagesDisplay(),this.ctx.layout.requestRender();break}this.ctx.layout.addMessageToChat(t.message),this.ctx.layout.updatePendingMessagesDisplay(),this.ctx.layout.requestRender()}else t.message.role==="assistant"&&(e.streamingComponent=new S(void 0,e.hideThinkingBlock,this.ctx.surface.getMarkdownThemeWithSettings()),e.streamingMessage=t.message,a.addChild(e.streamingComponent),e.streamingComponent.updateContent(e.streamingMessage),this.ctx.layout.requestRender());break;case"message_update":if(e.streamingComponent&&t.message.role==="assistant"){e.loadingAnimation&&e.loadingAnimation.resetStallTimer(),e.streamingMessage=t.message,e.streamingComponent.updateContent(e.streamingMessage),a.markDirty(e.streamingComponent);for(const s of e.streamingMessage.content)if(s.type==="toolCall"){if(!this.ctx.toolTrace.shouldRenderToolTrace(s.name))continue;if(e.pendingTools.has(s.id)){const r=e.pendingTools.get(s.id);r&&(r.updateArgs(s.arguments),a.markDirty(r))}else{a.addChild(new y("",0,0));const r=new x(s.name,s.arguments,{showImages:this.ctx.toolTrace.getShowImages()},this.ctx.toolTrace.getRegisteredToolDefinition(s.name),n);r.setExpanded(e.toolOutputExpanded),a.addChild(r),e.pendingTools.set(s.id,r)}}this.ctx.layout.requestRender()}break;case"message_end":if(t.message.role==="user")break;if(e.streamingComponent&&t.message.role==="assistant"){e.streamingMessage=t.message;let s;if(e.streamingMessage.stopReason==="aborted"){const r=this.ctx.runtime.getRetryAttempt();s=r>0?`Aborted after ${r} retry attempt${r>1?"s":""}`:"Operation aborted",e.streamingMessage.errorMessage=s}if(e.streamingComponent.updateContent(e.streamingMessage),a.markDirty(e.streamingComponent),e.streamingMessage.stopReason==="aborted"||e.streamingMessage.stopReason==="error"){s||(s=e.streamingMessage.errorMessage||"Error");for(const[,r]of e.pendingTools.entries())r.updateResult({content:[{type:"text",text:s}],isError:!0}),a.markDirty(r);e.pendingTools.clear()}else for(const[,r]of e.pendingTools.entries())r.setArgsComplete(),a.markDirty(r);e.streamingComponent=void 0,e.streamingMessage=void 0,this.ctx.layout.invalidateFooter()}this.ctx.layout.requestRender();break;case"tool_execution_start":{if(e.planProgress&&e.planProgressPanel&&(U(e.planProgress,t.toolName,t.args),e.planProgressPanel.update(e.planProgress),this.ctx.layout.requestRender()),!this.ctx.toolTrace.shouldRenderToolTrace(t.toolName))break;if(!e.pendingTools.has(t.toolCallId)){const s=new x(t.toolName,t.args,{showImages:this.ctx.toolTrace.getShowImages()},this.ctx.toolTrace.getRegisteredToolDefinition(t.toolName),n);s.setExpanded(e.toolOutputExpanded),a.addChild(s),e.pendingTools.set(t.toolCallId,s),this.ctx.layout.requestRender()}break}case"tool_execution_update":{const s=e.pendingTools.get(t.toolCallId);s&&(s.updateResult({...t.partialResult,isError:!1},!0),a.markDirty(s),this.ctx.layout.requestRender());break}case"tool_execution_end":{const s=e.pendingTools.get(t.toolCallId);s&&(s.updateResult({...t.result,isError:t.isError}),a.markDirty(s),e.pendingTools.delete(t.toolCallId),this.ctx.layout.requestRender());break}case"agent_end":{C("agent_end received");const s=e.agentRunStartMs!==void 0?this.ctx.loaders.formatElapsedSeconds(Date.now()-e.agentRunStartMs):void 0;this.ctx.loaders.stopAgentRunTimer(),e.agentRunStartMs=void 0,e.workingMessageOverride=void 0,e.loadingAnimation&&(e.loadingAnimation.stop(),e.loadingAnimation=void 0,o.clear()),e.streamingComponent&&(a.removeChild(e.streamingComponent),e.streamingComponent=void 0,e.streamingMessage=void 0),e.pendingTools.clear(),e.subAgentPanelComponent&&(o.removeChild(e.subAgentPanelComponent),e.subAgentPanelComponent=void 0),e.subAgentStates.clear(),e.planProgressPanel&&(o.removeChild(e.planProgressPanel),e.planProgressPanel=void 0),e.planProgress=void 0,e.taskStatusPanel&&(o.removeChild(e.taskStatusPanel),e.taskStatusPanel=void 0),this.taskAutoHideTimer&&(clearTimeout(this.taskAutoHideTimer),this.taskAutoHideTimer=void 0),this.ctx.runtime.clearAttachments(),this.ctx.loaders.setBuddyPetState("happy","Done!",{resetTo:"idle",afterMs:1800}),s&&this.ctx.surface.showStatus(`Completed in ${s}`),await this.ctx.runtime.checkShutdownRequested(),this.ctx.surface.restoreEditorFocusIfPossible(),this.ctx.layout.requestRender();break}case"sub_agent_start":{const s={id:t.subAgentId,agentType:t.agentType,description:t.description,isAsync:t.isAsync,isResolved:!1,isError:!1,toolUseCount:0,lastToolName:null,startTime:Date.now()};e.subAgentStates.set(t.subAgentId,s),e.subAgentPanelComponent||(e.subAgentPanelComponent=new M(n,l),o.addChild(e.subAgentPanelComponent)),e.subAgentPanelComponent.update(e.subAgentStates),this.ctx.layout.requestRender();break}case"sub_agent_tool_start":{const s=e.subAgentStates.get(t.subAgentId);s&&(s.lastToolName=t.toolName,e.subAgentPanelComponent&&e.subAgentPanelComponent.update(e.subAgentStates),this.ctx.layout.requestRender());break}case"sub_agent_tool_end":{const s=e.subAgentStates.get(t.subAgentId);s&&(s.toolUseCount+=1,s.lastToolName=null,e.subAgentPanelComponent&&e.subAgentPanelComponent.update(e.subAgentStates),this.ctx.layout.requestRender());break}case"sub_agent_end":{const s=e.subAgentStates.get(t.subAgentId);s&&(s.isResolved=!0,s.isError=!t.success,s.lastToolName=null,e.subAgentPanelComponent&&e.subAgentPanelComponent.update(e.subAgentStates),this.ctx.layout.requestRender());break}case"auto_compaction_start":{this.autoCompactionEscapeHandler=this.ctx.escape.getHandler(),this.ctx.escape.setHandler(()=>{this.ctx.runtime.abortCompaction()}),o.clear();const s=t.reason==="overflow"?"Context overflow detected, ":"";this.autoCompactionLoader=new g(n,l,`${s}Auto-compacting... (${this.ctx.loaders.getInterruptKeyHint()} to cancel)`),o.addChild(this.autoCompactionLoader),this.ctx.layout.requestRender();break}case"auto_compaction_end":{this.autoCompactionEscapeHandler&&(this.ctx.escape.setHandler(this.autoCompactionEscapeHandler),this.autoCompactionEscapeHandler=void 0),this.autoCompactionLoader&&(this.autoCompactionLoader.stop(),this.autoCompactionLoader=void 0,o.clear()),t.aborted?this.ctx.surface.showStatus("Auto-compaction cancelled"):t.result?(a.clear(),this.ctx.layout.rebuildChatFromMessages(),this.ctx.layout.addMessageToChat({role:"compactionSummary",tokensBefore:t.result.tokensBefore,summary:t.result.summary,timestamp:Date.now()}),this.ctx.layout.invalidateFooter()):t.errorMessage&&(a.addChild(new b(1)),a.addChild(new y(l.fg("error",t.errorMessage),1,0))),this.ctx.runtime.flushCompactionQueue({willRetry:t.willRetry}),this.ctx.layout.requestRender();break}case"auto_retry_start":{this.retryEscapeHandler=this.ctx.escape.getHandler(),this.ctx.escape.setHandler(()=>{this.ctx.runtime.abortRetry()}),o.clear();const s=Math.round(t.delayMs/1e3);this.retryLoader=new g(n,l,`Retrying (${t.attempt}/${t.maxAttempts}) in ${s}s... (${this.ctx.loaders.getInterruptKeyHint()} to cancel)`),o.addChild(this.retryLoader),this.ctx.layout.requestRender();break}case"auto_retry_end":{this.retryEscapeHandler&&(this.ctx.escape.setHandler(this.retryEscapeHandler),this.retryEscapeHandler=void 0),this.retryLoader&&(this.retryLoader.stop(),this.retryLoader=void 0,o.clear()),t.success||this.ctx.surface.showError(`Retry failed after ${t.attempt} attempts: ${t.finalError||"Unknown error"}`),this.ctx.layout.requestRender();break}}}static TASK_TOOL_NAMES=new Set(["TaskCreate","TaskUpdate","TaskList","TaskGet","TaskStop","TaskDelete"]);async refreshTaskPanel(t,e,n){const a=this.ctx.runtime.getAgentDir();if(a)try{const o=await T(a,m),s=o.filter(d=>!d.metadata?._internal).map(d=>({id:d.id,subject:d.subject,status:d.status,activeForm:d.activeForm,blockedBy:d.blockedBy.filter(p=>o.some(c=>c.id===p&&c.status!=="completed"))}));if(s.length===0){t.taskStatusPanel&&(n.removeChild(t.taskStatusPanel),t.taskStatusPanel=void 0),this.taskAutoHideTimer&&(clearTimeout(this.taskAutoHideTimer),this.taskAutoHideTimer=void 0);return}t.taskStatusPanel||(t.taskStatusPanel=new _(e,l),n.addChild(t.taskStatusPanel)),t.taskStatusPanel.update(s),this.ctx.layout.requestRender(),s.every(d=>d.status==="completed")?this.taskAutoHideTimer||(this.taskAutoHideTimer=setTimeout(async()=>{this.taskAutoHideTimer=void 0;const d=await T(a,m).catch(()=>[]);d.length>0&&d.every(c=>c.status==="completed")&&await E(a,m).catch(()=>{})},I)):this.taskAutoHideTimer&&(clearTimeout(this.taskAutoHideTimer),this.taskAutoHideTimer=void 0)}catch{}}}const D=["Phase 1: Initial Understanding","Phase 2: Design","Phase 3: Review","Phase 4: Final Plan","Phase 5: Call ExitPlanMode"];function L(){return{phases:D.map((i,t)=>({label:i,status:t===0?"in_progress":"pending"})),currentPhaseIndex:0,startTime:Date.now()}}u(L,"createInitialPlanProgress");function U(i,t,e){let n;if(t==="ExitPlanMode"){for(const a of i.phases)a.status="completed";i.currentPhaseIndex=i.phases.length;return}if(t==="Agent")(e.subagent_type??"").toLowerCase()==="plan"?n=1:n=0;else if(t==="Read"||t==="Grep"||t==="Find")n=2;else if(t==="Write"||t==="Edit")n=3;else return void 0;if(n>i.currentPhaseIndex){for(let a=i.currentPhaseIndex;a<n;a++)i.phases[a].status="completed";i.currentPhaseIndex=n,i.phases[n].status="in_progress"}}u(U,"detectPlanPhaseTransition");export{Y as StreamRenderController};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides TreeOverlayController + TreeOverlayContext — interactive session tree/fork/resume overlays
|
|
3
|
+
* [FROM]: Depends on AgentSession/SessionManager for session lifecycle, TUI containers/components, PromptHost-like prompts
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts for /tree, /fork, /resume, keybindings, extension session switch
|
|
5
|
+
* [HERE]: modes/interactive/controllers/tree-overlay-controller.ts — P5 tree-overlay slice (UI05, pure move + rename)
|
|
6
|
+
*
|
|
7
|
+
* Owns interactive session selection overlays only. It delegates reusable session lifecycle behavior to
|
|
8
|
+
* AgentSession and SessionManager; it does not parse or mutate session files directly except the existing
|
|
9
|
+
* rename-session callback through SessionManager.open().
|
|
10
|
+
*/
|
|
11
|
+
import type { Component, Container, TUI } from "@catui/tui";
|
|
12
|
+
import type { AgentSession } from "../../../core/runtime/agent-session.js";
|
|
13
|
+
import { SessionManager } from "../../../core/session/session-manager.js";
|
|
14
|
+
import type { KeybindingsManager } from "../../../core/platform/keybindings.js";
|
|
15
|
+
export interface TreeOverlaySurface {
|
|
16
|
+
showSelector(create: (done: () => void) => {
|
|
17
|
+
component: Component;
|
|
18
|
+
focus: Component;
|
|
19
|
+
}): void;
|
|
20
|
+
showStatus(message: string): void;
|
|
21
|
+
showError(message: string): void;
|
|
22
|
+
requestRender(): void;
|
|
23
|
+
getUi(): TUI;
|
|
24
|
+
getChatContainer(): Container;
|
|
25
|
+
getStatusContainer(): Container;
|
|
26
|
+
clearChat(): void;
|
|
27
|
+
clearTransientSessionUi(): void;
|
|
28
|
+
addSessionNavigationBanner(message: string): void;
|
|
29
|
+
renderInitialMessages(): void;
|
|
30
|
+
getEditorText(): string;
|
|
31
|
+
setEditorText(text: string): void;
|
|
32
|
+
getEscapeHandler(): (() => void) | undefined;
|
|
33
|
+
setEscapeHandler(handler: (() => void) | undefined): void;
|
|
34
|
+
}
|
|
35
|
+
export interface TreeOverlayPromptHost {
|
|
36
|
+
selector(title: string, options: string[]): Promise<string | undefined>;
|
|
37
|
+
editor(title: string, prefill?: string): Promise<string | undefined>;
|
|
38
|
+
}
|
|
39
|
+
export interface TreeOverlayContext {
|
|
40
|
+
session: AgentSession;
|
|
41
|
+
getSessionManager(): SessionManager;
|
|
42
|
+
surface: TreeOverlaySurface;
|
|
43
|
+
promptHost: TreeOverlayPromptHost;
|
|
44
|
+
keybindings: KeybindingsManager;
|
|
45
|
+
shutdown(): Promise<void>;
|
|
46
|
+
}
|
|
47
|
+
export declare class TreeOverlayController {
|
|
48
|
+
private readonly ctx;
|
|
49
|
+
constructor(ctx: TreeOverlayContext);
|
|
50
|
+
private get sessionManager();
|
|
51
|
+
showForkSelector(): void;
|
|
52
|
+
showTreeSelector(initialSelectedId?: string): void;
|
|
53
|
+
showSessionSelector(): void;
|
|
54
|
+
resumeSession(sessionPath: string): Promise<void>;
|
|
55
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var x=Object.defineProperty;var h=(m,e)=>x(m,"name",{value:e,configurable:!0});import{Spacer as d}from"@catui/tui";import{SessionManager as f}from"../../../core/session/session-manager.js";import{SessionSelectorComponent as g}from"../components/session-selector.js";import{TreeSelectorComponent as S}from"../components/tree-selector.js";import{UserMessageSelectorComponent as p}from"../components/user-message-selector.js";import{CatuiLoader as w}from"../components/catui-loader.js";import{appKey as C}from"../components/keybinding-hints.js";import{theme as y}from"../theme/theme.js";class q{static{h(this,"TreeOverlayController")}ctx;constructor(e){this.ctx=e}get sessionManager(){return this.ctx.getSessionManager()}showForkSelector(){const e=this.ctx.session.getUserMessagesForForking();if(e.length===0){this.ctx.surface.showStatus("No messages to fork from");return}this.ctx.surface.showSelector(i=>{const t=new p(e.map(r=>({id:r.entryId,text:r.text})),async r=>{const a=await this.ctx.session.fork(r);if(a.cancelled){i(),this.ctx.surface.requestRender();return}this.ctx.surface.clearChat(),this.ctx.surface.addSessionNavigationBanner("Branched session"),this.ctx.surface.renderInitialMessages(),this.ctx.surface.setEditorText(a.selectedText),i(),this.ctx.surface.showStatus("Branched to new session")},()=>{i(),this.ctx.surface.requestRender()});return{component:t,focus:t.getMessageList()}})}showTreeSelector(e){const i=this.sessionManager.getTree(),t=this.sessionManager.getLeafId();if(i.length===0){this.ctx.surface.showStatus("No entries in session");return}this.ctx.surface.showSelector(r=>{const a=new S(i,t,this.ctx.surface.getUi().terminal.rows,async n=>{if(n===t){r(),this.ctx.surface.showStatus("Already at this point");return}r();let c=!1,u;for(;;){const s=await this.ctx.promptHost.selector("Summarize branch?",["No summary","Summarize","Summarize with custom prompt"]);if(s===void 0){this.showTreeSelector(n);return}if(c=s!=="No summary",!(s==="Summarize with custom prompt"&&(u=await this.ctx.promptHost.editor("Custom summarization instructions"),u===void 0)))break}let o;const l=this.ctx.surface.getEscapeHandler();c&&(this.ctx.surface.setEscapeHandler(()=>{this.ctx.session.abortBranchSummary()}),this.ctx.surface.getChatContainer().addChild(new d(1)),o=new w(this.ctx.surface.getUi(),y,`Summarizing branch... (${C(this.ctx.keybindings,"interrupt")} to cancel)`),this.ctx.surface.getStatusContainer().addChild(o),this.ctx.surface.requestRender());try{const s=await this.ctx.session.navigateTree(n,{summarize:c,customInstructions:u});if(s.aborted){this.ctx.surface.showStatus("Branch summarization cancelled"),this.showTreeSelector(n);return}if(s.cancelled){this.ctx.surface.showStatus("Navigation cancelled");return}this.ctx.surface.clearChat(),this.ctx.surface.addSessionNavigationBanner("Navigated session tree"),this.ctx.surface.renderInitialMessages(),s.editorText&&!this.ctx.surface.getEditorText().trim()&&this.ctx.surface.setEditorText(s.editorText),this.ctx.surface.showStatus("Navigated to selected point")}catch(s){this.ctx.surface.showError(s instanceof Error?s.message:String(s))}finally{o&&(o.stop(),this.ctx.surface.getStatusContainer().clear()),this.ctx.surface.setEscapeHandler(l)}},()=>{r(),this.ctx.surface.requestRender()},(n,c)=>{this.sessionManager.appendLabelChange(n,c),this.ctx.surface.requestRender()},e);return{component:a,focus:a}})}showSessionSelector(){this.ctx.surface.showSelector(e=>{const i=new g(t=>f.list(this.sessionManager.getCwd(),this.sessionManager.getSessionDir(),t),f.listAll,async t=>{e(),await this.resumeSession(t)},()=>{e(),this.ctx.surface.requestRender()},()=>{this.ctx.shutdown()},()=>this.ctx.surface.requestRender(),{renameSession:h(async(t,r)=>{const a=(r??"").trim();if(!a)return;f.open(t).appendSessionInfo(a)},"renameSession"),showRenameHint:!0,keybindings:this.ctx.keybindings},this.sessionManager.getSessionFile());return{component:i,focus:i}})}async resumeSession(e){this.ctx.surface.clearTransientSessionUi(),await this.ctx.session.switchSession(e),this.ctx.surface.clearChat(),this.ctx.surface.addSessionNavigationBanner("Resumed session"),this.ctx.surface.renderInitialMessages(),this.ctx.surface.showStatus("Resumed session")}}export{q as TreeOverlayController};
|