Commit 0ac1caa
authored
Issue LIF-Initiative#853: Add GA4 analytics instrumentation to Advisor and MDR frontends (LIF-Initiative#875)
##### Description of Change
Adds Google Analytics 4 (GA4) instrumentation to both the Advisor and
MDR frontends to provide visibility into who is visiting each app and
how features are being used.
**What problem does this solve?**
Neither frontend has any analytics — there is no visibility into visitor
traffic or feature usage.
**What is the solution?**
- A shared `analytics.ts` utility per frontend that conditionally loads
gtag.js when `VITE_GA_MEASUREMENT_ID` is set at build time
- Core event tracking calls added to key user actions in each app
- Dockerfile updates to accept the measurement ID as a build arg
**Advisor events (5):** `login`, `login_failed`, `conversation_started`,
`message_sent`, `logout`
**MDR events (5 + auto page_view):** `login`, `login_failed`,
`model_selected`, `search_performed`, `mapping_opened`
**Side effects / limitations:**
- No analytics traffic in local dev (env var unset = complete no-op)
- GA4 account/property/data streams must be created manually before
deploy
- No PII is sent in any event parameter
**How should reviewers test this?**
- Set `VITE_GA_MEASUREMENT_ID=G-XXXXXXXXXX` in a `.env.local` file and
run either frontend
- Verify gtag script loads in the browser network tab
- Verify events appear in GA4 DebugView (Realtime > DebugView)
- Confirm no gtag script or network requests when the env var is unset
##### Related Issues
Closes LIF-Initiative#853
Closes LIF-Initiative#867
##### Type of Change
- [x] New feature (non-breaking change which adds functionality)
- [x] Infrastructure/deployment change
##### Project Area(s) Affected
- [x] frontends/
---
##### Checklist
- [x] commit message follows commit guidelines (see
commitlint.config.mjs)
- [x] documentation is changed or added (in /docs directory)
- [x] pre-commit hooks have been run successfully
##### Testing
- [ ] Manual testing performed
- [ ] Automated tests added/updated
- [ ] Integration testing completed
##### Additional Notes
**Remaining manual steps before deploy:**
1. Create GA4 account, property, and two web data streams (Advisor +
MDR)
2. Add `GA_MEASUREMENT_ID` build arg to CI/CD or Docker build commands
3. Share GA4 property access (Unicon = Editor, client = Viewer)
See `docs/ga4-implementation-notes.md` and
`docs/proposals/ga-analytics-instrumentation.md` for the full design doc
and implementation notes.
🤖 Generated with [Claude Code](https://claude.com/claude-code)File tree
18 files changed
+146
-4
lines changed- .github/workflows
- frontends
- lif_advisor_app
- src
- components
- hooks
- utils
- mdr-frontend
- src
- components/DataModelSelector
- pages
- Explore
- Mappings
- utils
- scripts
18 files changed
+146
-4
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
57 | 57 | | |
58 | 58 | | |
59 | 59 | | |
| 60 | + | |
60 | 61 | | |
61 | 62 | | |
62 | 63 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
47 | 47 | | |
48 | 48 | | |
49 | 49 | | |
| 50 | + | |
50 | 51 | | |
51 | 52 | | |
52 | 53 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
4 | | - | |
| 4 | + | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
| 8 | + | |
7 | 9 | | |
8 | 10 | | |
9 | 11 | | |
| |||
15 | 17 | | |
16 | 18 | | |
17 | 19 | | |
18 | | - | |
| 20 | + | |
19 | 21 | | |
| 22 | + | |
20 | 23 | | |
21 | 24 | | |
22 | 25 | | |
| |||
Lines changed: 2 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
| 25 | + | |
24 | 26 | | |
25 | 27 | | |
26 | 28 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
40 | 41 | | |
41 | 42 | | |
42 | 43 | | |
| 44 | + | |
43 | 45 | | |
44 | 46 | | |
45 | 47 | | |
46 | 48 | | |
| 49 | + | |
47 | 50 | | |
48 | 51 | | |
49 | 52 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
81 | 82 | | |
82 | 83 | | |
83 | 84 | | |
| 85 | + | |
84 | 86 | | |
85 | 87 | | |
86 | 88 | | |
| |||
104 | 106 | | |
105 | 107 | | |
106 | 108 | | |
| 109 | + | |
107 | 110 | | |
108 | 111 | | |
109 | 112 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
| 2 | + | |
2 | 3 | | |
3 | 4 | | |
4 | 5 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
4 | | - | |
| 4 | + | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
| 8 | + | |
7 | 9 | | |
8 | 10 | | |
9 | 11 | | |
| |||
15 | 17 | | |
16 | 18 | | |
17 | 19 | | |
18 | | - | |
| 20 | + | |
19 | 21 | | |
| 22 | + | |
20 | 23 | | |
21 | 24 | | |
22 | 25 | | |
| |||
0 commit comments