Skip to content

Commit

Permalink
PagePerformance: Delay log of page view/visit to include onload metric
Browse files Browse the repository at this point in the history
  • Loading branch information
rr-it committed Dec 17, 2024
1 parent 3e77fd8 commit 52831cd
Showing 1 changed file with 36 additions and 0 deletions.
36 changes: 36 additions & 0 deletions js/piwik.js
Original file line number Diff line number Diff line change
Expand Up @@ -4274,12 +4274,48 @@ if (typeof window.Matomo !== 'object') {

// append already available performance metrics if they were not already tracked (or appended)
if (configPerformanceTrackingEnabled && !performanceTracked) {
if (!performanceAvailable && supportsSendBeacon()) {
delayLogPageViewWithPerformanceMetrics(request, configTrackerPause, callback);
return;
}
request = appendAvailablePerformanceMetrics(request);
}

sendRequest(request, configTrackerPause, callback);
}

/*
* Delay log of page view / visit
* Wait until PerformanceMetrics are available or visitor leaves page.
*/
function delayLogPageViewWithPerformanceMetrics(request, configTrackerPause, callback) {
// - Ensure page view is only logged once.
// - Matomo context might change in the meantime: Store request in closure to ensure original context.
var logOnce = function() {
var store = { request: request, configTrackerPause: configTrackerPause, callback: callback};
var hasRunOnce = false;
return function() {
if (!hasRunOnce) {
hasRunOnce = true;
store.request = appendAvailablePerformanceMetrics(store.request);
sendRequest(store.request, store.configTrackerPause, store.callback);
}
};
}();

/* Performance metrics are available, once onload event has finished */
trackCallbackOnLoad(function(){
setTimeout(logOnce, 0);
});
/* Visitor leaves page */
addEventListener(windowAlias, 'visibilitychange', function () {
// if not visible
if (documentAlias.visibilityState === 'hidden') {
logOnce();
}
}, false);
}

/*
* Construct regular expression of classes
*/
Expand Down

0 comments on commit 52831cd

Please sign in to comment.