This is a guide on how to prepare event tracking when creating a new page or redesigning an existing page.
Events are user interactions on the application that standard pageviews cannot track within a session. We create custom code snippets in the application in order to trigger these events.
Events are useful for measuring user engagement on the website. Tracking events lets us know when users interact with elements and forms and can help us understand how successful users are at accomplishing their goals.
Event tracking is a great way to validate our design decisions and assumptions. We can create reports in Matomo to gather insights and improve our product.
View the Matomo guide on event tracking.
ethereum.org uses Matomo, an open-source alternative to Google Analytics, allowing us to protect user privacy by not sharing any analytics with third parties.
We implemented Matomo using the JavaScript tracking client via the @socialgouv/matomo-next
package.
Ideally, ask yourself what design decision/assumptions have been made on the page and should/could be validated by measured performance:
- clicks
- downloads
- site searches
- popups viewed/dismissed
- form fields abandoned
- scroll behavior down a page
This data can be later used to decide whether a feature is being used or is underperforming.
It's helpful to ask yourself how the results of what we track and measure might influence our decision-making. For example, measuring something that won't help us make concrete product decisions is probably not worth tracking.
Broadly, events should be grouped by specific topic (e.g. L2 page external links, selected bridge, selected cex).
- Category (other events may share the same category if one feature has several actions)
- Action
- Name (optional)
- Value (optional, can be number or text)
Please consider the page's visual position when deciding which events should be grouped together (under the same category). Ideally, all events related to one feature should be grouped together under the same category only if there is also a single position on the page where the event can be triggered. If in doubt, always use a different category when a feature gets used in multiple places on the page.
Example: Find wallets page redirects to external links (wallets) in two positions: A) through the main list of wallets B) Through a modal window with detailed info about a specific wallet. In this case, we would like to have two separate categories for external links instead of one:
- Matomo list view
- Category: WalletExternalLinkList
- Action: Go to wallet
- eventName: WalletName
- Value: position
- Matomo modal view
- Category: WalletExternalLinkModal
- Action: Go to wallet
- eventName: WalletName
- Value: position
Such division allows us to identify where a user clicked on the page precisely; if all external links were under one category, "ExternalLink", we would not be able to measure the performance difference between the list and the modal window.
Ethereum.org has a utility function (trackCustomEvent
) for easily creating Matomo events.
import { trackCustomEvent } from "../utils/matomo"
The function requires an object of event options. See the example below.
const handleEvent = (): void => {
trackCustomEvent({
eventCategory: `FeedbackWidget toggled`,
eventAction: `Clicked`,
eventName: `Opened feedback widget`,
eventValue: `1`,
})
}
Hidden gem of tracking: Value
Can be used to get more info on the UX.
Examples:
- Use it to track the average position of clicked search result
- What terms are entered into the search field
- Which option is chosen from a dropdown menu
- How many or what filters are applied when filtering the list of wallets