This guide will help you to set up Matomo, Google Analytics or other analytics tools with Lychee.
⚠️ Make sure to use your actual values for domain and siteId
Set the following env vars:
SECURITY_HEADER_SCRIPT_SRC_ALLOW=https://analytics.example.com/matomo.js
SECURITY_HEADER_CSP_CONNECT_SRC=https://analytics.example.com/matomo.js
Add the following to Settings > Advanced Customization
var _paq = window._paq = window._paq || [];
_paq.push(['trackPageView']);
_paq.push(['enableLinkTracking']);
(function () {
var u = "https://analytics.example.com/";
_paq.push(['setTrackerUrl', u + 'matomo.php']);
_paq.push(['setSiteId', '<site-id>']);
var d = document, g = d.createElement('script'), s = d.getElementsByTagName('script')[0];
g.async = true;
g.src = u + 'matomo.js';
s.parentNode.insertBefore(g, s);
})();
navigation.addEventListener("navigate", function (e) {
_paq.push(['setDocumentTitle', document.title]);
_paq.push(['trackPageView']);
});
⚠️ Make sure to use your actual domain
Set the following env vars:
SECURITY_HEADER_SCRIPT_SRC_ALLOW=https://analytics.example.com
SECURITY_HEADER_CSP_CONNECT_SRC=https://analytics.example.com/script.js
Add the following to Settings > Advanced Customization
const script = document.createElement('script');
script.setAttribute('defer', true);
script.setAttribute('src', 'https://analytics.example.com/script.js');
document.body.appendChild(script);
⚠️ Make sure to replace <your-tracking-id> with the actual value
Set the following env vars:
SECURITY_HEADER_SCRIPT_SRC_ALLOW=https://www.googletagmanager.com/gtag/js?id=<your-tracking-id>
SECURITY_HEADER_CSP_CONNECT_SRC=https://www.googletagmanager.com/gtag/js?id=<your-tracking-id>
Add the following to Settings > Advanced Customization
(function () {
var u = "https://www.googletagmanager.com/gtag/js";
var d = document, g = d.createElement('script'), s = d.getElementsByTagName('script')[0];
g.async = true;
g.src = u + '?id=<your-tracking-id>';
s.parentNode.insertBefore(g, s);
})();
window.dataLayer = window.dataLayer || [];
function gtag(){
dataLayer.push(arguments);
}
function trackPageView() {
gtag('event', 'page_view', {
page_title: document.title,
page_location: window.location
});
}
gtag('js', new Date());
gtag('config', '<your-tracking-id>', {
send_page_view: false
});
trackPageView();
navigation.addEventListener("navigate", function (e) {
trackPageView()
});
⚠️ Make sure to use your actual values for DOMAIN SCRIPT URL and
Set the following env vars:
SECURITY_HEADER_SCRIPT_SRC_ALLOW=https://umami.example.com/script.js
SECURITY_HEADER_CSP_CONNECT_SRC=https://umami.example.com/script.js
Add the following to Settings > Advanced Customization
(function() {
var d = document, s = d.createElement('script'), g = d.getElementsByTagName('script')[0];
s.defer = true;
s.src = 'https://umami.example.com/script.js';
s.setAttribute('data-website-id', '<WEBSITE_ID>');
g.parentNode.insertBefore(s, g);
})();
navigation.addEventListener("navigate", function (e) {
if (window.umami && typeof umami.trackView === 'function') {
umami.trackView(document.title, window.location.pathname);
}
});
To make the frontend load the tracking script you need to change two environment variables:
CSP: srcript-src
CSP: connect-src
Add your custom tracking code to Settings > Custom JS
As Lychee uses history based routing you need to track page changes on the navigate event
like this:
navigation.addEventListener("navigate", function (e) {
// track page logic goes here
});
{tip} Caught a mistake or want to contribute to the documentation? Edit this page on Github!