blob: 525335f043537890553f552a141182cf19961d0e (
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
43
44
45
46
47
48
49
50
51
52
53
|
import { useRouter } from 'next/router';
import { IntlProvider } from 'react-intl';
import '../styles/globals.scss';
import type { AppPropsWithLayout } from '../types';
import { CONFIG } from '../utils/config';
import { PRISM_THEME_ATTRIBUTE, STORAGE_KEY } from '../utils/constants';
import {
AckeeProvider,
MotionProvider,
PrismThemeProvider,
ThemeProvider,
} from '../utils/providers';
const App = ({ Component, pageProps }: AppPropsWithLayout) => {
const { locale, defaultLocale } = useRouter();
const appLocale: string = locale ?? CONFIG.locales.defaultLocale;
const getLayout = Component.getLayout ?? ((page) => page);
const { translation, ...componentProps } = pageProps;
return (
<AckeeProvider
domainId={CONFIG.ackee.siteId}
server={CONFIG.ackee.url}
storageKey={STORAGE_KEY.ACKEE}
tracking="full"
>
<MotionProvider
attribute={STORAGE_KEY.MOTION}
storageKey={STORAGE_KEY.MOTION}
>
<IntlProvider
locale={appLocale}
defaultLocale={defaultLocale}
messages={translation}
>
<ThemeProvider
attribute={STORAGE_KEY.THEME}
storageKey={STORAGE_KEY.THEME}
>
<PrismThemeProvider
attribute={PRISM_THEME_ATTRIBUTE}
storageKey={STORAGE_KEY.PRISM}
>
{getLayout(<Component {...componentProps} />, {})}
</PrismThemeProvider>
</ThemeProvider>
</IntlProvider>
</MotionProvider>
</AckeeProvider>
);
};
export default App;
|