I'm trying to track Revenue with the new GA4 but i'm having a hard time understanding how.
Show image
Can anyone please help?
Thank you!
The "value" parameter in tagging populates the "Revenue" metric in reports. For example if you upload the purchase event from this example (https://developers.google.com/analytics/devguides/collection/ga4/ecommerce#purchase):
gtag('event', 'purchase', {
affiliation: 'Google Store',
coupon: 'SUMMER_FUN',
currency: 'USD',
items: [{
item_id: 'SKU_12345',
item_name: 'jeggings',
coupon: 'SUMMER_FUN',
discount: 2.22,
affiliation: 'Google Store',
item_brand: 'Gucci',
item_category: 'pants',
item_variant: 'black',
price: 9.99,
currency: 'USD',
quantity: 1
}, {
item_id: 'SKU_12346',
item_name: 'jeggings',
coupon: 'SUMMER_FUN',
discount: 2.22,
affiliation: 'Google Store',
item_brand: 'Gucci',
item_category: 'pants',
item_variant: 'gray',
price: 9.99,
currency: 'USD',
quantity: 1
}],
transaction_id: 'T_12345',
shipping: 3.33,
value: 21.09,
tax: 2.22
})
Then, GA4 will show a Total Revenue of $21.09.
In the Monetization Overview Report, GA4 will show this $21.09 is specifically categorized as Ecommerce revenue.
Related
I'm using Google Tag Manager to deploy Google Analytics 4. I want to use view_list_items. If I follow this Google example and push the following JSON with a variable ecommerce.items mapped to the items parameter of a view_item_list event:
dataLayer.push({
'event': 'view_item_list',
'ecommerce': {
'items': [
{
'item_name': 'Triblend Android T-Shirt', // Name or ID is required.
'item_id': '12345',
'price': '15.25',
'item_brand': 'Google',
'item_category': 'Apparel',
'item_category2': 'Mens',
'item_category3': 'Shirts',
'item_category4': 'Tshirts',
'item_variant': 'Gray',
'item_list_name': 'Search Results',
'item_list_id': 'SR123',
'index': 1,
'quantity': '1'
},
{
'item_name': 'Donut Friday Scented T-Shirt',
'item_id': '67890',
'price': '33.75',
'item_brand': 'Google',
'item_category': 'Apparel',
'item_category2': 'Mens',
'item_category3': 'Shirts',
'item_category4': 'Tshirts',
'item_variant': 'Black',
'item_list_name': 'Search Results',
'item_list_id': 'SR123',
'index': 2,
'quantity': '1'
}]
}
});
Then in the GA4 debugger instead of showing 2 items it show up 4. 2 products and 2 list items as below:
Triblend Android T-Shirt (12345)
item_id: 12345
quantity: 1
item_name: Triblend Android T-Shirt
item_brand: Google
item_category: Apparel
item_category2: Mens
item_category3: Shirts
item_category4: Tshirts
variant: Gray
price: 15250000
Donut Friday Scented T-Shirt (67890)
item_id: 67890
quantity: 1
item_name: Donut Friday Scented T-Shirt
item_brand: Google
item_category: Apparel
item_category2: Mens
item_category3: Shirts
item_category4: Tshirts
variant: Black
price: 33750000
Item
item_list_id: SR123
item_list_name: Search Results
index: 1
Item
item_list_id: SR123
item_list_name: Search Results
index: 2
How do I manager to map the item_list_name and item_list_id to their corresponding products?
Assuming that I need to send some dataLayer info to Google Tag Manager, I will need this:
dataLayer.push({
'ecommerce': {
'currencyCode': 'EUR', // Local currency is optional.
'impressions': [
{
'name': 'Triblend Android T-Shirt', // Name or ID is required.
'id': '12345',
'price': '15.25',
'brand': 'Google',
'category': 'Apparel',
'variant': 'Gray',
'list': 'Search Results',
'position': 1
},
{
'name': 'Donut Friday Scented T-Shirt',
'id': '67890',
'price': '33.75',
'brand': 'Google',
'category': 'Apparel',
'variant': 'Black',
'list': 'Search Results',
'position': 2
}]
}
});
The question is: do I need to manually write the JSON into my page or the gtm will do this for me after inserting the gtm tracking code into my page?
After searching some tutorials online, all the helpful info I found was how to configure the TagManager account but nobody talks about how the script is generated.
You have to add the script in the page. It will not be generated automatically, but the parameter values will be recognized automatically It your GTM and GA configuration is right (I mean you don't have to create the variables in GTM but you have to create the ecommerce construct in the page with the values of your products).
We're implementing GA conversion tracking with GTM per the following documentation, but I'm not finding any information about how to handle discounts (coupons) at the order level.
https://support.google.com/tagmanager/answer/6106097?hl=en
https://developers.google.com/analytics/devguides/collection/analyticsjs/ecommerce
I can send revenue, shipping, and tax, but these won't total correctly for orders that include a discount. If an order is placed as follows:
T-Shirt: $5
Socks: $5
subtotal: $10
tax: $2
shipping: $3
discount: -$5
order total: $10
Should my dataLayer look like this?
<script>
dataLayer = [{
'transactionId': '1234',
'transactionAffiliation': 'Acme Clothing',
'transactionTotal': 10,
'transactionTax': 2,
'transactionShipping': 3,
'transactionProducts': [{
'sku': 'DD44',
'name': 'T-Shirt',
'category': 'Apparel',
'price': 5,
'quantity': 1
},{
'sku': 'AA1243544',
'name': 'Socks',
'category': 'Apparel',
'price': 5,
'quantity': 1
}]
}];
</script>
Will that cause any inaccuracies or inconsistencies in GA?
A co-worker and I are tackling the same question right now.
Before I get into that though you should never, ever declare your dataLayer like that. Sadly it seems to be the way that Google themselves do it in all their code examples, but it's incredibly dangerous because it will overwrite your existing dataLayer with a new one that only contains those key : value pairs. Instead check if dataLayer exists, creating it if it doesn't, and push to it.
window.dataLayer = window.dataLayer || [];
dataLayer.push({
'key' : 'value'
});
Additionally assuming you've switched over to Universal Analytics consider toggling Enhanced Ecommerce Tracking. It's simultaneously a much more powerful, and cleaner implementation of ecommerce tracking.
So far we've come up with a couple seemingly workable approaches. You can ignore the discount all together, like you did above, and report the total revenue manually after the discount has been applied. One thing I would add if you switch to Enhanced Ecommerce is a coupon code to acknowledge that a product has a discount applied.
<script>
window.dataLayer = window.dataLayer || [];
dataLayer.push({
'ecommerce': {
'purchase': {
'actionField': {
'id': '1234',
'affiliation': 'Acme Clothing',
'revenue': '10.00',
'tax':'2.00',
'shipping': '3.00',
'coupon': 'SUMMER_SALE' //Transaction-scope coupon. This would
//be where you'd include discounts like '$10 off purchases of $50 or more'
},
'products': [{
'name': 'T-Shirt',
'id': 'DD44',
'price': '5.00',
'category': 'Apparel',
'quantity': 1
},
{
'name': 'Socks',
'id': 'AA1243544',
'price': '5.00',
'category': 'Apparel',
'quantity': 1,
'coupon': 'FREE_SOCKS' //Product-scope coupon. This would be for
//discounts like 'free socks with purchase of a t-shirt'
}]
}
}
});
</script>
Alternatively you can enter the discounts as negative value SKUs and track them as their own line items in the transaction.
<script>
window.dataLayer = window.dataLayer || [];
dataLayer.push({
'ecommerce': {
'purchase': {
'actionField': {
'id': '1234',
'affiliation': 'Acme Clothing',
'revenue': '10.00',
'tax':'2.00',
'shipping': '3.00'
},
'products': [{
'name': 'T-Shirt',
'id': 'DD44',
'price': '5.00',
'category': 'Apparel',
'quantity': 1
},
{
'name': 'Socks',
'id': 'AA1243544',
'price': '5.00',
'category': 'Apparel',
'quantity': 1,
},
{
'name': 'Socks-Discount',
'id': 'free-socks',
'price': '-5.00',
'category': 'Apparel',
'quantity': 1,
}]
}
}
});
</script>
Ultimately my recommendation is to mirror the logic for how you're handling the discount in the cart itself. If discounts are their own line items with their own SKUs in your cart report them in GA the same way. If coupon codes make more sense do that. You can even combine the two if you'd like.
Use the coupon field to specify the fact that the transaction and/or product is being discounted. e.g.
"coupon" : "10% summer sale" or just "general discount"
Then use a custom metric (scope=hit, format=decimal) to track the total amount of discount applied for the transaction.
'dimension1': '50.0'
Ref: https://developers.google.com/tag-manager/enhanced-ecommerce#checkout
Your transaction total in the DL should get pushed to the addTrans call. So just make sure whatver value you send to it is what you want to send. GA does not care how you define revenues.
I'm developing a tag, but the product, wines, has 5 categories, like country, region, type of grape, etc...
However, the dataLayer contains a slot for only 1 category.
'transactionProducts': [{
'sku': 'DD44',
'name': 'T-Shirt',
'category': 'Apparel',
'price': 11.99,
'quantity': 1
}]
I need this:
'transactionProducts': [{
'sku': 'DD44',
'name': 'T-Shirt',
'category': ['Category 1','Category 2','Category 3'],
'price': 11.99,
'quantity': 1
}]
Is possible? Works correctly?
Putting the categories into an array won't work as the field only accepts a single string. You can use a pipe (or anything)-delimited string instead:
'category': 'Category 1|Category 2|Category 3',
I'm currently implementing Google Analytics enhanced ecommerce. When I buy something in my dev env I check my dev analytics Shopping Behavior and I only see values in All Sessions and Sessions with Transactions, but nothing in between. My code is below. Before or after each ga('ec') & ga('send') pair I sometimes fire an event for normal analytics. Is there anything wrong with my code?
// All values are angular expressions that I've
// double triple checked to make sure they give good values
ga('ec:addImpression', 'detail',{
'id': $location.search().tripToken,
'name': $scope.holds[a].value,
'price': $scope.holds[a].price,
'category' : tileDisable
});
ga('send','pageview')
// Next GA fire a bit later
ga('ec:addProduct', 'checkout', {
'id': $location.search().tripToken,
'name': optionType,
'price': $scope.getOptionPrice(optionType),
'quantity': parseInt($scope.baseInfo.total_travelers)
});
ga('send','pageview');
// A bit later
ga('ec:setAction', 'purchase', {
'id': $scope.userData.option_type,
'affiliation': $scope.userData.token,
'revenue': $scope.userData.option_price * $scope.baseInfo.total_travelers
});
ga('send','pageview');
For common impressions you have to remove the 'detail'
ga('ec:addImpression' *** REMOVE ,'detail'***,{
'id': $location.search().tripToken,
'name': $scope.holds[a].value,
'price': $scope.holds[a].price,
'category' : tileDisable
});
Then when a product is clicked you need to add
ga('ec:addProduct', {
'id': 'P12345',
'name': 'Android Warhol T-Shirt',
'category': 'Apparel',
'brand': 'Google',
'variant': 'black',
'position': 1
});
ga('ec:setAction', 'click', {list: 'Search Results'});
//Remember to add a (non interaction if you wish) event here in order to send the data to GA
ga('send','event','whatever-value');
The last step would be adding the clic (add to cart) for the detail page:
ga('ec:addProduct', {
'id': product.id,
'name': product.name,
'category': product.category,
'brand': product.brand,
'variant': product.variant,
'price': product.price,
'quantity': product.qty
});
ga('ec:setAction', 'add');
// Send data using an event again (depends on user interaction)
ga('send', 'event', 'UX', 'click', 'add to cart');
In case you want to see a live example please visit official Google's demo:
http://enhancedecommerce.appspot.com/