Files
NotionNext/pages/_app.js
tangly1024 43de0a80d4 feature:
Google Adsense
2021-12-17 21:03:20 +08:00

47 lines
1.5 KiB
JavaScript

import BLOG from 'blog.config'
import 'animate.css'
import '@/styles/notion.css'
import '@/styles/globals.css'
import 'rc-dropdown/assets/index.css'
import 'prismjs/themes/prism-okaidia.css'
import 'katex/dist/katex.min.css'
import dynamic from 'next/dynamic'
import { GlobalContextProvider, handleRouteChange } from '@/lib/global'
import { useEffect } from 'react'
import { useRouter } from 'next/router'
import { config } from '@fortawesome/fontawesome-svg-core'
import '@fortawesome/fontawesome-svg-core/styles.css'
config.autoAddCss = false
const Ackee = dynamic(() => import('@/components/Ackee'), { ssr: false })
const Gtag = dynamic(() => import('@/components/Gtag'), { ssr: false })
const MyApp = ({ Component, pageProps }) => {
// 全局监听路由变化
const router = useRouter()
useEffect(() => {
handleRouteChange(router.pathname)
const routerListener = (url) => {
handleRouteChange(url)
}
router.events.on('routeChangeComplete', routerListener)
return () => {
router.events.off('routeChangeComplete', routerListener)
}
})
return (
<GlobalContextProvider>
{BLOG.isProd && BLOG?.analytics?.provider === 'ackee' && (
<Ackee
ackeeServerUrl={BLOG.analytics.ackeeConfig.dataAckeeServer}
ackeeDomainId={BLOG.analytics.ackeeConfig.domainId}
/>
)}
{BLOG.isProd && BLOG?.analytics?.provider === 'ga' && <Gtag />}
<Component {...pageProps} />
</GlobalContextProvider>
)
}
export default MyApp