From b8dbfaaed083734b05a28a05bf100941dc673ea7 Mon Sep 17 00:00:00 2001 From: Fallenbagel <98979876+Fallenbagel@users.noreply.github.com> Date: Fri, 10 Jan 2025 07:05:13 +0800 Subject: [PATCH] fix(setup): plex library setting validation (#1233) * fix(setup): plex library setting validation * fix(setup): fixes plex continue button and scroll-to-top when clicked issue in setup --- src/components/Settings/SettingsPlex.tsx | 8 +-- src/components/Setup/index.tsx | 79 +++++++++++------------- 2 files changed, 41 insertions(+), 46 deletions(-) diff --git a/src/components/Settings/SettingsPlex.tsx b/src/components/Settings/SettingsPlex.tsx index 82cabe92f..780dc0eef 100644 --- a/src/components/Settings/SettingsPlex.tsx +++ b/src/components/Settings/SettingsPlex.tsx @@ -350,6 +350,10 @@ const SettingsPlex = ({ onComplete }: SettingsPlexProps) => { ); if (!res.ok) throw new Error(); } + + if (onComplete) { + onComplete(); + } setIsSyncing(false); revalidate(); }; @@ -435,10 +439,6 @@ const SettingsPlex = ({ onComplete }: SettingsPlexProps) => { autoDismiss: true, appearance: 'success', }); - - if (onComplete) { - onComplete(); - } } catch (e) { if (toastId) { removeToast(toastId); diff --git a/src/components/Setup/index.tsx b/src/components/Setup/index.tsx index 1217b655f..6995fa825 100644 --- a/src/components/Setup/index.tsx +++ b/src/components/Setup/index.tsx @@ -97,63 +97,58 @@ const Setup = () => { settings.currentSettings.mediaServerType !== MediaServerType.NOT_CONFIGURED ) { - setCurrentStep(3); setMediaServerType(settings.currentSettings.mediaServerType); + if (currentStep < 3) { + setCurrentStep(3); + } } if (currentStep === 3) { - const validateLibraries = async () => { - try { - const endpoint = - settings.currentSettings.mediaServerType === - MediaServerType.JELLYFIN || MediaServerType.EMBY - ? '/api/v1/settings/jellyfin' - : '/api/v1/settings/plex'; - - const res = await fetch(endpoint); - if (!res.ok) throw new Error('Fetch failed'); - const data = await res.json(); - - const hasEnabledLibraries = data?.libraries?.some( - (library: Library) => library.enabled - ); - - setMediaServerSettingsComplete(hasEnabledLibraries); - if (hasEnabledLibraries) { - localStorage.setItem('mediaServerSettingsComplete', 'true'); - } else { - localStorage.removeItem('mediaServerSettingsComplete'); - } - } catch (e) { - toasts.addToast(intl.formatMessage(messages.librarieserror), { - autoDismiss: true, - appearance: 'error', - }); - - setMediaServerSettingsComplete(false); - localStorage.removeItem('mediaServerSettingsComplete'); - } - }; - validateLibraries(); - } else { - // Initialize from localStorage on mount - const storedState = - localStorage.getItem('mediaServerSettingsComplete') === 'true'; - setMediaServerSettingsComplete(storedState); } }, [ settings.currentSettings.mediaServerType, settings.currentSettings.initialized, router, - currentStep, toasts, intl, + currentStep, + mediaServerType, ]); + const validateLibraries = async () => { + try { + const endpointMap: Record = { + [MediaServerType.JELLYFIN]: '/api/v1/settings/jellyfin', + [MediaServerType.EMBY]: '/api/v1/settings/jellyfin', + [MediaServerType.PLEX]: '/api/v1/settings/plex', + [MediaServerType.NOT_CONFIGURED]: '', + }; + + const endpoint = endpointMap[mediaServerType]; + if (!endpoint) return; + + const res = await fetch(endpoint); + if (!res.ok) throw new Error('Fetch failed'); + const data = await res.json(); + + const hasEnabledLibraries = data?.libraries?.some( + (library: Library) => library.enabled + ); + + setMediaServerSettingsComplete(hasEnabledLibraries); + } catch (e) { + toasts.addToast(intl.formatMessage(messages.librarieserror), { + autoDismiss: true, + appearance: 'error', + }); + + setMediaServerSettingsComplete(false); + } + }; + const handleComplete = () => { - setMediaServerSettingsComplete(true); - localStorage.setItem('mediaServerSettingsComplete', 'true'); + validateLibraries(); }; if (settings.currentSettings.initialized) return <>;