1
0
mirror of https://github.com/kremalicious/gatsby-plugin-matomo.git synced 2025-01-03 10:25:00 +01:00

capture and send custom page title

* workaround to delay page tracking until react-helmet is finished updating document.title
* closes #11
This commit is contained in:
Matthias Kretschmann 2019-03-30 17:09:23 +01:00
parent 7b7f4783a6
commit aedb80684f
Signed by: m
GPG Key ID: 606EEEF3C479A91F
2 changed files with 30 additions and 17 deletions

View File

@ -16,15 +16,40 @@ function getDuration() {
exports.onRouteUpdate = ({ location, prevLocation }) => { exports.onRouteUpdate = ({ location, prevLocation }) => {
if (process.env.NODE_ENV === 'production' && typeof _paq !== 'undefined' || window.dev === true) { if (process.env.NODE_ENV === 'production' && typeof _paq !== 'undefined' || window.dev === true) {
window._paq = window._paq || [] const _paq = window._paq || []
window.dev = window.dev || null const dev = window.dev || null
const url = location.pathname + location.search + location.hash const url = location.pathname + location.search + location.hash
const prevUrl = prevLocation && prevLocation.pathname + prevLocation.search + prevLocation.hash const prevUrl = prevLocation && prevLocation.pathname + prevLocation.search + prevLocation.hash
// document.title workaround stolen from:
// https://github.com/gatsbyjs/gatsby/blob/master/packages/gatsby-plugin-google-analytics/src/gatsby-browser.js
const sendPageView = () => {
const { title } = document
prevUrl && _paq.push(['setReferrerUrl', prevUrl])
_paq.push(['setCustomUrl', url])
_paq.push(['setDocumentTitle', title])
_paq.push(['trackPageView'])
_paq.push(['enableLinkTracking'])
if (dev) {
console.log(`[Matomo] Page view for: ${url} - ${title}`)
}
}
if ('requestAnimationFrame' in window) {
requestAnimationFrame(() => {
requestAnimationFrame(sendPageView)
})
} else {
// simulate 2 rAF calls
setTimeout(sendPageView, 32)
}
if (first) { if (first) {
first = false first = false
window._paq.push([ _paq.push([
'trackEvent', 'trackEvent',
'javascript', 'javascript',
'load', 'load',
@ -32,18 +57,8 @@ exports.onRouteUpdate = ({ location, prevLocation }) => {
getDuration() getDuration()
]) ])
if (window.dev) { if (dev) {
console.log(`[Matomo] Page view for: ${url}`) console.log(`[Matomo] Tracking duration for: ${url}`)
}
} else {
window._paq.push(['setReferrerUrl', prevUrl])
window._paq.push(['setCustomUrl', url])
window._paq.push(['setDocumentTitle', url])
window._paq.push(['trackPageView'])
window._paq.push(['enableLinkTracking'])
if (window.dev) {
console.log(`[Matomo] Page view for: ${url}`)
} }
} }
} }

View File

@ -13,8 +13,6 @@ function buildTrackingCode(pluginOptions) {
${pluginOptions.disableCookies ? 'window._paq.push([\'disableCookies\']);' : ''} ${pluginOptions.disableCookies ? 'window._paq.push([\'disableCookies\']);' : ''}
window._paq.push(['setTrackerUrl', '${pluginOptions.matomoUrl}/piwik.php']); window._paq.push(['setTrackerUrl', '${pluginOptions.matomoUrl}/piwik.php']);
window._paq.push(['setSiteId', '${pluginOptions.siteId}']); window._paq.push(['setSiteId', '${pluginOptions.siteId}']);
window._paq.push(['trackPageView']);
window._paq.push(['enableLinkTracking']);
window._paq.push(['enableHeartBeatTimer']); window._paq.push(['enableHeartBeatTimer']);
window.start = new Date(); window.start = new Date();