summaryrefslogtreecommitdiffstats
path: root/src/pages/_app.tsx
blob: 7c6142c0d1d1c76228a62cfbf5f5fda4390d744d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import { AppPropsWithLayout } from '@ts/types/app';
import { settings } from '@utils/config';
import { ThemeProvider } from 'next-themes';
import { useRouter } from 'next/router';
import { IntlProvider } from 'react-intl';
import '../styles/globals.scss';

const MyApp = ({ Component, pageProps }: AppPropsWithLayout) => {
  const { locale, defaultLocale } = useRouter();
  const appLocale: string = locale || settings.locales.defaultLocale;

  const getLayout = Component.getLayout ?? ((page) => page);
  return (
    <IntlProvider
      locale={appLocale}
      defaultLocale={defaultLocale}
      messages={pageProps.translation}
    >
      <ThemeProvider
        defaultTheme="system"
        enableColorScheme={true}
        enableSystem={true}
      >
        {getLayout(<Component {...pageProps} />)}
      </ThemeProvider>
    </IntlProvider>
  );
};

export default MyApp;