norsys / google-tag-manager-bundle
Bundle handling Google Tag Manager
Installs: 371
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 9
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=7.0.0
- symfony/config: ^3.1.0
- symfony/dependency-injection: ^3.1.0
- symfony/http-kernel: ^3.1.0
- twig/extensions: ^1.5
Requires (Dev)
- atoum/atoum: ~3.0
- atoum/bdd-extension: ~2.1
- atoum/stubs: ~2.5
- norsys/php-coding-standard: ~1.0
- squizlabs/php_codesniffer: ^2.6
This package is auto-updated.
Last update: 2025-01-28 10:03:09 UTC
README
This project is a bundle which eases the configuration and handling of Google Tag Manager.
It provides a bunch of base classes to extend from.
Installation
Step 1: Add the repository & download the Bundle
Open a command console, enter your project directory and execute the following commands:
# download the latest stable version of this bundle:
$ composer require norsys/google-tag-manager-bundle
This command requires you to have composer
installed globally, as explained
in the installation chapter
of the Composer documentation.
Step 2: Register the Bundle
Then, enable the bundle by adding it to the list of registered bundles
in the app/AppKernel.php
file of your project:
<?php // app/AppKernel.php // ... class AppKernel extends Kernel { public function registerBundles() { $bundles = array( // ... new Norsys\GoogleTagManagerBundle\NorsysGoogleTagManagerBundle(), // ... ); // ... } // ... }
Step 3: Configuration & Implementation
The GTM bundle allows you to define google tag manager parameters, providing a default values management.
Basic integration
# app/config/config.yml #... norsys_google_tag_manager: id: 'GTM-XXXXXX'
Template integration
To ease quick integration, the bundle provides a twig
partial and a javascript file to include in your template:
Example:
{# Google Tag Manager #} {% block google_tag_manager %} {% include '@NorsysGoogleTagManager/google_tag_manager.html.twig' %} {{ asset('web/bundles/norsysgoogletagmanager/js/google-tag-manager.js') }} {% endblock google_tag_manager %}
Controlling GTM loading
By default, GoogleTagManager is initialized at the point the javascript file is included.
You can also tied it to a specific DOM event:
# app/config/config.yml #... norsys_google_tag_manager: id: 'GTM-XXXXXX' on_event: enabled: true name: load container: body
DataLayer configuration
The GoogleTagManager Bundle handles 2 distinct types of parameters:
- Static parameters
- Dynamic parameters
⚠️ As a rule of thumb,
static
anddynamic
parameters must have different names.
Static parameters
Here is a very basic config example:
# app/config/config.yml #... norsys_google_tag_manager: data_layer: default: static: virtualPageURL: '/home' pages: faq: static: virtualPageURL: '/otherLink/faq'
The bundle will merge defaults and per-route static parameters, and issue the resulting data layer.
The dataLayer sent for the page responding to the faq
route will be:
dataLayer = [ { "virtualPageURL": "/otherLink/faq" } ];
Dynamic parameters
On some situations, it can be useful to have some parameters value changing dynamically upon the context.
For this purpose, the bundle provides support for dynamic parameters.
Each dynamic parameter consists of a service implementing NorsysGoogleTagManagerBundle\Dynamic\ParameterInterface.
The custom dynamic parameter class will have to implement the 2 following methods:
getValue()
The method responsible for calculating the parameters value. It receives the whole merged and resolved config as unique argumentgetName()
This method must return the unique parameter name, the one that represents it in the config
# src/AppBundle/DynamicParameter/Acme.php <?php namespace AppBundle\DynamicParameter; use Norsys\GoogleTagManagerBundle\Config\ParameterBag; use Norsys\GoogleTagManagerBundle\Dynamic\ParameterInterface; class Acme implements ParameterInterface { public function getValue(ParameterBag $configPage): string { // do something to calculate value // ... return $calculatedValue; } public function getName(): string { return 'acmeDynamicParam'; } }
Each dynamic parameter class refered to in the bundle config must be registered, hence declared using the appropriate tag:
# app/config/services.yml #... app.google_tag_manager.config.dynamic_parameter.acme: class: AppBundle\DynamicParameter\Acme tags: - { name: 'norsys_google_tag_manager.dynamic_parameter' } #...
Now we can use the parameter in the bundle config, referencing to it via the alias defined by its getName()
method.
# app/config/config.yml #... norsys_google_tag_manager: data_layer: default: # ... dynamic: acmeDynamicParam: ~ # ...
Even if rarely ever needed for most cases, it is possible to pass the parameter an initialization string, and then fetch it in the associated service.
As an example, let's say we want to pass a C-like template string:
# app/config/config.yml #... norsys_google_tag_manager: data_layer: default: # ... dynamic: acmeDynamicParam: '%s:%s:%s' # ...
We can then easily fetch this init value for further processing inside the getValue()
method:
# src/AppBundle/DynamicParameter/Acme.php <?php namespace AppBundle\DynamicParameter; use Norsys\GoogleTagManagerBundle\Config\ParameterBag; use Norsys\GoogleTagManagerBundle\Dynamic\ParameterInterface; class Acme implements ParameterInterface { // ... public function getValue(ParameterBag $configPage): string { // The value passed in the parameter config can be retreived easily $initValue = $configPage->get($this->getName()); // Fetch $locale, $route, $land, for example from an object injected in the service's constructor // ... $calculatedValue = sprintf($initValue, $locale, $route, $land); return $calculatedValue; } // ... }
Dynamic parameters can also be overriden, on a per-route basis:
norsys_google_tag_manager: data_layer: default: # ... dynamic: acmeDynamicParam: 'whatever-init-value' pages: faq: dynamic: acmeDynamicParam: 'another-init-value'
Dynamic parameters aliases
Additionnally this bundle also supports aliases for dynamic parameters.
Let's consider using an alias of the previously created acmeDynamicParam
:
norsys_google_tag_manager: data_layer: aliases: myDummyParam: acmeDynamicParam default: # ... dynamic: acmeDynamicParam: 'whatever-init-value'
Now we can use the aliased name to refer directly to its target:
norsys_google_tag_manager: data_layer: aliases: myDummyParam: acmeDynamicParam default: # ... dynamic: # The following is equivalent to: # # acmeDynamicParam: 'whatever-init-value' # myDummyParam: 'whatever-init-value'
Conclusion
Now, taking for granted the 2 above static
and dynamic
configured parameters, the resulting generated dataLayer for the faq
route would be something like:
dataLayer = [ { "virtualPageURL": "/otherLink/faq", "acmeDynamicParam": "constructed-value" } ];
Credits
Developped by ❤️ with Norsys
License
This project is licensed under the MIT license.