@google/gemini-cli 0.0.3-preview.4 → 0.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +2 -2
- package/README.md +12 -2
- package/dist/package.json +6 -7
- package/dist/src/commands/extensions/disable.d.ts +1 -1
- package/dist/src/commands/extensions/disable.js +3 -3
- package/dist/src/commands/extensions/disable.js.map +1 -1
- package/dist/src/commands/extensions/enable.d.ts +1 -1
- package/dist/src/commands/extensions/enable.js +6 -8
- package/dist/src/commands/extensions/enable.js.map +1 -1
- package/dist/src/commands/extensions/examples/context/GEMINI.md +8 -0
- package/dist/src/commands/extensions/examples/context/gemini-extension.json +5 -0
- package/dist/src/commands/extensions/examples/custom-commands/commands/fs/grep-code.toml +6 -0
- package/dist/src/commands/extensions/examples/custom-commands/gemini-extension.json +4 -0
- package/dist/src/commands/extensions/examples/exclude-tools/gemini-extension.json +5 -0
- package/dist/src/commands/extensions/examples/mcp-server/example.js +46 -0
- package/dist/src/commands/extensions/examples/mcp-server/example.js.map +1 -0
- package/dist/src/commands/extensions/examples/mcp-server/example.ts +60 -0
- package/dist/src/commands/extensions/examples/mcp-server/gemini-extension.json +10 -0
- package/dist/src/commands/extensions/install.d.ts +1 -0
- package/dist/src/commands/extensions/install.js +41 -12
- package/dist/src/commands/extensions/install.js.map +1 -1
- package/dist/src/commands/extensions/install.test.js +79 -3
- package/dist/src/commands/extensions/install.test.js.map +1 -1
- package/dist/src/commands/extensions/link.d.ts +12 -0
- package/dist/src/commands/extensions/link.js +37 -0
- package/dist/src/commands/extensions/link.js.map +1 -0
- package/dist/src/commands/extensions/new.d.ts +7 -0
- package/dist/src/commands/extensions/new.js +70 -0
- package/dist/src/commands/extensions/new.js.map +1 -0
- package/dist/src/commands/extensions/new.test.d.ts +6 -0
- package/dist/src/commands/extensions/new.test.js +50 -0
- package/dist/src/commands/extensions/new.test.js.map +1 -0
- package/dist/src/commands/extensions/uninstall.js +1 -1
- package/dist/src/commands/extensions/uninstall.js.map +1 -1
- package/dist/src/commands/extensions/update.d.ts +2 -1
- package/dist/src/commands/extensions/update.js +46 -15
- package/dist/src/commands/extensions/update.js.map +1 -1
- package/dist/src/commands/extensions.js +4 -0
- package/dist/src/commands/extensions.js.map +1 -1
- package/dist/src/commands/mcp/add.js +1 -1
- package/dist/src/commands/mcp/add.js.map +1 -1
- package/dist/src/commands/mcp/list.js +2 -2
- package/dist/src/commands/mcp/list.js.map +1 -1
- package/dist/src/commands/mcp/remove.js +1 -1
- package/dist/src/commands/mcp/remove.js.map +1 -1
- package/dist/src/config/auth.d.ts +1 -1
- package/dist/src/config/auth.js +4 -4
- package/dist/src/config/auth.js.map +1 -1
- package/dist/src/config/auth.test.js +15 -7
- package/dist/src/config/auth.test.js.map +1 -1
- package/dist/src/config/config.d.ts +4 -1
- package/dist/src/config/config.js +57 -23
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/extension.d.ts +20 -13
- package/dist/src/config/extension.js +261 -109
- package/dist/src/config/extension.js.map +1 -1
- package/dist/src/config/extensions/extensionEnablement.d.ts +30 -0
- package/dist/src/config/extensions/extensionEnablement.js +113 -0
- package/dist/src/config/extensions/extensionEnablement.js.map +1 -0
- package/dist/src/config/extensions/extensionEnablement.test.d.ts +6 -0
- package/dist/src/config/extensions/extensionEnablement.test.js +116 -0
- package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -0
- package/dist/src/config/extensions/github.d.ts +25 -0
- package/dist/src/config/extensions/github.js +258 -0
- package/dist/src/config/extensions/github.js.map +1 -0
- package/dist/src/config/extensions/github.test.d.ts +6 -0
- package/dist/src/config/extensions/github.test.js +232 -0
- package/dist/src/config/extensions/github.test.js.map +1 -0
- package/dist/src/config/extensions/variableSchema.d.ts +8 -0
- package/dist/src/config/extensions/variableSchema.js +4 -0
- package/dist/src/config/extensions/variableSchema.js.map +1 -1
- package/dist/src/config/keyBindings.d.ts +5 -1
- package/dist/src/config/keyBindings.js +14 -25
- package/dist/src/config/keyBindings.js.map +1 -1
- package/dist/src/config/policy-engine.integration.test.d.ts +6 -0
- package/dist/src/config/policy-engine.integration.test.js +270 -0
- package/dist/src/config/policy-engine.integration.test.js.map +1 -0
- package/dist/src/config/policy.d.ts +8 -0
- package/dist/src/config/policy.js +150 -0
- package/dist/src/config/policy.js.map +1 -0
- package/dist/src/config/policy.test.d.ts +6 -0
- package/dist/src/config/policy.test.js +336 -0
- package/dist/src/config/policy.test.js.map +1 -0
- package/dist/src/config/settings.d.ts +8 -5
- package/dist/src/config/settings.js +148 -251
- package/dist/src/config/settings.js.map +1 -1
- package/dist/src/config/settingsSchema.d.ts +232 -23
- package/dist/src/config/settingsSchema.js +222 -20
- package/dist/src/config/settingsSchema.js.map +1 -1
- package/dist/src/config/settingsSchema.test.js +68 -55
- package/dist/src/config/settingsSchema.test.js.map +1 -1
- package/dist/src/config/trustedFolders.d.ts +13 -3
- package/dist/src/config/trustedFolders.js +66 -42
- package/dist/src/config/trustedFolders.js.map +1 -1
- package/dist/src/config/trustedFolders.test.js +107 -12
- package/dist/src/config/trustedFolders.test.js.map +1 -1
- package/dist/src/core/auth.d.ts +13 -0
- package/dist/src/core/auth.js +27 -0
- package/dist/src/core/auth.js.map +1 -0
- package/dist/src/core/initializer.d.ts +21 -0
- package/dist/src/core/initializer.js +33 -0
- package/dist/src/core/initializer.js.map +1 -0
- package/dist/src/core/theme.d.ts +12 -0
- package/dist/src/core/theme.js +20 -0
- package/dist/src/core/theme.js.map +1 -0
- package/dist/src/gemini.d.ts +2 -1
- package/dist/src/gemini.js +96 -51
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/gemini.test.js +113 -42
- package/dist/src/gemini.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/nonInteractiveCli.js +87 -71
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/services/BuiltinCommandLoader.js +1 -1
- package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
- package/dist/src/services/BuiltinCommandLoader.test.js +16 -17
- package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
- package/dist/src/services/FileCommandLoader.d.ts +2 -0
- package/dist/src/services/FileCommandLoader.js +7 -0
- package/dist/src/services/FileCommandLoader.js.map +1 -1
- package/dist/src/services/McpPromptLoader.js +43 -8
- package/dist/src/services/McpPromptLoader.js.map +1 -1
- package/dist/src/services/McpPromptLoader.test.js +228 -1
- package/dist/src/services/McpPromptLoader.test.js.map +1 -1
- package/dist/src/services/prompt-processors/shellProcessor.js +8 -1
- package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
- package/dist/src/ui/App.d.ts +1 -10
- package/dist/src/ui/App.js +13 -667
- package/dist/src/ui/App.js.map +1 -1
- package/dist/src/ui/AppContainer.d.ts +17 -0
- package/dist/src/ui/AppContainer.js +879 -0
- package/dist/src/ui/AppContainer.js.map +1 -0
- package/dist/src/ui/AppContainer.test.d.ts +6 -0
- package/dist/src/ui/AppContainer.test.js +414 -0
- package/dist/src/ui/AppContainer.test.js.map +1 -0
- package/dist/src/ui/IdeIntegrationNudge.d.ts +2 -2
- package/dist/src/ui/IdeIntegrationNudge.js +3 -3
- package/dist/src/ui/IdeIntegrationNudge.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.d.ts +18 -0
- package/dist/src/ui/auth/AuthDialog.js +99 -0
- package/dist/src/ui/auth/AuthDialog.js.map +1 -0
- package/dist/src/ui/auth/AuthDialog.test.d.ts +6 -0
- package/dist/src/ui/auth/AuthDialog.test.js +184 -0
- package/dist/src/ui/auth/AuthDialog.test.js.map +1 -0
- package/dist/src/ui/{components → auth}/AuthInProgress.js +2 -2
- package/dist/src/ui/auth/AuthInProgress.js.map +1 -0
- package/dist/src/ui/auth/useAuth.d.ts +15 -0
- package/dist/src/ui/auth/useAuth.js +73 -0
- package/dist/src/ui/auth/useAuth.js.map +1 -0
- package/dist/src/ui/commands/aboutCommand.js +9 -3
- package/dist/src/ui/commands/aboutCommand.js.map +1 -1
- package/dist/src/ui/commands/bugCommand.js +9 -4
- package/dist/src/ui/commands/bugCommand.js.map +1 -1
- package/dist/src/ui/commands/chatCommand.d.ts +2 -0
- package/dist/src/ui/commands/chatCommand.js +82 -3
- package/dist/src/ui/commands/chatCommand.js.map +1 -1
- package/dist/src/ui/commands/clearCommand.js +1 -1
- package/dist/src/ui/commands/clearCommand.js.map +1 -1
- package/dist/src/ui/commands/corgiCommand.js +1 -0
- package/dist/src/ui/commands/corgiCommand.js.map +1 -1
- package/dist/src/ui/commands/directoryCommand.js +1 -1
- package/dist/src/ui/commands/directoryCommand.js.map +1 -1
- package/dist/src/ui/commands/extensionsCommand.js +70 -16
- package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
- package/dist/src/ui/commands/ideCommand.d.ts +1 -2
- package/dist/src/ui/commands/ideCommand.js +19 -10
- package/dist/src/ui/commands/ideCommand.js.map +1 -1
- package/dist/src/ui/commands/mcpCommand.js +14 -5
- package/dist/src/ui/commands/mcpCommand.js.map +1 -1
- package/dist/src/ui/commands/memoryCommand.js +1 -1
- package/dist/src/ui/commands/memoryCommand.js.map +1 -1
- package/dist/src/ui/commands/types.d.ts +5 -1
- package/dist/src/ui/commands/types.js +0 -1
- package/dist/src/ui/commands/types.js.map +1 -1
- package/dist/src/ui/components/AboutBox.js +2 -2
- package/dist/src/ui/components/AboutBox.js.map +1 -1
- package/dist/src/ui/components/AnsiOutput.d.ts +13 -0
- package/dist/src/ui/components/AnsiOutput.js +12 -0
- package/dist/src/ui/components/AnsiOutput.js.map +1 -0
- package/dist/src/ui/components/AnsiOutput.test.d.ts +6 -0
- package/dist/src/ui/components/AnsiOutput.test.js +97 -0
- package/dist/src/ui/components/AnsiOutput.test.js.map +1 -0
- package/dist/src/ui/components/AppHeader.d.ts +10 -0
- package/dist/src/ui/components/AppHeader.js +22 -0
- package/dist/src/ui/components/AppHeader.js.map +1 -0
- package/dist/src/ui/components/AutoAcceptIndicator.js +4 -4
- package/dist/src/ui/components/AutoAcceptIndicator.js.map +1 -1
- package/dist/src/ui/components/Composer.d.ts +6 -0
- package/dist/src/ui/components/Composer.js +73 -0
- package/dist/src/ui/components/Composer.js.map +1 -0
- package/dist/src/ui/components/Composer.test.d.ts +6 -0
- package/dist/src/ui/components/Composer.test.js +337 -0
- package/dist/src/ui/components/Composer.test.js.map +1 -0
- package/dist/src/ui/components/ConfigInitDisplay.d.ts +6 -0
- package/dist/src/ui/components/ConfigInitDisplay.js +38 -0
- package/dist/src/ui/components/ConfigInitDisplay.js.map +1 -0
- package/dist/src/ui/components/ConsoleSummaryDisplay.js +2 -2
- package/dist/src/ui/components/ConsoleSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/ContextSummaryDisplay.js +3 -3
- package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/ContextUsageDisplay.js +2 -2
- package/dist/src/ui/components/ContextUsageDisplay.js.map +1 -1
- package/dist/src/ui/components/DebugProfiler.js +2 -2
- package/dist/src/ui/components/DebugProfiler.js.map +1 -1
- package/dist/src/ui/components/DetailedMessagesDisplay.js +7 -7
- package/dist/src/ui/components/DetailedMessagesDisplay.js.map +1 -1
- package/dist/src/ui/components/DialogManager.d.ts +6 -0
- package/dist/src/ui/components/DialogManager.js +85 -0
- package/dist/src/ui/components/DialogManager.js.map +1 -0
- package/dist/src/ui/components/EditorSettingsDialog.js +5 -5
- package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.js +19 -9
- package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.test.js +35 -10
- package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
- package/dist/src/ui/components/Footer.d.ts +4 -2
- package/dist/src/ui/components/Footer.js +8 -3
- package/dist/src/ui/components/Footer.js.map +1 -1
- package/dist/src/ui/components/GeminiRespondingSpinner.d.ts +5 -0
- package/dist/src/ui/components/GeminiRespondingSpinner.js +7 -2
- package/dist/src/ui/components/GeminiRespondingSpinner.js.map +1 -1
- package/dist/src/ui/components/Header.js +2 -2
- package/dist/src/ui/components/Header.js.map +1 -1
- package/dist/src/ui/components/Help.d.ts +1 -1
- package/dist/src/ui/components/Help.js +9 -6
- package/dist/src/ui/components/Help.js.map +1 -1
- package/dist/src/ui/components/Help.test.d.ts +6 -0
- package/dist/src/ui/components/Help.test.js +57 -0
- package/dist/src/ui/components/Help.test.js.map +1 -0
- package/dist/src/ui/components/HistoryItemDisplay.d.ts +2 -2
- package/dist/src/ui/components/HistoryItemDisplay.js +3 -1
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.d.ts +9 -0
- package/dist/src/ui/components/InputPrompt.js +180 -42
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/LoadingIndicator.js +2 -2
- package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
- package/dist/src/ui/components/LoopDetectionConfirmation.d.ts +13 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.js +35 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.js.map +1 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.d.ts +6 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js +25 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js.map +1 -0
- package/dist/src/ui/components/MainContent.d.ts +6 -0
- package/dist/src/ui/components/MainContent.js +23 -0
- package/dist/src/ui/components/MainContent.js.map +1 -0
- package/dist/src/ui/components/MemoryUsageDisplay.js +6 -4
- package/dist/src/ui/components/MemoryUsageDisplay.js.map +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.js +7 -7
- package/dist/src/ui/components/ModelStatsDisplay.js.map +1 -1
- package/dist/src/ui/components/Notifications.d.ts +6 -0
- package/dist/src/ui/components/Notifications.js +23 -0
- package/dist/src/ui/components/Notifications.js.map +1 -0
- package/dist/src/ui/components/PrepareLabel.d.ts +5 -5
- package/dist/src/ui/components/PrepareLabel.js +67 -11
- package/dist/src/ui/components/PrepareLabel.js.map +1 -1
- package/dist/src/ui/components/PrepareLabel.test.d.ts +6 -0
- package/dist/src/ui/components/PrepareLabel.test.js +71 -0
- package/dist/src/ui/components/PrepareLabel.test.js.map +1 -0
- package/dist/src/ui/components/ProQuotaDialog.d.ts +13 -0
- package/dist/src/ui/components/ProQuotaDialog.js +21 -0
- package/dist/src/ui/components/ProQuotaDialog.js.map +1 -0
- package/dist/src/ui/components/ProQuotaDialog.test.d.ts +6 -0
- package/dist/src/ui/components/ProQuotaDialog.test.js +56 -0
- package/dist/src/ui/components/ProQuotaDialog.test.js.map +1 -0
- package/dist/src/ui/components/QueuedMessageDisplay.d.ts +9 -0
- package/dist/src/ui/components/QueuedMessageDisplay.js +20 -0
- package/dist/src/ui/components/QueuedMessageDisplay.js.map +1 -0
- package/dist/src/ui/components/QueuedMessageDisplay.test.d.ts +6 -0
- package/dist/src/ui/components/QueuedMessageDisplay.test.js +56 -0
- package/dist/src/ui/components/QueuedMessageDisplay.test.js.map +1 -0
- package/dist/src/ui/components/QuittingDisplay.d.ts +6 -0
- package/dist/src/ui/components/QuittingDisplay.js +20 -0
- package/dist/src/ui/components/QuittingDisplay.js.map +1 -0
- package/dist/src/ui/components/SettingsDialog.d.ts +2 -1
- package/dist/src/ui/components/SettingsDialog.js +93 -22
- package/dist/src/ui/components/SettingsDialog.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.test.js +436 -80
- package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/ShellConfirmationDialog.js +2 -2
- package/dist/src/ui/components/ShellConfirmationDialog.js.map +1 -1
- package/dist/src/ui/components/ShellInputPrompt.d.ts +11 -0
- package/dist/src/ui/components/ShellInputPrompt.js +36 -0
- package/dist/src/ui/components/ShellInputPrompt.js.map +1 -0
- package/dist/src/ui/components/ShellModeIndicator.js +2 -2
- package/dist/src/ui/components/ShellModeIndicator.js.map +1 -1
- package/dist/src/ui/components/ShowMoreLines.js +2 -2
- package/dist/src/ui/components/ShowMoreLines.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.js +6 -6
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.d.ts +7 -2
- package/dist/src/ui/components/SuggestionsDisplay.js +17 -17
- package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.js +12 -29
- package/dist/src/ui/components/ThemeDialog.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.test.d.ts +6 -0
- package/dist/src/ui/components/ThemeDialog.test.js +75 -0
- package/dist/src/ui/components/ThemeDialog.test.js.map +1 -0
- package/dist/src/ui/components/Tips.js +2 -2
- package/dist/src/ui/components/Tips.js.map +1 -1
- package/dist/src/ui/components/ToolStatsDisplay.js +4 -4
- package/dist/src/ui/components/ToolStatsDisplay.js.map +1 -1
- package/dist/src/ui/components/UpdateNotification.js +2 -2
- package/dist/src/ui/components/UpdateNotification.js.map +1 -1
- package/dist/src/ui/components/WorkspaceMigrationDialog.js +4 -4
- package/dist/src/ui/components/WorkspaceMigrationDialog.js.map +1 -1
- package/dist/src/ui/components/messages/CompressionMessage.d.ts +1 -2
- package/dist/src/ui/components/messages/CompressionMessage.js +37 -8
- package/dist/src/ui/components/messages/CompressionMessage.js.map +1 -1
- package/dist/src/ui/components/messages/CompressionMessage.test.d.ts +6 -0
- package/dist/src/ui/components/messages/CompressionMessage.test.js +160 -0
- package/dist/src/ui/components/messages/CompressionMessage.test.js.map +1 -0
- package/dist/src/ui/components/messages/DiffRenderer.d.ts +2 -1
- package/dist/src/ui/components/messages/DiffRenderer.js +14 -22
- package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
- package/dist/src/ui/components/messages/ErrorMessage.js +2 -2
- package/dist/src/ui/components/messages/ErrorMessage.js.map +1 -1
- package/dist/src/ui/components/messages/GeminiMessage.js +2 -2
- package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
- 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/ToolConfirmationMessage.js +33 -21
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +0 -8
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -2
- package/dist/src/ui/components/messages/ToolGroupMessage.js +17 -9
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js +17 -15
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.d.ts +4 -0
- package/dist/src/ui/components/messages/ToolMessage.js +24 -10
- package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.test.js +33 -1
- package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/UserMessage.js +3 -3
- package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
- package/dist/src/ui/components/messages/UserShellMessage.js +2 -2
- package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
- package/dist/src/ui/components/messages/WarningMessage.d.ts +11 -0
- package/dist/src/ui/components/messages/WarningMessage.js +10 -0
- package/dist/src/ui/components/messages/WarningMessage.js.map +1 -0
- package/dist/src/ui/components/shared/EnumSelector.d.ts +18 -0
- package/dist/src/ui/components/shared/EnumSelector.js +44 -0
- package/dist/src/ui/components/shared/EnumSelector.js.map +1 -0
- package/dist/src/ui/components/shared/EnumSelector.test.d.ts +6 -0
- package/dist/src/ui/components/shared/EnumSelector.test.js +70 -0
- package/dist/src/ui/components/shared/EnumSelector.test.js.map +1 -0
- package/dist/src/ui/components/shared/MaxSizedBox.js +2 -2
- package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
- package/dist/src/ui/components/shared/RadioButtonSelect.js +12 -12
- package/dist/src/ui/components/shared/RadioButtonSelect.js.map +1 -1
- package/dist/src/ui/components/shared/ScopeSelector.d.ts +19 -0
- package/dist/src/ui/components/shared/ScopeSelector.js +11 -0
- package/dist/src/ui/components/shared/ScopeSelector.js.map +1 -0
- package/dist/src/ui/components/shared/text-buffer.d.ts +25 -2
- package/dist/src/ui/components/shared/text-buffer.js +296 -187
- package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
- package/dist/src/ui/components/views/ExtensionsList.d.ts +6 -0
- package/dist/src/ui/components/views/ExtensionsList.js +47 -0
- package/dist/src/ui/components/views/ExtensionsList.js.map +1 -0
- package/dist/src/ui/components/views/ExtensionsList.test.d.ts +6 -0
- package/dist/src/ui/components/views/ExtensionsList.test.js +97 -0
- package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -0
- package/dist/src/ui/constants.d.ts +1 -0
- package/dist/src/ui/constants.js +1 -0
- package/dist/src/ui/constants.js.map +1 -1
- package/dist/src/ui/contexts/AppContext.d.ts +11 -0
- package/dist/src/ui/contexts/AppContext.js +15 -0
- package/dist/src/ui/contexts/AppContext.js.map +1 -0
- package/dist/src/ui/contexts/ConfigContext.d.ts +9 -0
- package/dist/src/ui/contexts/ConfigContext.js +16 -0
- package/dist/src/ui/contexts/ConfigContext.js.map +1 -0
- package/dist/src/ui/contexts/FocusContext.d.ts +7 -0
- package/dist/src/ui/contexts/FocusContext.js +9 -0
- package/dist/src/ui/contexts/FocusContext.js.map +1 -0
- package/dist/src/ui/contexts/KeypressContext.d.ts +3 -0
- package/dist/src/ui/contexts/KeypressContext.js +306 -44
- package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
- package/dist/src/ui/contexts/KeypressContext.test.js +288 -2
- package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
- package/dist/src/ui/contexts/SessionContext.d.ts +6 -0
- package/dist/src/ui/contexts/SessionContext.js +107 -5
- package/dist/src/ui/contexts/SessionContext.js.map +1 -1
- package/dist/src/ui/contexts/UIActionsContext.d.ts +36 -0
- package/dist/src/ui/contexts/UIActionsContext.js +20 -0
- package/dist/src/ui/contexts/UIActionsContext.js.map +1 -0
- package/dist/src/ui/contexts/UIStateContext.d.ts +95 -0
- package/dist/src/ui/contexts/UIStateContext.js +15 -0
- package/dist/src/ui/contexts/UIStateContext.js.map +1 -0
- package/dist/src/ui/hooks/atCommandProcessor.test.js +7 -5
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/keyToAnsi.d.ts +15 -0
- package/dist/src/ui/hooks/keyToAnsi.js +67 -0
- package/dist/src/ui/hooks/keyToAnsi.js.map +1 -0
- package/dist/src/ui/hooks/shellCommandProcessor.d.ts +2 -1
- package/dist/src/ui/hooks/shellCommandProcessor.js +60 -15
- package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/shellCommandProcessor.test.js +196 -17
- package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.d.ts +15 -2
- package/dist/src/ui/hooks/slashCommandProcessor.js +36 -73
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.d.ts +3 -2
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js +9 -5
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js.map +1 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +69 -0
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +1 -1
- package/dist/src/ui/hooks/useFolderTrust.d.ts +1 -1
- package/dist/src/ui/hooks/useFolderTrust.js +12 -11
- package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.d.ts +13 -2
- package/dist/src/ui/hooks/useGeminiStream.js +150 -60
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.js +15 -18
- package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.test.js +49 -53
- package/dist/src/ui/hooks/useGitBranchName.test.js.map +1 -1
- package/dist/src/ui/hooks/useIdeTrustListener.d.ts +14 -0
- package/dist/src/ui/hooks/useIdeTrustListener.js +39 -0
- package/dist/src/ui/hooks/useIdeTrustListener.js.map +1 -0
- package/dist/src/ui/hooks/useInputHistoryStore.d.ts +19 -0
- package/dist/src/ui/hooks/useInputHistoryStore.js +81 -0
- package/dist/src/ui/hooks/useInputHistoryStore.js.map +1 -0
- package/dist/src/ui/hooks/useInputHistoryStore.test.d.ts +6 -0
- package/dist/src/ui/hooks/useInputHistoryStore.test.js +234 -0
- package/dist/src/ui/hooks/useInputHistoryStore.test.js.map +1 -0
- package/dist/src/ui/hooks/useLoadingIndicator.d.ts +1 -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 +2 -2
- package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
- package/dist/src/ui/hooks/useMemoryMonitor.d.ts +13 -0
- package/dist/src/ui/hooks/useMemoryMonitor.js +28 -0
- package/dist/src/ui/hooks/useMemoryMonitor.js.map +1 -0
- package/dist/src/ui/hooks/useMemoryMonitor.test.d.ts +6 -0
- package/dist/src/ui/hooks/useMemoryMonitor.test.js +57 -0
- package/dist/src/ui/hooks/useMemoryMonitor.test.js.map +1 -0
- package/dist/src/ui/hooks/useMessageQueue.d.ts +2 -1
- package/dist/src/ui/hooks/useMessageQueue.js +5 -3
- package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
- package/dist/src/ui/hooks/useMessageQueue.test.js +9 -0
- package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
- package/dist/src/ui/hooks/usePhraseCycler.d.ts +1 -1
- package/dist/src/ui/hooks/usePhraseCycler.js +11 -8
- package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
- package/dist/src/ui/hooks/usePrivacySettings.d.ts +1 -1
- package/dist/src/ui/hooks/usePrivacySettings.js +8 -13
- package/dist/src/ui/hooks/usePrivacySettings.js.map +1 -1
- package/dist/src/ui/hooks/usePrivacySettings.test.js +33 -97
- package/dist/src/ui/hooks/usePrivacySettings.test.js.map +1 -1
- package/dist/src/ui/hooks/useQuotaAndFallback.d.ts +21 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.js +122 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.js.map +1 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.d.ts +6 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.js +267 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.js.map +1 -0
- package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -2
- package/dist/src/ui/hooks/useReactToolScheduler.js +23 -17
- package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
- package/dist/src/ui/hooks/useReverseSearchCompletion.d.ts +1 -1
- package/dist/src/ui/hooks/useReverseSearchCompletion.js +67 -20
- package/dist/src/ui/hooks/useReverseSearchCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.d.ts +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.js +276 -67
- package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.test.d.ts +4 -1
- package/dist/src/ui/hooks/useSlashCompletion.test.js +357 -65
- package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
- package/dist/src/ui/hooks/useStateAndRef.d.ts +1 -1
- package/dist/src/ui/hooks/useStateAndRef.js +2 -2
- package/dist/src/ui/hooks/useStateAndRef.js.map +1 -1
- package/dist/src/ui/hooks/useThemeCommand.d.ts +1 -1
- package/dist/src/ui/hooks/useThemeCommand.js +3 -14
- package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.test.js +66 -61
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
- package/dist/src/ui/hooks/useWorkspaceMigration.js +2 -1
- package/dist/src/ui/hooks/useWorkspaceMigration.js.map +1 -1
- package/dist/src/ui/keyMatchers.test.js +17 -0
- package/dist/src/ui/keyMatchers.test.js.map +1 -1
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js +5 -5
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js +2 -2
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js +2 -2
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js.map +1 -1
- package/dist/src/ui/state/extensions.d.ts +14 -0
- package/dist/src/ui/state/extensions.js +16 -0
- package/dist/src/ui/state/extensions.js.map +1 -0
- package/dist/src/ui/themes/ayu.js +1 -1
- package/dist/src/ui/themes/dracula.js +2 -2
- package/dist/src/ui/themes/github-dark.js +1 -1
- package/dist/src/ui/themes/theme.js +17 -17
- package/dist/src/ui/themes/theme.js.map +1 -1
- package/dist/src/ui/types.d.ts +34 -3
- package/dist/src/ui/types.js +12 -0
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/ui/utils/CodeColorizer.js +3 -2
- package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
- package/dist/src/ui/utils/InlineMarkdownRenderer.js +7 -7
- package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.js +10 -10
- package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.test.js +6 -2
- package/dist/src/ui/utils/MarkdownDisplay.test.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.js +4 -4
- package/dist/src/ui/utils/TableRenderer.js.map +1 -1
- package/dist/src/ui/utils/clipboardUtils.js +5 -6
- package/dist/src/ui/utils/clipboardUtils.js.map +1 -1
- package/dist/src/ui/utils/displayUtils.js +4 -4
- package/dist/src/ui/utils/displayUtils.js.map +1 -1
- package/dist/src/ui/utils/highlight.d.ts +11 -0
- package/dist/src/ui/utils/highlight.js +78 -0
- package/dist/src/ui/utils/highlight.js.map +1 -0
- package/dist/src/ui/utils/highlight.test.d.ts +6 -0
- package/dist/src/ui/utils/highlight.test.js +120 -0
- package/dist/src/ui/utils/highlight.test.js.map +1 -0
- package/dist/src/ui/utils/kittyProtocolDetector.js +39 -29
- package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -1
- package/dist/src/ui/utils/platformConstants.d.ts +24 -1
- package/dist/src/ui/utils/platformConstants.js +26 -1
- package/dist/src/ui/utils/platformConstants.js.map +1 -1
- package/dist/src/ui/utils/textUtils.d.ts +9 -0
- package/dist/src/ui/utils/textUtils.js +52 -3
- package/dist/src/ui/utils/textUtils.js.map +1 -1
- package/dist/src/utils/commands.d.ts +20 -0
- package/dist/src/utils/commands.js +53 -0
- package/dist/src/utils/commands.js.map +1 -0
- package/dist/src/utils/commands.test.d.ts +6 -0
- package/dist/src/utils/commands.test.js +115 -0
- package/dist/src/utils/commands.test.js.map +1 -0
- package/dist/src/utils/commentJson.d.ts +9 -0
- package/dist/src/utils/commentJson.js +48 -0
- package/dist/src/utils/commentJson.js.map +1 -0
- package/dist/src/utils/commentJson.test.d.ts +6 -0
- package/dist/src/utils/commentJson.test.js +146 -0
- package/dist/src/utils/commentJson.test.js.map +1 -0
- package/dist/src/utils/deepMerge.d.ts +10 -0
- package/dist/src/utils/deepMerge.js +58 -0
- package/dist/src/utils/deepMerge.js.map +1 -0
- package/dist/src/utils/deepMerge.test.d.ts +6 -0
- package/dist/src/utils/deepMerge.test.js +143 -0
- package/dist/src/utils/deepMerge.test.js.map +1 -0
- package/dist/src/utils/envVarResolver.d.ts +39 -0
- package/dist/src/utils/envVarResolver.js +97 -0
- package/dist/src/utils/envVarResolver.js.map +1 -0
- package/dist/src/utils/envVarResolver.test.d.ts +6 -0
- package/dist/src/utils/envVarResolver.test.js +221 -0
- package/dist/src/utils/envVarResolver.test.js.map +1 -0
- package/dist/src/utils/errors.d.ts +21 -0
- package/dist/src/utils/errors.js +93 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/errors.test.d.ts +6 -0
- package/dist/src/utils/errors.test.js +303 -0
- package/dist/src/utils/errors.test.js.map +1 -0
- package/dist/src/utils/events.d.ts +2 -1
- package/dist/src/utils/events.js +1 -0
- package/dist/src/utils/events.js.map +1 -1
- package/dist/src/utils/processUtils.d.ts +13 -0
- package/dist/src/utils/processUtils.js +18 -0
- package/dist/src/utils/processUtils.js.map +1 -0
- package/dist/src/utils/processUtils.test.d.ts +6 -0
- package/dist/src/utils/processUtils.test.js +20 -0
- package/dist/src/utils/processUtils.test.js.map +1 -0
- package/dist/src/utils/sandbox.d.ts +1 -1
- package/dist/src/utils/sandbox.js +19 -8
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/utils/settingsUtils.d.ts +16 -6
- package/dist/src/utils/settingsUtils.js +35 -25
- package/dist/src/utils/settingsUtils.js.map +1 -1
- package/dist/src/utils/settingsUtils.test.js +455 -158
- package/dist/src/utils/settingsUtils.test.js.map +1 -1
- package/dist/src/utils/userStartupWarnings.d.ts +1 -1
- package/dist/src/utils/userStartupWarnings.js +1 -1
- package/dist/src/utils/userStartupWarnings.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.d.ts +2 -1
- package/dist/src/validateNonInterActiveAuth.js +33 -12
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/src/zed-integration/schema.d.ts +578 -578
- package/dist/src/zed-integration/zedIntegration.js +17 -12
- package/dist/src/zed-integration/zedIntegration.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/npm-shrinkwrap.json +17168 -0
- package/package.json +7 -8
- package/dist/google-gemini-cli-0.3.0-preview.3.tgz +0 -0
- package/dist/src/ui/components/AuthDialog.d.ts +0 -16
- package/dist/src/ui/components/AuthDialog.js +0 -92
- package/dist/src/ui/components/AuthDialog.js.map +0 -1
- package/dist/src/ui/components/AuthDialog.test.js +0 -276
- package/dist/src/ui/components/AuthDialog.test.js.map +0 -1
- package/dist/src/ui/components/AuthInProgress.js.map +0 -1
- package/dist/src/ui/hooks/useAuthCommand.d.ts +0 -14
- package/dist/src/ui/hooks/useAuthCommand.js +0 -66
- package/dist/src/ui/hooks/useAuthCommand.js.map +0 -1
- /package/dist/src/{ui/components/AuthDialog.test.d.ts → commands/extensions/examples/mcp-server/example.d.ts} +0 -0
- /package/dist/src/ui/{components → auth}/AuthInProgress.d.ts +0 -0
|
@@ -5,29 +5,37 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
7
7
|
import { act } from 'react';
|
|
8
|
-
import { renderHook } from '@testing-library/react';
|
|
8
|
+
import { renderHook, waitFor } from '@testing-library/react';
|
|
9
9
|
import { useGitBranchName } from './useGitBranchName.js';
|
|
10
10
|
import { fs, vol } from 'memfs'; // For mocking fs
|
|
11
|
-
import {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
vi.
|
|
11
|
+
import { spawnAsync as mockSpawnAsync } from '@google/gemini-cli-core';
|
|
12
|
+
// Mock @google/gemini-cli-core
|
|
13
|
+
vi.mock('@google/gemini-cli-core', async () => {
|
|
14
|
+
const original = await vi.importActual('@google/gemini-cli-core');
|
|
15
|
+
return {
|
|
16
|
+
...original,
|
|
17
|
+
spawnAsync: vi.fn(),
|
|
18
|
+
};
|
|
19
|
+
});
|
|
15
20
|
// Mock fs and fs/promises
|
|
16
21
|
vi.mock('node:fs', async () => {
|
|
17
22
|
const memfs = await vi.importActual('memfs');
|
|
18
|
-
return
|
|
23
|
+
return {
|
|
24
|
+
...memfs.fs,
|
|
25
|
+
default: memfs.fs,
|
|
26
|
+
};
|
|
19
27
|
});
|
|
20
28
|
vi.mock('node:fs/promises', async () => {
|
|
21
29
|
const memfs = await vi.importActual('memfs');
|
|
22
30
|
return memfs.fs.promises;
|
|
23
31
|
});
|
|
24
32
|
const CWD = '/test/project';
|
|
25
|
-
const
|
|
33
|
+
const GIT_LOGS_HEAD_PATH = `${CWD}/.git/logs/HEAD`;
|
|
26
34
|
describe('useGitBranchName', () => {
|
|
27
35
|
beforeEach(() => {
|
|
28
36
|
vol.reset(); // Reset in-memory filesystem
|
|
29
37
|
vol.fromJSON({
|
|
30
|
-
[
|
|
38
|
+
[GIT_LOGS_HEAD_PATH]: 'ref: refs/heads/main',
|
|
31
39
|
});
|
|
32
40
|
vi.useFakeTimers(); // Use fake timers for async operations
|
|
33
41
|
});
|
|
@@ -36,9 +44,8 @@ describe('useGitBranchName', () => {
|
|
|
36
44
|
vi.clearAllTimers();
|
|
37
45
|
});
|
|
38
46
|
it('should return branch name', async () => {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
return new EventEmitter();
|
|
47
|
+
mockSpawnAsync.mockResolvedValue({
|
|
48
|
+
stdout: 'main\n',
|
|
42
49
|
});
|
|
43
50
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
44
51
|
await act(async () => {
|
|
@@ -48,10 +55,7 @@ describe('useGitBranchName', () => {
|
|
|
48
55
|
expect(result.current).toBe('main');
|
|
49
56
|
});
|
|
50
57
|
it('should return undefined if git command fails', async () => {
|
|
51
|
-
|
|
52
|
-
callback?.(new Error('Git error'), '', 'error output');
|
|
53
|
-
return new EventEmitter();
|
|
54
|
-
});
|
|
58
|
+
mockSpawnAsync.mockRejectedValue(new Error('Git error'));
|
|
55
59
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
56
60
|
expect(result.current).toBeUndefined();
|
|
57
61
|
await act(async () => {
|
|
@@ -61,14 +65,14 @@ describe('useGitBranchName', () => {
|
|
|
61
65
|
expect(result.current).toBeUndefined();
|
|
62
66
|
});
|
|
63
67
|
it('should return short commit hash if branch is HEAD (detached state)', async () => {
|
|
64
|
-
|
|
65
|
-
if (
|
|
66
|
-
|
|
68
|
+
mockSpawnAsync.mockImplementation(async (command, args) => {
|
|
69
|
+
if (args.includes('--abbrev-ref')) {
|
|
70
|
+
return { stdout: 'HEAD\n' };
|
|
67
71
|
}
|
|
68
|
-
else if (
|
|
69
|
-
|
|
72
|
+
else if (args.includes('--short')) {
|
|
73
|
+
return { stdout: 'a1b2c3d\n' };
|
|
70
74
|
}
|
|
71
|
-
return
|
|
75
|
+
return { stdout: '' };
|
|
72
76
|
});
|
|
73
77
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
74
78
|
await act(async () => {
|
|
@@ -78,14 +82,14 @@ describe('useGitBranchName', () => {
|
|
|
78
82
|
expect(result.current).toBe('a1b2c3d');
|
|
79
83
|
});
|
|
80
84
|
it('should return undefined if branch is HEAD and getting commit hash fails', async () => {
|
|
81
|
-
|
|
82
|
-
if (
|
|
83
|
-
|
|
85
|
+
mockSpawnAsync.mockImplementation(async (command, args) => {
|
|
86
|
+
if (args.includes('--abbrev-ref')) {
|
|
87
|
+
return { stdout: 'HEAD\n' };
|
|
84
88
|
}
|
|
85
|
-
else if (
|
|
86
|
-
|
|
89
|
+
else if (args.includes('--short')) {
|
|
90
|
+
throw new Error('Git error');
|
|
87
91
|
}
|
|
88
|
-
return
|
|
92
|
+
return { stdout: '' };
|
|
89
93
|
});
|
|
90
94
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
91
95
|
await act(async () => {
|
|
@@ -96,36 +100,31 @@ describe('useGitBranchName', () => {
|
|
|
96
100
|
});
|
|
97
101
|
it('should update branch name when .git/HEAD changes', async ({ skip }) => {
|
|
98
102
|
skip(); // TODO: fix
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
});
|
|
103
|
+
mockSpawnAsync
|
|
104
|
+
.mockResolvedValueOnce({ stdout: 'main\n' })
|
|
105
|
+
.mockResolvedValueOnce({ stdout: 'develop\n' });
|
|
103
106
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
104
107
|
await act(async () => {
|
|
105
108
|
vi.runAllTimers();
|
|
106
109
|
rerender();
|
|
107
110
|
});
|
|
108
111
|
expect(result.current).toBe('main');
|
|
109
|
-
// Simulate a branch change
|
|
110
|
-
mockExec.mockImplementationOnce((_command, _options, callback) => {
|
|
111
|
-
callback?.(null, 'develop\n', '');
|
|
112
|
-
return new EventEmitter();
|
|
113
|
-
});
|
|
114
112
|
// Simulate file change event
|
|
115
113
|
// Ensure the watcher is set up before triggering the change
|
|
116
114
|
await act(async () => {
|
|
117
|
-
fs.writeFileSync(
|
|
115
|
+
fs.writeFileSync(GIT_LOGS_HEAD_PATH, 'ref: refs/heads/develop'); // Trigger watcher
|
|
118
116
|
vi.runAllTimers(); // Process timers for watcher and exec
|
|
119
117
|
rerender();
|
|
120
118
|
});
|
|
121
|
-
|
|
119
|
+
await waitFor(() => {
|
|
120
|
+
expect(result.current).toBe('develop');
|
|
121
|
+
});
|
|
122
122
|
});
|
|
123
123
|
it('should handle watcher setup error silently', async () => {
|
|
124
|
-
// Remove .git/HEAD to cause an error in fs.watch setup
|
|
125
|
-
vol.unlinkSync(
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
return new EventEmitter();
|
|
124
|
+
// Remove .git/logs/HEAD to cause an error in fs.watch setup
|
|
125
|
+
vol.unlinkSync(GIT_LOGS_HEAD_PATH);
|
|
126
|
+
mockSpawnAsync.mockResolvedValue({
|
|
127
|
+
stdout: 'main\n',
|
|
129
128
|
});
|
|
130
129
|
const { result, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
131
130
|
await act(async () => {
|
|
@@ -133,19 +132,17 @@ describe('useGitBranchName', () => {
|
|
|
133
132
|
rerender();
|
|
134
133
|
});
|
|
135
134
|
expect(result.current).toBe('main'); // Branch name should still be fetched initially
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
callback?.(null, 'develop\n', '');
|
|
139
|
-
return new EventEmitter();
|
|
135
|
+
mockSpawnAsync.mockResolvedValueOnce({
|
|
136
|
+
stdout: 'develop\n',
|
|
140
137
|
});
|
|
141
138
|
// This write would trigger the watcher if it was set up
|
|
142
139
|
// but since it failed, the branch name should not update
|
|
143
140
|
// We need to create the file again for writeFileSync to not throw
|
|
144
141
|
vol.fromJSON({
|
|
145
|
-
[
|
|
142
|
+
[GIT_LOGS_HEAD_PATH]: 'ref: refs/heads/develop',
|
|
146
143
|
});
|
|
147
144
|
await act(async () => {
|
|
148
|
-
fs.writeFileSync(
|
|
145
|
+
fs.writeFileSync(GIT_LOGS_HEAD_PATH, 'ref: refs/heads/develop');
|
|
149
146
|
vi.runAllTimers();
|
|
150
147
|
rerender();
|
|
151
148
|
});
|
|
@@ -158,9 +155,8 @@ describe('useGitBranchName', () => {
|
|
|
158
155
|
const watchMock = vi.spyOn(fs, 'watch').mockReturnValue({
|
|
159
156
|
close: closeMock,
|
|
160
157
|
});
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
return new EventEmitter();
|
|
158
|
+
mockSpawnAsync.mockResolvedValue({
|
|
159
|
+
stdout: 'main\n',
|
|
164
160
|
});
|
|
165
161
|
const { unmount, rerender } = renderHook(() => useGitBranchName(CWD));
|
|
166
162
|
await act(async () => {
|
|
@@ -168,7 +164,7 @@ describe('useGitBranchName', () => {
|
|
|
168
164
|
rerender();
|
|
169
165
|
});
|
|
170
166
|
unmount();
|
|
171
|
-
expect(watchMock).toHaveBeenCalledWith(
|
|
167
|
+
expect(watchMock).toHaveBeenCalledWith(GIT_LOGS_HEAD_PATH, expect.any(Function));
|
|
172
168
|
expect(closeMock).toHaveBeenCalled();
|
|
173
169
|
});
|
|
174
170
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useGitBranchName.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useGitBranchName.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"useGitBranchName.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useGitBranchName.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC,CAAC,iBAAiB;AAGlD,OAAO,EAAE,UAAU,IAAI,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEvE,+BAA+B;AAC/B,EAAE,CAAC,IAAI,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;IAC5C,MAAM,QAAQ,GAAG,MAAM,EAAE,CAAC,YAAY,CAEpC,yBAAyB,CAAC,CAAC;IAC7B,OAAO;QACL,GAAG,QAAQ;QACX,UAAU,EAAE,EAAE,CAAC,EAAE,EAAE;KACpB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,0BAA0B;AAC1B,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;IAC5B,MAAM,KAAK,GAAG,MAAM,EAAE,CAAC,YAAY,CAAyB,OAAO,CAAC,CAAC;IACrE,OAAO;QACL,GAAG,KAAK,CAAC,EAAE;QACX,OAAO,EAAE,KAAK,CAAC,EAAE;KAClB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,IAAI,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;IACrC,MAAM,KAAK,GAAG,MAAM,EAAE,CAAC,YAAY,CAAyB,OAAO,CAAC,CAAC;IACrE,OAAO,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC;AAC3B,CAAC,CAAC,CAAC;AAEH,MAAM,GAAG,GAAG,eAAe,CAAC;AAC5B,MAAM,kBAAkB,GAAG,GAAG,GAAG,iBAAiB,CAAC;AAEnD,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,UAAU,CAAC,GAAG,EAAE;QACd,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,6BAA6B;QAC1C,GAAG,CAAC,QAAQ,CAAC;YACX,CAAC,kBAAkB,CAAC,EAAE,sBAAsB;SAC7C,CAAC,CAAC;QACH,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC,uCAAuC;IAC7D,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,GAAG,EAAE;QACb,EAAE,CAAC,eAAe,EAAE,CAAC;QACrB,EAAE,CAAC,cAAc,EAAE,CAAC;IACtB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACxC,cAAwD,CAAC,iBAAiB,CACzE;YACE,MAAM,EAAE,QAAQ;SACqB,CACxC,CAAC;QACF,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QAErE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC,wDAAwD;YAC3E,QAAQ,EAAE,CAAC,CAAC,oCAAoC;QAClD,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC3D,cAAwD,CAAC,iBAAiB,CACzE,IAAI,KAAK,CAAC,WAAW,CAAC,CACvB,CAAC;QAEF,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QACrE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;QAEvC,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;QAEhF,cACD,CAAC,kBAAkB,CAAC,KAAK,EAAE,OAAe,EAAE,IAAc,EAAE,EAAE;YAC7D,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;gBAClC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAwC,CAAC;YACpE,CAAC;iBAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;gBACpC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAwC,CAAC;YACvE,CAAC;YACD,OAAO,EAAE,MAAM,EAAE,EAAE,EAAwC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QACrE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EAAE,KAAK,IAAI,EAAE;QAErF,cACD,CAAC,kBAAkB,CAAC,KAAK,EAAE,OAAe,EAAE,IAAc,EAAE,EAAE;YAC7D,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;gBAClC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAwC,CAAC;YACpE,CAAC;iBAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;gBACpC,MAAM,IAAI,KAAK,CAAC,WAAW,CAAC,CAAC;YAC/B,CAAC;YACD,OAAO,EAAE,MAAM,EAAE,EAAE,EAAwC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QACrE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;QACxE,IAAI,EAAE,CAAC,CAAC,YAAY;QACnB,cAAwD;aACtD,qBAAqB,CAAC,EAAE,MAAM,EAAE,QAAQ,EAGxC,CAAC;aACD,qBAAqB,CAAC,EAAE,MAAM,EAAE,WAAW,EAG3C,CAAC,CAAC;QAEL,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QAErE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEpC,6BAA6B;QAC7B,4DAA4D;QAC5D,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,aAAa,CAAC,kBAAkB,EAAE,yBAAyB,CAAC,CAAC,CAAC,kBAAkB;YACnF,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC,sCAAsC;YACzD,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QAEH,MAAM,OAAO,CAAC,GAAG,EAAE;YACjB,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,4DAA4D;QAC5D,GAAG,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;QAElC,cAAwD,CAAC,iBAAiB,CACzE;YACE,MAAM,EAAE,QAAQ;SACqB,CACxC,CAAC;QAEF,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QAErE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,gDAAgD;QAGnF,cACD,CAAC,qBAAqB,CAAC;YACtB,MAAM,EAAE,WAAW;SACkB,CAAC,CAAC;QAEzC,wDAAwD;QACxD,yDAAyD;QACzD,kEAAkE;QAClE,GAAG,CAAC,QAAQ,CAAC;YACX,CAAC,kBAAkB,CAAC,EAAE,yBAAyB;SAChD,CAAC,CAAC;QAEH,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,aAAa,CAAC,kBAAkB,EAAE,yBAAyB,CAAC,CAAC;YAChE,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QAEH,6DAA6D;QAC7D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;QACzD,IAAI,EAAE,CAAC,CAAC,YAAY;QACpB,MAAM,SAAS,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;QAC1B,MAAM,SAAS,GAAG,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC,eAAe,CAAC;YACtD,KAAK,EAAE,SAAS;SACO,CAAC,CAAC;QAE1B,cAAwD,CAAC,iBAAiB,CACzE;YACE,MAAM,EAAE,QAAQ;SACqB,CACxC,CAAC;QAEF,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC;QAEtE,MAAM,GAAG,CAAC,KAAK,IAAI,EAAE;YACnB,EAAE,CAAC,YAAY,EAAE,CAAC;YAClB,QAAQ,EAAE,CAAC;QACb,CAAC,CAAC,CAAC;QAEH,OAAO,EAAE,CAAC;QACV,MAAM,CAAC,SAAS,CAAC,CAAC,oBAAoB,CACpC,kBAAkB,EAClB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CACrB,CAAC;QACF,MAAM,CAAC,SAAS,CAAC,CAAC,gBAAgB,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* This hook listens for trust status updates from the IDE companion extension.
|
|
8
|
+
* It provides the current trust status from the IDE and a flag indicating
|
|
9
|
+
* if a restart is needed because the trust state has changed.
|
|
10
|
+
*/
|
|
11
|
+
export declare function useIdeTrustListener(): {
|
|
12
|
+
isIdeTrusted: boolean | undefined;
|
|
13
|
+
needsRestart: boolean;
|
|
14
|
+
};
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { useCallback, useEffect, useState, useSyncExternalStore } from 'react';
|
|
7
|
+
import { IdeClient, ideContextStore } from '@google/gemini-cli-core';
|
|
8
|
+
/**
|
|
9
|
+
* This hook listens for trust status updates from the IDE companion extension.
|
|
10
|
+
* It provides the current trust status from the IDE and a flag indicating
|
|
11
|
+
* if a restart is needed because the trust state has changed.
|
|
12
|
+
*/
|
|
13
|
+
export function useIdeTrustListener() {
|
|
14
|
+
const subscribe = useCallback((onStoreChange) => {
|
|
15
|
+
(async () => {
|
|
16
|
+
const ideClient = await IdeClient.getInstance();
|
|
17
|
+
ideClient.addTrustChangeListener(onStoreChange);
|
|
18
|
+
})();
|
|
19
|
+
return () => {
|
|
20
|
+
(async () => {
|
|
21
|
+
const ideClient = await IdeClient.getInstance();
|
|
22
|
+
ideClient.removeTrustChangeListener(onStoreChange);
|
|
23
|
+
})();
|
|
24
|
+
};
|
|
25
|
+
}, []);
|
|
26
|
+
const getSnapshot = () => ideContextStore.get()?.workspaceState?.isTrusted;
|
|
27
|
+
const isIdeTrusted = useSyncExternalStore(subscribe, getSnapshot);
|
|
28
|
+
const [needsRestart, setNeedsRestart] = useState(false);
|
|
29
|
+
const [initialTrustValue] = useState(isIdeTrusted);
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
if (!needsRestart &&
|
|
32
|
+
initialTrustValue !== undefined &&
|
|
33
|
+
initialTrustValue !== isIdeTrusted) {
|
|
34
|
+
setNeedsRestart(true);
|
|
35
|
+
}
|
|
36
|
+
}, [isIdeTrusted, initialTrustValue, needsRestart]);
|
|
37
|
+
return { isIdeTrusted, needsRestart };
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=useIdeTrustListener.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useIdeTrustListener.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useIdeTrustListener.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAErE;;;;GAIG;AACH,MAAM,UAAU,mBAAmB;IACjC,MAAM,SAAS,GAAG,WAAW,CAAC,CAAC,aAAyB,EAAE,EAAE;QAC1D,CAAC,KAAK,IAAI,EAAE;YACV,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,WAAW,EAAE,CAAC;YAChD,SAAS,CAAC,sBAAsB,CAAC,aAAa,CAAC,CAAC;QAClD,CAAC,CAAC,EAAE,CAAC;QACL,OAAO,GAAG,EAAE;YACV,CAAC,KAAK,IAAI,EAAE;gBACV,MAAM,SAAS,GAAG,MAAM,SAAS,CAAC,WAAW,EAAE,CAAC;gBAChD,SAAS,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC;YACrD,CAAC,CAAC,EAAE,CAAC;QACP,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,eAAe,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,SAAS,CAAC;IAE3E,MAAM,YAAY,GAAG,oBAAoB,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAElE,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,CAAC,iBAAiB,CAAC,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;IAEnD,SAAS,CAAC,GAAG,EAAE;QACb,IACE,CAAC,YAAY;YACb,iBAAiB,KAAK,SAAS;YAC/B,iBAAiB,KAAK,YAAY,EAClC,CAAC;YACD,eAAe,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;IACH,CAAC,EAAE,CAAC,YAAY,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC,CAAC;IAEpD,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
interface Logger {
|
|
7
|
+
getPreviousUserMessages(): Promise<string[]>;
|
|
8
|
+
}
|
|
9
|
+
export interface UseInputHistoryStoreReturn {
|
|
10
|
+
inputHistory: string[];
|
|
11
|
+
addInput: (input: string) => void;
|
|
12
|
+
initializeFromLogger: (logger: Logger | null) => Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Hook for independently managing input history.
|
|
16
|
+
* Completely separated from chat history and unaffected by /clear commands.
|
|
17
|
+
*/
|
|
18
|
+
export declare function useInputHistoryStore(): UseInputHistoryStoreReturn;
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { useState, useCallback } from 'react';
|
|
7
|
+
/**
|
|
8
|
+
* Hook for independently managing input history.
|
|
9
|
+
* Completely separated from chat history and unaffected by /clear commands.
|
|
10
|
+
*/
|
|
11
|
+
export function useInputHistoryStore() {
|
|
12
|
+
const [inputHistory, setInputHistory] = useState([]);
|
|
13
|
+
const [_pastSessionMessages, setPastSessionMessages] = useState([]);
|
|
14
|
+
const [_currentSessionMessages, setCurrentSessionMessages] = useState([]);
|
|
15
|
+
const [isInitialized, setIsInitialized] = useState(false);
|
|
16
|
+
/**
|
|
17
|
+
* Recalculate the complete input history from past and current sessions.
|
|
18
|
+
* Applies the same deduplication logic as the previous implementation.
|
|
19
|
+
*/
|
|
20
|
+
const recalculateHistory = useCallback((currentSession, pastSession) => {
|
|
21
|
+
// Combine current session (newest first) + past session (newest first)
|
|
22
|
+
const combinedMessages = [...currentSession, ...pastSession];
|
|
23
|
+
// Deduplicate consecutive identical messages (same algorithm as before)
|
|
24
|
+
const deduplicatedMessages = [];
|
|
25
|
+
if (combinedMessages.length > 0) {
|
|
26
|
+
deduplicatedMessages.push(combinedMessages[0]); // Add the newest one unconditionally
|
|
27
|
+
for (let i = 1; i < combinedMessages.length; i++) {
|
|
28
|
+
if (combinedMessages[i] !== combinedMessages[i - 1]) {
|
|
29
|
+
deduplicatedMessages.push(combinedMessages[i]);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Reverse to oldest first for useInputHistory
|
|
34
|
+
setInputHistory(deduplicatedMessages.reverse());
|
|
35
|
+
}, []);
|
|
36
|
+
/**
|
|
37
|
+
* Initialize input history from logger with past session data.
|
|
38
|
+
* Executed only once at app startup.
|
|
39
|
+
*/
|
|
40
|
+
const initializeFromLogger = useCallback(async (logger) => {
|
|
41
|
+
if (isInitialized || !logger)
|
|
42
|
+
return;
|
|
43
|
+
try {
|
|
44
|
+
const pastMessages = (await logger.getPreviousUserMessages()) || [];
|
|
45
|
+
setPastSessionMessages(pastMessages); // Store as newest first
|
|
46
|
+
recalculateHistory([], pastMessages);
|
|
47
|
+
setIsInitialized(true);
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
// Start with empty history even if logger initialization fails
|
|
51
|
+
console.warn('Failed to initialize input history from logger:', error);
|
|
52
|
+
setPastSessionMessages([]);
|
|
53
|
+
recalculateHistory([], []);
|
|
54
|
+
setIsInitialized(true);
|
|
55
|
+
}
|
|
56
|
+
}, [isInitialized, recalculateHistory]);
|
|
57
|
+
/**
|
|
58
|
+
* Add new input to history.
|
|
59
|
+
* Recalculates the entire history with deduplication.
|
|
60
|
+
*/
|
|
61
|
+
const addInput = useCallback((input) => {
|
|
62
|
+
const trimmedInput = input.trim();
|
|
63
|
+
if (!trimmedInput)
|
|
64
|
+
return; // Filter empty/whitespace-only inputs
|
|
65
|
+
setCurrentSessionMessages((prevCurrent) => {
|
|
66
|
+
const newCurrentSession = [...prevCurrent, trimmedInput];
|
|
67
|
+
setPastSessionMessages((prevPast) => {
|
|
68
|
+
recalculateHistory(newCurrentSession.slice().reverse(), // Convert to newest first
|
|
69
|
+
prevPast);
|
|
70
|
+
return prevPast; // No change to past messages
|
|
71
|
+
});
|
|
72
|
+
return newCurrentSession;
|
|
73
|
+
});
|
|
74
|
+
}, [recalculateHistory]);
|
|
75
|
+
return {
|
|
76
|
+
inputHistory,
|
|
77
|
+
addInput,
|
|
78
|
+
initializeFromLogger,
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=useInputHistoryStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useInputHistoryStore.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useInputHistoryStore.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AAY9C;;;GAGG;AACH,MAAM,UAAU,oBAAoB;IAClC,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IAC/D,MAAM,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IAC9E,MAAM,CAAC,uBAAuB,EAAE,yBAAyB,CAAC,GAAG,QAAQ,CAEnE,EAAE,CAAC,CAAC;IACN,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE1D;;;OAGG;IACH,MAAM,kBAAkB,GAAG,WAAW,CACpC,CAAC,cAAwB,EAAE,WAAqB,EAAE,EAAE;QAClD,uEAAuE;QACvE,MAAM,gBAAgB,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,WAAW,CAAC,CAAC;QAE7D,wEAAwE;QACxE,MAAM,oBAAoB,GAAa,EAAE,CAAC;QAC1C,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,oBAAoB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,qCAAqC;YACrF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjD,IAAI,gBAAgB,CAAC,CAAC,CAAC,KAAK,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBACpD,oBAAoB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;gBACjD,CAAC;YACH,CAAC;QACH,CAAC;QAED,8CAA8C;QAC9C,eAAe,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC,CAAC;IAClD,CAAC,EACD,EAAE,CACH,CAAC;IAEF;;;OAGG;IACH,MAAM,oBAAoB,GAAG,WAAW,CACtC,KAAK,EAAE,MAAqB,EAAE,EAAE;QAC9B,IAAI,aAAa,IAAI,CAAC,MAAM;YAAE,OAAO;QAErC,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,CAAC,MAAM,MAAM,CAAC,uBAAuB,EAAE,CAAC,IAAI,EAAE,CAAC;YACpE,sBAAsB,CAAC,YAAY,CAAC,CAAC,CAAC,wBAAwB;YAC9D,kBAAkB,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;YACrC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,+DAA+D;YAC/D,OAAO,CAAC,IAAI,CAAC,iDAAiD,EAAE,KAAK,CAAC,CAAC;YACvE,sBAAsB,CAAC,EAAE,CAAC,CAAC;YAC3B,kBAAkB,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAC3B,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;IACH,CAAC,EACD,CAAC,aAAa,EAAE,kBAAkB,CAAC,CACpC,CAAC;IAEF;;;OAGG;IACH,MAAM,QAAQ,GAAG,WAAW,CAC1B,CAAC,KAAa,EAAE,EAAE;QAChB,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,YAAY;YAAE,OAAO,CAAC,sCAAsC;QAEjE,yBAAyB,CAAC,CAAC,WAAW,EAAE,EAAE;YACxC,MAAM,iBAAiB,GAAG,CAAC,GAAG,WAAW,EAAE,YAAY,CAAC,CAAC;YAEzD,sBAAsB,CAAC,CAAC,QAAQ,EAAE,EAAE;gBAClC,kBAAkB,CAChB,iBAAiB,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,EAAE,0BAA0B;gBAC/D,QAAQ,CACT,CAAC;gBACF,OAAO,QAAQ,CAAC,CAAC,6BAA6B;YAChD,CAAC,CAAC,CAAC;YAEH,OAAO,iBAAiB,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC,EACD,CAAC,kBAAkB,CAAC,CACrB,CAAC;IAEF,OAAO;QACL,YAAY;QACZ,QAAQ;QACR,oBAAoB;KACrB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,234 @@
|
|
|
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 { vi, describe, it, expect, beforeEach } from 'vitest';
|
|
8
|
+
import { useInputHistoryStore } from './useInputHistoryStore.js';
|
|
9
|
+
describe('useInputHistoryStore', () => {
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
vi.clearAllMocks();
|
|
12
|
+
});
|
|
13
|
+
it('should initialize with empty input history', () => {
|
|
14
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
15
|
+
expect(result.current.inputHistory).toEqual([]);
|
|
16
|
+
});
|
|
17
|
+
it('should add input to history', () => {
|
|
18
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
19
|
+
act(() => {
|
|
20
|
+
result.current.addInput('test message 1');
|
|
21
|
+
});
|
|
22
|
+
expect(result.current.inputHistory).toEqual(['test message 1']);
|
|
23
|
+
act(() => {
|
|
24
|
+
result.current.addInput('test message 2');
|
|
25
|
+
});
|
|
26
|
+
expect(result.current.inputHistory).toEqual([
|
|
27
|
+
'test message 1',
|
|
28
|
+
'test message 2',
|
|
29
|
+
]);
|
|
30
|
+
});
|
|
31
|
+
it('should not add empty or whitespace-only inputs', () => {
|
|
32
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
33
|
+
act(() => {
|
|
34
|
+
result.current.addInput('');
|
|
35
|
+
});
|
|
36
|
+
expect(result.current.inputHistory).toEqual([]);
|
|
37
|
+
act(() => {
|
|
38
|
+
result.current.addInput(' ');
|
|
39
|
+
});
|
|
40
|
+
expect(result.current.inputHistory).toEqual([]);
|
|
41
|
+
});
|
|
42
|
+
it('should deduplicate consecutive identical messages', () => {
|
|
43
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
44
|
+
act(() => {
|
|
45
|
+
result.current.addInput('test message');
|
|
46
|
+
});
|
|
47
|
+
act(() => {
|
|
48
|
+
result.current.addInput('test message'); // Same as previous
|
|
49
|
+
});
|
|
50
|
+
expect(result.current.inputHistory).toEqual(['test message']);
|
|
51
|
+
act(() => {
|
|
52
|
+
result.current.addInput('different message');
|
|
53
|
+
});
|
|
54
|
+
act(() => {
|
|
55
|
+
result.current.addInput('test message'); // Same as first, but not consecutive
|
|
56
|
+
});
|
|
57
|
+
expect(result.current.inputHistory).toEqual([
|
|
58
|
+
'test message',
|
|
59
|
+
'different message',
|
|
60
|
+
'test message',
|
|
61
|
+
]);
|
|
62
|
+
});
|
|
63
|
+
it('should initialize from logger successfully', async () => {
|
|
64
|
+
const mockLogger = {
|
|
65
|
+
getPreviousUserMessages: vi
|
|
66
|
+
.fn()
|
|
67
|
+
.mockResolvedValue(['newest', 'middle', 'oldest']),
|
|
68
|
+
};
|
|
69
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
70
|
+
await act(async () => {
|
|
71
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
72
|
+
});
|
|
73
|
+
// Should reverse the order to oldest first
|
|
74
|
+
expect(result.current.inputHistory).toEqual(['oldest', 'middle', 'newest']);
|
|
75
|
+
expect(mockLogger.getPreviousUserMessages).toHaveBeenCalledTimes(1);
|
|
76
|
+
});
|
|
77
|
+
it('should handle logger initialization failure gracefully', async () => {
|
|
78
|
+
const mockLogger = {
|
|
79
|
+
getPreviousUserMessages: vi
|
|
80
|
+
.fn()
|
|
81
|
+
.mockRejectedValue(new Error('Logger error')),
|
|
82
|
+
};
|
|
83
|
+
const consoleSpy = vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
84
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
85
|
+
await act(async () => {
|
|
86
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
87
|
+
});
|
|
88
|
+
expect(result.current.inputHistory).toEqual([]);
|
|
89
|
+
expect(consoleSpy).toHaveBeenCalledWith('Failed to initialize input history from logger:', expect.any(Error));
|
|
90
|
+
consoleSpy.mockRestore();
|
|
91
|
+
});
|
|
92
|
+
it('should initialize only once', async () => {
|
|
93
|
+
const mockLogger = {
|
|
94
|
+
getPreviousUserMessages: vi
|
|
95
|
+
.fn()
|
|
96
|
+
.mockResolvedValue(['message1', 'message2']),
|
|
97
|
+
};
|
|
98
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
99
|
+
// Call initializeFromLogger twice
|
|
100
|
+
await act(async () => {
|
|
101
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
102
|
+
});
|
|
103
|
+
await act(async () => {
|
|
104
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
105
|
+
});
|
|
106
|
+
// Should be called only once
|
|
107
|
+
expect(mockLogger.getPreviousUserMessages).toHaveBeenCalledTimes(1);
|
|
108
|
+
expect(result.current.inputHistory).toEqual(['message2', 'message1']);
|
|
109
|
+
});
|
|
110
|
+
it('should handle null logger gracefully', async () => {
|
|
111
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
112
|
+
await act(async () => {
|
|
113
|
+
await result.current.initializeFromLogger(null);
|
|
114
|
+
});
|
|
115
|
+
expect(result.current.inputHistory).toEqual([]);
|
|
116
|
+
});
|
|
117
|
+
it('should trim input before adding to history', () => {
|
|
118
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
119
|
+
act(() => {
|
|
120
|
+
result.current.addInput(' test message ');
|
|
121
|
+
});
|
|
122
|
+
expect(result.current.inputHistory).toEqual(['test message']);
|
|
123
|
+
});
|
|
124
|
+
describe('deduplication logic from previous implementation', () => {
|
|
125
|
+
it('should deduplicate consecutive messages from past sessions during initialization', async () => {
|
|
126
|
+
const mockLogger = {
|
|
127
|
+
getPreviousUserMessages: vi
|
|
128
|
+
.fn()
|
|
129
|
+
.mockResolvedValue([
|
|
130
|
+
'message1',
|
|
131
|
+
'message1',
|
|
132
|
+
'message2',
|
|
133
|
+
'message2',
|
|
134
|
+
'message3',
|
|
135
|
+
]), // newest first with duplicates
|
|
136
|
+
};
|
|
137
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
138
|
+
await act(async () => {
|
|
139
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
140
|
+
});
|
|
141
|
+
// Should deduplicate consecutive messages and reverse to oldest first
|
|
142
|
+
expect(result.current.inputHistory).toEqual([
|
|
143
|
+
'message3',
|
|
144
|
+
'message2',
|
|
145
|
+
'message1',
|
|
146
|
+
]);
|
|
147
|
+
});
|
|
148
|
+
it('should deduplicate across session boundaries', async () => {
|
|
149
|
+
const mockLogger = {
|
|
150
|
+
getPreviousUserMessages: vi.fn().mockResolvedValue(['old2', 'old1']), // newest first
|
|
151
|
+
};
|
|
152
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
153
|
+
// Initialize with past session
|
|
154
|
+
await act(async () => {
|
|
155
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
156
|
+
});
|
|
157
|
+
// Add current session inputs
|
|
158
|
+
act(() => {
|
|
159
|
+
result.current.addInput('old2'); // Same as last past session message
|
|
160
|
+
});
|
|
161
|
+
// Should deduplicate across session boundary
|
|
162
|
+
expect(result.current.inputHistory).toEqual(['old1', 'old2']);
|
|
163
|
+
act(() => {
|
|
164
|
+
result.current.addInput('new1');
|
|
165
|
+
});
|
|
166
|
+
expect(result.current.inputHistory).toEqual(['old1', 'old2', 'new1']);
|
|
167
|
+
});
|
|
168
|
+
it('should preserve non-consecutive duplicates', async () => {
|
|
169
|
+
const mockLogger = {
|
|
170
|
+
getPreviousUserMessages: vi
|
|
171
|
+
.fn()
|
|
172
|
+
.mockResolvedValue(['message2', 'message1', 'message2']), // newest first with non-consecutive duplicate
|
|
173
|
+
};
|
|
174
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
175
|
+
await act(async () => {
|
|
176
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
177
|
+
});
|
|
178
|
+
// Non-consecutive duplicates should be preserved
|
|
179
|
+
expect(result.current.inputHistory).toEqual([
|
|
180
|
+
'message2',
|
|
181
|
+
'message1',
|
|
182
|
+
'message2',
|
|
183
|
+
]);
|
|
184
|
+
});
|
|
185
|
+
it('should handle complex deduplication with current session', () => {
|
|
186
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
187
|
+
// Add multiple messages with duplicates
|
|
188
|
+
act(() => {
|
|
189
|
+
result.current.addInput('hello');
|
|
190
|
+
});
|
|
191
|
+
act(() => {
|
|
192
|
+
result.current.addInput('hello'); // consecutive duplicate
|
|
193
|
+
});
|
|
194
|
+
act(() => {
|
|
195
|
+
result.current.addInput('world');
|
|
196
|
+
});
|
|
197
|
+
act(() => {
|
|
198
|
+
result.current.addInput('world'); // consecutive duplicate
|
|
199
|
+
});
|
|
200
|
+
act(() => {
|
|
201
|
+
result.current.addInput('hello'); // non-consecutive duplicate
|
|
202
|
+
});
|
|
203
|
+
// Should have deduplicated consecutive ones
|
|
204
|
+
expect(result.current.inputHistory).toEqual(['hello', 'world', 'hello']);
|
|
205
|
+
});
|
|
206
|
+
it('should maintain oldest-first order in final output', async () => {
|
|
207
|
+
const mockLogger = {
|
|
208
|
+
getPreviousUserMessages: vi
|
|
209
|
+
.fn()
|
|
210
|
+
.mockResolvedValue(['newest', 'middle', 'oldest']), // newest first
|
|
211
|
+
};
|
|
212
|
+
const { result } = renderHook(() => useInputHistoryStore());
|
|
213
|
+
await act(async () => {
|
|
214
|
+
await result.current.initializeFromLogger(mockLogger);
|
|
215
|
+
});
|
|
216
|
+
// Add current session messages
|
|
217
|
+
act(() => {
|
|
218
|
+
result.current.addInput('current1');
|
|
219
|
+
});
|
|
220
|
+
act(() => {
|
|
221
|
+
result.current.addInput('current2');
|
|
222
|
+
});
|
|
223
|
+
// Should maintain oldest-first order
|
|
224
|
+
expect(result.current.inputHistory).toEqual([
|
|
225
|
+
'oldest',
|
|
226
|
+
'middle',
|
|
227
|
+
'newest',
|
|
228
|
+
'current1',
|
|
229
|
+
'current2',
|
|
230
|
+
]);
|
|
231
|
+
});
|
|
232
|
+
});
|
|
233
|
+
});
|
|
234
|
+
//# sourceMappingURL=useInputHistoryStore.test.js.map
|