-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathgatsby-browser.tsx
77 lines (64 loc) · 2.62 KB
/
gatsby-browser.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/**
* Implement Gatsby's Browser APIs in this file.
*
* See: https://www.gatsbyjs.org/docs/browser-apis/
*/
// You can delete this file if you're not using it
import React from 'react'
import type { GatsbyBrowser } from 'gatsby'
import { GlobalStyle } from './src/styles/global'
import { registerGlobalMailtoClickHandler } from './src/report-mailto-click-to-google-analytics'
import { setupTrackingConsentInPixel } from './plugins/facebook-pixel/tracking-consent'
import { loadConsentDecision } from './src/analytics/local-storage-constants'
import { setupGtagTrackingConsent } from './plugins/google-gtag/tracking-consent'
import { setupTrackingConsentInHotjar } from './plugins/hotjar/tracking-consent'
import { setupTrackingConsentInLinkedIn } from './plugins/linkedin-pixel/tracking-consent'
import { CookieConsentContextWrapper } from './src/analytics/contextual-cookie-consent'
import { i18nForPageContext, withI18next } from './src/i18n'
import { setupTrackingConsentClarity } from './plugins/clarity/tracking-consent'
import { setupTrackingConsentMicrosoftAds } from './plugins/microsoft-ads/tracking-consent'
let nextRoute = ''
export const onPreRouteUpdate: GatsbyBrowser['onPreRouteUpdate'] = ({ location }) => {
nextRoute = location.pathname
}
window.addEventListener('unhandledrejection', event => {
if (/loading chunk \d* failed./i.test(event.reason)) {
if (nextRoute) {
window.location.pathname = nextRoute
}
}
})
export const wrapPageElement: GatsbyBrowser['wrapPageElement'] = ({ element, props: { pageContext } }) => {
return withI18next(i18nForPageContext(pageContext))(
<>
<GlobalStyle />
{element}
</>
)
}
export const wrapRootElement: GatsbyBrowser['wrapRootElement'] = ({ element }) => (
<CookieConsentContextWrapper>{element}</CookieConsentContextWrapper>
)
export const onInitialClientRender: GatsbyBrowser['onInitialClientRender'] = () => {
registerGlobalMailtoClickHandler()
}
export const onClientEntry: GatsbyBrowser['onClientEntry'] = () => {
setupGtagTrackingConsent({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
setupTrackingConsentInPixel({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
setupTrackingConsentInHotjar({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
setupTrackingConsentInLinkedIn({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
setupTrackingConsentClarity({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
setupTrackingConsentMicrosoftAds({
consentDecisionLoader: loadConsentDecision,
}).catch(console.error)
}