37 lines
957 B
TypeScript
37 lines
957 B
TypeScript
import Script from 'next/script'
|
|
|
|
import siteMetadata from '@/data/siteMetadata'
|
|
|
|
const GAScript = () => {
|
|
return (
|
|
<>
|
|
<Script
|
|
strategy="lazyOnload"
|
|
src={`https://www.googletagmanager.com/gtag/js?id=${siteMetadata.analytics.googleAnalyticsId}`}
|
|
/>
|
|
|
|
<Script strategy="lazyOnload" id="ga-script">
|
|
{`
|
|
window.dataLayer = window.dataLayer || [];
|
|
function gtag(){dataLayer.push(arguments);}
|
|
gtag('js', new Date());
|
|
gtag('config', '${siteMetadata.analytics.googleAnalyticsId}', {
|
|
page_path: window.location.pathname,
|
|
});
|
|
`}
|
|
</Script>
|
|
</>
|
|
)
|
|
}
|
|
|
|
export default GAScript
|
|
|
|
// https://developers.google.com/analytics/devguides/collection/gtagjs/events
|
|
export const logEvent = (action, category, label, value) => {
|
|
window.gtag?.('event', action, {
|
|
event_category: category,
|
|
event_label: label,
|
|
value: value,
|
|
})
|
|
}
|