manifold/web/pages/_app.tsx

95 lines
3.2 KiB
TypeScript
Raw Normal View History

import 'tailwindcss/tailwind.css'
import type { AppProps } from 'next/app'
import { useEffect } from 'react'
2021-12-16 04:52:07 +00:00
import Head from 'next/head'
import Script from 'next/script'
import { QueryClient, QueryClientProvider } from 'react-query'
2022-09-22 19:46:48 +00:00
import { AuthProvider, AuthUser } from 'web/components/auth-context'
import Welcome from 'web/components/onboarding/welcome'
function firstLine(msg: string) {
return msg.replace(/\r?\n.*/s, '')
}
function printBuildInfo() {
// These are undefined if e.g. dev server
if (process.env.NEXT_PUBLIC_VERCEL_ENV) {
const env = process.env.NEXT_PUBLIC_VERCEL_ENV
const msg = process.env.NEXT_PUBLIC_VERCEL_GIT_COMMIT_MESSAGE
const owner = process.env.NEXT_PUBLIC_VERCEL_GIT_REPO_OWNER
const repo = process.env.NEXT_PUBLIC_VERCEL_GIT_REPO_SLUG
const sha = process.env.NEXT_PUBLIC_VERCEL_GIT_COMMIT_SHA
const url = `https://github.com/${owner}/${repo}/commit/${sha}`
console.info(`Build: ${env} / ${firstLine(msg || '???')} / ${url}`)
}
}
2022-09-22 19:46:48 +00:00
// specially treated props that may be present in the server/static props
type ManifoldPageProps = { auth?: AuthUser }
function MyApp({ Component, pageProps }: AppProps<ManifoldPageProps>) {
2022-05-13 18:33:02 +00:00
useEffect(printBuildInfo, [])
2021-12-16 04:52:07 +00:00
return (
<>
<Script src="https://www.googletagmanager.com/gtag/js?id=G-SSFK1Q138D" />
<Script id="google-analytics">
{`
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-SSFK1Q138D');
`}
</Script>
2021-12-16 04:52:07 +00:00
<Head>
<title>{'Manifold Markets — A market for every question'}</title>
2021-12-16 04:52:07 +00:00
<meta
property="og:title"
name="twitter:title"
2022-04-06 18:20:16 +00:00
content="Manifold Markets — A market for every question"
2021-12-16 04:52:07 +00:00
key="title"
/>
<meta
name="description"
2022-04-06 18:20:16 +00:00
content="Manifold Markets lets you create a market on any question. Sign up in 30 seconds and start trading on politics, sports, or anything that interests you."
2021-12-16 18:40:23 +00:00
key="description1"
2021-12-16 04:52:07 +00:00
/>
<meta
property="og:description"
name="twitter:description"
2022-04-06 18:20:16 +00:00
content="Manifold Markets lets you create a market on any question. Sign up in 30 seconds and start trading on politics, sports, or anything that interests you."
2021-12-16 18:40:23 +00:00
key="description2"
2021-12-16 04:52:07 +00:00
/>
<meta property="og:url" content="https://manifold.markets" key="url" />
<meta name="twitter:card" content="summary" key="card" />
<meta name="twitter:site" content="@manifoldmarkets" />
2021-12-16 04:52:07 +00:00
<meta
property="og:image"
content="https://manifold.markets/logo-cover.png"
key="image1"
2022-01-07 03:54:11 +00:00
/>
<meta
2021-12-16 04:52:07 +00:00
name="twitter:image"
content="https://manifold.markets/logo-bg-white.png"
key="image2"
2021-12-16 04:52:07 +00:00
/>
<meta
name="viewport"
content="width=device-width, initial-scale=1, maximum-scale=1"
/>
2021-12-16 04:52:07 +00:00
</Head>
2022-08-12 20:45:38 +00:00
<AuthProvider serverUser={pageProps.auth}>
<QueryClientProvider client={queryClient}>
2022-09-22 19:46:48 +00:00
<Welcome />
<Component {...pageProps} />
</QueryClientProvider>
</AuthProvider>
2021-12-16 04:52:07 +00:00
</>
)
}
const queryClient = new QueryClient()
export default MyApp