icns-frontend/pages/_app.tsx

165 lines
4.9 KiB
TypeScript
Raw Normal View History

2022-12-17 13:40:07 +00:00
import * as amplitude from "@amplitude/analytics-browser";
2022-11-30 10:36:59 +00:00
import type { AppProps } from "next/app";
2022-12-17 09:37:14 +00:00
import Head from "next/head";
2022-12-16 09:14:47 +00:00
import { useRouter } from "next/router";
2022-12-17 13:40:07 +00:00
import React, { useEffect, useMemo } from "react";
2022-12-16 09:14:47 +00:00
import { DefaultTheme, ThemeProvider } from "styled-components";
2022-12-14 15:39:51 +00:00
import ErrorBoundary from "../components/error-boundary";
2022-12-18 12:58:39 +00:00
import color from "../styles/color";
import { GlobalStyle } from "../styles/global";
2022-12-16 09:14:47 +00:00
// Tooltip default style.
import "react-tooltip/dist/react-tooltip.css";
2022-12-16 09:14:47 +00:00
const homePageTheme: DefaultTheme = {
2022-12-18 12:58:39 +00:00
bgColor: color.black,
bgGridColor: color.grey["600"],
2022-12-16 09:14:47 +00:00
};
const defaultPageTheme: DefaultTheme = {
2022-12-18 12:58:39 +00:00
bgColor: "#0B0B0B",
bgGridColor: color.grey["900"],
2022-12-16 09:14:47 +00:00
};
2022-11-30 08:11:45 +00:00
2022-12-17 13:40:07 +00:00
if (process.env.NEXT_PUBLIC_AMPLITUDE_API_KEY !== undefined) {
amplitude.init(process.env.NEXT_PUBLIC_AMPLITUDE_API_KEY);
}
2022-11-30 08:11:45 +00:00
export default function App({ Component, pageProps }: AppProps) {
2022-12-16 09:14:47 +00:00
const router = useRouter();
const pageTheme = useMemo(() => {
return router.pathname === "/" ? homePageTheme : defaultPageTheme;
}, [router.pathname]);
2022-12-17 09:37:14 +00:00
const origin = typeof window !== "undefined" ? window.location.origin : "";
2022-12-17 13:40:07 +00:00
useEffect(() => {
const handleRouteChangeComplete = (url: string) => {
const pathname = url.split("?")[0];
2022-12-17 14:45:50 +00:00
amplitude.track("view page", {
2022-12-17 13:40:07 +00:00
pathname,
});
};
handleRouteChangeComplete(router.pathname);
router.events.on("routeChangeStart", handleRouteChangeComplete);
// If the component is unmounted, unsubscribe
// from the event with the `off` method:
return () => {
router.events.off("routeChangeComplete", handleRouteChangeComplete);
};
}, []);
return (
2022-12-16 09:14:47 +00:00
<ThemeProvider theme={pageTheme}>
2022-12-17 09:37:14 +00:00
<Head>
<title>Interchain Name Service</title>
<meta content="Interchain Name Service" property="og:title" />
2022-12-20 18:53:46 +00:00
<meta content="Interchain Name Service" name="twitter:title" />
2022-12-17 09:37:14 +00:00
<meta
content="Your identity for the Interchain. Claim yours today."
property="og:description"
/>
<meta
content="Your identity for the Interchain. Claim yours today."
property="twitter:description"
/>
<meta name="viewport" content="initial-scale=1.0, width=device-width" />
2022-12-20 18:53:46 +00:00
<meta content={`${origin}/images/og-image.jpg`} name="twitter:image" />
<meta content={`ICNS image`} name="twitter:image:alt" />
2022-12-20 18:41:45 +00:00
<meta content={`${origin}/images/og-image.jpg`} property="og:image" />
2022-12-17 09:37:14 +00:00
<meta content="summary_large_image" name="twitter:card" />
<meta property="og:type" content="website" />
{/* generated favicons */}
<link
rel="apple-touch-icon"
sizes="57x57"
href="/images/favicon/apple-icon-57x57.png"
/>
<link
rel="apple-touch-icon"
sizes="60x60"
href="/images/favicon/apple-icon-60x60.png"
/>
<link
rel="apple-touch-icon"
sizes="72x72"
href="/images/favicon/apple-icon-72x72.png"
/>
<link
rel="apple-touch-icon"
sizes="76x76"
href="/images/favicon/apple-icon-76x76.png"
/>
<link
rel="apple-touch-icon"
sizes="114x114"
href="/images/favicon/apple-icon-114x114.png"
/>
<link
rel="apple-touch-icon"
sizes="120x120"
href="/images/favicon/apple-icon-120x120.png"
/>
<link
rel="apple-touch-icon"
sizes="144x144"
href="/images/favicon/apple-icon-144x144.png"
/>
<link
rel="apple-touch-icon"
sizes="152x152"
href="/images/favicon/apple-icon-152x152.png"
/>
<link
rel="apple-touch-icon"
sizes="180x180"
href="/images/favicon/apple-icon-180x180.png"
/>
<link
rel="icon"
type="image/png"
sizes="192x192"
href="/images/favicon/android-icon-192x192.png"
/>
<link
rel="icon"
type="image/png"
sizes="32x32"
href="/images/favicon/favicon-32x32.png"
/>
<link
rel="icon"
type="image/png"
sizes="96x96"
href="/images/favicon/favicon-96x96.png"
/>
<link
rel="icon"
type="image/png"
sizes="16x16"
href="/images/favicon/favicon-16x16.png"
/>
<link rel="manifest" href="/images/favicon/manifest.json" />
<meta name="msapplication-TileColor" content="#ffffff" />
<meta
name="msapplication-TileImage"
content="/images/favicon/ms-icon-144x144.png"
/>
<meta name="theme-color" content="#ffffff" />
</Head>
<React.Fragment>
<GlobalStyle />
<ErrorBoundary>
2022-12-16 09:21:35 +00:00
<Component {...pageProps} />
</ErrorBoundary>
</React.Fragment>
</ThemeProvider>
);
2022-11-30 08:11:45 +00:00
}