@deriv-com/analytics 1.38.9 → 1.39.0

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.
Files changed (56) hide show
  1. package/dist/browser/analytics.bundle.global.js +12 -12
  2. package/dist/browser/analytics.bundle.global.js.map +1 -1
  3. package/dist/browser/analytics.esm.mjs +1 -1
  4. package/dist/browser/analytics.esm.mjs.map +1 -1
  5. package/dist/{chunk-D2MKQCJB.mjs → chunk-44P2MMGV.mjs} +3 -3
  6. package/dist/{chunk-D2MKQCJB.mjs.map → chunk-44P2MMGV.mjs.map} +1 -1
  7. package/dist/{chunk-YGU4ZMIH.mjs → chunk-FY3NPDUL.mjs} +2 -2
  8. package/dist/chunk-GGU2UVKH.mjs +4 -0
  9. package/dist/chunk-GGU2UVKH.mjs.map +1 -0
  10. package/dist/chunk-J3V5QNIH.js +4 -0
  11. package/dist/chunk-J3V5QNIH.js.map +1 -0
  12. package/dist/{chunk-7CT4XR74.mjs → chunk-LIPHY7JK.mjs} +3 -3
  13. package/dist/{chunk-7CT4XR74.mjs.map → chunk-LIPHY7JK.mjs.map} +1 -1
  14. package/dist/{chunk-FE5YWK6A.js → chunk-SQ6Q4Z5S.js} +3 -3
  15. package/dist/{chunk-FE5YWK6A.js.map → chunk-SQ6Q4Z5S.js.map} +1 -1
  16. package/dist/chunk-UG2YL4OB.mjs +9 -0
  17. package/dist/chunk-UG2YL4OB.mjs.map +1 -0
  18. package/dist/{chunk-ILN7DKKL.js → chunk-Y3QT7NAG.js} +3 -3
  19. package/dist/{chunk-ILN7DKKL.js.map → chunk-Y3QT7NAG.js.map} +1 -1
  20. package/dist/{growthbook-3K6VUME4.mjs → growthbook-IRLKT4KH.mjs} +2 -2
  21. package/dist/index.d.mts +11 -3
  22. package/dist/index.d.ts +11 -3
  23. package/dist/index.js +2 -2
  24. package/dist/index.js.map +1 -1
  25. package/dist/index.mjs +2 -2
  26. package/dist/index.mjs.map +1 -1
  27. package/dist/metafile-cjs.json +1 -1
  28. package/dist/metafile-esm.json +1 -1
  29. package/dist/metafile-iife.json +1 -1
  30. package/dist/posthog-2YOT34O2.mjs +6 -0
  31. package/dist/posthog-2YOT34O2.mjs.map +1 -0
  32. package/dist/{posthog-Ds4g1sJf.d.mts → posthog-CRa194Jm.d.mts} +8 -3
  33. package/dist/{posthog-DvDj4azD.d.ts → posthog-CZnsy0at.d.ts} +8 -3
  34. package/dist/providers/growthbook/index.js +2 -2
  35. package/dist/providers/growthbook/index.mjs +1 -1
  36. package/dist/providers/posthog/index.d.mts +1 -1
  37. package/dist/providers/posthog/index.d.ts +1 -1
  38. package/dist/providers/posthog/index.js +2 -2
  39. package/dist/providers/posthog/index.js.map +1 -1
  40. package/dist/providers/posthog/index.mjs +2 -2
  41. package/dist/providers/posthog/index.mjs.map +1 -1
  42. package/dist/providers/rudderstack/index.js +1 -1
  43. package/dist/providers/rudderstack/index.mjs +1 -1
  44. package/dist/utils/analytics-cache/index.js +1 -1
  45. package/dist/utils/analytics-cache/index.mjs +1 -1
  46. package/package.json +1 -1
  47. package/dist/chunk-BVGYK54Z.js +0 -4
  48. package/dist/chunk-BVGYK54Z.js.map +0 -1
  49. package/dist/chunk-ID2GN2PS.mjs +0 -4
  50. package/dist/chunk-ID2GN2PS.mjs.map +0 -1
  51. package/dist/chunk-OB6HH25Z.mjs +0 -9
  52. package/dist/chunk-OB6HH25Z.mjs.map +0 -1
  53. package/dist/posthog-ANAV4RFJ.mjs +0 -6
  54. package/dist/posthog-ANAV4RFJ.mjs.map +0 -1
  55. /package/dist/{chunk-YGU4ZMIH.mjs.map → chunk-FY3NPDUL.mjs.map} +0 -0
  56. /package/dist/{growthbook-3K6VUME4.mjs.map → growthbook-IRLKT4KH.mjs.map} +0 -0
