mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-29 07:53:23 +00:00
fix: On attend que la session soit mise à jour pour intiialiser le
contexte
This commit is contained in:
@ -1,21 +1,22 @@
|
|||||||
import React, { createContext, useContext, useState, useEffect } from 'react';
|
import React, { createContext, useContext, useState, useEffect } from 'react';
|
||||||
import { getSession } from 'next-auth/react';
|
import { useSession } from 'next-auth/react';
|
||||||
import logger from '@/utils/logger';
|
import logger from '@/utils/logger';
|
||||||
|
|
||||||
const EstablishmentContext = createContext();
|
const EstablishmentContext = createContext();
|
||||||
|
|
||||||
export const EstablishmentProvider = ({ children }) => {
|
export const EstablishmentProvider = ({ children }) => {
|
||||||
|
const { data: session, status } = useSession();
|
||||||
const [selectedEstablishmentId, setSelectedEstablishmentId] = useState(null);
|
const [selectedEstablishmentId, setSelectedEstablishmentId] = useState(null);
|
||||||
const [profileRole, setProfileRole] = useState(null);
|
const [profileRole, setProfileRole] = useState(null);
|
||||||
const [establishments, setEstablishments] = useState([]);
|
const [establishments, setEstablishments] = useState([]);
|
||||||
const [user, setUser] = useState(null);
|
const [user, setUser] = useState(null);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
getSession()
|
if (status === 'loading') return; // Attendre que le statut de la session soit défini
|
||||||
.then(session => {
|
|
||||||
if (session && session.user) {
|
if (session && session.user) {
|
||||||
setUser(session.user);
|
setUser(session.user);
|
||||||
console.log("getSession")
|
console.log("getSession");
|
||||||
const userEstablishments = session.user.roles.map(role => ({
|
const userEstablishments = session.user.roles.map(role => ({
|
||||||
id: role.establishment__id,
|
id: role.establishment__id,
|
||||||
name: role.establishment__name,
|
name: role.establishment__name,
|
||||||
@ -28,11 +29,7 @@ export const EstablishmentProvider = ({ children }) => {
|
|||||||
setProfileRole(userEstablishments[0].role_type);
|
setProfileRole(userEstablishments[0].role_type);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}, [session, status]);
|
||||||
.catch(err => {
|
|
||||||
logger.error('Error fetching session:', err);
|
|
||||||
});
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<EstablishmentContext.Provider value={{ selectedEstablishmentId, setSelectedEstablishmentId, profileRole, setProfileRole, establishments, user }}>
|
<EstablishmentContext.Provider value={{ selectedEstablishmentId, setSelectedEstablishmentId, profileRole, setProfileRole, establishments, user }}>
|
||||||
|
|||||||
Reference in New Issue
Block a user