mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-05-12 12:54:07 -07:00
fix(settings): persist restart-required changes when exiting with ESC (#12443)
This commit is contained in:
@@ -453,6 +453,31 @@ export function SettingsDialog({
|
|||||||
const showScrollUp = items.length > effectiveMaxItemsToShow;
|
const showScrollUp = items.length > effectiveMaxItemsToShow;
|
||||||
const showScrollDown = items.length > effectiveMaxItemsToShow;
|
const showScrollDown = items.length > effectiveMaxItemsToShow;
|
||||||
|
|
||||||
|
const saveRestartRequiredSettings = () => {
|
||||||
|
const restartRequiredSettings =
|
||||||
|
getRestartRequiredFromModified(modifiedSettings);
|
||||||
|
const restartRequiredSet = new Set(restartRequiredSettings);
|
||||||
|
|
||||||
|
if (restartRequiredSet.size > 0) {
|
||||||
|
saveModifiedSettings(
|
||||||
|
restartRequiredSet,
|
||||||
|
pendingSettings,
|
||||||
|
settings,
|
||||||
|
selectedScope,
|
||||||
|
);
|
||||||
|
|
||||||
|
// Remove saved keys from global pending changes
|
||||||
|
setGlobalPendingChanges((prev) => {
|
||||||
|
if (prev.size === 0) return prev;
|
||||||
|
const next = new Map(prev);
|
||||||
|
for (const key of restartRequiredSet) {
|
||||||
|
next.delete(key);
|
||||||
|
}
|
||||||
|
return next;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
useKeypress(
|
useKeypress(
|
||||||
(key) => {
|
(key) => {
|
||||||
const { name, ctrl } = key;
|
const { name, ctrl } = key;
|
||||||
@@ -699,28 +724,7 @@ export function SettingsDialog({
|
|||||||
}
|
}
|
||||||
if (showRestartPrompt && name === 'r') {
|
if (showRestartPrompt && name === 'r') {
|
||||||
// Only save settings that require restart (non-restart settings were already saved immediately)
|
// Only save settings that require restart (non-restart settings were already saved immediately)
|
||||||
const restartRequiredSettings =
|
saveRestartRequiredSettings();
|
||||||
getRestartRequiredFromModified(modifiedSettings);
|
|
||||||
const restartRequiredSet = new Set(restartRequiredSettings);
|
|
||||||
|
|
||||||
if (restartRequiredSet.size > 0) {
|
|
||||||
saveModifiedSettings(
|
|
||||||
restartRequiredSet,
|
|
||||||
pendingSettings,
|
|
||||||
settings,
|
|
||||||
selectedScope,
|
|
||||||
);
|
|
||||||
|
|
||||||
// Remove saved keys from global pending changes
|
|
||||||
setGlobalPendingChanges((prev) => {
|
|
||||||
if (prev.size === 0) return prev;
|
|
||||||
const next = new Map(prev);
|
|
||||||
for (const key of restartRequiredSet) {
|
|
||||||
next.delete(key);
|
|
||||||
}
|
|
||||||
return next;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
setShowRestartPrompt(false);
|
setShowRestartPrompt(false);
|
||||||
setRestartRequiredSettings(new Set()); // Clear restart-required settings
|
setRestartRequiredSettings(new Set()); // Clear restart-required settings
|
||||||
@@ -730,6 +734,8 @@ export function SettingsDialog({
|
|||||||
if (editingKey) {
|
if (editingKey) {
|
||||||
commitEdit(editingKey);
|
commitEdit(editingKey);
|
||||||
} else {
|
} else {
|
||||||
|
// Save any restart-required settings before closing
|
||||||
|
saveRestartRequiredSettings();
|
||||||
onSelect(undefined, selectedScope);
|
onSelect(undefined, selectedScope);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user