@walkeros/web-destination-gtag 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +330 -0
- package/dist/examples/index.d.mts +60 -0
- package/dist/examples/index.d.ts +60 -0
- package/dist/examples/index.js +279 -0
- package/dist/examples/index.mjs +257 -0
- package/dist/index.browser.js +1 -0
- package/dist/index.d.mts +123 -0
- package/dist/index.d.ts +123 -0
- package/dist/index.es5.js +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +1 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +56 -0
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Mapping as Mapping$1 } from '@walkeros/core';
|
|
2
|
+
import { DestinationWeb } from '@walkeros/web-core';
|
|
3
|
+
|
|
4
|
+
interface WindowWithDataLayer extends Window {
|
|
5
|
+
dataLayer: unknown[];
|
|
6
|
+
gtag?: Gtag.Gtag;
|
|
7
|
+
[key: string]: unknown;
|
|
8
|
+
}
|
|
9
|
+
declare global {
|
|
10
|
+
interface Window {
|
|
11
|
+
gtag?: Gtag.Gtag;
|
|
12
|
+
[key: string]: unknown;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
type WindowData = WindowWithDataLayer;
|
|
16
|
+
type Destination = DestinationWeb.Destination<Settings, Mapping>;
|
|
17
|
+
type Config = DestinationWeb.Config<Settings, Mapping>;
|
|
18
|
+
interface Settings {
|
|
19
|
+
ga4?: GA4Settings;
|
|
20
|
+
ads?: AdsSettings;
|
|
21
|
+
gtm?: GTMSettings;
|
|
22
|
+
}
|
|
23
|
+
interface GA4Settings {
|
|
24
|
+
measurementId: string;
|
|
25
|
+
debug?: boolean;
|
|
26
|
+
include?: Include;
|
|
27
|
+
pageview?: boolean;
|
|
28
|
+
server_container_url?: string;
|
|
29
|
+
snakeCase?: boolean;
|
|
30
|
+
transport_url?: string;
|
|
31
|
+
}
|
|
32
|
+
interface AdsSettings {
|
|
33
|
+
conversionId: string;
|
|
34
|
+
currency?: string;
|
|
35
|
+
}
|
|
36
|
+
interface AdsMapping {
|
|
37
|
+
label?: string;
|
|
38
|
+
}
|
|
39
|
+
interface GTMSettings {
|
|
40
|
+
containerId: string;
|
|
41
|
+
dataLayer?: string;
|
|
42
|
+
domain?: string;
|
|
43
|
+
}
|
|
44
|
+
interface Mapping {
|
|
45
|
+
ga4?: GA4Mapping;
|
|
46
|
+
ads?: AdsMapping;
|
|
47
|
+
gtm?: GTMMapping;
|
|
48
|
+
}
|
|
49
|
+
interface GA4Mapping {
|
|
50
|
+
include?: Include;
|
|
51
|
+
}
|
|
52
|
+
interface GTMMapping {
|
|
53
|
+
}
|
|
54
|
+
type Rule = Mapping$1.Rule<Mapping>;
|
|
55
|
+
type Rules = Mapping$1.Rules<Rule>;
|
|
56
|
+
type Param = Mapping$1.Value;
|
|
57
|
+
type Include = Array<'all' | 'context' | 'data' | 'event' | 'globals' | 'source' | 'user' | 'version'>;
|
|
58
|
+
type Parameters = Gtag.ControlParams & Gtag.EventParams & Gtag.CustomParams;
|
|
59
|
+
|
|
60
|
+
type index$1_AdsMapping = AdsMapping;
|
|
61
|
+
type index$1_AdsSettings = AdsSettings;
|
|
62
|
+
type index$1_Config = Config;
|
|
63
|
+
type index$1_Destination = Destination;
|
|
64
|
+
type index$1_GA4Mapping = GA4Mapping;
|
|
65
|
+
type index$1_GA4Settings = GA4Settings;
|
|
66
|
+
type index$1_GTMMapping = GTMMapping;
|
|
67
|
+
type index$1_GTMSettings = GTMSettings;
|
|
68
|
+
type index$1_Include = Include;
|
|
69
|
+
type index$1_Mapping = Mapping;
|
|
70
|
+
type index$1_Param = Param;
|
|
71
|
+
type index$1_Parameters = Parameters;
|
|
72
|
+
type index$1_Rule = Rule;
|
|
73
|
+
type index$1_Rules = Rules;
|
|
74
|
+
type index$1_Settings = Settings;
|
|
75
|
+
type index$1_WindowData = WindowData;
|
|
76
|
+
declare namespace index$1 {
|
|
77
|
+
export type { index$1_AdsMapping as AdsMapping, index$1_AdsSettings as AdsSettings, index$1_Config as Config, index$1_Destination as Destination, index$1_GA4Mapping as GA4Mapping, index$1_GA4Settings as GA4Settings, index$1_GTMMapping as GTMMapping, index$1_GTMSettings as GTMSettings, index$1_Include as Include, index$1_Mapping as Mapping, index$1_Param as Param, index$1_Parameters as Parameters, index$1_Rule as Rule, index$1_Rules as Rules, index$1_Settings as Settings, index$1_WindowData as WindowData };
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
declare function ga4Purchase$1(): unknown[];
|
|
81
|
+
declare function ga4AddToCart$1(): unknown[];
|
|
82
|
+
declare function adsConversion$1(): unknown[];
|
|
83
|
+
declare function gtmEvent(): Record<string, unknown>;
|
|
84
|
+
|
|
85
|
+
declare const events_gtmEvent: typeof gtmEvent;
|
|
86
|
+
declare namespace events {
|
|
87
|
+
export { adsConversion$1 as adsConversion, ga4AddToCart$1 as ga4AddToCart, ga4Purchase$1 as ga4Purchase, events_gtmEvent as gtmEvent };
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
declare const ga4Purchase: Rule;
|
|
91
|
+
declare const ga4AddToCart: Rule;
|
|
92
|
+
declare const adsConversion: Rule;
|
|
93
|
+
declare const gtmProductView: Rule;
|
|
94
|
+
declare const combinedPurchase: Rule;
|
|
95
|
+
declare const config: {
|
|
96
|
+
order: {
|
|
97
|
+
complete: Rule;
|
|
98
|
+
};
|
|
99
|
+
product: {
|
|
100
|
+
add: Rule;
|
|
101
|
+
view: Rule;
|
|
102
|
+
};
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
declare const mapping_adsConversion: typeof adsConversion;
|
|
106
|
+
declare const mapping_combinedPurchase: typeof combinedPurchase;
|
|
107
|
+
declare const mapping_config: typeof config;
|
|
108
|
+
declare const mapping_ga4AddToCart: typeof ga4AddToCart;
|
|
109
|
+
declare const mapping_ga4Purchase: typeof ga4Purchase;
|
|
110
|
+
declare const mapping_gtmProductView: typeof gtmProductView;
|
|
111
|
+
declare namespace mapping {
|
|
112
|
+
export { mapping_adsConversion as adsConversion, mapping_combinedPurchase as combinedPurchase, mapping_config as config, mapping_ga4AddToCart as ga4AddToCart, mapping_ga4Purchase as ga4Purchase, mapping_gtmProductView as gtmProductView };
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
declare const index_events: typeof events;
|
|
116
|
+
declare const index_mapping: typeof mapping;
|
|
117
|
+
declare namespace index {
|
|
118
|
+
export { index_events as events, index_mapping as mapping };
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
declare const destinationGtag: Destination;
|
|
122
|
+
|
|
123
|
+
export { index$1 as DestinationGtag, destinationGtag as default, destinationGtag, index as examples };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Mapping as Mapping$1 } from '@walkeros/core';
|
|
2
|
+
import { DestinationWeb } from '@walkeros/web-core';
|
|
3
|
+
|
|
4
|
+
interface WindowWithDataLayer extends Window {
|
|
5
|
+
dataLayer: unknown[];
|
|
6
|
+
gtag?: Gtag.Gtag;
|
|
7
|
+
[key: string]: unknown;
|
|
8
|
+
}
|
|
9
|
+
declare global {
|
|
10
|
+
interface Window {
|
|
11
|
+
gtag?: Gtag.Gtag;
|
|
12
|
+
[key: string]: unknown;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
type WindowData = WindowWithDataLayer;
|
|
16
|
+
type Destination = DestinationWeb.Destination<Settings, Mapping>;
|
|
17
|
+
type Config = DestinationWeb.Config<Settings, Mapping>;
|
|
18
|
+
interface Settings {
|
|
19
|
+
ga4?: GA4Settings;
|
|
20
|
+
ads?: AdsSettings;
|
|
21
|
+
gtm?: GTMSettings;
|
|
22
|
+
}
|
|
23
|
+
interface GA4Settings {
|
|
24
|
+
measurementId: string;
|
|
25
|
+
debug?: boolean;
|
|
26
|
+
include?: Include;
|
|
27
|
+
pageview?: boolean;
|
|
28
|
+
server_container_url?: string;
|
|
29
|
+
snakeCase?: boolean;
|
|
30
|
+
transport_url?: string;
|
|
31
|
+
}
|
|
32
|
+
interface AdsSettings {
|
|
33
|
+
conversionId: string;
|
|
34
|
+
currency?: string;
|
|
35
|
+
}
|
|
36
|
+
interface AdsMapping {
|
|
37
|
+
label?: string;
|
|
38
|
+
}
|
|
39
|
+
interface GTMSettings {
|
|
40
|
+
containerId: string;
|
|
41
|
+
dataLayer?: string;
|
|
42
|
+
domain?: string;
|
|
43
|
+
}
|
|
44
|
+
interface Mapping {
|
|
45
|
+
ga4?: GA4Mapping;
|
|
46
|
+
ads?: AdsMapping;
|
|
47
|
+
gtm?: GTMMapping;
|
|
48
|
+
}
|
|
49
|
+
interface GA4Mapping {
|
|
50
|
+
include?: Include;
|
|
51
|
+
}
|
|
52
|
+
interface GTMMapping {
|
|
53
|
+
}
|
|
54
|
+
type Rule = Mapping$1.Rule<Mapping>;
|
|
55
|
+
type Rules = Mapping$1.Rules<Rule>;
|
|
56
|
+
type Param = Mapping$1.Value;
|
|
57
|
+
type Include = Array<'all' | 'context' | 'data' | 'event' | 'globals' | 'source' | 'user' | 'version'>;
|
|
58
|
+
type Parameters = Gtag.ControlParams & Gtag.EventParams & Gtag.CustomParams;
|
|
59
|
+
|
|
60
|
+
type index$1_AdsMapping = AdsMapping;
|
|
61
|
+
type index$1_AdsSettings = AdsSettings;
|
|
62
|
+
type index$1_Config = Config;
|
|
63
|
+
type index$1_Destination = Destination;
|
|
64
|
+
type index$1_GA4Mapping = GA4Mapping;
|
|
65
|
+
type index$1_GA4Settings = GA4Settings;
|
|
66
|
+
type index$1_GTMMapping = GTMMapping;
|
|
67
|
+
type index$1_GTMSettings = GTMSettings;
|
|
68
|
+
type index$1_Include = Include;
|
|
69
|
+
type index$1_Mapping = Mapping;
|
|
70
|
+
type index$1_Param = Param;
|
|
71
|
+
type index$1_Parameters = Parameters;
|
|
72
|
+
type index$1_Rule = Rule;
|
|
73
|
+
type index$1_Rules = Rules;
|
|
74
|
+
type index$1_Settings = Settings;
|
|
75
|
+
type index$1_WindowData = WindowData;
|
|
76
|
+
declare namespace index$1 {
|
|
77
|
+
export type { index$1_AdsMapping as AdsMapping, index$1_AdsSettings as AdsSettings, index$1_Config as Config, index$1_Destination as Destination, index$1_GA4Mapping as GA4Mapping, index$1_GA4Settings as GA4Settings, index$1_GTMMapping as GTMMapping, index$1_GTMSettings as GTMSettings, index$1_Include as Include, index$1_Mapping as Mapping, index$1_Param as Param, index$1_Parameters as Parameters, index$1_Rule as Rule, index$1_Rules as Rules, index$1_Settings as Settings, index$1_WindowData as WindowData };
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
declare function ga4Purchase$1(): unknown[];
|
|
81
|
+
declare function ga4AddToCart$1(): unknown[];
|
|
82
|
+
declare function adsConversion$1(): unknown[];
|
|
83
|
+
declare function gtmEvent(): Record<string, unknown>;
|
|
84
|
+
|
|
85
|
+
declare const events_gtmEvent: typeof gtmEvent;
|
|
86
|
+
declare namespace events {
|
|
87
|
+
export { adsConversion$1 as adsConversion, ga4AddToCart$1 as ga4AddToCart, ga4Purchase$1 as ga4Purchase, events_gtmEvent as gtmEvent };
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
declare const ga4Purchase: Rule;
|
|
91
|
+
declare const ga4AddToCart: Rule;
|
|
92
|
+
declare const adsConversion: Rule;
|
|
93
|
+
declare const gtmProductView: Rule;
|
|
94
|
+
declare const combinedPurchase: Rule;
|
|
95
|
+
declare const config: {
|
|
96
|
+
order: {
|
|
97
|
+
complete: Rule;
|
|
98
|
+
};
|
|
99
|
+
product: {
|
|
100
|
+
add: Rule;
|
|
101
|
+
view: Rule;
|
|
102
|
+
};
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
declare const mapping_adsConversion: typeof adsConversion;
|
|
106
|
+
declare const mapping_combinedPurchase: typeof combinedPurchase;
|
|
107
|
+
declare const mapping_config: typeof config;
|
|
108
|
+
declare const mapping_ga4AddToCart: typeof ga4AddToCart;
|
|
109
|
+
declare const mapping_ga4Purchase: typeof ga4Purchase;
|
|
110
|
+
declare const mapping_gtmProductView: typeof gtmProductView;
|
|
111
|
+
declare namespace mapping {
|
|
112
|
+
export { mapping_adsConversion as adsConversion, mapping_combinedPurchase as combinedPurchase, mapping_config as config, mapping_ga4AddToCart as ga4AddToCart, mapping_ga4Purchase as ga4Purchase, mapping_gtmProductView as gtmProductView };
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
declare const index_events: typeof events;
|
|
116
|
+
declare const index_mapping: typeof mapping;
|
|
117
|
+
declare namespace index {
|
|
118
|
+
export { index_events as events, index_mapping as mapping };
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
declare const destinationGtag: Destination;
|
|
122
|
+
|
|
123
|
+
export { index$1 as DestinationGtag, destinationGtag as default, destinationGtag, index as examples };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";function _array_like_to_array(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,a=new Array(t);r<t;r++)a[r]=e[r];return a}function _array_with_holes(e){if(Array.isArray(e))return e}function _array_without_holes(e){if(Array.isArray(e))return _array_like_to_array(e)}function _define_property(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function _iterable_to_array(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}function _iterable_to_array_limit(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var a,n,o=[],i=!0,c=!1;try{for(r=r.call(e);!(i=(a=r.next()).done)&&(o.push(a.value),!t||o.length!==t);i=!0);}catch(e){c=!0,n=e}finally{try{i||null==r.return||r.return()}finally{if(c)throw n}}return o}}function _non_iterable_rest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _non_iterable_spread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _object_spread(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{},a=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(r).filter(function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))),a.forEach(function(t){_define_property(e,t,r[t])})}return e}function ownKeys(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,a)}return r}function _object_spread_props(e,t){return t=null!=t?t:{},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):ownKeys(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))}),e}function _sliced_to_array(e,t){return _array_with_holes(e)||_iterable_to_array_limit(e,t)||_unsupported_iterable_to_array(e,t)||_non_iterable_rest()}function _to_consumable_array(e){return _array_without_holes(e)||_iterable_to_array(e)||_unsupported_iterable_to_array(e)||_non_iterable_spread()}function _type_of(e){return e&&"undefined"!=typeof Symbol&&e.constructor===Symbol?"symbol":typeof e}function _unsupported_iterable_to_array(e,t){if(e){if("string"==typeof e)return _array_like_to_array(e,t);var r=Object.prototype.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(r):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?_array_like_to_array(e,t):void 0}}var Destination=function(){var e=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"https://www.googletagmanager.com/gtag/js?id=";if(!h.has(e)){var r=document.createElement("script");r.src=t+e,document.head.appendChild(r),h.add(e)}},t=function(){var e=window;e.dataLayer=e.dataLayer||[],e.gtag||(e.gtag=function(){e.dataLayer.push(arguments)})},r=function(e){return e("gtag",window.gtag)},a=function(e){return"object"==(void 0===e?"undefined":_type_of(e))&&null!==e&&!function(e){return Array.isArray(e)}(e)&&"[object Object]"===Object.prototype.toString.call(e)},n=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.timestamp||(new Date).setHours(0,13,37,0),r=e.group||"gr0up",a=e.count||1,n=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};r=_object_spread({},O,r);var a=Object.entries(t).reduce(function(t,a){var n=_sliced_to_array(a,2),o=n[0],i=n[1],c=e[o];return r.merge&&Array.isArray(c)&&Array.isArray(i)?t[o]=i.reduce(function(e,t){return e.includes(t)?e:_to_consumable_array(e).concat([t])},_to_consumable_array(c)):(r.extend||o in e)&&(t[o]=i),t},{});return r.shallow?_object_spread({},e,a):(Object.assign(e,a),e)}({event:"entity action",data:{string:"foo",number:1,boolean:!0,array:[0,"text",!1],not:void 0},context:{dev:["test",1]},globals:{lang:"elb"},custom:{completely:"random"},user:{id:"us3r",device:"c00k13",session:"s3ss10n"},nested:[{type:"child",data:{is:"subordinated"},nested:[],context:{element:["child",0]}}],consent:{functional:!0},id:"".concat(t,"-").concat(r,"-").concat(a),trigger:"test",entity:"entity",action:"action",timestamp:t,timing:3.14,group:r,count:a,version:{source:k,tagging:1},source:{type:"web",id:"https://localhost:80",previous_id:"http://remotehost:9001"}},e,{merge:!1});if(e.event){var o,i=_sliced_to_array(null!==(o=e.event.split(" "))&&void 0!==o?o:[],2),c=i[0],s=i[1];c&&s&&(n.entity=c,n.action=s)}return n},o=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"entity action",t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=t.timestamp||(new Date).setHours(0,13,37,0),a={data:{id:"ers",name:"Everyday Ruck Snack",color:"black",size:"l",price:420}},o={data:{id:"cc",name:"Cool Cap",size:"one size",price:42}};return n(_object_spread_props(_object_spread({},{"cart view":{data:{currency:"EUR",value:2*a.data.price},context:{shopping:["cart",0]},globals:{pagegroup:"shop"},nested:[{type:"product",data:_object_spread_props(_object_spread({},a.data),{quantity:2}),context:{shopping:["cart",0]},nested:[]}],trigger:"load"},"checkout view":{data:{step:"payment",currency:"EUR",value:a.data.price+o.data.price},context:{shopping:["checkout",0]},globals:{pagegroup:"shop"},nested:[_object_spread_props(_object_spread({type:"product"},a),{context:{shopping:["checkout",0]},nested:[]}),_object_spread_props(_object_spread({type:"product"},o),{context:{shopping:["checkout",0]},nested:[]})],trigger:"load"},"order complete":{data:{id:"0rd3r1d",currency:"EUR",shipping:5.22,taxes:73.76,total:555},context:{shopping:["complete",0]},globals:{pagegroup:"shop"},nested:[_object_spread_props(_object_spread({type:"product"},a),{context:{shopping:["complete",0]},nested:[]}),_object_spread_props(_object_spread({type:"product"},o),{context:{shopping:["complete",0]},nested:[]}),{type:"gift",data:{name:"Surprise"},context:{shopping:["complete",0]},nested:[]}],trigger:"load"},"page view":{data:{domain:"www.example.com",title:"walkerOS documentation",referrer:"https://www.elbwalker.com/",search:"?foo=bar",hash:"#hash",id:"/docs/"},globals:{pagegroup:"docs"},trigger:"load"},"product add":_object_spread_props(_object_spread({},a),{context:{shopping:["intent",0]},globals:{pagegroup:"shop"},nested:[],trigger:"click"}),"product view":_object_spread_props(_object_spread({},a),{context:{shopping:["detail",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"}),"product visible":{data:_object_spread_props(_object_spread({},a.data),{position:3,promo:!0}),context:{shopping:["discover",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"},"promotion visible":{data:{name:"Setting up tracking easily",position:"hero"},context:{ab_test:["engagement",0]},globals:{pagegroup:"homepage"},trigger:"visible"},"session start":{data:{id:"s3ss10n",start:r,isNew:!0,count:1,runs:1,isStart:!0,storage:!0,referrer:"",device:"c00k13"},user:{id:"us3r",device:"c00k13",session:"s3ss10n",hash:"h4sh",address:"street number",email:"user@example.com",phone:"+49 123 456 789",userAgent:"Mozilla...",browser:"Chrome",browserVersion:"90",deviceType:"desktop",language:"de-DE",country:"DE",region:"HH",city:"Hamburg",zip:"20354",timezone:"Berlin",os:"walkerOS",osVersion:"1.0",screenSize:"1337x420",ip:"127.0.0.0",internal:!0,custom:"value"}}}[e],t),{event:e}))},i=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;if(t.measurementId){var c=a(o)?o:{},s=function(e,t){var r={};return t.includes("all")&&(t=["context","data","event","globals","source","user","version"]),t.forEach(function(t){var a=e[t]||{};"event"==t&&(a={id:e.id,timing:e.timing,trigger:e.trigger,entity:e.entity,action:e.action,group:e.group,count:e.count}),Object.entries(a).forEach(function(e){var a=_sliced_to_array(e,2),n=a[0],o=a[1];"context"==t&&(o=o[0]),r["".concat(t,"_").concat(n)]=o})}),r}(e,n.include||t.include||["data"]),d=_object_spread({},s,c),u=e.event;!1!==t.snakeCase&&(u=function(e){return arguments.length>1&&void 0!==arguments[1]&&!arguments[1]?e:e.replace(/\s+/g,"_").toLowerCase()}(u)),d.send_to=t.measurementId,t.debug&&(d.debug_mode=!0),r(i)("event",u,d)}},c=function(e,t,r){var a=r!=x?"&l="+r:"",n=document.createElement("script");n.src=t+e+a,document.head.appendChild(n)},s=function(){var e=o("order complete");return["event","purchase",{transaction_id:e.data.id,value:e.data.total,tax:e.data.taxes,shipping:e.data.shipping,currency:"EUR",items:e.nested.filter(function(e){return"product"===e.type}).map(function(e){return{item_id:e.data.id,item_name:e.data.name,quantity:1}}),send_to:"G-XXXXXX-1"}]},d=function(){var e=o("product add");return["event","add_to_cart",{currency:"EUR",value:e.data.price,items:[{item_id:e.data.id,item_variant:e.data.color,quantity:1}],send_to:"G-XXXXXX-1"}]},u=function(){var e=o("order complete");return["event","conversion",{send_to:"AW-XXXXXXXXX/CONVERSION_LABEL",currency:"EUR",value:e.data.total,transaction_id:e.data.id}]},l=function(){var e=o("product view");return{event:"product_view",product_id:e.data.id,product_name:e.data.name,product_category:e.data.category,value:e.data.price,currency:"EUR"}},p=Object.defineProperty,g=Object.getOwnPropertyDescriptor,_=Object.getOwnPropertyNames,y=Object.prototype.hasOwnProperty,m=function(e,t){for(var r in t)p(e,r,{get:t[r],enumerable:!0})},v={};m(v,{DestinationGtag:function(){return E},default:function(){return N},destinationGtag:function(){return z},examples:function(){return I}});var f,b,h=new Set,w=Object.getOwnPropertyNames,j=(f={"package.json":function(e,t){t.exports={name:"@walkeros/core",description:"Core types and platform-agnostic utilities for walkerOS",version:"0.0.7",main:"./dist/index.js",module:"./dist/index.mjs",types:"./dist/index.d.ts",license:"MIT",files:["dist/**"],scripts:{build:"tsup --silent",clean:"rm -rf .turbo && rm -rf node_modules && rm -rf dist",dev:"jest --watchAll --colors",lint:'tsc && eslint "**/*.ts*"',test:"jest",update:"npx npm-check-updates -u && npm update"},dependencies:{},devDependencies:{},repository:{url:"git+https://github.com/elbwalker/walkerOS.git",directory:"packages/core"},author:"elbwalker <hello@elbwalker.com>",homepage:"https://github.com/elbwalker/walkerOS#readme",bugs:{url:"https://github.com/elbwalker/walkerOS/issues"},keywords:["walker","walkerOS","analytics","tracking","data collection","measurement","data privacy","privacy friendly","web analytics","product analytics","core","types","utils"],funding:[{type:"GitHub Sponsors",url:"https://github.com/sponsors/elbwalker"}]}}},function(){return b||(0,f[w(f)[0]])((b={exports:{}}).exports,b),b.exports}),O={merge:!0,shallow:!0,extend:!0},k=j().version,x="dataLayer",S="https://www.googletagmanager.com/gtm.js?id=",E={},I={};m(I,{events:function(){return A},mapping:function(){return P}});var A={};m(A,{adsConversion:function(){return u},ga4AddToCart:function(){return d},ga4Purchase:function(){return s},gtmEvent:function(){return l}});var P={};m(P,{adsConversion:function(){return L},combinedPurchase:function(){return U},config:function(){return q},ga4AddToCart:function(){return D},ga4Purchase:function(){return R},gtmProductView:function(){return C}});var X,R={name:"purchase",settings:{ga4:{include:["data","context"]}},data:{map:{transaction_id:"data.id",value:"data.total",tax:"data.taxes",shipping:"data.shipping",currency:{key:"data.currency",value:"EUR"},items:{loop:["nested",{condition:function(e){return a(e)&&"product"===e.type},map:{item_id:"data.id",item_name:"data.name",quantity:{key:"data.quantity",value:1}}}]}}}},D={name:"add_to_cart",settings:{ga4:{include:["data"]}},data:{map:{currency:{value:"EUR",key:"data.currency"},value:"data.price",items:{loop:["this",{map:{item_id:"data.id",item_variant:"data.color",quantity:{value:1,key:"data.quantity"}}}]}}}},L={name:"CONVERSION_LABEL",settings:{ads:{}},data:{map:{value:"data.total",currency:{value:"EUR",key:"data.currency"},transaction_id:"data.id"}}},C={name:"product_view",settings:{gtm:{}},data:{map:{product_id:"data.id",product_name:"data.name",product_category:"data.category",value:"data.price",currency:{value:"EUR",key:"data.currency"}}}},U={name:"purchase",settings:{ga4:{include:["data"]},ads:{},gtm:{}},data:{map:{transaction_id:"data.id",value:"data.total",currency:{value:"EUR",key:"data.currency"},items:{loop:["nested",{condition:function(e){return a(e)&&"product"===e.type},map:{item_id:"data.id",item_name:"data.name",quantity:{value:1,key:"data.quantity"}}}]}}}},q={order:{complete:U},product:{add:D,view:C}},z={type:"google-gtag",config:{settings:{}},init:function(a){var n=a.config,o=a.wrap,i=n.settings,s=void 0===i?{}:i,d=n.loadScript,u=s.ga4,l=s.ads,p=s.gtm;return(null==u?void 0:u.measurementId)&&function(a,n,o){var i=a.measurementId,c=a.transport_url,s=a.server_container_url,d=a.pageview;if(i){o&&e(i),t();var u={};c&&(u.transport_url=c),s&&(u.server_container_url=s),!1===d&&(u.send_page_view=!1);var l=r(n);l("js",new Date),l("config",i,u)}}(u,o,d),(null==l?void 0:l.conversionId)&&function(a,n,o){var i=a.conversionId;if(i){a.currency||(a.currency="EUR"),o&&e(i),t();var c=r(n);c("js",new Date),c("config",i)}}(l,o,d),(null==p?void 0:p.containerId)&&function(e,t,r){var a=e.containerId,n=e.dataLayer,o=e.domain,i=n||x,s=window;i===x?s.dataLayer=s.dataLayer||[]:s[i]=s[i]||[];var d=s[i];t("dataLayer.push",d.push.bind(d))({"gtm.start":(new Date).getTime(),event:"gtm.js"}),r&&a&&c(a,o||S,i)}(p,o,d),!!((null==u?void 0:u.measurementId)||(null==l?void 0:l.conversionId)||(null==p?void 0:p.containerId))&&n},push:function(e,t){var n=t.config,o=t.mapping,c=void 0===o?{}:o,s=t.data,d=t.wrap,u=n.settings,l=void 0===u?{}:u,p=l.ga4,g=l.ads,_=l.gtm,y=c.settings||{};(null==p?void 0:p.measurementId)&&i(e,p,y.ga4,s,d),(null==g?void 0:g.conversionId)&&c.name&&function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0,c=arguments.length>5?arguments[5]:void 0,s=t.conversionId,d=t.currency,u=a(o)?o:{},l=n.label||c;if(l){var p=_object_spread({send_to:"".concat(s,"/").concat(l),currency:d||"EUR"},u);r(i)("event","conversion",p)}}(e,g,y.ads,s,d,c.name),(null==_?void 0:_.containerId)&&function(e,t){var r=arguments.length>3?arguments[3]:void 0,n=window;(arguments.length>4?arguments[4]:void 0)("dataLayer.push",n.dataLayer.push.bind(n.dataLayer))(_object_spread({},{event:e.event},a(r)?r:e))}(e,_,y.gtm,s,d)}},N=z;return X=v,function(e,t,r,a){if(t&&"object"===(void 0===t?"undefined":_type_of(t))||"function"==typeof t){var n=!0,o=!1,i=void 0;try{for(var c,s=function(){var n=c.value;y.call(e,n)||n===r||p(e,n,{get:function(){return t[n]},enumerable:!(a=g(t,n))||a.enumerable})},d=_(t)[Symbol.iterator]();!(n=(c=d.next()).done);n=!0)s()}catch(e){o=!0,i=e}finally{try{n||null==d.return||d.return()}finally{if(o)throw i}}}return e}(p({},"__esModule",{value:!0}),X)}();
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";var e,t=Object.defineProperty,a=Object.getOwnPropertyDescriptor,n=Object.getOwnPropertyNames,r=Object.prototype.hasOwnProperty,o=(e,a)=>{for(var n in a)t(e,n,{get:a[n],enumerable:!0})},i={};o(i,{DestinationGtag:()=>x,default:()=>z,destinationGtag:()=>P,examples:()=>E}),module.exports=(e=i,((e,o,i,s)=>{if(o&&"object"==typeof o||"function"==typeof o)for(let c of n(o))r.call(e,c)||c===i||t(e,c,{get:()=>o[c],enumerable:!(s=a(o,c))||s.enumerable});return e})(t({},"__esModule",{value:!0}),e));var s,c,d=new Set;function u(e,t="https://www.googletagmanager.com/gtag/js?id="){if(d.has(e))return;const a=document.createElement("script");a.src=t+e,document.head.appendChild(a),d.add(e)}function p(){const e=window;e.dataLayer=e.dataLayer||[],e.gtag||(e.gtag=function(){e.dataLayer.push(arguments)})}function l(e){return e("gtag",window.gtag)}var g=Object.getOwnPropertyNames,m=(s={"package.json"(e,t){t.exports={name:"@walkeros/core",description:"Core types and platform-agnostic utilities for walkerOS",version:"0.0.7",main:"./dist/index.js",module:"./dist/index.mjs",types:"./dist/index.d.ts",license:"MIT",files:["dist/**"],scripts:{build:"tsup --silent",clean:"rm -rf .turbo && rm -rf node_modules && rm -rf dist",dev:"jest --watchAll --colors",lint:'tsc && eslint "**/*.ts*"',test:"jest",update:"npx npm-check-updates -u && npm update"},dependencies:{},devDependencies:{},repository:{url:"git+https://github.com/elbwalker/walkerOS.git",directory:"packages/core"},author:"elbwalker <hello@elbwalker.com>",homepage:"https://github.com/elbwalker/walkerOS#readme",bugs:{url:"https://github.com/elbwalker/walkerOS/issues"},keywords:["walker","walkerOS","analytics","tracking","data collection","measurement","data privacy","privacy friendly","web analytics","product analytics","core","types","utils"],funding:[{type:"GitHub Sponsors",url:"https://github.com/sponsors/elbwalker"}]}}},function(){return c||(0,s[g(s)[0]])((c={exports:{}}).exports,c),c.exports}),y={merge:!0,shallow:!0,extend:!0};function v(e){return"object"==typeof e&&null!==e&&!function(e){return Array.isArray(e)}(e)&&"[object Object]"===Object.prototype.toString.call(e)}var{version:h}=m();function w(e={}){var t;const a=e.timestamp||(new Date).setHours(0,13,37,0),n=e.group||"gr0up",r=e.count||1,o=function(e,t={},a={}){a={...y,...a};const n=Object.entries(t).reduce((t,[n,r])=>{const o=e[n];return a.merge&&Array.isArray(o)&&Array.isArray(r)?t[n]=r.reduce((e,t)=>e.includes(t)?e:[...e,t],[...o]):(a.extend||n in e)&&(t[n]=r),t},{});return a.shallow?{...e,...n}:(Object.assign(e,n),e)}({event:"entity action",data:{string:"foo",number:1,boolean:!0,array:[0,"text",!1],not:void 0},context:{dev:["test",1]},globals:{lang:"elb"},custom:{completely:"random"},user:{id:"us3r",device:"c00k13",session:"s3ss10n"},nested:[{type:"child",data:{is:"subordinated"},nested:[],context:{element:["child",0]}}],consent:{functional:!0},id:`${a}-${n}-${r}`,trigger:"test",entity:"entity",action:"action",timestamp:a,timing:3.14,group:n,count:r,version:{source:h,tagging:1},source:{type:"web",id:"https://localhost:80",previous_id:"http://remotehost:9001"}},e,{merge:!1});if(e.event){const[a,n]=null!=(t=e.event.split(" "))?t:[];a&&n&&(o.entity=a,o.action=n)}return o}function b(e="entity action",t={}){const a=t.timestamp||(new Date).setHours(0,13,37,0),n={data:{id:"ers",name:"Everyday Ruck Snack",color:"black",size:"l",price:420}},r={data:{id:"cc",name:"Cool Cap",size:"one size",price:42}};return w({...{"cart view":{data:{currency:"EUR",value:2*n.data.price},context:{shopping:["cart",0]},globals:{pagegroup:"shop"},nested:[{type:"product",data:{...n.data,quantity:2},context:{shopping:["cart",0]},nested:[]}],trigger:"load"},"checkout view":{data:{step:"payment",currency:"EUR",value:n.data.price+r.data.price},context:{shopping:["checkout",0]},globals:{pagegroup:"shop"},nested:[{type:"product",...n,context:{shopping:["checkout",0]},nested:[]},{type:"product",...r,context:{shopping:["checkout",0]},nested:[]}],trigger:"load"},"order complete":{data:{id:"0rd3r1d",currency:"EUR",shipping:5.22,taxes:73.76,total:555},context:{shopping:["complete",0]},globals:{pagegroup:"shop"},nested:[{type:"product",...n,context:{shopping:["complete",0]},nested:[]},{type:"product",...r,context:{shopping:["complete",0]},nested:[]},{type:"gift",data:{name:"Surprise"},context:{shopping:["complete",0]},nested:[]}],trigger:"load"},"page view":{data:{domain:"www.example.com",title:"walkerOS documentation",referrer:"https://www.elbwalker.com/",search:"?foo=bar",hash:"#hash",id:"/docs/"},globals:{pagegroup:"docs"},trigger:"load"},"product add":{...n,context:{shopping:["intent",0]},globals:{pagegroup:"shop"},nested:[],trigger:"click"},"product view":{...n,context:{shopping:["detail",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"},"product visible":{data:{...n.data,position:3,promo:!0},context:{shopping:["discover",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"},"promotion visible":{data:{name:"Setting up tracking easily",position:"hero"},context:{ab_test:["engagement",0]},globals:{pagegroup:"homepage"},trigger:"visible"},"session start":{data:{id:"s3ss10n",start:a,isNew:!0,count:1,runs:1,isStart:!0,storage:!0,referrer:"",device:"c00k13"},user:{id:"us3r",device:"c00k13",session:"s3ss10n",hash:"h4sh",address:"street number",email:"user@example.com",phone:"+49 123 456 789",userAgent:"Mozilla...",browser:"Chrome",browserVersion:"90",deviceType:"desktop",language:"de-DE",country:"DE",region:"HH",city:"Hamburg",zip:"20354",timezone:"Berlin",os:"walkerOS",osVersion:"1.0",screenSize:"1337x420",ip:"127.0.0.0",internal:!0,custom:"value"}}}[e],...t,event:e})}function f(e,t,a={},n,r){if(!t.measurementId)return;const o=v(n)?n:{},i=function(e,t){const a={};return t.includes("all")&&(t=["context","data","event","globals","source","user","version"]),t.forEach(t=>{let n=e[t]||{};"event"==t&&(n={id:e.id,timing:e.timing,trigger:e.trigger,entity:e.entity,action:e.action,group:e.group,count:e.count}),Object.entries(n).forEach(([e,n])=>{"context"==t&&(n=n[0]),a[`${t}_${e}`]=n})}),a}(e,a.include||t.include||["data"]),s={...i,...o};let c=e.event;!1!==t.snakeCase&&(c=function(e,t=!0){return t?e.replace(/\s+/g,"_").toLowerCase():e}(c)),s.send_to=t.measurementId,t.debug&&(s.debug_mode=!0);l(r)("event",c,s)}var _="dataLayer";function k(e,t,a){const{containerId:n,dataLayer:r,domain:o}=e,i=r||_,s=window;i===_?s.dataLayer=s.dataLayer||[]:s[i]=s[i]||[];const c=s[i];t("dataLayer.push",c.push.bind(c))({"gtm.start":(new Date).getTime(),event:"gtm.js"}),a&&n&&function(e,t,a){const n=a!=_?"&l="+a:"",r=document.createElement("script");r.src=t+e+n,document.head.appendChild(r)}(n,o||"https://www.googletagmanager.com/gtm.js?id=",i)}var x={},E={};o(E,{events:()=>O,mapping:()=>R});var O={};function j(){const e=b("order complete");return["event","purchase",{transaction_id:e.data.id,value:e.data.total,tax:e.data.taxes,shipping:e.data.shipping,currency:"EUR",items:e.nested.filter(e=>"product"===e.type).map(e=>({item_id:e.data.id,item_name:e.data.name,quantity:1})),send_to:"G-XXXXXX-1"}]}function X(){const e=b("product add");return["event","add_to_cart",{currency:"EUR",value:e.data.price,items:[{item_id:e.data.id,item_variant:e.data.color,quantity:1}],send_to:"G-XXXXXX-1"}]}function I(){const e=b("order complete");return["event","conversion",{send_to:"AW-XXXXXXXXX/CONVERSION_LABEL",currency:"EUR",value:e.data.total,transaction_id:e.data.id}]}function S(){const e=b("product view");return{event:"product_view",product_id:e.data.id,product_name:e.data.name,product_category:e.data.category,value:e.data.price,currency:"EUR"}}o(O,{adsConversion:()=>I,ga4AddToCart:()=>X,ga4Purchase:()=>j,gtmEvent:()=>S});var R={};o(R,{adsConversion:()=>U,combinedPurchase:()=>D,config:()=>q,ga4AddToCart:()=>C,ga4Purchase:()=>L,gtmProductView:()=>A});var L={name:"purchase",settings:{ga4:{include:["data","context"]}},data:{map:{transaction_id:"data.id",value:"data.total",tax:"data.taxes",shipping:"data.shipping",currency:{key:"data.currency",value:"EUR"},items:{loop:["nested",{condition:e=>v(e)&&"product"===e.type,map:{item_id:"data.id",item_name:"data.name",quantity:{key:"data.quantity",value:1}}}]}}}},C={name:"add_to_cart",settings:{ga4:{include:["data"]}},data:{map:{currency:{value:"EUR",key:"data.currency"},value:"data.price",items:{loop:["this",{map:{item_id:"data.id",item_variant:"data.color",quantity:{value:1,key:"data.quantity"}}}]}}}},U={name:"CONVERSION_LABEL",settings:{ads:{}},data:{map:{value:"data.total",currency:{value:"EUR",key:"data.currency"},transaction_id:"data.id"}}},A={name:"product_view",settings:{gtm:{}},data:{map:{product_id:"data.id",product_name:"data.name",product_category:"data.category",value:"data.price",currency:{value:"EUR",key:"data.currency"}}}},D={name:"purchase",settings:{ga4:{include:["data"]},ads:{},gtm:{}},data:{map:{transaction_id:"data.id",value:"data.total",currency:{value:"EUR",key:"data.currency"},items:{loop:["nested",{condition:e=>v(e)&&"product"===e.type,map:{item_id:"data.id",item_name:"data.name",quantity:{value:1,key:"data.quantity"}}}]}}}},q={order:{complete:D},product:{add:C,view:A}},P={type:"google-gtag",config:{settings:{}},init({config:e,wrap:t}){const{settings:a={},loadScript:n}=e,{ga4:r,ads:o,gtm:i}=a;return(null==r?void 0:r.measurementId)&&function(e,t,a){const{measurementId:n,transport_url:r,server_container_url:o,pageview:i}=e;if(!n)return;a&&u(n),p();const s={};r&&(s.transport_url=r),o&&(s.server_container_url=o),!1===i&&(s.send_page_view=!1);const c=l(t);c("js",new Date),c("config",n,s)}(r,t,n),(null==o?void 0:o.conversionId)&&function(e,t,a){const{conversionId:n}=e;if(!n)return;e.currency||(e.currency="EUR"),a&&u(n),p();const r=l(t);r("js",new Date),r("config",n)}(o,t,n),(null==i?void 0:i.containerId)&&k(i,t,n),!!((null==r?void 0:r.measurementId)||(null==o?void 0:o.conversionId)||(null==i?void 0:i.containerId))&&e},push(e,{config:t,mapping:a={},data:n,wrap:r}){const{settings:o={}}=t,{ga4:i,ads:s,gtm:c}=o,d=a.settings||{};(null==i?void 0:i.measurementId)&&f(e,i,d.ga4,n,r),(null==s?void 0:s.conversionId)&&a.name&&function(e,t,a={},n,r,o){const{conversionId:i,currency:s}=t,c=v(n)?n:{},d=a.label||o;if(!d)return;const u={send_to:`${i}/${d}`,currency:s||"EUR",...c};l(r)("event","conversion",u)}(0,s,d.ads,n,r,a.name),(null==c?void 0:c.containerId)&&function(e,t,a={},n,r){const o=window;r("dataLayer.push",o.dataLayer.push.bind(o.dataLayer))({event:e.event,...v(n)?n:e})}(e,0,d.gtm,n,r)}},z=P;//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/shared/gtag.ts","../src/ga4/config.ts","../src/shared/parameters.ts","../src/shared/mapping.ts","../src/ga4/push.ts","../src/ads/config.ts","../src/ads/push.ts","../src/gtm/config.ts","../src/gtm/push.ts","../src/types/index.ts","../src/examples/index.ts","../src/examples/events.ts","../src/examples/mapping.ts"],"sourcesContent":["import type { WalkerOS } from '@walkeros/core';\nimport type { Settings, Destination } from './types';\nimport { initGA4, pushGA4Event } from './ga4';\nimport { initAds, pushAdsEvent } from './ads';\nimport { initGTM, pushGTMEvent } from './gtm';\n\n// Types\nexport * as DestinationGtag from './types';\n\n// Examples\nexport * as examples from './examples';\n\nexport const destinationGtag: Destination = {\n type: 'google-gtag',\n\n config: { settings: {} },\n\n init({ config, wrap }) {\n const { settings = {} as Partial<Settings>, loadScript } = config;\n const { ga4, ads, gtm } = settings;\n\n // Initialize GA4 if configured\n if (ga4?.measurementId) {\n initGA4(ga4, wrap, loadScript);\n }\n\n // Initialize Google Ads if configured\n if (ads?.conversionId) {\n initAds(ads, wrap, loadScript);\n }\n\n // Initialize GTM if configured\n if (gtm?.containerId) {\n initGTM(gtm, wrap, loadScript);\n }\n\n // Fail if no tools are configured\n if (!ga4?.measurementId && !ads?.conversionId && !gtm?.containerId) {\n return false;\n }\n\n return config;\n },\n\n push(event, { config, mapping = {}, data, wrap }) {\n const { settings = {} } = config;\n const { ga4, ads, gtm } = settings;\n const eventMapping = mapping.settings || {};\n\n // Push to GA4 if configured\n if (ga4?.measurementId) {\n pushGA4Event(\n event,\n ga4,\n eventMapping.ga4,\n data as WalkerOS.AnyObject,\n wrap,\n );\n }\n\n // Push to Google Ads if configured and has mapping name\n if (ads?.conversionId && mapping.name) {\n pushAdsEvent(\n event,\n ads,\n eventMapping.ads,\n data as WalkerOS.AnyObject,\n wrap,\n mapping.name,\n );\n }\n\n // Push to GTM if configured\n if (gtm?.containerId) {\n pushGTMEvent(\n event,\n gtm,\n eventMapping.gtm,\n data as WalkerOS.AnyObject,\n wrap,\n );\n }\n },\n};\n\nexport default destinationGtag;\n","// Gtag script loading and initialization utilities\n\nconst loadedScripts = new Set<string>();\n\n// For testing: allow resetting loaded scripts\nexport function resetLoadedScripts(): void {\n loadedScripts.clear();\n}\n\nexport function addScript(\n id: string,\n src = 'https://www.googletagmanager.com/gtag/js?id=',\n): void {\n // Prevent loading the same script multiple times\n if (loadedScripts.has(id)) return;\n\n const script = document.createElement('script');\n script.src = src + id;\n document.head.appendChild(script);\n loadedScripts.add(id);\n}\n\nexport function initializeGtag(): void {\n const w = window;\n\n // Setup dataLayer if not exists\n w.dataLayer = w.dataLayer || [];\n\n // Setup gtag function if not exists\n if (!w.gtag) {\n w.gtag = function () {\n (w.dataLayer as unknown[]).push(arguments);\n };\n }\n}\n\nexport function getGtag(\n wrap: (name: string, fn: Function) => Function,\n): Gtag.Gtag {\n return wrap('gtag', window.gtag) as Gtag.Gtag;\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GA4Settings } from '../types';\nimport { addScript, initializeGtag, getGtag } from '../shared/gtag';\n\nexport function initGA4(\n settings: GA4Settings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { measurementId, transport_url, server_container_url, pageview } =\n settings;\n\n if (!measurementId) return;\n\n // Load the gtag script\n if (loadScript) addScript(measurementId);\n\n // Initialize gtag infrastructure\n initializeGtag();\n\n const gtagSettings: WalkerOS.AnyObject = {};\n\n // custom transport_url\n if (transport_url) gtagSettings.transport_url = transport_url;\n\n // custom server_container_url\n if (server_container_url)\n gtagSettings.server_container_url = server_container_url;\n\n // disable pageviews\n if (pageview === false) gtagSettings.send_page_view = false;\n\n const gtag = getGtag(wrap);\n gtag('js', new Date());\n\n // gtag init call\n gtag('config', measurementId, gtagSettings);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { Include, Parameters } from '../types';\n\nexport function getParamsInclude(\n event: WalkerOS.DeepPartialEvent,\n include: Include,\n): Parameters {\n const params: Parameters = {};\n\n // Check for the 'all' group to add each group\n if (include.includes('all'))\n include = [\n 'context',\n 'data',\n 'event',\n 'globals',\n 'source',\n 'user',\n 'version',\n ];\n\n include.forEach((groupName) => {\n let group = event[groupName as keyof Omit<WalkerOS.Event, 'all'>] || {};\n\n // Create a fake group for event properties\n if (groupName == 'event')\n group = {\n id: event.id,\n timing: event.timing,\n trigger: event.trigger,\n entity: event.entity,\n action: event.action,\n group: event.group,\n count: event.count,\n };\n\n Object.entries(group).forEach(([key, val]) => {\n // Different value access for context\n if (groupName == 'context') val = (val as WalkerOS.OrderedProperties)[0];\n\n params[`${groupName}_${key}`] = val;\n });\n });\n\n return params;\n}\n","// Shared mapping utilities for all Google tools\n\nexport function normalizeEventName(\n eventName: string,\n snakeCase = true,\n): string {\n if (!snakeCase) return eventName;\n\n return eventName.replace(/\\s+/g, '_').toLowerCase();\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GA4Settings, GA4Mapping, Parameters } from '../types';\nimport { isObject } from '@walkeros/core';\nimport { getParamsInclude } from '../shared/parameters';\nimport { normalizeEventName } from '../shared/mapping';\nimport { getGtag } from '../shared/gtag';\n\nexport function pushGA4Event(\n event: WalkerOS.Event,\n settings: GA4Settings,\n mapping: GA4Mapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n): void {\n if (!settings.measurementId) return;\n\n const eventData = isObject(data) ? data : {};\n\n const paramsInclude = getParamsInclude(\n event,\n // Add data to include by default\n mapping.include || settings.include || ['data'],\n );\n\n const eventParams: Parameters = {\n ...paramsInclude,\n ...eventData,\n };\n\n // Event name (snake_case default)\n let eventName = event.event; // Assume custom mapped name\n if (settings.snakeCase !== false) {\n // Use snake case if not disabled\n eventName = normalizeEventName(eventName);\n }\n\n // Set the GA4 stream id\n eventParams.send_to = settings.measurementId;\n\n // Debug mode\n if (settings.debug) eventParams.debug_mode = true;\n\n const gtag = getGtag(wrap);\n gtag('event', eventName, eventParams);\n}\n","import type { AdsSettings } from '../types';\nimport { addScript, initializeGtag, getGtag } from '../shared/gtag';\n\nexport function initAds(\n settings: AdsSettings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { conversionId } = settings;\n\n if (!conversionId) return;\n\n // Default currency value\n if (!settings.currency) settings.currency = 'EUR';\n\n if (loadScript) addScript(conversionId);\n\n // Initialize gtag infrastructure\n initializeGtag();\n\n const gtag = getGtag(wrap);\n gtag('js', new Date());\n\n // gtag init call\n gtag('config', conversionId);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { AdsSettings, AdsMapping } from '../types';\nimport { isObject } from '@walkeros/core';\nimport { getGtag } from '../shared/gtag';\n\nexport function pushAdsEvent(\n event: WalkerOS.Event,\n settings: AdsSettings,\n mapping: AdsMapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n mappingName?: string,\n): void {\n const { conversionId, currency } = settings;\n const eventData = isObject(data) ? data : {};\n\n // Use label from mapping settings, fallback to mappingName for backward compatibility\n const conversionLabel = mapping.label || mappingName;\n if (!conversionLabel) return;\n\n const params: Gtag.CustomParams = {\n send_to: `${conversionId}/${conversionLabel}`,\n currency: currency || 'EUR',\n ...eventData,\n };\n\n const gtag = getGtag(wrap);\n gtag('event', 'conversion', params);\n}\n","import type { GTMSettings, WindowData } from '../types';\n\nconst defaultDataLayer = 'dataLayer';\nconst defaultDomain = 'https://www.googletagmanager.com/gtm.js?id=';\n\nexport function initGTM(\n settings: GTMSettings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { containerId, dataLayer, domain } = settings;\n const dataLayerName = dataLayer || defaultDataLayer;\n\n const win = window as WindowData;\n\n // Initialize the dataLayer (default or custom name)\n if (dataLayerName === defaultDataLayer) {\n win.dataLayer = win.dataLayer || [];\n } else {\n win[dataLayerName] = (win[dataLayerName] as unknown[]) || [];\n }\n\n // Get the appropriate dataLayer array\n const dataLayerArray = win[dataLayerName] as unknown[];\n\n const push = wrap('dataLayer.push', dataLayerArray.push.bind(dataLayerArray));\n push({\n 'gtm.start': new Date().getTime(),\n event: 'gtm.js',\n });\n\n // Load the gtm script and container\n if (loadScript && containerId)\n addScript(containerId, domain || defaultDomain, dataLayerName);\n}\n\nfunction addScript(containerId: string, src: string, dataLayerName: string) {\n const dl = dataLayerName != defaultDataLayer ? '&l=' + dataLayerName : '';\n const script = document.createElement('script');\n script.src = src + containerId + dl;\n document.head.appendChild(script);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GTMSettings, GTMMapping, WindowData } from '../types';\nimport { isObject } from '@walkeros/core';\n\nexport function pushGTMEvent(\n event: WalkerOS.Event,\n settings: GTMSettings,\n mapping: GTMMapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n): void {\n const win = window as WindowData;\n const push = wrap('dataLayer.push', win.dataLayer.push.bind(win.dataLayer));\n const obj = { event: event.event }; // Use the name mapping by default\n\n push({\n ...obj,\n ...(isObject(data) ? data : event),\n });\n}\n","import type { Mapping as WalkerOSMapping } from '@walkeros/core';\nimport type { DestinationWeb } from '@walkeros/web-core';\n\n// Extend Window interface with specific dataLayer typing\ninterface WindowWithDataLayer extends Window {\n dataLayer: unknown[];\n gtag?: Gtag.Gtag;\n [key: string]: unknown; // For custom dataLayer names and other properties\n}\n\ndeclare global {\n interface Window {\n gtag?: Gtag.Gtag;\n [key: string]: unknown; // For custom dataLayer names and other properties\n }\n}\n\n// Export helper type for internal use\nexport type WindowData = WindowWithDataLayer;\n\nexport type Destination = DestinationWeb.Destination<Settings, Mapping>;\nexport type Config = DestinationWeb.Config<Settings, Mapping>;\n\n// Unified settings for all Google tools\nexport interface Settings {\n // GA4 settings\n ga4?: GA4Settings;\n // Google Ads settings\n ads?: AdsSettings;\n // GTM settings\n gtm?: GTMSettings;\n}\n\n// GA4-specific settings\nexport interface GA4Settings {\n measurementId: string;\n debug?: boolean;\n include?: Include;\n pageview?: boolean;\n server_container_url?: string;\n snakeCase?: boolean;\n transport_url?: string;\n}\n\n// Google Ads specific settings\nexport interface AdsSettings {\n conversionId: string;\n currency?: string;\n}\n\n// Google Ads specific mapping\nexport interface AdsMapping {\n label?: string; // Conversion label for this specific event\n}\n\n// GTM specific settings\nexport interface GTMSettings {\n containerId: string;\n dataLayer?: string;\n domain?: string;\n}\n\n// Unified mapping interface\nexport interface Mapping {\n ga4?: GA4Mapping;\n ads?: AdsMapping;\n gtm?: GTMMapping;\n}\n\n// GA4-specific mapping\nexport interface GA4Mapping {\n include?: Include;\n}\n\n// GTM specific mapping\nexport interface GTMMapping {}\n\nexport type Rule = WalkerOSMapping.Rule<Mapping>;\nexport type Rules = WalkerOSMapping.Rules<Rule>;\nexport type Param = WalkerOSMapping.Value;\n\nexport type Include = Array<\n | 'all'\n | 'context'\n | 'data'\n | 'event'\n | 'globals'\n | 'source'\n | 'user'\n | 'version'\n>;\n\nexport type Parameters = Gtag.ControlParams &\n Gtag.EventParams &\n Gtag.CustomParams;\n","export * as events from './events';\nexport * as mapping from './mapping';\n","import { getEvent } from '@walkeros/core';\n\n// GA4 Purchase Event Example\nexport function ga4Purchase(): unknown[] {\n const event = getEvent('order complete');\n\n return [\n 'event',\n 'purchase',\n {\n transaction_id: event.data.id,\n value: event.data.total,\n tax: event.data.taxes,\n shipping: event.data.shipping,\n currency: 'EUR',\n items: event.nested\n .filter((item) => item.type === 'product')\n .map((item) => ({\n item_id: item.data.id,\n item_name: item.data.name,\n quantity: 1,\n })),\n send_to: 'G-XXXXXX-1',\n },\n ];\n}\n\n// GA4 Add to Cart Event Example\nexport function ga4AddToCart(): unknown[] {\n const event = getEvent('product add');\n\n return [\n 'event',\n 'add_to_cart',\n {\n currency: 'EUR',\n value: event.data.price,\n items: [\n {\n item_id: event.data.id,\n item_variant: event.data.color,\n quantity: 1,\n },\n ],\n send_to: 'G-XXXXXX-1',\n },\n ];\n}\n\n// Google Ads Conversion Event Example\nexport function adsConversion(): unknown[] {\n const event = getEvent('order complete');\n\n return [\n 'event',\n 'conversion',\n {\n send_to: 'AW-XXXXXXXXX/CONVERSION_LABEL',\n currency: 'EUR',\n value: event.data.total,\n transaction_id: event.data.id,\n },\n ];\n}\n\n// GTM DataLayer Push Example\nexport function gtmEvent(): Record<string, unknown> {\n const event = getEvent('product view');\n\n return {\n event: 'product_view',\n product_id: event.data.id,\n product_name: event.data.name,\n product_category: event.data.category,\n value: event.data.price,\n currency: 'EUR',\n };\n}\n","import type { Mapping } from '@walkeros/core';\nimport type { DestinationGtag } from '..';\nimport { isObject } from '@walkeros/core';\n\n// GA4 Purchase Mapping\nexport const ga4Purchase: DestinationGtag.Rule = {\n name: 'purchase',\n settings: {\n ga4: {\n include: ['data', 'context'],\n },\n },\n data: {\n map: {\n transaction_id: 'data.id',\n value: 'data.total',\n tax: 'data.taxes',\n shipping: 'data.shipping',\n currency: { key: 'data.currency', value: 'EUR' },\n items: {\n loop: [\n 'nested',\n {\n condition: (entity) =>\n isObject(entity) && entity.type === 'product',\n map: {\n item_id: 'data.id',\n item_name: 'data.name',\n quantity: { key: 'data.quantity', value: 1 },\n },\n },\n ],\n },\n },\n },\n};\n\n// GA4 Add to Cart Mapping\nexport const ga4AddToCart: DestinationGtag.Rule = {\n name: 'add_to_cart',\n settings: {\n ga4: {\n include: ['data'],\n },\n },\n data: {\n map: {\n currency: { value: 'EUR', key: 'data.currency' },\n value: 'data.price',\n items: {\n loop: [\n 'this',\n {\n map: {\n item_id: 'data.id',\n item_variant: 'data.color',\n quantity: { value: 1, key: 'data.quantity' },\n },\n },\n ],\n },\n },\n },\n};\n\n// Google Ads Conversion Mapping\nexport const adsConversion: DestinationGtag.Rule = {\n name: 'CONVERSION_LABEL', // This becomes the conversion label\n settings: {\n ads: {},\n },\n data: {\n map: {\n value: 'data.total',\n currency: { value: 'EUR', key: 'data.currency' },\n transaction_id: 'data.id',\n },\n },\n};\n\n// GTM Event Mapping\nexport const gtmProductView: DestinationGtag.Rule = {\n name: 'product_view',\n settings: {\n gtm: {},\n },\n data: {\n map: {\n product_id: 'data.id',\n product_name: 'data.name',\n product_category: 'data.category',\n value: 'data.price',\n currency: { value: 'EUR', key: 'data.currency' },\n },\n },\n};\n\n// Combined mapping for all tools\nexport const combinedPurchase: DestinationGtag.Rule = {\n name: 'purchase', // GA4 event name\n settings: {\n ga4: {\n include: ['data'],\n },\n ads: {}, // Will use 'purchase' as conversion label for ads\n gtm: {},\n },\n data: {\n map: {\n transaction_id: 'data.id',\n value: 'data.total',\n currency: { value: 'EUR', key: 'data.currency' },\n items: {\n loop: [\n 'nested',\n {\n condition: (entity) =>\n isObject(entity) && entity.type === 'product',\n map: {\n item_id: 'data.id',\n item_name: 'data.name',\n quantity: { value: 1, key: 'data.quantity' },\n },\n },\n ],\n },\n },\n },\n};\n\n// Example configuration with all mappings\nexport const config = {\n order: { complete: combinedPurchase },\n product: {\n add: ga4AddToCart,\n view: gtmProductView,\n },\n} satisfies DestinationGtag.Rules;\n"],"mappings":"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","names":["w","addScript","adsConversion","ga4AddToCart","ga4Purchase","ga4Purchase","ga4AddToCart","adsConversion","config"]}
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e,t,a=Object.defineProperty,n=(e,t)=>{for(var n in t)a(e,n,{get:t[n],enumerable:!0})},r=new Set;function o(e,t="https://www.googletagmanager.com/gtag/js?id="){if(r.has(e))return;const a=document.createElement("script");a.src=t+e,document.head.appendChild(a),r.add(e)}function i(){const e=window;e.dataLayer=e.dataLayer||[],e.gtag||(e.gtag=function(){e.dataLayer.push(arguments)})}function s(e){return e("gtag",window.gtag)}var c=Object.getOwnPropertyNames,d=(e={"package.json"(e,t){t.exports={name:"@walkeros/core",description:"Core types and platform-agnostic utilities for walkerOS",version:"0.0.7",main:"./dist/index.js",module:"./dist/index.mjs",types:"./dist/index.d.ts",license:"MIT",files:["dist/**"],scripts:{build:"tsup --silent",clean:"rm -rf .turbo && rm -rf node_modules && rm -rf dist",dev:"jest --watchAll --colors",lint:'tsc && eslint "**/*.ts*"',test:"jest",update:"npx npm-check-updates -u && npm update"},dependencies:{},devDependencies:{},repository:{url:"git+https://github.com/elbwalker/walkerOS.git",directory:"packages/core"},author:"elbwalker <hello@elbwalker.com>",homepage:"https://github.com/elbwalker/walkerOS#readme",bugs:{url:"https://github.com/elbwalker/walkerOS/issues"},keywords:["walker","walkerOS","analytics","tracking","data collection","measurement","data privacy","privacy friendly","web analytics","product analytics","core","types","utils"],funding:[{type:"GitHub Sponsors",url:"https://github.com/sponsors/elbwalker"}]}}},function(){return t||(0,e[c(e)[0]])((t={exports:{}}).exports,t),t.exports}),u={merge:!0,shallow:!0,extend:!0};function p(e){return"object"==typeof e&&null!==e&&!function(e){return Array.isArray(e)}(e)&&"[object Object]"===Object.prototype.toString.call(e)}var{version:l}=d();function g(e={}){var t;const a=e.timestamp||(new Date).setHours(0,13,37,0),n=e.group||"gr0up",r=e.count||1,o=function(e,t={},a={}){a={...u,...a};const n=Object.entries(t).reduce((t,[n,r])=>{const o=e[n];return a.merge&&Array.isArray(o)&&Array.isArray(r)?t[n]=r.reduce((e,t)=>e.includes(t)?e:[...e,t],[...o]):(a.extend||n in e)&&(t[n]=r),t},{});return a.shallow?{...e,...n}:(Object.assign(e,n),e)}({event:"entity action",data:{string:"foo",number:1,boolean:!0,array:[0,"text",!1],not:void 0},context:{dev:["test",1]},globals:{lang:"elb"},custom:{completely:"random"},user:{id:"us3r",device:"c00k13",session:"s3ss10n"},nested:[{type:"child",data:{is:"subordinated"},nested:[],context:{element:["child",0]}}],consent:{functional:!0},id:`${a}-${n}-${r}`,trigger:"test",entity:"entity",action:"action",timestamp:a,timing:3.14,group:n,count:r,version:{source:l,tagging:1},source:{type:"web",id:"https://localhost:80",previous_id:"http://remotehost:9001"}},e,{merge:!1});if(e.event){const[a,n]=null!=(t=e.event.split(" "))?t:[];a&&n&&(o.entity=a,o.action=n)}return o}function m(e="entity action",t={}){const a=t.timestamp||(new Date).setHours(0,13,37,0),n={data:{id:"ers",name:"Everyday Ruck Snack",color:"black",size:"l",price:420}},r={data:{id:"cc",name:"Cool Cap",size:"one size",price:42}};return g({...{"cart view":{data:{currency:"EUR",value:2*n.data.price},context:{shopping:["cart",0]},globals:{pagegroup:"shop"},nested:[{type:"product",data:{...n.data,quantity:2},context:{shopping:["cart",0]},nested:[]}],trigger:"load"},"checkout view":{data:{step:"payment",currency:"EUR",value:n.data.price+r.data.price},context:{shopping:["checkout",0]},globals:{pagegroup:"shop"},nested:[{type:"product",...n,context:{shopping:["checkout",0]},nested:[]},{type:"product",...r,context:{shopping:["checkout",0]},nested:[]}],trigger:"load"},"order complete":{data:{id:"0rd3r1d",currency:"EUR",shipping:5.22,taxes:73.76,total:555},context:{shopping:["complete",0]},globals:{pagegroup:"shop"},nested:[{type:"product",...n,context:{shopping:["complete",0]},nested:[]},{type:"product",...r,context:{shopping:["complete",0]},nested:[]},{type:"gift",data:{name:"Surprise"},context:{shopping:["complete",0]},nested:[]}],trigger:"load"},"page view":{data:{domain:"www.example.com",title:"walkerOS documentation",referrer:"https://www.elbwalker.com/",search:"?foo=bar",hash:"#hash",id:"/docs/"},globals:{pagegroup:"docs"},trigger:"load"},"product add":{...n,context:{shopping:["intent",0]},globals:{pagegroup:"shop"},nested:[],trigger:"click"},"product view":{...n,context:{shopping:["detail",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"},"product visible":{data:{...n.data,position:3,promo:!0},context:{shopping:["discover",0]},globals:{pagegroup:"shop"},nested:[],trigger:"load"},"promotion visible":{data:{name:"Setting up tracking easily",position:"hero"},context:{ab_test:["engagement",0]},globals:{pagegroup:"homepage"},trigger:"visible"},"session start":{data:{id:"s3ss10n",start:a,isNew:!0,count:1,runs:1,isStart:!0,storage:!0,referrer:"",device:"c00k13"},user:{id:"us3r",device:"c00k13",session:"s3ss10n",hash:"h4sh",address:"street number",email:"user@example.com",phone:"+49 123 456 789",userAgent:"Mozilla...",browser:"Chrome",browserVersion:"90",deviceType:"desktop",language:"de-DE",country:"DE",region:"HH",city:"Hamburg",zip:"20354",timezone:"Berlin",os:"walkerOS",osVersion:"1.0",screenSize:"1337x420",ip:"127.0.0.0",internal:!0,custom:"value"}}}[e],...t,event:e})}function y(e,t,a={},n,r){if(!t.measurementId)return;const o=p(n)?n:{},i=function(e,t){const a={};return t.includes("all")&&(t=["context","data","event","globals","source","user","version"]),t.forEach(t=>{let n=e[t]||{};"event"==t&&(n={id:e.id,timing:e.timing,trigger:e.trigger,entity:e.entity,action:e.action,group:e.group,count:e.count}),Object.entries(n).forEach(([e,n])=>{"context"==t&&(n=n[0]),a[`${t}_${e}`]=n})}),a}(e,a.include||t.include||["data"]),c={...i,...o};let d=e.event;!1!==t.snakeCase&&(d=function(e,t=!0){return t?e.replace(/\s+/g,"_").toLowerCase():e}(d)),c.send_to=t.measurementId,t.debug&&(c.debug_mode=!0);s(r)("event",d,c)}var v="dataLayer";function h(e,t,a){const{containerId:n,dataLayer:r,domain:o}=e,i=r||v,s=window;i===v?s.dataLayer=s.dataLayer||[]:s[i]=s[i]||[];const c=s[i];t("dataLayer.push",c.push.bind(c))({"gtm.start":(new Date).getTime(),event:"gtm.js"}),a&&n&&function(e,t,a){const n=a!=v?"&l="+a:"",r=document.createElement("script");r.src=t+e+n,document.head.appendChild(r)}(n,o||"https://www.googletagmanager.com/gtm.js?id=",i)}var w={},b={};n(b,{events:()=>f,mapping:()=>X});var f={};function _(){const e=m("order complete");return["event","purchase",{transaction_id:e.data.id,value:e.data.total,tax:e.data.taxes,shipping:e.data.shipping,currency:"EUR",items:e.nested.filter(e=>"product"===e.type).map(e=>({item_id:e.data.id,item_name:e.data.name,quantity:1})),send_to:"G-XXXXXX-1"}]}function k(){const e=m("product add");return["event","add_to_cart",{currency:"EUR",value:e.data.price,items:[{item_id:e.data.id,item_variant:e.data.color,quantity:1}],send_to:"G-XXXXXX-1"}]}function x(){const e=m("order complete");return["event","conversion",{send_to:"AW-XXXXXXXXX/CONVERSION_LABEL",currency:"EUR",value:e.data.total,transaction_id:e.data.id}]}function E(){const e=m("product view");return{event:"product_view",product_id:e.data.id,product_name:e.data.name,product_category:e.data.category,value:e.data.price,currency:"EUR"}}n(f,{adsConversion:()=>x,ga4AddToCart:()=>k,ga4Purchase:()=>_,gtmEvent:()=>E});var X={};n(X,{adsConversion:()=>I,combinedPurchase:()=>R,config:()=>L,ga4AddToCart:()=>O,ga4Purchase:()=>j,gtmProductView:()=>S});var j={name:"purchase",settings:{ga4:{include:["data","context"]}},data:{map:{transaction_id:"data.id",value:"data.total",tax:"data.taxes",shipping:"data.shipping",currency:{key:"data.currency",value:"EUR"},items:{loop:["nested",{condition:e=>p(e)&&"product"===e.type,map:{item_id:"data.id",item_name:"data.name",quantity:{key:"data.quantity",value:1}}}]}}}},O={name:"add_to_cart",settings:{ga4:{include:["data"]}},data:{map:{currency:{value:"EUR",key:"data.currency"},value:"data.price",items:{loop:["this",{map:{item_id:"data.id",item_variant:"data.color",quantity:{value:1,key:"data.quantity"}}}]}}}},I={name:"CONVERSION_LABEL",settings:{ads:{}},data:{map:{value:"data.total",currency:{value:"EUR",key:"data.currency"},transaction_id:"data.id"}}},S={name:"product_view",settings:{gtm:{}},data:{map:{product_id:"data.id",product_name:"data.name",product_category:"data.category",value:"data.price",currency:{value:"EUR",key:"data.currency"}}}},R={name:"purchase",settings:{ga4:{include:["data"]},ads:{},gtm:{}},data:{map:{transaction_id:"data.id",value:"data.total",currency:{value:"EUR",key:"data.currency"},items:{loop:["nested",{condition:e=>p(e)&&"product"===e.type,map:{item_id:"data.id",item_name:"data.name",quantity:{value:1,key:"data.quantity"}}}]}}}},L={order:{complete:R},product:{add:O,view:S}},C={type:"google-gtag",config:{settings:{}},init({config:e,wrap:t}){const{settings:a={},loadScript:n}=e,{ga4:r,ads:c,gtm:d}=a;return(null==r?void 0:r.measurementId)&&function(e,t,a){const{measurementId:n,transport_url:r,server_container_url:c,pageview:d}=e;if(!n)return;a&&o(n),i();const u={};r&&(u.transport_url=r),c&&(u.server_container_url=c),!1===d&&(u.send_page_view=!1);const p=s(t);p("js",new Date),p("config",n,u)}(r,t,n),(null==c?void 0:c.conversionId)&&function(e,t,a){const{conversionId:n}=e;if(!n)return;e.currency||(e.currency="EUR"),a&&o(n),i();const r=s(t);r("js",new Date),r("config",n)}(c,t,n),(null==d?void 0:d.containerId)&&h(d,t,n),!!((null==r?void 0:r.measurementId)||(null==c?void 0:c.conversionId)||(null==d?void 0:d.containerId))&&e},push(e,{config:t,mapping:a={},data:n,wrap:r}){const{settings:o={}}=t,{ga4:i,ads:c,gtm:d}=o,u=a.settings||{};(null==i?void 0:i.measurementId)&&y(e,i,u.ga4,n,r),(null==c?void 0:c.conversionId)&&a.name&&function(e,t,a={},n,r,o){const{conversionId:i,currency:c}=t,d=p(n)?n:{},u=a.label||o;if(!u)return;const l={send_to:`${i}/${u}`,currency:c||"EUR",...d};s(r)("event","conversion",l)}(0,c,u.ads,n,r,a.name),(null==d?void 0:d.containerId)&&function(e,t,a={},n,r){const o=window;r("dataLayer.push",o.dataLayer.push.bind(o.dataLayer))({event:e.event,...p(n)?n:e})}(e,0,u.gtm,n,r)}},U=C;export{w as DestinationGtag,U as default,C as destinationGtag,b as examples};//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/shared/gtag.ts","../src/ga4/config.ts","../src/shared/parameters.ts","../src/shared/mapping.ts","../src/ga4/push.ts","../src/ads/config.ts","../src/ads/push.ts","../src/gtm/config.ts","../src/gtm/push.ts","../src/types/index.ts","../src/examples/index.ts","../src/examples/events.ts","../src/examples/mapping.ts","../src/index.ts"],"sourcesContent":["// Gtag script loading and initialization utilities\n\nconst loadedScripts = new Set<string>();\n\n// For testing: allow resetting loaded scripts\nexport function resetLoadedScripts(): void {\n loadedScripts.clear();\n}\n\nexport function addScript(\n id: string,\n src = 'https://www.googletagmanager.com/gtag/js?id=',\n): void {\n // Prevent loading the same script multiple times\n if (loadedScripts.has(id)) return;\n\n const script = document.createElement('script');\n script.src = src + id;\n document.head.appendChild(script);\n loadedScripts.add(id);\n}\n\nexport function initializeGtag(): void {\n const w = window;\n\n // Setup dataLayer if not exists\n w.dataLayer = w.dataLayer || [];\n\n // Setup gtag function if not exists\n if (!w.gtag) {\n w.gtag = function () {\n (w.dataLayer as unknown[]).push(arguments);\n };\n }\n}\n\nexport function getGtag(\n wrap: (name: string, fn: Function) => Function,\n): Gtag.Gtag {\n return wrap('gtag', window.gtag) as Gtag.Gtag;\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GA4Settings } from '../types';\nimport { addScript, initializeGtag, getGtag } from '../shared/gtag';\n\nexport function initGA4(\n settings: GA4Settings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { measurementId, transport_url, server_container_url, pageview } =\n settings;\n\n if (!measurementId) return;\n\n // Load the gtag script\n if (loadScript) addScript(measurementId);\n\n // Initialize gtag infrastructure\n initializeGtag();\n\n const gtagSettings: WalkerOS.AnyObject = {};\n\n // custom transport_url\n if (transport_url) gtagSettings.transport_url = transport_url;\n\n // custom server_container_url\n if (server_container_url)\n gtagSettings.server_container_url = server_container_url;\n\n // disable pageviews\n if (pageview === false) gtagSettings.send_page_view = false;\n\n const gtag = getGtag(wrap);\n gtag('js', new Date());\n\n // gtag init call\n gtag('config', measurementId, gtagSettings);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { Include, Parameters } from '../types';\n\nexport function getParamsInclude(\n event: WalkerOS.DeepPartialEvent,\n include: Include,\n): Parameters {\n const params: Parameters = {};\n\n // Check for the 'all' group to add each group\n if (include.includes('all'))\n include = [\n 'context',\n 'data',\n 'event',\n 'globals',\n 'source',\n 'user',\n 'version',\n ];\n\n include.forEach((groupName) => {\n let group = event[groupName as keyof Omit<WalkerOS.Event, 'all'>] || {};\n\n // Create a fake group for event properties\n if (groupName == 'event')\n group = {\n id: event.id,\n timing: event.timing,\n trigger: event.trigger,\n entity: event.entity,\n action: event.action,\n group: event.group,\n count: event.count,\n };\n\n Object.entries(group).forEach(([key, val]) => {\n // Different value access for context\n if (groupName == 'context') val = (val as WalkerOS.OrderedProperties)[0];\n\n params[`${groupName}_${key}`] = val;\n });\n });\n\n return params;\n}\n","// Shared mapping utilities for all Google tools\n\nexport function normalizeEventName(\n eventName: string,\n snakeCase = true,\n): string {\n if (!snakeCase) return eventName;\n\n return eventName.replace(/\\s+/g, '_').toLowerCase();\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GA4Settings, GA4Mapping, Parameters } from '../types';\nimport { isObject } from '@walkeros/core';\nimport { getParamsInclude } from '../shared/parameters';\nimport { normalizeEventName } from '../shared/mapping';\nimport { getGtag } from '../shared/gtag';\n\nexport function pushGA4Event(\n event: WalkerOS.Event,\n settings: GA4Settings,\n mapping: GA4Mapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n): void {\n if (!settings.measurementId) return;\n\n const eventData = isObject(data) ? data : {};\n\n const paramsInclude = getParamsInclude(\n event,\n // Add data to include by default\n mapping.include || settings.include || ['data'],\n );\n\n const eventParams: Parameters = {\n ...paramsInclude,\n ...eventData,\n };\n\n // Event name (snake_case default)\n let eventName = event.event; // Assume custom mapped name\n if (settings.snakeCase !== false) {\n // Use snake case if not disabled\n eventName = normalizeEventName(eventName);\n }\n\n // Set the GA4 stream id\n eventParams.send_to = settings.measurementId;\n\n // Debug mode\n if (settings.debug) eventParams.debug_mode = true;\n\n const gtag = getGtag(wrap);\n gtag('event', eventName, eventParams);\n}\n","import type { AdsSettings } from '../types';\nimport { addScript, initializeGtag, getGtag } from '../shared/gtag';\n\nexport function initAds(\n settings: AdsSettings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { conversionId } = settings;\n\n if (!conversionId) return;\n\n // Default currency value\n if (!settings.currency) settings.currency = 'EUR';\n\n if (loadScript) addScript(conversionId);\n\n // Initialize gtag infrastructure\n initializeGtag();\n\n const gtag = getGtag(wrap);\n gtag('js', new Date());\n\n // gtag init call\n gtag('config', conversionId);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { AdsSettings, AdsMapping } from '../types';\nimport { isObject } from '@walkeros/core';\nimport { getGtag } from '../shared/gtag';\n\nexport function pushAdsEvent(\n event: WalkerOS.Event,\n settings: AdsSettings,\n mapping: AdsMapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n mappingName?: string,\n): void {\n const { conversionId, currency } = settings;\n const eventData = isObject(data) ? data : {};\n\n // Use label from mapping settings, fallback to mappingName for backward compatibility\n const conversionLabel = mapping.label || mappingName;\n if (!conversionLabel) return;\n\n const params: Gtag.CustomParams = {\n send_to: `${conversionId}/${conversionLabel}`,\n currency: currency || 'EUR',\n ...eventData,\n };\n\n const gtag = getGtag(wrap);\n gtag('event', 'conversion', params);\n}\n","import type { GTMSettings, WindowData } from '../types';\n\nconst defaultDataLayer = 'dataLayer';\nconst defaultDomain = 'https://www.googletagmanager.com/gtm.js?id=';\n\nexport function initGTM(\n settings: GTMSettings,\n wrap: (name: string, fn: Function) => Function,\n loadScript?: boolean,\n): void {\n const { containerId, dataLayer, domain } = settings;\n const dataLayerName = dataLayer || defaultDataLayer;\n\n const win = window as WindowData;\n\n // Initialize the dataLayer (default or custom name)\n if (dataLayerName === defaultDataLayer) {\n win.dataLayer = win.dataLayer || [];\n } else {\n win[dataLayerName] = (win[dataLayerName] as unknown[]) || [];\n }\n\n // Get the appropriate dataLayer array\n const dataLayerArray = win[dataLayerName] as unknown[];\n\n const push = wrap('dataLayer.push', dataLayerArray.push.bind(dataLayerArray));\n push({\n 'gtm.start': new Date().getTime(),\n event: 'gtm.js',\n });\n\n // Load the gtm script and container\n if (loadScript && containerId)\n addScript(containerId, domain || defaultDomain, dataLayerName);\n}\n\nfunction addScript(containerId: string, src: string, dataLayerName: string) {\n const dl = dataLayerName != defaultDataLayer ? '&l=' + dataLayerName : '';\n const script = document.createElement('script');\n script.src = src + containerId + dl;\n document.head.appendChild(script);\n}\n","import type { WalkerOS } from '@walkeros/core';\nimport type { GTMSettings, GTMMapping, WindowData } from '../types';\nimport { isObject } from '@walkeros/core';\n\nexport function pushGTMEvent(\n event: WalkerOS.Event,\n settings: GTMSettings,\n mapping: GTMMapping = {},\n data: WalkerOS.AnyObject,\n wrap: (name: string, fn: Function) => Function,\n): void {\n const win = window as WindowData;\n const push = wrap('dataLayer.push', win.dataLayer.push.bind(win.dataLayer));\n const obj = { event: event.event }; // Use the name mapping by default\n\n push({\n ...obj,\n ...(isObject(data) ? data : event),\n });\n}\n","import type { Mapping as WalkerOSMapping } from '@walkeros/core';\nimport type { DestinationWeb } from '@walkeros/web-core';\n\n// Extend Window interface with specific dataLayer typing\ninterface WindowWithDataLayer extends Window {\n dataLayer: unknown[];\n gtag?: Gtag.Gtag;\n [key: string]: unknown; // For custom dataLayer names and other properties\n}\n\ndeclare global {\n interface Window {\n gtag?: Gtag.Gtag;\n [key: string]: unknown; // For custom dataLayer names and other properties\n }\n}\n\n// Export helper type for internal use\nexport type WindowData = WindowWithDataLayer;\n\nexport type Destination = DestinationWeb.Destination<Settings, Mapping>;\nexport type Config = DestinationWeb.Config<Settings, Mapping>;\n\n// Unified settings for all Google tools\nexport interface Settings {\n // GA4 settings\n ga4?: GA4Settings;\n // Google Ads settings\n ads?: AdsSettings;\n // GTM settings\n gtm?: GTMSettings;\n}\n\n// GA4-specific settings\nexport interface GA4Settings {\n measurementId: string;\n debug?: boolean;\n include?: Include;\n pageview?: boolean;\n server_container_url?: string;\n snakeCase?: boolean;\n transport_url?: string;\n}\n\n// Google Ads specific settings\nexport interface AdsSettings {\n conversionId: string;\n currency?: string;\n}\n\n// Google Ads specific mapping\nexport interface AdsMapping {\n label?: string; // Conversion label for this specific event\n}\n\n// GTM specific settings\nexport interface GTMSettings {\n containerId: string;\n dataLayer?: string;\n domain?: string;\n}\n\n// Unified mapping interface\nexport interface Mapping {\n ga4?: GA4Mapping;\n ads?: AdsMapping;\n gtm?: GTMMapping;\n}\n\n// GA4-specific mapping\nexport interface GA4Mapping {\n include?: Include;\n}\n\n// GTM specific mapping\nexport interface GTMMapping {}\n\nexport type Rule = WalkerOSMapping.Rule<Mapping>;\nexport type Rules = WalkerOSMapping.Rules<Rule>;\nexport type Param = WalkerOSMapping.Value;\n\nexport type Include = Array<\n | 'all'\n | 'context'\n | 'data'\n | 'event'\n | 'globals'\n | 'source'\n | 'user'\n | 'version'\n>;\n\nexport type Parameters = Gtag.ControlParams &\n Gtag.EventParams &\n Gtag.CustomParams;\n","export * as events from './events';\nexport * as mapping from './mapping';\n","import { getEvent } from '@walkeros/core';\n\n// GA4 Purchase Event Example\nexport function ga4Purchase(): unknown[] {\n const event = getEvent('order complete');\n\n return [\n 'event',\n 'purchase',\n {\n transaction_id: event.data.id,\n value: event.data.total,\n tax: event.data.taxes,\n shipping: event.data.shipping,\n currency: 'EUR',\n items: event.nested\n .filter((item) => item.type === 'product')\n .map((item) => ({\n item_id: item.data.id,\n item_name: item.data.name,\n quantity: 1,\n })),\n send_to: 'G-XXXXXX-1',\n },\n ];\n}\n\n// GA4 Add to Cart Event Example\nexport function ga4AddToCart(): unknown[] {\n const event = getEvent('product add');\n\n return [\n 'event',\n 'add_to_cart',\n {\n currency: 'EUR',\n value: event.data.price,\n items: [\n {\n item_id: event.data.id,\n item_variant: event.data.color,\n quantity: 1,\n },\n ],\n send_to: 'G-XXXXXX-1',\n },\n ];\n}\n\n// Google Ads Conversion Event Example\nexport function adsConversion(): unknown[] {\n const event = getEvent('order complete');\n\n return [\n 'event',\n 'conversion',\n {\n send_to: 'AW-XXXXXXXXX/CONVERSION_LABEL',\n currency: 'EUR',\n value: event.data.total,\n transaction_id: event.data.id,\n },\n ];\n}\n\n// GTM DataLayer Push Example\nexport function gtmEvent(): Record<string, unknown> {\n const event = getEvent('product view');\n\n return {\n event: 'product_view',\n product_id: event.data.id,\n product_name: event.data.name,\n product_category: event.data.category,\n value: event.data.price,\n currency: 'EUR',\n };\n}\n","import type { Mapping } from '@walkeros/core';\nimport type { DestinationGtag } from '..';\nimport { isObject } from '@walkeros/core';\n\n// GA4 Purchase Mapping\nexport const ga4Purchase: DestinationGtag.Rule = {\n name: 'purchase',\n settings: {\n ga4: {\n include: ['data', 'context'],\n },\n },\n data: {\n map: {\n transaction_id: 'data.id',\n value: 'data.total',\n tax: 'data.taxes',\n shipping: 'data.shipping',\n currency: { key: 'data.currency', value: 'EUR' },\n items: {\n loop: [\n 'nested',\n {\n condition: (entity) =>\n isObject(entity) && entity.type === 'product',\n map: {\n item_id: 'data.id',\n item_name: 'data.name',\n quantity: { key: 'data.quantity', value: 1 },\n },\n },\n ],\n },\n },\n },\n};\n\n// GA4 Add to Cart Mapping\nexport const ga4AddToCart: DestinationGtag.Rule = {\n name: 'add_to_cart',\n settings: {\n ga4: {\n include: ['data'],\n },\n },\n data: {\n map: {\n currency: { value: 'EUR', key: 'data.currency' },\n value: 'data.price',\n items: {\n loop: [\n 'this',\n {\n map: {\n item_id: 'data.id',\n item_variant: 'data.color',\n quantity: { value: 1, key: 'data.quantity' },\n },\n },\n ],\n },\n },\n },\n};\n\n// Google Ads Conversion Mapping\nexport const adsConversion: DestinationGtag.Rule = {\n name: 'CONVERSION_LABEL', // This becomes the conversion label\n settings: {\n ads: {},\n },\n data: {\n map: {\n value: 'data.total',\n currency: { value: 'EUR', key: 'data.currency' },\n transaction_id: 'data.id',\n },\n },\n};\n\n// GTM Event Mapping\nexport const gtmProductView: DestinationGtag.Rule = {\n name: 'product_view',\n settings: {\n gtm: {},\n },\n data: {\n map: {\n product_id: 'data.id',\n product_name: 'data.name',\n product_category: 'data.category',\n value: 'data.price',\n currency: { value: 'EUR', key: 'data.currency' },\n },\n },\n};\n\n// Combined mapping for all tools\nexport const combinedPurchase: DestinationGtag.Rule = {\n name: 'purchase', // GA4 event name\n settings: {\n ga4: {\n include: ['data'],\n },\n ads: {}, // Will use 'purchase' as conversion label for ads\n gtm: {},\n },\n data: {\n map: {\n transaction_id: 'data.id',\n value: 'data.total',\n currency: { value: 'EUR', key: 'data.currency' },\n items: {\n loop: [\n 'nested',\n {\n condition: (entity) =>\n isObject(entity) && entity.type === 'product',\n map: {\n item_id: 'data.id',\n item_name: 'data.name',\n quantity: { value: 1, key: 'data.quantity' },\n },\n },\n ],\n },\n },\n },\n};\n\n// Example configuration with all mappings\nexport const config = {\n order: { complete: combinedPurchase },\n product: {\n add: ga4AddToCart,\n view: gtmProductView,\n },\n} satisfies DestinationGtag.Rules;\n","import type { WalkerOS } from '@walkeros/core';\nimport type { Settings, Destination } from './types';\nimport { initGA4, pushGA4Event } from './ga4';\nimport { initAds, pushAdsEvent } from './ads';\nimport { initGTM, pushGTMEvent } from './gtm';\n\n// Types\nexport * as DestinationGtag from './types';\n\n// Examples\nexport * as examples from './examples';\n\nexport const destinationGtag: Destination = {\n type: 'google-gtag',\n\n config: { settings: {} },\n\n init({ config, wrap }) {\n const { settings = {} as Partial<Settings>, loadScript } = config;\n const { ga4, ads, gtm } = settings;\n\n // Initialize GA4 if configured\n if (ga4?.measurementId) {\n initGA4(ga4, wrap, loadScript);\n }\n\n // Initialize Google Ads if configured\n if (ads?.conversionId) {\n initAds(ads, wrap, loadScript);\n }\n\n // Initialize GTM if configured\n if (gtm?.containerId) {\n initGTM(gtm, wrap, loadScript);\n }\n\n // Fail if no tools are configured\n if (!ga4?.measurementId && !ads?.conversionId && !gtm?.containerId) {\n return false;\n }\n\n return config;\n },\n\n push(event, { config, mapping = {}, data, wrap }) {\n const { settings = {} } = config;\n const { ga4, ads, gtm } = settings;\n const eventMapping = mapping.settings || {};\n\n // Push to GA4 if configured\n if (ga4?.measurementId) {\n pushGA4Event(\n event,\n ga4,\n eventMapping.ga4,\n data as WalkerOS.AnyObject,\n wrap,\n );\n }\n\n // Push to Google Ads if configured and has mapping name\n if (ads?.conversionId && mapping.name) {\n pushAdsEvent(\n event,\n ads,\n eventMapping.ads,\n data as WalkerOS.AnyObject,\n wrap,\n mapping.name,\n );\n }\n\n // Push to GTM if configured\n if (gtm?.containerId) {\n pushGTMEvent(\n event,\n gtm,\n eventMapping.gtm,\n data as WalkerOS.AnyObject,\n wrap,\n );\n }\n },\n};\n\nexport default destinationGtag;\n"],"mappings":"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","names":["w","addScript","adsConversion","ga4AddToCart","ga4Purchase","ga4Purchase","ga4AddToCart","adsConversion","config"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@walkeros/web-destination-gtag",
|
|
3
|
+
"description": "Unified Google destination for walkerOS (GA4, Ads, GTM)",
|
|
4
|
+
"version": "0.0.7",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"module": "./dist/index.mjs",
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": {
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"import": "./dist/index.mjs",
|
|
13
|
+
"require": "./dist/index.js"
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
"files": [
|
|
17
|
+
"dist/**"
|
|
18
|
+
],
|
|
19
|
+
"scripts": {
|
|
20
|
+
"build": "tsup --silent",
|
|
21
|
+
"clean": "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
|
|
22
|
+
"dev": "jest --watchAll --colors",
|
|
23
|
+
"lint": "tsc && eslint \"**/*.ts*\"",
|
|
24
|
+
"test": "jest",
|
|
25
|
+
"update": "npx npm-check-updates -u && npm update"
|
|
26
|
+
},
|
|
27
|
+
"dependencies": {
|
|
28
|
+
"@walkeros/web-core": "0.0.7"
|
|
29
|
+
},
|
|
30
|
+
"repository": {
|
|
31
|
+
"url": "git+https://github.com/elbwalker/walkerOS.git",
|
|
32
|
+
"directory": "packages/web/destinations/gtag"
|
|
33
|
+
},
|
|
34
|
+
"author": "elbwalker <hello@elbwalker.com>",
|
|
35
|
+
"homepage": "https://github.com/elbwalker/walkerOS#readme",
|
|
36
|
+
"bugs": {
|
|
37
|
+
"url": "https://github.com/elbwalker/walkerOS/issues"
|
|
38
|
+
},
|
|
39
|
+
"keywords": [
|
|
40
|
+
"walker",
|
|
41
|
+
"walkerOS",
|
|
42
|
+
"destination",
|
|
43
|
+
"web",
|
|
44
|
+
"google",
|
|
45
|
+
"gtag",
|
|
46
|
+
"ga4",
|
|
47
|
+
"google-ads",
|
|
48
|
+
"gtm"
|
|
49
|
+
],
|
|
50
|
+
"funding": [
|
|
51
|
+
{
|
|
52
|
+
"type": "GitHub Sponsors",
|
|
53
|
+
"url": "https://github.com/sponsors/elbwalker"
|
|
54
|
+
}
|
|
55
|
+
]
|
|
56
|
+
}
|