rapidez / gtm
Rapidez GTM
Installs: 4 612
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 4
Open Issues: 0
Language:JavaScript
Requires
- php: ^8.0|^8.1|^8.2
- illuminate/support: ^9.0|^10.0|^11.0
- illuminate/view: ^9.0|^10.0|^11.0
- rapidez/core: ^3.0
- dev-master
- 3.0.1
- 3.0.0
- 2.x-dev
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.0
- 1.0.0
- 0.16.1
- 0.16.0
- 0.15.1
- 0.15.0
- 0.14.0
- 0.13.1
- 0.13.0
- 0.12.2
- 0.12.1
- 0.12.0
- 0.11.3
- 0.11.2
- 0.11.1
- 0.11.0
- 0.10.0
- 0.9.0
- 0.8.0
- 0.7.0
- 0.6.0
- 0.5.1
- 0.5.0
- 0.4.0
- 0.3.0
- 0.2.0
- 0.1.0
- dev-feature/fix-missing-event-detail-2.x
- dev-feature/fix-missing-event-detail
This package is auto-updated.
Last update: 2024-12-20 08:11:02 UTC
README
This Rapidez package provides 2 views with the GTM scripts, listens to events emitted by the Rapidez Core and adds ecommerce data to the datalayer. Currently for Universal Analytics Enhanced Ecommerce but you can use this with Analytics 4 by using a GTM Template.
Installation
composer require rapidez/gtm
And add your GTM ID in the .env
GTM_ID=
And finally add @include('rapidez-gtm::head')
and @include('rapidez-gtm::foot')
in the head and at the bottom of your layout template, most likely at: resources/views/vendor/rapidez/layouts/app.blade.php
. If you haven't published the Rapidez views yet, you can publish them with:
php artisan vendor:publish --provider="Rapidez\Core\RapidezServiceProvider" --tag=views
Multistore
Just add all stores in config/rapidez/gtm.php
after you've published the config with:
php artisan vendor:publish --provider="Rapidez\GTM\GTMServiceProvider" --tag=config
Where the key of the id
array is the store code.
Views
If you need to change the views you can publish them with:
php artisan vendor:publish --provider="Rapidez\GTM\GTMServiceProvider" --tag=views
Purchase tracking
This package doesn't send any purchase events as it's better to send those from the backend in case a visitor blocks Analytics with a browser extension, for example with elgentos/magento2-serversideanalytics which includes a "AddGaUserId" GraphQL mutation so it's possible to push the id from Rapidez to Magento.
When installed you can enable it in the .env
with:
GTM_ELGENTOS=true
view_item_list event
To track the view_item_list
event, you can use the v-item-list
directive on your product list, for example:
v-item-list="{ items: items, item_list_id: 'recommended_products', item_list_name: 'Recommended products', }"
You can also track it only on intersection by adding the .intersection
modifier. This defaults to 50% intersection, but can be overridden: v-item-list.intersection="{ intersection: 80, ... }"
Enhanced Conversions
To track Enhanced Conversions, we supply a seperate file you can run when you have captured the relevant user info you want to push.
for example after subscribing to the newsletter, or entering their details in the checkout. Here's an example of how you could implement it
import { setUserData } from 'Vendor/rapidez/gtm/resources/js/datalayer/google-ads.js'; window.app.$on('logged-in', () => { setUserData(); }); window.app.$on('checkout-credentials-saved', () => { setUserData(); });
Temporarily disable
If you'd like to test for example the Lighthouse scores without GTM you can disable it by added ?gtm=false
to the url
Partytown
Scripts like GTM have a massive negative impact on performance and pagespeed, to remedy this scripts like Partytown have been made. Which allows you to keep your analytics but reclaim some of the performance.
Note that partytown is technically not production ready and still in beta.
Installation
- Execute
yarn add @builder.io/partytown
- Configure Vite to copy the partytown files (however instead of dist it should go in public)
- Make sure symfony/psr-http-message-bridge is installed, if it is not:
composer require symfony/psr-http-message-bridge
- Enable partytown for GTM by adding
GTM_PARTYTOWN_ENABLE=true
to your .env - Add
/public/~partytown
to your .gitignore
Additional domains and CORS
Not all domains support partytown due to their CORS settings (https://partytown.builder.io/proxying-requests)
This package comes with a proxy for these domains which by default is only set up for GTM (see: config/rapidez/gtm.php)
If you notice more domains giving CORS errors you can add them to the config or in a comma seperated list in your .env under GTM_PARTYTOWN_DOMAIN_WHITELIST
.
Custom config
The partytown configuration is available in window.partytown
so you can change the configuration by updating the configuration within <script></script>
tags.
Running partytown but not for GTM
If you want to run partytown but not for GTM that's possible too by configuring GTM_PARTYTOWN_ENABLE=false
and manually including the partytown view in the head.
@push('head') @include('rapidez-gtm::partytown.index') @endpush
License
GNU General Public License v3. Please see License File for more information.