import { useEffect, useRef } from 'react'; import { useRouter } from 'next/router'; import { i18n } from '@lingui/core'; import { I18nProvider } from '@lingui/react'; import { AppPropsWithLayout } from '@ts/types/app'; import { initTranslation } from '@utils/helpers/i18n'; import '../styles/globals.scss'; import { ThemeProvider } from 'next-themes'; initTranslation(i18n); function MyApp({ Component, pageProps }: AppPropsWithLayout) { const router = useRouter(); const locale: string = router.locale || router.defaultLocale!; const firstRender = useRef(true); if (pageProps.translation && firstRender.current) { i18n.load(locale, pageProps.translation); i18n.activate(locale); firstRender.current = false; } useEffect(() => { if (pageProps.translation) { i18n.load(locale, pageProps.translation); i18n.activate(locale); } }, [locale, pageProps.translation]); const getLayout = Component.getLayout ?? ((page) => page); return ( {getLayout()} ); } export default MyApp; personal website.Armand Philippot
aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/Icons/Hamburger/Hamburger.tsx
blob: 9b39272bce6deed2d3e81e0b23c16fac077fb2ed (plain)
1
2
3
4
5
6
7
8
9
10