package/dist/index.js CHANGED
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkILN7DKKL_js=require('./chunk-ILN7DKKL.js'),chunkFE5YWK6A_js=require('./chunk-FE5YWK6A.js'),chunkBVGYK54Z_js=require('./chunk-BVGYK54Z.js'),k=require('js-cookie');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var k__default=/*#__PURE__*/_interopDefault(k);/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var x="cached_analytics_events",R="cached_analytics_page_views",Q=(r,c)=>{try{let t=chunkBVGYK54Z_js.f(),f=k__default.default.get(x),a=f?JSON.parse(f):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k__default.default.set(x,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache event",t);}},X=(r,c)=>{try{let t=chunkBVGYK54Z_js.f(),f=k__default.default.get(R),a=f?JSON.parse(f):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k__default.default.set(R,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache page view",t);}},Y=()=>{try{let r=k__default.default.get(x);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached events",r);}return []},Z=()=>{try{let r=k__default.default.get(R);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached pages",r);}return []},ee=()=>{let r=chunkBVGYK54Z_js.f(),c=r?{domain:r}:{};k__default.default.remove(x,c);},te=()=>{let r=chunkBVGYK54Z_js.f(),c=r?{domain:r}:{};k__default.default.remove(R,c);};function he(r){let c=false,t=chunkBVGYK54Z_js.g("",()=>c),f,a,g,h={},_={},w=[],m=[],L=false,ie=()=>{if(!L&&a?.has_initialized){L=true;try{let e=Y();e.length>0&&(t(`processCookieCache | replaying ${e.length} cached event(s)`,e),e.forEach(o=>{a?.track(o.name,o.properties);}),ee());let i=Z();i.length>0&&(t(`processCookieCache | replaying ${i.length} cached page view(s)`,i),i.forEach(o=>{a?.pageView(o.name,"Deriv App",E(),o.properties);}),te());}catch(e){console.warn("Analytics: Failed to process cookie cache",e);}}},ne=()=>{t("onSdkLoaded | RudderStack SDK loaded"),ie(),m.length>0&&t(`onSdkLoaded | flushing ${m.length} pending identify call(s)`),m.forEach(({userId:e,traits:i})=>{e&&a?.identifyEvent(e,i);}),m=[];},oe=async({growthbookKey:e,growthbookDecryptionKey:i,rudderstackKey:o,growthbookOptions:s,posthogOptions:p,debug:d})=>{var l,u;d!==void 0&&(c=d),chunkFE5YWK6A_js.a.setDebug(c),t("initialise | starting analytics initialization",{rudderstack:!!o,growthbook:!!e,posthog:!!p});try{let y=s?.attributes?.country||(e?await chunkBVGYK54Z_js.j():void 0);if(o&&(t("initialise | initializing RudderStack"),a=chunkILN7DKKL_js.a.getRudderStackInstance(o,ne,c)),s?.attributes&&Object.keys(s.attributes).length>0){let n=s.attributes,v=a?.getAnonymousId();h={...h,country:y,...n.user_language&&{user_language:n.user_language},...n.account_type&&{account_type:n.account_type},...n.app_id&&{app_id:n.app_id},...n.residence_country&&{residence_country:n.residence_country},...n.device_type&&{device_type:n.device_type},...n.url&&{url:n.url},...n.email_hash&&{email_hash:n.email_hash},...n.network_type&&{network_type:n.network_type},...n.network_rtt&&{network_rtt:n.network_rtt},...n.network_downlink&&{network_downlink:n.network_downlink},...n.account_currency&&{account_currency:n.account_currency},...n.account_mode&&{account_mode:n.account_mode},loggedIn:!!n.loggedIn,...n.user_id&&!chunkBVGYK54Z_js.i(n.user_id)&&{user_id:n.user_id},...v&&{anonymous_id:v}};}s??(s={}),s.attributes??(s.attributes={});let P=a?.getAnonymousId();if((l=s.attributes).id??(l.id=P),(u=s.attributes).country??(u.country=y),e){t("initialise | initializing GrowthBook");let{Growthbook:n}=await import('./providers/growthbook/index.js');f=n.getGrowthBookInstance(e,i,s,c),t("initialise | GrowthBook initialized");let v=setInterval(()=>{Object.keys(_).length>0?clearInterval(v):_=U("tracking-buttons-config",{});},1e3);}if(p){t("initialise | initializing PostHog");let{Posthog:n}=await import('./providers/posthog/index.js');g=n.getPosthogInstance(p,c),t("initialise | PostHog initialized");}t("initialise | analytics initialization complete");}catch(y){console.warn("Analytics: Failed to initialize",y);}},se=({country:e,user_language:i,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:u,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,residence_country:C,url:T,domain:B,geo_location:z,loggedIn:S,network_downlink:G,network_rtt:O,network_type:F,account_currency:D,account_mode:H})=>{let N=d??E();if(t("setAttributes | received attributes",{country:e,user_language:i,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:u,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,residence_country:C,url:T,domain:B,geo_location:z,loggedIn:S,network_downlink:G,network_rtt:O,network_type:F,account_currency:D,account_mode:H}),f){let I={country:e,residence_country:C,user_language:i,device_language:o,device_type:s,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,url:T,domain:B,loggedIn:S,...d&&!chunkBVGYK54Z_js.i(d)&&{user_id:d},anonymous_id:l};N&&(I.id=N,I.user_id=N),t("setAttributes | called GrowthBook setAttributes",I),f.setAttributes(I);}h={...h,...e!==void 0&&{country:e},...z!==void 0&&{geo_location:z},...i!==void 0&&{user_language:i},...p!==void 0&&{account_type:p},...u!==void 0&&{app_id:u},...C!==void 0&&{residence_country:C},...s!==void 0&&{device_type:s},...T!==void 0&&{url:T},...S!==void 0&&{loggedIn:S},...G!==void 0&&{network_downlink:G},...O!==void 0&&{network_rtt:O},...F!==void 0&&{network_type:F},...d!==void 0&&!chunkBVGYK54Z_js.i(d)&&{user_id:d},...l!==void 0&&{anonymous_id:l},...D!==void 0&&{account_currency:D},...H!==void 0&&{account_mode:H}},t("setAttributes | updated core_data",h);},ae=e=>f?.getFeatureState(e)?.experimentResult?.name,U=(e,i)=>f?.getFeatureValue(e,i),re=async()=>await f?.getStatus(),ce=e=>f?.isOn(e),de=e=>f?.setUrl(e),E=()=>{let e=a?.getUserId()||"";return e&&!chunkBVGYK54Z_js.i(e)?e:""},le=()=>a?.getAnonymousId()||"",ge=(e,i="Deriv App",o)=>{let s=E();t("pageView | called",{current_page:e,platform:i,properties:o,userId:s}),a&&(a.has_initialized?(t("pageView | sending page view to RudderStack",{current_page:e,platform:i}),a.pageView(e,i,s,o)):(t("pageView | RudderStack not initialized \u2014 caching page view to cookie",{current_page:e}),X(e,{platform:i,...o})));},fe=(e,i)=>{let o=e||E();if(!o){t("identifyEvent | skipped \u2014 no user_id available");return}t("identifyEvent | called",{user_id:o,traits:i});let s=i?.rudderstack!==void 0||i?.posthog!==void 0,p=s?i?.rudderstack:i,d=s?i?.posthog:i;a&&(a.has_initialized?(t("identifyEvent | calling RudderStack identify",{user_id:o,traits:p}),a.identifyEvent(o,p)):m.some(l=>l.userId===o)||(t("identifyEvent | RudderStack not initialized \u2014 queuing identify call",{user_id:o}),m.push({userId:o,traits:p}))),g?.has_initialized&&d&&(t("identifyEvent | calling PostHog identify",{user_id:o,traits:d}),g.identifyEvent(o,d));},pe=()=>{t("reset | resetting all providers"),a?.has_initialized&&(t("reset | resetting RudderStack"),a.reset()),g?.has_initialized&&(t("reset | resetting PostHog"),g.reset());},ue=e=>"event_metadata"in e||"cta_information"in e||"error"in e,j={initialise:oe,setAttributes:se,identifyEvent:fe,backfillPersonProperties:(e,i)=>{t("backfillPersonProperties | called",{user_id:e}),g?.has_initialized?(t("backfillPersonProperties | backfilling person properties in PostHog",{user_id:e}),g.backfillPersonProperties(e,i)):t("backfillPersonProperties | skipped \u2014 PostHog not initialized");},getFeatureState:ae,getFeatureValue:U,getGrowthbookStatus:re,isFeatureOn:ce,setUrl:de,getId:E,getAnonymousId:le,trackEvent:(e,i)=>{let o=E(),s={};if(t("trackEvent | called",{event:e,analytics_data:i,userId:o,core_data:h}),ue(i)){let l=i;s={...l,event_metadata:{...h,...o&&!h.user_id&&{user_id:o},...l.event_metadata}},t("trackEvent | built V2 payload",{event:e,final_payload:s});}else s={...h,...i,...o&&!h.user_id&&{user_id:o}},t("trackEvent | built V1 payload",{event:e,final_payload:s});if(!(!(e in _)||_[e])){t("trackEvent | skipped \u2014 event disabled by tracking_config",{event:e});return}let d=a?.has_initialized;if(!navigator.onLine||!d)d?(t("trackEvent | offline \u2014 caching event to memory",{event:e}),w.push({event:e,payload:s})):(t("trackEvent | RudderStack not initialized \u2014 caching event to cookie",{event:e}),Q(e,s));else {w.length>0&&(t(`trackEvent | flushing ${w.length} offline cached event(s) to RudderStack`),w.forEach(u=>{let y=chunkBVGYK54Z_js.k(u.payload);a?.track(u.event,y);}),w=[]);let l=chunkBVGYK54Z_js.k(s);t("trackEvent | sending event to RudderStack",{event:e,payload:l}),a?.track(e,l);}if(g?.has_initialized){let l=chunkBVGYK54Z_js.l(s),u=chunkBVGYK54Z_js.k(l);t("trackEvent | sending event to PostHog",{event:e,payload:u}),g.capture(e,u);}},getInstances:()=>({ab:f,tracking:a,posthog:g}),pageView:ge,reset:pe};return typeof window<"u"&&(window.AnalyticsInstance=j),j}var ye=he();Object.defineProperty(exports,"cacheTrackEvents",{enumerable:true,get:function(){return chunkFE5YWK6A_js.a}});exports.Analytics=ye;//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkY3QT7NAG_js=require('./chunk-Y3QT7NAG.js'),chunkSQ6Q4Z5S_js=require('./chunk-SQ6Q4Z5S.js'),chunkJ3V5QNIH_js=require('./chunk-J3V5QNIH.js'),k=require('js-cookie');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var k__default=/*#__PURE__*/_interopDefault(k);/* @deriv-com/analytics - NPM Package - Built with tsup */
2
+ var x="cached_analytics_events",R="cached_analytics_page_views",Q=(r,c)=>{try{let t=chunkJ3V5QNIH_js.f(),f=k__default.default.get(x),a=f?JSON.parse(f):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k__default.default.set(x,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache event",t);}},X=(r,c)=>{try{let t=chunkJ3V5QNIH_js.f(),f=k__default.default.get(R),a=f?JSON.parse(f):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k__default.default.set(R,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache page view",t);}},Y=()=>{try{let r=k__default.default.get(x);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached events",r);}return []},Z=()=>{try{let r=k__default.default.get(R);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached pages",r);}return []},ee=()=>{let r=chunkJ3V5QNIH_js.f(),c=r?{domain:r}:{};k__default.default.remove(x,c);},te=()=>{let r=chunkJ3V5QNIH_js.f(),c=r?{domain:r}:{};k__default.default.remove(R,c);};function he(r){let c=false,t=chunkJ3V5QNIH_js.g("",()=>c),f,a,g,y={},C={},w=[],m=[],J=false,ie=()=>{if(!J&&a?.has_initialized){J=true;try{let e=Y();e.length>0&&(t(`processCookieCache | replaying ${e.length} cached event(s)`,e),e.forEach(o=>{let s=chunkJ3V5QNIH_js.k(o.properties);a?.track(o.name,s);}),ee());let i=Z();i.length>0&&(t(`processCookieCache | replaying ${i.length} cached page view(s)`,i),i.forEach(o=>{a?.pageView(o.name,"Deriv App",_(),o.properties);}),te());}catch(e){console.warn("Analytics: Failed to process cookie cache",e);}}},ne=()=>{t("onSdkLoaded | RudderStack SDK loaded"),ie(),m.length>0&&t(`onSdkLoaded | flushing ${m.length} pending identify call(s)`),m.forEach(({userId:e,traits:i})=>{e&&a?.identifyEvent(e,i);}),m=[];},oe=async({growthbookKey:e,growthbookDecryptionKey:i,rudderstackKey:o,growthbookOptions:s,posthogOptions:p,debug:d})=>{var l,h;d!==void 0&&(c=d),chunkSQ6Q4Z5S_js.a.setDebug(c),t("initialise | starting analytics initialization",{rudderstack:!!o,growthbook:!!e,posthog:!!p});try{let u=s?.attributes?.country||(e?await chunkJ3V5QNIH_js.j():void 0);if(o&&(t("initialise | initializing RudderStack"),a=chunkY3QT7NAG_js.a.getRudderStackInstance(o,ne,c)),s?.attributes&&Object.keys(s.attributes).length>0){let n=s.attributes,v=a?.getAnonymousId();y={...y,country:u,...n.user_language&&{user_language:n.user_language},...n.account_type&&{account_type:n.account_type},...n.app_id&&{app_id:n.app_id},...n.residence_country&&{residence_country:n.residence_country},...n.device_type&&{device_type:n.device_type},...n.url&&{url:n.url},...n.email_hash&&{email_hash:n.email_hash},...n.network_type&&{network_type:n.network_type},...n.network_rtt&&{network_rtt:n.network_rtt},...n.network_downlink&&{network_downlink:n.network_downlink},...n.account_currency&&{account_currency:n.account_currency},...n.account_mode&&{account_mode:n.account_mode},loggedIn:!!n.loggedIn,...n.user_id&&!chunkJ3V5QNIH_js.i(n.user_id)&&{user_id:n.user_id},...v&&{anonymous_id:v}};}s??(s={}),s.attributes??(s.attributes={});let E=a?.getAnonymousId();if((l=s.attributes).id??(l.id=E),(h=s.attributes).country??(h.country=u),e){t("initialise | initializing GrowthBook");let{Growthbook:n}=await import('./providers/growthbook/index.js');f=n.getGrowthBookInstance(e,i,s,c),t("initialise | GrowthBook initialized");let v=setInterval(()=>{Object.keys(C).length>0?clearInterval(v):C=L("tracking-buttons-config",{});},1e3);}if(p){t("initialise | initializing PostHog");let{Posthog:n}=await import('./providers/posthog/index.js');g=n.getPosthogInstance(p,c),t("initialise | PostHog initialized");}t("initialise | analytics initialization complete");}catch(u){console.warn("Analytics: Failed to initialize",u);}},se=({country:e,user_language:i,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:h,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,residence_country:T,url:S,domain:B,geo_location:z,loggedIn:I,network_downlink:O,network_rtt:G,network_type:F,account_currency:D,account_mode:H})=>{let N=d??_();if(t("setAttributes | received attributes",{country:e,user_language:i,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:h,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,residence_country:T,url:S,domain:B,geo_location:z,loggedIn:I,network_downlink:O,network_rtt:G,network_type:F,account_currency:D,account_mode:H}),f){let V={country:e,residence_country:T,user_language:i,device_language:o,device_type:s,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,url:S,domain:B,loggedIn:I,...d&&!chunkJ3V5QNIH_js.i(d)&&{user_id:d},anonymous_id:l};N&&(V.id=N,V.user_id=N),t("setAttributes | called GrowthBook setAttributes",V),f.setAttributes(V);}y={...y,...e!==void 0&&{country:e},...z!==void 0&&{geo_location:z},...i!==void 0&&{user_language:i},...p!==void 0&&{account_type:p},...h!==void 0&&{app_id:h},...T!==void 0&&{residence_country:T},...s!==void 0&&{device_type:s},...S!==void 0&&{url:S},...I!==void 0&&{loggedIn:I},...O!==void 0&&{network_downlink:O},...G!==void 0&&{network_rtt:G},...F!==void 0&&{network_type:F},...d!==void 0&&!chunkJ3V5QNIH_js.i(d)&&{user_id:d},...l!==void 0&&{anonymous_id:l},...D!==void 0&&{account_currency:D},...H!==void 0&&{account_mode:H}},t("setAttributes | updated core_data",y);},ae=e=>f?.getFeatureState(e)?.experimentResult?.name,L=(e,i)=>f?.getFeatureValue(e,i),re=async()=>await f?.getStatus(),ce=e=>f?.isOn(e),de=e=>f?.setUrl(e),_=()=>{let e=a?.getUserId()||"";return e&&!chunkJ3V5QNIH_js.i(e)?e:""},le=()=>a?.getAnonymousId()||"",ge=(e,i="Deriv App",o)=>{let s=_();t("pageView | called",{current_page:e,platform:i,properties:o,userId:s}),a&&(a.has_initialized?(t("pageView | sending page view to RudderStack",{current_page:e,platform:i}),a.pageView(e,i,s,o)):(t("pageView | RudderStack not initialized \u2014 caching page view to cookie",{current_page:e}),X(e,{platform:i,...o})));},fe=(e,i)=>{let o=e||_();if(!o){t("identifyEvent | skipped \u2014 no user_id available");return}t("identifyEvent | called",{user_id:o,traits:i});let s=i?.rudderstack!==void 0||i?.posthog!==void 0,p=s?i?.rudderstack:i,d=s?i?.posthog:i;a&&(a.has_initialized?(t("identifyEvent | calling RudderStack identify",{user_id:o,traits:p}),a.identifyEvent(o,p)):m.some(l=>l.userId===o)||(t("identifyEvent | RudderStack not initialized \u2014 queuing identify call",{user_id:o}),m.push({userId:o,traits:p}))),g?.has_initialized&&d&&(t("identifyEvent | calling PostHog identify",{user_id:o,traits:d}),g.identifyEvent(o,d));},pe=()=>{t("reset | resetting all providers"),a?.has_initialized&&(t("reset | resetting RudderStack"),a.reset()),g?.has_initialized&&(t("reset | resetting PostHog"),g.reset());},ue=e=>"event_metadata"in e||"cta_information"in e||"error"in e,U={initialise:oe,setAttributes:se,identifyEvent:fe,backfillPersonProperties:({user_id:e,email:i,country_of_residence:o})=>{t("backfillPersonProperties | called",{user_id:e}),g?.has_initialized?(t("backfillPersonProperties | backfilling person properties in PostHog",{user_id:e}),g.backfillPersonProperties({user_id:e,email:i,country_of_residence:o})):t("backfillPersonProperties | skipped \u2014 PostHog not initialized");},getFeatureState:ae,getFeatureValue:L,getGrowthbookStatus:re,isFeatureOn:ce,setUrl:de,getId:_,getAnonymousId:le,trackEvent:(e,i)=>{let o=_(),s={};if(t("trackEvent | called",{event:e,analytics_data:i,userId:o,core_data:y}),ue(i)){let l=i;s={...l,event_metadata:{...y,...o&&!y.user_id&&{user_id:o},...l.event_metadata}},t("trackEvent | built V2 payload",{event:e,final_payload:s});}else s={...y,...i,...o&&!y.user_id&&{user_id:o}},t("trackEvent | built V1 payload",{event:e,final_payload:s});if(!(!(e in C)||C[e])){t("trackEvent | skipped \u2014 event disabled by tracking_config",{event:e});return}let d=a?.has_initialized;if(!navigator.onLine||!d)d?(t("trackEvent | offline \u2014 caching event to memory",{event:e}),w.push({event:e,payload:s})):(t("trackEvent | RudderStack not initialized \u2014 caching event to cookie",{event:e}),Q(e,s));else {w.length>0&&(t(`trackEvent | flushing ${w.length} offline cached event(s) to RudderStack`),w.forEach(h=>{let u=chunkJ3V5QNIH_js.k(h.payload);a?.track(h.event,u);}),w=[]);let l=chunkJ3V5QNIH_js.k(s);t("trackEvent | sending event to RudderStack",{event:e,payload:l}),a?.track(e,l);}if(g?.has_initialized){let l=["page_name","user_language","form_name","version","email_hash"],h=chunkJ3V5QNIH_js.l(s),u=chunkJ3V5QNIH_js.k(Object.fromEntries(Object.entries(h).filter(([E])=>!l.includes(E))));t("trackEvent | sending event to PostHog",{event:e,payload:u}),g.capture(e,u);}},getInstances:()=>({ab:f,tracking:a,posthog:g}),pageView:ge,reset:pe};return typeof window<"u"&&(window.AnalyticsInstance=U),U}var ye=he();Object.defineProperty(exports,"cacheTrackEvents",{enumerable:true,get:function(){return chunkSQ6Q4Z5S_js.a}});exports.Analytics=ye;//# sourceMappingURL=index.js.map
3
3
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/utils/cookie.ts","../src/analytics.ts"],"names":["CACHE_COOKIE_EVENTS","CACHE_COOKIE_PAGES","cacheEventToCookie","eventName","properties","domain","getAllowedDomain","existingCache","Cookies","events","cookieOptions","err","cachePageViewToCookie","pageName","pages","getCachedEvents","storedEventsString","getCachedPageViews","storedPagesString","clearCachedEvents","clearCachedPageViews","createAnalyticsInstance","_options","_debug","log","createLogger","_growthbook","_rudderstack","_posthog","core_data","tracking_config","offline_event_cache","_pending_identify_calls","_cookie_cache_processed","processCookieCache","storedEvents","event","storedPages","page","getId","onSdkLoaded","userId","traits","initialise","growthbookKey","growthbookDecryptionKey","rudderstackKey","growthbookOptions","posthogOptions","debug","_a","_b","cacheTrackEvents","country","getCountry","RudderStack","attrs","anonymousId","isUUID","anonId","Growthbook","interval","getFeatureValue","Posthog","setAttributes","user_language","device_language","device_type","account_type","user_id","anonymous_id","app_id","utm_source","utm_medium","utm_campaign","is_authorised","residence_country","url","geo_location","loggedIn","network_downlink","network_rtt","network_type","account_currency","account_mode","user_identity","config","getFeatureState","id","defaultValue","getGrowthbookStatus","isFeatureOn","key","setUrl","href","getAnonymousId","pageView","current_page","platform","identifyEvent","stored_user_id","hasProviderStructure","rudderstackTraits","posthogTraits","call","reset","isV2Payload","payload","AnalyticsInstance","email","analytics_data","final_payload","v2_data","hasRudderstackInitialized","cache","cleaned_cache_payload","cleanObject","cleaned_payload","flattened_payload","flattenObject","cleaned_posthog_payload","Analytics"],"mappings":"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","file":"index.js","sourcesContent":["import Cookies from 'js-cookie'\nimport { getAllowedDomain } from './urls'\n\nexport const CACHE_COOKIE_EVENTS = 'cached_analytics_events'\nexport const CACHE_COOKIE_PAGES = 'cached_analytics_page_views'\n\nexport type CachedEvent = {\n name: string\n properties: Record<string, unknown>\n timestamp: number\n}\n\nexport type CachedPageView = {\n name: string\n properties?: Record<string, unknown>\n timestamp: number\n}\n\nexport const cacheEventToCookie = (eventName: string, properties: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_EVENTS)\n const events: CachedEvent[] = existingCache ? JSON.parse(existingCache) : []\n events.push({ name: eventName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_EVENTS, JSON.stringify(events), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache event', err)\n }\n}\n\nexport const cachePageViewToCookie = (pageName: string, properties?: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_PAGES)\n const pages: CachedPageView[] = existingCache ? JSON.parse(existingCache) : []\n pages.push({ name: pageName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_PAGES, JSON.stringify(pages), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache page view', err)\n }\n}\n\nexport const getCachedEvents = (): CachedEvent[] => {\n try {\n const storedEventsString = Cookies.get(CACHE_COOKIE_EVENTS)\n if (storedEventsString) {\n const events = JSON.parse(storedEventsString)\n return Array.isArray(events) ? events : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached events', err)\n }\n return []\n}\n\nexport const getCachedPageViews = (): CachedPageView[] => {\n try {\n const storedPagesString = Cookies.get(CACHE_COOKIE_PAGES)\n if (storedPagesString) {\n const pages = JSON.parse(storedPagesString)\n return Array.isArray(pages) ? pages : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached pages', err)\n }\n return []\n}\n\nexport const clearCachedEvents = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_EVENTS, cookieOptions)\n}\n\nexport const clearCachedPageViews = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_PAGES, cookieOptions)\n}\n","import { RudderStack } from './providers/rudderstack'\nimport type { TCoreAttributes, TAllEvents, TV2EventPayload } from './types'\nimport {\n cacheEventToCookie,\n cachePageViewToCookie,\n getCachedEvents,\n getCachedPageViews,\n clearCachedEvents,\n clearCachedPageViews,\n} from './utils/cookie'\nimport { isUUID, getCountry, cleanObject, flattenObject, createLogger } from './utils/helpers'\nimport { cacheTrackEvents } from './utils/analytics-cache'\n\n// Optional Growthbook types - only import if using Growthbook\nimport type { Growthbook, GrowthbookConfigs } from './providers/growthbook'\nimport type { TGrowthbookAttributes, TGrowthbookOptions } from './providers/growthbookTypes'\n\n// Optional Posthog types - only import if using Posthog\nimport type { Posthog } from './providers/posthog'\nimport type { TPosthogIdentifyTraits, TPosthogOptions } from './providers/posthogTypes'\n\ndeclare global {\n interface Window {\n AnalyticsInstance: ReturnType<typeof createAnalyticsInstance>\n }\n}\n\n/**\n * Configuration options for initializing the analytics instance\n */\ntype Options = {\n /** GrowthBook client API key for A/B testing and feature flags */\n growthbookKey?: string\n /** GrowthBook decryption key for encrypted feature payloads */\n growthbookDecryptionKey?: string\n /** RudderStack write key for event tracking */\n rudderstackKey?: string\n /** Additional configuration options for GrowthBook */\n growthbookOptions?: TGrowthbookOptions\n /** PostHog configuration options including API keys and settings */\n posthogOptions?: TPosthogOptions\n /** Enable debug logging — logs all analytics calls prefixed with [ANALYTIC] */\n debug?: boolean\n}\n\n/**\n * Creates a unified analytics instance that integrates RudderStack and GrowthBook.\n *\n * This function provides a centralized interface for:\n * - Event tracking across multiple analytics platforms\n * - A/B testing and feature flag management via GrowthBook\n * - Offline event caching with automatic replay\n *\n * @param {Options} _options - Optional initialization configuration\n * @returns {Object} Analytics instance with methods for tracking, identification, and feature management\n *\n * @example\n * ```typescript\n * const analytics = createAnalyticsInstance();\n *\n * // Initialize with providers\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY'\n * });\n *\n * // Set user attributes\n * analytics.setAttributes({\n * user_id: 'user123',\n * country: 'US',\n * user_language: 'en'\n * });\n *\n * // Track events\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // Track page views\n * analytics.pageView('/dashboard', 'Deriv App');\n * ```\n */\nexport function createAnalyticsInstance(_options?: Options) {\n let _debug = _options?.debug ?? false\n\n const log = createLogger('', () => _debug)\n\n let _growthbook: Growthbook | undefined,\n _rudderstack: RudderStack,\n _posthog: Posthog | undefined,\n core_data: Partial<TCoreAttributes> = {},\n tracking_config: { [key: string]: boolean } = {},\n offline_event_cache: Array<{ event: keyof TAllEvents; payload: TAllEvents[keyof TAllEvents] }> = [],\n _pending_identify_calls: Array<{ userId: string; traits?: Record<string, any> }> = [],\n _cookie_cache_processed = false\n\n const processCookieCache = () => {\n if (_cookie_cache_processed) return\n if (!_rudderstack?.has_initialized) return\n\n _cookie_cache_processed = true\n\n try {\n const storedEvents = getCachedEvents()\n if (storedEvents.length > 0) {\n log(`processCookieCache | replaying ${storedEvents.length} cached event(s)`, storedEvents)\n storedEvents.forEach(event => {\n _rudderstack?.track(event.name as keyof TAllEvents, event.properties as any)\n })\n clearCachedEvents()\n }\n\n const storedPages = getCachedPageViews()\n if (storedPages.length > 0) {\n log(`processCookieCache | replaying ${storedPages.length} cached page view(s)`, storedPages)\n storedPages.forEach(page => {\n _rudderstack?.pageView(page.name, 'Deriv App', getId(), page.properties)\n })\n clearCachedPageViews()\n }\n } catch (err) {\n console.warn('Analytics: Failed to process cookie cache', err)\n }\n }\n\n const onSdkLoaded = () => {\n log('onSdkLoaded | RudderStack SDK loaded')\n processCookieCache()\n\n if (_pending_identify_calls.length > 0) {\n log(`onSdkLoaded | flushing ${_pending_identify_calls.length} pending identify call(s)`)\n }\n _pending_identify_calls.forEach(({ userId, traits }) => {\n if (userId) {\n _rudderstack?.identifyEvent(userId, traits)\n }\n })\n _pending_identify_calls = []\n }\n\n /**\n * Initializes the analytics instance with specified provider configurations.\n * This method should be called before tracking any events.\n *\n * Features:\n * - Lazy-loads providers (GrowthBook, PostHog) only when configured\n * - Automatically fetches user's country for GrowthBook targeting\n * - Processes any cached events from previous sessions\n * - Sets up event tracking callback for GrowthBook experiments\n *\n * @param {Options} options - Configuration options for analytics providers\n * @returns {Promise<void>} Resolves when initialization is complete\n *\n * @example\n * ```typescript\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY',\n * posthogOptions: {\n * apiKey: 'YOUR_POSTHOG_API_KEY',\n * config: {\n * session_recording: {\n * recordCrossOriginIframes: true,\n * minimumDurationMilliseconds: 30000\n * }\n * }\n * }\n * });\n * ```\n */\n const initialise = async ({\n growthbookKey,\n growthbookDecryptionKey,\n rudderstackKey,\n growthbookOptions,\n posthogOptions,\n debug,\n }: Options) => {\n if (debug !== undefined) _debug = debug\n cacheTrackEvents.setDebug(_debug)\n\n log('initialise | starting analytics initialization', {\n rudderstack: !!rudderstackKey,\n growthbook: !!growthbookKey,\n posthog: !!posthogOptions,\n })\n\n try {\n // Only fetch country if GrowthBook is enabled and country not provided\n const country = growthbookOptions?.attributes?.country || (growthbookKey ? await getCountry() : undefined)\n\n if (rudderstackKey) {\n log('initialise | initializing RudderStack')\n _rudderstack = RudderStack.getRudderStackInstance(rudderstackKey, onSdkLoaded, _debug)\n }\n\n if (growthbookOptions?.attributes && Object.keys(growthbookOptions.attributes).length > 0) {\n const attrs = growthbookOptions.attributes\n const anonymousId = _rudderstack?.getAnonymousId()\n\n core_data = {\n ...core_data,\n country,\n ...(attrs.user_language && { user_language: attrs.user_language }),\n ...(attrs.account_type && { account_type: attrs.account_type }),\n ...(attrs.app_id && { app_id: attrs.app_id }),\n ...(attrs.residence_country && { residence_country: attrs.residence_country }),\n ...(attrs.device_type && { device_type: attrs.device_type }),\n ...(attrs.url && { url: attrs.url }),\n ...(attrs.email_hash && { email_hash: attrs.email_hash }),\n ...(attrs.network_type && { network_type: attrs.network_type }),\n ...(attrs.network_rtt && { network_rtt: attrs.network_rtt }),\n ...(attrs.network_downlink && { network_downlink: attrs.network_downlink }),\n ...(attrs.account_currency && { account_currency: attrs.account_currency }),\n ...(attrs.account_mode && { account_mode: attrs.account_mode }),\n loggedIn: !!attrs.loggedIn,\n ...(attrs.user_id && !isUUID(attrs.user_id) && { user_id: attrs.user_id }),\n ...(anonymousId && { anonymous_id: anonymousId }),\n }\n }\n\n growthbookOptions ??= {}\n growthbookOptions.attributes ??= {}\n const anonId = _rudderstack?.getAnonymousId()\n growthbookOptions.attributes.id ??= anonId\n growthbookOptions.attributes.country ??= country\n\n if (growthbookKey) {\n log('initialise | initializing GrowthBook')\n // Dynamically import Growthbook only when needed\n const { Growthbook } = await import('./providers/growthbook')\n _growthbook = Growthbook.getGrowthBookInstance(\n growthbookKey,\n growthbookDecryptionKey,\n growthbookOptions,\n _debug\n )\n log('initialise | GrowthBook initialized')\n\n const interval = setInterval(() => {\n if (Object.keys(tracking_config).length > 0) clearInterval(interval)\n else tracking_config = getFeatureValue('tracking-buttons-config', {}) as { [key: string]: boolean }\n }, 1000)\n }\n\n if (posthogOptions) {\n log('initialise | initializing PostHog')\n // Dynamically import Posthog only when needed\n const { Posthog } = await import('./providers/posthog')\n _posthog = Posthog.getPosthogInstance(posthogOptions, _debug)\n log('initialise | PostHog initialized')\n }\n\n log('initialise | analytics initialization complete')\n } catch (err) {\n console.warn('Analytics: Failed to initialize', err)\n }\n }\n\n /**\n * Sets user and context attributes for analytics tracking and targeting.\n * These attributes are automatically included in all subsequent events.\n *\n * Attributes are used for:\n * - Event enrichment (added to all tracked events)\n * - GrowthBook targeting (feature flags and A/B tests)\n * - User segmentation across analytics platforms\n *\n * @param {TCoreAttributes} attributes - User and context attributes\n *\n * @example\n * ```typescript\n * analytics.setAttributes({\n * user_id: 'CR123456',\n * country: 'US',\n * user_language: 'en',\n * device_type: 'desktop',\n * account_type: 'real',\n * loggedIn: true\n * });\n * ```\n */\n const setAttributes = ({\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n }: TCoreAttributes) => {\n const user_identity = user_id ?? getId()\n\n log('setAttributes | received attributes', {\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n })\n\n if (_growthbook) {\n const config: TGrowthbookAttributes = {\n country,\n residence_country,\n user_language,\n device_language,\n device_type,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n url,\n domain,\n loggedIn,\n ...(user_id && !isUUID(user_id) && { user_id }),\n anonymous_id,\n }\n if (user_identity) {\n config.id = user_identity\n config.user_id = user_identity\n }\n log('setAttributes | called GrowthBook setAttributes', config)\n _growthbook.setAttributes(config)\n }\n\n core_data = {\n ...core_data,\n ...(country !== undefined && { country }),\n ...(geo_location !== undefined && { geo_location }),\n ...(user_language !== undefined && { user_language }),\n ...(account_type !== undefined && { account_type }),\n ...(app_id !== undefined && { app_id }),\n ...(residence_country !== undefined && { residence_country }),\n ...(device_type !== undefined && { device_type }),\n ...(url !== undefined && { url }),\n ...(loggedIn !== undefined && { loggedIn }),\n ...(network_downlink !== undefined && { network_downlink }),\n ...(network_rtt !== undefined && { network_rtt }),\n ...(network_type !== undefined && { network_type }),\n ...(user_id !== undefined && !isUUID(user_id) && { user_id }),\n ...(anonymous_id !== undefined && { anonymous_id }),\n ...(account_currency !== undefined && { account_currency }),\n ...(account_mode !== undefined && { account_mode }),\n }\n\n log('setAttributes | updated core_data', core_data)\n }\n\n const getFeatureState = (id: string) => _growthbook?.getFeatureState(id)?.experimentResult?.name\n\n const getFeatureValue = <K extends keyof GrowthbookConfigs, V extends GrowthbookConfigs[K]>(\n id: K,\n defaultValue: V\n ) => _growthbook?.getFeatureValue(id as string, defaultValue)\n\n const getGrowthbookStatus = async () => await _growthbook?.getStatus()\n const isFeatureOn = (key: string) => _growthbook?.isOn(key)\n const setUrl = (href: string) => _growthbook?.setUrl(href)\n\n const getId = () => {\n const userId = _rudderstack?.getUserId() || ''\n return userId && !isUUID(userId) ? userId : ''\n }\n\n const getAnonymousId = () => _rudderstack?.getAnonymousId() || ''\n\n /**\n * Tracks a page view event.\n *\n * Features:\n * - Automatically includes user ID if available\n * - Caches page views when offline or provider not initialized\n *\n * @param {string} current_page - The current page URL or path\n * @param {string} [platform='Deriv App'] - The platform name\n * @param {Record<string, unknown>} [properties] - Additional page properties\n *\n * @example\n * ```typescript\n * analytics.pageView('/dashboard');\n * analytics.pageView('/trade', 'Deriv Trader', { section: 'multipliers' });\n * ```\n */\n const pageView = (current_page: string, platform = 'Deriv App', properties?: Record<string, unknown>) => {\n const userId = getId()\n\n log('pageView | called', { current_page, platform, properties, userId })\n\n // Handle RudderStack pageView independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('pageView | sending page view to RudderStack', { current_page, platform })\n _rudderstack.pageView(current_page, platform, userId, properties)\n } else {\n log('pageView | RudderStack not initialized — caching page view to cookie', { current_page })\n cachePageViewToCookie(current_page, { platform, ...properties })\n }\n }\n\n // PostHog handles page views automatically via autocapture\n // No need to manually send page views to PostHog\n }\n\n /**\n * Identifies a user across analytics platforms.\n * This method should be called after user login or when user identity is known.\n *\n * Features:\n * - Queues identify calls if provider not yet initialized\n * - Allows custom traits for each provider or shared traits for both\n * - Identifies user in PostHog if configured\n *\n * @param {string} [user_id] - The user ID to identify. If not provided, uses stored user ID\n * @param {Record<string, any>} [traits] - Optional traits to send to both providers, or provider-specific traits\n *\n * @example\n * ```typescript\n * // Simple identify\n * analytics.identifyEvent('CR123456');\n *\n * // Identify with same traits for both providers\n * analytics.identifyEvent('CR123456', {\n * language: 'en',\n * country_of_residence: 'US'\n * });\n *\n * // Identify with provider-specific traits\n * analytics.identifyEvent('CR123456', {\n * rudderstack: { language: 'en', custom_field: 'value' },\n * posthog: { language: 'en', country_of_residence: 'US' }\n * });\n * ```\n */\n const identifyEvent = (user_id?: string, traits?: Record<string, any>) => {\n const stored_user_id = user_id || getId()\n if (!stored_user_id) {\n log('identifyEvent | skipped — no user_id available')\n return\n }\n\n log('identifyEvent | called', { user_id: stored_user_id, traits })\n\n // Check if traits has provider-specific structure\n const hasProviderStructure = traits?.rudderstack !== undefined || traits?.posthog !== undefined\n const rudderstackTraits = hasProviderStructure ? traits?.rudderstack : traits\n const posthogTraits = hasProviderStructure ? traits?.posthog : traits\n\n // Handle RudderStack identification independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('identifyEvent | calling RudderStack identify', {\n user_id: stored_user_id,\n traits: rudderstackTraits,\n })\n _rudderstack.identifyEvent(stored_user_id, rudderstackTraits)\n } else {\n if (!_pending_identify_calls.some(call => call.userId === stored_user_id)) {\n log('identifyEvent | RudderStack not initialized — queuing identify call', {\n user_id: stored_user_id,\n })\n _pending_identify_calls.push({ userId: stored_user_id, traits: rudderstackTraits })\n }\n }\n }\n\n // Handle PostHog identification independently\n if (_posthog?.has_initialized && posthogTraits) {\n log('identifyEvent | calling PostHog identify', { user_id: stored_user_id, traits: posthogTraits })\n _posthog.identifyEvent(stored_user_id, posthogTraits as TPosthogIdentifyTraits)\n }\n }\n\n const reset = () => {\n log('reset | resetting all providers')\n // Reset each provider independently\n if (_rudderstack?.has_initialized) {\n log('reset | resetting RudderStack')\n _rudderstack.reset()\n }\n if (_posthog?.has_initialized) {\n log('reset | resetting PostHog')\n _posthog.reset()\n }\n }\n\n const isV2Payload = (payload: any): payload is TV2EventPayload => {\n return 'event_metadata' in payload || 'cta_information' in payload || 'error' in payload\n }\n\n /**\n * Tracks a custom event with associated data.\n *\n * Features:\n * - Automatically enriches events with core attributes\n * - Supports both V1 and V2 event payload formats\n * - RudderStack: Caches events when offline or not initialized\n * - PostHog: Sends immediately if initialized (has built-in caching)\n * - Respects feature flag configurations\n * - Each provider works independently - one failing won't affect the other\n *\n * @template T - The event name type from TAllEvents\n * @param {T} event - The event name to track\n * @param {TAllEvents[T]} analytics_data - The event data payload\n *\n * @example\n * ```typescript\n * // Simple event\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // V2 event with metadata\n * analytics.trackEvent('form_submitted', {\n * event_metadata: { form_name: 'registration' },\n * cta_information: { button_text: 'Create Account' }\n * });\n * ```\n */\n const trackEvent = <T extends keyof TAllEvents>(event: T, analytics_data: TAllEvents[T]) => {\n const userId = getId()\n let final_payload: any = {}\n\n log('trackEvent | called', { event, analytics_data, userId, core_data })\n\n if (isV2Payload(analytics_data)) {\n const v2_data = analytics_data as TV2EventPayload\n final_payload = {\n ...v2_data,\n event_metadata: {\n ...core_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n ...v2_data.event_metadata,\n },\n }\n log('trackEvent | built V2 payload', { event, final_payload })\n } else {\n final_payload = {\n ...core_data,\n ...analytics_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n }\n log('trackEvent | built V1 payload', { event, final_payload })\n }\n\n const shouldTrack = !(event in tracking_config) || tracking_config[event as string]\n if (!shouldTrack) {\n log('trackEvent | skipped — event disabled by tracking_config', { event })\n return\n }\n\n // Handle RudderStack independently\n const hasRudderstackInitialized = _rudderstack?.has_initialized\n if (!navigator.onLine || !hasRudderstackInitialized) {\n if (!hasRudderstackInitialized) {\n log('trackEvent | RudderStack not initialized — caching event to cookie', { event })\n cacheEventToCookie(event as string, final_payload)\n } else {\n log('trackEvent | offline — caching event to memory', { event })\n offline_event_cache.push({ event, payload: final_payload })\n }\n } else {\n // Send cached events to RudderStack\n if (offline_event_cache.length > 0) {\n log(`trackEvent | flushing ${offline_event_cache.length} offline cached event(s) to RudderStack`)\n offline_event_cache.forEach(cache => {\n const cleaned_cache_payload = cleanObject(cache.payload)\n _rudderstack?.track(cache.event, cleaned_cache_payload)\n })\n offline_event_cache = []\n }\n\n // Send current event to RudderStack\n const cleaned_payload = cleanObject(final_payload)\n log('trackEvent | sending event to RudderStack', { event, payload: cleaned_payload })\n _rudderstack?.track(event, cleaned_payload)\n }\n\n // Handle PostHog independently - send immediately if initialized\n if (_posthog?.has_initialized) {\n const flattened_payload = flattenObject(final_payload)\n const cleaned_posthog_payload = cleanObject(flattened_payload)\n log('trackEvent | sending event to PostHog', { event, payload: cleaned_posthog_payload })\n _posthog.capture(event as string, cleaned_posthog_payload)\n }\n }\n\n /**\n * Ensures client_id is set in PostHog stored person properties.\n * Call this when the user ID is available and PostHog is loaded.\n * Useful for backfilling client_id for users identified in previous sessions.\n * No-op if client_id is already present or PostHog is not initialized.\n *\n * @param user_id - The user ID to use as client_id\n *\n * @example\n * ```typescript\n * if (window.posthog?.__loaded && userId) {\n * analytics.backfillPersonProperties(userId, email)\n * }\n * ```\n */\n const backfillPersonProperties = (user_id: string, email?: string): void => {\n log('backfillPersonProperties | called', { user_id })\n if (_posthog?.has_initialized) {\n log('backfillPersonProperties | backfilling person properties in PostHog', { user_id })\n _posthog.backfillPersonProperties(user_id, email)\n } else {\n log('backfillPersonProperties | skipped — PostHog not initialized')\n }\n }\n\n const getInstances = () => ({ ab: _growthbook, tracking: _rudderstack, posthog: _posthog })\n\n const AnalyticsInstance = {\n initialise,\n setAttributes,\n identifyEvent,\n backfillPersonProperties,\n getFeatureState,\n getFeatureValue,\n getGrowthbookStatus,\n isFeatureOn,\n setUrl,\n getId,\n getAnonymousId,\n trackEvent,\n getInstances,\n pageView,\n reset,\n }\n\n if (typeof window !== 'undefined') {\n window.AnalyticsInstance = AnalyticsInstance\n }\n\n return AnalyticsInstance\n}\n\nexport const Analytics = createAnalyticsInstance()\n"]}
1
+ {"version":3,"sources":["../src/utils/cookie.ts","../src/analytics.ts"],"names":["CACHE_COOKIE_EVENTS","CACHE_COOKIE_PAGES","cacheEventToCookie","eventName","properties","domain","getAllowedDomain","existingCache","Cookies","events","cookieOptions","err","cachePageViewToCookie","pageName","pages","getCachedEvents","storedEventsString","getCachedPageViews","storedPagesString","clearCachedEvents","clearCachedPageViews","createAnalyticsInstance","_options","_debug","log","createLogger","_growthbook","_rudderstack","_posthog","core_data","tracking_config","offline_event_cache","_pending_identify_calls","_cookie_cache_processed","processCookieCache","storedEvents","event","cleaned_properties","cleanObject","storedPages","page","getId","onSdkLoaded","userId","traits","initialise","growthbookKey","growthbookDecryptionKey","rudderstackKey","growthbookOptions","posthogOptions","debug","_a","_b","cacheTrackEvents","country","getCountry","RudderStack","attrs","anonymousId","isUUID","anonId","Growthbook","interval","getFeatureValue","Posthog","setAttributes","user_language","device_language","device_type","account_type","user_id","anonymous_id","app_id","utm_source","utm_medium","utm_campaign","is_authorised","residence_country","url","geo_location","loggedIn","network_downlink","network_rtt","network_type","account_currency","account_mode","user_identity","config","getFeatureState","id","defaultValue","getGrowthbookStatus","isFeatureOn","key","setUrl","href","getAnonymousId","pageView","current_page","platform","identifyEvent","stored_user_id","hasProviderStructure","rudderstackTraits","posthogTraits","call","reset","isV2Payload","payload","AnalyticsInstance","email","country_of_residence","analytics_data","final_payload","v2_data","hasRudderstackInitialized","cache","cleaned_cache_payload","cleaned_payload","posthog_excluded_keys","flattened_payload","flattenObject","posthog_payload","Analytics"],"mappings":"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","file":"index.js","sourcesContent":["import Cookies from 'js-cookie'\nimport { getAllowedDomain } from './urls'\n\nexport const CACHE_COOKIE_EVENTS = 'cached_analytics_events'\nexport const CACHE_COOKIE_PAGES = 'cached_analytics_page_views'\n\nexport type CachedEvent = {\n name: string\n properties: Record<string, unknown>\n timestamp: number\n}\n\nexport type CachedPageView = {\n name: string\n properties?: Record<string, unknown>\n timestamp: number\n}\n\nexport const cacheEventToCookie = (eventName: string, properties: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_EVENTS)\n const events: CachedEvent[] = existingCache ? JSON.parse(existingCache) : []\n events.push({ name: eventName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_EVENTS, JSON.stringify(events), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache event', err)\n }\n}\n\nexport const cachePageViewToCookie = (pageName: string, properties?: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_PAGES)\n const pages: CachedPageView[] = existingCache ? JSON.parse(existingCache) : []\n pages.push({ name: pageName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_PAGES, JSON.stringify(pages), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache page view', err)\n }\n}\n\nexport const getCachedEvents = (): CachedEvent[] => {\n try {\n const storedEventsString = Cookies.get(CACHE_COOKIE_EVENTS)\n if (storedEventsString) {\n const events = JSON.parse(storedEventsString)\n return Array.isArray(events) ? events : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached events', err)\n }\n return []\n}\n\nexport const getCachedPageViews = (): CachedPageView[] => {\n try {\n const storedPagesString = Cookies.get(CACHE_COOKIE_PAGES)\n if (storedPagesString) {\n const pages = JSON.parse(storedPagesString)\n return Array.isArray(pages) ? pages : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached pages', err)\n }\n return []\n}\n\nexport const clearCachedEvents = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_EVENTS, cookieOptions)\n}\n\nexport const clearCachedPageViews = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_PAGES, cookieOptions)\n}\n","import { RudderStack } from './providers/rudderstack'\nimport type { TCoreAttributes, TAllEvents, TV2EventPayload } from './types'\nimport {\n cacheEventToCookie,\n cachePageViewToCookie,\n getCachedEvents,\n getCachedPageViews,\n clearCachedEvents,\n clearCachedPageViews,\n} from './utils/cookie'\nimport { isUUID, getCountry, cleanObject, flattenObject, createLogger } from './utils/helpers'\nimport { cacheTrackEvents } from './utils/analytics-cache'\n\n// Optional Growthbook types - only import if using Growthbook\nimport type { Growthbook, GrowthbookConfigs } from './providers/growthbook'\nimport type { TGrowthbookAttributes, TGrowthbookOptions } from './providers/growthbookTypes'\n\n// Optional Posthog types - only import if using Posthog\nimport type { Posthog } from './providers/posthog'\nimport type { TPosthogIdentifyTraits, TPosthogOptions } from './providers/posthogTypes'\n\ndeclare global {\n interface Window {\n AnalyticsInstance: ReturnType<typeof createAnalyticsInstance>\n }\n}\n\n/**\n * Configuration options for initializing the analytics instance\n */\ntype Options = {\n /** GrowthBook client API key for A/B testing and feature flags */\n growthbookKey?: string\n /** GrowthBook decryption key for encrypted feature payloads */\n growthbookDecryptionKey?: string\n /** RudderStack write key for event tracking */\n rudderstackKey?: string\n /** Additional configuration options for GrowthBook */\n growthbookOptions?: TGrowthbookOptions\n /** PostHog configuration options including API keys and settings */\n posthogOptions?: TPosthogOptions\n /** Enable debug logging — logs all analytics calls prefixed with [ANALYTIC] */\n debug?: boolean\n}\n\n/**\n * Creates a unified analytics instance that integrates RudderStack and GrowthBook.\n *\n * This function provides a centralized interface for:\n * - Event tracking across multiple analytics platforms\n * - A/B testing and feature flag management via GrowthBook\n * - Offline event caching with automatic replay\n *\n * @param {Options} _options - Optional initialization configuration\n * @returns {Object} Analytics instance with methods for tracking, identification, and feature management\n *\n * @example\n * ```typescript\n * const analytics = createAnalyticsInstance();\n *\n * // Initialize with providers\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY'\n * });\n *\n * // Set user attributes\n * analytics.setAttributes({\n * user_id: 'user123',\n * country: 'US',\n * user_language: 'en'\n * });\n *\n * // Track events\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // Track page views\n * analytics.pageView('/dashboard', 'Deriv App');\n * ```\n */\nexport function createAnalyticsInstance(_options?: Options) {\n let _debug = _options?.debug ?? false\n\n const log = createLogger('', () => _debug)\n\n let _growthbook: Growthbook | undefined,\n _rudderstack: RudderStack,\n _posthog: Posthog | undefined,\n core_data: Partial<TCoreAttributes> = {},\n tracking_config: { [key: string]: boolean } = {},\n offline_event_cache: Array<{ event: keyof TAllEvents; payload: TAllEvents[keyof TAllEvents] }> = [],\n _pending_identify_calls: Array<{ userId: string; traits?: Record<string, any> }> = [],\n _cookie_cache_processed = false\n\n const processCookieCache = () => {\n if (_cookie_cache_processed) return\n if (!_rudderstack?.has_initialized) return\n\n _cookie_cache_processed = true\n\n try {\n const storedEvents = getCachedEvents()\n if (storedEvents.length > 0) {\n log(`processCookieCache | replaying ${storedEvents.length} cached event(s)`, storedEvents)\n storedEvents.forEach(event => {\n const cleaned_properties = cleanObject(event.properties)\n _rudderstack?.track(event.name as keyof TAllEvents, cleaned_properties as any)\n })\n clearCachedEvents()\n }\n\n const storedPages = getCachedPageViews()\n if (storedPages.length > 0) {\n log(`processCookieCache | replaying ${storedPages.length} cached page view(s)`, storedPages)\n storedPages.forEach(page => {\n _rudderstack?.pageView(page.name, 'Deriv App', getId(), page.properties)\n })\n clearCachedPageViews()\n }\n } catch (err) {\n console.warn('Analytics: Failed to process cookie cache', err)\n }\n }\n\n const onSdkLoaded = () => {\n log('onSdkLoaded | RudderStack SDK loaded')\n processCookieCache()\n\n if (_pending_identify_calls.length > 0) {\n log(`onSdkLoaded | flushing ${_pending_identify_calls.length} pending identify call(s)`)\n }\n _pending_identify_calls.forEach(({ userId, traits }) => {\n if (userId) {\n _rudderstack?.identifyEvent(userId, traits)\n }\n })\n _pending_identify_calls = []\n }\n\n /**\n * Initializes the analytics instance with specified provider configurations.\n * This method should be called before tracking any events.\n *\n * Features:\n * - Lazy-loads providers (GrowthBook, PostHog) only when configured\n * - Automatically fetches user's country for GrowthBook targeting\n * - Processes any cached events from previous sessions\n * - Sets up event tracking callback for GrowthBook experiments\n *\n * @param {Options} options - Configuration options for analytics providers\n * @returns {Promise<void>} Resolves when initialization is complete\n *\n * @example\n * ```typescript\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY',\n * posthogOptions: {\n * apiKey: 'YOUR_POSTHOG_API_KEY',\n * config: {\n * session_recording: {\n * recordCrossOriginIframes: true,\n * minimumDurationMilliseconds: 30000\n * }\n * }\n * }\n * });\n * ```\n */\n const initialise = async ({\n growthbookKey,\n growthbookDecryptionKey,\n rudderstackKey,\n growthbookOptions,\n posthogOptions,\n debug,\n }: Options) => {\n if (debug !== undefined) _debug = debug\n cacheTrackEvents.setDebug(_debug)\n\n log('initialise | starting analytics initialization', {\n rudderstack: !!rudderstackKey,\n growthbook: !!growthbookKey,\n posthog: !!posthogOptions,\n })\n\n try {\n // Only fetch country if GrowthBook is enabled and country not provided\n const country = growthbookOptions?.attributes?.country || (growthbookKey ? await getCountry() : undefined)\n\n if (rudderstackKey) {\n log('initialise | initializing RudderStack')\n _rudderstack = RudderStack.getRudderStackInstance(rudderstackKey, onSdkLoaded, _debug)\n }\n\n if (growthbookOptions?.attributes && Object.keys(growthbookOptions.attributes).length > 0) {\n const attrs = growthbookOptions.attributes\n const anonymousId = _rudderstack?.getAnonymousId()\n\n core_data = {\n ...core_data,\n country,\n ...(attrs.user_language && { user_language: attrs.user_language }),\n ...(attrs.account_type && { account_type: attrs.account_type }),\n ...(attrs.app_id && { app_id: attrs.app_id }),\n ...(attrs.residence_country && { residence_country: attrs.residence_country }),\n ...(attrs.device_type && { device_type: attrs.device_type }),\n ...(attrs.url && { url: attrs.url }),\n ...(attrs.email_hash && { email_hash: attrs.email_hash }),\n ...(attrs.network_type && { network_type: attrs.network_type }),\n ...(attrs.network_rtt && { network_rtt: attrs.network_rtt }),\n ...(attrs.network_downlink && { network_downlink: attrs.network_downlink }),\n ...(attrs.account_currency && { account_currency: attrs.account_currency }),\n ...(attrs.account_mode && { account_mode: attrs.account_mode }),\n loggedIn: !!attrs.loggedIn,\n ...(attrs.user_id && !isUUID(attrs.user_id) && { user_id: attrs.user_id }),\n ...(anonymousId && { anonymous_id: anonymousId }),\n }\n }\n\n growthbookOptions ??= {}\n growthbookOptions.attributes ??= {}\n const anonId = _rudderstack?.getAnonymousId()\n growthbookOptions.attributes.id ??= anonId\n growthbookOptions.attributes.country ??= country\n\n if (growthbookKey) {\n log('initialise | initializing GrowthBook')\n // Dynamically import Growthbook only when needed\n const { Growthbook } = await import('./providers/growthbook')\n _growthbook = Growthbook.getGrowthBookInstance(\n growthbookKey,\n growthbookDecryptionKey,\n growthbookOptions,\n _debug\n )\n log('initialise | GrowthBook initialized')\n\n const interval = setInterval(() => {\n if (Object.keys(tracking_config).length > 0) clearInterval(interval)\n else tracking_config = getFeatureValue('tracking-buttons-config', {}) as { [key: string]: boolean }\n }, 1000)\n }\n\n if (posthogOptions) {\n log('initialise | initializing PostHog')\n // Dynamically import Posthog only when needed\n const { Posthog } = await import('./providers/posthog')\n _posthog = Posthog.getPosthogInstance(posthogOptions, _debug)\n log('initialise | PostHog initialized')\n }\n\n log('initialise | analytics initialization complete')\n } catch (err) {\n console.warn('Analytics: Failed to initialize', err)\n }\n }\n\n /**\n * Sets user and context attributes for analytics tracking and targeting.\n * These attributes are automatically included in all subsequent events.\n *\n * Attributes are used for:\n * - Event enrichment (added to all tracked events)\n * - GrowthBook targeting (feature flags and A/B tests)\n * - User segmentation across analytics platforms\n *\n * @param {TCoreAttributes} attributes - User and context attributes\n *\n * @example\n * ```typescript\n * analytics.setAttributes({\n * user_id: 'CR123456',\n * country: 'US',\n * user_language: 'en',\n * device_type: 'desktop',\n * account_type: 'real',\n * loggedIn: true\n * });\n * ```\n */\n const setAttributes = ({\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n }: TCoreAttributes) => {\n const user_identity = user_id ?? getId()\n\n log('setAttributes | received attributes', {\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n })\n\n if (_growthbook) {\n const config: TGrowthbookAttributes = {\n country,\n residence_country,\n user_language,\n device_language,\n device_type,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n url,\n domain,\n loggedIn,\n ...(user_id && !isUUID(user_id) && { user_id }),\n anonymous_id,\n }\n if (user_identity) {\n config.id = user_identity\n config.user_id = user_identity\n }\n log('setAttributes | called GrowthBook setAttributes', config)\n _growthbook.setAttributes(config)\n }\n\n core_data = {\n ...core_data,\n ...(country !== undefined && { country }),\n ...(geo_location !== undefined && { geo_location }),\n ...(user_language !== undefined && { user_language }),\n ...(account_type !== undefined && { account_type }),\n ...(app_id !== undefined && { app_id }),\n ...(residence_country !== undefined && { residence_country }),\n ...(device_type !== undefined && { device_type }),\n ...(url !== undefined && { url }),\n ...(loggedIn !== undefined && { loggedIn }),\n ...(network_downlink !== undefined && { network_downlink }),\n ...(network_rtt !== undefined && { network_rtt }),\n ...(network_type !== undefined && { network_type }),\n ...(user_id !== undefined && !isUUID(user_id) && { user_id }),\n ...(anonymous_id !== undefined && { anonymous_id }),\n ...(account_currency !== undefined && { account_currency }),\n ...(account_mode !== undefined && { account_mode }),\n }\n\n log('setAttributes | updated core_data', core_data)\n }\n\n const getFeatureState = (id: string) => _growthbook?.getFeatureState(id)?.experimentResult?.name\n\n const getFeatureValue = <K extends keyof GrowthbookConfigs, V extends GrowthbookConfigs[K]>(\n id: K,\n defaultValue: V\n ) => _growthbook?.getFeatureValue(id as string, defaultValue)\n\n const getGrowthbookStatus = async () => await _growthbook?.getStatus()\n const isFeatureOn = (key: string) => _growthbook?.isOn(key)\n const setUrl = (href: string) => _growthbook?.setUrl(href)\n\n const getId = () => {\n const userId = _rudderstack?.getUserId() || ''\n return userId && !isUUID(userId) ? userId : ''\n }\n\n const getAnonymousId = () => _rudderstack?.getAnonymousId() || ''\n\n /**\n * Tracks a page view event.\n *\n * Features:\n * - Automatically includes user ID if available\n * - Caches page views when offline or provider not initialized\n *\n * @param {string} current_page - The current page URL or path\n * @param {string} [platform='Deriv App'] - The platform name\n * @param {Record<string, unknown>} [properties] - Additional page properties\n *\n * @example\n * ```typescript\n * analytics.pageView('/dashboard');\n * analytics.pageView('/trade', 'Deriv Trader', { section: 'multipliers' });\n * ```\n */\n const pageView = (current_page: string, platform = 'Deriv App', properties?: Record<string, unknown>) => {\n const userId = getId()\n\n log('pageView | called', { current_page, platform, properties, userId })\n\n // Handle RudderStack pageView independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('pageView | sending page view to RudderStack', { current_page, platform })\n _rudderstack.pageView(current_page, platform, userId, properties)\n } else {\n log('pageView | RudderStack not initialized — caching page view to cookie', { current_page })\n cachePageViewToCookie(current_page, { platform, ...properties })\n }\n }\n\n // PostHog handles page views automatically via autocapture\n // No need to manually send page views to PostHog\n }\n\n /**\n * Identifies a user across analytics platforms.\n * This method should be called after user login or when user identity is known.\n *\n * Features:\n * - Queues identify calls if provider not yet initialized\n * - Allows custom traits for each provider or shared traits for both\n * - Identifies user in PostHog if configured\n *\n * @param {string} [user_id] - The user ID to identify. If not provided, uses stored user ID\n * @param {Record<string, any>} [traits] - Optional traits to send to both providers, or provider-specific traits\n *\n * @example\n * ```typescript\n * // Simple identify\n * analytics.identifyEvent('CR123456');\n *\n * // Identify with same traits for both providers\n * analytics.identifyEvent('CR123456', {\n * language: 'en',\n * country_of_residence: 'US'\n * });\n *\n * // Identify with provider-specific traits\n * analytics.identifyEvent('CR123456', {\n * rudderstack: { language: 'en', custom_field: 'value' },\n * posthog: { language: 'en', country_of_residence: 'US' }\n * });\n * ```\n */\n const identifyEvent = (user_id?: string, traits?: Record<string, any>) => {\n const stored_user_id = user_id || getId()\n if (!stored_user_id) {\n log('identifyEvent | skipped — no user_id available')\n return\n }\n\n log('identifyEvent | called', { user_id: stored_user_id, traits })\n\n // Check if traits has provider-specific structure\n const hasProviderStructure = traits?.rudderstack !== undefined || traits?.posthog !== undefined\n const rudderstackTraits = hasProviderStructure ? traits?.rudderstack : traits\n const posthogTraits = hasProviderStructure ? traits?.posthog : traits\n\n // Handle RudderStack identification independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('identifyEvent | calling RudderStack identify', {\n user_id: stored_user_id,\n traits: rudderstackTraits,\n })\n _rudderstack.identifyEvent(stored_user_id, rudderstackTraits)\n } else {\n if (!_pending_identify_calls.some(call => call.userId === stored_user_id)) {\n log('identifyEvent | RudderStack not initialized — queuing identify call', {\n user_id: stored_user_id,\n })\n _pending_identify_calls.push({ userId: stored_user_id, traits: rudderstackTraits })\n }\n }\n }\n\n // Handle PostHog identification independently\n if (_posthog?.has_initialized && posthogTraits) {\n log('identifyEvent | calling PostHog identify', { user_id: stored_user_id, traits: posthogTraits })\n _posthog.identifyEvent(stored_user_id, posthogTraits as TPosthogIdentifyTraits)\n }\n }\n\n const reset = () => {\n log('reset | resetting all providers')\n // Reset each provider independently\n if (_rudderstack?.has_initialized) {\n log('reset | resetting RudderStack')\n _rudderstack.reset()\n }\n if (_posthog?.has_initialized) {\n log('reset | resetting PostHog')\n _posthog.reset()\n }\n }\n\n const isV2Payload = (payload: any): payload is TV2EventPayload => {\n return 'event_metadata' in payload || 'cta_information' in payload || 'error' in payload\n }\n\n /**\n * Tracks a custom event with associated data.\n *\n * Features:\n * - Automatically enriches events with core attributes\n * - Supports both V1 and V2 event payload formats\n * - RudderStack: Caches events when offline or not initialized\n * - PostHog: Sends immediately if initialized (has built-in caching)\n * - Respects feature flag configurations\n * - Each provider works independently - one failing won't affect the other\n *\n * @template T - The event name type from TAllEvents\n * @param {T} event - The event name to track\n * @param {TAllEvents[T]} analytics_data - The event data payload\n *\n * @example\n * ```typescript\n * // Simple event\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // V2 event with metadata\n * analytics.trackEvent('form_submitted', {\n * event_metadata: { form_name: 'registration' },\n * cta_information: { button_text: 'Create Account' }\n * });\n * ```\n */\n const trackEvent = <T extends keyof TAllEvents>(event: T, analytics_data: TAllEvents[T]) => {\n const userId = getId()\n let final_payload: any = {}\n\n log('trackEvent | called', { event, analytics_data, userId, core_data })\n\n if (isV2Payload(analytics_data)) {\n const v2_data = analytics_data as TV2EventPayload\n final_payload = {\n ...v2_data,\n event_metadata: {\n ...core_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n ...v2_data.event_metadata,\n },\n }\n log('trackEvent | built V2 payload', { event, final_payload })\n } else {\n final_payload = {\n ...core_data,\n ...analytics_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n }\n log('trackEvent | built V1 payload', { event, final_payload })\n }\n\n const shouldTrack = !(event in tracking_config) || tracking_config[event as string]\n if (!shouldTrack) {\n log('trackEvent | skipped — event disabled by tracking_config', { event })\n return\n }\n\n // Handle RudderStack independently\n const hasRudderstackInitialized = _rudderstack?.has_initialized\n if (!navigator.onLine || !hasRudderstackInitialized) {\n if (!hasRudderstackInitialized) {\n log('trackEvent | RudderStack not initialized — caching event to cookie', { event })\n cacheEventToCookie(event as string, final_payload)\n } else {\n log('trackEvent | offline — caching event to memory', { event })\n offline_event_cache.push({ event, payload: final_payload })\n }\n } else {\n // Send cached events to RudderStack\n if (offline_event_cache.length > 0) {\n log(`trackEvent | flushing ${offline_event_cache.length} offline cached event(s) to RudderStack`)\n offline_event_cache.forEach(cache => {\n const cleaned_cache_payload = cleanObject(cache.payload)\n _rudderstack?.track(cache.event, cleaned_cache_payload)\n })\n offline_event_cache = []\n }\n\n // Send current event to RudderStack\n const cleaned_payload = cleanObject(final_payload)\n log('trackEvent | sending event to RudderStack', { event, payload: cleaned_payload })\n _rudderstack?.track(event, cleaned_payload)\n }\n\n // Handle PostHog independently - send immediately if initialized\n if (_posthog?.has_initialized) {\n const posthog_excluded_keys = ['page_name', 'user_language', 'form_name', 'version', 'email_hash'] as const\n const flattened_payload = flattenObject(final_payload)\n const posthog_payload = cleanObject(\n Object.fromEntries(\n Object.entries(flattened_payload).filter(([key]) => !posthog_excluded_keys.includes(key as any))\n )\n )\n log('trackEvent | sending event to PostHog', { event, payload: posthog_payload })\n _posthog.capture(event as string, posthog_payload)\n }\n }\n\n /**\n * Ensures client_id is set in PostHog stored person properties.\n * Call this when the user ID is available and PostHog is loaded.\n * Useful for backfilling client_id for users identified in previous sessions.\n * No-op if client_id is already present or PostHog is not initialized.\n *\n * @param params.user_id - The user ID to use as client_id\n * @param params.email - The user's email, used to determine is_internal\n * @param params.country_of_residence - The user's country of residence\n *\n * @example\n * ```typescript\n * if (window.posthog?.__loaded && userId) {\n * analytics.backfillPersonProperties({ user_id: userId, email, country_of_residence })\n * }\n * ```\n */\n const backfillPersonProperties = ({\n user_id,\n email,\n country_of_residence,\n }: {\n user_id: string\n email?: string\n country_of_residence?: string\n }): void => {\n log('backfillPersonProperties | called', { user_id })\n if (_posthog?.has_initialized) {\n log('backfillPersonProperties | backfilling person properties in PostHog', { user_id })\n _posthog.backfillPersonProperties({ user_id, email, country_of_residence })\n } else {\n log('backfillPersonProperties | skipped — PostHog not initialized')\n }\n }\n\n const getInstances = () => ({ ab: _growthbook, tracking: _rudderstack, posthog: _posthog })\n\n const AnalyticsInstance = {\n initialise,\n setAttributes,\n identifyEvent,\n backfillPersonProperties,\n getFeatureState,\n getFeatureValue,\n getGrowthbookStatus,\n isFeatureOn,\n setUrl,\n getId,\n getAnonymousId,\n trackEvent,\n getInstances,\n pageView,\n reset,\n }\n\n if (typeof window !== 'undefined') {\n window.AnalyticsInstance = AnalyticsInstance\n }\n\n return AnalyticsInstance\n}\n\nexport const Analytics = createAnalyticsInstance()\n"]}
package/dist/index.mjs CHANGED
@@ -1,3 +1,3 @@
1
- import {a as a$1}from'./chunk-D2MKQCJB.mjs';import {a}from'./chunk-7CT4XR74.mjs';export{a as cacheTrackEvents}from'./chunk-7CT4XR74.mjs';import {g,i,j,f,k as k$1,l}from'./chunk-ID2GN2PS.mjs';import k from'js-cookie';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var x="cached_analytics_events",R="cached_analytics_page_views",M=(r,c)=>{try{let t=f(),f$1=k.get(x),a=f$1?JSON.parse(f$1):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k.set(x,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache event",t);}},Q=(r,c)=>{try{let t=f(),f$1=k.get(R),a=f$1?JSON.parse(f$1):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k.set(R,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache page view",t);}},X=()=>{try{let r=k.get(x);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached events",r);}return []},Y=()=>{try{let r=k.get(R);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached pages",r);}return []},Z=()=>{let r=f(),c=r?{domain:r}:{};k.remove(x,c);},ee=()=>{let r=f(),c=r?{domain:r}:{};k.remove(R,c);};function ue(r){let c=false,t=g("",()=>c),f,a$2,g$1,h={},_={},w=[],m=[],L=false,te=()=>{if(!L&&a$2?.has_initialized){L=true;try{let e=X();e.length>0&&(t(`processCookieCache | replaying ${e.length} cached event(s)`,e),e.forEach(o=>{a$2?.track(o.name,o.properties);}),Z());let i=Y();i.length>0&&(t(`processCookieCache | replaying ${i.length} cached page view(s)`,i),i.forEach(o=>{a$2?.pageView(o.name,"Deriv App",E(),o.properties);}),ee());}catch(e){console.warn("Analytics: Failed to process cookie cache",e);}}},ie=()=>{t("onSdkLoaded | RudderStack SDK loaded"),te(),m.length>0&&t(`onSdkLoaded | flushing ${m.length} pending identify call(s)`),m.forEach(({userId:e,traits:i})=>{e&&a$2?.identifyEvent(e,i);}),m=[];},ne=async({growthbookKey:e,growthbookDecryptionKey:i$1,rudderstackKey:o,growthbookOptions:s,posthogOptions:p,debug:d})=>{var l,u;d!==void 0&&(c=d),a.setDebug(c),t("initialise | starting analytics initialization",{rudderstack:!!o,growthbook:!!e,posthog:!!p});try{let y=s?.attributes?.country||(e?await j():void 0);if(o&&(t("initialise | initializing RudderStack"),a$2=a$1.getRudderStackInstance(o,ie,c)),s?.attributes&&Object.keys(s.attributes).length>0){let n=s.attributes,v=a$2?.getAnonymousId();h={...h,country:y,...n.user_language&&{user_language:n.user_language},...n.account_type&&{account_type:n.account_type},...n.app_id&&{app_id:n.app_id},...n.residence_country&&{residence_country:n.residence_country},...n.device_type&&{device_type:n.device_type},...n.url&&{url:n.url},...n.email_hash&&{email_hash:n.email_hash},...n.network_type&&{network_type:n.network_type},...n.network_rtt&&{network_rtt:n.network_rtt},...n.network_downlink&&{network_downlink:n.network_downlink},...n.account_currency&&{account_currency:n.account_currency},...n.account_mode&&{account_mode:n.account_mode},loggedIn:!!n.loggedIn,...n.user_id&&!i(n.user_id)&&{user_id:n.user_id},...v&&{anonymous_id:v}};}s??(s={}),s.attributes??(s.attributes={});let P=a$2?.getAnonymousId();if((l=s.attributes).id??(l.id=P),(u=s.attributes).country??(u.country=y),e){t("initialise | initializing GrowthBook");let{Growthbook:n}=await import('./providers/growthbook/index.mjs');f=n.getGrowthBookInstance(e,i$1,s,c),t("initialise | GrowthBook initialized");let v=setInterval(()=>{Object.keys(_).length>0?clearInterval(v):_=U("tracking-buttons-config",{});},1e3);}if(p){t("initialise | initializing PostHog");let{Posthog:n}=await import('./providers/posthog/index.mjs');g$1=n.getPosthogInstance(p,c),t("initialise | PostHog initialized");}t("initialise | analytics initialization complete");}catch(y){console.warn("Analytics: Failed to initialize",y);}},oe=({country:e,user_language:i$1,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:u,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,residence_country:C,url:T,domain:B,geo_location:z,loggedIn:S,network_downlink:G,network_rtt:O,network_type:F,account_currency:D,account_mode:H})=>{let N=d??E();if(t("setAttributes | received attributes",{country:e,user_language:i$1,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:u,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,residence_country:C,url:T,domain:B,geo_location:z,loggedIn:S,network_downlink:G,network_rtt:O,network_type:F,account_currency:D,account_mode:H}),f){let I={country:e,residence_country:C,user_language:i$1,device_language:o,device_type:s,utm_source:y,utm_medium:P,utm_campaign:n,is_authorised:v,url:T,domain:B,loggedIn:S,...d&&!i(d)&&{user_id:d},anonymous_id:l};N&&(I.id=N,I.user_id=N),t("setAttributes | called GrowthBook setAttributes",I),f.setAttributes(I);}h={...h,...e!==void 0&&{country:e},...z!==void 0&&{geo_location:z},...i$1!==void 0&&{user_language:i$1},...p!==void 0&&{account_type:p},...u!==void 0&&{app_id:u},...C!==void 0&&{residence_country:C},...s!==void 0&&{device_type:s},...T!==void 0&&{url:T},...S!==void 0&&{loggedIn:S},...G!==void 0&&{network_downlink:G},...O!==void 0&&{network_rtt:O},...F!==void 0&&{network_type:F},...d!==void 0&&!i(d)&&{user_id:d},...l!==void 0&&{anonymous_id:l},...D!==void 0&&{account_currency:D},...H!==void 0&&{account_mode:H}},t("setAttributes | updated core_data",h);},se=e=>f?.getFeatureState(e)?.experimentResult?.name,U=(e,i)=>f?.getFeatureValue(e,i),ae=async()=>await f?.getStatus(),re=e=>f?.isOn(e),ce=e=>f?.setUrl(e),E=()=>{let e=a$2?.getUserId()||"";return e&&!i(e)?e:""},de=()=>a$2?.getAnonymousId()||"",le=(e,i="Deriv App",o)=>{let s=E();t("pageView | called",{current_page:e,platform:i,properties:o,userId:s}),a$2&&(a$2.has_initialized?(t("pageView | sending page view to RudderStack",{current_page:e,platform:i}),a$2.pageView(e,i,s,o)):(t("pageView | RudderStack not initialized \u2014 caching page view to cookie",{current_page:e}),Q(e,{platform:i,...o})));},ge=(e,i)=>{let o=e||E();if(!o){t("identifyEvent | skipped \u2014 no user_id available");return}t("identifyEvent | called",{user_id:o,traits:i});let s=i?.rudderstack!==void 0||i?.posthog!==void 0,p=s?i?.rudderstack:i,d=s?i?.posthog:i;a$2&&(a$2.has_initialized?(t("identifyEvent | calling RudderStack identify",{user_id:o,traits:p}),a$2.identifyEvent(o,p)):m.some(l=>l.userId===o)||(t("identifyEvent | RudderStack not initialized \u2014 queuing identify call",{user_id:o}),m.push({userId:o,traits:p}))),g$1?.has_initialized&&d&&(t("identifyEvent | calling PostHog identify",{user_id:o,traits:d}),g$1.identifyEvent(o,d));},fe=()=>{t("reset | resetting all providers"),a$2?.has_initialized&&(t("reset | resetting RudderStack"),a$2.reset()),g$1?.has_initialized&&(t("reset | resetting PostHog"),g$1.reset());},pe=e=>"event_metadata"in e||"cta_information"in e||"error"in e,j$1={initialise:ne,setAttributes:oe,identifyEvent:ge,backfillPersonProperties:(e,i)=>{t("backfillPersonProperties | called",{user_id:e}),g$1?.has_initialized?(t("backfillPersonProperties | backfilling person properties in PostHog",{user_id:e}),g$1.backfillPersonProperties(e,i)):t("backfillPersonProperties | skipped \u2014 PostHog not initialized");},getFeatureState:se,getFeatureValue:U,getGrowthbookStatus:ae,isFeatureOn:re,setUrl:ce,getId:E,getAnonymousId:de,trackEvent:(e,i)=>{let o=E(),s={};if(t("trackEvent | called",{event:e,analytics_data:i,userId:o,core_data:h}),pe(i)){let l=i;s={...l,event_metadata:{...h,...o&&!h.user_id&&{user_id:o},...l.event_metadata}},t("trackEvent | built V2 payload",{event:e,final_payload:s});}else s={...h,...i,...o&&!h.user_id&&{user_id:o}},t("trackEvent | built V1 payload",{event:e,final_payload:s});if(!(!(e in _)||_[e])){t("trackEvent | skipped \u2014 event disabled by tracking_config",{event:e});return}let d=a$2?.has_initialized;if(!navigator.onLine||!d)d?(t("trackEvent | offline \u2014 caching event to memory",{event:e}),w.push({event:e,payload:s})):(t("trackEvent | RudderStack not initialized \u2014 caching event to cookie",{event:e}),M(e,s));else {w.length>0&&(t(`trackEvent | flushing ${w.length} offline cached event(s) to RudderStack`),w.forEach(u=>{let y=k$1(u.payload);a$2?.track(u.event,y);}),w=[]);let l=k$1(s);t("trackEvent | sending event to RudderStack",{event:e,payload:l}),a$2?.track(e,l);}if(g$1?.has_initialized){let l$1=l(s),u=k$1(l$1);t("trackEvent | sending event to PostHog",{event:e,payload:u}),g$1.capture(e,u);}},getInstances:()=>({ab:f,tracking:a$2,posthog:g$1}),pageView:le,reset:fe};return typeof window<"u"&&(window.AnalyticsInstance=j$1),j$1}var he=ue();export{he as Analytics};//# sourceMappingURL=index.mjs.map
1
+ import {a as a$1}from'./chunk-44P2MMGV.mjs';import {a}from'./chunk-LIPHY7JK.mjs';export{a as cacheTrackEvents}from'./chunk-LIPHY7JK.mjs';import {g,i,j,f,k as k$1,l}from'./chunk-GGU2UVKH.mjs';import k from'js-cookie';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
+ var x="cached_analytics_events",R="cached_analytics_page_views",M=(r,c)=>{try{let t=f(),f$1=k.get(x),a=f$1?JSON.parse(f$1):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k.set(x,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache event",t);}},Q=(r,c)=>{try{let t=f(),f$1=k.get(R),a=f$1?JSON.parse(f$1):[];a.push({name:r,properties:c,timestamp:Date.now()});let g={expires:1};t&&(g.domain=t),k.set(R,JSON.stringify(a),g);}catch(t){console.warn("Analytics: Failed to cache page view",t);}},X=()=>{try{let r=k.get(x);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached events",r);}return []},Y=()=>{try{let r=k.get(R);if(r){let c=JSON.parse(r);return Array.isArray(c)?c:[]}}catch(r){console.warn("Analytics: Failed to get cached pages",r);}return []},Z=()=>{let r=f(),c=r?{domain:r}:{};k.remove(x,c);},ee=()=>{let r=f(),c=r?{domain:r}:{};k.remove(R,c);};function ue(r){let c=false,t=g("",()=>c),f,a$2,g$1,y={},C={},w=[],m=[],J=false,te=()=>{if(!J&&a$2?.has_initialized){J=true;try{let e=X();e.length>0&&(t(`processCookieCache | replaying ${e.length} cached event(s)`,e),e.forEach(o=>{let s=k$1(o.properties);a$2?.track(o.name,s);}),Z());let i=Y();i.length>0&&(t(`processCookieCache | replaying ${i.length} cached page view(s)`,i),i.forEach(o=>{a$2?.pageView(o.name,"Deriv App",_(),o.properties);}),ee());}catch(e){console.warn("Analytics: Failed to process cookie cache",e);}}},ie=()=>{t("onSdkLoaded | RudderStack SDK loaded"),te(),m.length>0&&t(`onSdkLoaded | flushing ${m.length} pending identify call(s)`),m.forEach(({userId:e,traits:i})=>{e&&a$2?.identifyEvent(e,i);}),m=[];},ne=async({growthbookKey:e,growthbookDecryptionKey:i$1,rudderstackKey:o,growthbookOptions:s,posthogOptions:p,debug:d})=>{var l,h;d!==void 0&&(c=d),a.setDebug(c),t("initialise | starting analytics initialization",{rudderstack:!!o,growthbook:!!e,posthog:!!p});try{let u=s?.attributes?.country||(e?await j():void 0);if(o&&(t("initialise | initializing RudderStack"),a$2=a$1.getRudderStackInstance(o,ie,c)),s?.attributes&&Object.keys(s.attributes).length>0){let n=s.attributes,v=a$2?.getAnonymousId();y={...y,country:u,...n.user_language&&{user_language:n.user_language},...n.account_type&&{account_type:n.account_type},...n.app_id&&{app_id:n.app_id},...n.residence_country&&{residence_country:n.residence_country},...n.device_type&&{device_type:n.device_type},...n.url&&{url:n.url},...n.email_hash&&{email_hash:n.email_hash},...n.network_type&&{network_type:n.network_type},...n.network_rtt&&{network_rtt:n.network_rtt},...n.network_downlink&&{network_downlink:n.network_downlink},...n.account_currency&&{account_currency:n.account_currency},...n.account_mode&&{account_mode:n.account_mode},loggedIn:!!n.loggedIn,...n.user_id&&!i(n.user_id)&&{user_id:n.user_id},...v&&{anonymous_id:v}};}s??(s={}),s.attributes??(s.attributes={});let E=a$2?.getAnonymousId();if((l=s.attributes).id??(l.id=E),(h=s.attributes).country??(h.country=u),e){t("initialise | initializing GrowthBook");let{Growthbook:n}=await import('./providers/growthbook/index.mjs');f=n.getGrowthBookInstance(e,i$1,s,c),t("initialise | GrowthBook initialized");let v=setInterval(()=>{Object.keys(C).length>0?clearInterval(v):C=L("tracking-buttons-config",{});},1e3);}if(p){t("initialise | initializing PostHog");let{Posthog:n}=await import('./providers/posthog/index.mjs');g$1=n.getPosthogInstance(p,c),t("initialise | PostHog initialized");}t("initialise | analytics initialization complete");}catch(u){console.warn("Analytics: Failed to initialize",u);}},oe=({country:e,user_language:i$1,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:h,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,residence_country:T,url:S,domain:B,geo_location:z,loggedIn:I,network_downlink:O,network_rtt:G,network_type:F,account_currency:D,account_mode:H})=>{let N=d??_();if(t("setAttributes | received attributes",{country:e,user_language:i$1,device_language:o,device_type:s,account_type:p,user_id:d,anonymous_id:l,app_id:h,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,residence_country:T,url:S,domain:B,geo_location:z,loggedIn:I,network_downlink:O,network_rtt:G,network_type:F,account_currency:D,account_mode:H}),f){let V={country:e,residence_country:T,user_language:i$1,device_language:o,device_type:s,utm_source:u,utm_medium:E,utm_campaign:n,is_authorised:v,url:S,domain:B,loggedIn:I,...d&&!i(d)&&{user_id:d},anonymous_id:l};N&&(V.id=N,V.user_id=N),t("setAttributes | called GrowthBook setAttributes",V),f.setAttributes(V);}y={...y,...e!==void 0&&{country:e},...z!==void 0&&{geo_location:z},...i$1!==void 0&&{user_language:i$1},...p!==void 0&&{account_type:p},...h!==void 0&&{app_id:h},...T!==void 0&&{residence_country:T},...s!==void 0&&{device_type:s},...S!==void 0&&{url:S},...I!==void 0&&{loggedIn:I},...O!==void 0&&{network_downlink:O},...G!==void 0&&{network_rtt:G},...F!==void 0&&{network_type:F},...d!==void 0&&!i(d)&&{user_id:d},...l!==void 0&&{anonymous_id:l},...D!==void 0&&{account_currency:D},...H!==void 0&&{account_mode:H}},t("setAttributes | updated core_data",y);},se=e=>f?.getFeatureState(e)?.experimentResult?.name,L=(e,i)=>f?.getFeatureValue(e,i),ae=async()=>await f?.getStatus(),re=e=>f?.isOn(e),ce=e=>f?.setUrl(e),_=()=>{let e=a$2?.getUserId()||"";return e&&!i(e)?e:""},de=()=>a$2?.getAnonymousId()||"",le=(e,i="Deriv App",o)=>{let s=_();t("pageView | called",{current_page:e,platform:i,properties:o,userId:s}),a$2&&(a$2.has_initialized?(t("pageView | sending page view to RudderStack",{current_page:e,platform:i}),a$2.pageView(e,i,s,o)):(t("pageView | RudderStack not initialized \u2014 caching page view to cookie",{current_page:e}),Q(e,{platform:i,...o})));},ge=(e,i)=>{let o=e||_();if(!o){t("identifyEvent | skipped \u2014 no user_id available");return}t("identifyEvent | called",{user_id:o,traits:i});let s=i?.rudderstack!==void 0||i?.posthog!==void 0,p=s?i?.rudderstack:i,d=s?i?.posthog:i;a$2&&(a$2.has_initialized?(t("identifyEvent | calling RudderStack identify",{user_id:o,traits:p}),a$2.identifyEvent(o,p)):m.some(l=>l.userId===o)||(t("identifyEvent | RudderStack not initialized \u2014 queuing identify call",{user_id:o}),m.push({userId:o,traits:p}))),g$1?.has_initialized&&d&&(t("identifyEvent | calling PostHog identify",{user_id:o,traits:d}),g$1.identifyEvent(o,d));},fe=()=>{t("reset | resetting all providers"),a$2?.has_initialized&&(t("reset | resetting RudderStack"),a$2.reset()),g$1?.has_initialized&&(t("reset | resetting PostHog"),g$1.reset());},pe=e=>"event_metadata"in e||"cta_information"in e||"error"in e,U={initialise:ne,setAttributes:oe,identifyEvent:ge,backfillPersonProperties:({user_id:e,email:i,country_of_residence:o})=>{t("backfillPersonProperties | called",{user_id:e}),g$1?.has_initialized?(t("backfillPersonProperties | backfilling person properties in PostHog",{user_id:e}),g$1.backfillPersonProperties({user_id:e,email:i,country_of_residence:o})):t("backfillPersonProperties | skipped \u2014 PostHog not initialized");},getFeatureState:se,getFeatureValue:L,getGrowthbookStatus:ae,isFeatureOn:re,setUrl:ce,getId:_,getAnonymousId:de,trackEvent:(e,i)=>{let o=_(),s={};if(t("trackEvent | called",{event:e,analytics_data:i,userId:o,core_data:y}),pe(i)){let l=i;s={...l,event_metadata:{...y,...o&&!y.user_id&&{user_id:o},...l.event_metadata}},t("trackEvent | built V2 payload",{event:e,final_payload:s});}else s={...y,...i,...o&&!y.user_id&&{user_id:o}},t("trackEvent | built V1 payload",{event:e,final_payload:s});if(!(!(e in C)||C[e])){t("trackEvent | skipped \u2014 event disabled by tracking_config",{event:e});return}let d=a$2?.has_initialized;if(!navigator.onLine||!d)d?(t("trackEvent | offline \u2014 caching event to memory",{event:e}),w.push({event:e,payload:s})):(t("trackEvent | RudderStack not initialized \u2014 caching event to cookie",{event:e}),M(e,s));else {w.length>0&&(t(`trackEvent | flushing ${w.length} offline cached event(s) to RudderStack`),w.forEach(h=>{let u=k$1(h.payload);a$2?.track(h.event,u);}),w=[]);let l=k$1(s);t("trackEvent | sending event to RudderStack",{event:e,payload:l}),a$2?.track(e,l);}if(g$1?.has_initialized){let l$1=["page_name","user_language","form_name","version","email_hash"],h=l(s),u=k$1(Object.fromEntries(Object.entries(h).filter(([E])=>!l$1.includes(E))));t("trackEvent | sending event to PostHog",{event:e,payload:u}),g$1.capture(e,u);}},getInstances:()=>({ab:f,tracking:a$2,posthog:g$1}),pageView:le,reset:fe};return typeof window<"u"&&(window.AnalyticsInstance=U),U}var he=ue();export{he as Analytics};//# sourceMappingURL=index.mjs.map
3
3
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/utils/cookie.ts","../src/analytics.ts"],"names":["CACHE_COOKIE_EVENTS","CACHE_COOKIE_PAGES","cacheEventToCookie","eventName","properties","domain","getAllowedDomain","existingCache","Cookies","events","cookieOptions","err","cachePageViewToCookie","pageName","pages","getCachedEvents","storedEventsString","getCachedPageViews","storedPagesString","clearCachedEvents","clearCachedPageViews","createAnalyticsInstance","_options","_debug","log","createLogger","_growthbook","_rudderstack","_posthog","core_data","tracking_config","offline_event_cache","_pending_identify_calls","_cookie_cache_processed","processCookieCache","storedEvents","event","storedPages","page","getId","onSdkLoaded","userId","traits","initialise","growthbookKey","growthbookDecryptionKey","rudderstackKey","growthbookOptions","posthogOptions","debug","_a","_b","cacheTrackEvents","country","getCountry","RudderStack","attrs","anonymousId","isUUID","anonId","Growthbook","interval","getFeatureValue","Posthog","setAttributes","user_language","device_language","device_type","account_type","user_id","anonymous_id","app_id","utm_source","utm_medium","utm_campaign","is_authorised","residence_country","url","geo_location","loggedIn","network_downlink","network_rtt","network_type","account_currency","account_mode","user_identity","config","getFeatureState","id","defaultValue","getGrowthbookStatus","isFeatureOn","key","setUrl","href","getAnonymousId","pageView","current_page","platform","identifyEvent","stored_user_id","hasProviderStructure","rudderstackTraits","posthogTraits","call","reset","isV2Payload","payload","AnalyticsInstance","email","analytics_data","final_payload","v2_data","hasRudderstackInitialized","cache","cleaned_cache_payload","cleanObject","cleaned_payload","flattened_payload","flattenObject","cleaned_posthog_payload","Analytics"],"mappings":"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","file":"index.mjs","sourcesContent":["import Cookies from 'js-cookie'\nimport { getAllowedDomain } from './urls'\n\nexport const CACHE_COOKIE_EVENTS = 'cached_analytics_events'\nexport const CACHE_COOKIE_PAGES = 'cached_analytics_page_views'\n\nexport type CachedEvent = {\n name: string\n properties: Record<string, unknown>\n timestamp: number\n}\n\nexport type CachedPageView = {\n name: string\n properties?: Record<string, unknown>\n timestamp: number\n}\n\nexport const cacheEventToCookie = (eventName: string, properties: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_EVENTS)\n const events: CachedEvent[] = existingCache ? JSON.parse(existingCache) : []\n events.push({ name: eventName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_EVENTS, JSON.stringify(events), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache event', err)\n }\n}\n\nexport const cachePageViewToCookie = (pageName: string, properties?: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_PAGES)\n const pages: CachedPageView[] = existingCache ? JSON.parse(existingCache) : []\n pages.push({ name: pageName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_PAGES, JSON.stringify(pages), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache page view', err)\n }\n}\n\nexport const getCachedEvents = (): CachedEvent[] => {\n try {\n const storedEventsString = Cookies.get(CACHE_COOKIE_EVENTS)\n if (storedEventsString) {\n const events = JSON.parse(storedEventsString)\n return Array.isArray(events) ? events : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached events', err)\n }\n return []\n}\n\nexport const getCachedPageViews = (): CachedPageView[] => {\n try {\n const storedPagesString = Cookies.get(CACHE_COOKIE_PAGES)\n if (storedPagesString) {\n const pages = JSON.parse(storedPagesString)\n return Array.isArray(pages) ? pages : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached pages', err)\n }\n return []\n}\n\nexport const clearCachedEvents = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_EVENTS, cookieOptions)\n}\n\nexport const clearCachedPageViews = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_PAGES, cookieOptions)\n}\n","import { RudderStack } from './providers/rudderstack'\nimport type { TCoreAttributes, TAllEvents, TV2EventPayload } from './types'\nimport {\n cacheEventToCookie,\n cachePageViewToCookie,\n getCachedEvents,\n getCachedPageViews,\n clearCachedEvents,\n clearCachedPageViews,\n} from './utils/cookie'\nimport { isUUID, getCountry, cleanObject, flattenObject, createLogger } from './utils/helpers'\nimport { cacheTrackEvents } from './utils/analytics-cache'\n\n// Optional Growthbook types - only import if using Growthbook\nimport type { Growthbook, GrowthbookConfigs } from './providers/growthbook'\nimport type { TGrowthbookAttributes, TGrowthbookOptions } from './providers/growthbookTypes'\n\n// Optional Posthog types - only import if using Posthog\nimport type { Posthog } from './providers/posthog'\nimport type { TPosthogIdentifyTraits, TPosthogOptions } from './providers/posthogTypes'\n\ndeclare global {\n interface Window {\n AnalyticsInstance: ReturnType<typeof createAnalyticsInstance>\n }\n}\n\n/**\n * Configuration options for initializing the analytics instance\n */\ntype Options = {\n /** GrowthBook client API key for A/B testing and feature flags */\n growthbookKey?: string\n /** GrowthBook decryption key for encrypted feature payloads */\n growthbookDecryptionKey?: string\n /** RudderStack write key for event tracking */\n rudderstackKey?: string\n /** Additional configuration options for GrowthBook */\n growthbookOptions?: TGrowthbookOptions\n /** PostHog configuration options including API keys and settings */\n posthogOptions?: TPosthogOptions\n /** Enable debug logging — logs all analytics calls prefixed with [ANALYTIC] */\n debug?: boolean\n}\n\n/**\n * Creates a unified analytics instance that integrates RudderStack and GrowthBook.\n *\n * This function provides a centralized interface for:\n * - Event tracking across multiple analytics platforms\n * - A/B testing and feature flag management via GrowthBook\n * - Offline event caching with automatic replay\n *\n * @param {Options} _options - Optional initialization configuration\n * @returns {Object} Analytics instance with methods for tracking, identification, and feature management\n *\n * @example\n * ```typescript\n * const analytics = createAnalyticsInstance();\n *\n * // Initialize with providers\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY'\n * });\n *\n * // Set user attributes\n * analytics.setAttributes({\n * user_id: 'user123',\n * country: 'US',\n * user_language: 'en'\n * });\n *\n * // Track events\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // Track page views\n * analytics.pageView('/dashboard', 'Deriv App');\n * ```\n */\nexport function createAnalyticsInstance(_options?: Options) {\n let _debug = _options?.debug ?? false\n\n const log = createLogger('', () => _debug)\n\n let _growthbook: Growthbook | undefined,\n _rudderstack: RudderStack,\n _posthog: Posthog | undefined,\n core_data: Partial<TCoreAttributes> = {},\n tracking_config: { [key: string]: boolean } = {},\n offline_event_cache: Array<{ event: keyof TAllEvents; payload: TAllEvents[keyof TAllEvents] }> = [],\n _pending_identify_calls: Array<{ userId: string; traits?: Record<string, any> }> = [],\n _cookie_cache_processed = false\n\n const processCookieCache = () => {\n if (_cookie_cache_processed) return\n if (!_rudderstack?.has_initialized) return\n\n _cookie_cache_processed = true\n\n try {\n const storedEvents = getCachedEvents()\n if (storedEvents.length > 0) {\n log(`processCookieCache | replaying ${storedEvents.length} cached event(s)`, storedEvents)\n storedEvents.forEach(event => {\n _rudderstack?.track(event.name as keyof TAllEvents, event.properties as any)\n })\n clearCachedEvents()\n }\n\n const storedPages = getCachedPageViews()\n if (storedPages.length > 0) {\n log(`processCookieCache | replaying ${storedPages.length} cached page view(s)`, storedPages)\n storedPages.forEach(page => {\n _rudderstack?.pageView(page.name, 'Deriv App', getId(), page.properties)\n })\n clearCachedPageViews()\n }\n } catch (err) {\n console.warn('Analytics: Failed to process cookie cache', err)\n }\n }\n\n const onSdkLoaded = () => {\n log('onSdkLoaded | RudderStack SDK loaded')\n processCookieCache()\n\n if (_pending_identify_calls.length > 0) {\n log(`onSdkLoaded | flushing ${_pending_identify_calls.length} pending identify call(s)`)\n }\n _pending_identify_calls.forEach(({ userId, traits }) => {\n if (userId) {\n _rudderstack?.identifyEvent(userId, traits)\n }\n })\n _pending_identify_calls = []\n }\n\n /**\n * Initializes the analytics instance with specified provider configurations.\n * This method should be called before tracking any events.\n *\n * Features:\n * - Lazy-loads providers (GrowthBook, PostHog) only when configured\n * - Automatically fetches user's country for GrowthBook targeting\n * - Processes any cached events from previous sessions\n * - Sets up event tracking callback for GrowthBook experiments\n *\n * @param {Options} options - Configuration options for analytics providers\n * @returns {Promise<void>} Resolves when initialization is complete\n *\n * @example\n * ```typescript\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY',\n * posthogOptions: {\n * apiKey: 'YOUR_POSTHOG_API_KEY',\n * config: {\n * session_recording: {\n * recordCrossOriginIframes: true,\n * minimumDurationMilliseconds: 30000\n * }\n * }\n * }\n * });\n * ```\n */\n const initialise = async ({\n growthbookKey,\n growthbookDecryptionKey,\n rudderstackKey,\n growthbookOptions,\n posthogOptions,\n debug,\n }: Options) => {\n if (debug !== undefined) _debug = debug\n cacheTrackEvents.setDebug(_debug)\n\n log('initialise | starting analytics initialization', {\n rudderstack: !!rudderstackKey,\n growthbook: !!growthbookKey,\n posthog: !!posthogOptions,\n })\n\n try {\n // Only fetch country if GrowthBook is enabled and country not provided\n const country = growthbookOptions?.attributes?.country || (growthbookKey ? await getCountry() : undefined)\n\n if (rudderstackKey) {\n log('initialise | initializing RudderStack')\n _rudderstack = RudderStack.getRudderStackInstance(rudderstackKey, onSdkLoaded, _debug)\n }\n\n if (growthbookOptions?.attributes && Object.keys(growthbookOptions.attributes).length > 0) {\n const attrs = growthbookOptions.attributes\n const anonymousId = _rudderstack?.getAnonymousId()\n\n core_data = {\n ...core_data,\n country,\n ...(attrs.user_language && { user_language: attrs.user_language }),\n ...(attrs.account_type && { account_type: attrs.account_type }),\n ...(attrs.app_id && { app_id: attrs.app_id }),\n ...(attrs.residence_country && { residence_country: attrs.residence_country }),\n ...(attrs.device_type && { device_type: attrs.device_type }),\n ...(attrs.url && { url: attrs.url }),\n ...(attrs.email_hash && { email_hash: attrs.email_hash }),\n ...(attrs.network_type && { network_type: attrs.network_type }),\n ...(attrs.network_rtt && { network_rtt: attrs.network_rtt }),\n ...(attrs.network_downlink && { network_downlink: attrs.network_downlink }),\n ...(attrs.account_currency && { account_currency: attrs.account_currency }),\n ...(attrs.account_mode && { account_mode: attrs.account_mode }),\n loggedIn: !!attrs.loggedIn,\n ...(attrs.user_id && !isUUID(attrs.user_id) && { user_id: attrs.user_id }),\n ...(anonymousId && { anonymous_id: anonymousId }),\n }\n }\n\n growthbookOptions ??= {}\n growthbookOptions.attributes ??= {}\n const anonId = _rudderstack?.getAnonymousId()\n growthbookOptions.attributes.id ??= anonId\n growthbookOptions.attributes.country ??= country\n\n if (growthbookKey) {\n log('initialise | initializing GrowthBook')\n // Dynamically import Growthbook only when needed\n const { Growthbook } = await import('./providers/growthbook')\n _growthbook = Growthbook.getGrowthBookInstance(\n growthbookKey,\n growthbookDecryptionKey,\n growthbookOptions,\n _debug\n )\n log('initialise | GrowthBook initialized')\n\n const interval = setInterval(() => {\n if (Object.keys(tracking_config).length > 0) clearInterval(interval)\n else tracking_config = getFeatureValue('tracking-buttons-config', {}) as { [key: string]: boolean }\n }, 1000)\n }\n\n if (posthogOptions) {\n log('initialise | initializing PostHog')\n // Dynamically import Posthog only when needed\n const { Posthog } = await import('./providers/posthog')\n _posthog = Posthog.getPosthogInstance(posthogOptions, _debug)\n log('initialise | PostHog initialized')\n }\n\n log('initialise | analytics initialization complete')\n } catch (err) {\n console.warn('Analytics: Failed to initialize', err)\n }\n }\n\n /**\n * Sets user and context attributes for analytics tracking and targeting.\n * These attributes are automatically included in all subsequent events.\n *\n * Attributes are used for:\n * - Event enrichment (added to all tracked events)\n * - GrowthBook targeting (feature flags and A/B tests)\n * - User segmentation across analytics platforms\n *\n * @param {TCoreAttributes} attributes - User and context attributes\n *\n * @example\n * ```typescript\n * analytics.setAttributes({\n * user_id: 'CR123456',\n * country: 'US',\n * user_language: 'en',\n * device_type: 'desktop',\n * account_type: 'real',\n * loggedIn: true\n * });\n * ```\n */\n const setAttributes = ({\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n }: TCoreAttributes) => {\n const user_identity = user_id ?? getId()\n\n log('setAttributes | received attributes', {\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n })\n\n if (_growthbook) {\n const config: TGrowthbookAttributes = {\n country,\n residence_country,\n user_language,\n device_language,\n device_type,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n url,\n domain,\n loggedIn,\n ...(user_id && !isUUID(user_id) && { user_id }),\n anonymous_id,\n }\n if (user_identity) {\n config.id = user_identity\n config.user_id = user_identity\n }\n log('setAttributes | called GrowthBook setAttributes', config)\n _growthbook.setAttributes(config)\n }\n\n core_data = {\n ...core_data,\n ...(country !== undefined && { country }),\n ...(geo_location !== undefined && { geo_location }),\n ...(user_language !== undefined && { user_language }),\n ...(account_type !== undefined && { account_type }),\n ...(app_id !== undefined && { app_id }),\n ...(residence_country !== undefined && { residence_country }),\n ...(device_type !== undefined && { device_type }),\n ...(url !== undefined && { url }),\n ...(loggedIn !== undefined && { loggedIn }),\n ...(network_downlink !== undefined && { network_downlink }),\n ...(network_rtt !== undefined && { network_rtt }),\n ...(network_type !== undefined && { network_type }),\n ...(user_id !== undefined && !isUUID(user_id) && { user_id }),\n ...(anonymous_id !== undefined && { anonymous_id }),\n ...(account_currency !== undefined && { account_currency }),\n ...(account_mode !== undefined && { account_mode }),\n }\n\n log('setAttributes | updated core_data', core_data)\n }\n\n const getFeatureState = (id: string) => _growthbook?.getFeatureState(id)?.experimentResult?.name\n\n const getFeatureValue = <K extends keyof GrowthbookConfigs, V extends GrowthbookConfigs[K]>(\n id: K,\n defaultValue: V\n ) => _growthbook?.getFeatureValue(id as string, defaultValue)\n\n const getGrowthbookStatus = async () => await _growthbook?.getStatus()\n const isFeatureOn = (key: string) => _growthbook?.isOn(key)\n const setUrl = (href: string) => _growthbook?.setUrl(href)\n\n const getId = () => {\n const userId = _rudderstack?.getUserId() || ''\n return userId && !isUUID(userId) ? userId : ''\n }\n\n const getAnonymousId = () => _rudderstack?.getAnonymousId() || ''\n\n /**\n * Tracks a page view event.\n *\n * Features:\n * - Automatically includes user ID if available\n * - Caches page views when offline or provider not initialized\n *\n * @param {string} current_page - The current page URL or path\n * @param {string} [platform='Deriv App'] - The platform name\n * @param {Record<string, unknown>} [properties] - Additional page properties\n *\n * @example\n * ```typescript\n * analytics.pageView('/dashboard');\n * analytics.pageView('/trade', 'Deriv Trader', { section: 'multipliers' });\n * ```\n */\n const pageView = (current_page: string, platform = 'Deriv App', properties?: Record<string, unknown>) => {\n const userId = getId()\n\n log('pageView | called', { current_page, platform, properties, userId })\n\n // Handle RudderStack pageView independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('pageView | sending page view to RudderStack', { current_page, platform })\n _rudderstack.pageView(current_page, platform, userId, properties)\n } else {\n log('pageView | RudderStack not initialized — caching page view to cookie', { current_page })\n cachePageViewToCookie(current_page, { platform, ...properties })\n }\n }\n\n // PostHog handles page views automatically via autocapture\n // No need to manually send page views to PostHog\n }\n\n /**\n * Identifies a user across analytics platforms.\n * This method should be called after user login or when user identity is known.\n *\n * Features:\n * - Queues identify calls if provider not yet initialized\n * - Allows custom traits for each provider or shared traits for both\n * - Identifies user in PostHog if configured\n *\n * @param {string} [user_id] - The user ID to identify. If not provided, uses stored user ID\n * @param {Record<string, any>} [traits] - Optional traits to send to both providers, or provider-specific traits\n *\n * @example\n * ```typescript\n * // Simple identify\n * analytics.identifyEvent('CR123456');\n *\n * // Identify with same traits for both providers\n * analytics.identifyEvent('CR123456', {\n * language: 'en',\n * country_of_residence: 'US'\n * });\n *\n * // Identify with provider-specific traits\n * analytics.identifyEvent('CR123456', {\n * rudderstack: { language: 'en', custom_field: 'value' },\n * posthog: { language: 'en', country_of_residence: 'US' }\n * });\n * ```\n */\n const identifyEvent = (user_id?: string, traits?: Record<string, any>) => {\n const stored_user_id = user_id || getId()\n if (!stored_user_id) {\n log('identifyEvent | skipped — no user_id available')\n return\n }\n\n log('identifyEvent | called', { user_id: stored_user_id, traits })\n\n // Check if traits has provider-specific structure\n const hasProviderStructure = traits?.rudderstack !== undefined || traits?.posthog !== undefined\n const rudderstackTraits = hasProviderStructure ? traits?.rudderstack : traits\n const posthogTraits = hasProviderStructure ? traits?.posthog : traits\n\n // Handle RudderStack identification independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('identifyEvent | calling RudderStack identify', {\n user_id: stored_user_id,\n traits: rudderstackTraits,\n })\n _rudderstack.identifyEvent(stored_user_id, rudderstackTraits)\n } else {\n if (!_pending_identify_calls.some(call => call.userId === stored_user_id)) {\n log('identifyEvent | RudderStack not initialized — queuing identify call', {\n user_id: stored_user_id,\n })\n _pending_identify_calls.push({ userId: stored_user_id, traits: rudderstackTraits })\n }\n }\n }\n\n // Handle PostHog identification independently\n if (_posthog?.has_initialized && posthogTraits) {\n log('identifyEvent | calling PostHog identify', { user_id: stored_user_id, traits: posthogTraits })\n _posthog.identifyEvent(stored_user_id, posthogTraits as TPosthogIdentifyTraits)\n }\n }\n\n const reset = () => {\n log('reset | resetting all providers')\n // Reset each provider independently\n if (_rudderstack?.has_initialized) {\n log('reset | resetting RudderStack')\n _rudderstack.reset()\n }\n if (_posthog?.has_initialized) {\n log('reset | resetting PostHog')\n _posthog.reset()\n }\n }\n\n const isV2Payload = (payload: any): payload is TV2EventPayload => {\n return 'event_metadata' in payload || 'cta_information' in payload || 'error' in payload\n }\n\n /**\n * Tracks a custom event with associated data.\n *\n * Features:\n * - Automatically enriches events with core attributes\n * - Supports both V1 and V2 event payload formats\n * - RudderStack: Caches events when offline or not initialized\n * - PostHog: Sends immediately if initialized (has built-in caching)\n * - Respects feature flag configurations\n * - Each provider works independently - one failing won't affect the other\n *\n * @template T - The event name type from TAllEvents\n * @param {T} event - The event name to track\n * @param {TAllEvents[T]} analytics_data - The event data payload\n *\n * @example\n * ```typescript\n * // Simple event\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // V2 event with metadata\n * analytics.trackEvent('form_submitted', {\n * event_metadata: { form_name: 'registration' },\n * cta_information: { button_text: 'Create Account' }\n * });\n * ```\n */\n const trackEvent = <T extends keyof TAllEvents>(event: T, analytics_data: TAllEvents[T]) => {\n const userId = getId()\n let final_payload: any = {}\n\n log('trackEvent | called', { event, analytics_data, userId, core_data })\n\n if (isV2Payload(analytics_data)) {\n const v2_data = analytics_data as TV2EventPayload\n final_payload = {\n ...v2_data,\n event_metadata: {\n ...core_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n ...v2_data.event_metadata,\n },\n }\n log('trackEvent | built V2 payload', { event, final_payload })\n } else {\n final_payload = {\n ...core_data,\n ...analytics_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n }\n log('trackEvent | built V1 payload', { event, final_payload })\n }\n\n const shouldTrack = !(event in tracking_config) || tracking_config[event as string]\n if (!shouldTrack) {\n log('trackEvent | skipped — event disabled by tracking_config', { event })\n return\n }\n\n // Handle RudderStack independently\n const hasRudderstackInitialized = _rudderstack?.has_initialized\n if (!navigator.onLine || !hasRudderstackInitialized) {\n if (!hasRudderstackInitialized) {\n log('trackEvent | RudderStack not initialized — caching event to cookie', { event })\n cacheEventToCookie(event as string, final_payload)\n } else {\n log('trackEvent | offline — caching event to memory', { event })\n offline_event_cache.push({ event, payload: final_payload })\n }\n } else {\n // Send cached events to RudderStack\n if (offline_event_cache.length > 0) {\n log(`trackEvent | flushing ${offline_event_cache.length} offline cached event(s) to RudderStack`)\n offline_event_cache.forEach(cache => {\n const cleaned_cache_payload = cleanObject(cache.payload)\n _rudderstack?.track(cache.event, cleaned_cache_payload)\n })\n offline_event_cache = []\n }\n\n // Send current event to RudderStack\n const cleaned_payload = cleanObject(final_payload)\n log('trackEvent | sending event to RudderStack', { event, payload: cleaned_payload })\n _rudderstack?.track(event, cleaned_payload)\n }\n\n // Handle PostHog independently - send immediately if initialized\n if (_posthog?.has_initialized) {\n const flattened_payload = flattenObject(final_payload)\n const cleaned_posthog_payload = cleanObject(flattened_payload)\n log('trackEvent | sending event to PostHog', { event, payload: cleaned_posthog_payload })\n _posthog.capture(event as string, cleaned_posthog_payload)\n }\n }\n\n /**\n * Ensures client_id is set in PostHog stored person properties.\n * Call this when the user ID is available and PostHog is loaded.\n * Useful for backfilling client_id for users identified in previous sessions.\n * No-op if client_id is already present or PostHog is not initialized.\n *\n * @param user_id - The user ID to use as client_id\n *\n * @example\n * ```typescript\n * if (window.posthog?.__loaded && userId) {\n * analytics.backfillPersonProperties(userId, email)\n * }\n * ```\n */\n const backfillPersonProperties = (user_id: string, email?: string): void => {\n log('backfillPersonProperties | called', { user_id })\n if (_posthog?.has_initialized) {\n log('backfillPersonProperties | backfilling person properties in PostHog', { user_id })\n _posthog.backfillPersonProperties(user_id, email)\n } else {\n log('backfillPersonProperties | skipped — PostHog not initialized')\n }\n }\n\n const getInstances = () => ({ ab: _growthbook, tracking: _rudderstack, posthog: _posthog })\n\n const AnalyticsInstance = {\n initialise,\n setAttributes,\n identifyEvent,\n backfillPersonProperties,\n getFeatureState,\n getFeatureValue,\n getGrowthbookStatus,\n isFeatureOn,\n setUrl,\n getId,\n getAnonymousId,\n trackEvent,\n getInstances,\n pageView,\n reset,\n }\n\n if (typeof window !== 'undefined') {\n window.AnalyticsInstance = AnalyticsInstance\n }\n\n return AnalyticsInstance\n}\n\nexport const Analytics = createAnalyticsInstance()\n"]}
1
+ {"version":3,"sources":["../src/utils/cookie.ts","../src/analytics.ts"],"names":["CACHE_COOKIE_EVENTS","CACHE_COOKIE_PAGES","cacheEventToCookie","eventName","properties","domain","getAllowedDomain","existingCache","Cookies","events","cookieOptions","err","cachePageViewToCookie","pageName","pages","getCachedEvents","storedEventsString","getCachedPageViews","storedPagesString","clearCachedEvents","clearCachedPageViews","createAnalyticsInstance","_options","_debug","log","createLogger","_growthbook","_rudderstack","_posthog","core_data","tracking_config","offline_event_cache","_pending_identify_calls","_cookie_cache_processed","processCookieCache","storedEvents","event","cleaned_properties","cleanObject","storedPages","page","getId","onSdkLoaded","userId","traits","initialise","growthbookKey","growthbookDecryptionKey","rudderstackKey","growthbookOptions","posthogOptions","debug","_a","_b","cacheTrackEvents","country","getCountry","RudderStack","attrs","anonymousId","isUUID","anonId","Growthbook","interval","getFeatureValue","Posthog","setAttributes","user_language","device_language","device_type","account_type","user_id","anonymous_id","app_id","utm_source","utm_medium","utm_campaign","is_authorised","residence_country","url","geo_location","loggedIn","network_downlink","network_rtt","network_type","account_currency","account_mode","user_identity","config","getFeatureState","id","defaultValue","getGrowthbookStatus","isFeatureOn","key","setUrl","href","getAnonymousId","pageView","current_page","platform","identifyEvent","stored_user_id","hasProviderStructure","rudderstackTraits","posthogTraits","call","reset","isV2Payload","payload","AnalyticsInstance","email","country_of_residence","analytics_data","final_payload","v2_data","hasRudderstackInitialized","cache","cleaned_cache_payload","cleaned_payload","posthog_excluded_keys","flattened_payload","flattenObject","posthog_payload","Analytics"],"mappings":"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","file":"index.mjs","sourcesContent":["import Cookies from 'js-cookie'\nimport { getAllowedDomain } from './urls'\n\nexport const CACHE_COOKIE_EVENTS = 'cached_analytics_events'\nexport const CACHE_COOKIE_PAGES = 'cached_analytics_page_views'\n\nexport type CachedEvent = {\n name: string\n properties: Record<string, unknown>\n timestamp: number\n}\n\nexport type CachedPageView = {\n name: string\n properties?: Record<string, unknown>\n timestamp: number\n}\n\nexport const cacheEventToCookie = (eventName: string, properties: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_EVENTS)\n const events: CachedEvent[] = existingCache ? JSON.parse(existingCache) : []\n events.push({ name: eventName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_EVENTS, JSON.stringify(events), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache event', err)\n }\n}\n\nexport const cachePageViewToCookie = (pageName: string, properties?: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_PAGES)\n const pages: CachedPageView[] = existingCache ? JSON.parse(existingCache) : []\n pages.push({ name: pageName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_PAGES, JSON.stringify(pages), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache page view', err)\n }\n}\n\nexport const getCachedEvents = (): CachedEvent[] => {\n try {\n const storedEventsString = Cookies.get(CACHE_COOKIE_EVENTS)\n if (storedEventsString) {\n const events = JSON.parse(storedEventsString)\n return Array.isArray(events) ? events : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached events', err)\n }\n return []\n}\n\nexport const getCachedPageViews = (): CachedPageView[] => {\n try {\n const storedPagesString = Cookies.get(CACHE_COOKIE_PAGES)\n if (storedPagesString) {\n const pages = JSON.parse(storedPagesString)\n return Array.isArray(pages) ? pages : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached pages', err)\n }\n return []\n}\n\nexport const clearCachedEvents = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_EVENTS, cookieOptions)\n}\n\nexport const clearCachedPageViews = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_PAGES, cookieOptions)\n}\n","import { RudderStack } from './providers/rudderstack'\nimport type { TCoreAttributes, TAllEvents, TV2EventPayload } from './types'\nimport {\n cacheEventToCookie,\n cachePageViewToCookie,\n getCachedEvents,\n getCachedPageViews,\n clearCachedEvents,\n clearCachedPageViews,\n} from './utils/cookie'\nimport { isUUID, getCountry, cleanObject, flattenObject, createLogger } from './utils/helpers'\nimport { cacheTrackEvents } from './utils/analytics-cache'\n\n// Optional Growthbook types - only import if using Growthbook\nimport type { Growthbook, GrowthbookConfigs } from './providers/growthbook'\nimport type { TGrowthbookAttributes, TGrowthbookOptions } from './providers/growthbookTypes'\n\n// Optional Posthog types - only import if using Posthog\nimport type { Posthog } from './providers/posthog'\nimport type { TPosthogIdentifyTraits, TPosthogOptions } from './providers/posthogTypes'\n\ndeclare global {\n interface Window {\n AnalyticsInstance: ReturnType<typeof createAnalyticsInstance>\n }\n}\n\n/**\n * Configuration options for initializing the analytics instance\n */\ntype Options = {\n /** GrowthBook client API key for A/B testing and feature flags */\n growthbookKey?: string\n /** GrowthBook decryption key for encrypted feature payloads */\n growthbookDecryptionKey?: string\n /** RudderStack write key for event tracking */\n rudderstackKey?: string\n /** Additional configuration options for GrowthBook */\n growthbookOptions?: TGrowthbookOptions\n /** PostHog configuration options including API keys and settings */\n posthogOptions?: TPosthogOptions\n /** Enable debug logging — logs all analytics calls prefixed with [ANALYTIC] */\n debug?: boolean\n}\n\n/**\n * Creates a unified analytics instance that integrates RudderStack and GrowthBook.\n *\n * This function provides a centralized interface for:\n * - Event tracking across multiple analytics platforms\n * - A/B testing and feature flag management via GrowthBook\n * - Offline event caching with automatic replay\n *\n * @param {Options} _options - Optional initialization configuration\n * @returns {Object} Analytics instance with methods for tracking, identification, and feature management\n *\n * @example\n * ```typescript\n * const analytics = createAnalyticsInstance();\n *\n * // Initialize with providers\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY'\n * });\n *\n * // Set user attributes\n * analytics.setAttributes({\n * user_id: 'user123',\n * country: 'US',\n * user_language: 'en'\n * });\n *\n * // Track events\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // Track page views\n * analytics.pageView('/dashboard', 'Deriv App');\n * ```\n */\nexport function createAnalyticsInstance(_options?: Options) {\n let _debug = _options?.debug ?? false\n\n const log = createLogger('', () => _debug)\n\n let _growthbook: Growthbook | undefined,\n _rudderstack: RudderStack,\n _posthog: Posthog | undefined,\n core_data: Partial<TCoreAttributes> = {},\n tracking_config: { [key: string]: boolean } = {},\n offline_event_cache: Array<{ event: keyof TAllEvents; payload: TAllEvents[keyof TAllEvents] }> = [],\n _pending_identify_calls: Array<{ userId: string; traits?: Record<string, any> }> = [],\n _cookie_cache_processed = false\n\n const processCookieCache = () => {\n if (_cookie_cache_processed) return\n if (!_rudderstack?.has_initialized) return\n\n _cookie_cache_processed = true\n\n try {\n const storedEvents = getCachedEvents()\n if (storedEvents.length > 0) {\n log(`processCookieCache | replaying ${storedEvents.length} cached event(s)`, storedEvents)\n storedEvents.forEach(event => {\n const cleaned_properties = cleanObject(event.properties)\n _rudderstack?.track(event.name as keyof TAllEvents, cleaned_properties as any)\n })\n clearCachedEvents()\n }\n\n const storedPages = getCachedPageViews()\n if (storedPages.length > 0) {\n log(`processCookieCache | replaying ${storedPages.length} cached page view(s)`, storedPages)\n storedPages.forEach(page => {\n _rudderstack?.pageView(page.name, 'Deriv App', getId(), page.properties)\n })\n clearCachedPageViews()\n }\n } catch (err) {\n console.warn('Analytics: Failed to process cookie cache', err)\n }\n }\n\n const onSdkLoaded = () => {\n log('onSdkLoaded | RudderStack SDK loaded')\n processCookieCache()\n\n if (_pending_identify_calls.length > 0) {\n log(`onSdkLoaded | flushing ${_pending_identify_calls.length} pending identify call(s)`)\n }\n _pending_identify_calls.forEach(({ userId, traits }) => {\n if (userId) {\n _rudderstack?.identifyEvent(userId, traits)\n }\n })\n _pending_identify_calls = []\n }\n\n /**\n * Initializes the analytics instance with specified provider configurations.\n * This method should be called before tracking any events.\n *\n * Features:\n * - Lazy-loads providers (GrowthBook, PostHog) only when configured\n * - Automatically fetches user's country for GrowthBook targeting\n * - Processes any cached events from previous sessions\n * - Sets up event tracking callback for GrowthBook experiments\n *\n * @param {Options} options - Configuration options for analytics providers\n * @returns {Promise<void>} Resolves when initialization is complete\n *\n * @example\n * ```typescript\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY',\n * posthogOptions: {\n * apiKey: 'YOUR_POSTHOG_API_KEY',\n * config: {\n * session_recording: {\n * recordCrossOriginIframes: true,\n * minimumDurationMilliseconds: 30000\n * }\n * }\n * }\n * });\n * ```\n */\n const initialise = async ({\n growthbookKey,\n growthbookDecryptionKey,\n rudderstackKey,\n growthbookOptions,\n posthogOptions,\n debug,\n }: Options) => {\n if (debug !== undefined) _debug = debug\n cacheTrackEvents.setDebug(_debug)\n\n log('initialise | starting analytics initialization', {\n rudderstack: !!rudderstackKey,\n growthbook: !!growthbookKey,\n posthog: !!posthogOptions,\n })\n\n try {\n // Only fetch country if GrowthBook is enabled and country not provided\n const country = growthbookOptions?.attributes?.country || (growthbookKey ? await getCountry() : undefined)\n\n if (rudderstackKey) {\n log('initialise | initializing RudderStack')\n _rudderstack = RudderStack.getRudderStackInstance(rudderstackKey, onSdkLoaded, _debug)\n }\n\n if (growthbookOptions?.attributes && Object.keys(growthbookOptions.attributes).length > 0) {\n const attrs = growthbookOptions.attributes\n const anonymousId = _rudderstack?.getAnonymousId()\n\n core_data = {\n ...core_data,\n country,\n ...(attrs.user_language && { user_language: attrs.user_language }),\n ...(attrs.account_type && { account_type: attrs.account_type }),\n ...(attrs.app_id && { app_id: attrs.app_id }),\n ...(attrs.residence_country && { residence_country: attrs.residence_country }),\n ...(attrs.device_type && { device_type: attrs.device_type }),\n ...(attrs.url && { url: attrs.url }),\n ...(attrs.email_hash && { email_hash: attrs.email_hash }),\n ...(attrs.network_type && { network_type: attrs.network_type }),\n ...(attrs.network_rtt && { network_rtt: attrs.network_rtt }),\n ...(attrs.network_downlink && { network_downlink: attrs.network_downlink }),\n ...(attrs.account_currency && { account_currency: attrs.account_currency }),\n ...(attrs.account_mode && { account_mode: attrs.account_mode }),\n loggedIn: !!attrs.loggedIn,\n ...(attrs.user_id && !isUUID(attrs.user_id) && { user_id: attrs.user_id }),\n ...(anonymousId && { anonymous_id: anonymousId }),\n }\n }\n\n growthbookOptions ??= {}\n growthbookOptions.attributes ??= {}\n const anonId = _rudderstack?.getAnonymousId()\n growthbookOptions.attributes.id ??= anonId\n growthbookOptions.attributes.country ??= country\n\n if (growthbookKey) {\n log('initialise | initializing GrowthBook')\n // Dynamically import Growthbook only when needed\n const { Growthbook } = await import('./providers/growthbook')\n _growthbook = Growthbook.getGrowthBookInstance(\n growthbookKey,\n growthbookDecryptionKey,\n growthbookOptions,\n _debug\n )\n log('initialise | GrowthBook initialized')\n\n const interval = setInterval(() => {\n if (Object.keys(tracking_config).length > 0) clearInterval(interval)\n else tracking_config = getFeatureValue('tracking-buttons-config', {}) as { [key: string]: boolean }\n }, 1000)\n }\n\n if (posthogOptions) {\n log('initialise | initializing PostHog')\n // Dynamically import Posthog only when needed\n const { Posthog } = await import('./providers/posthog')\n _posthog = Posthog.getPosthogInstance(posthogOptions, _debug)\n log('initialise | PostHog initialized')\n }\n\n log('initialise | analytics initialization complete')\n } catch (err) {\n console.warn('Analytics: Failed to initialize', err)\n }\n }\n\n /**\n * Sets user and context attributes for analytics tracking and targeting.\n * These attributes are automatically included in all subsequent events.\n *\n * Attributes are used for:\n * - Event enrichment (added to all tracked events)\n * - GrowthBook targeting (feature flags and A/B tests)\n * - User segmentation across analytics platforms\n *\n * @param {TCoreAttributes} attributes - User and context attributes\n *\n * @example\n * ```typescript\n * analytics.setAttributes({\n * user_id: 'CR123456',\n * country: 'US',\n * user_language: 'en',\n * device_type: 'desktop',\n * account_type: 'real',\n * loggedIn: true\n * });\n * ```\n */\n const setAttributes = ({\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n }: TCoreAttributes) => {\n const user_identity = user_id ?? getId()\n\n log('setAttributes | received attributes', {\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n })\n\n if (_growthbook) {\n const config: TGrowthbookAttributes = {\n country,\n residence_country,\n user_language,\n device_language,\n device_type,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n url,\n domain,\n loggedIn,\n ...(user_id && !isUUID(user_id) && { user_id }),\n anonymous_id,\n }\n if (user_identity) {\n config.id = user_identity\n config.user_id = user_identity\n }\n log('setAttributes | called GrowthBook setAttributes', config)\n _growthbook.setAttributes(config)\n }\n\n core_data = {\n ...core_data,\n ...(country !== undefined && { country }),\n ...(geo_location !== undefined && { geo_location }),\n ...(user_language !== undefined && { user_language }),\n ...(account_type !== undefined && { account_type }),\n ...(app_id !== undefined && { app_id }),\n ...(residence_country !== undefined && { residence_country }),\n ...(device_type !== undefined && { device_type }),\n ...(url !== undefined && { url }),\n ...(loggedIn !== undefined && { loggedIn }),\n ...(network_downlink !== undefined && { network_downlink }),\n ...(network_rtt !== undefined && { network_rtt }),\n ...(network_type !== undefined && { network_type }),\n ...(user_id !== undefined && !isUUID(user_id) && { user_id }),\n ...(anonymous_id !== undefined && { anonymous_id }),\n ...(account_currency !== undefined && { account_currency }),\n ...(account_mode !== undefined && { account_mode }),\n }\n\n log('setAttributes | updated core_data', core_data)\n }\n\n const getFeatureState = (id: string) => _growthbook?.getFeatureState(id)?.experimentResult?.name\n\n const getFeatureValue = <K extends keyof GrowthbookConfigs, V extends GrowthbookConfigs[K]>(\n id: K,\n defaultValue: V\n ) => _growthbook?.getFeatureValue(id as string, defaultValue)\n\n const getGrowthbookStatus = async () => await _growthbook?.getStatus()\n const isFeatureOn = (key: string) => _growthbook?.isOn(key)\n const setUrl = (href: string) => _growthbook?.setUrl(href)\n\n const getId = () => {\n const userId = _rudderstack?.getUserId() || ''\n return userId && !isUUID(userId) ? userId : ''\n }\n\n const getAnonymousId = () => _rudderstack?.getAnonymousId() || ''\n\n /**\n * Tracks a page view event.\n *\n * Features:\n * - Automatically includes user ID if available\n * - Caches page views when offline or provider not initialized\n *\n * @param {string} current_page - The current page URL or path\n * @param {string} [platform='Deriv App'] - The platform name\n * @param {Record<string, unknown>} [properties] - Additional page properties\n *\n * @example\n * ```typescript\n * analytics.pageView('/dashboard');\n * analytics.pageView('/trade', 'Deriv Trader', { section: 'multipliers' });\n * ```\n */\n const pageView = (current_page: string, platform = 'Deriv App', properties?: Record<string, unknown>) => {\n const userId = getId()\n\n log('pageView | called', { current_page, platform, properties, userId })\n\n // Handle RudderStack pageView independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('pageView | sending page view to RudderStack', { current_page, platform })\n _rudderstack.pageView(current_page, platform, userId, properties)\n } else {\n log('pageView | RudderStack not initialized — caching page view to cookie', { current_page })\n cachePageViewToCookie(current_page, { platform, ...properties })\n }\n }\n\n // PostHog handles page views automatically via autocapture\n // No need to manually send page views to PostHog\n }\n\n /**\n * Identifies a user across analytics platforms.\n * This method should be called after user login or when user identity is known.\n *\n * Features:\n * - Queues identify calls if provider not yet initialized\n * - Allows custom traits for each provider or shared traits for both\n * - Identifies user in PostHog if configured\n *\n * @param {string} [user_id] - The user ID to identify. If not provided, uses stored user ID\n * @param {Record<string, any>} [traits] - Optional traits to send to both providers, or provider-specific traits\n *\n * @example\n * ```typescript\n * // Simple identify\n * analytics.identifyEvent('CR123456');\n *\n * // Identify with same traits for both providers\n * analytics.identifyEvent('CR123456', {\n * language: 'en',\n * country_of_residence: 'US'\n * });\n *\n * // Identify with provider-specific traits\n * analytics.identifyEvent('CR123456', {\n * rudderstack: { language: 'en', custom_field: 'value' },\n * posthog: { language: 'en', country_of_residence: 'US' }\n * });\n * ```\n */\n const identifyEvent = (user_id?: string, traits?: Record<string, any>) => {\n const stored_user_id = user_id || getId()\n if (!stored_user_id) {\n log('identifyEvent | skipped — no user_id available')\n return\n }\n\n log('identifyEvent | called', { user_id: stored_user_id, traits })\n\n // Check if traits has provider-specific structure\n const hasProviderStructure = traits?.rudderstack !== undefined || traits?.posthog !== undefined\n const rudderstackTraits = hasProviderStructure ? traits?.rudderstack : traits\n const posthogTraits = hasProviderStructure ? traits?.posthog : traits\n\n // Handle RudderStack identification independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n log('identifyEvent | calling RudderStack identify', {\n user_id: stored_user_id,\n traits: rudderstackTraits,\n })\n _rudderstack.identifyEvent(stored_user_id, rudderstackTraits)\n } else {\n if (!_pending_identify_calls.some(call => call.userId === stored_user_id)) {\n log('identifyEvent | RudderStack not initialized — queuing identify call', {\n user_id: stored_user_id,\n })\n _pending_identify_calls.push({ userId: stored_user_id, traits: rudderstackTraits })\n }\n }\n }\n\n // Handle PostHog identification independently\n if (_posthog?.has_initialized && posthogTraits) {\n log('identifyEvent | calling PostHog identify', { user_id: stored_user_id, traits: posthogTraits })\n _posthog.identifyEvent(stored_user_id, posthogTraits as TPosthogIdentifyTraits)\n }\n }\n\n const reset = () => {\n log('reset | resetting all providers')\n // Reset each provider independently\n if (_rudderstack?.has_initialized) {\n log('reset | resetting RudderStack')\n _rudderstack.reset()\n }\n if (_posthog?.has_initialized) {\n log('reset | resetting PostHog')\n _posthog.reset()\n }\n }\n\n const isV2Payload = (payload: any): payload is TV2EventPayload => {\n return 'event_metadata' in payload || 'cta_information' in payload || 'error' in payload\n }\n\n /**\n * Tracks a custom event with associated data.\n *\n * Features:\n * - Automatically enriches events with core attributes\n * - Supports both V1 and V2 event payload formats\n * - RudderStack: Caches events when offline or not initialized\n * - PostHog: Sends immediately if initialized (has built-in caching)\n * - Respects feature flag configurations\n * - Each provider works independently - one failing won't affect the other\n *\n * @template T - The event name type from TAllEvents\n * @param {T} event - The event name to track\n * @param {TAllEvents[T]} analytics_data - The event data payload\n *\n * @example\n * ```typescript\n * // Simple event\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // V2 event with metadata\n * analytics.trackEvent('form_submitted', {\n * event_metadata: { form_name: 'registration' },\n * cta_information: { button_text: 'Create Account' }\n * });\n * ```\n */\n const trackEvent = <T extends keyof TAllEvents>(event: T, analytics_data: TAllEvents[T]) => {\n const userId = getId()\n let final_payload: any = {}\n\n log('trackEvent | called', { event, analytics_data, userId, core_data })\n\n if (isV2Payload(analytics_data)) {\n const v2_data = analytics_data as TV2EventPayload\n final_payload = {\n ...v2_data,\n event_metadata: {\n ...core_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n ...v2_data.event_metadata,\n },\n }\n log('trackEvent | built V2 payload', { event, final_payload })\n } else {\n final_payload = {\n ...core_data,\n ...analytics_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n }\n log('trackEvent | built V1 payload', { event, final_payload })\n }\n\n const shouldTrack = !(event in tracking_config) || tracking_config[event as string]\n if (!shouldTrack) {\n log('trackEvent | skipped — event disabled by tracking_config', { event })\n return\n }\n\n // Handle RudderStack independently\n const hasRudderstackInitialized = _rudderstack?.has_initialized\n if (!navigator.onLine || !hasRudderstackInitialized) {\n if (!hasRudderstackInitialized) {\n log('trackEvent | RudderStack not initialized — caching event to cookie', { event })\n cacheEventToCookie(event as string, final_payload)\n } else {\n log('trackEvent | offline — caching event to memory', { event })\n offline_event_cache.push({ event, payload: final_payload })\n }\n } else {\n // Send cached events to RudderStack\n if (offline_event_cache.length > 0) {\n log(`trackEvent | flushing ${offline_event_cache.length} offline cached event(s) to RudderStack`)\n offline_event_cache.forEach(cache => {\n const cleaned_cache_payload = cleanObject(cache.payload)\n _rudderstack?.track(cache.event, cleaned_cache_payload)\n })\n offline_event_cache = []\n }\n\n // Send current event to RudderStack\n const cleaned_payload = cleanObject(final_payload)\n log('trackEvent | sending event to RudderStack', { event, payload: cleaned_payload })\n _rudderstack?.track(event, cleaned_payload)\n }\n\n // Handle PostHog independently - send immediately if initialized\n if (_posthog?.has_initialized) {\n const posthog_excluded_keys = ['page_name', 'user_language', 'form_name', 'version', 'email_hash'] as const\n const flattened_payload = flattenObject(final_payload)\n const posthog_payload = cleanObject(\n Object.fromEntries(\n Object.entries(flattened_payload).filter(([key]) => !posthog_excluded_keys.includes(key as any))\n )\n )\n log('trackEvent | sending event to PostHog', { event, payload: posthog_payload })\n _posthog.capture(event as string, posthog_payload)\n }\n }\n\n /**\n * Ensures client_id is set in PostHog stored person properties.\n * Call this when the user ID is available and PostHog is loaded.\n * Useful for backfilling client_id for users identified in previous sessions.\n * No-op if client_id is already present or PostHog is not initialized.\n *\n * @param params.user_id - The user ID to use as client_id\n * @param params.email - The user's email, used to determine is_internal\n * @param params.country_of_residence - The user's country of residence\n *\n * @example\n * ```typescript\n * if (window.posthog?.__loaded && userId) {\n * analytics.backfillPersonProperties({ user_id: userId, email, country_of_residence })\n * }\n * ```\n */\n const backfillPersonProperties = ({\n user_id,\n email,\n country_of_residence,\n }: {\n user_id: string\n email?: string\n country_of_residence?: string\n }): void => {\n log('backfillPersonProperties | called', { user_id })\n if (_posthog?.has_initialized) {\n log('backfillPersonProperties | backfilling person properties in PostHog', { user_id })\n _posthog.backfillPersonProperties({ user_id, email, country_of_residence })\n } else {\n log('backfillPersonProperties | skipped — PostHog not initialized')\n }\n }\n\n const getInstances = () => ({ ab: _growthbook, tracking: _rudderstack, posthog: _posthog })\n\n const AnalyticsInstance = {\n initialise,\n setAttributes,\n identifyEvent,\n backfillPersonProperties,\n getFeatureState,\n getFeatureValue,\n getGrowthbookStatus,\n isFeatureOn,\n setUrl,\n getId,\n getAnonymousId,\n trackEvent,\n getInstances,\n pageView,\n reset,\n }\n\n if (typeof window !== 'undefined') {\n window.AnalyticsInstance = AnalyticsInstance\n }\n\n return AnalyticsInstance\n}\n\nexport const Analytics = createAnalyticsInstance()\n"]}