@google/gemini-cli 0.30.1 → 0.31.0-preview.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/google-gemini-cli-0.31.0-preview.0.tgz +0 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +15 -2
- package/dist/index.js.map +1 -1
- package/dist/package.json +7 -6
- package/dist/src/commands/extensions/install.js +72 -4
- package/dist/src/commands/extensions/install.js.map +1 -1
- package/dist/src/commands/extensions/install.test.js +153 -20
- package/dist/src/commands/extensions/install.test.js.map +1 -1
- package/dist/src/commands/extensions/utils.js +1 -0
- package/dist/src/commands/extensions/utils.js.map +1 -1
- package/dist/src/config/config.js +17 -5
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +79 -4
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/extension-manager-hydration.test.js +2 -2
- package/dist/src/config/extension-manager-hydration.test.js.map +1 -1
- package/dist/src/config/extension-manager.js +10 -6
- package/dist/src/config/extension-manager.js.map +1 -1
- package/dist/src/config/extension.test.js +20 -20
- package/dist/src/config/extension.test.js.map +1 -1
- package/dist/src/config/extensionRegistryClient.js +3 -2
- package/dist/src/config/extensionRegistryClient.js.map +1 -1
- package/dist/src/config/extensionRegistryClient.test.js +52 -0
- package/dist/src/config/extensionRegistryClient.test.js.map +1 -1
- package/dist/src/config/extensions/consent.d.ts +10 -0
- package/dist/src/config/extensions/consent.js +10 -3
- package/dist/src/config/extensions/consent.js.map +1 -1
- package/dist/src/config/extensions/consent.test.js +1 -1
- package/dist/src/config/extensions/consent.test.js.map +1 -1
- package/dist/src/config/extensions/extensionEnablement.js +1 -0
- package/dist/src/config/extensions/extensionEnablement.js.map +1 -1
- package/dist/src/config/extensions/extensionSettings.js +20 -3
- package/dist/src/config/extensions/extensionSettings.js.map +1 -1
- package/dist/src/config/extensions/extensionSettings.test.js +16 -0
- package/dist/src/config/extensions/extensionSettings.test.js.map +1 -1
- package/dist/src/config/extensions/github.test.js +1 -1
- package/dist/src/config/extensions/github.test.js.map +1 -1
- package/dist/src/config/extensions/variables.js +3 -1
- package/dist/src/config/extensions/variables.js.map +1 -1
- package/dist/src/config/keyBindings.js +6 -2
- package/dist/src/config/keyBindings.js.map +1 -1
- package/dist/src/config/policy-engine.integration.test.js +51 -13
- package/dist/src/config/policy-engine.integration.test.js.map +1 -1
- package/dist/src/config/policy.d.ts +15 -3
- package/dist/src/config/policy.js +49 -4
- package/dist/src/config/policy.js.map +1 -1
- package/dist/src/config/policy.test.d.ts +6 -0
- package/dist/src/config/policy.test.js +152 -0
- package/dist/src/config/policy.test.js.map +1 -0
- package/dist/src/config/settings-validation.js +1 -1
- package/dist/src/config/settings-validation.js.map +1 -1
- package/dist/src/config/settings-validation.test.js +2 -3
- package/dist/src/config/settings-validation.test.js.map +1 -1
- package/dist/src/config/settings.d.ts +2 -0
- package/dist/src/config/settings.js +18 -20
- package/dist/src/config/settings.js.map +1 -1
- package/dist/src/config/settings.test.js +118 -18
- package/dist/src/config/settings.test.js.map +1 -1
- package/dist/src/config/settingsSchema.d.ts +171 -9
- package/dist/src/config/settingsSchema.js +159 -9
- package/dist/src/config/settingsSchema.js.map +1 -1
- package/dist/src/config/settingsSchema.test.js +26 -0
- package/dist/src/config/settingsSchema.test.js.map +1 -1
- package/dist/src/config/settings_repro.test.js +0 -1
- package/dist/src/config/settings_repro.test.js.map +1 -1
- package/dist/src/config/trustedFolders.test.js +3 -1
- package/dist/src/config/trustedFolders.test.js.map +1 -1
- package/dist/src/config/workspace-policy-cli.test.d.ts +6 -0
- package/dist/src/config/workspace-policy-cli.test.js +180 -0
- package/dist/src/config/workspace-policy-cli.test.js.map +1 -0
- package/dist/src/gemini.d.ts +2 -2
- package/dist/src/gemini.js +15 -5
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/gemini.test.js +18 -2
- package/dist/src/gemini.test.js.map +1 -1
- package/dist/src/gemini_cleanup.test.js +27 -24
- package/dist/src/gemini_cleanup.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/generated/git-commit.js.map +1 -1
- package/dist/src/integration-tests/modelSteering.test.d.ts +6 -0
- package/dist/src/integration-tests/modelSteering.test.js +65 -0
- package/dist/src/integration-tests/modelSteering.test.js.map +1 -0
- package/dist/src/nonInteractiveCli.js +2 -3
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/test-utils/AppRig.d.ts +1 -1
- package/dist/src/test-utils/AppRig.js +16 -7
- package/dist/src/test-utils/AppRig.js.map +1 -1
- package/dist/src/test-utils/AppRig.test.js +37 -2
- package/dist/src/test-utils/AppRig.test.js.map +1 -1
- package/dist/src/test-utils/async.d.ts +1 -1
- package/dist/src/test-utils/async.js +1 -1
- package/dist/src/test-utils/async.js.map +1 -1
- package/dist/src/test-utils/customMatchers.js +1 -1
- package/dist/src/test-utils/customMatchers.js.map +1 -1
- package/dist/src/test-utils/mockCommandContext.js +8 -2
- package/dist/src/test-utils/mockCommandContext.js.map +1 -1
- package/dist/src/test-utils/mockConfig.js +2 -1
- package/dist/src/test-utils/mockConfig.js.map +1 -1
- package/dist/src/test-utils/render.d.ts +81 -5
- package/dist/src/test-utils/render.js +299 -29
- package/dist/src/test-utils/render.js.map +1 -1
- package/dist/src/test-utils/render.test.js +49 -23
- package/dist/src/test-utils/render.test.js.map +1 -1
- package/dist/src/test-utils/settings.js +4 -2
- package/dist/src/test-utils/settings.js.map +1 -1
- package/dist/src/ui/App.test.js +56 -24
- package/dist/src/ui/App.test.js.map +1 -1
- package/dist/src/ui/AppContainer.d.ts +2 -2
- package/dist/src/ui/AppContainer.js +231 -11
- package/dist/src/ui/AppContainer.js.map +1 -1
- package/dist/src/ui/AppContainer.test.js +561 -7
- package/dist/src/ui/AppContainer.test.js.map +1 -1
- package/dist/src/ui/IdeIntegrationNudge.test.js +29 -33
- package/dist/src/ui/IdeIntegrationNudge.test.js.map +1 -1
- package/dist/src/ui/auth/ApiAuthDialog.test.js +19 -9
- package/dist/src/ui/auth/ApiAuthDialog.test.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.js +1 -1
- package/dist/src/ui/auth/AuthDialog.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.test.js +61 -27
- package/dist/src/ui/auth/AuthDialog.test.js.map +1 -1
- package/dist/src/ui/auth/AuthInProgress.test.js +35 -14
- package/dist/src/ui/auth/AuthInProgress.test.js.map +1 -1
- package/dist/src/ui/auth/LoginWithGoogleRestartDialog.test.js +11 -5
- package/dist/src/ui/auth/LoginWithGoogleRestartDialog.test.js.map +1 -1
- package/dist/src/ui/colors.js +6 -0
- package/dist/src/ui/colors.js.map +1 -1
- package/dist/src/ui/commands/clearCommand.js +2 -0
- package/dist/src/ui/commands/clearCommand.js.map +1 -1
- package/dist/src/ui/commands/clearCommand.test.js +7 -1
- package/dist/src/ui/commands/clearCommand.test.js.map +1 -1
- package/dist/src/ui/commands/copyCommand.js +2 -1
- package/dist/src/ui/commands/copyCommand.js.map +1 -1
- package/dist/src/ui/commands/copyCommand.test.js +6 -4
- package/dist/src/ui/commands/copyCommand.test.js.map +1 -1
- package/dist/src/ui/commands/extensionsCommand.js +18 -0
- package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
- package/dist/src/ui/commands/extensionsCommand.test.js +4 -4
- package/dist/src/ui/commands/extensionsCommand.test.js.map +1 -1
- package/dist/src/ui/commands/planCommand.js +1 -1
- package/dist/src/ui/commands/planCommand.js.map +1 -1
- package/dist/src/ui/commands/planCommand.test.js +1 -1
- package/dist/src/ui/commands/planCommand.test.js.map +1 -1
- package/dist/src/ui/commands/policiesCommand.js +5 -0
- package/dist/src/ui/commands/policiesCommand.js.map +1 -1
- package/dist/src/ui/commands/policiesCommand.test.js +38 -1
- package/dist/src/ui/commands/policiesCommand.test.js.map +1 -1
- package/dist/src/ui/commands/rewindCommand.js +3 -2
- package/dist/src/ui/commands/rewindCommand.js.map +1 -1
- package/dist/src/ui/components/AboutBox.test.js +16 -8
- package/dist/src/ui/components/AboutBox.test.js.map +1 -1
- package/dist/src/ui/components/AdminSettingsChangedDialog.test.js +7 -4
- package/dist/src/ui/components/AdminSettingsChangedDialog.test.js.map +1 -1
- package/dist/src/ui/components/AgentConfigDialog.test.js +41 -19
- package/dist/src/ui/components/AgentConfigDialog.test.js.map +1 -1
- package/dist/src/ui/components/AlternateBufferQuittingDisplay.js +1 -1
- package/dist/src/ui/components/AlternateBufferQuittingDisplay.js.map +1 -1
- package/dist/src/ui/components/AlternateBufferQuittingDisplay.test.js +24 -12
- package/dist/src/ui/components/AlternateBufferQuittingDisplay.test.js.map +1 -1
- package/dist/src/ui/components/AnsiOutput.test.js +35 -19
- package/dist/src/ui/components/AnsiOutput.test.js.map +1 -1
- package/dist/src/ui/components/AppHeader.test.js +27 -17
- package/dist/src/ui/components/AppHeader.test.js.map +1 -1
- package/dist/src/ui/components/ApprovalModeIndicator.test.js +18 -12
- package/dist/src/ui/components/ApprovalModeIndicator.test.js.map +1 -1
- package/dist/src/ui/components/AskUserDialog.test.js +147 -85
- package/dist/src/ui/components/AskUserDialog.test.js.map +1 -1
- package/dist/src/ui/components/BackgroundShellDisplay.test.js +50 -48
- package/dist/src/ui/components/BackgroundShellDisplay.test.js.map +1 -1
- package/dist/src/ui/components/Banner.test.js +8 -4
- package/dist/src/ui/components/Banner.test.js.map +1 -1
- package/dist/src/ui/components/Checklist.test.js +17 -12
- package/dist/src/ui/components/Checklist.test.js.map +1 -1
- package/dist/src/ui/components/ChecklistItem.test.js +9 -6
- package/dist/src/ui/components/ChecklistItem.test.js.map +1 -1
- package/dist/src/ui/components/CliSpinner.test.js +8 -5
- package/dist/src/ui/components/CliSpinner.test.js.map +1 -1
- package/dist/src/ui/components/Composer.js +5 -5
- package/dist/src/ui/components/Composer.js.map +1 -1
- package/dist/src/ui/components/Composer.test.js +104 -100
- package/dist/src/ui/components/Composer.test.js.map +1 -1
- package/dist/src/ui/components/ConfigInitDisplay.test.js +3 -2
- package/dist/src/ui/components/ConfigInitDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ConsentPrompt.test.js +15 -8
- package/dist/src/ui/components/ConsentPrompt.test.js.map +1 -1
- package/dist/src/ui/components/ConsoleSummaryDisplay.test.js +9 -5
- package/dist/src/ui/components/ConsoleSummaryDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ContextSummaryDisplay.test.js +16 -14
- package/dist/src/ui/components/ContextSummaryDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ContextUsageDisplay.test.js +12 -6
- package/dist/src/ui/components/ContextUsageDisplay.test.js.map +1 -1
- package/dist/src/ui/components/CopyModeWarning.test.js +9 -5
- package/dist/src/ui/components/CopyModeWarning.test.js.map +1 -1
- package/dist/src/ui/components/DebugProfiler.test.js +17 -14
- package/dist/src/ui/components/DebugProfiler.test.js.map +1 -1
- package/dist/src/ui/components/DetailedMessagesDisplay.test.js +13 -7
- package/dist/src/ui/components/DetailedMessagesDisplay.test.js.map +1 -1
- package/dist/src/ui/components/DialogManager.js +5 -1
- package/dist/src/ui/components/DialogManager.js.map +1 -1
- package/dist/src/ui/components/DialogManager.test.js +9 -5
- package/dist/src/ui/components/DialogManager.test.js.map +1 -1
- package/dist/src/ui/components/EditorSettingsDialog.test.js +16 -8
- package/dist/src/ui/components/EditorSettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/ExitPlanModeDialog.js +2 -2
- package/dist/src/ui/components/ExitPlanModeDialog.js.map +1 -1
- package/dist/src/ui/components/ExitPlanModeDialog.test.js +2 -2
- package/dist/src/ui/components/ExitPlanModeDialog.test.js.map +1 -1
- package/dist/src/ui/components/ExitWarning.test.js +18 -10
- package/dist/src/ui/components/ExitWarning.test.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.d.ts +2 -0
- package/dist/src/ui/components/FolderTrustDialog.js +49 -3
- package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.test.js +249 -18
- package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
- package/dist/src/ui/components/Footer.test.js +101 -50
- package/dist/src/ui/components/Footer.test.js.map +1 -1
- package/dist/src/ui/components/GeminiRespondingSpinner.test.js +23 -13
- package/dist/src/ui/components/GeminiRespondingSpinner.test.js.map +1 -1
- package/dist/src/ui/components/GradientRegression.test.js +20 -10
- package/dist/src/ui/components/GradientRegression.test.js.map +1 -1
- package/dist/src/ui/components/Header.test.js +2 -0
- package/dist/src/ui/components/Header.test.js.map +1 -1
- package/dist/src/ui/components/Help.test.js +9 -6
- package/dist/src/ui/components/Help.test.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.d.ts +1 -2
- package/dist/src/ui/components/HistoryItemDisplay.js +4 -3
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.test.js +80 -35
- package/dist/src/ui/components/HistoryItemDisplay.test.js.map +1 -1
- package/dist/src/ui/components/HookStatusDisplay.test.js +13 -9
- package/dist/src/ui/components/HookStatusDisplay.test.js.map +1 -1
- package/dist/src/ui/components/IdeTrustChangeDialog.test.js +36 -16
- package/dist/src/ui/components/IdeTrustChangeDialog.test.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.js +10 -12
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.test.js +127 -13
- package/dist/src/ui/components/InputPrompt.test.js.map +1 -1
- package/dist/src/ui/components/LoadingIndicator.test.js +97 -47
- package/dist/src/ui/components/LoadingIndicator.test.js.map +1 -1
- package/dist/src/ui/components/LogoutConfirmationDialog.test.js +25 -9
- package/dist/src/ui/components/LogoutConfirmationDialog.test.js.map +1 -1
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js +9 -5
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js.map +1 -1
- package/dist/src/ui/components/MainContent.js +35 -14
- package/dist/src/ui/components/MainContent.js.map +1 -1
- package/dist/src/ui/components/MainContent.test.js +224 -10
- package/dist/src/ui/components/MainContent.test.js.map +1 -1
- package/dist/src/ui/components/MemoryUsageDisplay.test.js +8 -3
- package/dist/src/ui/components/MemoryUsageDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ModelDialog.js +6 -6
- package/dist/src/ui/components/ModelDialog.js.map +1 -1
- package/dist/src/ui/components/ModelDialog.test.js +142 -16
- package/dist/src/ui/components/ModelDialog.test.js.map +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.test.js +38 -24
- package/dist/src/ui/components/ModelStatsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/MultiFolderTrustDialog.test.js +32 -9
- package/dist/src/ui/components/MultiFolderTrustDialog.test.js.map +1 -1
- package/dist/src/ui/components/NewAgentsNotification.test.js +6 -4
- package/dist/src/ui/components/NewAgentsNotification.test.js.map +1 -1
- package/dist/src/ui/components/Notifications.js +50 -4
- package/dist/src/ui/components/Notifications.js.map +1 -1
- package/dist/src/ui/components/Notifications.test.js +162 -30
- package/dist/src/ui/components/Notifications.test.js.map +1 -1
- package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +36 -10
- package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -1
- package/dist/src/ui/components/PolicyUpdateDialog.d.ts +18 -0
- package/dist/src/ui/components/PolicyUpdateDialog.js +59 -0
- package/dist/src/ui/components/PolicyUpdateDialog.js.map +1 -0
- package/dist/src/ui/components/PolicyUpdateDialog.test.d.ts +6 -0
- package/dist/src/ui/components/PolicyUpdateDialog.test.js +93 -0
- package/dist/src/ui/components/PolicyUpdateDialog.test.js.map +1 -0
- package/dist/src/ui/components/QueuedMessageDisplay.test.js +16 -11
- package/dist/src/ui/components/QueuedMessageDisplay.test.js.map +1 -1
- package/dist/src/ui/components/QuittingDisplay.test.js +9 -5
- package/dist/src/ui/components/QuittingDisplay.test.js.map +1 -1
- package/dist/src/ui/components/QuotaDisplay.test.js +40 -22
- package/dist/src/ui/components/QuotaDisplay.test.js.map +1 -1
- package/dist/src/ui/components/RawMarkdownIndicator.test.js +8 -4
- package/dist/src/ui/components/RawMarkdownIndicator.test.js.map +1 -1
- package/dist/src/ui/components/RewindConfirmation.test.js +15 -7
- package/dist/src/ui/components/RewindConfirmation.test.js.map +1 -1
- package/dist/src/ui/components/RewindViewer.js +9 -7
- package/dist/src/ui/components/RewindViewer.js.map +1 -1
- package/dist/src/ui/components/RewindViewer.test.js +54 -17
- package/dist/src/ui/components/RewindViewer.test.js.map +1 -1
- package/dist/src/ui/components/SessionBrowser.test.js +24 -11
- package/dist/src/ui/components/SessionBrowser.test.js.map +1 -1
- package/dist/src/ui/components/SessionRetentionWarningDialog.test.js +12 -7
- package/dist/src/ui/components/SessionRetentionWarningDialog.test.js.map +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.js +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.test.js +7 -4
- package/dist/src/ui/components/SessionSummaryDisplay.test.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.js +76 -7
- package/dist/src/ui/components/SettingsDialog.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.test.js +252 -109
- package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/ShellInputPrompt.test.js +120 -67
- package/dist/src/ui/components/ShellInputPrompt.test.js.map +1 -1
- package/dist/src/ui/components/ShellModeIndicator.test.js +4 -2
- package/dist/src/ui/components/ShellModeIndicator.test.js.map +1 -1
- package/dist/src/ui/components/ShortcutsHelp.js +1 -1
- package/dist/src/ui/components/ShortcutsHelp.js.map +1 -1
- package/dist/src/ui/components/ShortcutsHelp.test.js +6 -3
- package/dist/src/ui/components/ShortcutsHelp.test.js.map +1 -1
- package/dist/src/ui/components/ShowMoreLines.d.ts +2 -1
- package/dist/src/ui/components/ShowMoreLines.js +10 -5
- package/dist/src/ui/components/ShowMoreLines.js.map +1 -1
- package/dist/src/ui/components/ShowMoreLines.test.js +47 -7
- package/dist/src/ui/components/ShowMoreLines.test.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.d.ts +1 -0
- package/dist/src/ui/components/StatsDisplay.js +9 -3
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.test.js +51 -34
- package/dist/src/ui/components/StatsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/StatusDisplay.test.js +30 -17
- package/dist/src/ui/components/StatusDisplay.test.js.map +1 -1
- package/dist/src/ui/components/StickyHeader.test.js +4 -2
- package/dist/src/ui/components/StickyHeader.test.js.map +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.test.js +19 -13
- package/dist/src/ui/components/SuggestionsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/Table.test.js +9 -6
- package/dist/src/ui/components/Table.test.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.test.js +42 -19
- package/dist/src/ui/components/ThemeDialog.test.js.map +1 -1
- package/dist/src/ui/components/ThemedGradient.test.js +4 -2
- package/dist/src/ui/components/ThemedGradient.test.js.map +1 -1
- package/dist/src/ui/components/Tips.test.js +4 -2
- package/dist/src/ui/components/Tips.test.js.map +1 -1
- package/dist/src/ui/components/ToastDisplay.js +6 -1
- package/dist/src/ui/components/ToastDisplay.js.map +1 -1
- package/dist/src/ui/components/ToastDisplay.test.js +48 -17
- package/dist/src/ui/components/ToastDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ToolConfirmationQueue.js +11 -8
- package/dist/src/ui/components/ToolConfirmationQueue.js.map +1 -1
- package/dist/src/ui/components/ToolConfirmationQueue.test.js +75 -17
- package/dist/src/ui/components/ToolConfirmationQueue.test.js.map +1 -1
- package/dist/src/ui/components/ToolStatsDisplay.test.js +19 -12
- package/dist/src/ui/components/ToolStatsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/UpdateNotification.test.js +4 -2
- package/dist/src/ui/components/UpdateNotification.test.js.map +1 -1
- package/dist/src/ui/components/UserIdentity.test.js +16 -11
- package/dist/src/ui/components/UserIdentity.test.js.map +1 -1
- package/dist/src/ui/components/ValidationDialog.test.js +33 -16
- package/dist/src/ui/components/ValidationDialog.test.js.map +1 -1
- package/dist/src/ui/components/messages/CompressionMessage.test.js +99 -101
- package/dist/src/ui/components/messages/CompressionMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ErrorMessage.test.js +8 -4
- package/dist/src/ui/components/messages/ErrorMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/GeminiMessage.js +5 -1
- package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
- package/dist/src/ui/components/messages/GeminiMessage.test.js +12 -6
- package/dist/src/ui/components/messages/GeminiMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/HintMessage.d.ts +11 -0
- package/dist/src/ui/components/messages/HintMessage.js +14 -0
- package/dist/src/ui/components/messages/HintMessage.js.map +1 -0
- package/dist/src/ui/components/messages/InfoMessage.d.ts +1 -0
- package/dist/src/ui/components/messages/InfoMessage.js +2 -2
- package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
- package/dist/src/ui/components/messages/InfoMessage.test.js +12 -6
- package/dist/src/ui/components/messages/InfoMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/RedirectionConfirmation.test.js +4 -2
- package/dist/src/ui/components/messages/RedirectionConfirmation.test.js.map +1 -1
- package/dist/src/ui/components/messages/ShellToolMessage.d.ts +1 -2
- package/dist/src/ui/components/messages/ShellToolMessage.js +15 -29
- package/dist/src/ui/components/messages/ShellToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ShellToolMessage.test.js +91 -22
- package/dist/src/ui/components/messages/ShellToolMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ThinkingMessage.test.js +25 -13
- package/dist/src/ui/components/messages/ThinkingMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/Todo.test.js +34 -19
- package/dist/src/ui/components/messages/Todo.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js +128 -13
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +175 -20
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -4
- package/dist/src/ui/components/messages/ToolGroupMessage.js +91 -35
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js +286 -63
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.js +4 -4
- package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.test.js +118 -39
- package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessageFocusHint.test.js +15 -6
- package/dist/src/ui/components/messages/ToolMessageFocusHint.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessageRawMarkdown.test.js +4 -2
- package/dist/src/ui/components/messages/ToolMessageRawMarkdown.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolOverflowConsistencyChecks.test.d.ts +6 -0
- package/dist/src/ui/components/messages/ToolOverflowConsistencyChecks.test.js +79 -0
- package/dist/src/ui/components/messages/ToolOverflowConsistencyChecks.test.js.map +1 -0
- package/dist/src/ui/components/messages/ToolResultDisplay.js +25 -14
- package/dist/src/ui/components/messages/ToolResultDisplay.js.map +1 -1
- package/dist/src/ui/components/messages/ToolResultDisplay.test.js +81 -31
- package/dist/src/ui/components/messages/ToolResultDisplay.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolResultDisplayOverflow.test.js +5 -5
- package/dist/src/ui/components/messages/ToolResultDisplayOverflow.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolShared.d.ts +8 -0
- package/dist/src/ui/components/messages/ToolShared.js +27 -9
- package/dist/src/ui/components/messages/ToolShared.js.map +1 -1
- package/dist/src/ui/components/messages/ToolShared.test.d.ts +6 -0
- package/dist/src/ui/components/messages/ToolShared.test.js +52 -0
- package/dist/src/ui/components/messages/ToolShared.test.js.map +1 -0
- package/dist/src/ui/components/messages/ToolStickyHeaderRegression.test.js +11 -4
- package/dist/src/ui/components/messages/ToolStickyHeaderRegression.test.js.map +1 -1
- package/dist/src/ui/components/messages/UserMessage.js +1 -2
- package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
- package/dist/src/ui/components/messages/UserMessage.test.js +16 -8
- package/dist/src/ui/components/messages/UserMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/UserShellMessage.js +1 -2
- package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
- package/dist/src/ui/components/messages/WarningMessage.test.js +8 -4
- package/dist/src/ui/components/messages/WarningMessage.test.js.map +1 -1
- package/dist/src/ui/components/shared/BaseSelectionList.test.js +118 -106
- package/dist/src/ui/components/shared/BaseSelectionList.test.js.map +1 -1
- package/dist/src/ui/components/shared/BaseSettingsDialog.js +22 -24
- package/dist/src/ui/components/shared/BaseSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/shared/BaseSettingsDialog.test.js +139 -40
- package/dist/src/ui/components/shared/BaseSettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js +10 -6
- package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js.map +1 -1
- package/dist/src/ui/components/shared/EnumSelector.test.js +42 -20
- package/dist/src/ui/components/shared/EnumSelector.test.js.map +1 -1
- package/dist/src/ui/components/shared/ExpandableText.test.js +21 -14
- package/dist/src/ui/components/shared/ExpandableText.test.js.map +1 -1
- package/dist/src/ui/components/shared/HalfLinePaddedBox.test.js +8 -4
- package/dist/src/ui/components/shared/HalfLinePaddedBox.test.js.map +1 -1
- package/dist/src/ui/components/shared/MaxSizedBox.test.js +41 -30
- package/dist/src/ui/components/shared/MaxSizedBox.test.js.map +1 -1
- package/dist/src/ui/components/shared/Scrollable.js +2 -3
- package/dist/src/ui/components/shared/Scrollable.js.map +1 -1
- package/dist/src/ui/components/shared/Scrollable.test.js +33 -17
- package/dist/src/ui/components/shared/Scrollable.test.js.map +1 -1
- package/dist/src/ui/components/shared/ScrollableList.js +1 -1
- package/dist/src/ui/components/shared/ScrollableList.js.map +1 -1
- package/dist/src/ui/components/shared/ScrollableList.test.js +36 -6
- package/dist/src/ui/components/shared/ScrollableList.test.js.map +1 -1
- package/dist/src/ui/components/shared/SearchableList.d.ts +46 -14
- package/dist/src/ui/components/shared/SearchableList.js +69 -57
- package/dist/src/ui/components/shared/SearchableList.js.map +1 -1
- package/dist/src/ui/components/shared/SearchableList.test.js +67 -14
- package/dist/src/ui/components/shared/SearchableList.test.js.map +1 -1
- package/dist/src/ui/components/shared/SectionHeader.d.ts +1 -0
- package/dist/src/ui/components/shared/SectionHeader.js +1 -1
- package/dist/src/ui/components/shared/SectionHeader.js.map +1 -1
- package/dist/src/ui/components/shared/SectionHeader.test.js +9 -2
- package/dist/src/ui/components/shared/SectionHeader.test.js.map +1 -1
- package/dist/src/ui/components/shared/TabHeader.js +1 -1
- package/dist/src/ui/components/shared/TabHeader.js.map +1 -1
- package/dist/src/ui/components/shared/TabHeader.test.js +65 -25
- package/dist/src/ui/components/shared/TabHeader.test.js.map +1 -1
- package/dist/src/ui/components/shared/TextInput.test.js +111 -65
- package/dist/src/ui/components/shared/TextInput.test.js.map +1 -1
- package/dist/src/ui/components/shared/VirtualizedList.test.js +27 -35
- package/dist/src/ui/components/shared/VirtualizedList.test.js.map +1 -1
- package/dist/src/ui/components/triage/TriageDuplicates.js +1 -0
- package/dist/src/ui/components/triage/TriageDuplicates.js.map +1 -1
- package/dist/src/ui/components/triage/TriageIssues.js +1 -0
- package/dist/src/ui/components/triage/TriageIssues.js.map +1 -1
- package/dist/src/ui/components/views/ChatList.test.js +9 -6
- package/dist/src/ui/components/views/ChatList.test.js.map +1 -1
- package/dist/src/ui/components/views/ExtensionRegistryView.d.ts +15 -0
- package/dist/src/ui/components/views/ExtensionRegistryView.js +60 -0
- package/dist/src/ui/components/views/ExtensionRegistryView.js.map +1 -0
- package/dist/src/ui/components/views/ExtensionRegistryView.test.d.ts +6 -0
- package/dist/src/ui/components/views/ExtensionRegistryView.test.js +168 -0
- package/dist/src/ui/components/views/ExtensionRegistryView.test.js.map +1 -0
- package/dist/src/ui/components/views/ExtensionsList.test.js +21 -19
- package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -1
- package/dist/src/ui/components/views/McpStatus.test.js +38 -25
- package/dist/src/ui/components/views/McpStatus.test.js.map +1 -1
- package/dist/src/ui/components/views/SkillsList.test.js +18 -12
- package/dist/src/ui/components/views/SkillsList.test.js.map +1 -1
- package/dist/src/ui/components/views/ToolsList.test.js +9 -6
- package/dist/src/ui/components/views/ToolsList.test.js.map +1 -1
- package/dist/src/ui/constants/tips.js +1 -1
- package/dist/src/ui/constants/tips.js.map +1 -1
- package/dist/src/ui/constants.d.ts +2 -1
- package/dist/src/ui/constants.js +2 -1
- package/dist/src/ui/constants.js.map +1 -1
- package/dist/src/ui/contexts/AppContext.d.ts +2 -1
- package/dist/src/ui/contexts/AppContext.js.map +1 -1
- package/dist/src/ui/contexts/KeypressContext.js +37 -8
- package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
- package/dist/src/ui/contexts/KeypressContext.test.js +68 -0
- package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
- package/dist/src/ui/contexts/OverflowContext.d.ts +3 -3
- package/dist/src/ui/contexts/OverflowContext.js +5 -1
- package/dist/src/ui/contexts/OverflowContext.js.map +1 -1
- package/dist/src/ui/contexts/TerminalContext.test.js +26 -15
- package/dist/src/ui/contexts/TerminalContext.test.js.map +1 -1
- package/dist/src/ui/contexts/UIActionsContext.d.ts +6 -1
- package/dist/src/ui/contexts/UIActionsContext.js +1 -1
- package/dist/src/ui/contexts/UIActionsContext.js.map +1 -1
- package/dist/src/ui/contexts/UIStateContext.d.ts +7 -1
- package/dist/src/ui/contexts/UIStateContext.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.test.js +6 -2
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.js +23 -11
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.test.js +30 -14
- package/dist/src/ui/hooks/slashCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/toolMapping.d.ts +2 -0
- package/dist/src/ui/hooks/toolMapping.js +13 -1
- package/dist/src/ui/hooks/toolMapping.js.map +1 -1
- package/dist/src/ui/hooks/toolMapping.test.js +42 -0
- package/dist/src/ui/hooks/toolMapping.test.js.map +1 -1
- package/dist/src/ui/hooks/useAnimatedScrollbar.js +13 -3
- package/dist/src/ui/hooks/useAnimatedScrollbar.js.map +1 -1
- package/dist/src/ui/hooks/useAtCompletion.js +74 -22
- package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useAtCompletion.test.js +88 -0
- package/dist/src/ui/hooks/useAtCompletion.test.js.map +1 -1
- package/dist/src/ui/hooks/useCommandCompletion.js +2 -3
- package/dist/src/ui/hooks/useCommandCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useCommandCompletion.test.js +0 -4
- package/dist/src/ui/hooks/useCommandCompletion.test.js.map +1 -1
- package/dist/src/ui/hooks/useConfirmingTool.d.ts +2 -6
- package/dist/src/ui/hooks/useConfirmingTool.js +2 -23
- package/dist/src/ui/hooks/useConfirmingTool.js.map +1 -1
- package/dist/src/ui/hooks/useConsoleMessages.js +18 -6
- package/dist/src/ui/hooks/useConsoleMessages.js.map +1 -1
- package/dist/src/ui/hooks/useConsoleMessages.test.js +4 -4
- package/dist/src/ui/hooks/useExtensionRegistry.d.ts +13 -0
- package/dist/src/ui/hooks/useExtensionRegistry.js +70 -0
- package/dist/src/ui/hooks/useExtensionRegistry.js.map +1 -0
- package/dist/src/ui/hooks/useFocus.d.ts +4 -1
- package/dist/src/ui/hooks/useFocus.js +7 -1
- package/dist/src/ui/hooks/useFocus.js.map +1 -1
- package/dist/src/ui/hooks/useFocus.test.js +20 -11
- package/dist/src/ui/hooks/useFocus.test.js.map +1 -1
- package/dist/src/ui/hooks/useFolderTrust.d.ts +2 -0
- package/dist/src/ui/hooks/useFolderTrust.js +15 -3
- package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
- package/dist/src/ui/hooks/useFolderTrust.test.js +3 -0
- package/dist/src/ui/hooks/useFolderTrust.test.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.d.ts +1 -1
- package/dist/src/ui/hooks/useGeminiStream.js +86 -20
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.test.js +150 -1
- package/dist/src/ui/hooks/useGeminiStream.test.js.map +1 -1
- package/dist/src/ui/hooks/useLoadingIndicator.d.ts +3 -1
- package/dist/src/ui/hooks/useLoadingIndicator.js +2 -2
- package/dist/src/ui/hooks/useLoadingIndicator.js.map +1 -1
- package/dist/src/ui/hooks/useLoadingIndicator.test.js +9 -4
- package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
- package/dist/src/ui/hooks/useMouseClick.test.js +15 -7
- package/dist/src/ui/hooks/useMouseClick.test.js.map +1 -1
- package/dist/src/ui/hooks/usePhraseCycler.d.ts +4 -2
- package/dist/src/ui/hooks/usePhraseCycler.js +38 -26
- package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
- package/dist/src/ui/hooks/usePhraseCycler.test.js +123 -73
- package/dist/src/ui/hooks/usePhraseCycler.test.js.map +1 -1
- package/dist/src/ui/hooks/usePromptCompletion.d.ts +1 -2
- package/dist/src/ui/hooks/usePromptCompletion.js +2 -2
- package/dist/src/ui/hooks/usePromptCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useRegistrySearch.d.ts +19 -0
- package/dist/src/ui/hooks/useRegistrySearch.js +35 -0
- package/dist/src/ui/hooks/useRegistrySearch.js.map +1 -0
- package/dist/src/ui/hooks/useRunEventNotifications.d.ts +22 -0
- package/dist/src/ui/hooks/useRunEventNotifications.js +93 -0
- package/dist/src/ui/hooks/useRunEventNotifications.js.map +1 -0
- package/dist/src/ui/hooks/useSearchBuffer.d.ts +11 -0
- package/dist/src/ui/hooks/useSearchBuffer.js +24 -0
- package/dist/src/ui/hooks/useSearchBuffer.js.map +1 -0
- package/dist/src/ui/hooks/useSelectionList.test.js +111 -45
- package/dist/src/ui/hooks/useSelectionList.test.js.map +1 -1
- package/dist/src/ui/hooks/useSessionBrowser.js +3 -2
- package/dist/src/ui/hooks/useSessionBrowser.js.map +1 -1
- package/dist/src/ui/hooks/useSessionBrowser.test.js +15 -12
- package/dist/src/ui/hooks/useSessionBrowser.test.js.map +1 -1
- package/dist/src/ui/hooks/useSessionResume.js +2 -2
- package/dist/src/ui/hooks/useSessionResume.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.js +1 -0
- package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useStateAndRef.js +1 -0
- package/dist/src/ui/hooks/useStateAndRef.js.map +1 -1
- package/dist/src/ui/hooks/useTerminalTheme.test.js +29 -18
- package/dist/src/ui/hooks/useTerminalTheme.test.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.js +19 -2
- package/dist/src/ui/hooks/useToolScheduler.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.test.js +44 -0
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
- package/dist/src/ui/keyMatchers.test.js +1 -0
- package/dist/src/ui/keyMatchers.test.js.map +1 -1
- package/dist/src/ui/layouts/DefaultAppLayout.test.js +12 -6
- package/dist/src/ui/layouts/DefaultAppLayout.test.js.map +1 -1
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.test.js +24 -8
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.test.js.map +1 -1
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.test.js +16 -5
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.test.js.map +1 -1
- package/dist/src/ui/privacy/GeminiPrivacyNotice.test.js +16 -5
- package/dist/src/ui/privacy/GeminiPrivacyNotice.test.js.map +1 -1
- package/dist/src/ui/privacy/PrivacyNotice.test.js +4 -2
- package/dist/src/ui/privacy/PrivacyNotice.test.js.map +1 -1
- package/dist/src/ui/themes/no-color.js +4 -0
- package/dist/src/ui/themes/no-color.js.map +1 -1
- package/dist/src/ui/themes/semantic-tokens.d.ts +2 -0
- package/dist/src/ui/themes/semantic-tokens.js +6 -2
- package/dist/src/ui/themes/semantic-tokens.js.map +1 -1
- package/dist/src/ui/themes/solarized-dark.js +2 -0
- package/dist/src/ui/themes/solarized-dark.js.map +1 -1
- package/dist/src/ui/themes/solarized-light.js +2 -0
- package/dist/src/ui/themes/solarized-light.js.map +1 -1
- package/dist/src/ui/themes/theme-manager.js +9 -4
- package/dist/src/ui/themes/theme-manager.js.map +1 -1
- package/dist/src/ui/themes/theme.d.ts +2 -0
- package/dist/src/ui/themes/theme.js +20 -7
- package/dist/src/ui/themes/theme.js.map +1 -1
- package/dist/src/ui/themes/theme.test.js +7 -7
- package/dist/src/ui/themes/theme.test.js.map +1 -1
- package/dist/src/ui/types.d.ts +14 -2
- package/dist/src/ui/types.js +1 -0
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/ui/utils/CodeColorizer.js +3 -5
- package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
- package/dist/src/ui/utils/CodeColorizer.test.js +4 -2
- package/dist/src/ui/utils/CodeColorizer.test.js.map +1 -1
- package/dist/src/ui/utils/InlineMarkdownRenderer.js +3 -1
- package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.js +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.test.js +65 -33
- package/dist/src/ui/utils/MarkdownDisplay.test.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.js +7 -3
- package/dist/src/ui/utils/TableRenderer.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.test.js +43 -22
- package/dist/src/ui/utils/TableRenderer.test.js.map +1 -1
- package/dist/src/ui/utils/borderStyles.d.ts +18 -0
- package/dist/src/ui/utils/borderStyles.js +78 -0
- package/dist/src/ui/utils/borderStyles.js.map +1 -0
- package/dist/src/ui/utils/commandUtils.d.ts +2 -1
- package/dist/src/ui/utils/commandUtils.js +8 -3
- package/dist/src/ui/utils/commandUtils.js.map +1 -1
- package/dist/src/ui/utils/commandUtils.test.js +18 -0
- package/dist/src/ui/utils/commandUtils.test.js.map +1 -1
- package/dist/src/ui/utils/confirmingTool.d.ts +15 -0
- package/dist/src/ui/utils/confirmingTool.js +27 -0
- package/dist/src/ui/utils/confirmingTool.js.map +1 -0
- package/dist/src/ui/utils/pendingAttentionNotification.d.ts +12 -0
- package/dist/src/ui/utils/pendingAttentionNotification.js +101 -0
- package/dist/src/ui/utils/pendingAttentionNotification.js.map +1 -0
- package/dist/src/ui/utils/pendingAttentionNotification.test.d.ts +6 -0
- package/dist/src/ui/utils/pendingAttentionNotification.test.js +79 -0
- package/dist/src/ui/utils/pendingAttentionNotification.test.js.map +1 -0
- package/dist/src/ui/utils/terminalCapabilityManager.d.ts +2 -0
- package/dist/src/ui/utils/terminalCapabilityManager.js +18 -0
- package/dist/src/ui/utils/terminalCapabilityManager.js.map +1 -1
- package/dist/src/ui/utils/terminalCapabilityManager.test.js +68 -0
- package/dist/src/ui/utils/terminalCapabilityManager.test.js.map +1 -1
- package/dist/src/ui/utils/terminalSetup.d.ts +24 -0
- package/dist/src/ui/utils/terminalSetup.js +130 -34
- package/dist/src/ui/utils/terminalSetup.js.map +1 -1
- package/dist/src/ui/utils/terminalSetup.test.js +35 -1
- package/dist/src/ui/utils/terminalSetup.test.js.map +1 -1
- package/dist/src/ui/utils/textUtils.d.ts +4 -0
- package/dist/src/ui/utils/textUtils.js +10 -1
- package/dist/src/ui/utils/textUtils.js.map +1 -1
- package/dist/src/ui/utils/textUtils.test.js +25 -2
- package/dist/src/ui/utils/textUtils.test.js.map +1 -1
- package/dist/src/ui/utils/toolLayoutUtils.d.ts +44 -0
- package/dist/src/ui/utils/toolLayoutUtils.js +73 -0
- package/dist/src/ui/utils/toolLayoutUtils.js.map +1 -0
- package/dist/src/ui/utils/urlSecurityUtils.d.ts +32 -0
- package/dist/src/ui/utils/urlSecurityUtils.js +71 -0
- package/dist/src/ui/utils/urlSecurityUtils.js.map +1 -0
- package/dist/src/ui/utils/urlSecurityUtils.test.d.ts +6 -0
- package/dist/src/ui/utils/urlSecurityUtils.test.js +49 -0
- package/dist/src/ui/utils/urlSecurityUtils.test.js.map +1 -0
- package/dist/src/utils/activityLogger.js +95 -24
- package/dist/src/utils/activityLogger.js.map +1 -1
- package/dist/src/utils/devtoolsService.js +1 -2
- package/dist/src/utils/devtoolsService.js.map +1 -1
- package/dist/src/utils/devtoolsService.test.js +1 -1
- package/dist/src/utils/devtoolsService.test.js.map +1 -1
- package/dist/src/utils/envVarResolver.js +4 -1
- package/dist/src/utils/envVarResolver.js.map +1 -1
- package/dist/src/utils/gitUtils.js +2 -0
- package/dist/src/utils/gitUtils.js.map +1 -1
- package/dist/src/utils/jsonoutput.js +2 -0
- package/dist/src/utils/jsonoutput.js.map +1 -1
- package/dist/src/utils/persistentState.d.ts +2 -0
- package/dist/src/utils/persistentState.js +1 -0
- package/dist/src/utils/persistentState.js.map +1 -1
- package/dist/src/utils/readStdin.js +1 -0
- package/dist/src/utils/readStdin.js.map +1 -1
- package/dist/src/utils/sessionUtils.d.ts +1 -6
- package/dist/src/utils/sessionUtils.js +8 -101
- package/dist/src/utils/sessionUtils.js.map +1 -1
- package/dist/src/utils/sessionUtils.test.js +47 -0
- package/dist/src/utils/sessionUtils.test.js.map +1 -1
- package/dist/src/utils/settingsUtils.js +2 -0
- package/dist/src/utils/settingsUtils.js.map +1 -1
- package/dist/src/utils/skillUtils.test.js +7 -5
- package/dist/src/utils/skillUtils.test.js.map +1 -1
- package/dist/src/utils/terminalNotifications.d.ts +25 -0
- package/dist/src/utils/terminalNotifications.js +77 -0
- package/dist/src/utils/terminalNotifications.js.map +1 -0
- package/dist/src/utils/terminalNotifications.test.d.ts +6 -0
- package/dist/src/utils/terminalNotifications.test.js +123 -0
- package/dist/src/utils/terminalNotifications.test.js.map +1 -0
- package/dist/src/utils/userStartupWarnings.d.ts +4 -1
- package/dist/src/utils/userStartupWarnings.js +22 -4
- package/dist/src/utils/userStartupWarnings.js.map +1 -1
- package/dist/src/utils/userStartupWarnings.test.js +53 -11
- package/dist/src/utils/userStartupWarnings.test.js.map +1 -1
- package/dist/src/zed-integration/acpErrors.js +2 -0
- package/dist/src/zed-integration/acpErrors.js.map +1 -1
- package/dist/src/zed-integration/acpResume.test.js +53 -3
- package/dist/src/zed-integration/acpResume.test.js.map +1 -1
- package/dist/src/zed-integration/fileSystemService.js +2 -0
- package/dist/src/zed-integration/fileSystemService.js.map +1 -1
- package/dist/src/zed-integration/zedIntegration.d.ts +2 -0
- package/dist/src/zed-integration/zedIntegration.js +77 -6
- package/dist/src/zed-integration/zedIntegration.js.map +1 -1
- package/dist/src/zed-integration/zedIntegration.test.js +176 -2
- package/dist/src/zed-integration/zedIntegration.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -7
- package/dist/google-gemini-cli-0.30.0.tgz +0 -0
- package/dist/src/ui/hooks/useFuzzyList.d.ts +0 -25
- package/dist/src/ui/hooks/useFuzzyList.js +0 -100
- package/dist/src/ui/hooks/useFuzzyList.js.map +0 -1
|
@@ -6,6 +6,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
6
6
|
*/
|
|
7
7
|
import { renderWithProviders } from '../../../test-utils/render.js';
|
|
8
8
|
import { describe, it, expect, vi, afterEach } from 'vitest';
|
|
9
|
+
import { act } from 'react';
|
|
9
10
|
import { ToolGroupMessage } from './ToolGroupMessage.js';
|
|
10
11
|
import { Scrollable } from '../shared/Scrollable.js';
|
|
11
12
|
import { makeFakeConfig, CoreToolCallStatus, ApprovalMode, ASK_USER_DISPLAY_NAME, WRITE_FILE_DISPLAY_NAME, EDIT_DISPLAY_NAME, READ_FILE_DISPLAY_NAME, GLOB_DISPLAY_NAME, } from '@google/gemini-cli-core';
|
|
@@ -25,9 +26,13 @@ describe('<ToolGroupMessage />', () => {
|
|
|
25
26
|
...overrides,
|
|
26
27
|
});
|
|
27
28
|
const baseProps = {
|
|
28
|
-
groupId: 1,
|
|
29
29
|
terminalWidth: 80,
|
|
30
30
|
};
|
|
31
|
+
const createItem = (tools) => ({
|
|
32
|
+
id: 1,
|
|
33
|
+
type: 'tool_group',
|
|
34
|
+
tools,
|
|
35
|
+
});
|
|
31
36
|
const baseMockConfig = makeFakeConfig({
|
|
32
37
|
model: 'gemini-pro',
|
|
33
38
|
targetDir: os.tmpdir(),
|
|
@@ -37,18 +42,25 @@ describe('<ToolGroupMessage />', () => {
|
|
|
37
42
|
enableInteractiveShell: true,
|
|
38
43
|
});
|
|
39
44
|
describe('Golden Snapshots', () => {
|
|
40
|
-
it('renders single successful tool call', () => {
|
|
45
|
+
it('renders single successful tool call', async () => {
|
|
41
46
|
const toolCalls = [createToolCall()];
|
|
42
|
-
const
|
|
47
|
+
const item = createItem(toolCalls);
|
|
48
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
43
49
|
config: baseMockConfig,
|
|
44
50
|
uiState: {
|
|
45
|
-
pendingHistoryItems: [
|
|
51
|
+
pendingHistoryItems: [
|
|
52
|
+
{
|
|
53
|
+
type: 'tool_group',
|
|
54
|
+
tools: toolCalls,
|
|
55
|
+
},
|
|
56
|
+
],
|
|
46
57
|
},
|
|
47
58
|
});
|
|
48
|
-
|
|
59
|
+
await waitUntilReady();
|
|
60
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
49
61
|
unmount();
|
|
50
62
|
});
|
|
51
|
-
it('hides confirming tools (standard behavior)', () => {
|
|
63
|
+
it('hides confirming tools (standard behavior)', async () => {
|
|
52
64
|
const toolCalls = [
|
|
53
65
|
createToolCall({
|
|
54
66
|
callId: 'confirm-tool',
|
|
@@ -60,12 +72,14 @@ describe('<ToolGroupMessage />', () => {
|
|
|
60
72
|
},
|
|
61
73
|
}),
|
|
62
74
|
];
|
|
63
|
-
const
|
|
75
|
+
const item = createItem(toolCalls);
|
|
76
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), { config: baseMockConfig });
|
|
64
77
|
// Should render nothing because all tools in the group are confirming
|
|
65
|
-
|
|
78
|
+
await waitUntilReady();
|
|
79
|
+
expect(lastFrame({ allowEmpty: true })).toBe('');
|
|
66
80
|
unmount();
|
|
67
81
|
});
|
|
68
|
-
it('renders multiple tool calls with different statuses (only visible ones)', () => {
|
|
82
|
+
it('renders multiple tool calls with different statuses (only visible ones)', async () => {
|
|
69
83
|
const toolCalls = [
|
|
70
84
|
createToolCall({
|
|
71
85
|
callId: 'tool-1',
|
|
@@ -86,13 +100,20 @@ describe('<ToolGroupMessage />', () => {
|
|
|
86
100
|
status: CoreToolCallStatus.Error,
|
|
87
101
|
}),
|
|
88
102
|
];
|
|
89
|
-
const
|
|
103
|
+
const item = createItem(toolCalls);
|
|
104
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
90
105
|
config: baseMockConfig,
|
|
91
106
|
uiState: {
|
|
92
|
-
pendingHistoryItems: [
|
|
107
|
+
pendingHistoryItems: [
|
|
108
|
+
{
|
|
109
|
+
type: 'tool_group',
|
|
110
|
+
tools: toolCalls,
|
|
111
|
+
},
|
|
112
|
+
],
|
|
93
113
|
},
|
|
94
114
|
});
|
|
95
115
|
// pending-tool should be hidden
|
|
116
|
+
await waitUntilReady();
|
|
96
117
|
const output = lastFrame();
|
|
97
118
|
expect(output).toContain('successful-tool');
|
|
98
119
|
expect(output).not.toContain('pending-tool');
|
|
@@ -100,7 +121,7 @@ describe('<ToolGroupMessage />', () => {
|
|
|
100
121
|
expect(output).toMatchSnapshot();
|
|
101
122
|
unmount();
|
|
102
123
|
});
|
|
103
|
-
it('renders mixed tool calls including shell command', () => {
|
|
124
|
+
it('renders mixed tool calls including shell command', async () => {
|
|
104
125
|
const toolCalls = [
|
|
105
126
|
createToolCall({
|
|
106
127
|
callId: 'tool-1',
|
|
@@ -121,13 +142,20 @@ describe('<ToolGroupMessage />', () => {
|
|
|
121
142
|
status: CoreToolCallStatus.Scheduled,
|
|
122
143
|
}),
|
|
123
144
|
];
|
|
124
|
-
const
|
|
145
|
+
const item = createItem(toolCalls);
|
|
146
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
125
147
|
config: baseMockConfig,
|
|
126
148
|
uiState: {
|
|
127
|
-
pendingHistoryItems: [
|
|
149
|
+
pendingHistoryItems: [
|
|
150
|
+
{
|
|
151
|
+
type: 'tool_group',
|
|
152
|
+
tools: toolCalls,
|
|
153
|
+
},
|
|
154
|
+
],
|
|
128
155
|
},
|
|
129
156
|
});
|
|
130
157
|
// write_file (Pending) should be hidden
|
|
158
|
+
await waitUntilReady();
|
|
131
159
|
const output = lastFrame();
|
|
132
160
|
expect(output).toContain('read_file');
|
|
133
161
|
expect(output).toContain('run_shell_command');
|
|
@@ -135,7 +163,7 @@ describe('<ToolGroupMessage />', () => {
|
|
|
135
163
|
expect(output).toMatchSnapshot();
|
|
136
164
|
unmount();
|
|
137
165
|
});
|
|
138
|
-
it('renders with limited terminal height', () => {
|
|
166
|
+
it('renders with limited terminal height', async () => {
|
|
139
167
|
const toolCalls = [
|
|
140
168
|
createToolCall({
|
|
141
169
|
callId: 'tool-1',
|
|
@@ -150,42 +178,64 @@ describe('<ToolGroupMessage />', () => {
|
|
|
150
178
|
resultDisplay: 'More output here',
|
|
151
179
|
}),
|
|
152
180
|
];
|
|
153
|
-
const
|
|
181
|
+
const item = createItem(toolCalls);
|
|
182
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls, availableTerminalHeight: 10 }), {
|
|
154
183
|
config: baseMockConfig,
|
|
155
184
|
uiState: {
|
|
156
|
-
pendingHistoryItems: [
|
|
185
|
+
pendingHistoryItems: [
|
|
186
|
+
{
|
|
187
|
+
type: 'tool_group',
|
|
188
|
+
tools: toolCalls,
|
|
189
|
+
},
|
|
190
|
+
],
|
|
157
191
|
},
|
|
158
192
|
});
|
|
159
|
-
|
|
193
|
+
await waitUntilReady();
|
|
194
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
160
195
|
unmount();
|
|
161
196
|
});
|
|
162
|
-
it('renders with narrow terminal width', () => {
|
|
197
|
+
it('renders with narrow terminal width', async () => {
|
|
163
198
|
const toolCalls = [
|
|
164
199
|
createToolCall({
|
|
165
200
|
name: 'very-long-tool-name-that-might-wrap',
|
|
166
201
|
description: 'This is a very long description that might cause wrapping issues',
|
|
167
202
|
}),
|
|
168
203
|
];
|
|
169
|
-
const
|
|
204
|
+
const item = createItem(toolCalls);
|
|
205
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls, terminalWidth: 40 }), {
|
|
170
206
|
config: baseMockConfig,
|
|
171
207
|
uiState: {
|
|
172
|
-
pendingHistoryItems: [
|
|
208
|
+
pendingHistoryItems: [
|
|
209
|
+
{
|
|
210
|
+
type: 'tool_group',
|
|
211
|
+
tools: toolCalls,
|
|
212
|
+
},
|
|
213
|
+
],
|
|
173
214
|
},
|
|
174
215
|
});
|
|
175
|
-
|
|
216
|
+
await waitUntilReady();
|
|
217
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
176
218
|
unmount();
|
|
177
219
|
});
|
|
178
|
-
it('renders empty tool calls array', () => {
|
|
179
|
-
const
|
|
220
|
+
it('renders empty tool calls array', async () => {
|
|
221
|
+
const toolCalls = [];
|
|
222
|
+
const item = createItem(toolCalls);
|
|
223
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
180
224
|
config: baseMockConfig,
|
|
181
225
|
uiState: {
|
|
182
|
-
pendingHistoryItems: [
|
|
226
|
+
pendingHistoryItems: [
|
|
227
|
+
{
|
|
228
|
+
type: 'tool_group',
|
|
229
|
+
tools: [],
|
|
230
|
+
},
|
|
231
|
+
],
|
|
183
232
|
},
|
|
184
233
|
});
|
|
185
|
-
|
|
234
|
+
await waitUntilReady();
|
|
235
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
186
236
|
unmount();
|
|
187
237
|
});
|
|
188
|
-
it('renders header when scrolled', () => {
|
|
238
|
+
it('renders header when scrolled', async () => {
|
|
189
239
|
const toolCalls = [
|
|
190
240
|
createToolCall({
|
|
191
241
|
callId: '1',
|
|
@@ -200,16 +250,23 @@ describe('<ToolGroupMessage />', () => {
|
|
|
200
250
|
resultDisplay: 'line1\nline2',
|
|
201
251
|
}),
|
|
202
252
|
];
|
|
203
|
-
const
|
|
253
|
+
const item = createItem(toolCalls);
|
|
254
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(Scrollable, { height: 10, hasFocus: true, scrollToBottom: true, children: _jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }) }), {
|
|
204
255
|
config: baseMockConfig,
|
|
205
256
|
uiState: {
|
|
206
|
-
pendingHistoryItems: [
|
|
257
|
+
pendingHistoryItems: [
|
|
258
|
+
{
|
|
259
|
+
type: 'tool_group',
|
|
260
|
+
tools: toolCalls,
|
|
261
|
+
},
|
|
262
|
+
],
|
|
207
263
|
},
|
|
208
264
|
});
|
|
209
|
-
|
|
265
|
+
await waitUntilReady();
|
|
266
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
210
267
|
unmount();
|
|
211
268
|
});
|
|
212
|
-
it('renders tool call with outputFile', () => {
|
|
269
|
+
it('renders tool call with outputFile', async () => {
|
|
213
270
|
const toolCalls = [
|
|
214
271
|
createToolCall({
|
|
215
272
|
callId: 'tool-output-file',
|
|
@@ -219,16 +276,23 @@ describe('<ToolGroupMessage />', () => {
|
|
|
219
276
|
outputFile: '/path/to/output.txt',
|
|
220
277
|
}),
|
|
221
278
|
];
|
|
222
|
-
const
|
|
279
|
+
const item = createItem(toolCalls);
|
|
280
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
223
281
|
config: baseMockConfig,
|
|
224
282
|
uiState: {
|
|
225
|
-
pendingHistoryItems: [
|
|
283
|
+
pendingHistoryItems: [
|
|
284
|
+
{
|
|
285
|
+
type: 'tool_group',
|
|
286
|
+
tools: toolCalls,
|
|
287
|
+
},
|
|
288
|
+
],
|
|
226
289
|
},
|
|
227
290
|
});
|
|
228
|
-
|
|
291
|
+
await waitUntilReady();
|
|
292
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
229
293
|
unmount();
|
|
230
294
|
});
|
|
231
|
-
it('renders two tool groups where only the last line of the previous group is visible', () => {
|
|
295
|
+
it('renders two tool groups where only the last line of the previous group is visible', async () => {
|
|
232
296
|
const toolCalls1 = [
|
|
233
297
|
createToolCall({
|
|
234
298
|
callId: '1',
|
|
@@ -237,6 +301,7 @@ describe('<ToolGroupMessage />', () => {
|
|
|
237
301
|
resultDisplay: 'line1\nline2\nline3\nline4\nline5',
|
|
238
302
|
}),
|
|
239
303
|
];
|
|
304
|
+
const item1 = createItem(toolCalls1);
|
|
240
305
|
const toolCalls2 = [
|
|
241
306
|
createToolCall({
|
|
242
307
|
callId: '2',
|
|
@@ -245,37 +310,52 @@ describe('<ToolGroupMessage />', () => {
|
|
|
245
310
|
resultDisplay: 'line1',
|
|
246
311
|
}),
|
|
247
312
|
];
|
|
248
|
-
const
|
|
313
|
+
const item2 = createItem(toolCalls2);
|
|
314
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsxs(Scrollable, { height: 6, hasFocus: true, scrollToBottom: true, children: [_jsx(ToolGroupMessage, { ...baseProps, item: item1, toolCalls: toolCalls1 }), _jsx(ToolGroupMessage, { ...baseProps, item: item2, toolCalls: toolCalls2 })] }), {
|
|
249
315
|
config: baseMockConfig,
|
|
250
316
|
uiState: {
|
|
251
317
|
pendingHistoryItems: [
|
|
252
|
-
{
|
|
253
|
-
|
|
318
|
+
{
|
|
319
|
+
type: 'tool_group',
|
|
320
|
+
tools: toolCalls1,
|
|
321
|
+
},
|
|
322
|
+
{
|
|
323
|
+
type: 'tool_group',
|
|
324
|
+
tools: toolCalls2,
|
|
325
|
+
},
|
|
254
326
|
],
|
|
255
327
|
},
|
|
256
328
|
});
|
|
257
|
-
|
|
329
|
+
await waitUntilReady();
|
|
330
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
258
331
|
unmount();
|
|
259
332
|
});
|
|
260
333
|
});
|
|
261
334
|
describe('Border Color Logic', () => {
|
|
262
|
-
it('uses yellow border for shell commands even when successful', () => {
|
|
335
|
+
it('uses yellow border for shell commands even when successful', async () => {
|
|
263
336
|
const toolCalls = [
|
|
264
337
|
createToolCall({
|
|
265
338
|
name: 'run_shell_command',
|
|
266
339
|
status: CoreToolCallStatus.Success,
|
|
267
340
|
}),
|
|
268
341
|
];
|
|
269
|
-
const
|
|
342
|
+
const item = createItem(toolCalls);
|
|
343
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
270
344
|
config: baseMockConfig,
|
|
271
345
|
uiState: {
|
|
272
|
-
pendingHistoryItems: [
|
|
346
|
+
pendingHistoryItems: [
|
|
347
|
+
{
|
|
348
|
+
type: 'tool_group',
|
|
349
|
+
tools: toolCalls,
|
|
350
|
+
},
|
|
351
|
+
],
|
|
273
352
|
},
|
|
274
353
|
});
|
|
275
|
-
|
|
354
|
+
await waitUntilReady();
|
|
355
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
276
356
|
unmount();
|
|
277
357
|
});
|
|
278
|
-
it('uses gray border when all tools are successful and no shell commands', () => {
|
|
358
|
+
it('uses gray border when all tools are successful and no shell commands', async () => {
|
|
279
359
|
const toolCalls = [
|
|
280
360
|
createToolCall({ status: CoreToolCallStatus.Success }),
|
|
281
361
|
createToolCall({
|
|
@@ -284,18 +364,25 @@ describe('<ToolGroupMessage />', () => {
|
|
|
284
364
|
status: CoreToolCallStatus.Success,
|
|
285
365
|
}),
|
|
286
366
|
];
|
|
287
|
-
const
|
|
367
|
+
const item = createItem(toolCalls);
|
|
368
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), {
|
|
288
369
|
config: baseMockConfig,
|
|
289
370
|
uiState: {
|
|
290
|
-
pendingHistoryItems: [
|
|
371
|
+
pendingHistoryItems: [
|
|
372
|
+
{
|
|
373
|
+
type: 'tool_group',
|
|
374
|
+
tools: toolCalls,
|
|
375
|
+
},
|
|
376
|
+
],
|
|
291
377
|
},
|
|
292
378
|
});
|
|
293
|
-
|
|
379
|
+
await waitUntilReady();
|
|
380
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
294
381
|
unmount();
|
|
295
382
|
});
|
|
296
383
|
});
|
|
297
384
|
describe('Height Calculation', () => {
|
|
298
|
-
it('calculates available height correctly with multiple tools with results', () => {
|
|
385
|
+
it('calculates available height correctly with multiple tools with results', async () => {
|
|
299
386
|
const toolCalls = [
|
|
300
387
|
createToolCall({
|
|
301
388
|
callId: 'tool-1',
|
|
@@ -310,13 +397,20 @@ describe('<ToolGroupMessage />', () => {
|
|
|
310
397
|
resultDisplay: '', // No result
|
|
311
398
|
}),
|
|
312
399
|
];
|
|
313
|
-
const
|
|
400
|
+
const item = createItem(toolCalls);
|
|
401
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls, availableTerminalHeight: 20 }), {
|
|
314
402
|
config: baseMockConfig,
|
|
315
403
|
uiState: {
|
|
316
|
-
pendingHistoryItems: [
|
|
404
|
+
pendingHistoryItems: [
|
|
405
|
+
{
|
|
406
|
+
type: 'tool_group',
|
|
407
|
+
tools: toolCalls,
|
|
408
|
+
},
|
|
409
|
+
],
|
|
317
410
|
},
|
|
318
411
|
});
|
|
319
|
-
|
|
412
|
+
await waitUntilReady();
|
|
413
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
320
414
|
unmount();
|
|
321
415
|
});
|
|
322
416
|
});
|
|
@@ -348,7 +442,7 @@ describe('<ToolGroupMessage />', () => {
|
|
|
348
442
|
resultDisplay: 'error message',
|
|
349
443
|
shouldHide: false,
|
|
350
444
|
},
|
|
351
|
-
])('filtering logic for status=$status and hasResult=$resultDisplay', ({ status, resultDisplay, shouldHide }) => {
|
|
445
|
+
])('filtering logic for status=$status and hasResult=$resultDisplay', async ({ status, resultDisplay, shouldHide }) => {
|
|
352
446
|
const toolCalls = [
|
|
353
447
|
createToolCall({
|
|
354
448
|
callId: `ask-user-${status}`,
|
|
@@ -357,16 +451,18 @@ describe('<ToolGroupMessage />', () => {
|
|
|
357
451
|
resultDisplay,
|
|
358
452
|
}),
|
|
359
453
|
];
|
|
360
|
-
const
|
|
454
|
+
const item = createItem(toolCalls);
|
|
455
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), { config: baseMockConfig });
|
|
456
|
+
await waitUntilReady();
|
|
361
457
|
if (shouldHide) {
|
|
362
|
-
expect(lastFrame()).toBe('');
|
|
458
|
+
expect(lastFrame({ allowEmpty: true })).toBe('');
|
|
363
459
|
}
|
|
364
460
|
else {
|
|
365
461
|
expect(lastFrame()).toMatchSnapshot();
|
|
366
462
|
}
|
|
367
463
|
unmount();
|
|
368
464
|
});
|
|
369
|
-
it('shows other tools when ask_user is filtered out', () => {
|
|
465
|
+
it('shows other tools when ask_user is filtered out', async () => {
|
|
370
466
|
const toolCalls = [
|
|
371
467
|
createToolCall({
|
|
372
468
|
callId: 'other-tool',
|
|
@@ -379,11 +475,13 @@ describe('<ToolGroupMessage />', () => {
|
|
|
379
475
|
status: CoreToolCallStatus.Scheduled,
|
|
380
476
|
}),
|
|
381
477
|
];
|
|
382
|
-
const
|
|
383
|
-
|
|
478
|
+
const item = createItem(toolCalls);
|
|
479
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), { config: baseMockConfig });
|
|
480
|
+
await waitUntilReady();
|
|
481
|
+
expect(lastFrame({ allowEmpty: true })).toMatchSnapshot();
|
|
384
482
|
unmount();
|
|
385
483
|
});
|
|
386
|
-
it('renders nothing when only tool is in-progress AskUser with borderBottom=false', () => {
|
|
484
|
+
it('renders nothing when only tool is in-progress AskUser with borderBottom=false', async () => {
|
|
387
485
|
// AskUser tools in progress are rendered by AskUserDialog, not ToolGroupMessage.
|
|
388
486
|
// When AskUser is the only tool and borderBottom=false (no border to close),
|
|
389
487
|
// the component should render nothing.
|
|
@@ -394,9 +492,11 @@ describe('<ToolGroupMessage />', () => {
|
|
|
394
492
|
status: CoreToolCallStatus.Executing,
|
|
395
493
|
}),
|
|
396
494
|
];
|
|
397
|
-
const
|
|
495
|
+
const item = createItem(toolCalls);
|
|
496
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls, borderBottom: false }), { config: baseMockConfig });
|
|
398
497
|
// AskUser tools in progress are rendered by AskUserDialog, so we expect nothing.
|
|
399
|
-
|
|
498
|
+
await waitUntilReady();
|
|
499
|
+
expect(lastFrame({ allowEmpty: true })).toBe('');
|
|
400
500
|
unmount();
|
|
401
501
|
});
|
|
402
502
|
});
|
|
@@ -415,7 +515,7 @@ describe('<ToolGroupMessage />', () => {
|
|
|
415
515
|
},
|
|
416
516
|
{ name: READ_FILE_DISPLAY_NAME, mode: ApprovalMode.PLAN, visible: true },
|
|
417
517
|
{ name: GLOB_DISPLAY_NAME, mode: ApprovalMode.PLAN, visible: true },
|
|
418
|
-
])('filtering logic for $name in $mode mode', ({ name, mode, visible }) => {
|
|
518
|
+
])('filtering logic for $name in $mode mode', async ({ name, mode, visible }) => {
|
|
419
519
|
const toolCalls = [
|
|
420
520
|
createToolCall({
|
|
421
521
|
callId: 'test-call',
|
|
@@ -423,15 +523,138 @@ describe('<ToolGroupMessage />', () => {
|
|
|
423
523
|
approvalMode: mode,
|
|
424
524
|
}),
|
|
425
525
|
];
|
|
426
|
-
const
|
|
526
|
+
const item = createItem(toolCalls);
|
|
527
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: item, toolCalls: toolCalls }), { config: baseMockConfig });
|
|
528
|
+
await waitUntilReady();
|
|
427
529
|
if (visible) {
|
|
428
530
|
expect(lastFrame()).toContain(name);
|
|
429
531
|
}
|
|
430
532
|
else {
|
|
431
|
-
expect(lastFrame()).toBe('');
|
|
533
|
+
expect(lastFrame({ allowEmpty: true })).toBe('');
|
|
432
534
|
}
|
|
433
535
|
unmount();
|
|
434
536
|
});
|
|
435
537
|
});
|
|
538
|
+
describe('Manual Overflow Detection', () => {
|
|
539
|
+
it('detects overflow for string results exceeding available height', async () => {
|
|
540
|
+
const toolCalls = [
|
|
541
|
+
createToolCall({
|
|
542
|
+
resultDisplay: 'line 1\nline 2\nline 3\nline 4\nline 5',
|
|
543
|
+
}),
|
|
544
|
+
];
|
|
545
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 6, isExpandable: true }), {
|
|
546
|
+
config: baseMockConfig,
|
|
547
|
+
useAlternateBuffer: true,
|
|
548
|
+
uiState: {
|
|
549
|
+
constrainHeight: true,
|
|
550
|
+
},
|
|
551
|
+
});
|
|
552
|
+
await waitUntilReady();
|
|
553
|
+
expect(lastFrame()?.toLowerCase()).toContain('press ctrl+o to show more lines');
|
|
554
|
+
unmount();
|
|
555
|
+
});
|
|
556
|
+
it('detects overflow for array results exceeding available height', async () => {
|
|
557
|
+
// resultDisplay when array is expected to be AnsiLine[]
|
|
558
|
+
// AnsiLine is AnsiToken[]
|
|
559
|
+
const toolCalls = [
|
|
560
|
+
createToolCall({
|
|
561
|
+
resultDisplay: Array(5).fill([{ text: 'line', fg: 'default' }]),
|
|
562
|
+
}),
|
|
563
|
+
];
|
|
564
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 6, isExpandable: true }), {
|
|
565
|
+
config: baseMockConfig,
|
|
566
|
+
useAlternateBuffer: true,
|
|
567
|
+
uiState: {
|
|
568
|
+
constrainHeight: true,
|
|
569
|
+
},
|
|
570
|
+
});
|
|
571
|
+
await waitUntilReady();
|
|
572
|
+
expect(lastFrame()?.toLowerCase()).toContain('press ctrl+o to show more lines');
|
|
573
|
+
unmount();
|
|
574
|
+
});
|
|
575
|
+
it('respects ACTIVE_SHELL_MAX_LINES for focused shell tools', async () => {
|
|
576
|
+
const toolCalls = [
|
|
577
|
+
createToolCall({
|
|
578
|
+
name: 'run_shell_command',
|
|
579
|
+
status: CoreToolCallStatus.Executing,
|
|
580
|
+
ptyId: 1,
|
|
581
|
+
resultDisplay: Array(20).fill('line').join('\n'), // 20 lines > 15 (limit)
|
|
582
|
+
}),
|
|
583
|
+
];
|
|
584
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 100, isExpandable: true }), {
|
|
585
|
+
config: baseMockConfig,
|
|
586
|
+
useAlternateBuffer: true,
|
|
587
|
+
uiState: {
|
|
588
|
+
constrainHeight: true,
|
|
589
|
+
activePtyId: 1,
|
|
590
|
+
embeddedShellFocused: true,
|
|
591
|
+
},
|
|
592
|
+
});
|
|
593
|
+
await waitUntilReady();
|
|
594
|
+
expect(lastFrame()?.toLowerCase()).toContain('press ctrl+o to show more lines');
|
|
595
|
+
unmount();
|
|
596
|
+
});
|
|
597
|
+
it('does not show expansion hint when content is within limits', async () => {
|
|
598
|
+
const toolCalls = [
|
|
599
|
+
createToolCall({
|
|
600
|
+
resultDisplay: 'small result',
|
|
601
|
+
}),
|
|
602
|
+
];
|
|
603
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 20, isExpandable: true }), {
|
|
604
|
+
config: baseMockConfig,
|
|
605
|
+
useAlternateBuffer: true,
|
|
606
|
+
uiState: {
|
|
607
|
+
constrainHeight: true,
|
|
608
|
+
},
|
|
609
|
+
});
|
|
610
|
+
await waitUntilReady();
|
|
611
|
+
expect(lastFrame()).not.toContain('Press Ctrl+O to show more lines');
|
|
612
|
+
unmount();
|
|
613
|
+
});
|
|
614
|
+
it('hides expansion hint when constrainHeight is false', async () => {
|
|
615
|
+
const toolCalls = [
|
|
616
|
+
createToolCall({
|
|
617
|
+
resultDisplay: 'line 1\nline 2\nline 3\nline 4\nline 5',
|
|
618
|
+
}),
|
|
619
|
+
];
|
|
620
|
+
const { lastFrame, unmount, waitUntilReady } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 6, isExpandable: true }), {
|
|
621
|
+
config: baseMockConfig,
|
|
622
|
+
useAlternateBuffer: true,
|
|
623
|
+
uiState: {
|
|
624
|
+
constrainHeight: false,
|
|
625
|
+
},
|
|
626
|
+
});
|
|
627
|
+
await waitUntilReady();
|
|
628
|
+
expect(lastFrame()).not.toContain('Press Ctrl+O to show more lines');
|
|
629
|
+
unmount();
|
|
630
|
+
});
|
|
631
|
+
it('isolates overflow hint in ASB mode (ignores global overflow state)', async () => {
|
|
632
|
+
// In this test, the tool output is SHORT (no local overflow).
|
|
633
|
+
// We will inject a dummy ID into the global overflow state.
|
|
634
|
+
// ToolGroupMessage should still NOT show the hint because it calculates
|
|
635
|
+
// overflow locally and passes it as a prop.
|
|
636
|
+
const toolCalls = [
|
|
637
|
+
createToolCall({
|
|
638
|
+
resultDisplay: 'short result',
|
|
639
|
+
}),
|
|
640
|
+
];
|
|
641
|
+
const { lastFrame, unmount, waitUntilReady, capturedOverflowActions } = renderWithProviders(_jsx(ToolGroupMessage, { ...baseProps, item: { id: 1, type: 'tool_group', tools: toolCalls }, toolCalls: toolCalls, availableTerminalHeight: 100, isExpandable: true }), {
|
|
642
|
+
config: baseMockConfig,
|
|
643
|
+
useAlternateBuffer: true,
|
|
644
|
+
uiState: {
|
|
645
|
+
constrainHeight: true,
|
|
646
|
+
},
|
|
647
|
+
});
|
|
648
|
+
await waitUntilReady();
|
|
649
|
+
// Manually trigger a global overflow
|
|
650
|
+
act(() => {
|
|
651
|
+
expect(capturedOverflowActions).toBeDefined();
|
|
652
|
+
capturedOverflowActions.addOverflowingId('unrelated-global-id');
|
|
653
|
+
});
|
|
654
|
+
// The hint should NOT appear because ToolGroupMessage is isolated by its prop logic
|
|
655
|
+
expect(lastFrame()).not.toContain('Press Ctrl+O to show more lines');
|
|
656
|
+
unmount();
|
|
657
|
+
});
|
|
658
|
+
});
|
|
436
659
|
});
|
|
437
660
|
//# sourceMappingURL=ToolGroupMessage.test.js.map
|