prgtw / google-bundle
The GoogleBundle adds the ability to add various google-related services to your application. These include Google Analytics, Adwords and Static Maps.
Installs: 277
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 88
Type:symfony-bundle
pkg:composer/prgtw/google-bundle
Requires
- php: ^7.4 || ^8.0
- doctrine/collections: ^1.0 || ^2.0
- symfony/config: ^3.0 || ^4.0 || ^5.0
- symfony/dependency-injection: ^3.0 || ^4.0 || ^5.0
- symfony/http-foundation: ^3.0 || ^4.0 || ^5.0
- symfony/http-kernel: ^3.0 || ^4.0 || ^5.0
- symfony/templating: ^3.0 || ^4.0 || ^5.0
- twig/twig: ^1.44.7 || ^2 || ^3
Requires (Dev)
- phpunit/phpunit: ^9
- symfony/browser-kit: ^3.0 || ^4.0 || ^5.0
- symfony/framework-bundle: ^3.0 || ^4.0 || ^5.0
- symfony/twig-bridge: ^3.0 || ^4.0 || ^5.0
- symfony/twig-bundle: ^3.0 || ^4.0 || ^5.0
- symfony/yaml: ^3.0 || ^4.0 || ^5.0
This package is auto-updated.
Last update: 2025-10-05 20:36:20 UTC
README
GoogleBundle
The GoogleBundle adds the ability to add various google-related services to your application. These include Google Analytics, Adwords and Static Maps.
Installation
Initialize Submodule
git submodule add git@github.com:antimattr/GoogleBundle.git src/AntiMattr/GoogleBundle
Application Kernel
Add GoogleBundle to the registerBundles() method of your application kernel:
public function registerBundles()
{
    return array(
        new AntiMattr\GoogleBundle\GoogleBundle(),
    );
}
Configuration
Google Analytics
Application config.yml
Enable loading of the Google Analytics service by adding the following to
the application's config.yml file:
google:
    analytics:
        trackers:
            default:
                name:      MyJavaScriptCompatibleVariableNameWithNoSpaces
                accountId: UA-xxxx-x
                domain:    .mydomain.com
                trackPageLoadTime: true
View
Include the Google Analytics Async template in the head tag or just before the </body> of your layout (The template will lazy load _gaq).
With twig:
{% include "GoogleBundle:Analytics:async.html.twig" %}
Features
Logging a Default Page View
Requires no additional code
Sending a Custom Page View
$this->container()->get('google.analytics')->setCustomPageView('/profile/'.$username);
Adding to Page View Queue
Note: Page View Queue is always executed before a Custom Page View
$this->container()->get('google.analytics')->enqueuePageView('/my-first-page-view-in-queue');
$this->container()->get('google.analytics')->enqueuePageView('/my-second-page-view-in-queue');
Ecommerce Tracking
$transaction = new \AntiMattr\GoogleBundle\Analytics\Transaction();
$transaction->setOrderNumber('xxxx');
$transaction->setAffiliation('Store 777');
$transaction->setTotal(100.00);
$transaction->setTax(10.00);
$transaction->setShipping(5.00);
$transaction->setCity("NYC");
$transaction->setState("NY");
$transaction->setCountry("USA");
$this->get('google.analytics')->setTransaction($transaction);
$item = new \AntiMattr\GoogleBundle\Analytics\Item();
$item->setOrderNumber('xxxx');
$item->setSku('zzzz');
$item->setName('Product X');
$item->setCategory('Category A');
$item->setPrice(50.00);
$item->setQuantity(1);
$this->get('google.analytics')->addItem($item);
$item = new \AntiMattr\GoogleBundle\Analytics\Item();
$item->setOrderNumber('bbbb');
$item->setSku('jjjj');
$item->setName('Product Y');
$item->setCategory('Category B');
$item->setPrice(25.00);
$item->setQuantity(2);
$this->get('google.analytics')->addItem($item);
Google Adwords
Application config.yml
Enable loading of the Google Adwords service by adding the following to
the applications's config.yml file:
google:
    adwords:
        conversions:
            account_create:
                id:    111111
                label: accountCreateLabel
                value: 0
            checkout_thanks:
                id:    222222
                label: checkoutThanksLabel
                value: 0
Controller
$this->get('google.adwords')->activateConversionByKey('account_create');
View
Include the Google Adwords tracking template like this
{% include "GoogleBundle:Adwords:track.html.twig" %}
Google Maps - Static Map
Application config.yml
Enable loading of the Google Maps Static service by adding the following to
the applications's config.yml file (The static service does NOT require an API Key):
google:
    maps: ~
Controller
use AntiMattr\GoogleBundle\Maps\StaticMap;
use AntiMattr\GoogleBundle\Maps\Marker;
...
$map = new StaticMap();
$map->setId("Paul");
$map->setSize("512x512");
$marker = new Marker();
$marker->setLatitude(40.596631);
$marker->setLongitude(-73.972359);
$map->addMarker($marker);
$this->container->get('google.maps')->addMap($map);
View
Include the Google Maps in your template like this:
{% if google_maps.hasMaps() %}
	{% for map in google_maps.getMaps() %}
		{% autoescape false %}
			{{ map.render }}
		{% endautoescape %}
	{% endfor %}
{% endif %}