refactor: optimize PreferencesContext by using useCallback for fetchPreferences and removing unnecessary state management

This commit is contained in:
Julien Froidefond
2025-10-26 07:10:25 +01:00
parent 8b34bb5ebb
commit 82a5817918

View File

@@ -28,9 +28,8 @@ export function PreferencesProvider({
initialPreferences || defaultPreferences initialPreferences || defaultPreferences
); );
const [isLoading, setIsLoading] = useState(false); const [isLoading, setIsLoading] = useState(false);
const [hasLoadedPrefs, setHasLoadedPrefs] = useState(!!initialPreferences);
const fetchPreferences = async () => { const fetchPreferences = useCallback(async () => {
try { try {
const response = await fetch("/api/preferences"); const response = await fetch("/api/preferences");
if (!response.ok) { if (!response.ok) {
@@ -41,25 +40,25 @@ export function PreferencesProvider({
...defaultPreferences, ...defaultPreferences,
...data, ...data,
}); });
setHasLoadedPrefs(true);
} catch (error) { } catch (error) {
logger.error({ err: error }, "Erreur lors de la récupération des préférences"); logger.error({ err: error }, "Erreur lors de la récupération des préférences");
setPreferences(defaultPreferences); setPreferences(defaultPreferences);
} finally { } finally {
setIsLoading(false); setIsLoading(false);
} }
}; }, []);
useEffect(() => { useEffect(() => {
// Recharger les préférences quand la session change (connexion/déconnexion) // Recharger les préférences quand la session change (connexion/déconnexion)
if (status === "authenticated" && !hasLoadedPrefs) { if (status === "authenticated") {
// Toujours recharger depuis l'API pour avoir les dernières valeurs
// même si on a des initialPreferences (qui peuvent être en cache)
fetchPreferences(); fetchPreferences();
} else if (status === "unauthenticated") { } else if (status === "unauthenticated") {
// Réinitialiser aux préférences par défaut quand l'utilisateur se déconnecte // Réinitialiser aux préférences par défaut quand l'utilisateur se déconnecte
setPreferences(defaultPreferences); setPreferences(defaultPreferences);
setHasLoadedPrefs(false);
} }
}, [status, hasLoadedPrefs]); }, [status, fetchPreferences]);
const updatePreferences = useCallback(async (newPreferences: Partial<UserPreferences>) => { const updatePreferences = useCallback(async (newPreferences: Partial<UserPreferences>) => {
try { try {