Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrezimpel/gatsby-plugin-gdpr-cookies
Gatsby plugin to add Google Analytics (V4 is supported), Google Tag Manager, Facebook Pixel, TikTok Pixel and Hotjar in a GDPR form to your site.
https://github.com/andrezimpel/gatsby-plugin-gdpr-cookies
analytics-tracking custom-cookie facebook-pixel gatsby-plugin google-analytics hotjar tiktok
Last synced: 13 days ago
JSON representation
Gatsby plugin to add Google Analytics (V4 is supported), Google Tag Manager, Facebook Pixel, TikTok Pixel and Hotjar in a GDPR form to your site.
- Host: GitHub
- URL: https://github.com/andrezimpel/gatsby-plugin-gdpr-cookies
- Owner: andrezimpel
- License: apache-2.0
- Created: 2019-07-24T18:48:34.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-03-22T10:19:08.000Z (over 1 year ago)
- Last Synced: 2024-10-22T03:18:42.795Z (22 days ago)
- Topics: analytics-tracking, custom-cookie, facebook-pixel, gatsby-plugin, google-analytics, hotjar, tiktok
- Language: JavaScript
- Homepage:
- Size: 492 KB
- Stars: 101
- Watchers: 7
- Forks: 70
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# gatsby-plugin-gdpr-cookies
Gatsby plugin to add Google Analytics (V4 is supported), Google Tag Manager, Facebook Pixel, TikTok Pixel and Hotjar in a GDPR form to your site.
**Version 2:** I did rewrite the whole plugin to remove all the ssr that was done before. This will ensure that no data is ever sent before the cookies are set to true and the plugin has been initialized. There are **no breaking changes**. The configuration is exactly the same and and `initializeAndTrack(location)` does still work as before. I also removed some dependencies to keep the bundle size as small as possible.
*Feedback is much appreciated* ππ½
## Install
`yarn add gatsby-plugin-gdpr-cookies`
or
`npm install --save gatsby-plugin-gdpr-cookies`## How to use
```javascript
// in your gatsby-config.js
module.exports = {
plugins: [
{
resolve: `gatsby-plugin-gdpr-cookies`,
options: {
googleAnalytics: {
trackingId: 'YOUR_GOOGLE_ANALYTICS_TRACKING_ID', // leave empty if you want to disable the tracker
cookieName: 'gatsby-gdpr-google-analytics', // default
anonymize: true, // default
allowAdFeatures: false // default
},
googleTagManager: {
trackingId: 'YOUR_GOOGLE_TAG_MANAGER_TRACKING_ID', // leave empty if you want to disable the tracker
cookieName: 'gatsby-gdpr-google-tagmanager', // default
dataLayerName: 'dataLayer', // default
},
facebookPixel: {
pixelId: 'YOUR_FACEBOOK_PIXEL_ID', // leave empty if you want to disable the tracker
cookieName: 'gatsby-gdpr-facebook-pixel', // default
},
tikTokPixel: {
pixelId: 'YOUR_TIKTOK_PIXEL_ID', // leave empty if you want to disable the tracker
cookieName: 'gatsby-gdpr-tiktok-pixel', // default
},
hotjar: {
hjid: 'YOUR_HOTJAR_ID',
hjsv: 'YOUR_HOTJAR_SNIPPET_VERSION',
cookieName: 'gatsby-gdpr-hotjar', // default
},
linkedin: {
trackingId: 'YOUR_LINKEDIN_TRACKING_ID', // leave empty if you want to disable the tracker
cookieName: 'gatsby-gdpr-linked-in', // default
},
// defines the environments where the tracking should be available - default is ["production"]
environments: ['production', 'development']
},
},
],
}
```## How it works
First of all the plugin checks in which environment your site is running. If it's currently running in one of your defined environments it will add the tracking code by default to the `/` of your site. It will not be activated or initialized by this.
By default this plugin will not send any data to Google or Facebook to make it GDPR compliant. The user first needs to accept your cookie policy. By accepting that you need to set cookies for the tracker you want to use - `gatsby-gdpr-google-analytics`, `gatsby-gdpr-google-tagmanager`, `gatsby-gdpr-facebook-pixel`. Depending on the user input the value of each of the cookies should be `true` or `false`.
If the `gatsby-gdpr-google-analytics` cookie is set to true, Google Analytics will be initialized `onClientEntry`. Same is for the Google Tag Manager and Facebook Pixel. The plugin will check if cookies for Google Analytics or Facebook Pixel have been set between route changes on `onRouteUpdate`. Reloading the page after setting the cookies is not required anymore.
The page view will be tracked on `onRouteUpdate`.
**Important:** read below about using the plugin with Google Tag Manager.
## Options
### Google Analytics
#### `trackingId`
Here you place your Google Analytics tracking ID. Analytics 4 is supported by the plugin beginning with v1.0.12.
#### `cookieName`
You can use a custom cookie name if you need to!
#### `allowAdFeatures`
The default value is false.
#### `anonymize`
Some countries (such as Germany) require you to use the
[\_anonymizeIP](https://support.google.com/analytics/answer/2763052) function for Google Analytics. Otherwise you are not allowed to use it. The option adds two blocks to the code:```javascript
ga('set', 'anonymizeIp', 1);
```#### `opt-out`
Your visitors should be able to opt-out for analytics tracking. By setting the Google Analytics cookie to false tracking will be stopped. Alternatively you can also set the corresponding window variable to false:```javascript
window[`ga-disable-YOUR_TRACKING_ID_HERE`] = true
```### Google Tag Manager
#### `trackingId`
Here you place your Google Tag Manager tracking ID.
#### `cookieName`
You can use a custom cookie name if you need to!
#### `dataLayerName`
Data layer name
#### `routeChangeEvent`
The name of the event which will be triggered when route changes
Defaults to `gatsbyRouteChange`#### `gtmAuth`
Google Tag Manager environment auth string
#### `gtmPreview`
Google Tag Manager environment preview name
#### `defaultDataLayer`
Data layer to be set before GTM is loaded. Should be an object or a function that is executed in the browser, e.g.:
```javascript
defaultDataLayer: { platform: "gatsby" }
``````javascript
defaultDataLayer: function() {
return {
pageType: window.pageType,
}
}
```#### Tracking routes
Out of the box this plugin will simply load Google Tag Manager on the initial page/app load. Itβs up to you to fire tags based on changes in your app.
This plugin will fire a new event called `gatsbyRouteChange` (by default) on Gatsby's `onRouteUpdate` (only if the consent was given by a visitor). To record this in Google Tag Manager, we will need to add a trigger to the desired tag to listen for the event:
In order to do that, go to _Tags_. Under _Triggering_ click the pencil icon, then the β+β button to add a new trigger. In the _Choose a trigger_ window, click on the β+β button again. Choose the trigger type by clicking the pencil button and clicking _Custom event_. For event name, enter `gatsbyRouteChange`. This tag will now catch every route change in Gatsby, and you can add Google tag services as you wish to it.
### Facebook Pixel
#### `pixelId`
Here you place your Facebook Pixel ID.
#### `cookieName`
You can use a custom cookie name if you need to!
### TikTok Pixel
#### `pixelId`
Here you place your TikTok Pixel ID.
#### `cookieName`
You can use a custom cookie name if you need to!
### Hotjar
#### `hjid`
Stands for 'Hotjar ID' - Your site's ID. This is the ID which tells Hotjar which site settings it should load and where it should save the data collected.
#### `hjsv`
Stands for 'Hotjar Snippet Version' - The version of the Tracking Code you are using. This is only needed if Hotjar ever updates the Tracking Code and needs to discontinue older ones. Knowing which version your site includes allows hotjar team to contact you and inform you accordingly.
#### `cookieName`
You can use a custom cookie name if you need to!
### Chatwoot
Chatwoot is an open source customer engagement platform. This plugin manages installing and initializing Chatwoot if the respective cookie is true.
#### `baseUrl`
You can find the base url within your inbox.
#### `websiteToken`
You can find the website token within your inbox.
#### `cookieName`
You can use a custom cookie name if you need to!
#### `trackingId`
Here you place your LinkedIn tracking ID.
#### `cookieName`
You can use a custom cookie name if you need to!
## Initialize and track
This gatsby plugin now supports initializing and tracking right after a user accepts the cookie consent.```javascript
// in your cookie banner
import { useLocation } from "@reach/router" // this helps tracking the location
import { initializeAndTrack } from 'gatsby-plugin-gdpr-cookies'
```
Then you can execute `initializeAndTrack(location)` in your cookie banner callback. This will initialize the plugin with your options from the `gatsby-config.js` and then starts tracking the user based on the cookies/services are accepted.```javascript
// in your cookie banner
const location = useLocation()
initializeAndTrack(location)
```## Contributors
Thanks goes to these wonderful people who helped shaping this project.
[Simon Vanherweghe](https://github.com/SimonVanherweghe)
[Stefan Tertan](https://github.com/ColdFire87)
[Osvaldas Valutis](https://github.com/osvaldasvalutis)
[ThΓ©o](https://github.com/3theochp)
[Paul Brickles](https://github.com/pbrickles)
[Ferran Buireu](https://github.com/fbuireu)
[Daniel Spaude](https://github.com/spaudanjo)
[Hahlh B](https://github.com/Hahlh)