Files
TheGame/packages/web/pages/_app.tsx
Mano bebe182b78 ga analytics merge to develop (#633)
* added analytics

* added analytics snippet

* Reworked GA addition implementation

Co-authored-by: Alec LaLonde <alec@convergencelabs.com>
2021-06-13 23:57:34 -06:00

54 lines
1.5 KiB
TypeScript

/* eslint-disable react/no-danger */
import { ChakraProvider, CSSReset, MetaTheme } from '@metafam/ds';
import { MobileFooter } from 'components/MobileFooter';
import { PageHeader } from 'components/PageHeader';
import { CONFIG } from 'config';
import { Web3ContextProvider } from 'contexts/Web3Context';
import Head from 'next/head';
import { WithUrqlProps } from 'next-urql';
import React from 'react';
import { wrapUrqlClient } from '../graphql/client';
const App: React.FC<WithUrqlProps> = ({
pageProps,
resetUrqlClient,
Component,
}) => (
<ChakraProvider theme={MetaTheme}>
<CSSReset />
<Head>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>MetaGame</title>
{CONFIG.gaId != null && (
<>
<script
async
src={`https://www.googletagmanager.com/gtag/js?id=${CONFIG.gaId}`}
/>
<script
dangerouslySetInnerHTML={{
__html: `
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments)}
gtag('js', new Date());
gtag('config', '${CONFIG.gaId}');
`,
}}
/>
</>
)}
</Head>
<Web3ContextProvider resetUrqlClient={resetUrqlClient}>
<>
{!pageProps.hideAppDrawer && <PageHeader />}
{!pageProps.hideAppDrawer && <MobileFooter />}
<Component {...pageProps} />
</>
</Web3ContextProvider>
</ChakraProvider>
);
export default wrapUrqlClient(App);