fix(settings): persist restart-required changes when exiting with ESC (#12443)

This commit is contained in:
Shehab
2025-11-03 22:04:53 +02:00
committed by GitHub
parent 265f24e5d7
commit c4377c1b1a
@@ -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);
} }
} }