import {useEffect} from 'react'; import {AppProps} from 'next/app'; import {ApolloProvider} from '@apollo/client'; import {ThemeProvider} from '@material-ui/core/styles'; import CssBaseline from '@material-ui/core/CssBaseline'; import {MuiPickersUtilsProvider} from '@material-ui/pickers'; import moment from 'moment'; import MomentUtils from '@date-io/moment'; import {useApollo} from '../lib/apolloClient'; import {Enum_Userspermissionsuser_Lang} from '../generated/graphql'; import useLangStore from '../stores/useLangStore'; import Metas from '../containers/Metas'; import Toasts from '../components/Toasts'; import theme from '../theme'; import 'moment/locale/fr-ch'; import {useTranslation} from 'react-i18next'; import useAuthStore from '../stores/useAuthStore'; import {getUserLng} from '../i18n'; moment.locale('fr-ch'); const App = function (props: AppProps) { const {Component, pageProps} = props; const apolloClient = useApollo(pageProps); const user = useAuthStore(); const {i18n} = useTranslation(); const language = useLangStore(s => s.language); const setLanguage = useLangStore(s => s.setLanguage); useEffect(() => { setLanguage(getUserLng()); }, []); useEffect(() => { const languageProfile = user?.lang ?? language; const momentLang = languageProfile === 'FR' ? 'fr-ch' : 'en'; moment.locale(momentLang); i18n.changeLanguage(languageProfile?.toLowerCase()); }, [language, user?.lang]); useEffect(() => { // Remove the server-side injected CSS. const jssStyles = document.querySelector('#jss-server-side'); if (jssStyles) { jssStyles.parentElement!.removeChild(jssStyles); } }, []); return ( ); }; export default App;