@deriv-com/analytics 1.39.2 → 1.39.4

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 (50) 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-35PJECDZ.mjs +9 -0
  6. package/dist/chunk-35PJECDZ.mjs.map +1 -0
  7. package/dist/{chunk-44P2MMGV.mjs → chunk-AGTZ7DYP.mjs} +3 -3
  8. package/dist/{chunk-44P2MMGV.mjs.map → chunk-AGTZ7DYP.mjs.map} +1 -1
  9. package/dist/chunk-AKXW5KX7.js +4 -0
  10. package/dist/chunk-AKXW5KX7.js.map +1 -0
  11. package/dist/chunk-ASVWETRZ.mjs +3 -0
  12. package/dist/chunk-ASVWETRZ.mjs.map +1 -0
  13. package/dist/chunk-EZWNCHVR.js +3 -0
  14. package/dist/chunk-EZWNCHVR.js.map +1 -0
  15. package/dist/{chunk-Y3QT7NAG.js → chunk-LFQLME3L.js} +3 -3
  16. package/dist/{chunk-Y3QT7NAG.js.map → chunk-LFQLME3L.js.map} +1 -1
  17. package/dist/{chunk-FY3NPDUL.mjs → chunk-T37YZXV4.mjs} +2 -2
  18. package/dist/chunk-XC5XM6FP.mjs +4 -0
  19. package/dist/chunk-XC5XM6FP.mjs.map +1 -0
  20. package/dist/{growthbook-IRLKT4KH.mjs → growthbook-TE4SOUS2.mjs} +2 -2
  21. package/dist/index.js +2 -2
  22. package/dist/index.mjs +1 -1
  23. package/dist/metafile-cjs.json +1 -1
  24. package/dist/metafile-esm.json +1 -1
  25. package/dist/metafile-iife.json +1 -1
  26. package/dist/posthog-66UECPCZ.mjs +6 -0
  27. package/dist/posthog-66UECPCZ.mjs.map +1 -0
  28. package/dist/providers/growthbook/index.js +2 -2
  29. package/dist/providers/growthbook/index.mjs +1 -1
  30. package/dist/providers/posthog/index.js +2 -2
  31. package/dist/providers/posthog/index.mjs +1 -1
  32. package/dist/providers/rudderstack/index.js +1 -1
  33. package/dist/providers/rudderstack/index.mjs +1 -1
  34. package/dist/utils/analytics-cache/index.js +1 -1
  35. package/dist/utils/analytics-cache/index.mjs +1 -1
  36. package/package.json +2 -2
  37. package/dist/chunk-GGU2UVKH.mjs +0 -4
  38. package/dist/chunk-GGU2UVKH.mjs.map +0 -1
  39. package/dist/chunk-J3V5QNIH.js +0 -4
  40. package/dist/chunk-J3V5QNIH.js.map +0 -1
  41. package/dist/chunk-LIPHY7JK.mjs +0 -3
  42. package/dist/chunk-LIPHY7JK.mjs.map +0 -1
  43. package/dist/chunk-SQ6Q4Z5S.js +0 -3
  44. package/dist/chunk-SQ6Q4Z5S.js.map +0 -1
  45. package/dist/chunk-UG2YL4OB.mjs +0 -9
  46. package/dist/chunk-UG2YL4OB.mjs.map +0 -1
  47. package/dist/posthog-PBG3EMGB.mjs +0 -6
  48. package/dist/posthog-PBG3EMGB.mjs.map +0 -1
  49. /package/dist/{chunk-FY3NPDUL.mjs.map → chunk-T37YZXV4.mjs.map} +0 -0
  50. /package/dist/{growthbook-IRLKT4KH.mjs.map → growthbook-TE4SOUS2.mjs.map} +0 -0
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkJ3V5QNIH_js=require('../../chunk-J3V5QNIH.js'),growthbook=require('@growthbook/growthbook'),analyticsJs=require('@rudderstack/analytics-js');/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var i=class i{constructor(t,e,o={},n=false){this.analytics=new analyticsJs.RudderAnalytics;this.isLoaded=false;this.status=void 0;this.debug=false;this.log=chunkJ3V5QNIH_js.g("[GrowthBook]",()=>this.debug);this.setAttributes=({id:t,country:e,user_language:o,device_language:n,device_type:s,utm_source:r,utm_medium:a,utm_campaign:d,is_authorised:h,url:u,domain:w,utm_content:l,residence_country:f,loggedIn:c,network_type:g,network_downlink:k,user_id:b,anonymous_id:p,account_mode:G})=>{let v={...this.GrowthBook.getAttributes(),id:t,...b!==void 0&&{user_id:b},...p!==void 0&&{anonymous_id:p},...e!==void 0&&{country:e},...f!==void 0&&{residence_country:f},...o!==void 0&&{user_language:o},...n!==void 0&&{device_language:n},...s!==void 0&&{device_type:s},...r!==void 0&&{utm_source:r},...a!==void 0&&{utm_medium:a},...d!==void 0&&{utm_campaign:d},...h!==void 0&&{is_authorised:h},...u!==void 0&&{url:u},...w!==void 0&&{domain:w},...l!==void 0&&{utm_content:l},...c!==void 0&&{loggedIn:c},...g!==void 0&&{network_type:g},...k!==void 0&&{network_downlink:k},...G!==void 0&&{account_mode:G}};this.log("setAttributes | updating GrowthBook attributes",v),this.GrowthBook.setAttributes(v);};this.getFeatureValue=(t,e)=>{let o=this.GrowthBook.getFeatureValue(t,e);return this.log("getFeatureValue",{key:t,value:o,defaultValue:e}),o};this.getStatus=async()=>(await this.waitForIsLoaded(),{isLoaded:this.isLoaded,status:this.status});this.getFeatureState=t=>{let e=this.GrowthBook.evalFeature(t);return this.log("getFeatureState",{id:t,result:e}),e};this.setUrl=t=>{this.log("setUrl",{href:t}),this.GrowthBook.setURL(t);};this.isOn=t=>{let e=this.GrowthBook.isOn(t);return this.log("isOn",{key:t,result:e}),e};this.init=async()=>{this.log("init | initializing GrowthBook SDK");let t=await this.GrowthBook.init({timeout:2e3,streaming:true}).catch(()=>{});this.status=t,this.isLoaded=true,this.log("init | GrowthBook SDK loaded",{status:t});};this.destroy=()=>{this.GrowthBook.destroy(),this.isLoaded=false,this.status=void 0;};this.debug=n;let s=typeof window<"u"?window.location.hostname.includes("localhost"):false;this.GrowthBook=new growthbook.GrowthBook({apiHost:chunkJ3V5QNIH_js.a,clientKey:t,decryptionKey:e,antiFlicker:false,navigateDelay:0,antiFlickerTimeout:3500,subscribeToChanges:true,enableDevMode:s,trackingCallback:(r,a)=>{this.log("trackingCallback | experiment viewed",{experiment_id:r.key,variation_id:a.variationId}),typeof window<"u"&&window.dataLayer&&window.dataLayer.push({event:"experiment_viewed",event_category:"experiment",rudder_anonymous_id:this.analytics.getAnonymousId(),experiment_id:r.key,variation_id:a.variationId}),this.analytics.track("experiment_viewed",{experimentId:r.key,variationId:a.variationId});},...o}),this.init();}reapplyExperiment(t){let e=t??(typeof window<"u"?window.location.href:"");this.GrowthBook.setURL(e);}waitForIsLoaded(t=1e4){return new Promise((e,o)=>{let n=Date.now(),s=setInterval(()=>{this.isLoaded?(clearInterval(s),e()):Date.now()-n>=t&&(clearInterval(s),o(new Error("GrowthBook initialization timeout")));},100);})}};i.getGrowthBookInstance=(t,e,o,n=false)=>i._instance?(typeof window<"u"&&console.warn&&console.warn("GrowthBook instance already exists. Ignoring new initialization parameters."),i._instance):(i._instance=new i(t,e??"",o,n),i._instance),i.resetInstance=()=>{i._instance&&(i._instance.destroy(),i._instance=void 0);};var m=i;exports.Growthbook=m;//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkAKXW5KX7_js=require('../../chunk-AKXW5KX7.js'),growthbook=require('@growthbook/growthbook'),analyticsJs=require('@rudderstack/analytics-js');/* @deriv-com/analytics - NPM Package - Built with tsup */
2
+ var i=class i{constructor(t,e,o={},n=false){this.analytics=new analyticsJs.RudderAnalytics;this.isLoaded=false;this.status=void 0;this.debug=false;this.log=chunkAKXW5KX7_js.g("[GrowthBook]",()=>this.debug);this.setAttributes=({id:t,country:e,user_language:o,device_language:n,device_type:s,utm_source:r,utm_medium:a,utm_campaign:d,is_authorised:h,url:u,domain:w,utm_content:l,residence_country:f,loggedIn:c,network_type:g,network_downlink:k,user_id:b,anonymous_id:p,account_mode:G})=>{let v={...this.GrowthBook.getAttributes(),id:t,...b!==void 0&&{user_id:b},...p!==void 0&&{anonymous_id:p},...e!==void 0&&{country:e},...f!==void 0&&{residence_country:f},...o!==void 0&&{user_language:o},...n!==void 0&&{device_language:n},...s!==void 0&&{device_type:s},...r!==void 0&&{utm_source:r},...a!==void 0&&{utm_medium:a},...d!==void 0&&{utm_campaign:d},...h!==void 0&&{is_authorised:h},...u!==void 0&&{url:u},...w!==void 0&&{domain:w},...l!==void 0&&{utm_content:l},...c!==void 0&&{loggedIn:c},...g!==void 0&&{network_type:g},...k!==void 0&&{network_downlink:k},...G!==void 0&&{account_mode:G}};this.log("setAttributes | updating GrowthBook attributes",v),this.GrowthBook.setAttributes(v);};this.getFeatureValue=(t,e)=>{let o=this.GrowthBook.getFeatureValue(t,e);return this.log("getFeatureValue",{key:t,value:o,defaultValue:e}),o};this.getStatus=async()=>(await this.waitForIsLoaded(),{isLoaded:this.isLoaded,status:this.status});this.getFeatureState=t=>{let e=this.GrowthBook.evalFeature(t);return this.log("getFeatureState",{id:t,result:e}),e};this.setUrl=t=>{this.log("setUrl",{href:t}),this.GrowthBook.setURL(t);};this.isOn=t=>{let e=this.GrowthBook.isOn(t);return this.log("isOn",{key:t,result:e}),e};this.init=async()=>{this.log("init | initializing GrowthBook SDK");let t=await this.GrowthBook.init({timeout:2e3,streaming:true}).catch(()=>{});this.status=t,this.isLoaded=true,this.log("init | GrowthBook SDK loaded",{status:t});};this.destroy=()=>{this.GrowthBook.destroy(),this.isLoaded=false,this.status=void 0;};this.debug=n;let s=typeof window<"u"?window.location.hostname.includes("localhost"):false;this.GrowthBook=new growthbook.GrowthBook({apiHost:chunkAKXW5KX7_js.a,clientKey:t,decryptionKey:e,antiFlicker:false,navigateDelay:0,antiFlickerTimeout:3500,subscribeToChanges:true,enableDevMode:s,trackingCallback:(r,a)=>{this.log("trackingCallback | experiment viewed",{experiment_id:r.key,variation_id:a.variationId}),typeof window<"u"&&window.dataLayer&&window.dataLayer.push({event:"experiment_viewed",event_category:"experiment",rudder_anonymous_id:this.analytics.getAnonymousId(),experiment_id:r.key,variation_id:a.variationId}),this.analytics.track("experiment_viewed",{experimentId:r.key,variationId:a.variationId});},...o}),this.init();}reapplyExperiment(t){let e=t??(typeof window<"u"?window.location.href:"");this.GrowthBook.setURL(e);}waitForIsLoaded(t=1e4){return new Promise((e,o)=>{let n=Date.now(),s=setInterval(()=>{this.isLoaded?(clearInterval(s),e()):Date.now()-n>=t&&(clearInterval(s),o(new Error("GrowthBook initialization timeout")));},100);})}};i.getGrowthBookInstance=(t,e,o,n=false)=>i._instance?(typeof window<"u"&&console.warn&&console.warn("GrowthBook instance already exists. Ignoring new initialization parameters."),i._instance):(i._instance=new i(t,e??"",o,n),i._instance),i.resetInstance=()=>{i._instance&&(i._instance.destroy(),i._instance=void 0);};var m=i;exports.Growthbook=m;//# sourceMappingURL=index.js.map
3
3
  //# sourceMappingURL=index.js.map
