aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/_app.tsx
blob: 914b0b6b3c887ca4d22ec7ecab7ba3f4f2634531 (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
31
32
33
34
35
36
37
38
39
40
41
42
import { useRouter } from 'next/router';
import { ThemeProvider } from 'next-themes';
import { IntlProvider } from 'react-intl';
import '../styles/globals.scss';
import type { AppPropsWithLayout } from '../types';
import { settings } from '../utils/config';
import { STORAGE_KEY } from '../utils/constants';
import { AckeeProvider, PrismThemeProvider } from '../utils/providers';

const App = ({ Component, pageProps }: AppPropsWithLayout) => {
  const { locale, defaultLocale } = useRouter();
  const appLocale: string = locale ?? settings.locales.defaultLocale;
  const getLayout = Component.getLayout ?? ((page) => page);
  const { translation, ...componentProps } = pageProps;

  return (
    <AckeeProvider
      domainId={settings.ackee.siteId}
      server={settings.ackee.url}
      storageKey={STORAGE_KEY.ACKEE}
      tracking="full"
    >
      <IntlProvider
        locale={appLocale}
        defaultLocale={defaultLocale}
        messages={translation}
      >
        <ThemeProvider
          defaultTheme="system"
          enableColorScheme={true}
          enableSystem={true}
        >
          <PrismThemeProvider>
            {getLayout(<Component {...componentProps} />, {})}
          </PrismThemeProvider>
        </ThemeProvider>
      </IntlProvider>
    </AckeeProvider>
  );
};

export default App;