all repos — caroster @ 1612fe42101ebc0ab86492e9e6c0ceed14c878d1

[Octree] Group carpool to your event https://caroster.io

frontend/pages/_app.tsx (view raw)

 1import {useEffect} from 'react';
 2import 'leaflet/dist/leaflet.css';
 3import '../public/leaflet_reset.css';
 4import Head from 'next/head';
 5import CssBaseline from '@mui/material/CssBaseline';
 6import {ThemeProvider, Theme} from '@mui/material/styles';
 7import {AppProps} from 'next/app';
 8import {appWithTranslation} from 'next-i18next';
 9import {ApolloProvider} from '@apollo/client';
10import {LocalizationProvider} from '@mui/x-date-pickers/LocalizationProvider';
11import {AdapterMoment} from '@mui/x-date-pickers/AdapterMoment';
12import {SessionProvider} from 'next-auth/react';
13import Metas from '../containers/Metas';
14import Toasts from '../components/Toasts';
15import theme from '../theme';
16import useLocale from '../hooks/useLocale';
17import {useApollo} from '../lib/apolloClient';
18import nextI18NextConfig from '../next-i18next.config.js';
19import moment from 'moment';
20import useTolgee from '../hooks/useTolgee';
21
22declare module '@mui/styles/defaultTheme' {
23  interface DefaultTheme extends Theme {}
24}
25
26const App = function (props: AppProps) {
27  const {Component, pageProps} = props;
28  const apolloClient = useApollo(pageProps);
29  const {locale} = useLocale();
30  useTolgee();
31
32  moment.locale(locale);
33
34  useEffect(() => {
35    // Remove the server-side injected CSS.
36    const jssStyles = document.querySelector('#jss-server-side');
37    if (jssStyles) {
38      jssStyles.parentElement!.removeChild(jssStyles);
39    }
40  }, []);
41
42  return (
43    <ApolloProvider client={apolloClient}>
44      <Metas metas={pageProps.metas} />
45      <ThemeProvider theme={theme}>
46        <LocalizationProvider
47          dateAdapter={AdapterMoment}
48          dateLibInstance={moment}
49          adapterLocale={locale}
50        >
51          <CssBaseline />
52          <Head>
53            <meta
54              name="viewport"
55              content="width=device-width, initial-scale=1, maximum-scale=1"
56            />
57          </Head>
58          <Component {...pageProps} />
59          <Toasts />
60        </LocalizationProvider>
61      </ThemeProvider>
62    </ApolloProvider>
63  );
64};
65
66const AppWrapper = (props: AppProps) => (
67  <SessionProvider session={props?.pageProps.session} basePath="/api/nauth">
68    <App {...props} />
69  </SessionProvider>
70);
71
72export default appWithTranslation(AppWrapper, nextI18NextConfig);