@dexto/tui 1.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +44 -0
- package/dist/InkCLIRefactored.cjs +319 -0
- package/dist/InkCLIRefactored.d.ts +55 -0
- package/dist/InkCLIRefactored.d.ts.map +1 -0
- package/dist/InkCLIRefactored.js +289 -0
- package/dist/assets/sounds/SOURCES.md +35 -0
- package/dist/assets/sounds/boot.wav +0 -0
- package/dist/assets/sounds/chime.wav +0 -0
- package/dist/assets/sounds/coin.wav +0 -0
- package/dist/assets/sounds/confirm.wav +0 -0
- package/dist/assets/sounds/levelup.wav +0 -0
- package/dist/assets/sounds/ping.wav +0 -0
- package/dist/assets/sounds/powerup.wav +0 -0
- package/dist/assets/sounds/startup.wav +0 -0
- package/dist/assets/sounds/success.wav +0 -0
- package/dist/assets/sounds/treasure.wav +0 -0
- package/dist/assets/sounds/win.wav +0 -0
- package/dist/components/ApprovalPrompt.cjs +353 -0
- package/dist/components/ApprovalPrompt.d.ts +44 -0
- package/dist/components/ApprovalPrompt.d.ts.map +1 -0
- package/dist/components/ApprovalPrompt.js +336 -0
- package/dist/components/BackgroundTasksPanel.cjs +117 -0
- package/dist/components/BackgroundTasksPanel.d.ts +18 -0
- package/dist/components/BackgroundTasksPanel.d.ts.map +1 -0
- package/dist/components/BackgroundTasksPanel.js +93 -0
- package/dist/components/CustomInput.cjs +77 -0
- package/dist/components/CustomInput.d.ts +17 -0
- package/dist/components/CustomInput.d.ts.map +1 -0
- package/dist/components/CustomInput.js +57 -0
- package/dist/components/CustomTextInput.cjs +76 -0
- package/dist/components/CustomTextInput.d.ts +16 -0
- package/dist/components/CustomTextInput.d.ts.map +1 -0
- package/dist/components/CustomTextInput.js +46 -0
- package/dist/components/EditableMultiLineInput.cjs +151 -0
- package/dist/components/EditableMultiLineInput.d.ts +19 -0
- package/dist/components/EditableMultiLineInput.d.ts.map +1 -0
- package/dist/components/EditableMultiLineInput.js +131 -0
- package/dist/components/ElicitationForm.cjs +622 -0
- package/dist/components/ElicitationForm.d.ts +24 -0
- package/dist/components/ElicitationForm.d.ts.map +1 -0
- package/dist/components/ElicitationForm.js +588 -0
- package/dist/components/ErrorBoundary.cjs +66 -0
- package/dist/components/ErrorBoundary.d.ts +20 -0
- package/dist/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ErrorBoundary.js +32 -0
- package/dist/components/Footer.cjs +165 -0
- package/dist/components/Footer.d.ts +23 -0
- package/dist/components/Footer.d.ts.map +1 -0
- package/dist/components/Footer.js +131 -0
- package/dist/components/HistorySearchBar.cjs +40 -0
- package/dist/components/HistorySearchBar.d.ts +17 -0
- package/dist/components/HistorySearchBar.d.ts.map +1 -0
- package/dist/components/HistorySearchBar.js +16 -0
- package/dist/components/MultiLineInput.cjs +56 -0
- package/dist/components/MultiLineInput.d.ts +12 -0
- package/dist/components/MultiLineInput.d.ts.map +1 -0
- package/dist/components/MultiLineInput.js +36 -0
- package/dist/components/ResourceAutocomplete.cjs +344 -0
- package/dist/components/ResourceAutocomplete.d.ts +26 -0
- package/dist/components/ResourceAutocomplete.d.ts.map +1 -0
- package/dist/components/ResourceAutocomplete.js +322 -0
- package/dist/components/SlashCommandAutocomplete.cjs +389 -0
- package/dist/components/SlashCommandAutocomplete.d.ts +28 -0
- package/dist/components/SlashCommandAutocomplete.d.ts.map +1 -0
- package/dist/components/SlashCommandAutocomplete.js +363 -0
- package/dist/components/StatusBar.cjs +142 -0
- package/dist/components/StatusBar.d.ts +41 -0
- package/dist/components/StatusBar.d.ts.map +1 -0
- package/dist/components/StatusBar.js +118 -0
- package/dist/components/TextBufferInput.cjs +531 -0
- package/dist/components/TextBufferInput.d.ts +54 -0
- package/dist/components/TextBufferInput.d.ts.map +1 -0
- package/dist/components/TextBufferInput.js +507 -0
- package/dist/components/TodoPanel.cjs +129 -0
- package/dist/components/TodoPanel.d.ts +26 -0
- package/dist/components/TodoPanel.d.ts.map +1 -0
- package/dist/components/TodoPanel.js +105 -0
- package/dist/components/base/BaseAutocomplete.cjs +153 -0
- package/dist/components/base/BaseAutocomplete.d.ts +29 -0
- package/dist/components/base/BaseAutocomplete.d.ts.map +1 -0
- package/dist/components/base/BaseAutocomplete.js +129 -0
- package/dist/components/base/BaseSelector.cjs +167 -0
- package/dist/components/base/BaseSelector.d.ts +37 -0
- package/dist/components/base/BaseSelector.d.ts.map +1 -0
- package/dist/components/base/BaseSelector.js +151 -0
- package/dist/components/base/index.cjs +31 -0
- package/dist/components/base/index.d.ts +6 -0
- package/dist/components/base/index.d.ts.map +1 -0
- package/dist/components/base/index.js +6 -0
- package/dist/components/chat/ChatView.cjs +51 -0
- package/dist/components/chat/ChatView.d.ts +19 -0
- package/dist/components/chat/ChatView.d.ts.map +1 -0
- package/dist/components/chat/ChatView.js +27 -0
- package/dist/components/chat/Footer.cjs +32 -0
- package/dist/components/chat/Footer.d.ts +9 -0
- package/dist/components/chat/Footer.d.ts.map +1 -0
- package/dist/components/chat/Footer.js +8 -0
- package/dist/components/chat/Header.cjs +86 -0
- package/dist/components/chat/Header.d.ts +18 -0
- package/dist/components/chat/Header.d.ts.map +1 -0
- package/dist/components/chat/Header.js +62 -0
- package/dist/components/chat/MessageItem.cjs +269 -0
- package/dist/components/chat/MessageItem.d.ts +23 -0
- package/dist/components/chat/MessageItem.d.ts.map +1 -0
- package/dist/components/chat/MessageItem.js +247 -0
- package/dist/components/chat/MessageList.cjs +46 -0
- package/dist/components/chat/MessageList.d.ts +16 -0
- package/dist/components/chat/MessageList.d.ts.map +1 -0
- package/dist/components/chat/MessageList.js +22 -0
- package/dist/components/chat/QueuedMessagesDisplay.cjs +59 -0
- package/dist/components/chat/QueuedMessagesDisplay.d.ts +16 -0
- package/dist/components/chat/QueuedMessagesDisplay.d.ts.map +1 -0
- package/dist/components/chat/QueuedMessagesDisplay.js +35 -0
- package/dist/components/chat/ToolIcon.cjs +60 -0
- package/dist/components/chat/ToolIcon.d.ts +18 -0
- package/dist/components/chat/ToolIcon.d.ts.map +1 -0
- package/dist/components/chat/ToolIcon.js +36 -0
- package/dist/components/chat/index.cjs +43 -0
- package/dist/components/chat/index.d.ts +10 -0
- package/dist/components/chat/index.d.ts.map +1 -0
- package/dist/components/chat/index.js +14 -0
- package/dist/components/chat/styled-boxes/ConfigBox.cjs +56 -0
- package/dist/components/chat/styled-boxes/ConfigBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/ConfigBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/ConfigBox.js +32 -0
- package/dist/components/chat/styled-boxes/HelpBox.cjs +53 -0
- package/dist/components/chat/styled-boxes/HelpBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/HelpBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/HelpBox.js +29 -0
- package/dist/components/chat/styled-boxes/LogConfigBox.cjs +54 -0
- package/dist/components/chat/styled-boxes/LogConfigBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/LogConfigBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/LogConfigBox.js +30 -0
- package/dist/components/chat/styled-boxes/SessionHistoryBox.cjs +81 -0
- package/dist/components/chat/styled-boxes/SessionHistoryBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/SessionHistoryBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/SessionHistoryBox.js +57 -0
- package/dist/components/chat/styled-boxes/SessionListBox.cjs +58 -0
- package/dist/components/chat/styled-boxes/SessionListBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/SessionListBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/SessionListBox.js +34 -0
- package/dist/components/chat/styled-boxes/ShortcutsBox.cjs +39 -0
- package/dist/components/chat/styled-boxes/ShortcutsBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/ShortcutsBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/ShortcutsBox.js +15 -0
- package/dist/components/chat/styled-boxes/StatsBox.cjs +123 -0
- package/dist/components/chat/styled-boxes/StatsBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/StatsBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/StatsBox.js +99 -0
- package/dist/components/chat/styled-boxes/StyledBox.cjs +88 -0
- package/dist/components/chat/styled-boxes/StyledBox.d.ts +45 -0
- package/dist/components/chat/styled-boxes/StyledBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/StyledBox.js +61 -0
- package/dist/components/chat/styled-boxes/SyspromptBox.cjs +33 -0
- package/dist/components/chat/styled-boxes/SyspromptBox.d.ts +10 -0
- package/dist/components/chat/styled-boxes/SyspromptBox.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/SyspromptBox.js +9 -0
- package/dist/components/chat/styled-boxes/index.cjs +58 -0
- package/dist/components/chat/styled-boxes/index.d.ts +13 -0
- package/dist/components/chat/styled-boxes/index.d.ts.map +1 -0
- package/dist/components/chat/styled-boxes/index.js +23 -0
- package/dist/components/input/InputArea.cjs +74 -0
- package/dist/components/input/InputArea.d.ts +48 -0
- package/dist/components/input/InputArea.d.ts.map +1 -0
- package/dist/components/input/InputArea.js +50 -0
- package/dist/components/input/index.cjs +28 -0
- package/dist/components/input/index.d.ts +5 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/index.js +4 -0
- package/dist/components/modes/AlternateBufferCLI.cjs +360 -0
- package/dist/components/modes/AlternateBufferCLI.d.ts +28 -0
- package/dist/components/modes/AlternateBufferCLI.d.ts.map +1 -0
- package/dist/components/modes/AlternateBufferCLI.js +339 -0
- package/dist/components/modes/StaticCLI.cjs +303 -0
- package/dist/components/modes/StaticCLI.d.ts +30 -0
- package/dist/components/modes/StaticCLI.d.ts.map +1 -0
- package/dist/components/modes/StaticCLI.js +279 -0
- package/dist/components/modes/index.cjs +31 -0
- package/dist/components/modes/index.d.ts +10 -0
- package/dist/components/modes/index.d.ts.map +1 -0
- package/dist/components/modes/index.js +6 -0
- package/dist/components/overlays/ApiKeyInput.cjs +131 -0
- package/dist/components/overlays/ApiKeyInput.d.ts +26 -0
- package/dist/components/overlays/ApiKeyInput.d.ts.map +1 -0
- package/dist/components/overlays/ApiKeyInput.js +115 -0
- package/dist/components/overlays/CommandOutputOverlay.cjs +103 -0
- package/dist/components/overlays/CommandOutputOverlay.d.ts +13 -0
- package/dist/components/overlays/CommandOutputOverlay.d.ts.map +1 -0
- package/dist/components/overlays/CommandOutputOverlay.js +69 -0
- package/dist/components/overlays/ContextStatsOverlay.cjs +354 -0
- package/dist/components/overlays/ContextStatsOverlay.d.ts +26 -0
- package/dist/components/overlays/ContextStatsOverlay.d.ts.map +1 -0
- package/dist/components/overlays/ContextStatsOverlay.js +334 -0
- package/dist/components/overlays/CustomModelWizard.cjs +362 -0
- package/dist/components/overlays/CustomModelWizard.d.ts +29 -0
- package/dist/components/overlays/CustomModelWizard.d.ts.map +1 -0
- package/dist/components/overlays/CustomModelWizard.js +356 -0
- package/dist/components/overlays/ExportWizard.cjs +382 -0
- package/dist/components/overlays/ExportWizard.d.ts +22 -0
- package/dist/components/overlays/ExportWizard.d.ts.map +1 -0
- package/dist/components/overlays/ExportWizard.js +352 -0
- package/dist/components/overlays/LogLevelSelector.cjs +120 -0
- package/dist/components/overlays/LogLevelSelector.d.ts +23 -0
- package/dist/components/overlays/LogLevelSelector.d.ts.map +1 -0
- package/dist/components/overlays/LogLevelSelector.js +100 -0
- package/dist/components/overlays/LoginOverlay.cjs +211 -0
- package/dist/components/overlays/LoginOverlay.d.ts +22 -0
- package/dist/components/overlays/LoginOverlay.d.ts.map +1 -0
- package/dist/components/overlays/LoginOverlay.js +194 -0
- package/dist/components/overlays/LogoutOverlay.cjs +138 -0
- package/dist/components/overlays/LogoutOverlay.d.ts +20 -0
- package/dist/components/overlays/LogoutOverlay.d.ts.map +1 -0
- package/dist/components/overlays/LogoutOverlay.js +130 -0
- package/dist/components/overlays/MarketplaceAddPrompt.cjs +119 -0
- package/dist/components/overlays/MarketplaceAddPrompt.d.ts +20 -0
- package/dist/components/overlays/MarketplaceAddPrompt.d.ts.map +1 -0
- package/dist/components/overlays/MarketplaceAddPrompt.js +99 -0
- package/dist/components/overlays/MarketplaceBrowser.cjs +364 -0
- package/dist/components/overlays/MarketplaceBrowser.d.ts +31 -0
- package/dist/components/overlays/MarketplaceBrowser.d.ts.map +1 -0
- package/dist/components/overlays/MarketplaceBrowser.js +358 -0
- package/dist/components/overlays/McpAddChoice.cjs +100 -0
- package/dist/components/overlays/McpAddChoice.d.ts +22 -0
- package/dist/components/overlays/McpAddChoice.d.ts.map +1 -0
- package/dist/components/overlays/McpAddChoice.js +80 -0
- package/dist/components/overlays/McpAddSelector.cjs +113 -0
- package/dist/components/overlays/McpAddSelector.d.ts +26 -0
- package/dist/components/overlays/McpAddSelector.d.ts.map +1 -0
- package/dist/components/overlays/McpAddSelector.js +93 -0
- package/dist/components/overlays/McpCustomTypeSelector.cjs +99 -0
- package/dist/components/overlays/McpCustomTypeSelector.d.ts +21 -0
- package/dist/components/overlays/McpCustomTypeSelector.d.ts.map +1 -0
- package/dist/components/overlays/McpCustomTypeSelector.js +79 -0
- package/dist/components/overlays/McpCustomWizard.cjs +258 -0
- package/dist/components/overlays/McpCustomWizard.d.ts +29 -0
- package/dist/components/overlays/McpCustomWizard.d.ts.map +1 -0
- package/dist/components/overlays/McpCustomWizard.js +238 -0
- package/dist/components/overlays/McpRemoveSelector.cjs +127 -0
- package/dist/components/overlays/McpRemoveSelector.d.ts +22 -0
- package/dist/components/overlays/McpRemoveSelector.d.ts.map +1 -0
- package/dist/components/overlays/McpRemoveSelector.js +107 -0
- package/dist/components/overlays/McpSelector.cjs +94 -0
- package/dist/components/overlays/McpSelector.d.ts +21 -0
- package/dist/components/overlays/McpSelector.d.ts.map +1 -0
- package/dist/components/overlays/McpSelector.js +74 -0
- package/dist/components/overlays/McpServerActions.cjs +124 -0
- package/dist/components/overlays/McpServerActions.d.ts +28 -0
- package/dist/components/overlays/McpServerActions.d.ts.map +1 -0
- package/dist/components/overlays/McpServerActions.js +111 -0
- package/dist/components/overlays/McpServerList.cjs +152 -0
- package/dist/components/overlays/McpServerList.d.ts +29 -0
- package/dist/components/overlays/McpServerList.d.ts.map +1 -0
- package/dist/components/overlays/McpServerList.js +139 -0
- package/dist/components/overlays/ModelSelectorRefactored.cjs +869 -0
- package/dist/components/overlays/ModelSelectorRefactored.d.ts +27 -0
- package/dist/components/overlays/ModelSelectorRefactored.d.ts.map +1 -0
- package/dist/components/overlays/ModelSelectorRefactored.js +870 -0
- package/dist/components/overlays/PluginActions.cjs +108 -0
- package/dist/components/overlays/PluginActions.d.ts +27 -0
- package/dist/components/overlays/PluginActions.d.ts.map +1 -0
- package/dist/components/overlays/PluginActions.js +95 -0
- package/dist/components/overlays/PluginList.cjs +115 -0
- package/dist/components/overlays/PluginList.d.ts +21 -0
- package/dist/components/overlays/PluginList.d.ts.map +1 -0
- package/dist/components/overlays/PluginList.js +102 -0
- package/dist/components/overlays/PluginManager.cjs +106 -0
- package/dist/components/overlays/PluginManager.d.ts +21 -0
- package/dist/components/overlays/PluginManager.d.ts.map +1 -0
- package/dist/components/overlays/PluginManager.js +86 -0
- package/dist/components/overlays/PromptAddChoice.cjs +92 -0
- package/dist/components/overlays/PromptAddChoice.d.ts +22 -0
- package/dist/components/overlays/PromptAddChoice.d.ts.map +1 -0
- package/dist/components/overlays/PromptAddChoice.js +72 -0
- package/dist/components/overlays/PromptAddWizard.cjs +215 -0
- package/dist/components/overlays/PromptAddWizard.d.ts +29 -0
- package/dist/components/overlays/PromptAddWizard.d.ts.map +1 -0
- package/dist/components/overlays/PromptAddWizard.js +195 -0
- package/dist/components/overlays/PromptDeleteSelector.cjs +148 -0
- package/dist/components/overlays/PromptDeleteSelector.d.ts +27 -0
- package/dist/components/overlays/PromptDeleteSelector.d.ts.map +1 -0
- package/dist/components/overlays/PromptDeleteSelector.js +135 -0
- package/dist/components/overlays/PromptList.cjs +169 -0
- package/dist/components/overlays/PromptList.d.ts +33 -0
- package/dist/components/overlays/PromptList.d.ts.map +1 -0
- package/dist/components/overlays/PromptList.js +157 -0
- package/dist/components/overlays/ReasoningOverlay.cjs +305 -0
- package/dist/components/overlays/ReasoningOverlay.d.ts +28 -0
- package/dist/components/overlays/ReasoningOverlay.d.ts.map +1 -0
- package/dist/components/overlays/ReasoningOverlay.js +278 -0
- package/dist/components/overlays/SearchOverlay.cjs +249 -0
- package/dist/components/overlays/SearchOverlay.d.ts +23 -0
- package/dist/components/overlays/SearchOverlay.d.ts.map +1 -0
- package/dist/components/overlays/SearchOverlay.js +236 -0
- package/dist/components/overlays/SessionRenameOverlay.cjs +101 -0
- package/dist/components/overlays/SessionRenameOverlay.d.ts +21 -0
- package/dist/components/overlays/SessionRenameOverlay.d.ts.map +1 -0
- package/dist/components/overlays/SessionRenameOverlay.js +81 -0
- package/dist/components/overlays/SessionSelectorRefactored.cjs +153 -0
- package/dist/components/overlays/SessionSelectorRefactored.d.ts +26 -0
- package/dist/components/overlays/SessionSelectorRefactored.d.ts.map +1 -0
- package/dist/components/overlays/SessionSelectorRefactored.js +133 -0
- package/dist/components/overlays/SessionSubcommandSelector.cjs +84 -0
- package/dist/components/overlays/SessionSubcommandSelector.d.ts +21 -0
- package/dist/components/overlays/SessionSubcommandSelector.d.ts.map +1 -0
- package/dist/components/overlays/SessionSubcommandSelector.js +64 -0
- package/dist/components/overlays/SoundsSelector.cjs +632 -0
- package/dist/components/overlays/SoundsSelector.d.ts +21 -0
- package/dist/components/overlays/SoundsSelector.d.ts.map +1 -0
- package/dist/components/overlays/SoundsSelector.js +619 -0
- package/dist/components/overlays/StreamSelector.cjs +104 -0
- package/dist/components/overlays/StreamSelector.d.ts +20 -0
- package/dist/components/overlays/StreamSelector.d.ts.map +1 -0
- package/dist/components/overlays/StreamSelector.js +84 -0
- package/dist/components/overlays/ToolBrowser.cjs +854 -0
- package/dist/components/overlays/ToolBrowser.d.ts +26 -0
- package/dist/components/overlays/ToolBrowser.d.ts.map +1 -0
- package/dist/components/overlays/ToolBrowser.js +831 -0
- package/dist/components/overlays/custom-model-wizard/LocalModelWizard.cjs +784 -0
- package/dist/components/overlays/custom-model-wizard/LocalModelWizard.d.ts +25 -0
- package/dist/components/overlays/custom-model-wizard/LocalModelWizard.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/LocalModelWizard.js +768 -0
- package/dist/components/overlays/custom-model-wizard/index.cjs +26 -0
- package/dist/components/overlays/custom-model-wizard/index.d.ts +15 -0
- package/dist/components/overlays/custom-model-wizard/index.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/index.js +3 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.cjs +549 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.d.ts +42 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.js +516 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.test.cjs +31 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.test.d.ts +2 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.test.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/provider-config.test.js +30 -0
- package/dist/components/overlays/custom-model-wizard/shared/ApiKeyStep.cjs +59 -0
- package/dist/components/overlays/custom-model-wizard/shared/ApiKeyStep.d.ts +25 -0
- package/dist/components/overlays/custom-model-wizard/shared/ApiKeyStep.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/shared/ApiKeyStep.js +33 -0
- package/dist/components/overlays/custom-model-wizard/shared/ProviderSelector.cjs +64 -0
- package/dist/components/overlays/custom-model-wizard/shared/ProviderSelector.d.ts +17 -0
- package/dist/components/overlays/custom-model-wizard/shared/ProviderSelector.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/shared/ProviderSelector.js +40 -0
- package/dist/components/overlays/custom-model-wizard/shared/SetupInfoBanner.cjs +48 -0
- package/dist/components/overlays/custom-model-wizard/shared/SetupInfoBanner.d.ts +20 -0
- package/dist/components/overlays/custom-model-wizard/shared/SetupInfoBanner.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/shared/SetupInfoBanner.js +24 -0
- package/dist/components/overlays/custom-model-wizard/shared/WizardStepInput.cjs +58 -0
- package/dist/components/overlays/custom-model-wizard/shared/WizardStepInput.d.ts +30 -0
- package/dist/components/overlays/custom-model-wizard/shared/WizardStepInput.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/shared/WizardStepInput.js +34 -0
- package/dist/components/overlays/custom-model-wizard/shared/index.cjs +41 -0
- package/dist/components/overlays/custom-model-wizard/shared/index.d.ts +8 -0
- package/dist/components/overlays/custom-model-wizard/shared/index.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/shared/index.js +12 -0
- package/dist/components/overlays/custom-model-wizard/types.cjs +53 -0
- package/dist/components/overlays/custom-model-wizard/types.d.ts +85 -0
- package/dist/components/overlays/custom-model-wizard/types.d.ts.map +1 -0
- package/dist/components/overlays/custom-model-wizard/types.js +29 -0
- package/dist/components/renderers/DiffRenderer.cjs +145 -0
- package/dist/components/renderers/DiffRenderer.d.ts +21 -0
- package/dist/components/renderers/DiffRenderer.d.ts.map +1 -0
- package/dist/components/renderers/DiffRenderer.js +118 -0
- package/dist/components/renderers/FilePreviewRenderer.cjs +146 -0
- package/dist/components/renderers/FilePreviewRenderer.d.ts +30 -0
- package/dist/components/renderers/FilePreviewRenderer.d.ts.map +1 -0
- package/dist/components/renderers/FilePreviewRenderer.js +119 -0
- package/dist/components/renderers/FileRenderer.cjs +95 -0
- package/dist/components/renderers/FileRenderer.d.ts +21 -0
- package/dist/components/renderers/FileRenderer.d.ts.map +1 -0
- package/dist/components/renderers/FileRenderer.js +71 -0
- package/dist/components/renderers/GenericRenderer.cjs +63 -0
- package/dist/components/renderers/GenericRenderer.d.ts +21 -0
- package/dist/components/renderers/GenericRenderer.d.ts.map +1 -0
- package/dist/components/renderers/GenericRenderer.js +39 -0
- package/dist/components/renderers/SearchRenderer.cjs +77 -0
- package/dist/components/renderers/SearchRenderer.d.ts +20 -0
- package/dist/components/renderers/SearchRenderer.d.ts.map +1 -0
- package/dist/components/renderers/SearchRenderer.js +43 -0
- package/dist/components/renderers/ShellRenderer.cjs +61 -0
- package/dist/components/renderers/ShellRenderer.d.ts +21 -0
- package/dist/components/renderers/ShellRenderer.d.ts.map +1 -0
- package/dist/components/renderers/ShellRenderer.js +37 -0
- package/dist/components/renderers/diff-shared.cjs +172 -0
- package/dist/components/renderers/diff-shared.d.ts +61 -0
- package/dist/components/renderers/diff-shared.d.ts.map +1 -0
- package/dist/components/renderers/diff-shared.js +142 -0
- package/dist/components/renderers/index.cjs +75 -0
- package/dist/components/renderers/index.d.ts +28 -0
- package/dist/components/renderers/index.d.ts.map +1 -0
- package/dist/components/renderers/index.js +44 -0
- package/dist/components/shared/FocusOverlayFrame.cjs +39 -0
- package/dist/components/shared/FocusOverlayFrame.d.ts +7 -0
- package/dist/components/shared/FocusOverlayFrame.d.ts.map +1 -0
- package/dist/components/shared/FocusOverlayFrame.js +15 -0
- package/dist/components/shared/HintBar.cjs +33 -0
- package/dist/components/shared/HintBar.d.ts +6 -0
- package/dist/components/shared/HintBar.d.ts.map +1 -0
- package/dist/components/shared/HintBar.js +9 -0
- package/dist/components/shared/MarkdownText.cjs +409 -0
- package/dist/components/shared/MarkdownText.d.ts +38 -0
- package/dist/components/shared/MarkdownText.d.ts.map +1 -0
- package/dist/components/shared/MarkdownText.js +373 -0
- package/dist/components/shared/VirtualizedList.cjs +365 -0
- package/dist/components/shared/VirtualizedList.d.ts +44 -0
- package/dist/components/shared/VirtualizedList.d.ts.map +1 -0
- package/dist/components/shared/VirtualizedList.js +349 -0
- package/dist/components/shared/text-buffer.cjs +1220 -0
- package/dist/components/shared/text-buffer.d.ts +185 -0
- package/dist/components/shared/text-buffer.d.ts.map +1 -0
- package/dist/components/shared/text-buffer.js +1194 -0
- package/dist/constants/processingPhrases.cjs +114 -0
- package/dist/constants/processingPhrases.d.ts +10 -0
- package/dist/constants/processingPhrases.d.ts.map +1 -0
- package/dist/constants/processingPhrases.js +89 -0
- package/dist/constants/spinnerFrames.cjs +28 -0
- package/dist/constants/spinnerFrames.d.ts +2 -0
- package/dist/constants/spinnerFrames.d.ts.map +1 -0
- package/dist/constants/spinnerFrames.js +4 -0
- package/dist/constants/tips.cjs +76 -0
- package/dist/constants/tips.d.ts +15 -0
- package/dist/constants/tips.d.ts.map +1 -0
- package/dist/constants/tips.js +51 -0
- package/dist/containers/InputContainer.cjs +706 -0
- package/dist/containers/InputContainer.d.ts +62 -0
- package/dist/containers/InputContainer.d.ts.map +1 -0
- package/dist/containers/InputContainer.js +672 -0
- package/dist/containers/OverlayContainer.cjs +2372 -0
- package/dist/containers/OverlayContainer.d.ts +42 -0
- package/dist/containers/OverlayContainer.d.ts.map +1 -0
- package/dist/containers/OverlayContainer.js +2356 -0
- package/dist/containers/index.cjs +31 -0
- package/dist/containers/index.d.ts +6 -0
- package/dist/containers/index.d.ts.map +1 -0
- package/dist/containers/index.js +6 -0
- package/dist/contexts/KeypressContext.cjs +436 -0
- package/dist/contexts/KeypressContext.d.ts +36 -0
- package/dist/contexts/KeypressContext.d.ts.map +1 -0
- package/dist/contexts/KeypressContext.js +408 -0
- package/dist/contexts/MouseContext.cjs +122 -0
- package/dist/contexts/MouseContext.d.ts +27 -0
- package/dist/contexts/MouseContext.d.ts.map +1 -0
- package/dist/contexts/MouseContext.js +101 -0
- package/dist/contexts/ScrollProvider.cjs +180 -0
- package/dist/contexts/ScrollProvider.d.ts +33 -0
- package/dist/contexts/ScrollProvider.d.ts.map +1 -0
- package/dist/contexts/ScrollProvider.js +163 -0
- package/dist/contexts/SoundContext.cjs +38 -0
- package/dist/contexts/SoundContext.d.ts +23 -0
- package/dist/contexts/SoundContext.d.ts.map +1 -0
- package/dist/contexts/SoundContext.js +13 -0
- package/dist/contexts/index.cjs +47 -0
- package/dist/contexts/index.d.ts +8 -0
- package/dist/contexts/index.d.ts.map +1 -0
- package/dist/contexts/index.js +25 -0
- package/dist/hooks/index.cjs +54 -0
- package/dist/hooks/index.d.ts +12 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +28 -0
- package/dist/hooks/useAgentEvents.cjs +382 -0
- package/dist/hooks/useAgentEvents.d.ts +49 -0
- package/dist/hooks/useAgentEvents.d.ts.map +1 -0
- package/dist/hooks/useAgentEvents.js +360 -0
- package/dist/hooks/useAnimationTick.cjs +71 -0
- package/dist/hooks/useAnimationTick.d.ts +11 -0
- package/dist/hooks/useAnimationTick.d.ts.map +1 -0
- package/dist/hooks/useAnimationTick.js +47 -0
- package/dist/hooks/useBatchedScroll.cjs +44 -0
- package/dist/hooks/useBatchedScroll.d.ts +14 -0
- package/dist/hooks/useBatchedScroll.d.ts.map +1 -0
- package/dist/hooks/useBatchedScroll.js +20 -0
- package/dist/hooks/useCLIState.cjs +222 -0
- package/dist/hooks/useCLIState.d.ts +53 -0
- package/dist/hooks/useCLIState.d.ts.map +1 -0
- package/dist/hooks/useCLIState.js +201 -0
- package/dist/hooks/useElapsedTime.cjs +79 -0
- package/dist/hooks/useElapsedTime.d.ts +24 -0
- package/dist/hooks/useElapsedTime.d.ts.map +1 -0
- package/dist/hooks/useElapsedTime.js +55 -0
- package/dist/hooks/useGitBranch.cjs +47 -0
- package/dist/hooks/useGitBranch.d.ts +13 -0
- package/dist/hooks/useGitBranch.d.ts.map +1 -0
- package/dist/hooks/useGitBranch.js +23 -0
- package/dist/hooks/useHistorySearch.cjs +219 -0
- package/dist/hooks/useHistorySearch.d.ts +61 -0
- package/dist/hooks/useHistorySearch.d.ts.map +1 -0
- package/dist/hooks/useHistorySearch.js +195 -0
- package/dist/hooks/useInputHistory.cjs +47 -0
- package/dist/hooks/useInputHistory.d.ts +18 -0
- package/dist/hooks/useInputHistory.d.ts.map +1 -0
- package/dist/hooks/useInputHistory.js +23 -0
- package/dist/hooks/useInputOrchestrator.cjs +663 -0
- package/dist/hooks/useInputOrchestrator.d.ts +136 -0
- package/dist/hooks/useInputOrchestrator.d.ts.map +1 -0
- package/dist/hooks/useInputOrchestrator.js +635 -0
- package/dist/hooks/useKeyboardShortcuts.cjs +87 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts +21 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
- package/dist/hooks/useKeyboardShortcuts.js +63 -0
- package/dist/hooks/useKeypress.cjs +41 -0
- package/dist/hooks/useKeypress.d.ts +18 -0
- package/dist/hooks/useKeypress.d.ts.map +1 -0
- package/dist/hooks/useKeypress.js +17 -0
- package/dist/hooks/usePhraseCycler.cjs +74 -0
- package/dist/hooks/usePhraseCycler.d.ts +30 -0
- package/dist/hooks/usePhraseCycler.d.ts.map +1 -0
- package/dist/hooks/usePhraseCycler.js +50 -0
- package/dist/hooks/useStreaming.cjs +43 -0
- package/dist/hooks/useStreaming.d.ts +19 -0
- package/dist/hooks/useStreaming.d.ts.map +1 -0
- package/dist/hooks/useStreaming.js +24 -0
- package/dist/hooks/useTerminalSize.cjs +48 -0
- package/dist/hooks/useTerminalSize.d.ts +14 -0
- package/dist/hooks/useTerminalSize.d.ts.map +1 -0
- package/dist/hooks/useTerminalSize.js +24 -0
- package/dist/hooks/useTokenCounter.cjs +105 -0
- package/dist/hooks/useTokenCounter.d.ts +46 -0
- package/dist/hooks/useTokenCounter.d.ts.map +1 -0
- package/dist/hooks/useTokenCounter.js +81 -0
- package/dist/host/index.cjs +144 -0
- package/dist/host/index.d.ts +108 -0
- package/dist/host/index.d.ts.map +1 -0
- package/dist/host/index.js +104 -0
- package/dist/index.cjs +33 -0
- package/dist/index.d.cts +195 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/interactive-commands/auth/index.cjs +44 -0
- package/dist/interactive-commands/auth/index.d.ts +13 -0
- package/dist/interactive-commands/auth/index.d.ts.map +1 -0
- package/dist/interactive-commands/auth/index.js +19 -0
- package/dist/interactive-commands/command-parser.cjs +184 -0
- package/dist/interactive-commands/command-parser.d.ts +56 -0
- package/dist/interactive-commands/command-parser.d.ts.map +1 -0
- package/dist/interactive-commands/command-parser.js +146 -0
- package/dist/interactive-commands/commands.cjs +135 -0
- package/dist/interactive-commands/commands.d.ts +52 -0
- package/dist/interactive-commands/commands.d.ts.map +1 -0
- package/dist/interactive-commands/commands.js +99 -0
- package/dist/interactive-commands/documentation-commands.cjs +61 -0
- package/dist/interactive-commands/documentation-commands.d.ts +15 -0
- package/dist/interactive-commands/documentation-commands.d.ts.map +1 -0
- package/dist/interactive-commands/documentation-commands.js +27 -0
- package/dist/interactive-commands/exit-handler.cjs +40 -0
- package/dist/interactive-commands/exit-handler.d.ts +12 -0
- package/dist/interactive-commands/exit-handler.d.ts.map +1 -0
- package/dist/interactive-commands/exit-handler.js +15 -0
- package/dist/interactive-commands/exit-stats.cjs +41 -0
- package/dist/interactive-commands/exit-stats.d.ts +24 -0
- package/dist/interactive-commands/exit-stats.d.ts.map +1 -0
- package/dist/interactive-commands/exit-stats.js +15 -0
- package/dist/interactive-commands/export/index.cjs +36 -0
- package/dist/interactive-commands/export/index.d.ts +13 -0
- package/dist/interactive-commands/export/index.d.ts.map +1 -0
- package/dist/interactive-commands/export/index.js +12 -0
- package/dist/interactive-commands/general-commands.cjs +478 -0
- package/dist/interactive-commands/general-commands.d.ts +22 -0
- package/dist/interactive-commands/general-commands.d.ts.map +1 -0
- package/dist/interactive-commands/general-commands.js +443 -0
- package/dist/interactive-commands/mcp/index.cjs +35 -0
- package/dist/interactive-commands/mcp/index.d.ts +13 -0
- package/dist/interactive-commands/mcp/index.d.ts.map +1 -0
- package/dist/interactive-commands/mcp/index.js +11 -0
- package/dist/interactive-commands/model/index.cjs +36 -0
- package/dist/interactive-commands/model/index.d.ts +13 -0
- package/dist/interactive-commands/model/index.d.ts.map +1 -0
- package/dist/interactive-commands/model/index.js +12 -0
- package/dist/interactive-commands/plugin/index.cjs +35 -0
- package/dist/interactive-commands/plugin/index.d.ts +13 -0
- package/dist/interactive-commands/plugin/index.d.ts.map +1 -0
- package/dist/interactive-commands/plugin/index.js +11 -0
- package/dist/interactive-commands/prompt-commands.cjs +269 -0
- package/dist/interactive-commands/prompt-commands.d.ts +25 -0
- package/dist/interactive-commands/prompt-commands.d.ts.map +1 -0
- package/dist/interactive-commands/prompt-commands.js +244 -0
- package/dist/interactive-commands/session/index.cjs +32 -0
- package/dist/interactive-commands/session/index.d.ts +16 -0
- package/dist/interactive-commands/session/index.d.ts.map +1 -0
- package/dist/interactive-commands/session/index.js +6 -0
- package/dist/interactive-commands/session/session-commands.cjs +64 -0
- package/dist/interactive-commands/session/session-commands.d.ts +32 -0
- package/dist/interactive-commands/session/session-commands.d.ts.map +1 -0
- package/dist/interactive-commands/session/session-commands.js +38 -0
- package/dist/interactive-commands/system/index.cjs +28 -0
- package/dist/interactive-commands/system/index.d.ts +13 -0
- package/dist/interactive-commands/system/index.d.ts.map +1 -0
- package/dist/interactive-commands/system/index.js +4 -0
- package/dist/interactive-commands/system/system-commands.cjs +217 -0
- package/dist/interactive-commands/system/system-commands.d.ts +6 -0
- package/dist/interactive-commands/system/system-commands.d.ts.map +1 -0
- package/dist/interactive-commands/system/system-commands.js +195 -0
- package/dist/interactive-commands/tool-commands.cjs +38 -0
- package/dist/interactive-commands/tool-commands.d.ts +15 -0
- package/dist/interactive-commands/tool-commands.d.ts.map +1 -0
- package/dist/interactive-commands/tool-commands.js +14 -0
- package/dist/interactive-commands/utils/arg-parser.cjs +59 -0
- package/dist/interactive-commands/utils/arg-parser.d.ts +57 -0
- package/dist/interactive-commands/utils/arg-parser.d.ts.map +1 -0
- package/dist/interactive-commands/utils/arg-parser.js +34 -0
- package/dist/interactive-commands/utils/command-output.cjs +75 -0
- package/dist/interactive-commands/utils/command-output.d.ts +40 -0
- package/dist/interactive-commands/utils/command-output.d.ts.map +1 -0
- package/dist/interactive-commands/utils/command-output.js +51 -0
- package/dist/interactive-commands/utils/format-output.cjs +36 -0
- package/dist/interactive-commands/utils/format-output.d.ts +14 -0
- package/dist/interactive-commands/utils/format-output.d.ts.map +1 -0
- package/dist/interactive-commands/utils/format-output.js +11 -0
- package/dist/services/CommandService.cjs +68 -0
- package/dist/services/CommandService.d.ts +58 -0
- package/dist/services/CommandService.d.ts.map +1 -0
- package/dist/services/CommandService.js +41 -0
- package/dist/services/InputService.cjs +97 -0
- package/dist/services/InputService.d.ts +40 -0
- package/dist/services/InputService.d.ts.map +1 -0
- package/dist/services/InputService.js +78 -0
- package/dist/services/MessageService.cjs +69 -0
- package/dist/services/MessageService.d.ts +35 -0
- package/dist/services/MessageService.d.ts.map +1 -0
- package/dist/services/MessageService.js +51 -0
- package/dist/services/index.cjs +39 -0
- package/dist/services/index.d.ts +8 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +16 -0
- package/dist/services/processStream.cjs +877 -0
- package/dist/services/processStream.d.ts +79 -0
- package/dist/services/processStream.d.ts.map +1 -0
- package/dist/services/processStream.js +843 -0
- package/dist/services/processStream.test.cjs +255 -0
- package/dist/services/processStream.test.d.ts +2 -0
- package/dist/services/processStream.test.d.ts.map +1 -0
- package/dist/services/processStream.test.js +254 -0
- package/dist/state/actions.cjs +16 -0
- package/dist/state/actions.d.ts +124 -0
- package/dist/state/actions.d.ts.map +1 -0
- package/dist/state/actions.js +0 -0
- package/dist/state/index.cjs +28 -0
- package/dist/state/index.d.ts +10 -0
- package/dist/state/index.d.ts.map +1 -0
- package/dist/state/index.js +4 -0
- package/dist/state/initialState.cjs +78 -0
- package/dist/state/initialState.d.ts +12 -0
- package/dist/state/initialState.d.ts.map +1 -0
- package/dist/state/initialState.js +54 -0
- package/dist/state/reducer.cjs +340 -0
- package/dist/state/reducer.d.ts +15 -0
- package/dist/state/reducer.d.ts.map +1 -0
- package/dist/state/reducer.js +316 -0
- package/dist/state/streaming-state.cjs +52 -0
- package/dist/state/streaming-state.d.ts +27 -0
- package/dist/state/streaming-state.d.ts.map +1 -0
- package/dist/state/streaming-state.js +25 -0
- package/dist/state/types.cjs +16 -0
- package/dist/state/types.d.ts +388 -0
- package/dist/state/types.d.ts.map +1 -0
- package/dist/state/types.js +0 -0
- package/dist/utils/bracketedPaste.cjs +37 -0
- package/dist/utils/bracketedPaste.d.ts +22 -0
- package/dist/utils/bracketedPaste.d.ts.map +1 -0
- package/dist/utils/bracketedPaste.js +12 -0
- package/dist/utils/clipboardUtils.cjs +297 -0
- package/dist/utils/clipboardUtils.d.ts +49 -0
- package/dist/utils/clipboardUtils.d.ts.map +1 -0
- package/dist/utils/clipboardUtils.js +261 -0
- package/dist/utils/commandOverlays.cjs +69 -0
- package/dist/utils/commandOverlays.d.ts +22 -0
- package/dist/utils/commandOverlays.d.ts.map +1 -0
- package/dist/utils/commandOverlays.js +44 -0
- package/dist/utils/debugLog.cjs +63 -0
- package/dist/utils/debugLog.d.ts +38 -0
- package/dist/utils/debugLog.d.ts.map +1 -0
- package/dist/utils/debugLog.js +39 -0
- package/dist/utils/elicitationSchema.cjs +85 -0
- package/dist/utils/elicitationSchema.d.ts +11 -0
- package/dist/utils/elicitationSchema.d.ts.map +1 -0
- package/dist/utils/elicitationSchema.js +61 -0
- package/dist/utils/elicitationSchema.test.cjs +78 -0
- package/dist/utils/elicitationSchema.test.d.ts +2 -0
- package/dist/utils/elicitationSchema.test.d.ts.map +1 -0
- package/dist/utils/elicitationSchema.test.js +77 -0
- package/dist/utils/idGenerator.cjs +31 -0
- package/dist/utils/idGenerator.d.ts +10 -0
- package/dist/utils/idGenerator.d.ts.map +1 -0
- package/dist/utils/idGenerator.js +7 -0
- package/dist/utils/index.cjs +62 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +39 -0
- package/dist/utils/input.cjs +72 -0
- package/dist/utils/input.d.ts +25 -0
- package/dist/utils/input.d.ts.map +1 -0
- package/dist/utils/input.js +39 -0
- package/dist/utils/inputParsing.cjs +76 -0
- package/dist/utils/inputParsing.d.ts +31 -0
- package/dist/utils/inputParsing.d.ts.map +1 -0
- package/dist/utils/inputParsing.js +48 -0
- package/dist/utils/llm-provider-display.cjs +49 -0
- package/dist/utils/llm-provider-display.d.ts +3 -0
- package/dist/utils/llm-provider-display.d.ts.map +1 -0
- package/dist/utils/llm-provider-display.js +25 -0
- package/dist/utils/messageFormatting.cjs +447 -0
- package/dist/utils/messageFormatting.d.ts +131 -0
- package/dist/utils/messageFormatting.d.ts.map +1 -0
- package/dist/utils/messageFormatting.js +393 -0
- package/dist/utils/messageFormatting.test.cjs +16 -0
- package/dist/utils/messageFormatting.test.d.ts +2 -0
- package/dist/utils/messageFormatting.test.d.ts.map +1 -0
- package/dist/utils/messageFormatting.test.js +15 -0
- package/dist/utils/mouse.cjs +196 -0
- package/dist/utils/mouse.d.ts +61 -0
- package/dist/utils/mouse.d.ts.map +1 -0
- package/dist/utils/mouse.js +172 -0
- package/dist/utils/overlayPresentation.cjs +48 -0
- package/dist/utils/overlayPresentation.d.ts +19 -0
- package/dist/utils/overlayPresentation.d.ts.map +1 -0
- package/dist/utils/overlayPresentation.js +22 -0
- package/dist/utils/overlaySizing.cjs +39 -0
- package/dist/utils/overlaySizing.d.ts +19 -0
- package/dist/utils/overlaySizing.d.ts.map +1 -0
- package/dist/utils/overlaySizing.js +15 -0
- package/dist/utils/soundNotification.cjs +217 -0
- package/dist/utils/soundNotification.d.ts +77 -0
- package/dist/utils/soundNotification.d.ts.map +1 -0
- package/dist/utils/soundNotification.js +188 -0
- package/dist/utils/soundNotification.test.cjs +126 -0
- package/dist/utils/soundNotification.test.d.ts +2 -0
- package/dist/utils/soundNotification.test.d.ts.map +1 -0
- package/dist/utils/soundNotification.test.js +125 -0
- package/dist/utils/streamSplitter.cjs +126 -0
- package/dist/utils/streamSplitter.d.ts +44 -0
- package/dist/utils/streamSplitter.d.ts.map +1 -0
- package/dist/utils/streamSplitter.js +100 -0
- package/dist/utils/textUtils.cjs +223 -0
- package/dist/utils/textUtils.d.ts +63 -0
- package/dist/utils/textUtils.d.ts.map +1 -0
- package/dist/utils/textUtils.js +174 -0
- package/dist/utils/toolUtils.cjs +40 -0
- package/dist/utils/toolUtils.d.ts +20 -0
- package/dist/utils/toolUtils.d.ts.map +1 -0
- package/dist/utils/toolUtils.js +14 -0
- package/package.json +51 -0
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { existsSync } from "fs";
|
|
2
|
+
import { isAbsolute, normalize, resolve, sep } from "path";
|
|
3
|
+
import { fileURLToPath } from "node:url";
|
|
4
|
+
import { execFile } from "child_process";
|
|
5
|
+
import { getDextoGlobalPath } from "@dexto/agent-management";
|
|
6
|
+
const CUSTOM_SOUND_EXTENSIONS = [".wav", ".mp3", ".ogg", ".oga", ".aiff", ".m4a"];
|
|
7
|
+
function getSoundFileKey(soundType) {
|
|
8
|
+
switch (soundType) {
|
|
9
|
+
case "startup":
|
|
10
|
+
return "startupSoundFile";
|
|
11
|
+
case "approval":
|
|
12
|
+
return "approvalSoundFile";
|
|
13
|
+
case "complete":
|
|
14
|
+
return "completeSoundFile";
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
function resolvePathWithinSoundsDir(soundPath) {
|
|
18
|
+
if (soundPath.trim().length === 0) return null;
|
|
19
|
+
const soundsDir = normalize(getDextoGlobalPath("sounds"));
|
|
20
|
+
const resolved = isAbsolute(soundPath) ? normalize(soundPath) : resolve(soundsDir, soundPath);
|
|
21
|
+
if (resolved === soundsDir || resolved.startsWith(soundsDir + sep)) {
|
|
22
|
+
return resolved;
|
|
23
|
+
}
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
const PLATFORM_SOUNDS = {
|
|
27
|
+
darwin: {
|
|
28
|
+
// macOS system sounds
|
|
29
|
+
approval: "/System/Library/Sounds/Blow.aiff",
|
|
30
|
+
complete: "/System/Library/Sounds/Glass.aiff"
|
|
31
|
+
},
|
|
32
|
+
linux: {
|
|
33
|
+
// Common Linux sound paths (freedesktop)
|
|
34
|
+
approval: "/usr/share/sounds/freedesktop/stereo/message-new-instant.oga",
|
|
35
|
+
complete: "/usr/share/sounds/freedesktop/stereo/complete.oga"
|
|
36
|
+
},
|
|
37
|
+
win32: {
|
|
38
|
+
// Windows system sounds (handled differently via PowerShell)
|
|
39
|
+
approval: "SystemAsterisk",
|
|
40
|
+
complete: "SystemHand"
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const BUNDLED_STARTUP_SOUND_PATH = fileURLToPath(
|
|
44
|
+
new URL("../../assets/sounds/startup.wav", import.meta.url)
|
|
45
|
+
);
|
|
46
|
+
function getDefaultSoundSpec(soundType) {
|
|
47
|
+
if (soundType === "startup") {
|
|
48
|
+
return BUNDLED_STARTUP_SOUND_PATH;
|
|
49
|
+
}
|
|
50
|
+
const platformSounds = PLATFORM_SOUNDS[process.platform];
|
|
51
|
+
return platformSounds?.[soundType] ?? null;
|
|
52
|
+
}
|
|
53
|
+
function playSound(soundPath) {
|
|
54
|
+
const execOrBell = (cmd, args, onError) => {
|
|
55
|
+
execFile(cmd, args, { windowsHide: true }, (error) => {
|
|
56
|
+
if (!error) return;
|
|
57
|
+
if (onError) {
|
|
58
|
+
onError();
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
playTerminalBell();
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
switch (process.platform) {
|
|
65
|
+
case "darwin": {
|
|
66
|
+
execOrBell("afplay", [soundPath]);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
case "linux": {
|
|
70
|
+
const lowerSoundPath = soundPath.toLowerCase();
|
|
71
|
+
const isOgg = lowerSoundPath.endsWith(".oga") || lowerSoundPath.endsWith(".ogg");
|
|
72
|
+
if (isOgg) {
|
|
73
|
+
execOrBell("paplay", [soundPath], () => {
|
|
74
|
+
execOrBell("ogg123", ["-q", soundPath]);
|
|
75
|
+
});
|
|
76
|
+
} else {
|
|
77
|
+
execOrBell("paplay", [soundPath], () => {
|
|
78
|
+
execOrBell("aplay", ["-q", soundPath]);
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
case "win32": {
|
|
84
|
+
if (["SystemAsterisk", "SystemHand", "SystemExclamation", "SystemQuestion"].includes(
|
|
85
|
+
soundPath
|
|
86
|
+
)) {
|
|
87
|
+
const systemSoundName = soundPath.replace("System", "");
|
|
88
|
+
execOrBell("powershell", [
|
|
89
|
+
"-NoProfile",
|
|
90
|
+
"-NonInteractive",
|
|
91
|
+
"-Command",
|
|
92
|
+
`[System.Media.SystemSounds]::${systemSoundName}.Play()`
|
|
93
|
+
]);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
execOrBell("powershell", [
|
|
97
|
+
"-NoProfile",
|
|
98
|
+
"-NonInteractive",
|
|
99
|
+
"-Command",
|
|
100
|
+
"& { param([string]$p) (New-Object System.Media.SoundPlayer $p).PlaySync() }",
|
|
101
|
+
soundPath
|
|
102
|
+
]);
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
default: {
|
|
106
|
+
playTerminalBell();
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
function playSoundFile(soundPath) {
|
|
112
|
+
playSound(soundPath);
|
|
113
|
+
}
|
|
114
|
+
function playTerminalBell() {
|
|
115
|
+
process.stdout.write("\x07");
|
|
116
|
+
}
|
|
117
|
+
function resolveNotificationSoundSpec(soundType, config) {
|
|
118
|
+
const configuredRelativePath = config?.[getSoundFileKey(soundType)];
|
|
119
|
+
if (configuredRelativePath) {
|
|
120
|
+
const resolved = resolvePathWithinSoundsDir(configuredRelativePath);
|
|
121
|
+
if (resolved && existsSync(resolved)) {
|
|
122
|
+
return resolved;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const defaultSpec = getDefaultSoundSpec(soundType);
|
|
126
|
+
if (!defaultSpec) return null;
|
|
127
|
+
if (process.platform === "win32") {
|
|
128
|
+
return defaultSpec;
|
|
129
|
+
}
|
|
130
|
+
return existsSync(defaultSpec) ? defaultSpec : null;
|
|
131
|
+
}
|
|
132
|
+
function playNotificationSound(soundType, config) {
|
|
133
|
+
const soundSpec = resolveNotificationSoundSpec(soundType, config);
|
|
134
|
+
if (!soundSpec) {
|
|
135
|
+
playTerminalBell();
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
playSound(soundSpec);
|
|
139
|
+
}
|
|
140
|
+
class SoundNotificationService {
|
|
141
|
+
config;
|
|
142
|
+
constructor(config) {
|
|
143
|
+
this.config = { ...config };
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Update configuration
|
|
147
|
+
*/
|
|
148
|
+
setConfig(config) {
|
|
149
|
+
this.config = { ...this.config, ...config };
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Get current configuration
|
|
153
|
+
*/
|
|
154
|
+
getConfig() {
|
|
155
|
+
return { ...this.config };
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Play CLI startup sound if enabled
|
|
159
|
+
*/
|
|
160
|
+
playStartupSound() {
|
|
161
|
+
if (this.config.enabled && this.config.onStartup) {
|
|
162
|
+
playNotificationSound("startup", this.config);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Play approval required sound if enabled
|
|
167
|
+
*/
|
|
168
|
+
playApprovalSound() {
|
|
169
|
+
if (this.config.enabled && this.config.onApprovalRequired) {
|
|
170
|
+
playNotificationSound("approval", this.config);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Play task complete sound if enabled
|
|
175
|
+
*/
|
|
176
|
+
playCompleteSound() {
|
|
177
|
+
if (this.config.enabled && this.config.onTaskComplete) {
|
|
178
|
+
playNotificationSound("complete", this.config);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
export {
|
|
183
|
+
CUSTOM_SOUND_EXTENSIONS,
|
|
184
|
+
SoundNotificationService,
|
|
185
|
+
getDefaultSoundSpec,
|
|
186
|
+
playNotificationSound,
|
|
187
|
+
playSoundFile
|
|
188
|
+
};
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var import_vitest = require("vitest");
|
|
3
|
+
var import_child_process = require("child_process");
|
|
4
|
+
var import_soundNotification = require("./soundNotification.js");
|
|
5
|
+
import_vitest.vi.mock("child_process", async (importOriginal) => {
|
|
6
|
+
const actual = await importOriginal();
|
|
7
|
+
return {
|
|
8
|
+
...actual,
|
|
9
|
+
execFile: import_vitest.vi.fn((_file, _args, _options, callback) => {
|
|
10
|
+
const cb = typeof _options === "function" ? _options : callback;
|
|
11
|
+
if (cb) cb(null, "", "");
|
|
12
|
+
})
|
|
13
|
+
};
|
|
14
|
+
});
|
|
15
|
+
const mockedExecFile = import_vitest.vi.mocked(import_child_process.execFile);
|
|
16
|
+
const TEST_CONFIG = {
|
|
17
|
+
enabled: true,
|
|
18
|
+
onStartup: false,
|
|
19
|
+
onApprovalRequired: true,
|
|
20
|
+
onTaskComplete: true
|
|
21
|
+
};
|
|
22
|
+
(0, import_vitest.describe)("SoundNotificationService", () => {
|
|
23
|
+
let originalStdoutWrite;
|
|
24
|
+
let writeSpy;
|
|
25
|
+
(0, import_vitest.beforeEach)(() => {
|
|
26
|
+
originalStdoutWrite = process.stdout.write;
|
|
27
|
+
writeSpy = import_vitest.vi.fn();
|
|
28
|
+
process.stdout.write = writeSpy;
|
|
29
|
+
});
|
|
30
|
+
(0, import_vitest.afterEach)(() => {
|
|
31
|
+
process.stdout.write = originalStdoutWrite;
|
|
32
|
+
});
|
|
33
|
+
(0, import_vitest.describe)("constructor", () => {
|
|
34
|
+
(0, import_vitest.it)("should accept full config", () => {
|
|
35
|
+
const service = new import_soundNotification.SoundNotificationService(TEST_CONFIG);
|
|
36
|
+
(0, import_vitest.expect)(service.getConfig()).toEqual(TEST_CONFIG);
|
|
37
|
+
});
|
|
38
|
+
(0, import_vitest.it)("should allow disabling specific sounds", () => {
|
|
39
|
+
const config = {
|
|
40
|
+
enabled: true,
|
|
41
|
+
onStartup: false,
|
|
42
|
+
onApprovalRequired: false,
|
|
43
|
+
onTaskComplete: true
|
|
44
|
+
};
|
|
45
|
+
const service = new import_soundNotification.SoundNotificationService(config);
|
|
46
|
+
(0, import_vitest.expect)(service.getConfig()).toEqual(config);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
(0, import_vitest.describe)("setConfig", () => {
|
|
50
|
+
(0, import_vitest.it)("should update config", () => {
|
|
51
|
+
const service = new import_soundNotification.SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
52
|
+
service.setConfig({ enabled: true });
|
|
53
|
+
(0, import_vitest.expect)(service.getConfig().enabled).toBe(true);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
(0, import_vitest.describe)("playApprovalSound", () => {
|
|
57
|
+
(0, import_vitest.it)("should not play when sounds disabled", () => {
|
|
58
|
+
const service = new import_soundNotification.SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
59
|
+
service.playApprovalSound();
|
|
60
|
+
(0, import_vitest.expect)(writeSpy).not.toHaveBeenCalled();
|
|
61
|
+
});
|
|
62
|
+
(0, import_vitest.it)("should not play when approval sounds disabled", () => {
|
|
63
|
+
const service = new import_soundNotification.SoundNotificationService({
|
|
64
|
+
...TEST_CONFIG,
|
|
65
|
+
onApprovalRequired: false
|
|
66
|
+
});
|
|
67
|
+
service.playApprovalSound();
|
|
68
|
+
(0, import_vitest.expect)(writeSpy).not.toHaveBeenCalled();
|
|
69
|
+
});
|
|
70
|
+
(0, import_vitest.it)("should attempt to play sound when enabled", () => {
|
|
71
|
+
const service = new import_soundNotification.SoundNotificationService(TEST_CONFIG);
|
|
72
|
+
mockedExecFile.mockClear();
|
|
73
|
+
writeSpy.mockClear();
|
|
74
|
+
service.playApprovalSound();
|
|
75
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
76
|
+
(0, import_vitest.expect)(soundAttempted).toBe(true);
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
(0, import_vitest.describe)("playStartupSound", () => {
|
|
80
|
+
(0, import_vitest.it)("should not play when startup sounds disabled", () => {
|
|
81
|
+
const service = new import_soundNotification.SoundNotificationService({
|
|
82
|
+
...TEST_CONFIG,
|
|
83
|
+
onStartup: false
|
|
84
|
+
});
|
|
85
|
+
mockedExecFile.mockClear();
|
|
86
|
+
writeSpy.mockClear();
|
|
87
|
+
service.playStartupSound();
|
|
88
|
+
(0, import_vitest.expect)(writeSpy).not.toHaveBeenCalled();
|
|
89
|
+
(0, import_vitest.expect)(mockedExecFile).not.toHaveBeenCalled();
|
|
90
|
+
});
|
|
91
|
+
(0, import_vitest.it)("should attempt to play sound when enabled", () => {
|
|
92
|
+
const service = new import_soundNotification.SoundNotificationService({
|
|
93
|
+
...TEST_CONFIG,
|
|
94
|
+
onStartup: true
|
|
95
|
+
});
|
|
96
|
+
mockedExecFile.mockClear();
|
|
97
|
+
writeSpy.mockClear();
|
|
98
|
+
service.playStartupSound();
|
|
99
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
100
|
+
(0, import_vitest.expect)(soundAttempted).toBe(true);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
(0, import_vitest.describe)("playCompleteSound", () => {
|
|
104
|
+
(0, import_vitest.it)("should not play when sounds disabled", () => {
|
|
105
|
+
const service = new import_soundNotification.SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
106
|
+
service.playCompleteSound();
|
|
107
|
+
(0, import_vitest.expect)(writeSpy).not.toHaveBeenCalled();
|
|
108
|
+
});
|
|
109
|
+
(0, import_vitest.it)("should not play when complete sounds disabled", () => {
|
|
110
|
+
const service = new import_soundNotification.SoundNotificationService({
|
|
111
|
+
...TEST_CONFIG,
|
|
112
|
+
onTaskComplete: false
|
|
113
|
+
});
|
|
114
|
+
service.playCompleteSound();
|
|
115
|
+
(0, import_vitest.expect)(writeSpy).not.toHaveBeenCalled();
|
|
116
|
+
});
|
|
117
|
+
(0, import_vitest.it)("should attempt to play sound when enabled", () => {
|
|
118
|
+
const service = new import_soundNotification.SoundNotificationService(TEST_CONFIG);
|
|
119
|
+
mockedExecFile.mockClear();
|
|
120
|
+
writeSpy.mockClear();
|
|
121
|
+
service.playCompleteSound();
|
|
122
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
123
|
+
(0, import_vitest.expect)(soundAttempted).toBe(true);
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"soundNotification.test.d.ts","sourceRoot":"","sources":["../../src/utils/soundNotification.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
|
|
2
|
+
import { execFile } from "child_process";
|
|
3
|
+
import { SoundNotificationService } from "./soundNotification.js";
|
|
4
|
+
vi.mock("child_process", async (importOriginal) => {
|
|
5
|
+
const actual = await importOriginal();
|
|
6
|
+
return {
|
|
7
|
+
...actual,
|
|
8
|
+
execFile: vi.fn((_file, _args, _options, callback) => {
|
|
9
|
+
const cb = typeof _options === "function" ? _options : callback;
|
|
10
|
+
if (cb) cb(null, "", "");
|
|
11
|
+
})
|
|
12
|
+
};
|
|
13
|
+
});
|
|
14
|
+
const mockedExecFile = vi.mocked(execFile);
|
|
15
|
+
const TEST_CONFIG = {
|
|
16
|
+
enabled: true,
|
|
17
|
+
onStartup: false,
|
|
18
|
+
onApprovalRequired: true,
|
|
19
|
+
onTaskComplete: true
|
|
20
|
+
};
|
|
21
|
+
describe("SoundNotificationService", () => {
|
|
22
|
+
let originalStdoutWrite;
|
|
23
|
+
let writeSpy;
|
|
24
|
+
beforeEach(() => {
|
|
25
|
+
originalStdoutWrite = process.stdout.write;
|
|
26
|
+
writeSpy = vi.fn();
|
|
27
|
+
process.stdout.write = writeSpy;
|
|
28
|
+
});
|
|
29
|
+
afterEach(() => {
|
|
30
|
+
process.stdout.write = originalStdoutWrite;
|
|
31
|
+
});
|
|
32
|
+
describe("constructor", () => {
|
|
33
|
+
it("should accept full config", () => {
|
|
34
|
+
const service = new SoundNotificationService(TEST_CONFIG);
|
|
35
|
+
expect(service.getConfig()).toEqual(TEST_CONFIG);
|
|
36
|
+
});
|
|
37
|
+
it("should allow disabling specific sounds", () => {
|
|
38
|
+
const config = {
|
|
39
|
+
enabled: true,
|
|
40
|
+
onStartup: false,
|
|
41
|
+
onApprovalRequired: false,
|
|
42
|
+
onTaskComplete: true
|
|
43
|
+
};
|
|
44
|
+
const service = new SoundNotificationService(config);
|
|
45
|
+
expect(service.getConfig()).toEqual(config);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
describe("setConfig", () => {
|
|
49
|
+
it("should update config", () => {
|
|
50
|
+
const service = new SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
51
|
+
service.setConfig({ enabled: true });
|
|
52
|
+
expect(service.getConfig().enabled).toBe(true);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
describe("playApprovalSound", () => {
|
|
56
|
+
it("should not play when sounds disabled", () => {
|
|
57
|
+
const service = new SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
58
|
+
service.playApprovalSound();
|
|
59
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
60
|
+
});
|
|
61
|
+
it("should not play when approval sounds disabled", () => {
|
|
62
|
+
const service = new SoundNotificationService({
|
|
63
|
+
...TEST_CONFIG,
|
|
64
|
+
onApprovalRequired: false
|
|
65
|
+
});
|
|
66
|
+
service.playApprovalSound();
|
|
67
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
68
|
+
});
|
|
69
|
+
it("should attempt to play sound when enabled", () => {
|
|
70
|
+
const service = new SoundNotificationService(TEST_CONFIG);
|
|
71
|
+
mockedExecFile.mockClear();
|
|
72
|
+
writeSpy.mockClear();
|
|
73
|
+
service.playApprovalSound();
|
|
74
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
75
|
+
expect(soundAttempted).toBe(true);
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
describe("playStartupSound", () => {
|
|
79
|
+
it("should not play when startup sounds disabled", () => {
|
|
80
|
+
const service = new SoundNotificationService({
|
|
81
|
+
...TEST_CONFIG,
|
|
82
|
+
onStartup: false
|
|
83
|
+
});
|
|
84
|
+
mockedExecFile.mockClear();
|
|
85
|
+
writeSpy.mockClear();
|
|
86
|
+
service.playStartupSound();
|
|
87
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
88
|
+
expect(mockedExecFile).not.toHaveBeenCalled();
|
|
89
|
+
});
|
|
90
|
+
it("should attempt to play sound when enabled", () => {
|
|
91
|
+
const service = new SoundNotificationService({
|
|
92
|
+
...TEST_CONFIG,
|
|
93
|
+
onStartup: true
|
|
94
|
+
});
|
|
95
|
+
mockedExecFile.mockClear();
|
|
96
|
+
writeSpy.mockClear();
|
|
97
|
+
service.playStartupSound();
|
|
98
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
99
|
+
expect(soundAttempted).toBe(true);
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
describe("playCompleteSound", () => {
|
|
103
|
+
it("should not play when sounds disabled", () => {
|
|
104
|
+
const service = new SoundNotificationService({ ...TEST_CONFIG, enabled: false });
|
|
105
|
+
service.playCompleteSound();
|
|
106
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
107
|
+
});
|
|
108
|
+
it("should not play when complete sounds disabled", () => {
|
|
109
|
+
const service = new SoundNotificationService({
|
|
110
|
+
...TEST_CONFIG,
|
|
111
|
+
onTaskComplete: false
|
|
112
|
+
});
|
|
113
|
+
service.playCompleteSound();
|
|
114
|
+
expect(writeSpy).not.toHaveBeenCalled();
|
|
115
|
+
});
|
|
116
|
+
it("should attempt to play sound when enabled", () => {
|
|
117
|
+
const service = new SoundNotificationService(TEST_CONFIG);
|
|
118
|
+
mockedExecFile.mockClear();
|
|
119
|
+
writeSpy.mockClear();
|
|
120
|
+
service.playCompleteSound();
|
|
121
|
+
const soundAttempted = mockedExecFile.mock.calls.length > 0 || writeSpy.mock.calls.length > 0;
|
|
122
|
+
expect(soundAttempted).toBe(true);
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
});
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var streamSplitter_exports = {};
|
|
20
|
+
__export(streamSplitter_exports, {
|
|
21
|
+
checkForSplit: () => checkForSplit,
|
|
22
|
+
findLastSafeNewline: () => findLastSafeNewline,
|
|
23
|
+
findLastSafeSplitPoint: () => findLastSafeSplitPoint
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(streamSplitter_exports);
|
|
26
|
+
function isIndexInsideCodeBlock(content, indexToTest) {
|
|
27
|
+
let fenceCount = 0;
|
|
28
|
+
let searchPos = 0;
|
|
29
|
+
while (searchPos < content.length) {
|
|
30
|
+
const nextFence = content.indexOf("```", searchPos);
|
|
31
|
+
if (nextFence === -1 || nextFence >= indexToTest) {
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
fenceCount++;
|
|
35
|
+
searchPos = nextFence + 3;
|
|
36
|
+
}
|
|
37
|
+
return fenceCount % 2 === 1;
|
|
38
|
+
}
|
|
39
|
+
function findEnclosingCodeBlockStart(content, index) {
|
|
40
|
+
if (!isIndexInsideCodeBlock(content, index)) {
|
|
41
|
+
return -1;
|
|
42
|
+
}
|
|
43
|
+
let currentSearchPos = 0;
|
|
44
|
+
while (currentSearchPos < index) {
|
|
45
|
+
const blockStartIndex = content.indexOf("```", currentSearchPos);
|
|
46
|
+
if (blockStartIndex === -1 || blockStartIndex >= index) {
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
const blockEndIndex = content.indexOf("```", blockStartIndex + 3);
|
|
50
|
+
if (blockStartIndex < index) {
|
|
51
|
+
if (blockEndIndex === -1 || index < blockEndIndex + 3) {
|
|
52
|
+
return blockStartIndex;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
if (blockEndIndex === -1) break;
|
|
56
|
+
currentSearchPos = blockEndIndex + 3;
|
|
57
|
+
}
|
|
58
|
+
return -1;
|
|
59
|
+
}
|
|
60
|
+
function findLastSafeSplitPoint(content) {
|
|
61
|
+
const enclosingBlockStart = findEnclosingCodeBlockStart(content, content.length);
|
|
62
|
+
if (enclosingBlockStart !== -1) {
|
|
63
|
+
return enclosingBlockStart;
|
|
64
|
+
}
|
|
65
|
+
let searchStartIndex = content.length;
|
|
66
|
+
while (searchStartIndex >= 0) {
|
|
67
|
+
const dnlIndex = content.lastIndexOf("\n\n", searchStartIndex);
|
|
68
|
+
if (dnlIndex === -1) {
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
const potentialSplitPoint = dnlIndex + 2;
|
|
72
|
+
if (!isIndexInsideCodeBlock(content, potentialSplitPoint)) {
|
|
73
|
+
return potentialSplitPoint;
|
|
74
|
+
}
|
|
75
|
+
searchStartIndex = dnlIndex - 1;
|
|
76
|
+
}
|
|
77
|
+
return content.length;
|
|
78
|
+
}
|
|
79
|
+
function findLastSafeNewline(content) {
|
|
80
|
+
let searchPos = content.length;
|
|
81
|
+
while (searchPos > 0) {
|
|
82
|
+
const nlIndex = content.lastIndexOf("\n", searchPos - 1);
|
|
83
|
+
if (nlIndex === -1) {
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
if (!isIndexInsideCodeBlock(content, nlIndex)) {
|
|
87
|
+
return nlIndex + 1;
|
|
88
|
+
}
|
|
89
|
+
searchPos = nlIndex;
|
|
90
|
+
}
|
|
91
|
+
return -1;
|
|
92
|
+
}
|
|
93
|
+
const MIN_PARAGRAPH_SPLIT_LENGTH = 200;
|
|
94
|
+
const MAX_PENDING_LENGTH = 300;
|
|
95
|
+
function checkForSplit(content) {
|
|
96
|
+
if (content.length < MIN_PARAGRAPH_SPLIT_LENGTH) {
|
|
97
|
+
return { shouldSplit: false };
|
|
98
|
+
}
|
|
99
|
+
const paragraphSplitPoint = findLastSafeSplitPoint(content);
|
|
100
|
+
if (paragraphSplitPoint > 80 && paragraphSplitPoint < content.length - 20) {
|
|
101
|
+
return {
|
|
102
|
+
shouldSplit: true,
|
|
103
|
+
splitIndex: paragraphSplitPoint,
|
|
104
|
+
before: content.substring(0, paragraphSplitPoint),
|
|
105
|
+
after: content.substring(paragraphSplitPoint)
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
if (content.length > MAX_PENDING_LENGTH) {
|
|
109
|
+
const lineSplitPoint = findLastSafeNewline(content);
|
|
110
|
+
if (lineSplitPoint > 80 && lineSplitPoint < content.length - 20) {
|
|
111
|
+
return {
|
|
112
|
+
shouldSplit: true,
|
|
113
|
+
splitIndex: lineSplitPoint,
|
|
114
|
+
before: content.substring(0, lineSplitPoint),
|
|
115
|
+
after: content.substring(lineSplitPoint)
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return { shouldSplit: false };
|
|
120
|
+
}
|
|
121
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
122
|
+
0 && (module.exports = {
|
|
123
|
+
checkForSplit,
|
|
124
|
+
findLastSafeNewline,
|
|
125
|
+
findLastSafeSplitPoint
|
|
126
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stream Splitter Utilities
|
|
3
|
+
*
|
|
4
|
+
* Provides markdown-aware splitting for streaming content to reduce flickering.
|
|
5
|
+
*
|
|
6
|
+
* Approach:
|
|
7
|
+
* - Find safe split points at paragraph boundaries (\n\n)
|
|
8
|
+
* - Protect code blocks from being split mid-block
|
|
9
|
+
* - Allow progressive finalization during streaming
|
|
10
|
+
*/
|
|
11
|
+
/**
|
|
12
|
+
* Find the last safe split point in the content.
|
|
13
|
+
*
|
|
14
|
+
* Safe split points are:
|
|
15
|
+
* 1. After paragraph breaks (\n\n) that are not inside code blocks
|
|
16
|
+
* 2. Before code blocks if we're inside one
|
|
17
|
+
*
|
|
18
|
+
* Returns the index to split at, or content.length if no split is needed.
|
|
19
|
+
*/
|
|
20
|
+
export declare function findLastSafeSplitPoint(content: string): number;
|
|
21
|
+
/**
|
|
22
|
+
* Find the last newline that's not inside a code block.
|
|
23
|
+
* Used for line-based batching.
|
|
24
|
+
*/
|
|
25
|
+
export declare function findLastSafeNewline(content: string): number;
|
|
26
|
+
/**
|
|
27
|
+
* Determines if content should be split for progressive finalization.
|
|
28
|
+
*
|
|
29
|
+
* Strategy:
|
|
30
|
+
* 1. First try paragraph splits (\n\n) for clean breaks
|
|
31
|
+
* 2. If content exceeds MAX_PENDING_LENGTH with no paragraph break,
|
|
32
|
+
* fall back to line-based splits (\n) to prevent flickering
|
|
33
|
+
*
|
|
34
|
+
* Returns:
|
|
35
|
+
* - { shouldSplit: false } if no split needed
|
|
36
|
+
* - { shouldSplit: true, splitIndex, before, after } if split found
|
|
37
|
+
*/
|
|
38
|
+
export declare function checkForSplit(content: string): {
|
|
39
|
+
shouldSplit: boolean;
|
|
40
|
+
splitIndex?: number;
|
|
41
|
+
before?: string;
|
|
42
|
+
after?: string;
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=streamSplitter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streamSplitter.d.ts","sourceRoot":"","sources":["../../src/utils/streamSplitter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAmDH;;;;;;;;GAQG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CA2B9D;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAiB3D;AAcD;;;;;;;;;;;GAWG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG;IAC5C,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB,CA+BA"}
|