-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathgatsby-browser.js
78 lines (66 loc) · 2.14 KB
/
gatsby-browser.js
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
78
/**
* Implement Gatsby's Browser APIs in this file.
*
* See: https://www.gatsbyjs.org/docs/browser-apis/
*/
import './src/styles/index.scss';
import 'uswds';
import { siteMetadata } from './gatsby-config';
let loaded = false;
const digitalAnalytics = (pathname) => {
window.gas && window.gas('send', 'pageview', pathname);
};
const googleAnalytics = (pathname) => {
window.ga && window.ga('send', 'pageview', pathname);
};
const loadScript = (src, onLoad, attrs = {}) =>
new Promise((resolve) => {
const script = document.createElement('script');
script.src = src;
Object.assign(script, attrs);
script.onload = () => {
onLoad();
resolve();
};
document.body.appendChild(script);
});
export const onInitialClientRender = () => {
const { dap, ga } = siteMetadata;
const { pathname } = window.location;
const scripts = [];
if (dap && dap.agency) {
let src = `https://dap.digitalgov.gov/Universal-Federated-Analytics-Min.js?agency=${dap.agency}`;
if (dap.subagency) {
src += `&subagency=${dap.subagency}`;
}
const onLoad = () => digitalAnalytics(pathname);
scripts.push(loadScript(src, onLoad, { id: '_fed_an_ua_tag' }));
}
if (ga && ga.ua) {
const src = `https://www.googletagmanager.com/gtag/js?id=${ga.ua}`;
const onLoad = () => googleAnalytics(pathname);
scripts.push(loadScript(src, onLoad));
/**
* `forceSSL` was used for analytics.js (the older Google Analytics script).
* It isn't documented for gtag.js, but the term occurs in the gtag.js code;
* figure it doesn't hurt to leave it in. -@afeld, 5/29/19
*/
const gtag = document.createElement('script');
gtag.text = `
window.dataLayer = window.dataLayer || [];
function gtag() { dataLayer.push(arguments); }
gtag('js', new Date());
gtag('config', '${ga.ua}', { 'anonymize_ip': true, 'forceSSL': true });
`;
document.body.appendChild(gtag);
}
Promise.all(scripts).then(() => {
loaded = true;
});
};
export const onRouteUpdate = ({ location }) => {
if (loaded) {
digitalAnalytics(location.pathname);
googleAnalytics(location.pathname);
}
};