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,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides ModelSelectorComponent — model picker UI with scope/filter/add-OpenRouter affordances
|
|
3
|
+
* [FROM]: Depends on @catui/ai, @catui/tui, model-registry types, theme,
|
|
4
|
+
* DynamicBorder, keybinding hints
|
|
5
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts and components/index.ts; emits selected
|
|
6
|
+
* models only, while provider configuration is owned by the caller
|
|
7
|
+
* [HERE]: modes/interactive/components/model-selector.ts — presentation component for model selection
|
|
8
|
+
*/
|
|
9
|
+
import type { Model } from "@catui/ai/types";
|
|
10
|
+
import { Container, type Focusable, Input, type TUI } from "@catui/tui";
|
|
11
|
+
import type { ModelRegistry } from "../../../core/model-registry.js";
|
|
12
|
+
interface ScopedModelItem {
|
|
13
|
+
model: Model<any>;
|
|
14
|
+
thinkingLevel: string;
|
|
15
|
+
}
|
|
16
|
+
export declare class ModelSelectorComponent extends Container implements Focusable {
|
|
17
|
+
private searchInput;
|
|
18
|
+
private _focused;
|
|
19
|
+
private listContainer;
|
|
20
|
+
private allModels;
|
|
21
|
+
private scopedModelItems;
|
|
22
|
+
private activeModels;
|
|
23
|
+
private filteredModels;
|
|
24
|
+
private selectedIndex;
|
|
25
|
+
private currentModel?;
|
|
26
|
+
private modelRegistry;
|
|
27
|
+
private onSelectCallback;
|
|
28
|
+
private onCancelCallback;
|
|
29
|
+
private errorMessage?;
|
|
30
|
+
private tui;
|
|
31
|
+
private scopedModels;
|
|
32
|
+
private scope;
|
|
33
|
+
private scopeText?;
|
|
34
|
+
private scopeHintText?;
|
|
35
|
+
private filterByProvider?;
|
|
36
|
+
/** When set, Ctrl+N runs this (parent closes selector and prompts for OpenRouter model id). */
|
|
37
|
+
private onAddOpenRouterModel?;
|
|
38
|
+
/** When set, Ctrl+K runs this (parent closes selector and prompts for API key). */
|
|
39
|
+
private onConfigureApiKey?;
|
|
40
|
+
get focused(): boolean;
|
|
41
|
+
set focused(value: boolean);
|
|
42
|
+
constructor(tui: TUI, currentModel: Model<any> | undefined, modelRegistry: ModelRegistry, scopedModels: ReadonlyArray<ScopedModelItem>, onSelect: (model: Model<any>) => void, onCancel: () => void, initialSearchInput?: string, filterByProvider?: string, onAddOpenRouterModel?: () => void, onConfigureApiKey?: () => void);
|
|
43
|
+
private loadModels;
|
|
44
|
+
private sortModels;
|
|
45
|
+
private getScopeText;
|
|
46
|
+
private getScopeHintText;
|
|
47
|
+
private setScope;
|
|
48
|
+
private filterModels;
|
|
49
|
+
private updateList;
|
|
50
|
+
handleInput(keyData: string): void;
|
|
51
|
+
/**
|
|
52
|
+
* Trigger remote model discovery and reload the model list.
|
|
53
|
+
* Shows a brief status message while refreshing.
|
|
54
|
+
*/
|
|
55
|
+
private refreshDiscovery;
|
|
56
|
+
private handleSelect;
|
|
57
|
+
getSearchInput(): Input;
|
|
58
|
+
}
|
|
59
|
+
export {};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var w=Object.defineProperty;var M=(m,e)=>w(m,"name",{value:e,configurable:!0});import{modelsAreEqual as p}from"@catui/ai/models";import{Container as g,fuzzyFilter as T,getEditorKeybindings as S,Input as R,matchesKey as u,Spacer as n,Text as o}from"@catui/tui";import{theme as d}from"../theme/theme.js";import{DynamicBorder as C}from"./dynamic-border.js";import{keyHint as $}from"./keybinding-hints.js";class K extends g{static{M(this,"ModelSelectorComponent")}searchInput;_focused=!1;listContainer;allModels=[];scopedModelItems=[];activeModels=[];filteredModels=[];selectedIndex=0;currentModel;modelRegistry;onSelectCallback;onCancelCallback;errorMessage;tui;scopedModels;scope="all";scopeText;scopeHintText;filterByProvider;onAddOpenRouterModel;onConfigureApiKey;get focused(){return this._focused}set focused(e){this._focused=e,this.searchInput.focused=e}constructor(e,t,s,i,l,r,h,c,a,f){super(),this.tui=e,this.currentModel=t,this.modelRegistry=s,this.scopedModels=i,this.filterByProvider=c,this.onAddOpenRouterModel=a,this.onConfigureApiKey=f,this.scope=i.length>0&&!c?"scoped":"all",this.onSelectCallback=l,this.onCancelCallback=r,this.addChild(new C),this.addChild(new n(1)),this.filterByProvider?this.addChild(new o(d.fg("muted",`Provider: ${this.filterByProvider}`),0,0)):i.length>0&&(this.scopeText=new o(this.getScopeText(),0,0),this.addChild(this.scopeText),this.scopeHintText=new o(this.getScopeHintText(),0,0),this.addChild(this.scopeHintText)),this.addChild(new n(1)),this.searchInput=new R,h&&this.searchInput.setValue(h),this.searchInput.onSubmit=()=>{this.filteredModels[this.selectedIndex]&&this.handleSelect(this.filteredModels[this.selectedIndex].model)},this.addChild(this.searchInput),this.onAddOpenRouterModel&&(this.addChild(new n(1)),this.addChild(new o(d.fg("muted","Ctrl+N: add OpenRouter model by id (same as openrouter.ai)"),0,0))),this.addChild(new n(1)),this.addChild(new o(d.fg("muted","Ctrl+R: refresh remote models (discovery)"),0,0)),this.listContainer=new g,this.addChild(this.listContainer),this.addChild(new n(1)),this.addChild(new C),this.loadModels().then(()=>{h?this.filterModels(h):this.updateList(),this.tui.requestRender()})}async loadModels(){let e;this.modelRegistry.refresh();const t=this.modelRegistry.getError();t&&(this.errorMessage=t);try{e=this.modelRegistry.getAll().map(i=>({provider:i.provider,id:i.id,model:i}))}catch(s){this.allModels=[],this.scopedModelItems=[],this.activeModels=[],this.filteredModels=[],this.errorMessage=s instanceof Error?s.message:String(s);return}if(this.allModels=this.sortModels(e),this.filterByProvider){const s=this.filterByProvider.toLowerCase();this.allModels=this.allModels.filter(i=>i.provider.toLowerCase()===s)}this.scopedModelItems=this.sortModels(this.scopedModels.map(s=>({provider:s.model.provider,id:s.model.id,model:s.model}))),this.activeModels=this.scope==="scoped"?this.scopedModelItems:this.allModels,this.filterByProvider&&(this.activeModels=this.allModels),this.filteredModels=this.activeModels,this.selectedIndex=Math.min(this.selectedIndex,Math.max(0,this.filteredModels.length-1))}sortModels(e){const t=[...e];return t.sort((s,i)=>{const l=p(this.currentModel,s.model),r=p(this.currentModel,i.model);return l&&!r?-1:!l&&r?1:s.provider.localeCompare(i.provider)}),t}getScopeText(){const e=this.scope==="all"?d.fg("accent","all"):d.fg("muted","all"),t=this.scope==="scoped"?d.fg("accent","scoped"):d.fg("muted","scoped");return`${d.fg("muted","Scope: ")}${e}${d.fg("muted"," | ")}${t}`}getScopeHintText(){return $("tab","scope")+d.fg("muted"," (all/scoped)")}setScope(e){this.scope!==e&&(this.scope=e,this.activeModels=this.scope==="scoped"?this.scopedModelItems:this.allModels,this.selectedIndex=0,this.filterModels(this.searchInput.getValue()),this.scopeText&&this.scopeText.setText(this.getScopeText()))}filterModels(e){this.filteredModels=e?T(this.activeModels,e,({id:t,provider:s})=>`${t} ${s}`):this.activeModels,this.selectedIndex=Math.min(this.selectedIndex,Math.max(0,this.filteredModels.length-1)),this.updateList()}updateList(){this.listContainer.clear();const e=10,t=Math.max(0,Math.min(this.selectedIndex-Math.floor(e/2),this.filteredModels.length-e)),s=Math.min(t+e,this.filteredModels.length);for(let i=t;i<s;i++){const l=this.filteredModels[i];if(!l)continue;const r=i===this.selectedIndex,h=p(this.currentModel,l.model),c=!this.modelRegistry.authStorage.hasAuth(l.provider),a=r?d.fg("accent","->"):" ",f=r?d.fg("accent",l.id):l.id,x=d.fg("muted",`[${l.provider}]`),I=l.model.source==="discovery"?d.fg("muted"," (remote)"):"",v=h?d.fg("success"," [current]"):"",y=c?d.fg("warning"," [needs API key]"):"";this.listContainer.addChild(new o(`${a}${f} ${x}${I}${v}${y}`,0,0))}if((t>0||s<this.filteredModels.length)&&this.listContainer.addChild(new o(d.fg("muted",` (${this.selectedIndex+1}/${this.filteredModels.length})`),0,0)),this.errorMessage)for(const i of this.errorMessage.split(`
|
|
2
|
+
`))this.listContainer.addChild(new o(d.fg("error",i),0,0));else if(this.filteredModels.length===0)this.listContainer.addChild(new o(d.fg("muted"," No matching models"),0,0));else{const i=this.filteredModels[this.selectedIndex];this.listContainer.addChild(new n(1)),this.listContainer.addChild(new o(d.fg("muted",` Model Name: ${i.model.name}`),0,0))}}handleInput(e){const t=S();if(t.matches(e,"tab")){if(!this.filterByProvider&&this.scopedModelItems.length>0){const s=this.scope==="all"?"scoped":"all";this.setScope(s),this.scopeHintText&&this.scopeHintText.setText(this.getScopeHintText())}return}if(t.matches(e,"selectUp")){if(this.filteredModels.length===0)return;this.selectedIndex=this.selectedIndex===0?this.filteredModels.length-1:this.selectedIndex-1,this.updateList()}else if(t.matches(e,"selectDown")){if(this.filteredModels.length===0)return;this.selectedIndex=this.selectedIndex===this.filteredModels.length-1?0:this.selectedIndex+1,this.updateList()}else if(t.matches(e,"selectConfirm")){const s=this.filteredModels[this.selectedIndex];s&&this.handleSelect(s.model)}else t.matches(e,"selectCancel")?this.onCancelCallback():this.onAddOpenRouterModel&&u(e,"ctrl+n")?this.onAddOpenRouterModel():this.onConfigureApiKey&&u(e,"ctrl+k")?this.onConfigureApiKey():u(e,"ctrl+r")?this.refreshDiscovery():(this.searchInput.handleInput(e),this.filterModels(this.searchInput.getValue()))}async refreshDiscovery(){this.errorMessage=void 0,this.listContainer.clear(),this.listContainer.addChild(new o(d.fg("muted"," Refreshing remote models..."),0,0)),this.tui.requestRender();try{await this.modelRegistry.refreshWithDiscovery(),await this.loadModels(),this.searchInput.getValue()?this.filterModels(this.searchInput.getValue()):this.updateList()}catch{this.errorMessage="Failed to refresh remote models",this.updateList()}this.tui.requestRender()}async handleSelect(e){try{const t=this.modelRegistry.find(e.provider,e.id)??e;this.onSelectCallback(t)}catch(t){throw this.onCancelCallback(),t}}getSearchInput(){return this.searchInput}}export{K as ModelSelectorComponent};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* NotificationQueue - Priority-based notification system with auto-dismiss and dedup.
|
|
3
|
+
*
|
|
4
|
+
* Renders up to 3 visible notifications at a time, newest first.
|
|
5
|
+
* Each notification has a priority level that controls its auto-dismiss timeout.
|
|
6
|
+
* Notifications with the same key replace each other (dedup).
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* [WHO]: NotificationQueue
|
|
10
|
+
* [FROM]: Depends on @catui/tui
|
|
11
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts
|
|
12
|
+
* [HERE]: modes/interactive/components/notification-queue.ts -
|
|
13
|
+
*/
|
|
14
|
+
import { Container, type TUI } from "@catui/tui";
|
|
15
|
+
import type { Theme } from "../theme/theme.js";
|
|
16
|
+
export type NotificationPriority = "immediate" | "high" | "medium" | "low";
|
|
17
|
+
export type NotificationType = "info" | "warning" | "error";
|
|
18
|
+
export interface NotificationOptions {
|
|
19
|
+
/** Dedup key — replacing existing notification with the same key. */
|
|
20
|
+
key?: string;
|
|
21
|
+
priority?: NotificationPriority;
|
|
22
|
+
type?: NotificationType;
|
|
23
|
+
/** Auto-dismiss timeout in ms. 0 = never auto-dismiss. Default based on priority. */
|
|
24
|
+
duration?: number;
|
|
25
|
+
}
|
|
26
|
+
export declare class NotificationQueue extends Container {
|
|
27
|
+
private tui;
|
|
28
|
+
private theme;
|
|
29
|
+
private items;
|
|
30
|
+
private textComponents;
|
|
31
|
+
constructor(tui: TUI, theme: Theme);
|
|
32
|
+
/**
|
|
33
|
+
* Show a notification.
|
|
34
|
+
*/
|
|
35
|
+
notify(message: string, options?: NotificationOptions): void;
|
|
36
|
+
private scheduleDismiss;
|
|
37
|
+
private removeItem;
|
|
38
|
+
private renderVisible;
|
|
39
|
+
private getTypePrefix;
|
|
40
|
+
private rebuildChildren;
|
|
41
|
+
/**
|
|
42
|
+
* Clear all notifications.
|
|
43
|
+
*/
|
|
44
|
+
clearAll(): void;
|
|
45
|
+
/**
|
|
46
|
+
* Get the number of active notifications.
|
|
47
|
+
*/
|
|
48
|
+
get count(): number;
|
|
49
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var a=Object.defineProperty;var d=(c,e)=>a(c,"name",{value:e,configurable:!0});import{Container as p,Spacer as x,Text as g}from"@catui/tui";const u={immediate:3e3,high:5e3,medium:8e3,low:12e3},f={immediate:4,high:3,medium:2,low:1},h=3;class w extends p{static{d(this,"NotificationQueue")}tui;theme;items=[];textComponents=[];constructor(e,i){super(),this.tui=e,this.theme=i;for(let t=0;t<h;t++){const r=new g("",0,0);this.textComponents.push(r)}this.rebuildChildren()}notify(e,i){const t=i?.priority??"medium",r=i?.type??"info",n=i?.key;if(n){const s=this.items.find(l=>l.key===n);if(s){s.timer&&clearTimeout(s.timer),s.message=e,s.priority=t,s.type=r,s.createdAt=Date.now(),s.timer=this.scheduleDismiss(s),this.renderVisible();return}}const o={key:n,message:e,priority:t,type:r,createdAt:Date.now(),timer:void 0};for((i?.duration??u[t])>0&&(o.timer=this.scheduleDismiss(o)),this.items.unshift(o);this.items.length>20;){const s=this.items.pop();s?.timer&&clearTimeout(s.timer)}this.renderVisible()}scheduleDismiss(e){const i=u[e.priority];return setTimeout(()=>{this.removeItem(e)},i)}removeItem(e){e.timer&&(clearTimeout(e.timer),e.timer=void 0);const i=this.items.indexOf(e);i!==-1&&this.items.splice(i,1),this.renderVisible()}renderVisible(){const i=[...this.items].sort((t,r)=>{const n=f[r.priority]-f[t.priority];return n!==0?n:r.createdAt-t.createdAt}).slice(0,h);for(let t=0;t<h;t++){const r=this.textComponents[t];if(t<i.length){const n=i[t],o=this.getTypePrefix(n.type),m=Math.floor((Date.now()-n.createdAt)/1e3),s=m>0?this.theme.fg("dim",` ${m}s`):"";r.setText(`${o} ${n.message}${s}`)}else r.setText("")}this.tui.requestRender()}getTypePrefix(e){switch(e){case"error":return this.theme.fg("error","!");case"warning":return this.theme.fg("warning","!");default:return this.theme.fg("accent","i")}}rebuildChildren(){this.clear(),this.addChild(new x(1));for(const e of this.textComponents)this.addChild(e)}clearAll(){for(const e of this.items)e.timer&&clearTimeout(e.timer);this.items=[],this.renderVisible()}get count(){return this.items.length}}export{w as NotificationQueue};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: OAuthSelectorComponent
|
|
3
|
+
* [FROM]: Depends on @catui/ai, @catui/tui, ../theme/theme.js, ./dynamic-border.js
|
|
4
|
+
* [TO]: Consumed by modes/interactive/components/index.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/oauth-selector.ts - OAuth provider selector
|
|
6
|
+
*/
|
|
7
|
+
import { Container } from "@catui/tui";
|
|
8
|
+
export interface ProviderSelectorItem {
|
|
9
|
+
id: string;
|
|
10
|
+
name: string;
|
|
11
|
+
authType: "oauth" | "api_key";
|
|
12
|
+
loggedIn?: boolean;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Component that renders a provider selector
|
|
16
|
+
*/
|
|
17
|
+
export declare class OAuthSelectorComponent extends Container {
|
|
18
|
+
private listContainer;
|
|
19
|
+
private allProviders;
|
|
20
|
+
private selectedIndex;
|
|
21
|
+
private mode;
|
|
22
|
+
private onSelectCallback;
|
|
23
|
+
private onCancelCallback;
|
|
24
|
+
private title;
|
|
25
|
+
constructor(mode: "login" | "logout", providers: ProviderSelectorItem[], onSelect: (providerId: string) => void, onCancel: () => void, options?: {
|
|
26
|
+
title?: string;
|
|
27
|
+
});
|
|
28
|
+
private updateList;
|
|
29
|
+
handleInput(keyData: string): void;
|
|
30
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var f=Object.defineProperty;var h=(a,e)=>f(a,"name",{value:e,configurable:!0});import{Container as r,getEditorKeybindings as g,Spacer as d,TruncatedText as o}from"@catui/tui";import{theme as l}from"../theme/theme.js";import{DynamicBorder as C}from"./dynamic-border.js";class b extends r{static{h(this,"OAuthSelectorComponent")}listContainer;allProviders=[];selectedIndex=0;mode;onSelectCallback;onCancelCallback;title;constructor(e,t,i,n,s){super(),this.mode=e,this.allProviders=t,this.onSelectCallback=i,this.onCancelCallback=n,this.title=s?.title??(e==="login"?"Select provider to login:":"Select provider to logout:"),this.addChild(new C),this.addChild(new d(1)),this.addChild(new o(l.bold(this.title))),this.addChild(new d(1)),this.listContainer=new r,this.addChild(this.listContainer),this.addChild(new d(1)),this.addChild(new C),this.updateList()}updateList(){this.listContainer.clear();for(let e=0;e<this.allProviders.length;e++){const t=this.allProviders[e];if(!t)continue;const i=e===this.selectedIndex,n=t.loggedIn?l.fg("success"," \u2713 configured"):"";let s="";if(i){const c=l.fg("accent","\u2192 "),m=l.fg("accent",t.name);s=c+m+n}else s=` ${t.name}`+n;this.listContainer.addChild(new o(s,0,0))}if(this.allProviders.length===0){const e=this.mode==="login"?"No providers available":"No providers logged in. Use /login first.";this.listContainer.addChild(new o(l.fg("muted",` ${e}`),0,0))}}handleInput(e){const t=g();if(t.matches(e,"selectUp"))this.selectedIndex=Math.max(0,this.selectedIndex-1),this.updateList();else if(t.matches(e,"selectDown"))this.selectedIndex=Math.min(this.allProviders.length-1,this.selectedIndex+1),this.updateList();else if(t.matches(e,"selectConfirm")){const i=this.allProviders[this.selectedIndex];i&&this.onSelectCallback(i.id)}else t.matches(e,"selectCancel")&&this.onCancelCallback()}}export{b as OAuthSelectorComponent};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides PersonaSelectorComponent — persona picker UI with search and keyboard navigation
|
|
3
|
+
* [FROM]: Depends on @catui/tui, theme, DynamicBorder, keybinding hints
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts; emits selected persona id
|
|
5
|
+
* [HERE]: modes/interactive/components/persona-selector.ts — presentation component for persona selection
|
|
6
|
+
*/
|
|
7
|
+
import { Container, type Focusable, type TUI } from "@catui/tui";
|
|
8
|
+
export declare class PersonaSelectorComponent extends Container implements Focusable {
|
|
9
|
+
private searchInput;
|
|
10
|
+
private _focused;
|
|
11
|
+
private listContainer;
|
|
12
|
+
private allPersonas;
|
|
13
|
+
private filteredPersonas;
|
|
14
|
+
private selectedIndex;
|
|
15
|
+
private onSelectCallback;
|
|
16
|
+
private onCancelCallback;
|
|
17
|
+
private tui;
|
|
18
|
+
get focused(): boolean;
|
|
19
|
+
set focused(value: boolean);
|
|
20
|
+
constructor(tui: TUI, personaIds: string[], activePersonaId: string | undefined, getDescription: (id: string) => string, onSelect: (personaId: string) => void, onCancel: () => void);
|
|
21
|
+
private filterPersonas;
|
|
22
|
+
private updateList;
|
|
23
|
+
handleInput(keyData: string): void;
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var I=Object.defineProperty;var f=(o,e)=>I(o,"name",{value:e,configurable:!0});import{Container as u,fuzzyFilter as P,getEditorKeybindings as x,Input as g,Spacer as r,Text as c}from"@catui/tui";import{theme as d}from"../theme/theme.js";import{DynamicBorder as C}from"./dynamic-border.js";class v extends u{static{f(this,"PersonaSelectorComponent")}searchInput;_focused=!1;listContainer;allPersonas=[];filteredPersonas=[];selectedIndex=0;onSelectCallback;onCancelCallback;tui;get focused(){return this._focused}set focused(e){this._focused=e,this.searchInput.focused=e}constructor(e,t,n,l,i,a){super(),this.tui=e,this.onSelectCallback=i,this.onCancelCallback=a,this.allPersonas=t.map(s=>({id:s,description:l(s),isActive:s===n})),this.allPersonas.sort((s,h)=>s.isActive&&!h.isActive?-1:!s.isActive&&h.isActive?1:s.id.localeCompare(h.id)),this.filteredPersonas=this.allPersonas,this.addChild(new C),this.addChild(new r(1)),this.addChild(new c(d.fg("muted","Select a persona to switch to:"),0,0)),this.addChild(new r(1)),this.searchInput=new g,this.searchInput.onSubmit=()=>{const s=this.filteredPersonas[this.selectedIndex];s&&this.onSelectCallback(s.id)},this.addChild(this.searchInput),this.addChild(new r(1)),this.listContainer=new u,this.addChild(this.listContainer),this.addChild(new r(1)),this.addChild(new C),this.updateList()}filterPersonas(e){this.filteredPersonas=e?P(this.allPersonas,e,t=>`${t.id} ${t.description}`):this.allPersonas,this.selectedIndex=Math.min(this.selectedIndex,Math.max(0,this.filteredPersonas.length-1)),this.updateList()}updateList(){this.listContainer.clear();const e=10,t=Math.max(0,Math.min(this.selectedIndex-Math.floor(e/2),this.filteredPersonas.length-e)),n=Math.min(t+e,this.filteredPersonas.length);for(let l=t;l<n;l++){const i=this.filteredPersonas[l];if(!i)continue;const a=l===this.selectedIndex,s=a?d.fg("accent","->"):" ",h=a?d.fg("accent",i.id):i.id,p=i.isActive?d.fg("success"," [active]"):"",m=i.description?d.fg("muted",` \u2014 ${i.description}`):"";this.listContainer.addChild(new c(`${s} ${h}${p}${m}`,0,0))}(t>0||n<this.filteredPersonas.length)&&this.listContainer.addChild(new c(d.fg("muted",` (${this.selectedIndex+1}/${this.filteredPersonas.length})`),0,0)),this.filteredPersonas.length===0&&this.listContainer.addChild(new c(d.fg("muted"," No personas found"),0,0))}handleInput(e){const t=x();if(t.matches(e,"selectUp")){if(this.filteredPersonas.length===0)return;this.selectedIndex=this.selectedIndex===0?this.filteredPersonas.length-1:this.selectedIndex-1,this.updateList()}else if(t.matches(e,"selectDown")){if(this.filteredPersonas.length===0)return;this.selectedIndex=this.selectedIndex===this.filteredPersonas.length-1?0:this.selectedIndex+1,this.updateList()}else if(t.matches(e,"selectConfirm")){const n=this.filteredPersonas[this.selectedIndex];n&&this.onSelectCallback(n.id)}else t.matches(e,"selectCancel")?this.onCancelCallback():(this.searchInput.handleInput(e),this.filterPersonas(this.searchInput.getValue()))}}export{v as PersonaSelectorComponent};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: PlanProgressPanelComponent - renders plan execution progress with phase checkboxes
|
|
3
|
+
* [FROM]: Depends on @catui/tui, ../state/interactive-state (PlanProgressState)
|
|
4
|
+
* [TO]: Consumed by StreamRenderController
|
|
5
|
+
* [HERE]: modes/interactive/components/plan-progress-panel.ts - CC-style plan execution TUI panel
|
|
6
|
+
*/
|
|
7
|
+
import { Container, type TUI } from "@catui/tui";
|
|
8
|
+
import type { Theme } from "../theme/theme.js";
|
|
9
|
+
import type { PlanProgressState } from "../state/interactive-state.js";
|
|
10
|
+
export declare class PlanProgressPanelComponent extends Container {
|
|
11
|
+
private tui;
|
|
12
|
+
private theme;
|
|
13
|
+
private spinnerFrame;
|
|
14
|
+
private headerText;
|
|
15
|
+
private phaseLines;
|
|
16
|
+
private isCondensed;
|
|
17
|
+
private condensedText;
|
|
18
|
+
private startTime;
|
|
19
|
+
constructor(tui: TUI, theme: Theme);
|
|
20
|
+
/** Rebuild the entire panel from current plan progress state. */
|
|
21
|
+
update(state: PlanProgressState): void;
|
|
22
|
+
private renderFull;
|
|
23
|
+
private renderCondensed;
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var T=Object.defineProperty;var c=(i,e)=>T(i,"name",{value:e,configurable:!0});import{Container as x,Spacer as $,Text as l}from"@catui/tui";const p=["\u28FE","\u28FD","\u28FB","\u28BF","\u287F","\u28DF","\u28EF","\u28F7"],C=16;class F extends x{static{c(this,"PlanProgressPanelComponent")}tui;theme;spinnerFrame=0;headerText;phaseLines=[];isCondensed=!1;condensedText;startTime=0;constructor(e,s){super(),this.tui=e,this.theme=s,this.headerText=new l("",0,0),this.addChild(new $(1)),this.addChild(this.headerText)}update(e){this.startTime=e.startTime;const s=e.phases.some(n=>n.status==="in_progress"),h=e.phases.every(n=>n.status==="completed");s&&(this.spinnerFrame=(this.spinnerFrame+1)%p.length);const o=s?this.theme.fg("accent",p[this.spinnerFrame]):h?this.theme.fg("success","\u2714"):this.theme.fg("dim","\u25FC"),r=this.tui.terminal?.rows??24,a=1+e.phases.length;this.isCondensed=r<C||r-a<4;for(const n of this.phaseLines)super.removeChild(n);this.condensedText&&(super.removeChild(this.condensedText),this.condensedText=void 0),this.phaseLines=[],this.isCondensed?this.renderCondensed(e,o,s):this.renderFull(e,o,s)}renderFull(e,s,h){const o=Date.now()-e.startTime,r=u(o),a=e.tokenCount!==void 0?` ${this.theme.fg("dim","\xB7")} ${this.theme.fg("dim",b(e.tokenCount))}`:"",n=h?"Planning\u2026":e.phases.every(d=>d.status==="completed")?"Plan complete":"Planning paused";this.headerText.setText(` ${s} ${n} ${this.theme.fg("dim",`(${r}${a})`)}`);for(let d=0;d<e.phases.length;d++){const t=e.phases[d],f=t.status==="completed"?this.theme.fg("success","\u2714"):t.status==="in_progress"?this.theme.fg("accent","\u25FC"):this.theme.fg("dim","\u25FB"),g=t.status==="completed"?this.theme.fg("dim",t.label):t.status==="in_progress"?t.label:this.theme.fg("dim",t.label),m=new l(` \u23BF ${f} ${g}`,0,0);this.phaseLines.push(m),this.addChild(m)}}renderCondensed(e,s,h){const o=e.phases.find(t=>t.status==="in_progress")??e.phases.find(t=>t.status==="pending"),r=Date.now()-e.startTime,a=u(r),n=o?o.label:"Done",d=` ${s} ${n} ${this.theme.fg("dim",`(${a})`)}`;this.condensedText=new l(d,0,0),this.addChild(this.condensedText),this.headerText.setText("")}}function u(i){const e=Math.floor(i/1e3),s=Math.floor(e/60),h=e%60;return s>0?`${s}m ${h}s`:`${h}s`}c(u,"formatElapsed");function b(i){return i>=1e3?`${(i/1e3).toFixed(1)}k tokens`:`${i} tokens`}c(b,"formatTokenCount");export{F as PlanProgressPanelComponent};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: ProviderSelectorComponent
|
|
3
|
+
* [FROM]: Depends on @catui/tui, ../theme/theme.js, ./dynamic-border.js
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/provider-selector.ts -
|
|
6
|
+
* Adds search to provider selection when /model has many providers
|
|
7
|
+
*/
|
|
8
|
+
import { type Focusable, Container, Input } from "@catui/tui";
|
|
9
|
+
export declare class ProviderSelectorComponent extends Container implements Focusable {
|
|
10
|
+
private searchInput;
|
|
11
|
+
private listContainer;
|
|
12
|
+
private allProviders;
|
|
13
|
+
private filteredProviders;
|
|
14
|
+
private selectedIndex;
|
|
15
|
+
private onSelectCallback;
|
|
16
|
+
private onCancelCallback;
|
|
17
|
+
private _focused;
|
|
18
|
+
get focused(): boolean;
|
|
19
|
+
set focused(value: boolean);
|
|
20
|
+
constructor(providers: string[], currentProvider: string | undefined, onSelect: (provider: string) => void, onCancel: () => void);
|
|
21
|
+
private filterProviders;
|
|
22
|
+
private updateList;
|
|
23
|
+
handleInput(keyData: string): void;
|
|
24
|
+
getSearchInput(): Input;
|
|
25
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var I=Object.defineProperty;var c=(o,e)=>I(o,"name",{value:e,configurable:!0});import{Container as a,fuzzyFilter as v,getEditorKeybindings as x,Input as P,Spacer as r,Text as h}from"@catui/tui";import{getCustomProtocolProviderDefinition as g,isCustomProtocolProvider as b}from"../../../core/model/custom-providers.js";import{theme as l}from"../theme/theme.js";import{DynamicBorder as f}from"./dynamic-border.js";class M extends a{static{c(this,"ProviderSelectorComponent")}searchInput;listContainer;allProviders;filteredProviders;selectedIndex=0;onSelectCallback;onCancelCallback;_focused=!1;get focused(){return this._focused}set focused(e){this._focused=e,this.searchInput.focused=e}constructor(e,i,s,n){if(super(),this.onSelectCallback=s,this.onCancelCallback=n,this.allProviders=e.map(t=>{const d=b(t)?g(t):void 0;return{value:t,label:d?.label??t,description:d?.description,isCurrent:t===i}}),this.filteredProviders=[...this.allProviders],i){const t=this.allProviders.findIndex(d=>d.value===i);t>=0&&(this.selectedIndex=t)}this.addChild(new f),this.addChild(new r(1)),this.addChild(new h(l.fg("muted","Search provider:"),0,0)),this.addChild(new r(1)),this.searchInput=new P,this.searchInput.onSubmit=()=>{this.filteredProviders[this.selectedIndex]&&this.onSelectCallback(this.filteredProviders[this.selectedIndex].value)},this.addChild(this.searchInput),this.addChild(new r(1)),this.listContainer=new a,this.addChild(this.listContainer),this.addChild(new r(1)),this.addChild(new f),this.updateList()}filterProviders(e){const i=e?v(this.allProviders,e,s=>`${s.label} ${s.value}`):[...this.allProviders];this.filteredProviders=i,this.selectedIndex=0,this.updateList()}updateList(){for(;this.listContainer.children.length>0;)this.listContainer.children.pop();const e=10,i=Math.max(0,Math.min(this.selectedIndex-Math.floor(e/2),this.filteredProviders.length-e)),s=Math.min(i+e,this.filteredProviders.length);for(let n=i;n<s;n++){const t=this.filteredProviders[n];if(!t)continue;const d=n===this.selectedIndex,u=d?l.fg("accent","->"):" ",C=d?l.fg("accent",t.label):t.label,m=t.isCurrent?l.fg("success"," [current]"):"",p=t.description?l.fg("muted",` ${t.description}`):"";this.listContainer.addChild(new h(`${u}${C}${m}${p}`,0,0))}(i>0||s<this.filteredProviders.length)&&this.listContainer.addChild(new h(l.fg("muted",` (${this.selectedIndex+1}/${this.filteredProviders.length})`),0,0)),this.filteredProviders.length===0&&this.listContainer.addChild(new h(l.fg("muted"," No matching providers"),0,0))}handleInput(e){const i=x();if(i.matches(e,"selectUp")){if(this.filteredProviders.length===0)return;this.selectedIndex=this.selectedIndex===0?this.filteredProviders.length-1:this.selectedIndex-1,this.updateList()}else if(i.matches(e,"selectDown")){if(this.filteredProviders.length===0)return;this.selectedIndex=this.selectedIndex===this.filteredProviders.length-1?0:this.selectedIndex+1,this.updateList()}else if(i.matches(e,"selectConfirm")){const s=this.filteredProviders[this.selectedIndex];s&&this.onSelectCallback(s.value)}else i.matches(e,"selectCancel")?this.onCancelCallback():(this.searchInput.handleInput(e),this.filterProviders(this.searchInput.getValue()))}getSearchInput(){return this.searchInput}}export{M as ProviderSelectorComponent};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: RawText - renders pre-formatted ANSI text without padding
|
|
3
|
+
* [FROM]: Depends on @catui/tui Component
|
|
4
|
+
* [TO]: Consumed by modes/interactive/interactive-mode.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/raw-text.ts - raw ANSI text component
|
|
6
|
+
*/
|
|
7
|
+
import type { Component } from "@catui/tui";
|
|
8
|
+
/**
|
|
9
|
+
* RawText - renders pre-formatted ANSI text lines without auto-padding.
|
|
10
|
+
* Use this when you have pre-formatted content (like a status card) that
|
|
11
|
+
* already has the exact width you want, and don't want TUI to pad it.
|
|
12
|
+
*/
|
|
13
|
+
export declare class RawText implements Component {
|
|
14
|
+
private lines;
|
|
15
|
+
constructor(text: string);
|
|
16
|
+
setText(text: string): void;
|
|
17
|
+
invalidate(): void;
|
|
18
|
+
render(_width: number): string[];
|
|
19
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: ModelsConfig, ModelsCallbacks, ScopedModelsSelectorComponent
|
|
3
|
+
* [FROM]: Depends on ../theme/theme.js, ./dynamic-border.js
|
|
4
|
+
* [TO]: Consumed by modes/interactive/components/index.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/scoped-models-selector.ts -
|
|
6
|
+
*/
|
|
7
|
+
import type { Model } from "@catui/ai/types";
|
|
8
|
+
import { Container, type Focusable, Input } from "@catui/tui";
|
|
9
|
+
export interface ModelsConfig {
|
|
10
|
+
allModels: Model<any>[];
|
|
11
|
+
enabledModelIds: Set<string>;
|
|
12
|
+
/** true if enabledModels setting is defined (empty = all enabled) */
|
|
13
|
+
hasEnabledModelsFilter: boolean;
|
|
14
|
+
}
|
|
15
|
+
export interface ModelsCallbacks {
|
|
16
|
+
/** Called when a model is toggled (session-only, no persist) */
|
|
17
|
+
onModelToggle: (modelId: string, enabled: boolean) => void;
|
|
18
|
+
/** Called when user wants to persist current selection to settings */
|
|
19
|
+
onPersist: (enabledModelIds: string[]) => void;
|
|
20
|
+
/** Called when user enables all models. Returns list of all model IDs. */
|
|
21
|
+
onEnableAll: (allModelIds: string[]) => void;
|
|
22
|
+
/** Called when user clears all models */
|
|
23
|
+
onClearAll: () => void;
|
|
24
|
+
/** Called when user toggles all models for a provider. Returns affected model IDs. */
|
|
25
|
+
onToggleProvider: (provider: string, modelIds: string[], enabled: boolean) => void;
|
|
26
|
+
onCancel: () => void;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Component for enabling/disabling models for Ctrl+P cycling.
|
|
30
|
+
* Changes are session-only until explicitly persisted with Ctrl+S.
|
|
31
|
+
*/
|
|
32
|
+
export declare class ScopedModelsSelectorComponent extends Container implements Focusable {
|
|
33
|
+
private modelsById;
|
|
34
|
+
private allIds;
|
|
35
|
+
private enabledIds;
|
|
36
|
+
private filteredItems;
|
|
37
|
+
private selectedIndex;
|
|
38
|
+
private searchInput;
|
|
39
|
+
private _focused;
|
|
40
|
+
get focused(): boolean;
|
|
41
|
+
set focused(value: boolean);
|
|
42
|
+
private listContainer;
|
|
43
|
+
private footerText;
|
|
44
|
+
private callbacks;
|
|
45
|
+
private maxVisible;
|
|
46
|
+
private isDirty;
|
|
47
|
+
constructor(config: ModelsConfig, callbacks: ModelsCallbacks);
|
|
48
|
+
private buildItems;
|
|
49
|
+
private getFooterText;
|
|
50
|
+
private refresh;
|
|
51
|
+
private updateList;
|
|
52
|
+
handleInput(data: string): void;
|
|
53
|
+
getSearchInput(): Input;
|
|
54
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var y=Object.defineProperty;var c=(l,e)=>y(l,"name",{value:e,configurable:!0});import{Container as m,fuzzyFilter as T,getEditorKeybindings as $,Input as v,Key as o,matchesKey as a,Spacer as f,Text as u}from"@catui/tui";import{theme as r}from"../theme/theme.js";import{DynamicBorder as g}from"./dynamic-border.js";function I(l,e){return l===null||l.includes(e)}c(I,"isEnabled");function M(l,e){if(l===null)return[e];const i=l.indexOf(e);return i>=0?[...l.slice(0,i),...l.slice(i+1)]:[...l,e]}c(M,"toggle");function x(l,e,i){if(l===null)return null;const s=i??e,t=[...l];for(const n of s)t.includes(n)||t.push(n);return t.length===e.length?null:t}c(x,"enableAll");function b(l,e,i){if(l===null)return i?e.filter(t=>!i.includes(t)):[];const s=new Set(i??l);return l.filter(t=>!s.has(t))}c(b,"clearAll");function S(l,e,i,s){const t=l??[...e],n=t.indexOf(i);if(n<0)return t;const h=n+s;if(h<0||h>=t.length)return t;const d=[...t];return[d[n],d[h]]=[d[h],d[n]],d}c(S,"move");function k(l,e){if(l===null)return e;const i=new Set(l);return[...l,...e.filter(s=>!i.has(s))]}c(k,"getSortedIds");class B extends m{static{c(this,"ScopedModelsSelectorComponent")}modelsById=new Map;allIds=[];enabledIds=null;filteredItems=[];selectedIndex=0;searchInput;_focused=!1;get focused(){return this._focused}set focused(e){this._focused=e,this.searchInput.focused=e}listContainer;footerText;callbacks;maxVisible=15;isDirty=!1;constructor(e,i){super(),this.callbacks=i;for(const s of e.allModels){const t=`${s.provider}/${s.id}`;this.modelsById.set(t,s),this.allIds.push(t)}this.enabledIds=e.hasEnabledModelsFilter?[...e.enabledModelIds]:null,this.filteredItems=this.buildItems(),this.addChild(new g),this.addChild(new f(1)),this.addChild(new u(r.fg("accent",r.bold("Model Configuration")),0,0)),this.addChild(new u(r.fg("muted","Session-only. Ctrl+S to save to settings."),0,0)),this.addChild(new f(1)),this.searchInput=new v,this.addChild(this.searchInput),this.addChild(new f(1)),this.listContainer=new m,this.addChild(this.listContainer),this.addChild(new f(1)),this.footerText=new u(this.getFooterText(),0,0),this.addChild(this.footerText),this.addChild(new g),this.updateList()}buildItems(){return k(this.enabledIds,this.allIds).filter(e=>this.modelsById.has(e)).map(e=>({fullId:e,model:this.modelsById.get(e),enabled:I(this.enabledIds,e)}))}getFooterText(){const e=this.enabledIds?.length??this.allIds.length,t=["Enter toggle","^A all","^X clear","^P provider","Alt+\u2191\u2193 reorder","^S save",this.enabledIds===null?"all enabled":`${e}/${this.allIds.length} enabled`];return this.isDirty?r.fg("dim",` ${t.join(" \xB7 ")} `)+r.fg("warning","(unsaved)"):r.fg("dim",` ${t.join(" \xB7 ")}`)}refresh(){const e=this.searchInput.getValue(),i=this.buildItems();this.filteredItems=e?T(i,e,s=>`${s.model.id} ${s.model.provider}`):i,this.selectedIndex=Math.min(this.selectedIndex,Math.max(0,this.filteredItems.length-1)),this.updateList(),this.footerText.setText(this.getFooterText())}updateList(){if(this.listContainer.clear(),this.filteredItems.length===0){this.listContainer.addChild(new u(r.fg("muted"," No matching models"),0,0));return}const e=Math.max(0,Math.min(this.selectedIndex-Math.floor(this.maxVisible/2),this.filteredItems.length-this.maxVisible)),i=Math.min(e+this.maxVisible,this.filteredItems.length),s=this.enabledIds===null;for(let t=e;t<i;t++){const n=this.filteredItems[t],h=t===this.selectedIndex,d=h?r.fg("accent","\u2192 "):" ",p=h?r.fg("accent",n.model.id):n.model.id,C=r.fg("muted",` [${n.model.provider}]`),w=s?"":n.enabled?r.fg("success"," \u2713"):r.fg("dim"," \u2717");this.listContainer.addChild(new u(`${d}${p}${C}${w}`,0,0))}if((e>0||i<this.filteredItems.length)&&this.listContainer.addChild(new u(r.fg("muted",` (${this.selectedIndex+1}/${this.filteredItems.length})`),0,0)),this.filteredItems.length>0){const t=this.filteredItems[this.selectedIndex];this.listContainer.addChild(new f(1)),this.listContainer.addChild(new u(r.fg("muted",` Model Name: ${t.model.name}`),0,0))}}handleInput(e){const i=$();if(i.matches(e,"selectUp")){if(this.filteredItems.length===0)return;this.selectedIndex=this.selectedIndex===0?this.filteredItems.length-1:this.selectedIndex-1,this.updateList();return}if(i.matches(e,"selectDown")){if(this.filteredItems.length===0)return;this.selectedIndex=this.selectedIndex===this.filteredItems.length-1?0:this.selectedIndex+1,this.updateList();return}if(a(e,o.alt("up"))||a(e,o.alt("down"))){const s=this.filteredItems[this.selectedIndex];if(s&&I(this.enabledIds,s.fullId)){const t=a(e,o.alt("up"))?-1:1,n=this.enabledIds??this.allIds,d=n.indexOf(s.fullId)+t;d>=0&&d<n.length&&(this.enabledIds=S(this.enabledIds,this.allIds,s.fullId,t),this.isDirty=!0,this.selectedIndex+=t,this.refresh())}return}if(a(e,o.enter)){const s=this.filteredItems[this.selectedIndex];if(s){const t=this.enabledIds===null;this.enabledIds=M(this.enabledIds,s.fullId),this.isDirty=!0,t&&this.callbacks.onClearAll(),this.callbacks.onModelToggle(s.fullId,I(this.enabledIds,s.fullId)),this.refresh()}return}if(a(e,o.ctrl("a"))){const s=this.searchInput.getValue()?this.filteredItems.map(t=>t.fullId):void 0;this.enabledIds=x(this.enabledIds,this.allIds,s),this.isDirty=!0,this.callbacks.onEnableAll(s??this.allIds),this.refresh();return}if(a(e,o.ctrl("x"))){const s=this.searchInput.getValue()?this.filteredItems.map(t=>t.fullId):void 0;this.enabledIds=b(this.enabledIds,this.allIds,s),this.isDirty=!0,this.callbacks.onClearAll(),this.refresh();return}if(a(e,o.ctrl("p"))){const s=this.filteredItems[this.selectedIndex];if(s){const t=s.model.provider,n=this.allIds.filter(d=>this.modelsById.get(d).provider===t),h=n.every(d=>I(this.enabledIds,d));this.enabledIds=h?b(this.enabledIds,this.allIds,n):x(this.enabledIds,this.allIds,n),this.isDirty=!0,this.callbacks.onToggleProvider(t,n,!h),this.refresh()}return}if(a(e,o.ctrl("s"))){this.callbacks.onPersist(this.enabledIds??[...this.allIds]),this.isDirty=!1,this.footerText.setText(this.getFooterText());return}if(a(e,o.ctrl("c"))){this.searchInput.getValue()?(this.searchInput.setValue(""),this.refresh()):this.callbacks.onCancel();return}if(a(e,o.escape)){this.callbacks.onCancel();return}this.searchInput.handleInput(e),this.refresh()}getSearchInput(){return this.searchInput}}export{B as ScopedModelsSelectorComponent};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: ParsedSearchQuery, MatchResult, hasSessionName, parseSearchQuery, matchSession
|
|
3
|
+
* [FROM]: Depends on @catui/tui
|
|
4
|
+
* [TO]: Consumed by modes/interactive/components/index.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/session-selector-search.ts -
|
|
6
|
+
*/
|
|
7
|
+
import type { SessionInfo } from "../../../core/session/session-manager.js";
|
|
8
|
+
export type SortMode = "threaded" | "recent" | "relevance";
|
|
9
|
+
export type NameFilter = "all" | "named";
|
|
10
|
+
export interface ParsedSearchQuery {
|
|
11
|
+
mode: "tokens" | "regex";
|
|
12
|
+
tokens: {
|
|
13
|
+
kind: "fuzzy" | "phrase";
|
|
14
|
+
value: string;
|
|
15
|
+
}[];
|
|
16
|
+
regex: RegExp | null;
|
|
17
|
+
/** If set, parsing failed and we should treat query as non-matching. */
|
|
18
|
+
error?: string;
|
|
19
|
+
}
|
|
20
|
+
export interface MatchResult {
|
|
21
|
+
matches: boolean;
|
|
22
|
+
/** Lower is better; only meaningful when matches === true */
|
|
23
|
+
score: number;
|
|
24
|
+
}
|
|
25
|
+
export declare function hasSessionName(session: SessionInfo): boolean;
|
|
26
|
+
export declare function parseSearchQuery(query: string): ParsedSearchQuery;
|
|
27
|
+
export declare function matchSession(session: SessionInfo, parsed: ParsedSearchQuery): MatchResult;
|
|
28
|
+
export declare function filterAndSortSessions(sessions: SessionInfo[], query: string, sortMode: SortMode, nameFilter?: NameFilter): SessionInfo[];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var h=Object.defineProperty;var f=(r,n)=>h(r,"name",{value:n,configurable:!0});import{fuzzyMatch as d}from"@catui/tui";function a(r){return r.toLowerCase().replace(/\s+/g," ").trim()}f(a,"normalizeWhitespaceLower");function g(r){return`${r.id} ${r.name??""} ${r.allMessagesText} ${r.cwd}`}f(g,"getSessionSearchText");function x(r){return!!r.name?.trim()}f(x,"hasSessionName");function p(r,n){return n==="all"?!0:x(r)}f(p,"matchesNameFilter");function k(r){const n=r.trim();if(!n)return{mode:"tokens",tokens:[],regex:null};if(n.startsWith("re:")){const t=n.slice(3).trim();if(!t)return{mode:"regex",tokens:[],regex:null,error:"Empty regex"};try{return{mode:"regex",tokens:[],regex:new RegExp(t,"i")}}catch(e){const i=e instanceof Error?e.message:String(e);return{mode:"regex",tokens:[],regex:null,error:i}}}const l=[];let c="",s=!1,u=!1;const o=f(t=>{const e=c.trim();c="",e&&l.push({kind:t,value:e})},"flush");for(let t=0;t<n.length;t++){const e=n[t];if(e==='"'){s?(o("phrase"),s=!1):(o("fuzzy"),s=!0);continue}if(!s&&/\s/.test(e)){o("fuzzy");continue}c+=e}return s&&(u=!0),u?{mode:"tokens",tokens:n.split(/\s+/).map(t=>t.trim()).filter(t=>t.length>0).map(t=>({kind:"fuzzy",value:t})),regex:null}:(o(s?"phrase":"fuzzy"),{mode:"tokens",tokens:l,regex:null})}f(k,"parseSearchQuery");function m(r,n){const l=g(r);if(n.mode==="regex"){if(!n.regex)return{matches:!1,score:0};const u=l.search(n.regex);return u<0?{matches:!1,score:0}:{matches:!0,score:u*.1}}if(n.tokens.length===0)return{matches:!0,score:0};let c=0,s=null;for(const u of n.tokens){if(u.kind==="phrase"){s===null&&(s=a(l));const t=a(u.value);if(!t)continue;const e=s.indexOf(t);if(e<0)return{matches:!1,score:0};c+=e*.1;continue}const o=d(u.value,l);if(!o.matches)return{matches:!1,score:0};c+=o.score}return{matches:!0,score:c}}f(m,"matchSession");function v(r,n,l,c="all"){const s=c==="all"?r:r.filter(e=>p(e,c));if(!n.trim())return s;const o=k(n);if(o.error)return[];if(l==="recent"){const e=[];for(const i of s)m(i,o).matches&&e.push(i);return e}const t=[];for(const e of s){const i=m(e,o);i.matches&&t.push({session:e,score:i.score})}return t.sort((e,i)=>e.score!==i.score?e.score-i.score:i.session.modified.getTime()-e.session.modified.getTime()),t.map(e=>e.session)}f(v,"filterAndSortSessions");export{v as filterAndSortSessions,x as hasSessionName,m as matchSession,k as parseSearchQuery};
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: SessionSelectorComponent
|
|
3
|
+
* [FROM]: Depends on node:child_process, node:fs, node:fs/promises, node:os, ../../../core/platform/keybindings.js
|
|
4
|
+
* [TO]: Consumed by modes/interactive/components/index.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/session-selector.ts -
|
|
6
|
+
*/
|
|
7
|
+
import { type Component, Container, type Focusable } from "@catui/tui";
|
|
8
|
+
import { KeybindingsManager } from "../../../core/platform/keybindings.js";
|
|
9
|
+
import type { SessionInfo, SessionListProgress } from "../../../core/session/session-manager.js";
|
|
10
|
+
import { type NameFilter, type SortMode } from "./session-selector-search.js";
|
|
11
|
+
/**
|
|
12
|
+
* Custom session list component with multi-line items and search
|
|
13
|
+
*/
|
|
14
|
+
declare class SessionList implements Component, Focusable {
|
|
15
|
+
getSelectedSessionPath(): string | undefined;
|
|
16
|
+
private allSessions;
|
|
17
|
+
private filteredSessions;
|
|
18
|
+
private selectedIndex;
|
|
19
|
+
private searchInput;
|
|
20
|
+
private showCwd;
|
|
21
|
+
private sortMode;
|
|
22
|
+
private nameFilter;
|
|
23
|
+
private keybindings;
|
|
24
|
+
private showPath;
|
|
25
|
+
private confirmingDeletePath;
|
|
26
|
+
private currentSessionFilePath?;
|
|
27
|
+
onSelect?: (sessionPath: string) => void;
|
|
28
|
+
onCancel?: () => void;
|
|
29
|
+
onExit: () => void;
|
|
30
|
+
onToggleScope?: () => void;
|
|
31
|
+
onToggleSort?: () => void;
|
|
32
|
+
onToggleNameFilter?: () => void;
|
|
33
|
+
onTogglePath?: (showPath: boolean) => void;
|
|
34
|
+
onDeleteConfirmationChange?: (path: string | null) => void;
|
|
35
|
+
onDeleteSession?: (sessionPath: string) => Promise<void>;
|
|
36
|
+
onRenameSession?: (sessionPath: string) => void;
|
|
37
|
+
onError?: (message: string) => void;
|
|
38
|
+
private maxVisible;
|
|
39
|
+
private _focused;
|
|
40
|
+
get focused(): boolean;
|
|
41
|
+
set focused(value: boolean);
|
|
42
|
+
constructor(sessions: SessionInfo[], showCwd: boolean, sortMode: SortMode, nameFilter: NameFilter, keybindings: KeybindingsManager, currentSessionFilePath?: string);
|
|
43
|
+
setSortMode(sortMode: SortMode): void;
|
|
44
|
+
setNameFilter(nameFilter: NameFilter): void;
|
|
45
|
+
setSessions(sessions: SessionInfo[], showCwd: boolean): void;
|
|
46
|
+
private filterSessions;
|
|
47
|
+
private setConfirmingDeletePath;
|
|
48
|
+
private startDeleteConfirmationForSelectedSession;
|
|
49
|
+
invalidate(): void;
|
|
50
|
+
render(width: number): string[];
|
|
51
|
+
private buildTreePrefix;
|
|
52
|
+
handleInput(keyData: string): void;
|
|
53
|
+
}
|
|
54
|
+
type SessionsLoader = (onProgress?: SessionListProgress) => Promise<SessionInfo[]>;
|
|
55
|
+
/**
|
|
56
|
+
* Component that renders a session selector
|
|
57
|
+
*/
|
|
58
|
+
export declare class SessionSelectorComponent extends Container implements Focusable {
|
|
59
|
+
handleInput(data: string): void;
|
|
60
|
+
private canRename;
|
|
61
|
+
private sessionList;
|
|
62
|
+
private header;
|
|
63
|
+
private keybindings;
|
|
64
|
+
private scope;
|
|
65
|
+
private sortMode;
|
|
66
|
+
private nameFilter;
|
|
67
|
+
private currentSessions;
|
|
68
|
+
private allSessions;
|
|
69
|
+
private currentSessionsLoader;
|
|
70
|
+
private allSessionsLoader;
|
|
71
|
+
private onCancel;
|
|
72
|
+
private requestRender;
|
|
73
|
+
private renameSession?;
|
|
74
|
+
private currentLoading;
|
|
75
|
+
private allLoading;
|
|
76
|
+
private allLoadSeq;
|
|
77
|
+
private mode;
|
|
78
|
+
private renameInput;
|
|
79
|
+
private renameTargetPath;
|
|
80
|
+
private _focused;
|
|
81
|
+
get focused(): boolean;
|
|
82
|
+
set focused(value: boolean);
|
|
83
|
+
private buildBaseLayout;
|
|
84
|
+
constructor(currentSessionsLoader: SessionsLoader, allSessionsLoader: SessionsLoader, onSelect: (sessionPath: string) => void, onCancel: () => void, onExit: () => void, requestRender: () => void, options?: {
|
|
85
|
+
renameSession?: (sessionPath: string, currentName: string | undefined) => Promise<void>;
|
|
86
|
+
showRenameHint?: boolean;
|
|
87
|
+
keybindings?: KeybindingsManager;
|
|
88
|
+
}, currentSessionFilePath?: string);
|
|
89
|
+
private loadCurrentSessions;
|
|
90
|
+
private enterRenameMode;
|
|
91
|
+
private exitRenameMode;
|
|
92
|
+
private confirmRename;
|
|
93
|
+
private loadScope;
|
|
94
|
+
private toggleSortMode;
|
|
95
|
+
private toggleNameFilter;
|
|
96
|
+
private refreshSessionsAfterMutation;
|
|
97
|
+
private toggleScope;
|
|
98
|
+
getSessionList(): SessionList;
|
|
99
|
+
}
|
|
100
|
+
export {};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var _=Object.defineProperty;var d=(a,e)=>_(a,"name",{value:e,configurable:!0});import{spawnSync as j}from"node:child_process";import{existsSync as z}from"node:fs";import{unlink as U}from"node:fs/promises";import*as G from"node:os";import{Container as N,getEditorKeybindings as D,Input as E,matchesKey as $,Spacer as x,Text as H,truncateToWidth as S,visibleWidth as w}from"@catui/tui";import{KeybindingsManager as J}from"../../../core/platform/keybindings.js";import{theme as h}from"../theme/theme.js";import{DynamicBorder as v}from"./dynamic-border.js";import{appKey as O,appKeyHint as Q,keyHint as I}from"./keybinding-hints.js";import{filterAndSortSessions as X,hasSessionName as Y}from"./session-selector-search.js";function V(a){const e=G.homedir();return a&&(a.startsWith(e)?`~${a.slice(e.length)}`:a)}d(V,"shortenPath");function Z(a){const s=new Date().getTime()-a.getTime(),t=Math.floor(s/6e4),i=Math.floor(s/36e5),n=Math.floor(s/864e5);return t<1?"now":t<60?`${t}m`:i<24?`${i}h`:n<7?`${n}d`:n<30?`${Math.floor(n/7)}w`:n<365?`${Math.floor(n/30)}mo`:`${Math.floor(n/365)}y`}d(Z,"formatSessionDate");class ee{static{d(this,"SessionSelectorHeader")}scope;sortMode;nameFilter;keybindings;requestRender;loading=!1;loadProgress=null;showPath=!1;confirmingDeletePath=null;statusMessage=null;statusTimeout=null;showRenameHint=!1;constructor(e,s,t,i,n){this.scope=e,this.sortMode=s,this.nameFilter=t,this.keybindings=i,this.requestRender=n}setScope(e){this.scope=e}setSortMode(e){this.sortMode=e}setNameFilter(e){this.nameFilter=e}setLoading(e){this.loading=e,this.loadProgress=null}setProgress(e,s){this.loadProgress={loaded:e,total:s}}setShowPath(e){this.showPath=e}setShowRenameHint(e){this.showRenameHint=e}setConfirmingDeletePath(e){this.confirmingDeletePath=e}clearStatusTimeout(){this.statusTimeout&&(clearTimeout(this.statusTimeout),this.statusTimeout=null)}setStatusMessage(e,s){this.clearStatusTimeout(),this.statusMessage=e,!(!e||!s)&&(this.statusTimeout=setTimeout(()=>{this.statusMessage=null,this.statusTimeout=null,this.requestRender()},s))}invalidate(){}render(e){const s=this.scope==="current"?"Resume Session (Current Folder)":"Resume Session (All)",t=h.bold(s),i=this.sortMode==="threaded"?"Threaded":this.sortMode==="recent"?"Recent":"Fuzzy",n=h.fg("muted","Sort: ")+h.fg("accent",i),o=this.nameFilter==="all"?"All":"Named",r=h.fg("muted","Name: ")+h.fg("accent",o);let c;if(this.loading){const g=this.loadProgress?`${this.loadProgress.loaded}/${this.loadProgress.total}`:"...";c=`${h.fg("muted","\u25CB Current Folder | ")}${h.fg("accent",`Loading ${g}`)}`}else this.scope==="current"?c=`${h.fg("accent","\u25C9 Current Folder")}${h.fg("muted"," | \u25CB All")}`:c=`${h.fg("muted","\u25CB Current Folder | ")}${h.fg("accent","\u25C9 All")}`;const u=S(`${c} ${r} ${n}`,e,""),L=Math.max(0,e-w(u)-1),l=S(t,L,""),M=Math.max(0,e-w(l)-w(u));let f,m;if(this.confirmingDeletePath!==null)f=h.fg("error",S("Delete session? [Enter] confirm \xB7 [Esc/Ctrl+C] cancel",e,"\u2026")),m="";else if(this.statusMessage){const g=this.statusMessage.type==="error"?"error":"accent";f=h.fg(g,S(this.statusMessage.message,e,"\u2026")),m=""}else{const g=this.showPath?"(on)":"(off)",C=h.fg("muted"," \xB7 "),p=I("tab","scope")+C+h.fg("muted",'re:<pattern> regex \xB7 "phrase" exact'),T=[I("toggleSessionSort","sort"),Q(this.keybindings,"toggleSessionNamedFilter","named"),I("deleteSession","delete"),I("toggleSessionPath",`path ${g}`)];this.showRenameHint&&T.push(I("renameSession","rename"));const b=T.join(C);f=S(p,e,"\u2026"),m=S(b,e,"\u2026")}return[`${l}${" ".repeat(M)}${u}`,f,m]}}function se(a){const e=new Map;for(const i of a)e.set(i.path,{session:i,children:[]});const s=[];for(const i of a){const n=e.get(i.path),o=i.parentSessionPath;o&&e.has(o)?e.get(o).children.push(n):s.push(n)}const t=d(i=>{i.sort((n,o)=>o.session.modified.getTime()-n.session.modified.getTime());for(const n of i)t(n.children)},"sortNodes");return t(s),s}d(se,"buildSessionTree");function te(a){const e=[],s=d((t,i,n,o)=>{e.push({session:t.session,depth:i,isLast:o,ancestorContinues:n});for(let r=0;r<t.children.length;r++){const c=r===t.children.length-1,u=i>0?!o:!1;s(t.children[r],i+1,[...n,u],c)}},"walk");for(let t=0;t<a.length;t++)s(a[t],0,[],t===a.length-1);return e}d(te,"flattenSessionTree");class ie{static{d(this,"SessionList")}getSelectedSessionPath(){return this.filteredSessions[this.selectedIndex]?.session.path}allSessions=[];filteredSessions=[];selectedIndex=0;searchInput;showCwd=!1;sortMode="threaded";nameFilter="all";keybindings;showPath=!1;confirmingDeletePath=null;currentSessionFilePath;onSelect;onCancel;onExit=d(()=>{},"onExit");onToggleScope;onToggleSort;onToggleNameFilter;onTogglePath;onDeleteConfirmationChange;onDeleteSession;onRenameSession;onError;maxVisible=10;_focused=!1;get focused(){return this._focused}set focused(e){this._focused=e,this.searchInput.focused=e}constructor(e,s,t,i,n,o){this.allSessions=e,this.filteredSessions=[],this.searchInput=new E,this.showCwd=s,this.sortMode=t,this.nameFilter=i,this.keybindings=n,this.currentSessionFilePath=o,this.filterSessions(""),this.searchInput.onSubmit=()=>{if(this.filteredSessions[this.selectedIndex]){const r=this.filteredSessions[this.selectedIndex];this.onSelect&&this.onSelect(r.session.path)}}}setSortMode(e){this.sortMode=e,this.filterSessions(this.searchInput.getValue())}setNameFilter(e){this.nameFilter=e,this.filterSessions(this.searchInput.getValue())}setSessions(e,s){this.allSessions=e,this.showCwd=s,this.filterSessions(this.searchInput.getValue())}filterSessions(e){const s=e.trim(),t=this.nameFilter==="all"?this.allSessions:this.allSessions.filter(i=>Y(i));if(this.sortMode==="threaded"&&!s){const i=se(t);this.filteredSessions=te(i)}else{const i=X(t,e,this.sortMode,"all");this.filteredSessions=i.map(n=>({session:n,depth:0,isLast:!0,ancestorContinues:[]}))}this.selectedIndex=Math.min(this.selectedIndex,Math.max(0,this.filteredSessions.length-1))}setConfirmingDeletePath(e){this.confirmingDeletePath=e,this.onDeleteConfirmationChange?.(e)}startDeleteConfirmationForSelectedSession(){const e=this.filteredSessions[this.selectedIndex];if(e){if(this.currentSessionFilePath&&e.session.path===this.currentSessionFilePath){this.onError?.("Cannot delete the currently active session");return}this.setConfirmingDeletePath(e.session.path)}}invalidate(){}render(e){const s=[];if(s.push(...this.searchInput.render(e)),s.push(""),this.filteredSessions.length===0){let n;if(this.nameFilter==="named"){const o=O(this.keybindings,"toggleSessionNamedFilter");this.showCwd?n=` No named sessions found. Press ${o} to show all.`:n=` No named sessions in current folder. Press ${o} to show all, or Tab to view all.`}else this.showCwd?n=" No sessions found":n=" No sessions in current folder. Press Tab to view all.";return s.push(h.fg("muted",S(n,e,"\u2026"))),s}const t=Math.max(0,Math.min(this.selectedIndex-Math.floor(this.maxVisible/2),this.filteredSessions.length-this.maxVisible)),i=Math.min(t+this.maxVisible,this.filteredSessions.length);for(let n=t;n<i;n++){const o=this.filteredSessions[n],r=o.session,c=n===this.selectedIndex,u=r.path===this.confirmingDeletePath,L=this.currentSessionFilePath===r.path,l=this.buildTreePrefix(o),M=!!r.name,m=(r.name??r.firstMessage).replace(/\n/g," ").trim(),g=Z(r.modified);let p=`${String(r.messageCount)} ${g}`;this.showCwd&&r.cwd&&(p=`${V(r.cwd)} ${p}`),this.showPath&&(p=`${V(r.path)} ${p}`);const T=c?h.fg("accent","\u203A "):" ",b=w(l),k=w(p)+2,A=e-2-b-k,y=S(m,Math.max(10,A),"\u2026");let P=null;u?P="error":L?P="accent":M&&(P="warning");let R=P?h.fg(P,y):y;c&&(R=h.bold(R));const q=T+h.fg("dim",l)+R,W=w(q),B=Math.max(1,e-W-w(p)),K=h.fg(u?"error":"dim",p);let F=q+" ".repeat(B)+K;c&&(F=h.bg("selectedBg",F)),s.push(S(F,e))}if(t>0||i<this.filteredSessions.length){const n=` (${this.selectedIndex+1}/${this.filteredSessions.length})`,o=h.fg("muted",S(n,e,""));s.push(o)}return s}buildTreePrefix(e){if(e.depth===0)return"";const s=e.ancestorContinues.map(i=>i?"\u2502 ":" "),t=e.isLast?"\u2514\u2500 ":"\u251C\u2500 ";return s.join("")+t}handleInput(e){const s=D();if(this.confirmingDeletePath!==null){if(s.matches(e,"selectConfirm")){const t=this.confirmingDeletePath;this.setConfirmingDeletePath(null),this.onDeleteSession?.(t);return}if(s.matches(e,"selectCancel")||$(e,"ctrl+c")){this.setConfirmingDeletePath(null);return}return}if(s.matches(e,"tab")){this.onToggleScope&&this.onToggleScope();return}if(s.matches(e,"toggleSessionSort")){this.onToggleSort?.();return}if(this.keybindings.matches(e,"toggleSessionNamedFilter")){this.onToggleNameFilter?.();return}if(s.matches(e,"toggleSessionPath")){this.showPath=!this.showPath,this.onTogglePath?.(this.showPath);return}if(s.matches(e,"deleteSession")){this.startDeleteConfirmationForSelectedSession();return}if($(e,"ctrl+r")){const t=this.filteredSessions[this.selectedIndex];t&&this.onRenameSession?.(t.session.path);return}if(s.matches(e,"deleteSessionNoninvasive")){if(this.searchInput.getValue().length>0){this.searchInput.handleInput(e),this.filterSessions(this.searchInput.getValue());return}this.startDeleteConfirmationForSelectedSession();return}if(s.matches(e,"selectUp"))this.selectedIndex=Math.max(0,this.selectedIndex-1);else if(s.matches(e,"selectDown"))this.selectedIndex=Math.min(this.filteredSessions.length-1,this.selectedIndex+1);else if(s.matches(e,"selectPageUp"))this.selectedIndex=Math.max(0,this.selectedIndex-this.maxVisible);else if(s.matches(e,"selectPageDown"))this.selectedIndex=Math.min(this.filteredSessions.length-1,this.selectedIndex+this.maxVisible);else if(s.matches(e,"selectConfirm")){const t=this.filteredSessions[this.selectedIndex];t&&this.onSelect&&this.onSelect(t.session.path)}else s.matches(e,"selectCancel")?this.onCancel&&this.onCancel():(this.searchInput.handleInput(e),this.filterSessions(this.searchInput.getValue()))}}async function ne(a){const e=a.startsWith("-")?["--",a]:[a],s=j("trash",e,{encoding:"utf-8"}),t=d(()=>{const i=[];s.error&&i.push(s.error.message);const n=s.stderr?.trim();return n&&i.push(n.split(`
|
|
2
|
+
`)[0]??n),i.length===0?null:`trash: ${i.join(" \xB7 ").slice(0,200)}`},"getTrashErrorHint");if(s.status===0||!z(a))return{ok:!0,method:"trash"};try{return await U(a),{ok:!0,method:"unlink"}}catch(i){const n=i instanceof Error?i.message:String(i),o=t();return{ok:!1,method:"unlink",error:o?`${n} (${o})`:n}}}d(ne,"deleteSessionFile");class ge extends N{static{d(this,"SessionSelectorComponent")}handleInput(e){if(this.mode==="rename"){if(D().matches(e,"selectCancel")||$(e,"ctrl+c")){this.exitRenameMode();return}this.renameInput.handleInput(e);return}this.sessionList.handleInput(e)}canRename=!0;sessionList;header;keybindings;scope="current";sortMode="threaded";nameFilter="all";currentSessions=null;allSessions=null;currentSessionsLoader;allSessionsLoader;onCancel;requestRender;renameSession;currentLoading=!1;allLoading=!1;allLoadSeq=0;mode="list";renameInput=new E;renameTargetPath=null;_focused=!1;get focused(){return this._focused}set focused(e){this._focused=e,this.sessionList.focused=e,this.renameInput.focused=e,e&&this.mode==="rename"&&(this.renameInput.focused=!0)}buildBaseLayout(e,s){this.clear(),this.addChild(new x(1)),this.addChild(new v(t=>h.fg("accent",t))),this.addChild(new x(1)),(s?.showHeader??!0)&&(this.addChild(this.header),this.addChild(new x(1))),this.addChild(e),this.addChild(new x(1)),this.addChild(new v(t=>h.fg("accent",t)))}constructor(e,s,t,i,n,o,r,c){super(),this.keybindings=r?.keybindings??J.create(),this.currentSessionsLoader=e,this.allSessionsLoader=s,this.onCancel=i,this.requestRender=o,this.header=new ee(this.scope,this.sortMode,this.nameFilter,this.keybindings,this.requestRender);const u=r?.renameSession;this.renameSession=u,this.canRename=!!u,this.header.setShowRenameHint(r?.showRenameHint??this.canRename),this.sessionList=new ie([],!1,this.sortMode,this.nameFilter,this.keybindings,c),this.buildBaseLayout(this.sessionList),this.renameInput.onSubmit=l=>{this.confirmRename(l)};const L=d(()=>this.header.setStatusMessage(null),"clearStatusMessage");this.sessionList.onSelect=l=>{L(),t(l)},this.sessionList.onCancel=()=>{L(),i()},this.sessionList.onExit=()=>{L(),n()},this.sessionList.onToggleScope=()=>this.toggleScope(),this.sessionList.onToggleSort=()=>this.toggleSortMode(),this.sessionList.onToggleNameFilter=()=>this.toggleNameFilter(),this.sessionList.onRenameSession=l=>{if(!u||this.scope==="current"&&this.currentLoading||this.scope==="all"&&this.allLoading)return;const f=(this.scope==="all"?this.allSessions??[]:this.currentSessions??[]).find(m=>m.path===l);this.enterRenameMode(l,f?.name)},this.sessionList.onTogglePath=l=>{this.header.setShowPath(l),this.requestRender()},this.sessionList.onDeleteConfirmationChange=l=>{this.header.setConfirmingDeletePath(l),this.requestRender()},this.sessionList.onError=l=>{this.header.setStatusMessage({type:"error",message:l},3e3),this.requestRender()},this.sessionList.onDeleteSession=async l=>{const M=await ne(l);if(M.ok){this.currentSessions&&(this.currentSessions=this.currentSessions.filter(C=>C.path!==l)),this.allSessions&&(this.allSessions=this.allSessions.filter(C=>C.path!==l));const f=this.scope==="all"?this.allSessions??[]:this.currentSessions??[],m=this.scope==="all";this.sessionList.setSessions(f,m);const g=M.method==="trash"?"Session moved to trash":"Session deleted";this.header.setStatusMessage({type:"info",message:g},2e3),await this.refreshSessionsAfterMutation()}else{const f=M.error??"Unknown error";this.header.setStatusMessage({type:"error",message:`Failed to delete: ${f}`},3e3)}this.requestRender()},this.loadCurrentSessions()}loadCurrentSessions(){this.loadScope("current","initial")}enterRenameMode(e,s){this.mode="rename",this.renameTargetPath=e,this.renameInput.setValue(s??""),this.renameInput.focused=!0;const t=new N;t.addChild(new H(h.bold("Rename Session"),1,0)),t.addChild(new x(1)),t.addChild(this.renameInput),t.addChild(new x(1)),t.addChild(new H(h.fg("muted","Enter to save \xB7 Esc/Ctrl+C to cancel"),1,0)),this.buildBaseLayout(t,{showHeader:!1}),this.requestRender()}exitRenameMode(){this.mode="list",this.renameTargetPath=null,this.buildBaseLayout(this.sessionList),this.requestRender()}async confirmRename(e){const s=e.trim();if(!s)return;const t=this.renameTargetPath;if(!t){this.exitRenameMode();return}const i=this.renameSession;if(!i){this.exitRenameMode();return}try{await i(t,s),await this.refreshSessionsAfterMutation()}finally{this.exitRenameMode()}}async loadScope(e,s){const t=e==="all";e==="current"?this.currentLoading=!0:this.allLoading=!0;const i=e==="all"?++this.allLoadSeq:void 0;this.header.setScope(e),this.header.setLoading(!0),this.requestRender();const n=d((o,r)=>{e===this.scope&&(i!==void 0&&i!==this.allLoadSeq||(this.header.setProgress(o,r),this.requestRender()))},"onProgress");try{const o=await(e==="current"?this.currentSessionsLoader(n):this.allSessionsLoader(n));if(e==="current"?(this.currentSessions=o,this.currentLoading=!1):(this.allSessions=o,this.allLoading=!1),e!==this.scope||i!==void 0&&i!==this.allLoadSeq)return;this.header.setLoading(!1),this.sessionList.setSessions(o,t),this.requestRender(),e==="all"&&o.length===0&&(this.currentSessions?.length??0)===0&&this.onCancel()}catch(o){if(e==="current"?this.currentLoading=!1:this.allLoading=!1,e!==this.scope||i!==void 0&&i!==this.allLoadSeq)return;const r=o instanceof Error?o.message:String(o);this.header.setLoading(!1),this.header.setStatusMessage({type:"error",message:`Failed to load sessions: ${r}`},4e3),s==="initial"&&this.sessionList.setSessions([],t),this.requestRender()}}toggleSortMode(){this.sortMode=this.sortMode==="threaded"?"recent":this.sortMode==="recent"?"relevance":"threaded",this.header.setSortMode(this.sortMode),this.sessionList.setSortMode(this.sortMode),this.requestRender()}toggleNameFilter(){this.nameFilter=this.nameFilter==="all"?"named":"all",this.header.setNameFilter(this.nameFilter),this.sessionList.setNameFilter(this.nameFilter),this.requestRender()}async refreshSessionsAfterMutation(){await this.loadScope(this.scope,"refresh")}toggleScope(){if(this.scope==="current"){if(this.scope="all",this.header.setScope(this.scope),this.allSessions!==null){this.header.setLoading(!1),this.sessionList.setSessions(this.allSessions,!0),this.requestRender();return}this.allLoading||this.loadScope("all","toggle");return}this.scope="current",this.header.setScope(this.scope),this.header.setLoading(this.currentLoading),this.sessionList.setSessions(this.currentSessions??[],!1),this.requestRender()}getSessionList(){return this.sessionList}}export{ge as SessionSelectorComponent};
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: SettingsConfig, SettingsCallbacks, SettingsSelectorComponent
|
|
3
|
+
* [FROM]: Depends on ../theme/theme.js, ./dynamic-border.js
|
|
4
|
+
* [TO]: Consumed by modes/interactive/components/index.ts
|
|
5
|
+
* [HERE]: modes/interactive/components/settings-selector.ts -
|
|
6
|
+
*/
|
|
7
|
+
import type { ThinkingLevel } from "@catui/agent-core";
|
|
8
|
+
import type { Transport } from "@catui/ai/types";
|
|
9
|
+
import { Container, SettingsList } from "@catui/tui";
|
|
10
|
+
type AgentLoopFrameworkSettingValue = "model-default" | "standard" | "weak-model-compatible";
|
|
11
|
+
export interface SettingsConfig {
|
|
12
|
+
autoCompact: boolean;
|
|
13
|
+
showImages: boolean;
|
|
14
|
+
autoResizeImages: boolean;
|
|
15
|
+
blockImages: boolean;
|
|
16
|
+
enableSkillCommands: boolean;
|
|
17
|
+
steeringMode: "all" | "one-at-a-time";
|
|
18
|
+
followUpMode: "all" | "one-at-a-time";
|
|
19
|
+
transport: Transport;
|
|
20
|
+
agentLoopFramework: AgentLoopFrameworkSettingValue;
|
|
21
|
+
thinkingLevel: ThinkingLevel;
|
|
22
|
+
availableThinkingLevels: ThinkingLevel[];
|
|
23
|
+
currentTheme: string;
|
|
24
|
+
availableThemes: string[];
|
|
25
|
+
hideThinkingBlock: boolean;
|
|
26
|
+
collapseChangelog: boolean;
|
|
27
|
+
doubleEscapeAction: "fork" | "tree" | "none";
|
|
28
|
+
showHardwareCursor: boolean;
|
|
29
|
+
editorPaddingX: number;
|
|
30
|
+
autocompleteMaxVisible: number;
|
|
31
|
+
quietStartup: boolean;
|
|
32
|
+
clearOnShrink: boolean;
|
|
33
|
+
showTokenStats: boolean;
|
|
34
|
+
buddyEnabled: boolean;
|
|
35
|
+
buddySpecies: number;
|
|
36
|
+
showWorkingTrace: boolean;
|
|
37
|
+
showMemoryTrace: boolean;
|
|
38
|
+
presenceEnabled: boolean;
|
|
39
|
+
}
|
|
40
|
+
export interface SettingsCallbacks {
|
|
41
|
+
onAutoCompactChange: (enabled: boolean) => void;
|
|
42
|
+
onShowImagesChange: (enabled: boolean) => void;
|
|
43
|
+
onAutoResizeImagesChange: (enabled: boolean) => void;
|
|
44
|
+
onBlockImagesChange: (blocked: boolean) => void;
|
|
45
|
+
onEnableSkillCommandsChange: (enabled: boolean) => void;
|
|
46
|
+
onSteeringModeChange: (mode: "all" | "one-at-a-time") => void;
|
|
47
|
+
onFollowUpModeChange: (mode: "all" | "one-at-a-time") => void;
|
|
48
|
+
onTransportChange: (transport: Transport) => void;
|
|
49
|
+
onAgentLoopFrameworkChange: (framework: AgentLoopFrameworkSettingValue) => void;
|
|
50
|
+
onThinkingLevelChange: (level: ThinkingLevel) => void;
|
|
51
|
+
onThemeChange: (theme: string) => void;
|
|
52
|
+
onThemePreview?: (theme: string) => void;
|
|
53
|
+
onHideThinkingBlockChange: (hidden: boolean) => void;
|
|
54
|
+
onCollapseChangelogChange: (collapsed: boolean) => void;
|
|
55
|
+
onDoubleEscapeActionChange: (action: "fork" | "tree" | "none") => void;
|
|
56
|
+
onShowHardwareCursorChange: (enabled: boolean) => void;
|
|
57
|
+
onEditorPaddingXChange: (padding: number) => void;
|
|
58
|
+
onAutocompleteMaxVisibleChange: (maxVisible: number) => void;
|
|
59
|
+
onQuietStartupChange: (enabled: boolean) => void;
|
|
60
|
+
onClearOnShrinkChange: (enabled: boolean) => void;
|
|
61
|
+
onShowTokenStatsChange: (enabled: boolean) => void;
|
|
62
|
+
onBuddyEnabledChange: (enabled: boolean) => void;
|
|
63
|
+
onBuddySpeciesChange: (species: number) => void;
|
|
64
|
+
onShowWorkingTraceChange: (enabled: boolean) => void;
|
|
65
|
+
onShowMemoryTraceChange: (enabled: boolean) => void;
|
|
66
|
+
onPresenceEnabledChange: (enabled: boolean) => void;
|
|
67
|
+
onCancel: () => void;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Main settings selector component.
|
|
71
|
+
*/
|
|
72
|
+
export declare class SettingsSelectorComponent extends Container {
|
|
73
|
+
private settingsList;
|
|
74
|
+
constructor(config: SettingsConfig, callbacks: SettingsCallbacks);
|
|
75
|
+
getSettingsList(): SettingsList;
|
|
76
|
+
}
|
|
77
|
+
export {};
|