From 1bd00c6632116dc00064445c4399cca18763125a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Sza=C5=82owski?= Date: Fri, 13 Dec 2024 17:00:37 +0100 Subject: [PATCH] feat: integrate matomo analytics --- CHANGELOG.md | 2 +- govtool/frontend/src/App.tsx | 2 ++ govtool/frontend/src/hooks/useMatomo.ts | 30 +++++++++++++++++++++++++ 3 files changed, 33 insertions(+), 1 deletion(-) create mode 100644 govtool/frontend/src/hooks/useMatomo.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index b9628fd1b..73a1b3168 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,7 +12,7 @@ changes. ### Added -- +- Integrate matomo analytics ### Fixed diff --git a/govtool/frontend/src/App.tsx b/govtool/frontend/src/App.tsx index 553d5295f..7745ceefb 100644 --- a/govtool/frontend/src/App.tsx +++ b/govtool/frontend/src/App.tsx @@ -39,8 +39,10 @@ import { import { PublicRoute } from "./pages/PublicRoute"; import { TopBanners } from "./components/organisms/TopBanners"; import { DashboardHome } from "./pages/DashboardHome"; +import { useMatomo } from "./hooks/useMatomo"; export default () => { + useMatomo(); const { isProposalDiscussionForumEnabled } = useFeatureFlag(); const { enable, isEnabled } = useCardano(); const navigate = useNavigate(); diff --git a/govtool/frontend/src/hooks/useMatomo.ts b/govtool/frontend/src/hooks/useMatomo.ts new file mode 100644 index 000000000..15a94db55 --- /dev/null +++ b/govtool/frontend/src/hooks/useMatomo.ts @@ -0,0 +1,30 @@ +/* eslint-disable func-names */ +/* eslint-disable no-multi-assign */ +/* eslint-disable prefer-template */ +/* eslint-disable no-underscore-dangle */ +/* eslint-disable wrap-iife */ +import { useEffect } from "react"; + +export const useMatomo = () => { + useEffect(() => { + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-expect-error + const _paq = (window._paq = window._pag || []); + _paq.push(["trackPageView"]); + _paq.push(["enableLinkTracking"]); + (function () { + const u = "//analytics.gov.tools/"; + _paq.push(["setTrackerUrl", u + "matomo.php"]); + _paq.push([ + "setSiteId", + import.meta.env.VITE_APP_ENV === "production" ? "1" : "2", + ]); + const d = document; + const g = d.createElement("script"); + const s = d.getElementsByTagName("script")[0]; + g.async = true; + g.src = u + "matomo.js"; + s.parentNode?.insertBefore(g, s); + })(); + }, []); +};