@@ -1,3 +1,3 @@
1
- import {g,a}from'../../chunk-GGU2UVKH.mjs';import {GrowthBook}from'@growthbook/growthbook';import {RudderAnalytics}from'@rudderstack/analytics-js';/* @deriv-com/analytics - NPM Package - Built with tsup */
1
+ import {g,a}from'../../chunk-XC5XM6FP.mjs';import {GrowthBook}from'@growthbook/growthbook';import {RudderAnalytics}from'@rudderstack/analytics-js';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
2
  var i=class i{constructor(t,e,o={},n=false){this.analytics=new RudderAnalytics;this.isLoaded=false;this.status=void 0;this.debug=false;this.log=g("[GrowthBook]",()=>this.debug);this.setAttributes=({id:t,country:e,user_language:o,device_language:n,device_type:s,utm_source:r,utm_medium:a,utm_campaign:d,is_authorised:h,url:u,domain:w,utm_content:l,residence_country:f,loggedIn:c,network_type:g,network_downlink:k,user_id:b,anonymous_id:p,account_mode:G})=>{let v={...this.GrowthBook.getAttributes(),id:t,...b!==void 0&&{user_id:b},...p!==void 0&&{anonymous_id:p},...e!==void 0&&{country:e},...f!==void 0&&{residence_country:f},...o!==void 0&&{user_language:o},...n!==void 0&&{device_language:n},...s!==void 0&&{device_type:s},...r!==void 0&&{utm_source:r},...a!==void 0&&{utm_medium:a},...d!==void 0&&{utm_campaign:d},...h!==void 0&&{is_authorised:h},...u!==void 0&&{url:u},...w!==void 0&&{domain:w},...l!==void 0&&{utm_content:l},...c!==void 0&&{loggedIn:c},...g!==void 0&&{network_type:g},...k!==void 0&&{network_downlink:k},...G!==void 0&&{account_mode:G}};this.log("setAttributes | updating GrowthBook attributes",v),this.GrowthBook.setAttributes(v);};this.getFeatureValue=(t,e)=>{let o=this.GrowthBook.getFeatureValue(t,e);return this.log("getFeatureValue",{key:t,value:o,defaultValue:e}),o};this.getStatus=async()=>(await this.waitForIsLoaded(),{isLoaded:this.isLoaded,status:this.status});this.getFeatureState=t=>{let e=this.GrowthBook.evalFeature(t);return this.log("getFeatureState",{id:t,result:e}),e};this.setUrl=t=>{this.log("setUrl",{href:t}),this.GrowthBook.setURL(t);};this.isOn=t=>{let e=this.GrowthBook.isOn(t);return this.log("isOn",{key:t,result:e}),e};this.init=async()=>{this.log("init | initializing GrowthBook SDK");let t=await this.GrowthBook.init({timeout:2e3,streaming:true}).catch(()=>{});this.status=t,this.isLoaded=true,this.log("init | GrowthBook SDK loaded",{status:t});};this.destroy=()=>{this.GrowthBook.destroy(),this.isLoaded=false,this.status=void 0;};this.debug=n;let s=typeof window<"u"?window.location.hostname.includes("localhost"):false;this.GrowthBook=new GrowthBook({apiHost:a,clientKey:t,decryptionKey:e,antiFlicker:false,navigateDelay:0,antiFlickerTimeout:3500,subscribeToChanges:true,enableDevMode:s,trackingCallback:(r,a)=>{this.log("trackingCallback | experiment viewed",{experiment_id:r.key,variation_id:a.variationId}),typeof window<"u"&&window.dataLayer&&window.dataLayer.push({event:"experiment_viewed",event_category:"experiment",rudder_anonymous_id:this.analytics.getAnonymousId(),experiment_id:r.key,variation_id:a.variationId}),this.analytics.track("experiment_viewed",{experimentId:r.key,variationId:a.variationId});},...o}),this.init();}reapplyExperiment(t){let e=t??(typeof window<"u"?window.location.href:"");this.GrowthBook.setURL(e);}waitForIsLoaded(t=1e4){return new Promise((e,o)=>{let n=Date.now(),s=setInterval(()=>{this.isLoaded?(clearInterval(s),e()):Date.now()-n>=t&&(clearInterval(s),o(new Error("GrowthBook initialization timeout")));},100);})}};i.getGrowthBookInstance=(t,e,o,n=false)=>i._instance?(typeof window<"u"&&console.warn&&console.warn("GrowthBook instance already exists. Ignoring new initialization parameters."),i._instance):(i._instance=new i(t,e??"",o,n),i._instance),i.resetInstance=()=>{i._instance&&(i._instance.destroy(),i._instance=void 0);};var m=i;export{m as Growthbook};//# sourceMappingURL=index.mjs.map
