@umsai/ums-code 0.0.11-post6 → 0.0.14-v1
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/dist/package.json +5 -5
- package/dist/src/acp/acp.d.ts +208 -0
- package/dist/src/{zed-integration → acp}/acp.js +44 -76
- package/dist/src/acp/acp.js.map +1 -0
- package/dist/src/acp/acpPeer.d.ts +8 -0
- package/dist/src/acp/acpPeer.js +537 -0
- package/dist/src/acp/acpPeer.js.map +1 -0
- package/dist/src/config/auth.js +11 -12
- package/dist/src/config/auth.js.map +1 -1
- package/dist/src/config/config.d.ts +3 -3
- package/dist/src/config/config.js +86 -164
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/extension.d.ts +1 -2
- package/dist/src/config/extension.js +4 -9
- package/dist/src/config/extension.js.map +1 -1
- package/dist/src/config/sandboxConfig.js +3 -3
- package/dist/src/config/sandboxConfig.js.map +1 -1
- package/dist/src/config/settings.d.ts +64 -3
- package/dist/src/config/settings.js +38 -58
- package/dist/src/config/settings.js.map +1 -1
- package/dist/src/gemini.js +41 -37
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +1 -2
- package/dist/src/generated/git-commit.js +1 -2
- package/dist/src/generated/git-commit.js.map +1 -1
- package/dist/src/nonInteractiveCli.js +8 -3
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/services/BuiltinCommandLoader.d.ts +1 -0
- package/dist/src/services/BuiltinCommandLoader.js +4 -11
- package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
- package/dist/src/services/FileCommandLoader.js +8 -10
- package/dist/src/services/FileCommandLoader.js.map +1 -1
- package/dist/src/services/McpPromptLoader.js +3 -3
- package/dist/src/services/McpPromptLoader.js.map +1 -1
- package/dist/src/services/prompt-processors/argumentProcessor.d.ts +7 -2
- package/dist/src/services/prompt-processors/argumentProcessor.js +10 -2
- package/dist/src/services/prompt-processors/argumentProcessor.js.map +1 -1
- package/dist/src/services/prompt-processors/shellProcessor.d.ts +13 -16
- package/dist/src/services/prompt-processors/shellProcessor.js +40 -125
- package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
- package/dist/src/services/prompt-processors/types.d.ts +0 -2
- package/dist/src/services/prompt-processors/types.js +0 -2
- package/dist/src/services/prompt-processors/types.js.map +1 -1
- package/dist/src/ui/App.js +46 -224
- package/dist/src/ui/App.js.map +1 -1
- package/dist/src/ui/commands/aboutCommand.js +5 -9
- package/dist/src/ui/commands/aboutCommand.js.map +1 -1
- package/dist/src/ui/commands/bugCommand.js +5 -13
- package/dist/src/ui/commands/bugCommand.js.map +1 -1
- package/dist/src/ui/commands/chatCommand.js +6 -23
- package/dist/src/ui/commands/chatCommand.js.map +1 -1
- package/dist/src/ui/commands/clearCommand.js +1 -0
- package/dist/src/ui/commands/clearCommand.js.map +1 -1
- package/dist/src/ui/commands/directoryCommand.js +21 -18
- package/dist/src/ui/commands/directoryCommand.js.map +1 -1
- package/dist/src/ui/commands/docsCommand.js +1 -1
- package/dist/src/ui/commands/docsCommand.js.map +1 -1
- package/dist/src/ui/commands/ideCommand.js +18 -90
- package/dist/src/ui/commands/ideCommand.js.map +1 -1
- package/dist/src/ui/commands/initCommand.d.ts +1 -1
- package/dist/src/ui/commands/initCommand.js +7 -17
- package/dist/src/ui/commands/initCommand.js.map +1 -1
- package/dist/src/ui/commands/mcpCommand.js +7 -11
- package/dist/src/ui/commands/mcpCommand.js.map +1 -1
- package/dist/src/ui/commands/memoryCommand.js +6 -139
- package/dist/src/ui/commands/memoryCommand.js.map +1 -1
- package/dist/src/ui/commands/quitCommand.d.ts +0 -1
- package/dist/src/ui/commands/quitCommand.js +0 -25
- package/dist/src/ui/commands/quitCommand.js.map +1 -1
- package/dist/src/ui/commands/setupGithubCommand.d.ts +0 -2
- package/dist/src/ui/commands/setupGithubCommand.js +26 -132
- package/dist/src/ui/commands/setupGithubCommand.js.map +1 -1
- package/dist/src/ui/commands/toolsCommand.js +2 -2
- package/dist/src/ui/commands/toolsCommand.js.map +1 -1
- package/dist/src/ui/commands/types.d.ts +3 -19
- package/dist/src/ui/commands/types.js.map +1 -1
- package/dist/src/ui/commands/ums/umsInitCommand.js +21 -55
- package/dist/src/ui/commands/ums/umsInitCommand.js.map +1 -1
- package/dist/src/ui/components/AboutBox.d.ts +0 -1
- package/dist/src/ui/components/AboutBox.js +1 -1
- package/dist/src/ui/components/AboutBox.js.map +1 -1
- package/dist/src/ui/components/AsciiArt.d.ts +0 -1
- package/dist/src/ui/components/AsciiArt.js +0 -8
- package/dist/src/ui/components/AsciiArt.js.map +1 -1
- package/dist/src/ui/components/AuthDialog.d.ts +1 -1
- package/dist/src/ui/components/AuthDialog.js +15 -17
- package/dist/src/ui/components/AuthDialog.js.map +1 -1
- package/dist/src/ui/components/AuthInProgress.js +5 -6
- package/dist/src/ui/components/AuthInProgress.js.map +1 -1
- package/dist/src/ui/components/ContextSummaryDisplay.js +25 -22
- package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/DebugProfiler.js +4 -5
- package/dist/src/ui/components/DebugProfiler.js.map +1 -1
- package/dist/src/ui/components/EditorSettingsDialog.js +5 -6
- package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/Footer.d.ts +0 -1
- package/dist/src/ui/components/Footer.js +6 -16
- package/dist/src/ui/components/Footer.js.map +1 -1
- package/dist/src/ui/components/Header.d.ts +1 -0
- package/dist/src/ui/components/Header.js +5 -13
- package/dist/src/ui/components/Header.js.map +1 -1
- package/dist/src/ui/components/Help.js +1 -1
- package/dist/src/ui/components/Help.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.js +1 -2
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/IDEContextDetailDisplay.d.ts +12 -0
- package/dist/src/ui/components/IDEContextDetailDisplay.js +12 -0
- package/dist/src/ui/components/IDEContextDetailDisplay.js.map +1 -0
- package/dist/src/ui/components/InputPrompt.d.ts +0 -1
- package/dist/src/ui/components/InputPrompt.js +35 -98
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/LoadingIndicator.js +5 -10
- package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
- package/dist/src/ui/components/ShellConfirmationDialog.js +5 -7
- package/dist/src/ui/components/ShellConfirmationDialog.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.js +7 -8
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.js +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.js +20 -10
- package/dist/src/ui/components/ThemeDialog.js.map +1 -1
- package/dist/src/ui/components/messages/DiffRenderer.js +1 -10
- package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
- package/dist/src/ui/components/messages/InfoMessage.js +1 -6
- package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js +14 -36
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.js +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.js +10 -75
- package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
- package/dist/src/ui/components/shared/MaxSizedBox.js +1 -1
- package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
- package/dist/src/ui/components/shared/RadioButtonSelect.js +9 -11
- package/dist/src/ui/components/shared/RadioButtonSelect.js.map +1 -1
- package/dist/src/ui/components/shared/text-buffer.d.ts +4 -17
- package/dist/src/ui/components/shared/text-buffer.js +80 -262
- package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
- package/dist/src/ui/components/shared/vim-buffer-actions.js +152 -139
- package/dist/src/ui/components/shared/vim-buffer-actions.js.map +1 -1
- package/dist/src/ui/components/ums/UMSKeyPrompt.js +3 -3
- package/dist/src/ui/components/ums/UMSKeyPrompt.js.map +1 -1
- package/dist/src/ui/contexts/SessionContext.d.ts +1 -3
- package/dist/src/ui/contexts/SessionContext.js +11 -3
- package/dist/src/ui/contexts/SessionContext.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.js +16 -17
- package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/shellCommandProcessor.js +13 -8
- package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.d.ts +2 -9
- package/dist/src/ui/hooks/slashCommandProcessor.js +62 -234
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/useAtCompletion.js +3 -4
- package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useAuthCommand.js +1 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js +6 -6
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js.map +1 -1
- package/dist/src/ui/hooks/useFocus.d.ts +0 -4
- package/dist/src/ui/hooks/useFocus.js +4 -4
- package/dist/src/ui/hooks/useFocus.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.d.ts +3 -4
- package/dist/src/ui/hooks/useGeminiStream.js +33 -50
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useKeypress.d.ts +16 -4
- package/dist/src/ui/hooks/useKeypress.js +140 -8
- package/dist/src/ui/hooks/useKeypress.js.map +1 -1
- package/dist/src/ui/hooks/usePhraseCycler.js +2 -2
- package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
- package/dist/src/ui/hooks/usePrivacySettings.js +2 -6
- package/dist/src/ui/hooks/usePrivacySettings.js.map +1 -1
- package/dist/src/ui/hooks/useReactToolScheduler.d.ts +1 -1
- package/dist/src/ui/hooks/useReactToolScheduler.js +15 -15
- package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
- package/dist/src/ui/hooks/useThemeCommand.js +1 -1
- package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js +4 -5
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js +4 -5
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js +4 -5
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js.map +1 -1
- package/dist/src/ui/themes/ansi-light.js +1 -2
- package/dist/src/ui/themes/ansi-light.js.map +1 -1
- package/dist/src/ui/themes/ansi.js +1 -2
- package/dist/src/ui/themes/ansi.js.map +1 -1
- package/dist/src/ui/themes/atom-one-dark.js +1 -2
- package/dist/src/ui/themes/atom-one-dark.js.map +1 -1
- package/dist/src/ui/themes/ayu-light.js +1 -2
- package/dist/src/ui/themes/ayu-light.js.map +1 -1
- package/dist/src/ui/themes/ayu.js +1 -2
- package/dist/src/ui/themes/ayu.js.map +1 -1
- package/dist/src/ui/themes/default-light.js +1 -2
- package/dist/src/ui/themes/default-light.js.map +1 -1
- package/dist/src/ui/themes/default.js +1 -2
- package/dist/src/ui/themes/default.js.map +1 -1
- package/dist/src/ui/themes/dracula.js +1 -2
- package/dist/src/ui/themes/dracula.js.map +1 -1
- package/dist/src/ui/themes/github-dark.js +1 -2
- package/dist/src/ui/themes/github-dark.js.map +1 -1
- package/dist/src/ui/themes/github-light.js +1 -2
- package/dist/src/ui/themes/github-light.js.map +1 -1
- package/dist/src/ui/themes/googlecode.js +1 -2
- package/dist/src/ui/themes/googlecode.js.map +1 -1
- package/dist/src/ui/themes/no-color.js +1 -30
- package/dist/src/ui/themes/no-color.js.map +1 -1
- package/dist/src/ui/themes/qwen-dark.js +1 -2
- package/dist/src/ui/themes/qwen-dark.js.map +1 -1
- package/dist/src/ui/themes/qwen-light.js +1 -2
- package/dist/src/ui/themes/qwen-light.js.map +1 -1
- package/dist/src/ui/themes/shades-of-purple.js +1 -2
- package/dist/src/ui/themes/shades-of-purple.js.map +1 -1
- package/dist/src/ui/themes/theme-manager.d.ts +0 -6
- package/dist/src/ui/themes/theme-manager.js +1 -8
- package/dist/src/ui/themes/theme-manager.js.map +1 -1
- package/dist/src/ui/themes/theme.d.ts +2 -45
- package/dist/src/ui/themes/theme.js +107 -92
- package/dist/src/ui/themes/theme.js.map +1 -1
- package/dist/src/ui/themes/xcode.js +1 -2
- package/dist/src/ui/themes/xcode.js.map +1 -1
- package/dist/src/ui/types.d.ts +4 -30
- package/dist/src/ui/types.js +0 -2
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/ui/utils/CodeColorizer.d.ts +1 -2
- package/dist/src/ui/utils/CodeColorizer.js +4 -5
- package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
- package/dist/src/ui/utils/ConsolePatcher.d.ts +0 -1
- package/dist/src/ui/utils/ConsolePatcher.js +0 -3
- package/dist/src/ui/utils/ConsolePatcher.js.map +1 -1
- package/dist/src/ui/utils/InlineMarkdownRenderer.js +1 -8
- package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.js +2 -4
- package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
- package/dist/src/ui/utils/commandUtils.d.ts +0 -1
- package/dist/src/ui/utils/commandUtils.js +1 -22
- package/dist/src/ui/utils/commandUtils.js.map +1 -1
- package/dist/src/ui/utils/computeStats.js +1 -3
- package/dist/src/ui/utils/computeStats.js.map +1 -1
- package/dist/src/ui/utils/errorParsing.d.ts +7 -0
- package/dist/src/ui/utils/errorParsing.js +90 -0
- package/dist/src/ui/utils/errorParsing.js.map +1 -0
- package/dist/src/ui/utils/updateCheck.d.ts +1 -1
- package/dist/src/ui/utils/updateCheck.js +10 -4
- package/dist/src/ui/utils/updateCheck.js.map +1 -1
- package/dist/src/utils/cleanup.d.ts +2 -2
- package/dist/src/utils/cleanup.js +2 -2
- package/dist/src/utils/cleanup.js.map +1 -1
- package/dist/src/utils/gitUtils.d.ts +1 -21
- package/dist/src/utils/gitUtils.js +3 -68
- package/dist/src/utils/gitUtils.js.map +1 -1
- package/dist/src/utils/installationInfo.js +5 -5
- package/dist/src/utils/installationInfo.js.map +1 -1
- package/dist/src/utils/readStdin.js +0 -10
- package/dist/src/utils/readStdin.js.map +1 -1
- package/dist/src/utils/sandbox.js +434 -457
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/utils/version.js +1 -1
- package/dist/src/utils/version.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.js +7 -4
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +6 -6
- package/dist/src/commands/mcp/add.d.ts +0 -7
- package/dist/src/commands/mcp/add.js +0 -166
- package/dist/src/commands/mcp/add.js.map +0 -1
- package/dist/src/commands/mcp/list.d.ts +0 -8
- package/dist/src/commands/mcp/list.js +0 -110
- package/dist/src/commands/mcp/list.js.map +0 -1
- package/dist/src/commands/mcp/remove.d.ts +0 -7
- package/dist/src/commands/mcp/remove.js +0 -44
- package/dist/src/commands/mcp/remove.js.map +0 -1
- package/dist/src/commands/mcp.d.ts +0 -7
- package/dist/src/commands/mcp.js +0 -23
- package/dist/src/commands/mcp.js.map +0 -1
- package/dist/src/config/auth.test.d.ts +0 -6
- package/dist/src/config/auth.test.js +0 -57
- package/dist/src/config/auth.test.js.map +0 -1
- package/dist/src/config/keyBindings.d.ts +0 -66
- package/dist/src/config/keyBindings.js +0 -141
- package/dist/src/config/keyBindings.js.map +0 -1
- package/dist/src/config/keyBindings.test.d.ts +0 -6
- package/dist/src/config/keyBindings.test.js +0 -51
- package/dist/src/config/keyBindings.test.js.map +0 -1
- package/dist/src/config/settingsSchema.d.ts +0 -613
- package/dist/src/config/settingsSchema.js +0 -586
- package/dist/src/config/settingsSchema.js.map +0 -1
- package/dist/src/config/settingsSchema.test.d.ts +0 -6
- package/dist/src/config/settingsSchema.test.js +0 -196
- package/dist/src/config/settingsSchema.test.js.map +0 -1
- package/dist/src/config/trustedFolders.d.ts +0 -37
- package/dist/src/config/trustedFolders.js +0 -118
- package/dist/src/config/trustedFolders.js.map +0 -1
- package/dist/src/config/trustedFolders.test.d.ts +0 -6
- package/dist/src/config/trustedFolders.test.js +0 -160
- package/dist/src/config/trustedFolders.test.js.map +0 -1
- package/dist/src/gemini.test.d.ts +0 -6
- package/dist/src/gemini.test.js +0 -193
- package/dist/src/gemini.test.js.map +0 -1
- package/dist/src/services/BuiltinCommandLoader.test.d.ts +0 -6
- package/dist/src/services/BuiltinCommandLoader.test.js +0 -111
- package/dist/src/services/BuiltinCommandLoader.test.js.map +0 -1
- package/dist/src/services/CommandService.test.d.ts +0 -6
- package/dist/src/services/CommandService.test.js +0 -232
- package/dist/src/services/CommandService.test.js.map +0 -1
- package/dist/src/test-utils/customMatchers.d.ts +0 -14
- package/dist/src/test-utils/customMatchers.js +0 -46
- package/dist/src/test-utils/customMatchers.js.map +0 -1
- package/dist/src/test-utils/mockCommandContext.d.ts +0 -18
- package/dist/src/test-utils/mockCommandContext.js +0 -87
- package/dist/src/test-utils/mockCommandContext.js.map +0 -1
- package/dist/src/test-utils/mockCommandContext.test.d.ts +0 -6
- package/dist/src/test-utils/mockCommandContext.test.js +0 -51
- package/dist/src/test-utils/mockCommandContext.test.js.map +0 -1
- package/dist/src/test-utils/render.d.ts +0 -8
- package/dist/src/test-utils/render.js +0 -10
- package/dist/src/test-utils/render.js.map +0 -1
- package/dist/src/ui/IdeIntegrationNudge.d.ts +0 -16
- package/dist/src/ui/IdeIntegrationNudge.js +0 -52
- package/dist/src/ui/IdeIntegrationNudge.js.map +0 -1
- package/dist/src/ui/commands/agentsCommand.d.ts +0 -7
- package/dist/src/ui/commands/agentsCommand.js +0 -32
- package/dist/src/ui/commands/agentsCommand.js.map +0 -1
- package/dist/src/ui/commands/settingsCommand.d.ts +0 -7
- package/dist/src/ui/commands/settingsCommand.js +0 -16
- package/dist/src/ui/commands/settingsCommand.js.map +0 -1
- package/dist/src/ui/commands/setupGithubCommand.test.d.ts +0 -6
- package/dist/src/ui/commands/setupGithubCommand.test.js +0 -167
- package/dist/src/ui/commands/setupGithubCommand.test.js.map +0 -1
- package/dist/src/ui/commands/summaryCommand.d.ts +0 -7
- package/dist/src/ui/commands/summaryCommand.js +0 -149
- package/dist/src/ui/commands/summaryCommand.js.map +0 -1
- package/dist/src/ui/commands/terminalSetupCommand.d.ts +0 -13
- package/dist/src/ui/commands/terminalSetupCommand.js +0 -41
- package/dist/src/ui/commands/terminalSetupCommand.js.map +0 -1
- package/dist/src/ui/components/AuthDialog.test.d.ts +0 -6
- package/dist/src/ui/components/AuthDialog.test.js +0 -220
- package/dist/src/ui/components/AuthDialog.test.js.map +0 -1
- package/dist/src/ui/components/ContextUsageDisplay.d.ts +0 -9
- package/dist/src/ui/components/ContextUsageDisplay.js +0 -14
- package/dist/src/ui/components/ContextUsageDisplay.js.map +0 -1
- package/dist/src/ui/components/FolderTrustDialog.d.ts +0 -16
- package/dist/src/ui/components/FolderTrustDialog.js +0 -39
- package/dist/src/ui/components/FolderTrustDialog.js.map +0 -1
- package/dist/src/ui/components/FolderTrustDialog.test.d.ts +0 -6
- package/dist/src/ui/components/FolderTrustDialog.test.js +0 -26
- package/dist/src/ui/components/FolderTrustDialog.test.js.map +0 -1
- package/dist/src/ui/components/Header.test.d.ts +0 -6
- package/dist/src/ui/components/Header.test.js +0 -37
- package/dist/src/ui/components/Header.test.js.map +0 -1
- package/dist/src/ui/components/HistoryItemDisplay.test.d.ts +0 -6
- package/dist/src/ui/components/HistoryItemDisplay.test.js +0 -91
- package/dist/src/ui/components/HistoryItemDisplay.test.js.map +0 -1
- package/dist/src/ui/components/LoadingIndicator.test.d.ts +0 -6
- package/dist/src/ui/components/LoadingIndicator.test.js +0 -190
- package/dist/src/ui/components/LoadingIndicator.test.js.map +0 -1
- package/dist/src/ui/components/OpenAIKeyPrompt.test.d.ts +0 -6
- package/dist/src/ui/components/OpenAIKeyPrompt.test.js +0 -44
- package/dist/src/ui/components/OpenAIKeyPrompt.test.js.map +0 -1
- package/dist/src/ui/components/QuitConfirmationDialog.d.ts +0 -17
- package/dist/src/ui/components/QuitConfirmationDialog.js +0 -44
- package/dist/src/ui/components/QuitConfirmationDialog.js.map +0 -1
- package/dist/src/ui/components/QwenOAuthProgress.test.d.ts +0 -6
- package/dist/src/ui/components/QwenOAuthProgress.test.js +0 -292
- package/dist/src/ui/components/QwenOAuthProgress.test.js.map +0 -1
- package/dist/src/ui/components/SettingsDialog.d.ts +0 -14
- package/dist/src/ui/components/SettingsDialog.js +0 -519
- package/dist/src/ui/components/SettingsDialog.js.map +0 -1
- package/dist/src/ui/components/SettingsDialog.test.d.ts +0 -6
- package/dist/src/ui/components/SettingsDialog.test.js +0 -568
- package/dist/src/ui/components/SettingsDialog.test.js.map +0 -1
- package/dist/src/ui/components/ShellConfirmationDialog.test.d.ts +0 -6
- package/dist/src/ui/components/ShellConfirmationDialog.test.js +0 -40
- package/dist/src/ui/components/ShellConfirmationDialog.test.js.map +0 -1
- package/dist/src/ui/components/TodoDisplay.d.ts +0 -16
- package/dist/src/ui/components/TodoDisplay.js +0 -27
- package/dist/src/ui/components/TodoDisplay.js.map +0 -1
- package/dist/src/ui/components/TodoDisplay.test.d.ts +0 -6
- package/dist/src/ui/components/TodoDisplay.test.js +0 -77
- package/dist/src/ui/components/TodoDisplay.test.js.map +0 -1
- package/dist/src/ui/components/WelcomeBackDialog.d.ts +0 -13
- package/dist/src/ui/components/WelcomeBackDialog.js +0 -31
- package/dist/src/ui/components/WelcomeBackDialog.js.map +0 -1
- package/dist/src/ui/components/messages/DiffRenderer.test.d.ts +0 -6
- package/dist/src/ui/components/messages/DiffRenderer.test.js +0 -239
- package/dist/src/ui/components/messages/DiffRenderer.test.js.map +0 -1
- package/dist/src/ui/components/messages/SummaryMessage.d.ts +0 -11
- package/dist/src/ui/components/messages/SummaryMessage.js +0 -35
- package/dist/src/ui/components/messages/SummaryMessage.js.map +0 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.d.ts +0 -6
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +0 -37
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +0 -1
- package/dist/src/ui/components/messages/ToolMessage.test.d.ts +0 -6
- package/dist/src/ui/components/messages/ToolMessage.test.js +0 -146
- package/dist/src/ui/components/messages/ToolMessage.test.js.map +0 -1
- package/dist/src/ui/components/shared/MaxSizedBox.test.d.ts +0 -6
- package/dist/src/ui/components/shared/MaxSizedBox.test.js +0 -154
- package/dist/src/ui/components/shared/MaxSizedBox.test.js.map +0 -1
- package/dist/src/ui/components/shared/RadioButtonSelect.test.d.ts +0 -6
- package/dist/src/ui/components/shared/RadioButtonSelect.test.js +0 -111
- package/dist/src/ui/components/shared/RadioButtonSelect.test.js.map +0 -1
- package/dist/src/ui/components/shared/TextInput.d.ts +0 -16
- package/dist/src/ui/components/shared/TextInput.js +0 -127
- package/dist/src/ui/components/shared/TextInput.js.map +0 -1
- package/dist/src/ui/components/subagents/constants.d.ts +0 -23
- package/dist/src/ui/components/subagents/constants.js +0 -67
- package/dist/src/ui/components/subagents/constants.js.map +0 -1
- package/dist/src/ui/components/subagents/create/AgentCreationWizard.d.ts +0 -15
- package/dist/src/ui/components/subagents/create/AgentCreationWizard.js +0 -171
- package/dist/src/ui/components/subagents/create/AgentCreationWizard.js.map +0 -1
- package/dist/src/ui/components/subagents/create/ColorSelector.d.ts +0 -15
- package/dist/src/ui/components/subagents/create/ColorSelector.js +0 -41
- package/dist/src/ui/components/subagents/create/ColorSelector.js.map +0 -1
- package/dist/src/ui/components/subagents/create/CreationSummary.d.ts +0 -10
- package/dist/src/ui/components/subagents/create/CreationSummary.js +0 -163
- package/dist/src/ui/components/subagents/create/CreationSummary.js.map +0 -1
- package/dist/src/ui/components/subagents/create/DescriptionInput.d.ts +0 -10
- package/dist/src/ui/components/subagents/create/DescriptionInput.js +0 -105
- package/dist/src/ui/components/subagents/create/DescriptionInput.js.map +0 -1
- package/dist/src/ui/components/subagents/create/GenerationMethodSelector.d.ts +0 -10
- package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js +0 -33
- package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js.map +0 -1
- package/dist/src/ui/components/subagents/create/LocationSelector.d.ts +0 -10
- package/dist/src/ui/components/subagents/create/LocationSelector.js +0 -33
- package/dist/src/ui/components/subagents/create/LocationSelector.js.map +0 -1
- package/dist/src/ui/components/subagents/create/TextEntryStep.d.ts +0 -26
- package/dist/src/ui/components/subagents/create/TextEntryStep.js +0 -28
- package/dist/src/ui/components/subagents/create/TextEntryStep.js.map +0 -1
- package/dist/src/ui/components/subagents/create/ToolSelector.d.ts +0 -16
- package/dist/src/ui/components/subagents/create/ToolSelector.js +0 -143
- package/dist/src/ui/components/subagents/create/ToolSelector.js.map +0 -1
- package/dist/src/ui/components/subagents/index.d.ts +0 -8
- package/dist/src/ui/components/subagents/index.js +0 -12
- package/dist/src/ui/components/subagents/index.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/ActionSelectionStep.d.ts +0 -13
- package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js +0 -45
- package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/AgentDeleteStep.d.ts +0 -13
- package/dist/src/ui/components/subagents/manage/AgentDeleteStep.js +0 -32
- package/dist/src/ui/components/subagents/manage/AgentDeleteStep.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/AgentEditStep.d.ts +0 -15
- package/dist/src/ui/components/subagents/manage/AgentEditStep.js +0 -62
- package/dist/src/ui/components/subagents/manage/AgentEditStep.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/AgentSelectionStep.d.ts +0 -12
- package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js +0 -224
- package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/AgentViewerStep.d.ts +0 -11
- package/dist/src/ui/components/subagents/manage/AgentViewerStep.js +0 -18
- package/dist/src/ui/components/subagents/manage/AgentViewerStep.js.map +0 -1
- package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.d.ts +0 -15
- package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js +0 -220
- package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js.map +0 -1
- package/dist/src/ui/components/subagents/reducers.d.ts +0 -14
- package/dist/src/ui/components/subagents/reducers.js +0 -161
- package/dist/src/ui/components/subagents/reducers.js.map +0 -1
- package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.d.ts +0 -19
- package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js +0 -184
- package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js.map +0 -1
- package/dist/src/ui/components/subagents/types.d.ts +0 -137
- package/dist/src/ui/components/subagents/types.js +0 -15
- package/dist/src/ui/components/subagents/types.js.map +0 -1
- package/dist/src/ui/components/subagents/utils.d.ts +0 -15
- package/dist/src/ui/components/subagents/utils.js +0 -79
- package/dist/src/ui/components/subagents/utils.js.map +0 -1
- package/dist/src/ui/contexts/KeypressContext.d.ts +0 -31
- package/dist/src/ui/contexts/KeypressContext.js +0 -388
- package/dist/src/ui/contexts/KeypressContext.js.map +0 -1
- package/dist/src/ui/contexts/KeypressContext.test.d.ts +0 -6
- package/dist/src/ui/contexts/KeypressContext.test.js +0 -754
- package/dist/src/ui/contexts/KeypressContext.test.js.map +0 -1
- package/dist/src/ui/contexts/SettingsContext.d.ts +0 -9
- package/dist/src/ui/contexts/SettingsContext.js +0 -15
- package/dist/src/ui/contexts/SettingsContext.js.map +0 -1
- package/dist/src/ui/hooks/atCommandProcessor.test.d.ts +0 -6
- package/dist/src/ui/hooks/atCommandProcessor.test.js +0 -824
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +0 -1
- package/dist/src/ui/hooks/shellCommandProcessor.test.d.ts +0 -6
- package/dist/src/ui/hooks/shellCommandProcessor.test.js +0 -328
- package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +0 -1
- package/dist/src/ui/hooks/useAgentsManagerDialog.d.ts +0 -11
- package/dist/src/ui/hooks/useAgentsManagerDialog.js +0 -21
- package/dist/src/ui/hooks/useAgentsManagerDialog.js.map +0 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.d.ts +0 -6
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +0 -191
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +0 -1
- package/dist/src/ui/hooks/useDialogClose.d.ts +0 -34
- package/dist/src/ui/hooks/useDialogClose.js +0 -62
- package/dist/src/ui/hooks/useDialogClose.js.map +0 -1
- package/dist/src/ui/hooks/useEditorSettings.test.d.ts +0 -6
- package/dist/src/ui/hooks/useEditorSettings.test.js +0 -164
- package/dist/src/ui/hooks/useEditorSettings.test.js.map +0 -1
- package/dist/src/ui/hooks/useFolderTrust.d.ts +0 -12
- package/dist/src/ui/hooks/useFolderTrust.js +0 -55
- package/dist/src/ui/hooks/useFolderTrust.js.map +0 -1
- package/dist/src/ui/hooks/useGitBranchName.test.d.ts +0 -6
- package/dist/src/ui/hooks/useGitBranchName.test.js +0 -239
- package/dist/src/ui/hooks/useGitBranchName.test.js.map +0 -1
- package/dist/src/ui/hooks/useHistoryManager.test.d.ts +0 -6
- package/dist/src/ui/hooks/useHistoryManager.test.js +0 -171
- package/dist/src/ui/hooks/useHistoryManager.test.js.map +0 -1
- package/dist/src/ui/hooks/useInputHistory.test.d.ts +0 -6
- package/dist/src/ui/hooks/useInputHistory.test.js +0 -207
- package/dist/src/ui/hooks/useInputHistory.test.js.map +0 -1
- package/dist/src/ui/hooks/useKittyKeyboardProtocol.d.ts +0 -15
- package/dist/src/ui/hooks/useKittyKeyboardProtocol.js +0 -20
- package/dist/src/ui/hooks/useKittyKeyboardProtocol.js.map +0 -1
- package/dist/src/ui/hooks/useLaunchEditor.d.ts +0 -10
- package/dist/src/ui/hooks/useLaunchEditor.js +0 -70
- package/dist/src/ui/hooks/useLaunchEditor.js.map +0 -1
- package/dist/src/ui/hooks/useLoadingIndicator.test.d.ts +0 -6
- package/dist/src/ui/hooks/useLoadingIndicator.test.js +0 -91
- package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +0 -1
- package/dist/src/ui/hooks/useMessageQueue.d.ts +0 -22
- package/dist/src/ui/hooks/useMessageQueue.js +0 -49
- package/dist/src/ui/hooks/useMessageQueue.js.map +0 -1
- package/dist/src/ui/hooks/useMessageQueue.test.d.ts +0 -6
- package/dist/src/ui/hooks/useMessageQueue.test.js +0 -158
- package/dist/src/ui/hooks/useMessageQueue.test.js.map +0 -1
- package/dist/src/ui/hooks/usePrivacySettings.test.d.ts +0 -6
- package/dist/src/ui/hooks/usePrivacySettings.test.js +0 -154
- package/dist/src/ui/hooks/usePrivacySettings.test.js.map +0 -1
- package/dist/src/ui/hooks/useQuitConfirmation.d.ts +0 -14
- package/dist/src/ui/hooks/useQuitConfirmation.js +0 -36
- package/dist/src/ui/hooks/useQuitConfirmation.js.map +0 -1
- package/dist/src/ui/hooks/useQwenAuth.test.d.ts +0 -6
- package/dist/src/ui/hooks/useQwenAuth.test.js +0 -288
- package/dist/src/ui/hooks/useQwenAuth.test.js.map +0 -1
- package/dist/src/ui/hooks/useReverseSearchCompletion.test.d.ts +0 -6
- package/dist/src/ui/hooks/useReverseSearchCompletion.test.js +0 -163
- package/dist/src/ui/hooks/useReverseSearchCompletion.test.js.map +0 -1
- package/dist/src/ui/hooks/useSettingsCommand.d.ts +0 -10
- package/dist/src/ui/hooks/useSettingsCommand.js +0 -21
- package/dist/src/ui/hooks/useSettingsCommand.js.map +0 -1
- package/dist/src/ui/hooks/useShellHistory.test.d.ts +0 -6
- package/dist/src/ui/hooks/useShellHistory.test.js +0 -162
- package/dist/src/ui/hooks/useShellHistory.test.js.map +0 -1
- package/dist/src/ui/hooks/useSlashCompletion.test.d.ts +0 -6
- package/dist/src/ui/hooks/useSlashCompletion.test.js +0 -272
- package/dist/src/ui/hooks/useSlashCompletion.test.js.map +0 -1
- package/dist/src/ui/hooks/useSubagentCreateDialog.d.ts +0 -10
- package/dist/src/ui/hooks/useSubagentCreateDialog.js +0 -21
- package/dist/src/ui/hooks/useSubagentCreateDialog.js.map +0 -1
- package/dist/src/ui/hooks/useTimer.test.d.ts +0 -6
- package/dist/src/ui/hooks/useTimer.test.js +0 -90
- package/dist/src/ui/hooks/useTimer.test.js.map +0 -1
- package/dist/src/ui/hooks/useToolScheduler.test.d.ts +0 -6
- package/dist/src/ui/hooks/useToolScheduler.test.js +0 -846
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +0 -1
- package/dist/src/ui/hooks/useWelcomeBack.d.ts +0 -23
- package/dist/src/ui/hooks/useWelcomeBack.js +0 -78
- package/dist/src/ui/hooks/useWelcomeBack.js.map +0 -1
- package/dist/src/ui/keyMatchers.d.ts +0 -26
- package/dist/src/ui/keyMatchers.js +0 -68
- package/dist/src/ui/keyMatchers.js.map +0 -1
- package/dist/src/ui/keyMatchers.test.d.ts +0 -6
- package/dist/src/ui/keyMatchers.test.js +0 -276
- package/dist/src/ui/keyMatchers.test.js.map +0 -1
- package/dist/src/ui/semantic-colors.d.ts +0 -7
- package/dist/src/ui/semantic-colors.js +0 -24
- package/dist/src/ui/semantic-colors.js.map +0 -1
- package/dist/src/ui/themes/color-utils.test.d.ts +0 -6
- package/dist/src/ui/themes/color-utils.test.js +0 -197
- package/dist/src/ui/themes/color-utils.test.js.map +0 -1
- package/dist/src/ui/themes/semantic-tokens.d.ts +0 -37
- package/dist/src/ui/themes/semantic-tokens.js +0 -94
- package/dist/src/ui/themes/semantic-tokens.js.map +0 -1
- package/dist/src/ui/themes/theme-manager.test.d.ts +0 -6
- package/dist/src/ui/themes/theme-manager.test.js +0 -83
- package/dist/src/ui/themes/theme-manager.test.js.map +0 -1
- package/dist/src/ui/utils/MarkdownDisplay.test.d.ts +0 -6
- package/dist/src/ui/utils/MarkdownDisplay.test.js +0 -151
- package/dist/src/ui/utils/MarkdownDisplay.test.js.map +0 -1
- package/dist/src/ui/utils/clipboardUtils.test.d.ts +0 -6
- package/dist/src/ui/utils/clipboardUtils.test.js +0 -65
- package/dist/src/ui/utils/clipboardUtils.test.js.map +0 -1
- package/dist/src/ui/utils/commandUtils.test.d.ts +0 -6
- package/dist/src/ui/utils/commandUtils.test.js +0 -294
- package/dist/src/ui/utils/commandUtils.test.js.map +0 -1
- package/dist/src/ui/utils/displayUtils.test.d.ts +0 -6
- package/dist/src/ui/utils/displayUtils.test.js +0 -42
- package/dist/src/ui/utils/displayUtils.test.js.map +0 -1
- package/dist/src/ui/utils/formatters.test.d.ts +0 -6
- package/dist/src/ui/utils/formatters.test.js +0 -56
- package/dist/src/ui/utils/formatters.test.js.map +0 -1
- package/dist/src/ui/utils/isNarrowWidth.d.ts +0 -6
- package/dist/src/ui/utils/isNarrowWidth.js +0 -9
- package/dist/src/ui/utils/isNarrowWidth.js.map +0 -1
- package/dist/src/ui/utils/kittyProtocolDetector.d.ts +0 -13
- package/dist/src/ui/utils/kittyProtocolDetector.js +0 -88
- package/dist/src/ui/utils/kittyProtocolDetector.js.map +0 -1
- package/dist/src/ui/utils/markdownUtilities.test.d.ts +0 -6
- package/dist/src/ui/utils/markdownUtilities.test.js +0 -42
- package/dist/src/ui/utils/markdownUtilities.test.js.map +0 -1
- package/dist/src/ui/utils/platformConstants.d.ts +0 -45
- package/dist/src/ui/utils/platformConstants.js +0 -46
- package/dist/src/ui/utils/platformConstants.js.map +0 -1
- package/dist/src/ui/utils/terminalSetup.d.ts +0 -30
- package/dist/src/ui/utils/terminalSetup.js +0 -281
- package/dist/src/ui/utils/terminalSetup.js.map +0 -1
- package/dist/src/ui/utils/updateCheck.test.d.ts +0 -6
- package/dist/src/ui/utils/updateCheck.test.js +0 -145
- package/dist/src/ui/utils/updateCheck.test.js.map +0 -1
- package/dist/src/utils/checks.d.ts +0 -19
- package/dist/src/utils/checks.js +0 -24
- package/dist/src/utils/checks.js.map +0 -1
- package/dist/src/utils/dialogScopeUtils.d.ts +0 -31
- package/dist/src/utils/dialogScopeUtils.js +0 -48
- package/dist/src/utils/dialogScopeUtils.js.map +0 -1
- package/dist/src/utils/gitUtils.test.d.ts +0 -6
- package/dist/src/utils/gitUtils.test.js +0 -113
- package/dist/src/utils/gitUtils.test.js.map +0 -1
- package/dist/src/utils/installationInfo.test.d.ts +0 -6
- package/dist/src/utils/installationInfo.test.js +0 -242
- package/dist/src/utils/installationInfo.test.js.map +0 -1
- package/dist/src/utils/settingsUtils.d.ts +0 -134
- package/dist/src/utils/settingsUtils.js +0 -336
- package/dist/src/utils/settingsUtils.js.map +0 -1
- package/dist/src/utils/settingsUtils.test.d.ts +0 -6
- package/dist/src/utils/settingsUtils.test.js +0 -514
- package/dist/src/utils/settingsUtils.test.js.map +0 -1
- package/dist/src/utils/userStartupWarnings.test.d.ts +0 -6
- package/dist/src/utils/userStartupWarnings.test.js +0 -67
- package/dist/src/utils/userStartupWarnings.test.js.map +0 -1
- package/dist/src/zed-integration/acp.d.ts +0 -63
- package/dist/src/zed-integration/acp.js.map +0 -1
- package/dist/src/zed-integration/fileSystemService.d.ts +0 -19
- package/dist/src/zed-integration/fileSystemService.js +0 -43
- package/dist/src/zed-integration/fileSystemService.js.map +0 -1
- package/dist/src/zed-integration/schema.d.ts +0 -11782
- package/dist/src/zed-integration/schema.js +0 -311
- package/dist/src/zed-integration/schema.js.map +0 -1
- package/dist/src/zed-integration/zedIntegration.d.ts +0 -10
- package/dist/src/zed-integration/zedIntegration.js +0 -765
- package/dist/src/zed-integration/zedIntegration.js.map +0 -1
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
export {};
|
|
7
|
-
// import {
|
|
8
|
-
// afterEach,
|
|
9
|
-
// beforeEach,
|
|
10
|
-
// describe,
|
|
11
|
-
// expect,
|
|
12
|
-
// it,
|
|
13
|
-
// vi,
|
|
14
|
-
// MockedFunction,
|
|
15
|
-
// } from 'vitest';
|
|
16
|
-
// import { act } from 'react';
|
|
17
|
-
// import { renderHook } from '@testing-library/react';
|
|
18
|
-
// import { useGitBranchName } from './useGitBranchName.js';
|
|
19
|
-
// import { fs, vol } from 'memfs'; // For mocking fs
|
|
20
|
-
// import { EventEmitter } from 'node:events';
|
|
21
|
-
// import { exec as mockExec, type ChildProcess } from 'node:child_process';
|
|
22
|
-
// // TODO BUG FIX
|
|
23
|
-
// import type { FSWatcher } from 'memfs/lib/volume.js';
|
|
24
|
-
//
|
|
25
|
-
// // Mock child_process
|
|
26
|
-
// vi.mock('child_process');
|
|
27
|
-
//
|
|
28
|
-
// // Mock fs and fs/promises
|
|
29
|
-
// vi.mock('node:fs', async () => {
|
|
30
|
-
// const memfs = await vi.importActual<typeof import('memfs')>('memfs');
|
|
31
|
-
// return memfs.fs;
|
|
32
|
-
// });
|
|
33
|
-
//
|
|
34
|
-
// vi.mock('node:fs/promises', async () => {
|
|
35
|
-
// const memfs = await vi.importActual<typeof import('memfs')>('memfs');
|
|
36
|
-
// return memfs.fs.promises;
|
|
37
|
-
// });
|
|
38
|
-
//
|
|
39
|
-
// const CWD = '/test/project';
|
|
40
|
-
// const GIT_HEAD_PATH = `${CWD}/.git/HEAD`;
|
|
41
|
-
//
|
|
42
|
-
// describe('useGitBranchName', () => {
|
|
43
|
-
// beforeEach(() => {
|
|
44
|
-
// vol.reset(); // Reset in-memory filesystem
|
|
45
|
-
// vol.fromJSON({
|
|
46
|
-
// [GIT_HEAD_PATH]: 'ref: refs/heads/main',
|
|
47
|
-
// });
|
|
48
|
-
// vi.useFakeTimers(); // Use fake timers for async operations
|
|
49
|
-
// });
|
|
50
|
-
//
|
|
51
|
-
// afterEach(() => {
|
|
52
|
-
// vi.restoreAllMocks();
|
|
53
|
-
// vi.clearAllTimers();
|
|
54
|
-
// });
|
|
55
|
-
//
|
|
56
|
-
// it('should return branch name', async () => {
|
|
57
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
58
|
-
// (_command, _options, callback) => {
|
|
59
|
-
// callback?.(null, 'main\n', '');
|
|
60
|
-
// return new EventEmitter() as ChildProcess;
|
|
61
|
-
// },
|
|
62
|
-
// );
|
|
63
|
-
//
|
|
64
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
65
|
-
//
|
|
66
|
-
// await act(async () => {
|
|
67
|
-
// vi.runAllTimers(); // Advance timers to trigger useEffect and exec callback
|
|
68
|
-
// rerender(); // Rerender to get the updated state
|
|
69
|
-
// });
|
|
70
|
-
//
|
|
71
|
-
// expect(result.current).toBe('main');
|
|
72
|
-
// });
|
|
73
|
-
//
|
|
74
|
-
// it('should return undefined if git command fails', async () => {
|
|
75
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
76
|
-
// (_command, _options, callback) => {
|
|
77
|
-
// callback?.(new Error('Git error'), '', 'error output');
|
|
78
|
-
// return new EventEmitter() as ChildProcess;
|
|
79
|
-
// },
|
|
80
|
-
// );
|
|
81
|
-
//
|
|
82
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
83
|
-
// expect(result.current).toBeUndefined();
|
|
84
|
-
//
|
|
85
|
-
// await act(async () => {
|
|
86
|
-
// vi.runAllTimers();
|
|
87
|
-
// rerender();
|
|
88
|
-
// });
|
|
89
|
-
// expect(result.current).toBeUndefined();
|
|
90
|
-
// });
|
|
91
|
-
//
|
|
92
|
-
// it('should return short commit hash if branch is HEAD (detached state)', async () => {
|
|
93
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
94
|
-
// (command, _options, callback) => {
|
|
95
|
-
// if (command === 'git rev-parse --abbrev-ref HEAD') {
|
|
96
|
-
// callback?.(null, 'HEAD\n', '');
|
|
97
|
-
// } else if (command === 'git rev-parse --short HEAD') {
|
|
98
|
-
// callback?.(null, 'a1b2c3d\n', '');
|
|
99
|
-
// }
|
|
100
|
-
// return new EventEmitter() as ChildProcess;
|
|
101
|
-
// },
|
|
102
|
-
// );
|
|
103
|
-
//
|
|
104
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
105
|
-
// await act(async () => {
|
|
106
|
-
// vi.runAllTimers();
|
|
107
|
-
// rerender();
|
|
108
|
-
// });
|
|
109
|
-
// expect(result.current).toBe('a1b2c3d');
|
|
110
|
-
// });
|
|
111
|
-
//
|
|
112
|
-
// it('should return undefined if branch is HEAD and getting commit hash fails', async () => {
|
|
113
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
114
|
-
// (command, _options, callback) => {
|
|
115
|
-
// if (command === 'git rev-parse --abbrev-ref HEAD') {
|
|
116
|
-
// callback?.(null, 'HEAD\n', '');
|
|
117
|
-
// } else if (command === 'git rev-parse --short HEAD') {
|
|
118
|
-
// callback?.(new Error('Git error'), '', 'error output');
|
|
119
|
-
// }
|
|
120
|
-
// return new EventEmitter() as ChildProcess;
|
|
121
|
-
// },
|
|
122
|
-
// );
|
|
123
|
-
//
|
|
124
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
125
|
-
// await act(async () => {
|
|
126
|
-
// vi.runAllTimers();
|
|
127
|
-
// rerender();
|
|
128
|
-
// });
|
|
129
|
-
// expect(result.current).toBeUndefined();
|
|
130
|
-
// });
|
|
131
|
-
//
|
|
132
|
-
// it('should update branch name when .git/HEAD changes', async ({ skip }) => {
|
|
133
|
-
// skip(); // TODO: fix
|
|
134
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementationOnce(
|
|
135
|
-
// (_command, _options, callback) => {
|
|
136
|
-
// callback?.(null, 'main\n', '');
|
|
137
|
-
// return new EventEmitter() as ChildProcess;
|
|
138
|
-
// },
|
|
139
|
-
// );
|
|
140
|
-
//
|
|
141
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
142
|
-
//
|
|
143
|
-
// await act(async () => {
|
|
144
|
-
// vi.runAllTimers();
|
|
145
|
-
// rerender();
|
|
146
|
-
// });
|
|
147
|
-
// expect(result.current).toBe('main');
|
|
148
|
-
//
|
|
149
|
-
// // Simulate a branch change
|
|
150
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementationOnce(
|
|
151
|
-
// (_command, _options, callback) => {
|
|
152
|
-
// callback?.(null, 'develop\n', '');
|
|
153
|
-
// return new EventEmitter() as ChildProcess;
|
|
154
|
-
// },
|
|
155
|
-
// );
|
|
156
|
-
//
|
|
157
|
-
// // Simulate file change event
|
|
158
|
-
// // Ensure the watcher is set up before triggering the change
|
|
159
|
-
// await act(async () => {
|
|
160
|
-
// fs.writeFileSync(GIT_HEAD_PATH, 'ref: refs/heads/develop'); // Trigger watcher
|
|
161
|
-
// vi.runAllTimers(); // Process timers for watcher and exec
|
|
162
|
-
// rerender();
|
|
163
|
-
// });
|
|
164
|
-
//
|
|
165
|
-
// expect(result.current).toBe('develop');
|
|
166
|
-
// });
|
|
167
|
-
//
|
|
168
|
-
// it('should handle watcher setup error silently', async () => {
|
|
169
|
-
// // Remove .git/HEAD to cause an error in fs.watch setup
|
|
170
|
-
// vol.unlinkSync(GIT_HEAD_PATH);
|
|
171
|
-
//
|
|
172
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
173
|
-
// (_command, _options, callback) => {
|
|
174
|
-
// callback?.(null, 'main\n', '');
|
|
175
|
-
// return new EventEmitter() as ChildProcess;
|
|
176
|
-
// },
|
|
177
|
-
// );
|
|
178
|
-
//
|
|
179
|
-
// const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
180
|
-
//
|
|
181
|
-
// await act(async () => {
|
|
182
|
-
// vi.runAllTimers();
|
|
183
|
-
// rerender();
|
|
184
|
-
// });
|
|
185
|
-
//
|
|
186
|
-
// expect(result.current).toBe('main'); // Branch name should still be fetched initially
|
|
187
|
-
//
|
|
188
|
-
// // Try to trigger a change that would normally be caught by the watcher
|
|
189
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementationOnce(
|
|
190
|
-
// (_command, _options, callback) => {
|
|
191
|
-
// callback?.(null, 'develop\n', '');
|
|
192
|
-
// return new EventEmitter() as ChildProcess;
|
|
193
|
-
// },
|
|
194
|
-
// );
|
|
195
|
-
//
|
|
196
|
-
// // This write would trigger the watcher if it was set up
|
|
197
|
-
// // but since it failed, the branch name should not update
|
|
198
|
-
// // We need to create the file again for writeFileSync to not throw
|
|
199
|
-
// vol.fromJSON({
|
|
200
|
-
// [GIT_HEAD_PATH]: 'ref: refs/heads/develop',
|
|
201
|
-
// });
|
|
202
|
-
//
|
|
203
|
-
// await act(async () => {
|
|
204
|
-
// fs.writeFileSync(GIT_HEAD_PATH, 'ref: refs/heads/develop');
|
|
205
|
-
// vi.runAllTimers();
|
|
206
|
-
// rerender();
|
|
207
|
-
// });
|
|
208
|
-
//
|
|
209
|
-
// // Branch name should not change because watcher setup failed
|
|
210
|
-
// expect(result.current).toBe('main');
|
|
211
|
-
// });
|
|
212
|
-
//
|
|
213
|
-
// it('should cleanup watcher on unmount', async ({ skip }) => {
|
|
214
|
-
// skip(); // TODO: fix
|
|
215
|
-
// const closeMock = vi.fn();
|
|
216
|
-
// const watchMock = vi.spyOn(fs, 'watch').mockReturnValue({
|
|
217
|
-
// close: closeMock,
|
|
218
|
-
// } as unknown as FSWatcher);
|
|
219
|
-
//
|
|
220
|
-
// (mockExec as MockedFunction<typeof mockExec>).mockImplementation(
|
|
221
|
-
// (_command, _options, callback) => {
|
|
222
|
-
// callback?.(null, 'main\n', '');
|
|
223
|
-
// return new EventEmitter() as ChildProcess;
|
|
224
|
-
// },
|
|
225
|
-
// );
|
|
226
|
-
//
|
|
227
|
-
// const { unmount, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
228
|
-
//
|
|
229
|
-
// await act(async () => {
|
|
230
|
-
// vi.runAllTimers();
|
|
231
|
-
// rerender();
|
|
232
|
-
// });
|
|
233
|
-
//
|
|
234
|
-
// unmount();
|
|
235
|
-
// expect(watchMock).toHaveBeenCalledWith(GIT_HEAD_PATH, expect.any(Function));
|
|
236
|
-
// expect(closeMock).toHaveBeenCalled();
|
|
237
|
-
// });
|
|
238
|
-
// });
|
|
239
|
-
//# sourceMappingURL=useGitBranchName.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useGitBranchName.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useGitBranchName.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,171 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
import { describe, it, expect } from 'vitest';
|
|
7
|
-
import { renderHook, act } from '@testing-library/react';
|
|
8
|
-
import { useHistory } from './useHistoryManager.js';
|
|
9
|
-
describe('useHistoryManager', () => {
|
|
10
|
-
it('should initialize with an empty history', () => {
|
|
11
|
-
const { result } = renderHook(() => useHistory());
|
|
12
|
-
expect(result.current.history).toEqual([]);
|
|
13
|
-
});
|
|
14
|
-
it('should add an item to history with a unique ID', () => {
|
|
15
|
-
const { result } = renderHook(() => useHistory());
|
|
16
|
-
const timestamp = Date.now();
|
|
17
|
-
const itemData = {
|
|
18
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
19
|
-
text: 'Hello',
|
|
20
|
-
};
|
|
21
|
-
act(() => {
|
|
22
|
-
result.current.addItem(itemData, timestamp);
|
|
23
|
-
});
|
|
24
|
-
expect(result.current.history).toHaveLength(1);
|
|
25
|
-
expect(result.current.history[0]).toEqual(expect.objectContaining({
|
|
26
|
-
...itemData,
|
|
27
|
-
id: expect.any(Number),
|
|
28
|
-
}));
|
|
29
|
-
// Basic check that ID incorporates timestamp
|
|
30
|
-
expect(result.current.history[0].id).toBeGreaterThanOrEqual(timestamp);
|
|
31
|
-
});
|
|
32
|
-
it('should generate unique IDs for items added with the same base timestamp', () => {
|
|
33
|
-
const { result } = renderHook(() => useHistory());
|
|
34
|
-
const timestamp = Date.now();
|
|
35
|
-
const itemData1 = {
|
|
36
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
37
|
-
text: 'First',
|
|
38
|
-
};
|
|
39
|
-
const itemData2 = {
|
|
40
|
-
type: 'gemini', // Replaced HistoryItemType.Gemini
|
|
41
|
-
text: 'Second',
|
|
42
|
-
};
|
|
43
|
-
let id1;
|
|
44
|
-
let id2;
|
|
45
|
-
act(() => {
|
|
46
|
-
id1 = result.current.addItem(itemData1, timestamp);
|
|
47
|
-
id2 = result.current.addItem(itemData2, timestamp);
|
|
48
|
-
});
|
|
49
|
-
expect(result.current.history).toHaveLength(2);
|
|
50
|
-
expect(id1).not.toEqual(id2);
|
|
51
|
-
expect(result.current.history[0].id).toEqual(id1);
|
|
52
|
-
expect(result.current.history[1].id).toEqual(id2);
|
|
53
|
-
// IDs should be sequential based on the counter
|
|
54
|
-
expect(id2).toBeGreaterThan(id1);
|
|
55
|
-
});
|
|
56
|
-
it('should update an existing history item', () => {
|
|
57
|
-
const { result } = renderHook(() => useHistory());
|
|
58
|
-
const timestamp = Date.now();
|
|
59
|
-
const initialItem = {
|
|
60
|
-
type: 'gemini', // Replaced HistoryItemType.Gemini
|
|
61
|
-
text: 'Initial content',
|
|
62
|
-
};
|
|
63
|
-
let itemId;
|
|
64
|
-
act(() => {
|
|
65
|
-
itemId = result.current.addItem(initialItem, timestamp);
|
|
66
|
-
});
|
|
67
|
-
const updatedText = 'Updated content';
|
|
68
|
-
act(() => {
|
|
69
|
-
result.current.updateItem(itemId, { text: updatedText });
|
|
70
|
-
});
|
|
71
|
-
expect(result.current.history).toHaveLength(1);
|
|
72
|
-
expect(result.current.history[0]).toEqual({
|
|
73
|
-
...initialItem,
|
|
74
|
-
id: itemId,
|
|
75
|
-
text: updatedText,
|
|
76
|
-
});
|
|
77
|
-
});
|
|
78
|
-
it('should not change history if updateHistoryItem is called with a nonexistent ID', () => {
|
|
79
|
-
const { result } = renderHook(() => useHistory());
|
|
80
|
-
const timestamp = Date.now();
|
|
81
|
-
const itemData = {
|
|
82
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
83
|
-
text: 'Hello',
|
|
84
|
-
};
|
|
85
|
-
act(() => {
|
|
86
|
-
result.current.addItem(itemData, timestamp);
|
|
87
|
-
});
|
|
88
|
-
const originalHistory = [...result.current.history]; // Clone before update attempt
|
|
89
|
-
act(() => {
|
|
90
|
-
result.current.updateItem(99999, { text: 'Should not apply' }); // Nonexistent ID
|
|
91
|
-
});
|
|
92
|
-
expect(result.current.history).toEqual(originalHistory);
|
|
93
|
-
});
|
|
94
|
-
it('should clear the history', () => {
|
|
95
|
-
const { result } = renderHook(() => useHistory());
|
|
96
|
-
const timestamp = Date.now();
|
|
97
|
-
const itemData1 = {
|
|
98
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
99
|
-
text: 'First',
|
|
100
|
-
};
|
|
101
|
-
const itemData2 = {
|
|
102
|
-
type: 'gemini', // Replaced HistoryItemType.Gemini
|
|
103
|
-
text: 'Second',
|
|
104
|
-
};
|
|
105
|
-
act(() => {
|
|
106
|
-
result.current.addItem(itemData1, timestamp);
|
|
107
|
-
result.current.addItem(itemData2, timestamp);
|
|
108
|
-
});
|
|
109
|
-
expect(result.current.history).toHaveLength(2);
|
|
110
|
-
act(() => {
|
|
111
|
-
result.current.clearItems();
|
|
112
|
-
});
|
|
113
|
-
expect(result.current.history).toEqual([]);
|
|
114
|
-
});
|
|
115
|
-
it('should not add consecutive duplicate user messages', () => {
|
|
116
|
-
const { result } = renderHook(() => useHistory());
|
|
117
|
-
const timestamp = Date.now();
|
|
118
|
-
const itemData1 = {
|
|
119
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
120
|
-
text: 'Duplicate message',
|
|
121
|
-
};
|
|
122
|
-
const itemData2 = {
|
|
123
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
124
|
-
text: 'Duplicate message',
|
|
125
|
-
};
|
|
126
|
-
const itemData3 = {
|
|
127
|
-
type: 'gemini', // Replaced HistoryItemType.Gemini
|
|
128
|
-
text: 'Gemini response',
|
|
129
|
-
};
|
|
130
|
-
const itemData4 = {
|
|
131
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
132
|
-
text: 'Another user message',
|
|
133
|
-
};
|
|
134
|
-
act(() => {
|
|
135
|
-
result.current.addItem(itemData1, timestamp);
|
|
136
|
-
result.current.addItem(itemData2, timestamp + 1); // Same text, different timestamp
|
|
137
|
-
result.current.addItem(itemData3, timestamp + 2);
|
|
138
|
-
result.current.addItem(itemData4, timestamp + 3);
|
|
139
|
-
});
|
|
140
|
-
expect(result.current.history).toHaveLength(3);
|
|
141
|
-
expect(result.current.history[0].text).toBe('Duplicate message');
|
|
142
|
-
expect(result.current.history[1].text).toBe('Gemini response');
|
|
143
|
-
expect(result.current.history[2].text).toBe('Another user message');
|
|
144
|
-
});
|
|
145
|
-
it('should add duplicate user messages if they are not consecutive', () => {
|
|
146
|
-
const { result } = renderHook(() => useHistory());
|
|
147
|
-
const timestamp = Date.now();
|
|
148
|
-
const itemData1 = {
|
|
149
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
150
|
-
text: 'Message 1',
|
|
151
|
-
};
|
|
152
|
-
const itemData2 = {
|
|
153
|
-
type: 'gemini', // Replaced HistoryItemType.Gemini
|
|
154
|
-
text: 'Gemini response',
|
|
155
|
-
};
|
|
156
|
-
const itemData3 = {
|
|
157
|
-
type: 'user', // Replaced HistoryItemType.User
|
|
158
|
-
text: 'Message 1', // Duplicate text, but not consecutive
|
|
159
|
-
};
|
|
160
|
-
act(() => {
|
|
161
|
-
result.current.addItem(itemData1, timestamp);
|
|
162
|
-
result.current.addItem(itemData2, timestamp + 1);
|
|
163
|
-
result.current.addItem(itemData3, timestamp + 2);
|
|
164
|
-
});
|
|
165
|
-
expect(result.current.history).toHaveLength(3);
|
|
166
|
-
expect(result.current.history[0].text).toBe('Message 1');
|
|
167
|
-
expect(result.current.history[1].text).toBe('Gemini response');
|
|
168
|
-
expect(result.current.history[2].text).toBe('Message 1');
|
|
169
|
-
});
|
|
170
|
-
});
|
|
171
|
-
//# sourceMappingURL=useHistoryManager.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useHistoryManager.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useHistoryManager.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,207 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
import { act, renderHook } from '@testing-library/react';
|
|
7
|
-
import { useInputHistory } from './useInputHistory.js';
|
|
8
|
-
describe('useInputHistory', () => {
|
|
9
|
-
const mockOnSubmit = vi.fn();
|
|
10
|
-
const mockOnChange = vi.fn();
|
|
11
|
-
beforeEach(() => {
|
|
12
|
-
vi.clearAllMocks();
|
|
13
|
-
});
|
|
14
|
-
const userMessages = ['message 1', 'message 2', 'message 3'];
|
|
15
|
-
it('should initialize with historyIndex -1 and empty originalQueryBeforeNav', () => {
|
|
16
|
-
const { result } = renderHook(() => useInputHistory({
|
|
17
|
-
userMessages: [],
|
|
18
|
-
onSubmit: mockOnSubmit,
|
|
19
|
-
isActive: true,
|
|
20
|
-
currentQuery: '',
|
|
21
|
-
onChange: mockOnChange,
|
|
22
|
-
}));
|
|
23
|
-
// Internal state is not directly testable, but we can infer from behavior.
|
|
24
|
-
// Attempting to navigate down should do nothing if historyIndex is -1.
|
|
25
|
-
act(() => {
|
|
26
|
-
result.current.navigateDown();
|
|
27
|
-
});
|
|
28
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
29
|
-
});
|
|
30
|
-
describe('handleSubmit', () => {
|
|
31
|
-
it('should call onSubmit with trimmed value and reset history', () => {
|
|
32
|
-
const { result } = renderHook(() => useInputHistory({
|
|
33
|
-
userMessages,
|
|
34
|
-
onSubmit: mockOnSubmit,
|
|
35
|
-
isActive: true,
|
|
36
|
-
currentQuery: ' test query ',
|
|
37
|
-
onChange: mockOnChange,
|
|
38
|
-
}));
|
|
39
|
-
act(() => {
|
|
40
|
-
result.current.handleSubmit(' submit value ');
|
|
41
|
-
});
|
|
42
|
-
expect(mockOnSubmit).toHaveBeenCalledWith('submit value');
|
|
43
|
-
// Check if history is reset (e.g., by trying to navigate down)
|
|
44
|
-
act(() => {
|
|
45
|
-
result.current.navigateDown();
|
|
46
|
-
});
|
|
47
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
48
|
-
});
|
|
49
|
-
it('should not call onSubmit if value is empty after trimming', () => {
|
|
50
|
-
const { result } = renderHook(() => useInputHistory({
|
|
51
|
-
userMessages,
|
|
52
|
-
onSubmit: mockOnSubmit,
|
|
53
|
-
isActive: true,
|
|
54
|
-
currentQuery: '',
|
|
55
|
-
onChange: mockOnChange,
|
|
56
|
-
}));
|
|
57
|
-
act(() => {
|
|
58
|
-
result.current.handleSubmit(' ');
|
|
59
|
-
});
|
|
60
|
-
expect(mockOnSubmit).not.toHaveBeenCalled();
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
describe('navigateUp', () => {
|
|
64
|
-
it('should not navigate if isActive is false', () => {
|
|
65
|
-
const { result } = renderHook(() => useInputHistory({
|
|
66
|
-
userMessages,
|
|
67
|
-
onSubmit: mockOnSubmit,
|
|
68
|
-
isActive: false,
|
|
69
|
-
currentQuery: 'current',
|
|
70
|
-
onChange: mockOnChange,
|
|
71
|
-
}));
|
|
72
|
-
act(() => {
|
|
73
|
-
const navigated = result.current.navigateUp();
|
|
74
|
-
expect(navigated).toBe(false);
|
|
75
|
-
});
|
|
76
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
77
|
-
});
|
|
78
|
-
it('should not navigate if userMessages is empty', () => {
|
|
79
|
-
const { result } = renderHook(() => useInputHistory({
|
|
80
|
-
userMessages: [],
|
|
81
|
-
onSubmit: mockOnSubmit,
|
|
82
|
-
isActive: true,
|
|
83
|
-
currentQuery: 'current',
|
|
84
|
-
onChange: mockOnChange,
|
|
85
|
-
}));
|
|
86
|
-
act(() => {
|
|
87
|
-
const navigated = result.current.navigateUp();
|
|
88
|
-
expect(navigated).toBe(false);
|
|
89
|
-
});
|
|
90
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
91
|
-
});
|
|
92
|
-
it('should call onChange with the last message when navigating up from initial state', () => {
|
|
93
|
-
const currentQuery = 'current query';
|
|
94
|
-
const { result } = renderHook(() => useInputHistory({
|
|
95
|
-
userMessages,
|
|
96
|
-
onSubmit: mockOnSubmit,
|
|
97
|
-
isActive: true,
|
|
98
|
-
currentQuery,
|
|
99
|
-
onChange: mockOnChange,
|
|
100
|
-
}));
|
|
101
|
-
act(() => {
|
|
102
|
-
result.current.navigateUp();
|
|
103
|
-
});
|
|
104
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[2]); // Last message
|
|
105
|
-
});
|
|
106
|
-
it('should store currentQuery as originalQueryBeforeNav on first navigateUp', () => {
|
|
107
|
-
const currentQuery = 'original user input';
|
|
108
|
-
const { result } = renderHook(() => useInputHistory({
|
|
109
|
-
userMessages,
|
|
110
|
-
onSubmit: mockOnSubmit,
|
|
111
|
-
isActive: true,
|
|
112
|
-
currentQuery,
|
|
113
|
-
onChange: mockOnChange,
|
|
114
|
-
}));
|
|
115
|
-
act(() => {
|
|
116
|
-
result.current.navigateUp(); // historyIndex becomes 0
|
|
117
|
-
});
|
|
118
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[2]);
|
|
119
|
-
// Navigate down to restore original query
|
|
120
|
-
act(() => {
|
|
121
|
-
result.current.navigateDown(); // historyIndex becomes -1
|
|
122
|
-
});
|
|
123
|
-
expect(mockOnChange).toHaveBeenCalledWith(currentQuery);
|
|
124
|
-
});
|
|
125
|
-
it('should navigate through history messages on subsequent navigateUp calls', () => {
|
|
126
|
-
const { result } = renderHook(() => useInputHistory({
|
|
127
|
-
userMessages,
|
|
128
|
-
onSubmit: mockOnSubmit,
|
|
129
|
-
isActive: true,
|
|
130
|
-
currentQuery: '',
|
|
131
|
-
onChange: mockOnChange,
|
|
132
|
-
}));
|
|
133
|
-
act(() => {
|
|
134
|
-
result.current.navigateUp(); // Navigates to 'message 3'
|
|
135
|
-
});
|
|
136
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[2]);
|
|
137
|
-
act(() => {
|
|
138
|
-
result.current.navigateUp(); // Navigates to 'message 2'
|
|
139
|
-
});
|
|
140
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[1]);
|
|
141
|
-
act(() => {
|
|
142
|
-
result.current.navigateUp(); // Navigates to 'message 1'
|
|
143
|
-
});
|
|
144
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[0]);
|
|
145
|
-
});
|
|
146
|
-
});
|
|
147
|
-
describe('navigateDown', () => {
|
|
148
|
-
it('should not navigate if isActive is false', () => {
|
|
149
|
-
const initialProps = {
|
|
150
|
-
userMessages,
|
|
151
|
-
onSubmit: mockOnSubmit,
|
|
152
|
-
isActive: true, // Start active to allow setup navigation
|
|
153
|
-
currentQuery: 'current',
|
|
154
|
-
onChange: mockOnChange,
|
|
155
|
-
};
|
|
156
|
-
const { result, rerender } = renderHook((props) => useInputHistory(props), {
|
|
157
|
-
initialProps,
|
|
158
|
-
});
|
|
159
|
-
// First navigate up to have something in history
|
|
160
|
-
act(() => {
|
|
161
|
-
result.current.navigateUp();
|
|
162
|
-
});
|
|
163
|
-
mockOnChange.mockClear(); // Clear calls from setup
|
|
164
|
-
// Set isActive to false for the actual test
|
|
165
|
-
rerender({ ...initialProps, isActive: false });
|
|
166
|
-
act(() => {
|
|
167
|
-
const navigated = result.current.navigateDown();
|
|
168
|
-
expect(navigated).toBe(false);
|
|
169
|
-
});
|
|
170
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
171
|
-
});
|
|
172
|
-
it('should not navigate if historyIndex is -1 (not in history navigation)', () => {
|
|
173
|
-
const { result } = renderHook(() => useInputHistory({
|
|
174
|
-
userMessages,
|
|
175
|
-
onSubmit: mockOnSubmit,
|
|
176
|
-
isActive: true,
|
|
177
|
-
currentQuery: 'current',
|
|
178
|
-
onChange: mockOnChange,
|
|
179
|
-
}));
|
|
180
|
-
act(() => {
|
|
181
|
-
const navigated = result.current.navigateDown();
|
|
182
|
-
expect(navigated).toBe(false);
|
|
183
|
-
});
|
|
184
|
-
expect(mockOnChange).not.toHaveBeenCalled();
|
|
185
|
-
});
|
|
186
|
-
it('should restore originalQueryBeforeNav when navigating down to initial state', () => {
|
|
187
|
-
const originalQuery = 'my original input';
|
|
188
|
-
const { result } = renderHook(() => useInputHistory({
|
|
189
|
-
userMessages,
|
|
190
|
-
onSubmit: mockOnSubmit,
|
|
191
|
-
isActive: true,
|
|
192
|
-
currentQuery: originalQuery,
|
|
193
|
-
onChange: mockOnChange,
|
|
194
|
-
}));
|
|
195
|
-
act(() => {
|
|
196
|
-
result.current.navigateUp(); // Navigates to 'message 3', stores 'originalQuery'
|
|
197
|
-
});
|
|
198
|
-
expect(mockOnChange).toHaveBeenCalledWith(userMessages[2]);
|
|
199
|
-
mockOnChange.mockClear();
|
|
200
|
-
act(() => {
|
|
201
|
-
result.current.navigateDown(); // Navigates back to original query
|
|
202
|
-
});
|
|
203
|
-
expect(mockOnChange).toHaveBeenCalledWith(originalQuery);
|
|
204
|
-
});
|
|
205
|
-
});
|
|
206
|
-
});
|
|
207
|
-
//# sourceMappingURL=useInputHistory.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useInputHistory.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useInputHistory.test.ts"],"names":[],"mappings":"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"}
|