refactor: optimize PreferencesContext by using useCallback for fetchPreferences and removing unnecessary state management
This commit is contained in:
@@ -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 {
|
||||||
|
|||||||
Reference in New Issue
Block a user