From 68a05f2a2173b9a185172c7c7907e8f2969a7774 Mon Sep 17 00:00:00 2001 From: Sucukdeluxe Date: Sat, 7 Mar 2026 00:55:39 +0100 Subject: [PATCH] Fix account settings save normalization --- src/renderer/App.tsx | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/src/renderer/App.tsx b/src/renderer/App.tsx index 73c62da..8d49473 100644 --- a/src/renderer/App.tsx +++ b/src/renderer/App.tsx @@ -329,6 +329,18 @@ function normalizeProviderOrderForSettings(settings: AppSettings): DebridProvide return ordered; } +function normalizeProviderSelectionForSettings( + settings: AppSettings +): Pick { + const providerOrder = normalizeProviderOrderForSettings(settings); + return { + providerOrder, + providerPrimary: providerOrder[0] ?? settings.providerPrimary, + providerSecondary: (providerOrder[1] ?? "none") as DebridFallbackProvider, + providerTertiary: (providerOrder[2] ?? "none") as DebridFallbackProvider + }; +} + function getConfiguredAccountKind(settings: AppSettings, service: AccountService): AccountKind | null { switch (service) { case "realdebrid": @@ -1599,11 +1611,8 @@ export function App(): ReactElement { const normalizedSettingsDraft: AppSettings = useMemo(() => ({ ...settingsDraft, - providerOrder: activeProviderOrder, - providerPrimary: activeProviderOrder[0] ?? settingsDraft.providerPrimary, - providerSecondary: (activeProviderOrder[1] ?? "none") as DebridFallbackProvider, - providerTertiary: (activeProviderOrder[2] ?? "none") as DebridFallbackProvider - }), [settingsDraft, activeProviderOrder]); + ...normalizeProviderSelectionForSettings(settingsDraft) + }), [settingsDraft]); const configuredAccounts = useMemo(() => { const entries: ConfiguredAccountEntry[] = [];