generated from AdobeDocs/dev-site-documentation-template
-
Notifications
You must be signed in to change notification settings - Fork 24
Expand file tree
/
Copy pathgatsby-browser.js
More file actions
70 lines (62 loc) · 2.45 KB
/
gatsby-browser.js
File metadata and controls
70 lines (62 loc) · 2.45 KB
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
/*
* Copyright 2020 Adobe. All rights reserved.
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
import React from 'react';
import { MDXProvider } from '@mdx-js/react';
import { Edition } from './src/@adobe/gatsby-theme-aio/components/Edition';
// Define the components that will be available in MDX files
const components = {
// Register the Edition component for inline use
Edition
};
// Wrap the root element with the MDXProvider
export const wrapRootElement = ({ element }) => {
return <MDXProvider components={components}>{element}</MDXProvider>;
};
const isBrowser = typeof window !== "undefined";
export const onClientEntry = () => {
// set adobe analytics window object
if (isBrowser) {
window._satellite = window._satellite || {};
window.alloy_all = window.alloy_all || {};
window.alloy_all.data = window.alloy_all.data || {};
window.alloy_all.data._adobe_corpnew = window.alloy_all.data._adobe_corpnew || {};
window.alloy_all.data._adobe_corpnew.web = window.alloy_all.data._adobe_corpnew.web || {};
window.alloy_all.data._adobe_corpnew.web.webPageDetails = window.alloy_all.data._adobe_corpnew.web.webPageDetails || {};
}
};
export const onRouteUpdate = ({ location, prevLocation }) => {
if (isBrowser) {
function watchAndFireAnalytics() {
// eslint-disable-next-line no-undef
if (typeof window._satellite !== 'undefined' && typeof window._satellite.track === 'function') {
// eslint-disable-next-line no-undef
_satellite.track('state',
{
xdm: {},
data: {
_adobe_corpnew: {
web: {
webPageDetails: {
customPageName: location.href
}
}
}
}
}
);
clearInterval(intervalId);
}
}
// watch if analytics is online then track page
const intervalId = setInterval(watchAndFireAnalytics, 1000);
}
}