2020-01-18 00:18:09 +00:00
|
|
|
import './style.css'
|
|
|
|
import App from 'next/app'
|
|
|
|
import NProgress from 'nprogress'
|
|
|
|
import Router from 'next/router'
|
|
|
|
import DefaultHeadTags from '../components/default-head-tags'
|
|
|
|
import ProductSubnav from '../components/subnav'
|
|
|
|
import MegaNav from '@hashicorp/react-mega-nav'
|
|
|
|
import Footer from '@hashicorp/react-footer'
|
|
|
|
import { ConsentManager, open } from '@hashicorp/react-consent-manager'
|
|
|
|
import consentManagerConfig from '../lib/consent-manager-config'
|
|
|
|
import bugsnagClient from '../lib/bugsnag'
|
|
|
|
import Error from './_error'
|
|
|
|
|
|
|
|
Router.events.on('routeChangeStart', NProgress.start)
|
|
|
|
Router.events.on('routeChangeError', NProgress.done)
|
|
|
|
Router.events.on('routeChangeComplete', url => {
|
|
|
|
setTimeout(() => window.analytics.page(url), 0)
|
|
|
|
NProgress.done()
|
|
|
|
})
|
|
|
|
|
|
|
|
// Bugsnag
|
|
|
|
const ErrorBoundary = bugsnagClient.getPlugin('react')
|
|
|
|
|
|
|
|
class NextApp extends App {
|
|
|
|
static async getInitialProps({ Component, ctx }) {
|
|
|
|
let pageProps = {}
|
|
|
|
|
|
|
|
if (Component.getInitialProps) {
|
|
|
|
pageProps = await Component.getInitialProps(ctx)
|
|
|
|
} else if (Component.isMDXComponent) {
|
|
|
|
// fix for https://github.com/mdx-js/mdx/issues/382
|
|
|
|
const mdxLayoutComponent = Component({}).props.originalType
|
|
|
|
if (mdxLayoutComponent.getInitialProps) {
|
|
|
|
pageProps = await mdxLayoutComponent.getInitialProps(ctx)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-13 17:00:18 +00:00
|
|
|
return { pageProps }
|
2020-01-18 00:18:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2020-03-13 17:00:18 +00:00
|
|
|
const { Component, pageProps } = this.props
|
2020-01-18 00:18:09 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<ErrorBoundary FallbackComponent={Error}>
|
|
|
|
<DefaultHeadTags />
|
|
|
|
<MegaNav product="Vault" />
|
2020-03-13 17:00:18 +00:00
|
|
|
<ProductSubnav />
|
2020-01-18 00:18:09 +00:00
|
|
|
<Component {...pageProps} />
|
|
|
|
<Footer openConsentManager={open} />
|
|
|
|
<ConsentManager {...consentManagerConfig} />
|
|
|
|
</ErrorBoundary>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default NextApp
|