Files
gemini-cli/packages/cli/src/ui/contexts/VimModeContext.tsx

60 lines
1.5 KiB
TypeScript
Raw Normal View History

2025-07-25 15:36:42 -07:00
/**
* @license
* Copyright 2025 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import { createContext, useCallback, useContext, useState } from 'react';
import { SettingScope } from '../../config/settings.js';
import { useSettingsStore } from './SettingsContext.js';
2025-07-25 15:36:42 -07:00
export type VimMode = 'NORMAL' | 'INSERT';
interface VimModeContextType {
vimEnabled: boolean;
vimMode: VimMode;
toggleVimEnabled: () => Promise<boolean>;
setVimMode: (mode: VimMode) => void;
}
const VimModeContext = createContext<VimModeContextType | undefined>(undefined);
export const VimModeProvider = ({
children,
}: {
children: React.ReactNode;
}) => {
const { settings, setSetting } = useSettingsStore();
const vimEnabled = settings.merged.general.vimMode;
const [vimMode, setVimMode] = useState<VimMode>('INSERT');
2025-07-25 15:36:42 -07:00
const toggleVimEnabled = useCallback(async () => {
const newValue = !vimEnabled;
// When enabling vim mode, start in INSERT mode
2025-07-25 15:36:42 -07:00
if (newValue) {
setVimMode('INSERT');
2025-07-25 15:36:42 -07:00
}
setSetting(SettingScope.User, 'general.vimMode', newValue);
2025-07-25 15:36:42 -07:00
return newValue;
}, [vimEnabled, setSetting]);
2025-07-25 15:36:42 -07:00
const value = {
vimEnabled,
vimMode,
toggleVimEnabled,
setVimMode,
};
return (
<VimModeContext.Provider value={value}>{children}</VimModeContext.Provider>
);
};
export const useVimMode = () => {
const context = useContext(VimModeContext);
if (context === undefined) {
throw new Error('useVimMode must be used within a VimModeProvider');
}
return context;
};