3
3
  //# sourceMappingURL=index.mjs.map
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkJ3V5QNIH_js=require('../../chunk-J3V5QNIH.js'),r=require('posthog-js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var r__default=/*#__PURE__*/_interopDefault(r);/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var n=class n{constructor(i,t=false){this.has_initialized=false;this.has_identified=false;this.debug=false;this.log=chunkJ3V5QNIH_js.g("[PostHog]",()=>this.debug);this.init=()=>{try{let{apiKey:i,api_host:t,config:e={}}=this.options;if(!i){console.warn("Posthog: No API key provided");return}let o=t||chunkJ3V5QNIH_js.d();this.log("init | loading PostHog SDK",{api_host:o});let s={api_host:o,ui_host:chunkJ3V5QNIH_js.c,autocapture:!0,capture_pageview:"history_change",session_recording:{recordCrossOriginIframes:!0,minimumDurationMilliseconds:3e4,...e.session_recording},before_send:l=>{if(typeof window>"u")return null;let a=window.location.hostname;if(a==="localhost"||a==="127.0.0.1")return l;let d=chunkJ3V5QNIH_js.e.some(c=>a.endsWith(`.${c}`)||a===c);return d||this.log("init | before_send blocked event from disallowed host",{currentHost:a}),d?l:null},...e};r__default.default.init(i,s),this.has_initialized=!0,this.log("init | PostHog SDK loaded successfully");}catch(i){console.error("Posthog: Failed to initialize",i);}};this.identifyEvent=(i,t)=>{if(!this.has_initialized){console.warn("Posthog: Cannot identify - not initialized");return}try{let e=typeof r__default.default._isIdentified=="function"?r__default.default._isIdentified():this.has_identified;i&&!e?(this.log("identifyEvent | identifying user",{user_id:i,traits:t}),r__default.default.identify(i,{...t,client_id:i}),this.has_identified=!0):this.log("identifyEvent | skipped \u2014 user already identified",{user_id:i});}catch(e){console.error("Posthog: Failed to identify user",e);}};this.reset=()=>{if(this.has_initialized)try{this.log("reset | resetting PostHog session"),r__default.default.reset(),this.has_identified=!1;}catch(i){console.error("Posthog: Failed to reset",i);}};this.backfillPersonProperties=({user_id:i,email:t,country_of_residence:e})=>{if(!(!this.has_initialized||!i))try{let o=r__default.default.get_property("$stored_person_properties")??{},s={};o.client_id||(s.client_id=i),t&&o.is_internal===void 0&&(s.is_internal=chunkJ3V5QNIH_js.h(t)),e&&!o.country_of_residence&&(s.country_of_residence=e),Object.keys(s).length>0?(this.log("backfillPersonProperties | backfilling person properties",{user_id:i,updates:s}),r__default.default.setPersonProperties(s)):this.log("backfillPersonProperties | skipped \u2014 all properties already present",{user_id:i,country_of_residence:e});}catch(o){console.error("Posthog: Failed to backfill person properties",o);}};this.capture=(i,t)=>{if(this.has_initialized)try{this.log("capture | sending event to PostHog",{event_name:i,properties:t}),r__default.default.capture(i,t);}catch(e){console.error("Posthog: Failed to capture event",e);}};this.options=i,this.debug=t,this.init();}};n.getPosthogInstance=(i,t=false)=>(n._instance||(n._instance=new n(i,t)),n._instance);var P=n;exports.Posthog=P;//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkAKXW5KX7_js=require('../../chunk-AKXW5KX7.js'),r=require('posthog-js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var r__default=/*#__PURE__*/_interopDefault(r);/* @deriv-com/analytics - NPM Package - Built with tsup */
2
+ var n=class n{constructor(i,t=false){this.has_initialized=false;this.has_identified=false;this.debug=false;this.log=chunkAKXW5KX7_js.g("[PostHog]",()=>this.debug);this.init=()=>{try{let{apiKey:i,api_host:t,config:e={}}=this.options;if(!i){console.warn("Posthog: No API key provided");return}let o=t||chunkAKXW5KX7_js.d();this.log("init | loading PostHog SDK",{api_host:o});let s={api_host:o,ui_host:chunkAKXW5KX7_js.c,autocapture:!0,capture_pageview:"history_change",session_recording:{recordCrossOriginIframes:!0,minimumDurationMilliseconds:3e4,...e.session_recording},before_send:l=>{if(typeof window>"u")return null;let a=window.location.hostname;if(a==="localhost"||a==="127.0.0.1")return l;let d=chunkAKXW5KX7_js.e.some(c=>a.endsWith(`.${c}`)||a===c);return d||this.log("init | before_send blocked event from disallowed host",{currentHost:a}),d?l:null},...e};r__default.default.init(i,s),this.has_initialized=!0,this.log("init | PostHog SDK loaded successfully");}catch(i){console.error("Posthog: Failed to initialize",i);}};this.identifyEvent=(i,t)=>{if(!this.has_initialized){console.warn("Posthog: Cannot identify - not initialized");return}try{let e=typeof r__default.default._isIdentified=="function"?r__default.default._isIdentified():this.has_identified;i&&!e?(this.log("identifyEvent | identifying user",{user_id:i,traits:t}),r__default.default.identify(i,{...t,client_id:i}),this.has_identified=!0):this.log("identifyEvent | skipped \u2014 user already identified",{user_id:i});}catch(e){console.error("Posthog: Failed to identify user",e);}};this.reset=()=>{if(this.has_initialized)try{this.log("reset | resetting PostHog session"),r__default.default.reset(),this.has_identified=!1;}catch(i){console.error("Posthog: Failed to reset",i);}};this.backfillPersonProperties=({user_id:i,email:t,country_of_residence:e})=>{if(!(!this.has_initialized||!i))try{let o=r__default.default.get_property("$stored_person_properties")??{},s={};o.client_id||(s.client_id=i),t&&o.is_internal===void 0&&(s.is_internal=chunkAKXW5KX7_js.h(t)),e&&!o.country_of_residence&&(s.country_of_residence=e),Object.keys(s).length>0?(this.log("backfillPersonProperties | backfilling person properties",{user_id:i,updates:s}),r__default.default.setPersonProperties(s)):this.log("backfillPersonProperties | skipped \u2014 all properties already present",{user_id:i,country_of_residence:e});}catch(o){console.error("Posthog: Failed to backfill person properties",o);}};this.capture=(i,t)=>{if(this.has_initialized)try{this.log("capture | sending event to PostHog",{event_name:i,properties:t}),r__default.default.capture(i,t);}catch(e){console.error("Posthog: Failed to capture event",e);}};this.options=i,this.debug=t,this.init();}};n.getPosthogInstance=(i,t=false)=>(n._instance||(n._instance=new n(i,t)),n._instance);var P=n;exports.Posthog=P;//# sourceMappingURL=index.js.map
3
3
  //# sourceMappingURL=index.js.map
@@ -1,3 +1,3 @@
1
- import {g,d,e,c,h}from'../../chunk-GGU2UVKH.mjs';import r from'posthog-js';/* @deriv-com/analytics - NPM Package - Built with tsup */
1
+ import {g,d,e,c,h}from'../../chunk-XC5XM6FP.mjs';import r from'posthog-js';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
2
  var n=class n{constructor(i,t=false){this.has_initialized=false;this.has_identified=false;this.debug=false;this.log=g("[PostHog]",()=>this.debug);this.init=()=>{try{let{apiKey:i,api_host:t,config:e$1={}}=this.options;if(!i){console.warn("Posthog: No API key provided");return}let o=t||d();this.log("init | loading PostHog SDK",{api_host:o});let s={api_host:o,ui_host:c,autocapture:!0,capture_pageview:"history_change",session_recording:{recordCrossOriginIframes:!0,minimumDurationMilliseconds:3e4,...e$1.session_recording},before_send:l=>{if(typeof window>"u")return null;let a=window.location.hostname;if(a==="localhost"||a==="127.0.0.1")return l;let d=e.some(c=>a.endsWith(`.${c}`)||a===c);return d||this.log("init | before_send blocked event from disallowed host",{currentHost:a}),d?l:null},...e$1};r.init(i,s),this.has_initialized=!0,this.log("init | PostHog SDK loaded successfully");}catch(i){console.error("Posthog: Failed to initialize",i);}};this.identifyEvent=(i,t)=>{if(!this.has_initialized){console.warn("Posthog: Cannot identify - not initialized");return}try{let e=typeof r._isIdentified=="function"?r._isIdentified():this.has_identified;i&&!e?(this.log("identifyEvent | identifying user",{user_id:i,traits:t}),r.identify(i,{...t,client_id:i}),this.has_identified=!0):this.log("identifyEvent | skipped \u2014 user already identified",{user_id:i});}catch(e){console.error("Posthog: Failed to identify user",e);}};this.reset=()=>{if(this.has_initialized)try{this.log("reset | resetting PostHog session"),r.reset(),this.has_identified=!1;}catch(i){console.error("Posthog: Failed to reset",i);}};this.backfillPersonProperties=({user_id:i,email:t,country_of_residence:e})=>{if(!(!this.has_initialized||!i))try{let o=r.get_property("$stored_person_properties")??{},s={};o.client_id||(s.client_id=i),t&&o.is_internal===void 0&&(s.is_internal=h(t)),e&&!o.country_of_residence&&(s.country_of_residence=e),Object.keys(s).length>0?(this.log("backfillPersonProperties | backfilling person properties",{user_id:i,updates:s}),r.setPersonProperties(s)):this.log("backfillPersonProperties | skipped \u2014 all properties already present",{user_id:i,country_of_residence:e});}catch(o){console.error("Posthog: Failed to backfill person properties",o);}};this.capture=(i,t)=>{if(this.has_initialized)try{this.log("capture | sending event to PostHog",{event_name:i,properties:t}),r.capture(i,t);}catch(e){console.error("Posthog: Failed to capture event",e);}};this.options=i,this.debug=t,this.init();}};n.getPosthogInstance=(i,t=false)=>(n._instance||(n._instance=new n(i,t)),n._instance);var P=n;export{P as Posthog};//# sourceMappingURL=index.mjs.map
3
3
  //# sourceMappingURL=index.mjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkY3QT7NAG_js=require('../../chunk-Y3QT7NAG.js');require('../../chunk-J3V5QNIH.js');Object.defineProperty(exports,"RudderStack",{enumerable:true,get:function(){return chunkY3QT7NAG_js.a}});//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkLFQLME3L_js=require('../../chunk-LFQLME3L.js');require('../../chunk-AKXW5KX7.js');Object.defineProperty(exports,"RudderStack",{enumerable:true,get:function(){return chunkLFQLME3L_js.a}});//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- export{a as RudderStack}from'../../chunk-44P2MMGV.mjs';import'../../chunk-GGU2UVKH.mjs';//# sourceMappingURL=index.mjs.map
1
+ export{a as RudderStack}from'../../chunk-AGTZ7DYP.mjs';import'../../chunk-XC5XM6FP.mjs';//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSQ6Q4Z5S_js=require('../../chunk-SQ6Q4Z5S.js');require('../../chunk-J3V5QNIH.js');Object.defineProperty(exports,"cacheTrackEvents",{enumerable:true,get:function(){return chunkSQ6Q4Z5S_js.a}});//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkEZWNCHVR_js=require('../../chunk-EZWNCHVR.js');require('../../chunk-AKXW5KX7.js');Object.defineProperty(exports,"cacheTrackEvents",{enumerable:true,get:function(){return chunkEZWNCHVR_js.a}});//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- export{a as cacheTrackEvents}from'../../chunk-LIPHY7JK.mjs';import'../../chunk-GGU2UVKH.mjs';//# sourceMappingURL=index.mjs.map
1
+ export{a as cacheTrackEvents}from'../../chunk-ASVWETRZ.mjs';import'../../chunk-XC5XM6FP.mjs';//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deriv-com/analytics",
3
- "version": "1.39.2",
3
+ "version": "1.39.4",
4
4
  "description": "Comprehensive analytics package for Deriv applications. Provides unified event tracking, A/B testing, and user analytics through RudderStack, PostHog and GrowthBook integrations with built-in caching and offline support.",
5
5
  "keywords": [
6
6
  "rudderstack",
@@ -83,7 +83,7 @@
83
83
  "dependencies": {
84
84
  "@rudderstack/analytics-js": "^3.14.0",
85
85
  "js-cookie": "^3.0.5",
86
- "posthog-js": "^1.356.1"
86
+ "posthog-js": "1.358.0"
87
87
  },
88
88
  "optionalDependencies": {
89
89
  "@growthbook/growthbook": "^1.4.1"
@@ -1,4 +0,0 @@
1
- import m from'js-cookie';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var c="https://deriv.com/cdn-cgi/trace",f="https://cdn.growthbook.io",y="https://deriv-dataplane.rudderstack.com",a="https://ph.deriv.com",g="https://us.posthog.com",h=()=>{if(typeof window>"u")return a;let t=window.location.hostname;return t.includes(".deriv.me")?"https://ph.deriv.me":t.includes(".deriv.be")?"https://ph.deriv.be":a},p=["deriv.com","deriv.be","deriv.me","deriv.team","deriv.ae"],l=["deriv.com","derivcrypto.com","besquare.my","besquare.com.my","ewallet.exchange","champion-fx.com","opalstraits.com","binary.com","binary.marketing","championgbs.com","4x.my","re-work.dev","regentmarkets.com","4x.com","binary.me","deriv.team","firstsource.io","firstsource.tech","deriv.hr","vmgbpo.net","mailisk.net","mailosaur.net","mobileapps.mailisk.net","w3e180zd.mailosaur.net"],v=()=>{if(typeof window>"u")return ".deriv.com";let t=window.location.hostname;if(t==="localhost")return "";let e=p.find(o=>t.includes(o));return e?`.${e}`:".deriv.com"};var k=(t,e)=>(...o)=>{e()&&console.log(`[ANALYTIC]${t}`,...o);},b=t=>{let e=t.split("@")[1]?.toLowerCase();return e?l.includes(e):false},O=t=>/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t),i=null,D=async()=>{if(i)return i;let t=JSON.parse(m.get("website_status")||"{}")?.clients_country;return i=(async()=>{try{let e=await fetch(c).catch(()=>null);if(!e)return t||"";let o=await e.text().catch(()=>"");return o?Object.fromEntries(o.split(`
3
- `).map(r=>r.split("=",2))).loc?.toLowerCase()||t||"":t||""}catch{return t||""}})(),i},d=t=>{if(t==null||typeof t!="object")return t;if(Array.isArray(t)){let n=[];for(let r=0;r<t.length;r++){let s=d(t[r]);s!=null&&n.push(s);}return n.length?n:void 0}let e={},o=false;for(let n in t){if(!Object.prototype.hasOwnProperty.call(t,n))continue;let r=d(t[n]);r==null||r===""||typeof r=="object"&&!Array.isArray(r)&&Object.keys(r).length===0||Array.isArray(r)&&r.length===0||(e[n]=r,o=true);}return o?e:void 0},u=(t,e)=>{for(let o in t){if(!Object.prototype.hasOwnProperty.call(t,o))continue;let n=t[o];n&&typeof n=="object"&&!Array.isArray(n)?u(n,e):e[o]=n;}},R=t=>{if(t==null||typeof t!="object"||Array.isArray(t))return t;let e={};return u(t,e),e};export{f as a,y as b,g as c,h as d,p as e,v as f,k as g,b as h,O as i,D as j,d as k,R as l};//# sourceMappingURL=chunk-GGU2UVKH.mjs.map
4
- //# sourceMappingURL=chunk-GGU2UVKH.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/utils/urls.ts","../src/utils/helpers.ts"],"names":["cloudflareTrace","growthbookApi","rudderstackDataplane","posthogApiHost","posthogUiHost","getPosthogApiHost","hostname","allowedDomains","internalEmailDomains","getAllowedDomain","matched","d","createLogger","prefix","isDebugEnabled","args","isInternalEmail","email","domain","isUUID","str","countryPromise","getCountry","cookieCountry","Cookies","response","text","v","cleanObject","obj","out","i","cleaned","hasKeys","key","_flattenInto","target","value","flattenObject"],"mappings":"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","file":"chunk-GGU2UVKH.mjs","sourcesContent":["export const cloudflareTrace = 'https://deriv.com/cdn-cgi/trace'\nexport const growthbookApi = 'https://cdn.growthbook.io'\nexport const rudderstackDataplane = 'https://deriv-dataplane.rudderstack.com'\nexport const posthogApiHost = 'https://ph.deriv.com'\nexport const posthogUiHost = 'https://us.posthog.com'\n\nexport const getPosthogApiHost = (): string => {\n if (typeof window === 'undefined') return posthogApiHost\n const hostname = window.location.hostname\n if (hostname.includes('.deriv.me')) return 'https://ph.deriv.me'\n if (hostname.includes('.deriv.be')) return 'https://ph.deriv.be'\n return posthogApiHost\n}\n\nexport const allowedDomains = ['deriv.com', 'deriv.be', 'deriv.me', 'deriv.team', 'deriv.ae'] as const\n\nexport const internalEmailDomains = [\n 'deriv.com',\n 'derivcrypto.com',\n 'besquare.my',\n 'besquare.com.my',\n 'ewallet.exchange',\n 'champion-fx.com',\n 'opalstraits.com',\n 'binary.com',\n 'binary.marketing',\n 'championgbs.com',\n '4x.my',\n 're-work.dev',\n 'regentmarkets.com',\n '4x.com',\n 'binary.me',\n 'deriv.team',\n 'firstsource.io',\n 'firstsource.tech',\n 'deriv.hr',\n 'vmgbpo.net',\n 'mailisk.net',\n 'mailosaur.net',\n 'mobileapps.mailisk.net',\n 'w3e180zd.mailosaur.net',\n] as const\n\nexport const getAllowedDomain = (): string => {\n if (typeof window === 'undefined') return '.deriv.com'\n const hostname = window.location.hostname\n\n if (hostname === 'localhost') return ''\n\n const matched = allowedDomains.find(d => hostname.includes(d))\n return matched ? `.${matched}` : '.deriv.com'\n}\n","import Cookies from 'js-cookie'\nimport { cloudflareTrace, internalEmailDomains } from './urls'\n\n/**\n * Creates a prefixed logger that only outputs when debug mode is enabled.\n * Pass a getter function so the logger always reads the latest debug state.\n *\n * @param prefix - Optional provider name appended after [ANALYTIC], e.g. '[RudderStack]'\n * @param isDebugEnabled - A function that returns the current debug flag value\n * @returns A log function with the same signature as console.log\n *\n * @example\n * // In a class\n * private log = createLogger('[RudderStack]', () => this.debug)\n *\n * // In a closure\n * const log = createLogger('', () => _debug)\n */\nexport const createLogger =\n (prefix: string, isDebugEnabled: () => boolean) =>\n (...args: any[]): void => {\n if (isDebugEnabled()) console.log(`[ANALYTIC]${prefix}`, ...args)\n }\n\nexport const isInternalEmail = (email: string): boolean => {\n const domain = email.split('@')[1]?.toLowerCase()\n if (!domain) return false\n return (internalEmailDomains as readonly string[]).includes(domain)\n}\n\nexport const isUUID = (str: string): boolean => {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i\n return uuidRegex.test(str)\n}\n\ntype TraceData = {\n loc?: string\n}\n\nlet countryPromise: Promise<string> | null = null\n\n/**\n * Fetches the country information based on Cloudflare's trace data or a fallback from cookies.\n * This function attempts to retrieve the country location by first fetching trace data from Cloudflare\n * and then falling back to the location stored in the cookies if the fetch fails.\n *\n * @returns {Promise<string>} A Promise that resolves to a string representing the country code in lowercase.\n * Returns an empty string if no country data is available or if an error occurs.\n *\n * @example\n * // Returns the country code in lowercase based on Cloudflare's trace data or cookies.\n * getCountry().then(country => console.log(country));\n */\nexport const getCountry = async (): Promise<string> => {\n if (countryPromise) return countryPromise\n\n const cookieCountry = JSON.parse(Cookies.get('website_status') || '{}')?.clients_country\n\n countryPromise = (async () => {\n try {\n const response = await fetch(cloudflareTrace).catch(() => null)\n if (!response) return cookieCountry || ''\n\n const text = await response.text().catch(() => '')\n if (!text) return cookieCountry || ''\n\n const data: TraceData = Object.fromEntries(text.split('\\n').map(v => v.split('=', 2)))\n return data.loc?.toLowerCase() || cookieCountry || ''\n } catch {\n return cookieCountry || ''\n }\n })()\n\n return countryPromise\n}\n\n/**\n * Recursively cleans an object by removing undefined, null, empty strings, empty objects, and empty arrays\n * Used to sanitize event properties before sending to analytics providers\n *\n * @param obj - The object to clean\n * @returns The cleaned object, or undefined if the result would be empty\n */\nexport const cleanObject = (obj: any): any => {\n if (obj == null || typeof obj !== 'object') return obj\n\n if (Array.isArray(obj)) {\n const out: any[] = []\n for (let i = 0; i < obj.length; i++) {\n const v = cleanObject(obj[i])\n if (v !== undefined && v !== null) out.push(v)\n }\n return out.length ? out : undefined\n }\n\n const cleaned: Record<string, any> = {}\n let hasKeys = false\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const v = cleanObject(obj[key])\n if (\n v === undefined ||\n v === null ||\n v === '' ||\n (typeof v === 'object' && !Array.isArray(v) && Object.keys(v).length === 0) ||\n (Array.isArray(v) && v.length === 0)\n )\n continue\n cleaned[key] = v\n hasKeys = true\n }\n return hasKeys ? cleaned : undefined\n}\n\n/**\n * Flattens a nested object structure into a single-level object\n * Lifts all nested properties to the top level without prefixing\n *\n * @param obj - The object to flatten\n * @returns A flattened object with all nested properties at the top level\n *\n * @example\n * flattenObject({ action: 'click', event_metadata: { version: 2, user_language: 'en' } })\n * // Returns: { action: 'click', version: 2, user_language: 'en' }\n *\n * flattenObject({ form_name: 'signup', cta_information: { cta_name: 'signup', section_name: 'header' } })\n * // Returns: { form_name: 'signup', cta_name: 'signup', section_name: 'header' }\n */\nconst _flattenInto = (obj: Record<string, any>, target: Record<string, any>): void => {\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const value = obj[key]\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n _flattenInto(value, target)\n } else {\n target[key] = value\n }\n }\n}\n\nexport const flattenObject = (obj: any): Record<string, any> => {\n if (obj == null || typeof obj !== 'object' || Array.isArray(obj)) {\n return obj\n }\n const target: Record<string, any> = {}\n _flattenInto(obj, target)\n return target\n}\n"]}
@@ -1,4 +0,0 @@
1
- 'use strict';var f=require('js-cookie');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var f__default=/*#__PURE__*/_interopDefault(f);/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var c="https://deriv.com/cdn-cgi/trace",y="https://cdn.growthbook.io",g="https://deriv-dataplane.rudderstack.com",a="https://ph.deriv.com",h="https://us.posthog.com",v=()=>{if(typeof window>"u")return a;let t=window.location.hostname;return t.includes(".deriv.me")?"https://ph.deriv.me":t.includes(".deriv.be")?"https://ph.deriv.be":a},m=["deriv.com","deriv.be","deriv.me","deriv.team","deriv.ae"],l=["deriv.com","derivcrypto.com","besquare.my","besquare.com.my","ewallet.exchange","champion-fx.com","opalstraits.com","binary.com","binary.marketing","championgbs.com","4x.my","re-work.dev","regentmarkets.com","4x.com","binary.me","deriv.team","firstsource.io","firstsource.tech","deriv.hr","vmgbpo.net","mailisk.net","mailosaur.net","mobileapps.mailisk.net","w3e180zd.mailosaur.net"],x=()=>{if(typeof window>"u")return ".deriv.com";let t=window.location.hostname;if(t==="localhost")return "";let e=m.find(o=>t.includes(o));return e?`.${e}`:".deriv.com"};var O=(t,e)=>(...o)=>{e()&&console.log(`[ANALYTIC]${t}`,...o);},D=t=>{let e=t.split("@")[1]?.toLowerCase();return e?l.includes(e):false},R=t=>/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(t),i=null,C=async()=>{if(i)return i;let t=JSON.parse(f__default.default.get("website_status")||"{}")?.clients_country;return i=(async()=>{try{let e=await fetch(c).catch(()=>null);if(!e)return t||"";let o=await e.text().catch(()=>"");return o?Object.fromEntries(o.split(`
3
- `).map(r=>r.split("=",2))).loc?.toLowerCase()||t||"":t||""}catch{return t||""}})(),i},d=t=>{if(t==null||typeof t!="object")return t;if(Array.isArray(t)){let n=[];for(let r=0;r<t.length;r++){let s=d(t[r]);s!=null&&n.push(s);}return n.length?n:void 0}let e={},o=false;for(let n in t){if(!Object.prototype.hasOwnProperty.call(t,n))continue;let r=d(t[n]);r==null||r===""||typeof r=="object"&&!Array.isArray(r)&&Object.keys(r).length===0||Array.isArray(r)&&r.length===0||(e[n]=r,o=true);}return o?e:void 0},u=(t,e)=>{for(let o in t){if(!Object.prototype.hasOwnProperty.call(t,o))continue;let n=t[o];n&&typeof n=="object"&&!Array.isArray(n)?u(n,e):e[o]=n;}},P=t=>{if(t==null||typeof t!="object"||Array.isArray(t))return t;let e={};return u(t,e),e};exports.a=y;exports.b=g;exports.c=h;exports.d=v;exports.e=m;exports.f=x;exports.g=O;exports.h=D;exports.i=R;exports.j=C;exports.k=d;exports.l=P;//# sourceMappingURL=chunk-J3V5QNIH.js.map
4
- //# sourceMappingURL=chunk-J3V5QNIH.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/utils/urls.ts","../src/utils/helpers.ts"],"names":["cloudflareTrace","growthbookApi","rudderstackDataplane","posthogApiHost","posthogUiHost","getPosthogApiHost","hostname","allowedDomains","internalEmailDomains","getAllowedDomain","matched","d","createLogger","prefix","isDebugEnabled","args","isInternalEmail","email","domain","isUUID","str","countryPromise","getCountry","cookieCountry","Cookies","response","text","v","cleanObject","obj","out","i","cleaned","hasKeys","key","_flattenInto","target","value","flattenObject"],"mappings":"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","file":"chunk-J3V5QNIH.js","sourcesContent":["export const cloudflareTrace = 'https://deriv.com/cdn-cgi/trace'\nexport const growthbookApi = 'https://cdn.growthbook.io'\nexport const rudderstackDataplane = 'https://deriv-dataplane.rudderstack.com'\nexport const posthogApiHost = 'https://ph.deriv.com'\nexport const posthogUiHost = 'https://us.posthog.com'\n\nexport const getPosthogApiHost = (): string => {\n if (typeof window === 'undefined') return posthogApiHost\n const hostname = window.location.hostname\n if (hostname.includes('.deriv.me')) return 'https://ph.deriv.me'\n if (hostname.includes('.deriv.be')) return 'https://ph.deriv.be'\n return posthogApiHost\n}\n\nexport const allowedDomains = ['deriv.com', 'deriv.be', 'deriv.me', 'deriv.team', 'deriv.ae'] as const\n\nexport const internalEmailDomains = [\n 'deriv.com',\n 'derivcrypto.com',\n 'besquare.my',\n 'besquare.com.my',\n 'ewallet.exchange',\n 'champion-fx.com',\n 'opalstraits.com',\n 'binary.com',\n 'binary.marketing',\n 'championgbs.com',\n '4x.my',\n 're-work.dev',\n 'regentmarkets.com',\n '4x.com',\n 'binary.me',\n 'deriv.team',\n 'firstsource.io',\n 'firstsource.tech',\n 'deriv.hr',\n 'vmgbpo.net',\n 'mailisk.net',\n 'mailosaur.net',\n 'mobileapps.mailisk.net',\n 'w3e180zd.mailosaur.net',\n] as const\n\nexport const getAllowedDomain = (): string => {\n if (typeof window === 'undefined') return '.deriv.com'\n const hostname = window.location.hostname\n\n if (hostname === 'localhost') return ''\n\n const matched = allowedDomains.find(d => hostname.includes(d))\n return matched ? `.${matched}` : '.deriv.com'\n}\n","import Cookies from 'js-cookie'\nimport { cloudflareTrace, internalEmailDomains } from './urls'\n\n/**\n * Creates a prefixed logger that only outputs when debug mode is enabled.\n * Pass a getter function so the logger always reads the latest debug state.\n *\n * @param prefix - Optional provider name appended after [ANALYTIC], e.g. '[RudderStack]'\n * @param isDebugEnabled - A function that returns the current debug flag value\n * @returns A log function with the same signature as console.log\n *\n * @example\n * // In a class\n * private log = createLogger('[RudderStack]', () => this.debug)\n *\n * // In a closure\n * const log = createLogger('', () => _debug)\n */\nexport const createLogger =\n (prefix: string, isDebugEnabled: () => boolean) =>\n (...args: any[]): void => {\n if (isDebugEnabled()) console.log(`[ANALYTIC]${prefix}`, ...args)\n }\n\nexport const isInternalEmail = (email: string): boolean => {\n const domain = email.split('@')[1]?.toLowerCase()\n if (!domain) return false\n return (internalEmailDomains as readonly string[]).includes(domain)\n}\n\nexport const isUUID = (str: string): boolean => {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i\n return uuidRegex.test(str)\n}\n\ntype TraceData = {\n loc?: string\n}\n\nlet countryPromise: Promise<string> | null = null\n\n/**\n * Fetches the country information based on Cloudflare's trace data or a fallback from cookies.\n * This function attempts to retrieve the country location by first fetching trace data from Cloudflare\n * and then falling back to the location stored in the cookies if the fetch fails.\n *\n * @returns {Promise<string>} A Promise that resolves to a string representing the country code in lowercase.\n * Returns an empty string if no country data is available or if an error occurs.\n *\n * @example\n * // Returns the country code in lowercase based on Cloudflare's trace data or cookies.\n * getCountry().then(country => console.log(country));\n */\nexport const getCountry = async (): Promise<string> => {\n if (countryPromise) return countryPromise\n\n const cookieCountry = JSON.parse(Cookies.get('website_status') || '{}')?.clients_country\n\n countryPromise = (async () => {\n try {\n const response = await fetch(cloudflareTrace).catch(() => null)\n if (!response) return cookieCountry || ''\n\n const text = await response.text().catch(() => '')\n if (!text) return cookieCountry || ''\n\n const data: TraceData = Object.fromEntries(text.split('\\n').map(v => v.split('=', 2)))\n return data.loc?.toLowerCase() || cookieCountry || ''\n } catch {\n return cookieCountry || ''\n }\n })()\n\n return countryPromise\n}\n\n/**\n * Recursively cleans an object by removing undefined, null, empty strings, empty objects, and empty arrays\n * Used to sanitize event properties before sending to analytics providers\n *\n * @param obj - The object to clean\n * @returns The cleaned object, or undefined if the result would be empty\n */\nexport const cleanObject = (obj: any): any => {\n if (obj == null || typeof obj !== 'object') return obj\n\n if (Array.isArray(obj)) {\n const out: any[] = []\n for (let i = 0; i < obj.length; i++) {\n const v = cleanObject(obj[i])\n if (v !== undefined && v !== null) out.push(v)\n }\n return out.length ? out : undefined\n }\n\n const cleaned: Record<string, any> = {}\n let hasKeys = false\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const v = cleanObject(obj[key])\n if (\n v === undefined ||\n v === null ||\n v === '' ||\n (typeof v === 'object' && !Array.isArray(v) && Object.keys(v).length === 0) ||\n (Array.isArray(v) && v.length === 0)\n )\n continue\n cleaned[key] = v\n hasKeys = true\n }\n return hasKeys ? cleaned : undefined\n}\n\n/**\n * Flattens a nested object structure into a single-level object\n * Lifts all nested properties to the top level without prefixing\n *\n * @param obj - The object to flatten\n * @returns A flattened object with all nested properties at the top level\n *\n * @example\n * flattenObject({ action: 'click', event_metadata: { version: 2, user_language: 'en' } })\n * // Returns: { action: 'click', version: 2, user_language: 'en' }\n *\n * flattenObject({ form_name: 'signup', cta_information: { cta_name: 'signup', section_name: 'header' } })\n * // Returns: { form_name: 'signup', cta_name: 'signup', section_name: 'header' }\n */\nconst _flattenInto = (obj: Record<string, any>, target: Record<string, any>): void => {\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const value = obj[key]\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n _flattenInto(value, target)\n } else {\n target[key] = value\n }\n }\n}\n\nexport const flattenObject = (obj: any): Record<string, any> => {\n if (obj == null || typeof obj !== 'object' || Array.isArray(obj)) {\n return obj\n }\n const target: Record<string, any> = {}\n _flattenInto(obj, target)\n return target\n}\n"]}
@@ -1,3 +0,0 @@
1
- import {g}from'./chunk-GGU2UVKH.mjs';/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var p=class{constructor(){this.interval=null;this.responses=[];this.isTrackingResponses=false;this.delegatedSelectors=new Set;this.debug=false;this.log=g("[CacheManager]",()=>this.debug);this.addEventhandler=this.addEventHandler.bind(this);}setDebug(e){this.debug=e;}hash(e,n=32){let t=a=>{let r=2166136261;for(let c=0;c<a.length;c++)r^=a.charCodeAt(c),r=r*16777619>>>0;return r.toString(16)},i=a=>btoa(a),s=t(e),o=i(s);for(;o.length<n;)o+=i(t(o));return o.substring(0,n)}getCookies(e){let t=`; ${document.cookie}`.split(`; ${e}=`);if(t.length===2){let i=decodeURIComponent(t.pop().split(";").shift());try{return JSON.parse(i)}catch{return i}}return null}trackPageUnload(){typeof window>"u"||window.addEventListener("beforeunload",()=>{this.isPageViewSent()||this.push("cached_analytics_page_views",{name:window.location.href,properties:{url:window.location.href}});});}trackResponses(){if(typeof window>"u"||typeof XMLHttpRequest>"u")return;let e=XMLHttpRequest.prototype.open,n=XMLHttpRequest.prototype.send;XMLHttpRequest.prototype.open=function(t,i){return this._url=i,this._method=t,e.apply(this,arguments)},XMLHttpRequest.prototype.send=function(t){return this.addEventListener("load",function(){let i=null;if(typeof t=="string")try{i=JSON.parse(t);}catch{i=t;}let s={url:this._url,method:this._method,status:this.status,headers:this.getAllResponseHeaders(),data:this.responseText,payload:i};f.responses.push(s);}),n.apply(this,arguments)},this.isTrackingResponses=true;}getAnalyticsInstance(){return typeof window>"u"?null:window.AnalyticsInstance??window.DerivAnalytics?.Analytics??window.Analytics?.Analytics}isReady(){if(typeof window>"u")return false;let e=this.getAnalyticsInstance();return e?!!e.getInstances?.()?.tracking:false}parseCookies(e){if(typeof document>"u")return null;let n=document.cookie.split("; ");for(let t of n){let i=t.indexOf("=");if(i!==-1&&decodeURIComponent(t.slice(0,i))===e){let s=t.slice(i+1);try{return JSON.parse(decodeURIComponent(s))}catch{return decodeURIComponent(s)}}}return null}isPageViewSent(){return !!this.responses.find(e=>e.payload?.type==="page"&&e.payload?.anonymousId)}set(e){this.log("set | caching event to cookie",e),this.push("cached_analytics_events",e);}push(e,n){if(typeof document>"u")return;let t=[],i=this.parseCookies(e);i&&Array.isArray(i)&&(t=i),t.push(n);let s=this.getAllowedDomain(),o=365*24*60*60,a=`${e}=${encodeURIComponent(JSON.stringify(t))}; path=/; Domain=${s}; max-age=${o}; SameSite=Lax`;document.cookie=a;}getAllowedDomain(){if(typeof window>"u")return "";let e=window.location.hostname;if(e==="localhost"||/^\d+\.\d+\.\d+\.\d+$/.test(e))return e;let n=e.split(".");return n.length===1?e:`.${n.slice(-2).join(".")}`}processEvent(e){let n=this.getCookies("client_information");if(n){let{email:t=null}=n;t&&(e.properties.email_hash=this.hash(t));}if(e?.properties?.email){let t=e.properties.email;delete e.properties.email,e.properties.email_hash=this.hash(t);}return e}track(e,n=false){if(typeof window>"u")return;let t=this.processEvent(e),i=this.getAnalyticsInstance();this.isReady()&&!n?(this.log("track | analytics ready \u2014 calling trackEvent",{event:t.name,properties:t.properties}),i.trackEvent(t.name,t.properties)):(this.log("track | analytics not ready or cache=true \u2014 storing event",{event:t.name,cache:n}),this.set(t));}pageView(){typeof window>"u"||(this.log("pageView | starting page view polling"),this.isTrackingResponses||(this.trackResponses(),this.trackPageUnload()),this.interval=setInterval(()=>{let e=window.Analytics;typeof e<"u"&&typeof e.Analytics?.pageView=="function"&&this.isReady()&&(this.log("pageView | analytics ready \u2014 sending page view",{href:window.location.href}),e.Analytics.pageView(window.location.href,"Trader's hub")),this.isPageViewSent()&&(this.log("pageView | page view confirmed sent \u2014 clearing interval"),this.interval&&clearInterval(this.interval));},1e3));}listen(e,{name:n="",properties:t={}},i=false,s=null){let o=r=>{r.dataset?.clickEventTracking||(r.addEventListener("click",c=>{let l={name:n,properties:t,cache:i};if(typeof s=="function"){let d=s(c);l={...d,cache:d.cache??i};}this.track(l,l.cache??false);}),r.dataset.clickEventTracking="true");};(e instanceof NodeList?Array.from(e):[e]).forEach(o);}addEventHandler(e){return typeof window>"u"?this:(e.forEach(({element:n,event:t={name:"",properties:{}},cache:i=false,callback:s=null})=>{if(typeof n=="string"){let o=n;if(!this.delegatedSelectors.has(o)){let a=r=>{let c=r.target;if(!c)return;let l=c.closest(o);if(l&&!l.dataset?.clickEventTracking){let d={name:t.name,properties:t.properties,cache:i};if(typeof s=="function"){let h=s(r);d={...h,cache:h.cache??i};}l.dataset.clickEventTracking="true",this.track(d,d.cache??false);}};document.addEventListener("click",a),this.delegatedSelectors.add(o);}}else (n instanceof NodeList?Array.from(n):[n]).forEach(a=>{a&&!a.dataset?.clickEventTracking&&this.listen(a,t,i,s);});}),this)}loadEvent(e){return this.log("loadEvent | firing load events",e.map(n=>n.event.name)),e.forEach(({event:n})=>{let{name:t,properties:i}=n;this.track({name:t,properties:i});}),this}pageLoadEvent(e){if(typeof window>"u")return this;let n=window.location.pathname.slice(1);return this.log("pageLoadEvent | checking page load events",{pathname:n}),e.forEach(({pages:t=[],excludedPages:i=[],event:s,callback:o=null})=>{let a=false;if(t.length?t.includes(n)&&(a=true):i.length&&i.includes(n)||(a=true),a){let r=o?o():s;this.log("pageLoadEvent | dispatching event for page",{pathname:n,event:r.name}),this.loadEvent([{event:r}]);}else this.log("pageLoadEvent | skipped event for page",{pathname:n,event:s.name,pages:t,excludedPages:i});}),this}clearInterval(){this.interval&&(clearInterval(this.interval),this.interval=null);}cleanup(){this.clearInterval(),this.responses=[],this.isTrackingResponses=false;}},f=new p;typeof window<"u"&&(window.cacheTrackEvents=f);export{f as a};//# sourceMappingURL=chunk-LIPHY7JK.mjs.map
3
- //# sourceMappingURL=chunk-LIPHY7JK.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/utils/analytics-cache.ts"],"names":["AnalyticsCacheManager","createLogger","debug","inputString","desiredLength","fnv1aHash","string","hash","i","base64Encode","combined","name","parts","cookieValue","originalXhrOpen","originalXhrSend","method","url","body","parsedPayload","responseData","cacheTrackEvents","instance","cookieName","cookies","cookie","eqIdx","raw","event","data","storedCookies","cacheCookie","domain","maxAge","cookieString","hostname","clientInfo","email","originalEvent","cache","Analytics","element","properties","callback","addClickListener","el","e","callbackResult","items","selector","delegatedHandler","target","matched","evt","pathname","pages","excludedPages","dispatch","eventData"],"mappings":"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","file":"chunk-LIPHY7JK.mjs","sourcesContent":["/**\n * Analytics Cache Manager - Version 1.1.0\n * Enhanced TypeScript implementation with better type safety and SSR support\n */\nimport { createLogger } from './helpers'\n\ntype CachedEvent = {\n name: string\n properties: Record<string, any>\n}\n\ntype ResponseData = {\n url: string\n method: string\n status: number\n headers: string\n data: string\n payload: any\n}\n\ntype EventListenerConfig = {\n element: Element | NodeList | string\n event: {\n name: string\n properties: Record<string, any>\n }\n cache?: boolean\n callback?: (e: Event) => { name: string; properties: Record<string, any>; cache?: boolean }\n}\n\ntype LoadEventConfig = {\n event: {\n name: string\n properties: Record<string, any>\n }\n}\n\ntype PageLoadEventConfig = {\n pages?: string[]\n excludedPages?: string[]\n event: {\n name: string\n properties: Record<string, any>\n }\n callback?: () => { name: string; properties: Record<string, any> }\n}\n\nclass AnalyticsCacheManager {\n private interval: NodeJS.Timeout | null = null\n private responses: ResponseData[] = []\n private isTrackingResponses = false\n private delegatedSelectors: Set<string> = new Set()\n private debug = false\n private log = createLogger('[CacheManager]', () => this.debug)\n\n setDebug(debug: boolean): void {\n this.debug = debug\n }\n\n /**\n * FNV-1a hash algorithm for creating consistent hashes\n */\n private hash(inputString: string, desiredLength = 32): string {\n const fnv1aHash = (string: string): string => {\n let hash = 0x811c9dc5\n for (let i = 0; i < string.length; i++) {\n hash ^= string.charCodeAt(i)\n hash = (hash * 0x01000193) >>> 0\n }\n return hash.toString(16)\n }\n\n const base64Encode = (string: string): string => btoa(string)\n\n let hash = fnv1aHash(inputString)\n let combined = base64Encode(hash)\n\n while (combined.length < desiredLength) {\n combined += base64Encode(fnv1aHash(combined))\n }\n\n return combined.substring(0, desiredLength)\n }\n\n /**\n * Get cookie value by name\n */\n getCookies(name: string): any {\n const value = `; ${document.cookie}`\n const parts = value.split(`; ${name}=`)\n if (parts.length === 2) {\n const cookieValue = decodeURIComponent(parts.pop()!.split(';').shift()!)\n\n try {\n return JSON.parse(cookieValue)\n } catch (e) {\n return cookieValue\n }\n }\n return null\n }\n\n /**\n * Track page unload events to cache pageviews before leaving\n */\n trackPageUnload(): void {\n if (typeof window === 'undefined') return\n\n window.addEventListener('beforeunload', () => {\n if (!this.isPageViewSent()) {\n this.push('cached_analytics_page_views', {\n name: window.location.href,\n properties: {\n url: window.location.href,\n },\n })\n }\n })\n }\n\n /**\n * Track XMLHttpRequest responses to monitor analytics calls\n */\n trackResponses(): void {\n if (typeof window === 'undefined' || typeof XMLHttpRequest === 'undefined') return\n\n const originalXhrOpen = XMLHttpRequest.prototype.open\n const originalXhrSend = XMLHttpRequest.prototype.send\n\n XMLHttpRequest.prototype.open = function (method: string, url: string | URL) {\n ;(this as any)._url = url\n ;(this as any)._method = method\n return originalXhrOpen.apply(this, arguments as any)\n }\n\n XMLHttpRequest.prototype.send = function (body?: Document | XMLHttpRequestBodyInit | null) {\n this.addEventListener('load', function () {\n let parsedPayload = null\n\n if (typeof body === 'string') {\n try {\n parsedPayload = JSON.parse(body)\n } catch (e) {\n parsedPayload = body\n }\n }\n\n const responseData: ResponseData = {\n url: (this as any)._url,\n method: (this as any)._method,\n status: this.status,\n headers: this.getAllResponseHeaders(),\n data: this.responseText,\n payload: parsedPayload,\n }\n cacheTrackEvents.responses.push(responseData)\n })\n\n return originalXhrSend.apply(this, arguments as any)\n }\n\n this.isTrackingResponses = true\n }\n\n /**\n * Resolve the analytics instance from the window object.\n * Supports three usage patterns:\n * - NPM import: analytics.ts sets window.AnalyticsInstance directly\n * - IIFE bundle: tsup sets window.DerivAnalytics = { Analytics, cacheTrackEvents }\n * - Legacy: consumers that explicitly set window.Analytics = window.DerivAnalytics\n */\n private getAnalyticsInstance(): any {\n if (typeof window === 'undefined') return null\n return (\n (window as any).AnalyticsInstance ??\n (window as any).DerivAnalytics?.Analytics ??\n (window as any).Analytics?.Analytics\n )\n }\n\n /**\n * Check if Analytics instance is ready\n */\n isReady(): boolean {\n if (typeof window === 'undefined') return false\n const instance = this.getAnalyticsInstance()\n if (!instance) return false\n return !!instance.getInstances?.()?.tracking\n }\n\n /**\n * Parse cookies to find a specific cookie by name.\n * Uses an early-exit linear scan instead of building a full map,\n * which is significantly faster when there are many cookies.\n */\n private parseCookies(cookieName: string): any {\n if (typeof document === 'undefined') return null\n\n const cookies = document.cookie.split('; ')\n for (const cookie of cookies) {\n const eqIdx = cookie.indexOf('=')\n if (eqIdx === -1) continue\n if (decodeURIComponent(cookie.slice(0, eqIdx)) === cookieName) {\n const raw = cookie.slice(eqIdx + 1)\n try {\n return JSON.parse(decodeURIComponent(raw))\n } catch {\n return decodeURIComponent(raw)\n }\n }\n }\n return null\n }\n\n /**\n * Check if pageview has been sent\n */\n isPageViewSent(): boolean {\n return !!this.responses.find(e => e.payload?.type === 'page' && e.payload?.anonymousId)\n }\n\n /**\n * Set a cached event\n */\n set(event: CachedEvent): void {\n this.log('set | caching event to cookie', event)\n this.push('cached_analytics_events', event)\n }\n\n /**\n * Push data to cookie cache\n */\n push(cookieName: string, data: any): void {\n if (typeof document === 'undefined') return\n\n let storedCookies: any[] = []\n const cacheCookie = this.parseCookies(cookieName)\n if (cacheCookie && Array.isArray(cacheCookie)) {\n storedCookies = cacheCookie\n }\n\n storedCookies.push(data)\n\n const domain = this.getAllowedDomain()\n const maxAge = 365 * 24 * 60 * 60 // 1 year\n const cookieString = `${cookieName}=${encodeURIComponent(JSON.stringify(storedCookies))}; path=/; Domain=${domain}; max-age=${maxAge}; SameSite=Lax`\n\n document.cookie = cookieString\n }\n\n /**\n * Get the allowed domain for cookies\n * For localhost/single-part domains: use as-is\n * For multi-part domains: use top-level domain (e.g., .deriv.com)\n */\n private getAllowedDomain(): string {\n if (typeof window === 'undefined') return ''\n\n const hostname = window.location.hostname\n\n // Handle IP addresses and localhost\n if (hostname === 'localhost' || /^\\d+\\.\\d+\\.\\d+\\.\\d+$/.test(hostname)) {\n return hostname\n }\n\n const parts = hostname.split('.')\n\n // Single part domain (e.g., \"localhost\")\n if (parts.length === 1) {\n return hostname\n }\n\n // Use top-level domain for proper subdomain sharing\n return `.${parts.slice(-2).join('.')}`\n }\n\n /**\n * Process event to hash email and add client info\n */\n processEvent(event: CachedEvent): CachedEvent {\n const clientInfo = this.getCookies('client_information')\n\n if (clientInfo) {\n const { email = null } = clientInfo\n\n if (email) {\n event.properties.email_hash = this.hash(email)\n }\n }\n\n if (event?.properties?.email) {\n const email = event.properties.email\n delete event.properties.email\n event.properties.email_hash = this.hash(email)\n }\n\n return event\n }\n\n /**\n * Track an event (either immediately or cache it)\n */\n track(originalEvent: CachedEvent, cache = false): void {\n if (typeof window === 'undefined') return\n\n const event = this.processEvent(originalEvent)\n const instance = this.getAnalyticsInstance()\n\n if (this.isReady() && !cache) {\n this.log('track | analytics ready — calling trackEvent', {\n event: event.name,\n properties: event.properties,\n })\n instance.trackEvent(event.name, event.properties)\n } else {\n this.log('track | analytics not ready or cache=true — storing event', { event: event.name, cache })\n this.set(event)\n }\n }\n\n /**\n * Track pageview with auto-retry until sent\n */\n pageView(): void {\n if (typeof window === 'undefined') return\n\n this.log('pageView | starting page view polling')\n\n if (!this.isTrackingResponses) {\n this.trackResponses()\n this.trackPageUnload()\n }\n\n this.interval = setInterval(() => {\n const Analytics = (window as any).Analytics\n\n if (\n typeof Analytics !== 'undefined' &&\n typeof Analytics.Analytics?.pageView === 'function' &&\n this.isReady()\n ) {\n this.log('pageView | analytics ready — sending page view', { href: window.location.href })\n Analytics.Analytics.pageView(window.location.href, \"Trader's hub\")\n }\n\n if (this.isPageViewSent()) {\n this.log('pageView | page view confirmed sent — clearing interval')\n if (this.interval) clearInterval(this.interval)\n }\n }, 1000)\n }\n\n /**\n * Add click event listener to element(s)\n */\n listen(\n element: Element | NodeList,\n { name = '', properties = {} }: { name: string; properties: Record<string, any> },\n cache = false,\n callback: ((e: Event) => { name: string; properties: Record<string, any>; cache?: boolean }) | null = null\n ): void {\n const addClickListener = (el: Element) => {\n if (!(el as any).dataset?.clickEventTracking) {\n el.addEventListener('click', (e: Event) => {\n let event = {\n name,\n properties,\n cache,\n }\n\n if (typeof callback === 'function') {\n const callbackResult = callback(e)\n event = {\n ...callbackResult,\n cache: callbackResult.cache ?? cache,\n }\n }\n\n this.track(event, event.cache ?? false)\n })\n ;(el as any).dataset.clickEventTracking = 'true'\n }\n }\n\n const elements = element instanceof NodeList ? Array.from(element as NodeListOf<Element>) : [element]\n elements.forEach(addClickListener)\n }\n\n /**\n * Add event handlers to multiple elements with auto-retry\n * Alias for backward compatibility with typo\n */\n addEventHandler(items: EventListenerConfig[]): this {\n if (typeof window === 'undefined') return this\n\n items.forEach(({ element, event = { name: '', properties: {} }, cache = false, callback = null }) => {\n // If a selector string is provided, use event delegation on document\n if (typeof element === 'string') {\n const selector = element\n\n if (!this.delegatedSelectors.has(selector)) {\n const delegatedHandler = (e: Event) => {\n const target = e.target as Element | null\n if (!target) return\n\n const matched = target.closest(selector)\n if (matched && !(matched as any).dataset?.clickEventTracking) {\n let evt: any = {\n name: event.name,\n properties: event.properties,\n cache,\n }\n\n if (typeof callback === 'function') {\n const callbackResult = callback(e)\n evt = {\n ...callbackResult,\n cache: callbackResult.cache ?? cache,\n }\n }\n\n ;(matched as any).dataset.clickEventTracking = 'true'\n this.track(evt, evt.cache ?? false)\n }\n }\n\n document.addEventListener('click', delegatedHandler)\n this.delegatedSelectors.add(selector)\n }\n } else {\n // Element or NodeList: attach directly to existing elements\n const elements = element instanceof NodeList ? Array.from(element) : [element]\n\n elements.forEach(el => {\n if (el && !(el as any).dataset?.clickEventTracking) {\n this.listen(el as Element, event, cache, callback)\n }\n })\n }\n })\n\n return this\n }\n\n /**\n * Backward compatibility alias (with typo from original)\n */\n addEventhandler = this.addEventHandler.bind(this)\n\n /**\n * Load events immediately\n */\n loadEvent(items: LoadEventConfig[]): this {\n this.log(\n 'loadEvent | firing load events',\n items.map(i => i.event.name)\n )\n items.forEach(({ event }) => {\n const { name, properties } = event\n this.track({\n name,\n properties,\n })\n })\n\n return this\n }\n\n /**\n * Load events on specific pages\n */\n pageLoadEvent(items: PageLoadEventConfig[]): this {\n if (typeof window === 'undefined') return this\n\n const pathname = window.location.pathname.slice(1)\n this.log('pageLoadEvent | checking page load events', { pathname })\n\n items.forEach(({ pages = [], excludedPages = [], event, callback = null }) => {\n let dispatch = false\n if (pages.length) {\n if (pages.includes(pathname)) {\n dispatch = true\n }\n } else if (excludedPages.length) {\n if (!excludedPages.includes(pathname)) {\n dispatch = true\n }\n } else {\n dispatch = true\n }\n\n if (dispatch) {\n const eventData = callback ? callback() : event\n this.log('pageLoadEvent | dispatching event for page', { pathname, event: eventData.name })\n this.loadEvent([{ event: eventData }])\n } else {\n this.log('pageLoadEvent | skipped event for page', {\n pathname,\n event: event.name,\n pages,\n excludedPages,\n })\n }\n })\n\n return this\n }\n\n /**\n * Clear the interval and cleanup\n */\n clearInterval(): void {\n if (this.interval) {\n clearInterval(this.interval)\n this.interval = null\n }\n }\n\n /**\n * Cleanup method for removing event listeners and intervals\n */\n cleanup(): void {\n this.clearInterval()\n this.responses = []\n this.isTrackingResponses = false\n }\n}\n\n// Create singleton instance\nexport const cacheTrackEvents = new AnalyticsCacheManager()\n\n// Export to global scope for backward compatibility\nif (typeof window !== 'undefined') {\n ;(window as any).cacheTrackEvents = cacheTrackEvents\n}\n"]}
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkJ3V5QNIH_js=require('./chunk-J3V5QNIH.js');/* @deriv-com/analytics - NPM Package - Built with tsup */
2
- var p=class{constructor(){this.interval=null;this.responses=[];this.isTrackingResponses=false;this.delegatedSelectors=new Set;this.debug=false;this.log=chunkJ3V5QNIH_js.g("[CacheManager]",()=>this.debug);this.addEventhandler=this.addEventHandler.bind(this);}setDebug(e){this.debug=e;}hash(e,n=32){let t=a=>{let r=2166136261;for(let c=0;c<a.length;c++)r^=a.charCodeAt(c),r=r*16777619>>>0;return r.toString(16)},i=a=>btoa(a),s=t(e),o=i(s);for(;o.length<n;)o+=i(t(o));return o.substring(0,n)}getCookies(e){let t=`; ${document.cookie}`.split(`; ${e}=`);if(t.length===2){let i=decodeURIComponent(t.pop().split(";").shift());try{return JSON.parse(i)}catch{return i}}return null}trackPageUnload(){typeof window>"u"||window.addEventListener("beforeunload",()=>{this.isPageViewSent()||this.push("cached_analytics_page_views",{name:window.location.href,properties:{url:window.location.href}});});}trackResponses(){if(typeof window>"u"||typeof XMLHttpRequest>"u")return;let e=XMLHttpRequest.prototype.open,n=XMLHttpRequest.prototype.send;XMLHttpRequest.prototype.open=function(t,i){return this._url=i,this._method=t,e.apply(this,arguments)},XMLHttpRequest.prototype.send=function(t){return this.addEventListener("load",function(){let i=null;if(typeof t=="string")try{i=JSON.parse(t);}catch{i=t;}let s={url:this._url,method:this._method,status:this.status,headers:this.getAllResponseHeaders(),data:this.responseText,payload:i};f.responses.push(s);}),n.apply(this,arguments)},this.isTrackingResponses=true;}getAnalyticsInstance(){return typeof window>"u"?null:window.AnalyticsInstance??window.DerivAnalytics?.Analytics??window.Analytics?.Analytics}isReady(){if(typeof window>"u")return false;let e=this.getAnalyticsInstance();return e?!!e.getInstances?.()?.tracking:false}parseCookies(e){if(typeof document>"u")return null;let n=document.cookie.split("; ");for(let t of n){let i=t.indexOf("=");if(i!==-1&&decodeURIComponent(t.slice(0,i))===e){let s=t.slice(i+1);try{return JSON.parse(decodeURIComponent(s))}catch{return decodeURIComponent(s)}}}return null}isPageViewSent(){return !!this.responses.find(e=>e.payload?.type==="page"&&e.payload?.anonymousId)}set(e){this.log("set | caching event to cookie",e),this.push("cached_analytics_events",e);}push(e,n){if(typeof document>"u")return;let t=[],i=this.parseCookies(e);i&&Array.isArray(i)&&(t=i),t.push(n);let s=this.getAllowedDomain(),o=365*24*60*60,a=`${e}=${encodeURIComponent(JSON.stringify(t))}; path=/; Domain=${s}; max-age=${o}; SameSite=Lax`;document.cookie=a;}getAllowedDomain(){if(typeof window>"u")return "";let e=window.location.hostname;if(e==="localhost"||/^\d+\.\d+\.\d+\.\d+$/.test(e))return e;let n=e.split(".");return n.length===1?e:`.${n.slice(-2).join(".")}`}processEvent(e){let n=this.getCookies("client_information");if(n){let{email:t=null}=n;t&&(e.properties.email_hash=this.hash(t));}if(e?.properties?.email){let t=e.properties.email;delete e.properties.email,e.properties.email_hash=this.hash(t);}return e}track(e,n=false){if(typeof window>"u")return;let t=this.processEvent(e),i=this.getAnalyticsInstance();this.isReady()&&!n?(this.log("track | analytics ready \u2014 calling trackEvent",{event:t.name,properties:t.properties}),i.trackEvent(t.name,t.properties)):(this.log("track | analytics not ready or cache=true \u2014 storing event",{event:t.name,cache:n}),this.set(t));}pageView(){typeof window>"u"||(this.log("pageView | starting page view polling"),this.isTrackingResponses||(this.trackResponses(),this.trackPageUnload()),this.interval=setInterval(()=>{let e=window.Analytics;typeof e<"u"&&typeof e.Analytics?.pageView=="function"&&this.isReady()&&(this.log("pageView | analytics ready \u2014 sending page view",{href:window.location.href}),e.Analytics.pageView(window.location.href,"Trader's hub")),this.isPageViewSent()&&(this.log("pageView | page view confirmed sent \u2014 clearing interval"),this.interval&&clearInterval(this.interval));},1e3));}listen(e,{name:n="",properties:t={}},i=false,s=null){let o=r=>{r.dataset?.clickEventTracking||(r.addEventListener("click",c=>{let l={name:n,properties:t,cache:i};if(typeof s=="function"){let d=s(c);l={...d,cache:d.cache??i};}this.track(l,l.cache??false);}),r.dataset.clickEventTracking="true");};(e instanceof NodeList?Array.from(e):[e]).forEach(o);}addEventHandler(e){return typeof window>"u"?this:(e.forEach(({element:n,event:t={name:"",properties:{}},cache:i=false,callback:s=null})=>{if(typeof n=="string"){let o=n;if(!this.delegatedSelectors.has(o)){let a=r=>{let c=r.target;if(!c)return;let l=c.closest(o);if(l&&!l.dataset?.clickEventTracking){let d={name:t.name,properties:t.properties,cache:i};if(typeof s=="function"){let h=s(r);d={...h,cache:h.cache??i};}l.dataset.clickEventTracking="true",this.track(d,d.cache??false);}};document.addEventListener("click",a),this.delegatedSelectors.add(o);}}else (n instanceof NodeList?Array.from(n):[n]).forEach(a=>{a&&!a.dataset?.clickEventTracking&&this.listen(a,t,i,s);});}),this)}loadEvent(e){return this.log("loadEvent | firing load events",e.map(n=>n.event.name)),e.forEach(({event:n})=>{let{name:t,properties:i}=n;this.track({name:t,properties:i});}),this}pageLoadEvent(e){if(typeof window>"u")return this;let n=window.location.pathname.slice(1);return this.log("pageLoadEvent | checking page load events",{pathname:n}),e.forEach(({pages:t=[],excludedPages:i=[],event:s,callback:o=null})=>{let a=false;if(t.length?t.includes(n)&&(a=true):i.length&&i.includes(n)||(a=true),a){let r=o?o():s;this.log("pageLoadEvent | dispatching event for page",{pathname:n,event:r.name}),this.loadEvent([{event:r}]);}else this.log("pageLoadEvent | skipped event for page",{pathname:n,event:s.name,pages:t,excludedPages:i});}),this}clearInterval(){this.interval&&(clearInterval(this.interval),this.interval=null);}cleanup(){this.clearInterval(),this.responses=[],this.isTrackingResponses=false;}},f=new p;typeof window<"u"&&(window.cacheTrackEvents=f);exports.a=f;//# sourceMappingURL=chunk-SQ6Q4Z5S.js.map
3
- //# sourceMappingURL=chunk-SQ6Q4Z5S.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/utils/analytics-cache.ts"],"names":["AnalyticsCacheManager","createLogger","debug","inputString","desiredLength","fnv1aHash","string","hash","i","base64Encode","combined","name","parts","cookieValue","originalXhrOpen","originalXhrSend","method","url","body","parsedPayload","responseData","cacheTrackEvents","instance","cookieName","cookies","cookie","eqIdx","raw","event","data","storedCookies","cacheCookie","domain","maxAge","cookieString","hostname","clientInfo","email","originalEvent","cache","Analytics","element","properties","callback","addClickListener","el","e","callbackResult","items","selector","delegatedHandler","target","matched","evt","pathname","pages","excludedPages","dispatch","eventData"],"mappings":"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","file":"chunk-SQ6Q4Z5S.js","sourcesContent":["/**\n * Analytics Cache Manager - Version 1.1.0\n * Enhanced TypeScript implementation with better type safety and SSR support\n */\nimport { createLogger } from './helpers'\n\ntype CachedEvent = {\n name: string\n properties: Record<string, any>\n}\n\ntype ResponseData = {\n url: string\n method: string\n status: number\n headers: string\n data: string\n payload: any\n}\n\ntype EventListenerConfig = {\n element: Element | NodeList | string\n event: {\n name: string\n properties: Record<string, any>\n }\n cache?: boolean\n callback?: (e: Event) => { name: string; properties: Record<string, any>; cache?: boolean }\n}\n\ntype LoadEventConfig = {\n event: {\n name: string\n properties: Record<string, any>\n }\n}\n\ntype PageLoadEventConfig = {\n pages?: string[]\n excludedPages?: string[]\n event: {\n name: string\n properties: Record<string, any>\n }\n callback?: () => { name: string; properties: Record<string, any> }\n}\n\nclass AnalyticsCacheManager {\n private interval: NodeJS.Timeout | null = null\n private responses: ResponseData[] = []\n private isTrackingResponses = false\n private delegatedSelectors: Set<string> = new Set()\n private debug = false\n private log = createLogger('[CacheManager]', () => this.debug)\n\n setDebug(debug: boolean): void {\n this.debug = debug\n }\n\n /**\n * FNV-1a hash algorithm for creating consistent hashes\n */\n private hash(inputString: string, desiredLength = 32): string {\n const fnv1aHash = (string: string): string => {\n let hash = 0x811c9dc5\n for (let i = 0; i < string.length; i++) {\n hash ^= string.charCodeAt(i)\n hash = (hash * 0x01000193) >>> 0\n }\n return hash.toString(16)\n }\n\n const base64Encode = (string: string): string => btoa(string)\n\n let hash = fnv1aHash(inputString)\n let combined = base64Encode(hash)\n\n while (combined.length < desiredLength) {\n combined += base64Encode(fnv1aHash(combined))\n }\n\n return combined.substring(0, desiredLength)\n }\n\n /**\n * Get cookie value by name\n */\n getCookies(name: string): any {\n const value = `; ${document.cookie}`\n const parts = value.split(`; ${name}=`)\n if (parts.length === 2) {\n const cookieValue = decodeURIComponent(parts.pop()!.split(';').shift()!)\n\n try {\n return JSON.parse(cookieValue)\n } catch (e) {\n return cookieValue\n }\n }\n return null\n }\n\n /**\n * Track page unload events to cache pageviews before leaving\n */\n trackPageUnload(): void {\n if (typeof window === 'undefined') return\n\n window.addEventListener('beforeunload', () => {\n if (!this.isPageViewSent()) {\n this.push('cached_analytics_page_views', {\n name: window.location.href,\n properties: {\n url: window.location.href,\n },\n })\n }\n })\n }\n\n /**\n * Track XMLHttpRequest responses to monitor analytics calls\n */\n trackResponses(): void {\n if (typeof window === 'undefined' || typeof XMLHttpRequest === 'undefined') return\n\n const originalXhrOpen = XMLHttpRequest.prototype.open\n const originalXhrSend = XMLHttpRequest.prototype.send\n\n XMLHttpRequest.prototype.open = function (method: string, url: string | URL) {\n ;(this as any)._url = url\n ;(this as any)._method = method\n return originalXhrOpen.apply(this, arguments as any)\n }\n\n XMLHttpRequest.prototype.send = function (body?: Document | XMLHttpRequestBodyInit | null) {\n this.addEventListener('load', function () {\n let parsedPayload = null\n\n if (typeof body === 'string') {\n try {\n parsedPayload = JSON.parse(body)\n } catch (e) {\n parsedPayload = body\n }\n }\n\n const responseData: ResponseData = {\n url: (this as any)._url,\n method: (this as any)._method,\n status: this.status,\n headers: this.getAllResponseHeaders(),\n data: this.responseText,\n payload: parsedPayload,\n }\n cacheTrackEvents.responses.push(responseData)\n })\n\n return originalXhrSend.apply(this, arguments as any)\n }\n\n this.isTrackingResponses = true\n }\n\n /**\n * Resolve the analytics instance from the window object.\n * Supports three usage patterns:\n * - NPM import: analytics.ts sets window.AnalyticsInstance directly\n * - IIFE bundle: tsup sets window.DerivAnalytics = { Analytics, cacheTrackEvents }\n * - Legacy: consumers that explicitly set window.Analytics = window.DerivAnalytics\n */\n private getAnalyticsInstance(): any {\n if (typeof window === 'undefined') return null\n return (\n (window as any).AnalyticsInstance ??\n (window as any).DerivAnalytics?.Analytics ??\n (window as any).Analytics?.Analytics\n )\n }\n\n /**\n * Check if Analytics instance is ready\n */\n isReady(): boolean {\n if (typeof window === 'undefined') return false\n const instance = this.getAnalyticsInstance()\n if (!instance) return false\n return !!instance.getInstances?.()?.tracking\n }\n\n /**\n * Parse cookies to find a specific cookie by name.\n * Uses an early-exit linear scan instead of building a full map,\n * which is significantly faster when there are many cookies.\n */\n private parseCookies(cookieName: string): any {\n if (typeof document === 'undefined') return null\n\n const cookies = document.cookie.split('; ')\n for (const cookie of cookies) {\n const eqIdx = cookie.indexOf('=')\n if (eqIdx === -1) continue\n if (decodeURIComponent(cookie.slice(0, eqIdx)) === cookieName) {\n const raw = cookie.slice(eqIdx + 1)\n try {\n return JSON.parse(decodeURIComponent(raw))\n } catch {\n return decodeURIComponent(raw)\n }\n }\n }\n return null\n }\n\n /**\n * Check if pageview has been sent\n */\n isPageViewSent(): boolean {\n return !!this.responses.find(e => e.payload?.type === 'page' && e.payload?.anonymousId)\n }\n\n /**\n * Set a cached event\n */\n set(event: CachedEvent): void {\n this.log('set | caching event to cookie', event)\n this.push('cached_analytics_events', event)\n }\n\n /**\n * Push data to cookie cache\n */\n push(cookieName: string, data: any): void {\n if (typeof document === 'undefined') return\n\n let storedCookies: any[] = []\n const cacheCookie = this.parseCookies(cookieName)\n if (cacheCookie && Array.isArray(cacheCookie)) {\n storedCookies = cacheCookie\n }\n\n storedCookies.push(data)\n\n const domain = this.getAllowedDomain()\n const maxAge = 365 * 24 * 60 * 60 // 1 year\n const cookieString = `${cookieName}=${encodeURIComponent(JSON.stringify(storedCookies))}; path=/; Domain=${domain}; max-age=${maxAge}; SameSite=Lax`\n\n document.cookie = cookieString\n }\n\n /**\n * Get the allowed domain for cookies\n * For localhost/single-part domains: use as-is\n * For multi-part domains: use top-level domain (e.g., .deriv.com)\n */\n private getAllowedDomain(): string {\n if (typeof window === 'undefined') return ''\n\n const hostname = window.location.hostname\n\n // Handle IP addresses and localhost\n if (hostname === 'localhost' || /^\\d+\\.\\d+\\.\\d+\\.\\d+$/.test(hostname)) {\n return hostname\n }\n\n const parts = hostname.split('.')\n\n // Single part domain (e.g., \"localhost\")\n if (parts.length === 1) {\n return hostname\n }\n\n // Use top-level domain for proper subdomain sharing\n return `.${parts.slice(-2).join('.')}`\n }\n\n /**\n * Process event to hash email and add client info\n */\n processEvent(event: CachedEvent): CachedEvent {\n const clientInfo = this.getCookies('client_information')\n\n if (clientInfo) {\n const { email = null } = clientInfo\n\n if (email) {\n event.properties.email_hash = this.hash(email)\n }\n }\n\n if (event?.properties?.email) {\n const email = event.properties.email\n delete event.properties.email\n event.properties.email_hash = this.hash(email)\n }\n\n return event\n }\n\n /**\n * Track an event (either immediately or cache it)\n */\n track(originalEvent: CachedEvent, cache = false): void {\n if (typeof window === 'undefined') return\n\n const event = this.processEvent(originalEvent)\n const instance = this.getAnalyticsInstance()\n\n if (this.isReady() && !cache) {\n this.log('track | analytics ready — calling trackEvent', {\n event: event.name,\n properties: event.properties,\n })\n instance.trackEvent(event.name, event.properties)\n } else {\n this.log('track | analytics not ready or cache=true — storing event', { event: event.name, cache })\n this.set(event)\n }\n }\n\n /**\n * Track pageview with auto-retry until sent\n */\n pageView(): void {\n if (typeof window === 'undefined') return\n\n this.log('pageView | starting page view polling')\n\n if (!this.isTrackingResponses) {\n this.trackResponses()\n this.trackPageUnload()\n }\n\n this.interval = setInterval(() => {\n const Analytics = (window as any).Analytics\n\n if (\n typeof Analytics !== 'undefined' &&\n typeof Analytics.Analytics?.pageView === 'function' &&\n this.isReady()\n ) {\n this.log('pageView | analytics ready — sending page view', { href: window.location.href })\n Analytics.Analytics.pageView(window.location.href, \"Trader's hub\")\n }\n\n if (this.isPageViewSent()) {\n this.log('pageView | page view confirmed sent — clearing interval')\n if (this.interval) clearInterval(this.interval)\n }\n }, 1000)\n }\n\n /**\n * Add click event listener to element(s)\n */\n listen(\n element: Element | NodeList,\n { name = '', properties = {} }: { name: string; properties: Record<string, any> },\n cache = false,\n callback: ((e: Event) => { name: string; properties: Record<string, any>; cache?: boolean }) | null = null\n ): void {\n const addClickListener = (el: Element) => {\n if (!(el as any).dataset?.clickEventTracking) {\n el.addEventListener('click', (e: Event) => {\n let event = {\n name,\n properties,\n cache,\n }\n\n if (typeof callback === 'function') {\n const callbackResult = callback(e)\n event = {\n ...callbackResult,\n cache: callbackResult.cache ?? cache,\n }\n }\n\n this.track(event, event.cache ?? false)\n })\n ;(el as any).dataset.clickEventTracking = 'true'\n }\n }\n\n const elements = element instanceof NodeList ? Array.from(element as NodeListOf<Element>) : [element]\n elements.forEach(addClickListener)\n }\n\n /**\n * Add event handlers to multiple elements with auto-retry\n * Alias for backward compatibility with typo\n */\n addEventHandler(items: EventListenerConfig[]): this {\n if (typeof window === 'undefined') return this\n\n items.forEach(({ element, event = { name: '', properties: {} }, cache = false, callback = null }) => {\n // If a selector string is provided, use event delegation on document\n if (typeof element === 'string') {\n const selector = element\n\n if (!this.delegatedSelectors.has(selector)) {\n const delegatedHandler = (e: Event) => {\n const target = e.target as Element | null\n if (!target) return\n\n const matched = target.closest(selector)\n if (matched && !(matched as any).dataset?.clickEventTracking) {\n let evt: any = {\n name: event.name,\n properties: event.properties,\n cache,\n }\n\n if (typeof callback === 'function') {\n const callbackResult = callback(e)\n evt = {\n ...callbackResult,\n cache: callbackResult.cache ?? cache,\n }\n }\n\n ;(matched as any).dataset.clickEventTracking = 'true'\n this.track(evt, evt.cache ?? false)\n }\n }\n\n document.addEventListener('click', delegatedHandler)\n this.delegatedSelectors.add(selector)\n }\n } else {\n // Element or NodeList: attach directly to existing elements\n const elements = element instanceof NodeList ? Array.from(element) : [element]\n\n elements.forEach(el => {\n if (el && !(el as any).dataset?.clickEventTracking) {\n this.listen(el as Element, event, cache, callback)\n }\n })\n }\n })\n\n return this\n }\n\n /**\n * Backward compatibility alias (with typo from original)\n */\n addEventhandler = this.addEventHandler.bind(this)\n\n /**\n * Load events immediately\n */\n loadEvent(items: LoadEventConfig[]): this {\n this.log(\n 'loadEvent | firing load events',\n items.map(i => i.event.name)\n )\n items.forEach(({ event }) => {\n const { name, properties } = event\n this.track({\n name,\n properties,\n })\n })\n\n return this\n }\n\n /**\n * Load events on specific pages\n */\n pageLoadEvent(items: PageLoadEventConfig[]): this {\n if (typeof window === 'undefined') return this\n\n const pathname = window.location.pathname.slice(1)\n this.log('pageLoadEvent | checking page load events', { pathname })\n\n items.forEach(({ pages = [], excludedPages = [], event, callback = null }) => {\n let dispatch = false\n if (pages.length) {\n if (pages.includes(pathname)) {\n dispatch = true\n }\n } else if (excludedPages.length) {\n if (!excludedPages.includes(pathname)) {\n dispatch = true\n }\n } else {\n dispatch = true\n }\n\n if (dispatch) {\n const eventData = callback ? callback() : event\n this.log('pageLoadEvent | dispatching event for page', { pathname, event: eventData.name })\n this.loadEvent([{ event: eventData }])\n } else {\n this.log('pageLoadEvent | skipped event for page', {\n pathname,\n event: event.name,\n pages,\n excludedPages,\n })\n }\n })\n\n return this\n }\n\n /**\n * Clear the interval and cleanup\n */\n clearInterval(): void {\n if (this.interval) {\n clearInterval(this.interval)\n this.interval = null\n }\n }\n\n /**\n * Cleanup method for removing event listeners and intervals\n */\n cleanup(): void {\n this.clearInterval()\n this.responses = []\n this.isTrackingResponses = false\n }\n}\n\n// Create singleton instance\nexport const cacheTrackEvents = new AnalyticsCacheManager()\n\n// Export to global scope for backward compatibility\nif (typeof window !== 'undefined') {\n ;(window as any).cacheTrackEvents = cacheTrackEvents\n}\n"]}
@@ -1,9 +0,0 @@
1
- /* @deriv-com/analytics - Browser ESM Bundle (RudderStack + PostHog) - Built with tsup */
2
- var w=Object.defineProperty;var A=(e,t,r)=>t in e?w(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r;var D=(e,t,r)=>A(e,typeof t!="symbol"?t+"":t,r);var m="https://deriv.com/cdn-cgi/trace",I="https://cdn.growthbook.io",U="https://deriv-dataplane.rudderstack.com",f="https://ph.deriv.com",b="https://us.posthog.com",E=()=>{if(typeof window>"u")return f;let e=window.location.hostname;return e.includes(".deriv.me")?"https://ph.deriv.me":e.includes(".deriv.be")?"https://ph.deriv.be":f},k=["deriv.com","deriv.be","deriv.me","deriv.team","deriv.ae"],y=["deriv.com","derivcrypto.com","besquare.my","besquare.com.my","ewallet.exchange","champion-fx.com","opalstraits.com","binary.com","binary.marketing","championgbs.com","4x.my","re-work.dev","regentmarkets.com","4x.com","binary.me","deriv.team","firstsource.io","firstsource.tech","deriv.hr","vmgbpo.net","mailisk.net","mailosaur.net","mobileapps.mailisk.net","w3e180zd.mailosaur.net"],P=()=>{if(typeof window>"u")return".deriv.com";let e=window.location.hostname;if(e==="localhost")return"";let t=k.find(r=>e.includes(r));return t?`.${t}`:".deriv.com"};function d(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var o in r)e[o]=r[o]}return e}var C={read:function(e){return e[0]==='"'&&(e=e.slice(1,-1)),e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(e){return encodeURIComponent(e).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}};function u(e,t){function r(n,c,i){if(!(typeof document>"u")){i=d({},t,i),typeof i.expires=="number"&&(i.expires=new Date(Date.now()+i.expires*864e5)),i.expires&&(i.expires=i.expires.toUTCString()),n=encodeURIComponent(n).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var s="";for(var a in i)i[a]&&(s+="; "+a,i[a]!==!0&&(s+="="+i[a].split(";")[0]));return document.cookie=n+"="+e.write(c,n)+s}}function o(n){if(!(typeof document>"u"||arguments.length&&!n)){for(var c=document.cookie?document.cookie.split("; "):[],i={},s=0;s<c.length;s++){var a=c[s].split("="),x=a.slice(1).join("=");try{var p=decodeURIComponent(a[0]);if(i[p]=e.read(x,p),n===p)break}catch{}}return n?i[n]:i}}return Object.create({set:r,get:o,remove:function(n,c){r(n,"",d({},c,{expires:-1}))},withAttributes:function(n){return u(this.converter,d({},this.attributes,n))},withConverter:function(n){return u(d({},this.converter,n),this.attributes)}},{attributes:{value:Object.freeze(t)},converter:{value:Object.freeze(e)}})}var g=u(C,{path:"/"});var F=(e,t)=>(...r)=>{t()&&console.log(`[ANALYTIC]${e}`,...r)},H=e=>{let t=e.split("@")[1]?.toLowerCase();return t?y.includes(t):!1},_=e=>/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(e),l=null,$=async()=>{if(l)return l;let e=JSON.parse(g.get("website_status")||"{}")?.clients_country;return l=(async()=>{try{let t=await fetch(m).catch(()=>null);if(!t)return e||"";let r=await t.text().catch(()=>"");return r?Object.fromEntries(r.split(`
3
- `).map(n=>n.split("=",2))).loc?.toLowerCase()||e||"":e||""}catch{return e||""}})(),l},h=e=>{if(e==null||typeof e!="object")return e;if(Array.isArray(e)){let o=[];for(let n=0;n<e.length;n++){let c=h(e[n]);c!=null&&o.push(c)}return o.length?o:void 0}let t={},r=!1;for(let o in e){if(!Object.prototype.hasOwnProperty.call(e,o))continue;let n=h(e[o]);n==null||n===""||typeof n=="object"&&!Array.isArray(n)&&Object.keys(n).length===0||Array.isArray(n)&&n.length===0||(t[o]=n,r=!0)}return r?t:void 0},v=(e,t)=>{for(let r in e){if(!Object.prototype.hasOwnProperty.call(e,r))continue;let o=e[r];o&&typeof o=="object"&&!Array.isArray(o)?v(o,t):t[r]=o}},q=e=>{if(e==null||typeof e!="object"||Array.isArray(e))return e;let t={};return v(e,t),t};export{D as a,I as b,U as c,b as d,E as e,k as f,P as g,g as h,F as i,H as j,_ as k,$ as l,h as m,q as n};
4
- /*! Bundled license information:
5
-
6
- js-cookie/dist/js.cookie.mjs:
7
- (*! js-cookie v3.0.5 | MIT *)
8
- */
9
- //# sourceMappingURL=chunk-UG2YL4OB.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/utils/urls.ts","../node_modules/js-cookie/dist/js.cookie.mjs","../src/utils/helpers.ts"],"sourcesContent":["export const cloudflareTrace = 'https://deriv.com/cdn-cgi/trace'\nexport const growthbookApi = 'https://cdn.growthbook.io'\nexport const rudderstackDataplane = 'https://deriv-dataplane.rudderstack.com'\nexport const posthogApiHost = 'https://ph.deriv.com'\nexport const posthogUiHost = 'https://us.posthog.com'\n\nexport const getPosthogApiHost = (): string => {\n if (typeof window === 'undefined') return posthogApiHost\n const hostname = window.location.hostname\n if (hostname.includes('.deriv.me')) return 'https://ph.deriv.me'\n if (hostname.includes('.deriv.be')) return 'https://ph.deriv.be'\n return posthogApiHost\n}\n\nexport const allowedDomains = ['deriv.com', 'deriv.be', 'deriv.me', 'deriv.team', 'deriv.ae'] as const\n\nexport const internalEmailDomains = [\n 'deriv.com',\n 'derivcrypto.com',\n 'besquare.my',\n 'besquare.com.my',\n 'ewallet.exchange',\n 'champion-fx.com',\n 'opalstraits.com',\n 'binary.com',\n 'binary.marketing',\n 'championgbs.com',\n '4x.my',\n 're-work.dev',\n 'regentmarkets.com',\n '4x.com',\n 'binary.me',\n 'deriv.team',\n 'firstsource.io',\n 'firstsource.tech',\n 'deriv.hr',\n 'vmgbpo.net',\n 'mailisk.net',\n 'mailosaur.net',\n 'mobileapps.mailisk.net',\n 'w3e180zd.mailosaur.net',\n] as const\n\nexport const getAllowedDomain = (): string => {\n if (typeof window === 'undefined') return '.deriv.com'\n const hostname = window.location.hostname\n\n if (hostname === 'localhost') return ''\n\n const matched = allowedDomains.find(d => hostname.includes(d))\n return matched ? `.${matched}` : '.deriv.com'\n}\n","/*! js-cookie v3.0.5 | MIT */\n/* eslint-disable no-var */\nfunction assign (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n target[key] = source[key];\n }\n }\n return target\n}\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\nvar defaultConverter = {\n read: function (value) {\n if (value[0] === '\"') {\n value = value.slice(1, -1);\n }\n return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n },\n write: function (value) {\n return encodeURIComponent(value).replace(\n /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n decodeURIComponent\n )\n }\n};\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\n\nfunction init (converter, defaultAttributes) {\n function set (name, value, attributes) {\n if (typeof document === 'undefined') {\n return\n }\n\n attributes = assign({}, defaultAttributes, attributes);\n\n if (typeof attributes.expires === 'number') {\n attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n }\n if (attributes.expires) {\n attributes.expires = attributes.expires.toUTCString();\n }\n\n name = encodeURIComponent(name)\n .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n .replace(/[()]/g, escape);\n\n var stringifiedAttributes = '';\n for (var attributeName in attributes) {\n if (!attributes[attributeName]) {\n continue\n }\n\n stringifiedAttributes += '; ' + attributeName;\n\n if (attributes[attributeName] === true) {\n continue\n }\n\n // Considers RFC 6265 section 5.2:\n // ...\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n // Consume the characters of the unparsed-attributes up to,\n // not including, the first %x3B (\";\") character.\n // ...\n stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n }\n\n return (document.cookie =\n name + '=' + converter.write(value, name) + stringifiedAttributes)\n }\n\n function get (name) {\n if (typeof document === 'undefined' || (arguments.length && !name)) {\n return\n }\n\n // To prevent the for loop in the first place assign an empty array\n // in case there are no cookies at all.\n var cookies = document.cookie ? document.cookie.split('; ') : [];\n var jar = {};\n for (var i = 0; i < cookies.length; i++) {\n var parts = cookies[i].split('=');\n var value = parts.slice(1).join('=');\n\n try {\n var found = decodeURIComponent(parts[0]);\n jar[found] = converter.read(value, found);\n\n if (name === found) {\n break\n }\n } catch (e) {}\n }\n\n return name ? jar[name] : jar\n }\n\n return Object.create(\n {\n set,\n get,\n remove: function (name, attributes) {\n set(\n name,\n '',\n assign({}, attributes, {\n expires: -1\n })\n );\n },\n withAttributes: function (attributes) {\n return init(this.converter, assign({}, this.attributes, attributes))\n },\n withConverter: function (converter) {\n return init(assign({}, this.converter, converter), this.attributes)\n }\n },\n {\n attributes: { value: Object.freeze(defaultAttributes) },\n converter: { value: Object.freeze(converter) }\n }\n )\n}\n\nvar api = init(defaultConverter, { path: '/' });\n/* eslint-enable no-var */\n\nexport { api as default };\n","import Cookies from 'js-cookie'\nimport { cloudflareTrace, internalEmailDomains } from './urls'\n\n/**\n * Creates a prefixed logger that only outputs when debug mode is enabled.\n * Pass a getter function so the logger always reads the latest debug state.\n *\n * @param prefix - Optional provider name appended after [ANALYTIC], e.g. '[RudderStack]'\n * @param isDebugEnabled - A function that returns the current debug flag value\n * @returns A log function with the same signature as console.log\n *\n * @example\n * // In a class\n * private log = createLogger('[RudderStack]', () => this.debug)\n *\n * // In a closure\n * const log = createLogger('', () => _debug)\n */\nexport const createLogger =\n (prefix: string, isDebugEnabled: () => boolean) =>\n (...args: any[]): void => {\n if (isDebugEnabled()) console.log(`[ANALYTIC]${prefix}`, ...args)\n }\n\nexport const isInternalEmail = (email: string): boolean => {\n const domain = email.split('@')[1]?.toLowerCase()\n if (!domain) return false\n return (internalEmailDomains as readonly string[]).includes(domain)\n}\n\nexport const isUUID = (str: string): boolean => {\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i\n return uuidRegex.test(str)\n}\n\ntype TraceData = {\n loc?: string\n}\n\nlet countryPromise: Promise<string> | null = null\n\n/**\n * Fetches the country information based on Cloudflare's trace data or a fallback from cookies.\n * This function attempts to retrieve the country location by first fetching trace data from Cloudflare\n * and then falling back to the location stored in the cookies if the fetch fails.\n *\n * @returns {Promise<string>} A Promise that resolves to a string representing the country code in lowercase.\n * Returns an empty string if no country data is available or if an error occurs.\n *\n * @example\n * // Returns the country code in lowercase based on Cloudflare's trace data or cookies.\n * getCountry().then(country => console.log(country));\n */\nexport const getCountry = async (): Promise<string> => {\n if (countryPromise) return countryPromise\n\n const cookieCountry = JSON.parse(Cookies.get('website_status') || '{}')?.clients_country\n\n countryPromise = (async () => {\n try {\n const response = await fetch(cloudflareTrace).catch(() => null)\n if (!response) return cookieCountry || ''\n\n const text = await response.text().catch(() => '')\n if (!text) return cookieCountry || ''\n\n const data: TraceData = Object.fromEntries(text.split('\\n').map(v => v.split('=', 2)))\n return data.loc?.toLowerCase() || cookieCountry || ''\n } catch {\n return cookieCountry || ''\n }\n })()\n\n return countryPromise\n}\n\n/**\n * Recursively cleans an object by removing undefined, null, empty strings, empty objects, and empty arrays\n * Used to sanitize event properties before sending to analytics providers\n *\n * @param obj - The object to clean\n * @returns The cleaned object, or undefined if the result would be empty\n */\nexport const cleanObject = (obj: any): any => {\n if (obj == null || typeof obj !== 'object') return obj\n\n if (Array.isArray(obj)) {\n const out: any[] = []\n for (let i = 0; i < obj.length; i++) {\n const v = cleanObject(obj[i])\n if (v !== undefined && v !== null) out.push(v)\n }\n return out.length ? out : undefined\n }\n\n const cleaned: Record<string, any> = {}\n let hasKeys = false\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const v = cleanObject(obj[key])\n if (\n v === undefined ||\n v === null ||\n v === '' ||\n (typeof v === 'object' && !Array.isArray(v) && Object.keys(v).length === 0) ||\n (Array.isArray(v) && v.length === 0)\n )\n continue\n cleaned[key] = v\n hasKeys = true\n }\n return hasKeys ? cleaned : undefined\n}\n\n/**\n * Flattens a nested object structure into a single-level object\n * Lifts all nested properties to the top level without prefixing\n *\n * @param obj - The object to flatten\n * @returns A flattened object with all nested properties at the top level\n *\n * @example\n * flattenObject({ action: 'click', event_metadata: { version: 2, user_language: 'en' } })\n * // Returns: { action: 'click', version: 2, user_language: 'en' }\n *\n * flattenObject({ form_name: 'signup', cta_information: { cta_name: 'signup', section_name: 'header' } })\n * // Returns: { form_name: 'signup', cta_name: 'signup', section_name: 'header' }\n */\nconst _flattenInto = (obj: Record<string, any>, target: Record<string, any>): void => {\n for (const key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) continue\n const value = obj[key]\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n _flattenInto(value, target)\n } else {\n target[key] = value\n }\n }\n}\n\nexport const flattenObject = (obj: any): Record<string, any> => {\n if (obj == null || typeof obj !== 'object' || Array.isArray(obj)) {\n return obj\n }\n const target: Record<string, any> = {}\n _flattenInto(obj, target)\n return target\n}\n"],"mappings":"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","names":["cloudflareTrace","growthbookApi","rudderstackDataplane","posthogApiHost","posthogUiHost","getPosthogApiHost","hostname","allowedDomains","internalEmailDomains","getAllowedDomain","matched","d","assign","target","i","source","key","defaultConverter","value","init","converter","defaultAttributes","set","name","attributes","stringifiedAttributes","attributeName","get","cookies","jar","parts","found","api","createLogger","prefix","isDebugEnabled","args","isInternalEmail","email","domain","internalEmailDomains","isUUID","str","countryPromise","getCountry","cookieCountry","api","response","cloudflareTrace","text","v","cleanObject","obj","out","i","cleaned","hasKeys","key","_flattenInto","target","value","flattenObject"]}