mkdocs-material/docs/setup/setting-up-site-analytics.md

193 lines
5.6 KiB
Markdown
Raw Normal View History

2020-07-22 09:54:17 +02:00
---
template: overrides/main.html
---
# Setting up site analytics
2020-07-26 14:46:09 +02:00
As with any other service offered on the web, understanding how your project
2021-07-19 09:30:47 +02:00
documentation is actually used can be an essential success factor. Material for
MkDocs natively integrates with [Google Analytics][1] and offers a customizable
and extendable [cookie consent][2].
2020-07-22 09:54:17 +02:00
[1]: https://developers.google.com/analytics
2021-07-19 09:30:47 +02:00
[2]: #cookie-consent
2020-07-22 09:54:17 +02:00
## Configuration
2020-07-22 11:57:41 +02:00
### Google Analytics
2020-07-22 09:54:17 +02:00
2020-07-22 11:57:41 +02:00
[:octicons-file-code-24: Source][3] · :octicons-milestone-24: Default: _none_
2020-07-22 09:54:17 +02:00
Material for MkDocs integrates with both, Google Analytics 4 and the now phasing
out Universal Analytics (`UA-*`). Depending on the prefix of the property, add
the following to `mkdocs.yml`:
2020-07-22 09:54:17 +02:00
=== "Google Analytics 4"
``` yaml
extra:
analytics:
provider: google
property: G-XXXXXXXXXX
```
=== "Universal Analytics"
``` yaml
extra:
analytics:
provider: google
property: UA-XXXXXXXX-X
```
2020-07-22 09:54:17 +02:00
2020-07-22 11:57:41 +02:00
[3]: https://github.com/squidfunk/mkdocs-material/blob/master/src/partials/integrations/analytics.html
2020-07-22 09:54:17 +02:00
2020-07-24 14:30:03 +02:00
#### Site search tracking
2020-07-22 09:54:17 +02:00
2020-07-26 14:46:09 +02:00
Besides basic page views, _site search_ can also be tracked to understand better
2020-07-22 09:54:17 +02:00
how people use your documentation and what they expect to find. To enable
search tracking:
1. Go to your Google Analytics __admin settings__
2. Select the property for the respective tracking code
3. Go to the __view settings__ tab.
4. Scroll down and enable __site search settings__
5. Set the __query parameter__ to `q`.
_Site search tracking is not supported with Google Analytics 4 due to the much
more complicated manual setup. If you want to set up site search tracking
yourself, [this tutorial][4] might be a good start._
[4]: https://www.analyticsmania.com/post/track-site-search-with-google-tag-manager-and-google-analytics/
2021-07-10 15:21:22 +02:00
### Cookie consent
[:octicons-file-code-24: Source][5] ·
2021-07-19 09:30:47 +02:00
:octicons-milestone-24: Default: _none_ ·
2021-07-10 15:21:22 +02:00
[:octicons-heart-fill-24:{ .mdx-heart } Insiders only][5]{ .mdx-insiders }
Material for MkDocs ships a native and extensible cookie consent form, which
2021-07-19 09:30:47 +02:00
asks the user for his consent prior to setting up analytics. Add the following
to `mkdocs.yml`:
2021-07-10 15:21:22 +02:00
``` yaml
extra:
2021-07-18 17:57:45 +02:00
consent:
title: Cookie consent
2021-07-19 09:30:47 +02:00
description: > # (1)
2021-07-18 17:57:45 +02:00
We use cookies to recognize your repeated visits and preferences, as well
as to measure the effectiveness of our documentation and whether users
find what they're searching for. With your consent, you're helping us to
make our documentation better.
2021-07-10 15:21:22 +02:00
```
2021-07-19 09:30:47 +02:00
1. You can add arbitrary HTML tags in the `description`, e.g. to link to your
terms of service or other parts of the site.
Note that both, `title` and `description`, are required. If Google Analytics was
configured via `mkdocs.yml`, the cookie consent will automatically include a
setting for the user to disable it. Furthermore, [custom cookies][6] can be
integrated by using the `cookies` field:
=== "Change cookie name"
``` yaml
extra:
consent:
cookies:
analytics: Custom name # (1)
```
1. The default name of the `analytics` cookie is `Google Analytics`.
=== "Add custom cookie"
``` yaml
extra:
consent:
cookies:
analytics: Google Analytics # (1)
custom: Custom cookie
```
1. If you add a custom cookie to the `cookies` field, the `analytics` cookie
must be added back explicitly, or analytics won't be triggered.
2021-07-10 15:21:22 +02:00
When a user first visits your site, a cookie consent form is rendered:
2021-07-20 19:36:41 +02:00
[![Cookie consent][7]][7]
In order to comply with GDPR, users must be able to change their cookie settings
at any time. This can be done by creating a simple link as part of any document,
e.g. privacy policy:
``` markdown
[Change cookie settings](#__consent){ .md-button }
```
2021-07-10 15:21:22 +02:00
[5]: ../insiders/index.md
2021-07-19 09:30:47 +02:00
[6]: #custom-cookies
[7]: ../assets/screenshots/consent.png
2021-07-10 15:21:22 +02:00
2020-07-22 09:54:17 +02:00
## Customization
2021-07-19 09:30:47 +02:00
### Custom site analytics
2020-07-22 09:54:17 +02:00
[:octicons-file-code-24: Source][3] ·
2021-07-19 09:30:47 +02:00
:octicons-mortar-board-24: Difficulty: _moderate_
2020-07-22 09:54:17 +02:00
2021-07-19 09:30:47 +02:00
In order to integrate another analytics service provider offering a
JavaScript-based tracking solution, you can [extend the theme][8] and add a new
`custom.html` partial [here][9]. The name of the partial can then be used to
configure the custom integration from `mkdocs.yml`:
2020-07-22 11:57:41 +02:00
2021-07-19 09:30:47 +02:00
``` yaml
extra:
analytics:
provider: custom # (1)
key: value # (2)
2020-07-22 11:57:41 +02:00
```
2020-07-22 09:54:17 +02:00
2021-07-19 09:30:47 +02:00
1. Of course, you can change the name to the partial to anything you like.
2. You can add arbitrary `key` and `value` combinations to configure your custom
integration. This is especially useful if you're sharing the custom
integration across multiple repositories.
[8]: ../customization.md#extending-the-theme
[9]: https://github.com/squidfunk/mkdocs-material/tree/master/src/partials/integrations/analytics
2020-07-22 09:54:17 +02:00
2021-07-19 09:30:47 +02:00
#### Instant loading
If you're using [instant loading][10], you may use the `location$` observable,
2020-07-22 11:57:41 +02:00
which will emit the current `URL` to listen for navigation events and register
a page view event with:
2020-07-22 09:54:17 +02:00
``` js
2021-02-22 22:27:30 +01:00
location$.subscribe(function(url) {
2021-07-19 09:30:47 +02:00
/* Track a page event */
2020-07-22 09:54:17 +02:00
})
```
2021-07-19 09:30:47 +02:00
Note that this must be integrated with [additional JavaScript][11].
[10]: setting-up-navigation.md#instant-loading
[11]: ../customization.md#additional-javascript
### Custom cookies
[:octicons-file-code-24: Source][3] ·
:octicons-mortar-board-24: Difficulty: _moderate_
If you've customized the [cookie consent][12] and added a `custom` cookie, the
user will be prompted to accept your custom cookie. Use
[additional JavaScript][11] to check whether the user accepted it:
``` js
var consent = __md_get("__consent")
if (consent && consent.custom) {
/* The user accepted the cookie */
}
```
2020-07-22 11:57:41 +02:00
2021-07-19 09:30:47 +02:00
[12]: #cookie-consent