@deriv-com/analytics 1.36.0 → 1.37.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +853 -72
- package/dist/browser/analytics.bundle.global.js +23 -0
- package/dist/browser/analytics.bundle.global.js.map +1 -0
- package/dist/browser/analytics.esm.mjs +9 -0
- package/dist/browser/analytics.esm.mjs.map +1 -0
- package/dist/chunk-2P7RWD3W.mjs +3 -0
- package/dist/chunk-2P7RWD3W.mjs.map +1 -0
- package/dist/chunk-3LFZFQL4.mjs +3 -0
- package/dist/chunk-3LFZFQL4.mjs.map +1 -0
- package/dist/chunk-DNCZM4KN.mjs +4 -0
- package/dist/chunk-DNCZM4KN.mjs.map +1 -0
- package/dist/chunk-EMF3RT6E.mjs +14 -0
- package/dist/chunk-EMF3RT6E.mjs.map +1 -0
- package/dist/chunk-HQX3Z7PF.mjs +3 -0
- package/dist/chunk-HQX3Z7PF.mjs.map +1 -0
- package/dist/chunk-LKLVBL24.js +3 -0
- package/dist/chunk-LKLVBL24.js.map +1 -0
- package/dist/chunk-NOEKD4DT.js +4 -0
- package/dist/chunk-NOEKD4DT.js.map +1 -0
- package/dist/chunk-TLPR24DO.js +3 -0
- package/dist/chunk-TLPR24DO.js.map +1 -0
- package/dist/growthbook-NJGOOJH4.mjs +3 -0
- package/dist/growthbook-NJGOOJH4.mjs.map +1 -0
- package/dist/index.d.mts +114 -0
- package/dist/index.d.ts +114 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +4 -0
- package/dist/index.mjs.map +1 -0
- package/dist/metafile-cjs.json +1 -0
- package/dist/metafile-esm.json +1 -0
- package/dist/metafile-iife.json +1 -0
- package/dist/posthog-CY-D6TZM.d.mts +90 -0
- package/dist/posthog-D--oI2Yn.d.ts +90 -0
- package/dist/posthog-OIC32FZG.mjs +6 -0
- package/dist/posthog-OIC32FZG.mjs.map +1 -0
- package/dist/providers/growthbook/index.d.mts +73 -0
- package/dist/providers/growthbook/index.d.ts +73 -0
- package/dist/providers/growthbook/index.js +3 -0
- package/dist/providers/growthbook/index.js.map +1 -0
- package/dist/providers/growthbook/index.mjs +3 -0
- package/dist/providers/growthbook/index.mjs.map +1 -0
- package/dist/providers/posthog/index.d.mts +3 -0
- package/dist/providers/posthog/index.d.ts +3 -0
- package/dist/providers/posthog/index.js +3 -0
- package/dist/providers/posthog/index.js.map +1 -0
- package/dist/providers/posthog/index.mjs +3 -0
- package/dist/providers/posthog/index.mjs.map +1 -0
- package/dist/providers/rudderstack/index.d.mts +73 -0
- package/dist/providers/rudderstack/index.d.ts +73 -0
- package/dist/providers/rudderstack/index.js +2 -0
- package/dist/providers/rudderstack/index.js.map +1 -0
- package/dist/providers/rudderstack/index.mjs +2 -0
- package/dist/providers/rudderstack/index.mjs.map +1 -0
- package/{lib/types.d.ts → dist/types-DoMejCXv.d.mts} +18 -29
- package/dist/types-DoMejCXv.d.ts +361 -0
- package/dist/utils/analytics-cache/index.d.mts +138 -0
- package/dist/utils/analytics-cache/index.d.ts +138 -0
- package/dist/utils/analytics-cache/index.js +2 -0
- package/dist/utils/analytics-cache/index.js.map +1 -0
- package/dist/utils/analytics-cache/index.mjs +2 -0
- package/dist/utils/analytics-cache/index.mjs.map +1 -0
- package/package.json +97 -68
- package/dist/analytics.bundle.js +0 -1
- package/lib/analytics.d.ts +0 -66
- package/lib/analytics.js +0 -418
- package/lib/growthbook.d.ts +0 -29
- package/lib/growthbook.js +0 -144
- package/lib/index.d.ts +0 -2
- package/lib/index.js +0 -5
- package/lib/posthog.d.ts +0 -28
- package/lib/posthog.js +0 -154
- package/lib/rudderstack.d.ts +0 -23
- package/lib/rudderstack.js +0 -100
- package/lib/types.js +0 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/utils/cookie.ts","../src/utils/helpers.ts","../src/analytics.ts"],"names":["CACHE_COOKIE_EVENTS","CACHE_COOKIE_PAGES","cacheEventToCookie","eventName","properties","domain","getAllowedDomain","existingCache","Cookies","events","cookieOptions","err","cachePageViewToCookie","pageName","pages","getCachedEvents","storedEventsString","getCachedPageViews","storedPagesString","clearCachedEvents","clearCachedPageViews","isUUID","str","countryPromise","getCountry","cookieCountry","response","cloudflareTrace","text","v","cleanObject","obj","cleanedArr","cleaned","key","value","flattenObject","flattened","createAnalyticsInstance","_options","_growthbook","_rudderstack","_posthog","core_data","tracking_config","offline_event_cache","_pending_identify_calls","_cookie_cache_processed","processCookieCache","storedEvents","event","storedPages","page","getId","onSdkLoaded","userId","traits","initialise","growthbookKey","growthbookDecryptionKey","rudderstackKey","growthbookOptions","posthogOptions","_a","_b","country","RudderStack","attrs","anonymousId","anonId","Growthbook","interval","getFeatureValue","Posthog","setAttributes","user_language","device_language","device_type","account_type","user_id","anonymous_id","app_id","utm_source","utm_medium","utm_campaign","is_authorised","residence_country","url","geo_location","loggedIn","network_downlink","network_rtt","network_type","account_currency","account_mode","user_identity","config","getFeatureState","id","defaultValue","getGrowthbookStatus","isFeatureOn","setUrl","href","getAnonymousId","pageView","current_page","platform","identifyEvent","stored_user_id","hasProviderStructure","rudderstackTraits","posthogTraits","call","reset","isV2Payload","payload","AnalyticsInstance","analytics_data","final_payload","v2_data","hasRudderstackInitialized","cache","cleaned_cache_payload","cleaned_payload","flattened_payload","cleaned_posthog_payload","Analytics"],"mappings":"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","file":"index.mjs","sourcesContent":["import Cookies from 'js-cookie'\nimport { getAllowedDomain } from './urls'\n\nexport const CACHE_COOKIE_EVENTS = 'cached_analytics_events'\nexport const CACHE_COOKIE_PAGES = 'cached_analytics_page_views'\n\nexport type CachedEvent = {\n name: string\n properties: Record<string, unknown>\n timestamp: number\n}\n\nexport type CachedPageView = {\n name: string\n properties?: Record<string, unknown>\n timestamp: number\n}\n\nexport const cacheEventToCookie = (eventName: string, properties: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_EVENTS)\n const events: CachedEvent[] = existingCache ? JSON.parse(existingCache) : []\n events.push({ name: eventName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_EVENTS, JSON.stringify(events), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache event', err)\n }\n}\n\nexport const cachePageViewToCookie = (pageName: string, properties?: Record<string, unknown>): void => {\n try {\n const domain = getAllowedDomain()\n const existingCache = Cookies.get(CACHE_COOKIE_PAGES)\n const pages: CachedPageView[] = existingCache ? JSON.parse(existingCache) : []\n pages.push({ name: pageName, properties, timestamp: Date.now() })\n const cookieOptions: Cookies.CookieAttributes = { expires: 1 }\n if (domain) cookieOptions.domain = domain\n Cookies.set(CACHE_COOKIE_PAGES, JSON.stringify(pages), cookieOptions)\n } catch (err) {\n console.warn('Analytics: Failed to cache page view', err)\n }\n}\n\nexport const getCachedEvents = (): CachedEvent[] => {\n try {\n const storedEventsString = Cookies.get(CACHE_COOKIE_EVENTS)\n if (storedEventsString) {\n const events = JSON.parse(storedEventsString)\n return Array.isArray(events) ? events : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached events', err)\n }\n return []\n}\n\nexport const getCachedPageViews = (): CachedPageView[] => {\n try {\n const storedPagesString = Cookies.get(CACHE_COOKIE_PAGES)\n if (storedPagesString) {\n const pages = JSON.parse(storedPagesString)\n return Array.isArray(pages) ? pages : []\n }\n } catch (err) {\n console.warn('Analytics: Failed to get cached pages', err)\n }\n return []\n}\n\nexport const clearCachedEvents = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_EVENTS, cookieOptions)\n}\n\nexport const clearCachedPageViews = (): void => {\n const domain = getAllowedDomain()\n const cookieOptions = domain ? { domain } : {}\n Cookies.remove(CACHE_COOKIE_PAGES, cookieOptions)\n}\n","import Cookies from 'js-cookie'\nimport { cloudflareTrace } from './urls'\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 cleanedArr = obj.map(cleanObject).filter(v => v !== undefined && v !== null)\n return cleanedArr.length ? cleanedArr : undefined\n }\n\n const cleaned: Record<string, any> = {}\n Object.entries(obj).forEach(([key, value]) => {\n const v = cleanObject(value)\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 return\n }\n\n cleaned[key] = v\n })\n\n return Object.keys(cleaned).length ? 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 */\nexport const flattenObject = (obj: any): Record<string, any> => {\n if (obj == null || typeof obj !== 'object' || Array.isArray(obj)) {\n return obj\n }\n\n const flattened: Record<string, any> = {}\n\n Object.entries(obj).forEach(([key, value]) => {\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n // Recursively flatten nested objects and merge them at the top level\n Object.assign(flattened, flattenObject(value))\n } else {\n flattened[key] = value\n }\n })\n\n return flattened\n}\n","import { RudderStack } from './providers/rudderstack'\nimport type { TCoreAttributes, TAllEvents, TV2EventPayload } from './types'\nimport {\n cacheEventToCookie,\n cachePageViewToCookie,\n getCachedEvents,\n getCachedPageViews,\n clearCachedEvents,\n clearCachedPageViews,\n} from './utils/cookie'\nimport { isUUID, getCountry, cleanObject, flattenObject } from './utils/helpers'\n\n// Optional Growthbook types - only import if using Growthbook\nimport type { Growthbook, GrowthbookConfigs } from './providers/growthbook'\nimport type { TGrowthbookAttributes, TGrowthbookOptions } from './providers/growthbookTypes'\n\n// Optional Posthog types - only import if using Posthog\nimport type { Posthog } from './providers/posthog'\nimport type { TPosthogOptions } from './providers/posthogTypes'\n\ndeclare global {\n interface Window {\n AnalyticsInstance: ReturnType<typeof createAnalyticsInstance>\n }\n}\n\n/**\n * Configuration options for initializing the analytics instance\n */\ntype Options = {\n /** GrowthBook client API key for A/B testing and feature flags */\n growthbookKey?: string\n /** GrowthBook decryption key for encrypted feature payloads */\n growthbookDecryptionKey?: string\n /** RudderStack write key for event tracking */\n rudderstackKey?: string\n /** Additional configuration options for GrowthBook */\n growthbookOptions?: TGrowthbookOptions\n /** PostHog configuration options including API keys and settings */\n posthogOptions?: TPosthogOptions\n}\n\n/**\n * Creates a unified analytics instance that integrates RudderStack and GrowthBook.\n *\n * This function provides a centralized interface for:\n * - Event tracking across multiple analytics platforms\n * - A/B testing and feature flag management via GrowthBook\n * - Offline event caching with automatic replay\n *\n * @param {Options} _options - Optional initialization configuration\n * @returns {Object} Analytics instance with methods for tracking, identification, and feature management\n *\n * @example\n * ```typescript\n * const analytics = createAnalyticsInstance();\n *\n * // Initialize with providers\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY'\n * });\n *\n * // Set user attributes\n * analytics.setAttributes({\n * user_id: 'user123',\n * country: 'US',\n * user_language: 'en'\n * });\n *\n * // Track events\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // Track page views\n * analytics.pageView('/dashboard', 'Deriv App');\n * ```\n */\nexport function createAnalyticsInstance(_options?: Options) {\n let _growthbook: Growthbook | undefined,\n _rudderstack: RudderStack,\n _posthog: Posthog | undefined,\n core_data: Partial<TCoreAttributes> = {},\n tracking_config: { [key: string]: boolean } = {},\n offline_event_cache: Array<{ event: keyof TAllEvents; payload: TAllEvents[keyof TAllEvents] }> = [],\n _pending_identify_calls: Array<{ userId: string; traits?: Record<string, any> }> = [],\n _cookie_cache_processed = false\n\n const processCookieCache = () => {\n if (_cookie_cache_processed) return\n if (!_rudderstack?.has_initialized) return\n\n _cookie_cache_processed = true\n\n try {\n const storedEvents = getCachedEvents()\n if (storedEvents.length > 0) {\n storedEvents.forEach(event => {\n _rudderstack?.track(event.name as keyof TAllEvents, event.properties as any)\n })\n clearCachedEvents()\n }\n\n const storedPages = getCachedPageViews()\n if (storedPages.length > 0) {\n storedPages.forEach(page => {\n _rudderstack?.pageView(page.name, 'Deriv App', getId(), page.properties)\n })\n clearCachedPageViews()\n }\n } catch (err) {\n console.warn('Analytics: Failed to process cookie cache', err)\n }\n }\n\n const onSdkLoaded = () => {\n processCookieCache()\n\n _pending_identify_calls.forEach(({ userId, traits }) => {\n if (userId) {\n _rudderstack?.identifyEvent(userId, traits)\n }\n })\n _pending_identify_calls = []\n }\n\n /**\n * Initializes the analytics instance with specified provider configurations.\n * This method should be called before tracking any events.\n *\n * Features:\n * - Lazy-loads providers (GrowthBook, PostHog) only when configured\n * - Automatically fetches user's country for GrowthBook targeting\n * - Processes any cached events from previous sessions\n * - Sets up event tracking callback for GrowthBook experiments\n *\n * @param {Options} options - Configuration options for analytics providers\n * @returns {Promise<void>} Resolves when initialization is complete\n *\n * @example\n * ```typescript\n * await analytics.initialise({\n * rudderstackKey: 'YOUR_RS_KEY',\n * growthbookKey: 'YOUR_GB_KEY',\n * growthbookDecryptionKey: 'YOUR_GB_DECRYPT_KEY',\n * posthogOptions: {\n * apiKey: 'YOUR_POSTHOG_API_KEY',\n * config: {\n * session_recording: {\n * recordCrossOriginIframes: true,\n * minimumDurationMilliseconds: 30000\n * }\n * }\n * }\n * });\n * ```\n */\n const initialise = async ({\n growthbookKey,\n growthbookDecryptionKey,\n rudderstackKey,\n growthbookOptions,\n posthogOptions,\n }: Options) => {\n try {\n // Only fetch country if GrowthBook is enabled and country not provided\n const country = growthbookOptions?.attributes?.country || (growthbookKey ? await getCountry() : undefined)\n\n if (rudderstackKey) {\n _rudderstack = RudderStack.getRudderStackInstance(rudderstackKey, onSdkLoaded)\n }\n\n if (growthbookOptions?.attributes && Object.keys(growthbookOptions.attributes).length > 0) {\n const attrs = growthbookOptions.attributes\n const anonymousId = _rudderstack?.getAnonymousId()\n\n core_data = {\n ...core_data,\n country,\n ...(attrs.user_language && { user_language: attrs.user_language }),\n ...(attrs.account_type && { account_type: attrs.account_type }),\n ...(attrs.app_id && { app_id: attrs.app_id }),\n ...(attrs.residence_country && { residence_country: attrs.residence_country }),\n ...(attrs.device_type && { device_type: attrs.device_type }),\n ...(attrs.url && { url: attrs.url }),\n ...(attrs.email_hash && { email_hash: attrs.email_hash }),\n ...(attrs.network_type && { network_type: attrs.network_type }),\n ...(attrs.network_rtt && { network_rtt: attrs.network_rtt }),\n ...(attrs.network_downlink && { network_downlink: attrs.network_downlink }),\n ...(attrs.account_currency && { account_currency: attrs.account_currency }),\n ...(attrs.account_mode && { account_mode: attrs.account_mode }),\n loggedIn: !!attrs.loggedIn,\n ...(attrs.user_id && !isUUID(attrs.user_id) && { user_id: attrs.user_id }),\n ...(anonymousId && { anonymous_id: anonymousId }),\n }\n }\n\n growthbookOptions ??= {}\n growthbookOptions.attributes ??= {}\n const anonId = _rudderstack?.getAnonymousId()\n growthbookOptions.attributes.id ??= anonId\n growthbookOptions.attributes.country ??= country\n\n if (growthbookKey) {\n // Dynamically import Growthbook only when needed\n const { Growthbook } = await import('./providers/growthbook')\n _growthbook = Growthbook.getGrowthBookInstance(\n growthbookKey,\n growthbookDecryptionKey,\n growthbookOptions\n )\n\n const interval = setInterval(() => {\n if (Object.keys(tracking_config).length > 0) clearInterval(interval)\n else tracking_config = getFeatureValue('tracking-buttons-config', {}) as { [key: string]: boolean }\n }, 1000)\n }\n\n if (posthogOptions) {\n // Dynamically import Posthog only when needed\n const { Posthog } = await import('./providers/posthog')\n _posthog = Posthog.getPosthogInstance(posthogOptions)\n }\n } catch (err) {\n console.warn('Analytics: Failed to initialize', err)\n }\n }\n\n /**\n * Sets user and context attributes for analytics tracking and targeting.\n * These attributes are automatically included in all subsequent events.\n *\n * Attributes are used for:\n * - Event enrichment (added to all tracked events)\n * - GrowthBook targeting (feature flags and A/B tests)\n * - User segmentation across analytics platforms\n *\n * @param {TCoreAttributes} attributes - User and context attributes\n *\n * @example\n * ```typescript\n * analytics.setAttributes({\n * user_id: 'CR123456',\n * country: 'US',\n * user_language: 'en',\n * device_type: 'desktop',\n * account_type: 'real',\n * loggedIn: true\n * });\n * ```\n */\n const setAttributes = ({\n country,\n user_language,\n device_language,\n device_type,\n account_type,\n user_id,\n anonymous_id,\n app_id,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n residence_country,\n url,\n domain,\n geo_location,\n loggedIn,\n network_downlink,\n network_rtt,\n network_type,\n account_currency,\n account_mode,\n }: TCoreAttributes) => {\n const user_identity = user_id ?? getId()\n\n if (_growthbook) {\n const config: TGrowthbookAttributes = {\n country,\n residence_country,\n user_language,\n device_language,\n device_type,\n utm_source,\n utm_medium,\n utm_campaign,\n is_authorised,\n url,\n domain,\n loggedIn,\n ...(user_id && !isUUID(user_id) && { user_id }),\n anonymous_id,\n }\n if (user_identity) {\n config.id = user_identity\n config.user_id = user_identity\n }\n _growthbook.setAttributes(config)\n }\n\n core_data = {\n ...core_data,\n ...(country !== undefined && { country }),\n ...(geo_location !== undefined && { geo_location }),\n ...(user_language !== undefined && { user_language }),\n ...(account_type !== undefined && { account_type }),\n ...(app_id !== undefined && { app_id }),\n ...(residence_country !== undefined && { residence_country }),\n ...(device_type !== undefined && { device_type }),\n ...(url !== undefined && { url }),\n ...(loggedIn !== undefined && { loggedIn }),\n ...(network_downlink !== undefined && { network_downlink }),\n ...(network_rtt !== undefined && { network_rtt }),\n ...(network_type !== undefined && { network_type }),\n ...(user_id !== undefined && !isUUID(user_id) && { user_id }),\n ...(anonymous_id !== undefined && { anonymous_id }),\n ...(account_currency !== undefined && { account_currency }),\n ...(account_mode !== undefined && { account_mode }),\n }\n }\n\n const getFeatureState = (id: string) => _growthbook?.getFeatureState(id)?.experimentResult?.name\n\n const getFeatureValue = <K extends keyof GrowthbookConfigs, V extends GrowthbookConfigs[K]>(\n id: K,\n defaultValue: V\n ) => _growthbook?.getFeatureValue(id as string, defaultValue)\n\n const getGrowthbookStatus = async () => await _growthbook?.getStatus()\n const isFeatureOn = (key: string) => _growthbook?.isOn(key)\n const setUrl = (href: string) => _growthbook?.setUrl(href)\n\n const getId = () => {\n const userId = _rudderstack?.getUserId() || ''\n return userId && !isUUID(userId) ? userId : ''\n }\n\n const getAnonymousId = () => _rudderstack?.getAnonymousId() || ''\n\n /**\n * Tracks a page view event.\n *\n * Features:\n * - Automatically includes user ID if available\n * - Caches page views when offline or provider not initialized\n *\n * @param {string} current_page - The current page URL or path\n * @param {string} [platform='Deriv App'] - The platform name\n * @param {Record<string, unknown>} [properties] - Additional page properties\n *\n * @example\n * ```typescript\n * analytics.pageView('/dashboard');\n * analytics.pageView('/trade', 'Deriv Trader', { section: 'multipliers' });\n * ```\n */\n const pageView = (current_page: string, platform = 'Deriv App', properties?: Record<string, unknown>) => {\n const userId = getId()\n\n // Handle RudderStack pageView independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n _rudderstack.pageView(current_page, platform, userId, properties)\n } else {\n cachePageViewToCookie(current_page, { platform, ...properties })\n }\n }\n\n // PostHog handles page views automatically via autocapture\n // No need to manually send page views to PostHog\n }\n\n /**\n * Identifies a user across analytics platforms.\n * This method should be called after user login or when user identity is known.\n *\n * Features:\n * - Queues identify calls if provider not yet initialized\n * - Allows custom traits for each provider or shared traits for both\n * - Identifies user in PostHog if configured\n *\n * @param {string} [user_id] - The user ID to identify. If not provided, uses stored user ID\n * @param {Record<string, any>} [traits] - Optional traits to send to both providers, or provider-specific traits\n *\n * @example\n * ```typescript\n * // Simple identify\n * analytics.identifyEvent('CR123456');\n *\n * // Identify with same traits for both providers\n * analytics.identifyEvent('CR123456', {\n * language: 'en',\n * country_of_residence: 'US'\n * });\n *\n * // Identify with provider-specific traits\n * analytics.identifyEvent('CR123456', {\n * rudderstack: { language: 'en', custom_field: 'value' },\n * posthog: { language: 'en', country_of_residence: 'US' }\n * });\n * ```\n */\n const identifyEvent = (user_id?: string, traits?: Record<string, any>) => {\n const stored_user_id = user_id || getId()\n if (!stored_user_id) return\n\n // Check if traits has provider-specific structure\n const hasProviderStructure = traits?.rudderstack !== undefined || traits?.posthog !== undefined\n const rudderstackTraits = hasProviderStructure ? traits?.rudderstack : traits\n const posthogTraits = hasProviderStructure ? traits?.posthog : traits\n\n // Handle RudderStack identification independently\n if (_rudderstack) {\n if (_rudderstack.has_initialized) {\n _rudderstack.identifyEvent(stored_user_id, rudderstackTraits)\n } else {\n if (!_pending_identify_calls.some(call => call.userId === stored_user_id)) {\n _pending_identify_calls.push({ userId: stored_user_id, traits: rudderstackTraits })\n }\n }\n }\n\n // Handle PostHog identification independently\n if (_posthog?.has_initialized) {\n _posthog.identifyEvent(stored_user_id, posthogTraits)\n }\n }\n\n const reset = () => {\n // Reset each provider independently\n if (_rudderstack?.has_initialized) {\n _rudderstack.reset()\n }\n if (_posthog?.has_initialized) {\n _posthog.reset()\n }\n }\n\n const isV2Payload = (payload: any): payload is TV2EventPayload => {\n return 'event_metadata' in payload || 'cta_information' in payload || 'error' in payload\n }\n\n /**\n * Tracks a custom event with associated data.\n *\n * Features:\n * - Automatically enriches events with core attributes\n * - Supports both V1 and V2 event payload formats\n * - RudderStack: Caches events when offline or not initialized\n * - PostHog: Sends immediately if initialized (has built-in caching)\n * - Respects feature flag configurations\n * - Each provider works independently - one failing won't affect the other\n *\n * @template T - The event name type from TAllEvents\n * @param {T} event - The event name to track\n * @param {TAllEvents[T]} analytics_data - The event data payload\n *\n * @example\n * ```typescript\n * // Simple event\n * analytics.trackEvent('button_clicked', { button_name: 'signup' });\n *\n * // V2 event with metadata\n * analytics.trackEvent('form_submitted', {\n * event_metadata: { form_name: 'registration' },\n * cta_information: { button_text: 'Create Account' }\n * });\n * ```\n */\n const trackEvent = <T extends keyof TAllEvents>(event: T, analytics_data: TAllEvents[T]) => {\n const userId = getId()\n let final_payload: any = {}\n\n if (isV2Payload(analytics_data)) {\n const v2_data = analytics_data as TV2EventPayload\n final_payload = {\n ...v2_data,\n event_metadata: {\n ...core_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n ...v2_data.event_metadata,\n },\n }\n } else {\n final_payload = {\n ...core_data,\n ...analytics_data,\n ...(userId && !core_data.user_id && { user_id: userId }),\n }\n }\n\n const shouldTrack = !(event in tracking_config) || tracking_config[event as string]\n if (!shouldTrack) return\n\n // Handle RudderStack independently\n const hasRudderstackInitialized = _rudderstack?.has_initialized\n if (!navigator.onLine || !hasRudderstackInitialized) {\n if (!hasRudderstackInitialized) {\n cacheEventToCookie(event as string, final_payload)\n } else {\n offline_event_cache.push({ event, payload: final_payload })\n }\n } else {\n // Send cached events to RudderStack\n if (offline_event_cache.length > 0) {\n offline_event_cache.forEach(cache => {\n const cleaned_cache_payload = cleanObject(cache.payload)\n _rudderstack?.track(cache.event, cleaned_cache_payload)\n })\n offline_event_cache = []\n }\n\n // Send current event to RudderStack\n const cleaned_payload = cleanObject(final_payload)\n _rudderstack?.track(event, cleaned_payload)\n }\n\n // Handle PostHog independently - send immediately if initialized\n if (_posthog?.has_initialized) {\n const flattened_payload = flattenObject(final_payload)\n const cleaned_posthog_payload = cleanObject(flattened_payload)\n _posthog.capture(event as string, cleaned_posthog_payload)\n }\n }\n\n const getInstances = () => ({ ab: _growthbook, tracking: _rudderstack, posthog: _posthog })\n\n const AnalyticsInstance = {\n initialise,\n setAttributes,\n identifyEvent,\n getFeatureState,\n getFeatureValue,\n getGrowthbookStatus,\n isFeatureOn,\n setUrl,\n getId,\n getAnonymousId,\n trackEvent,\n getInstances,\n pageView,\n reset,\n }\n\n if (typeof window !== 'undefined') {\n window.AnalyticsInstance = AnalyticsInstance\n }\n\n return AnalyticsInstance\n}\n\nexport const Analytics = createAnalyticsInstance()\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"inputs":{"node_modules/tsup/assets/cjs_shims.js":{"bytes":569,"imports":[],"format":"esm"},"src/utils/urls.ts":{"bytes":730,"imports":[{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/providers/rudderstack.ts":{"bytes":6957,"imports":[{"path":"@rudderstack/analytics-js","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/utils/cookie.ts":{"bytes":2956,"imports":[{"path":"js-cookie","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/utils/helpers.ts":{"bytes":4070,"imports":[{"path":"js-cookie","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/providers/growthbook.ts":{"bytes":6572,"imports":[{"path":"@growthbook/growthbook","kind":"import-statement","external":true},{"path":"@rudderstack/analytics-js","kind":"import-statement","external":true},{"path":"./growthbookTypes","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/providers/posthog.ts":{"bytes":5108,"imports":[{"path":"posthog-js","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/analytics.ts":{"bytes":20464,"imports":[{"path":"src/providers/rudderstack.ts","kind":"import-statement","original":"./providers/rudderstack"},{"path":"src/utils/cookie.ts","kind":"import-statement","original":"./utils/cookie"},{"path":"src/utils/helpers.ts","kind":"import-statement","original":"./utils/helpers"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true},{"path":"src/providers/growthbook.ts","kind":"dynamic-import","original":"./providers/growthbook"},{"path":"src/providers/posthog.ts","kind":"dynamic-import","original":"./providers/posthog"}],"format":"esm"},"src/utils/analytics-cache.ts":{"bytes":14873,"imports":[{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"},"src/index.ts":{"bytes":138,"imports":[{"path":"src/analytics.ts","kind":"import-statement","original":"./analytics"},{"path":"src/utils/analytics-cache.ts","kind":"import-statement","original":"./utils/analytics-cache"},{"path":"/home/runner/work/deriv-analytics/deriv-analytics/node_modules/tsup/assets/cjs_shims.js","kind":"import-statement","external":true}],"format":"esm"}},"outputs":{"dist/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":39388},"dist/index.js":{"imports":[{"path":"dist/chunk-TLPR24DO.js","kind":"import-statement"},{"path":"dist/chunk-NOEKD4DT.js","kind":"import-statement"},{"path":"dist/chunk-LKLVBL24.js","kind":"import-statement"},{"path":"js-cookie","kind":"import-statement","external":true},{"path":"js-cookie","kind":"import-statement","external":true},{"path":"dist/providers/growthbook/index.js","kind":"dynamic-import"},{"path":"dist/providers/posthog/index.js","kind":"dynamic-import"}],"exports":["Analytics","cacheTrackEvents"],"entryPoint":"src/index.ts","inputs":{"src/utils/cookie.ts":{"bytesInOutput":972},"src/utils/helpers.ts":{"bytesInOutput":985},"src/analytics.ts":{"bytesInOutput":4503},"src/index.ts":{"bytesInOutput":0}},"bytes":6695},"dist/providers/growthbook/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":10284},"dist/providers/growthbook/index.js":{"imports":[{"path":"dist/chunk-NOEKD4DT.js","kind":"import-statement"},{"path":"@growthbook/growthbook","kind":"import-statement","external":true},{"path":"@rudderstack/analytics-js","kind":"import-statement","external":true}],"exports":["Growthbook"],"entryPoint":"src/providers/growthbook.ts","inputs":{"src/providers/growthbook.ts":{"bytesInOutput":2835}},"bytes":2963},"dist/providers/rudderstack/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":93},"dist/providers/rudderstack/index.js":{"imports":[{"path":"dist/chunk-TLPR24DO.js","kind":"import-statement"},{"path":"dist/chunk-NOEKD4DT.js","kind":"import-statement"}],"exports":["RudderStack"],"entryPoint":"src/providers/rudderstack.ts","inputs":{},"bytes":156},"dist/chunk-TLPR24DO.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":9651},"dist/chunk-TLPR24DO.js":{"imports":[{"path":"dist/chunk-NOEKD4DT.js","kind":"import-statement"},{"path":"@rudderstack/analytics-js","kind":"import-statement","external":true}],"exports":["a"],"inputs":{"src/providers/rudderstack.ts":{"bytesInOutput":2300}},"bytes":2415},"dist/providers/posthog/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":7089},"dist/providers/posthog/index.js":{"imports":[{"path":"dist/chunk-NOEKD4DT.js","kind":"import-statement"},{"path":"posthog-js","kind":"import-statement","external":true}],"exports":["Posthog"],"entryPoint":"src/providers/posthog.ts","inputs":{"src/providers/posthog.ts":{"bytesInOutput":1324}},"bytes":1458},"dist/chunk-NOEKD4DT.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":1338},"dist/chunk-NOEKD4DT.js":{"imports":[],"exports":["a","b","c","d","e","f","g"],"inputs":{"src/utils/urls.ts":{"bytesInOutput":396}},"bytes":513},"dist/utils/analytics-cache/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":93},"dist/utils/analytics-cache/index.js":{"imports":[{"path":"dist/chunk-LKLVBL24.js","kind":"import-statement"}],"exports":["cacheTrackEvents"],"entryPoint":"src/utils/analytics-cache.ts","inputs":{},"bytes":129},"dist/chunk-LKLVBL24.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":21937},"dist/chunk-LKLVBL24.js":{"imports":[],"exports":["a"],"inputs":{"src/utils/analytics-cache.ts":{"bytesInOutput":4793}},"bytes":4868}}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"inputs":{"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs":{"bytes":263304,"imports":[{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/utils/urls.ts":{"bytes":730,"imports":[],"format":"esm"},"src/providers/rudderstack.ts":{"bytes":6957,"imports":[{"path":"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs","kind":"import-statement","original":"@rudderstack/analytics-js"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"node_modules/js-cookie/dist/js.cookie.mjs":{"bytes":3475,"imports":[],"format":"esm"},"src/utils/cookie.ts":{"bytes":2956,"imports":[{"path":"node_modules/js-cookie/dist/js.cookie.mjs","kind":"import-statement","original":"js-cookie"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"}],"format":"esm"},"src/utils/helpers.ts":{"bytes":4070,"imports":[{"path":"node_modules/js-cookie/dist/js.cookie.mjs","kind":"import-statement","original":"js-cookie"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"}],"format":"esm"},"src/providers/growthbook.ts":{"bytes":6572,"imports":[{"path":"@growthbook/growthbook","kind":"import-statement","external":true},{"path":"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs","kind":"import-statement","original":"@rudderstack/analytics-js"},{"path":"./growthbookTypes","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"node_modules/posthog-js/dist/module.js":{"bytes":177040,"imports":[],"format":"esm"},"src/providers/posthog.ts":{"bytes":5108,"imports":[{"path":"node_modules/posthog-js/dist/module.js","kind":"import-statement","original":"posthog-js"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"src/analytics.ts":{"bytes":20464,"imports":[{"path":"src/providers/rudderstack.ts","kind":"import-statement","original":"./providers/rudderstack"},{"path":"src/utils/cookie.ts","kind":"import-statement","original":"./utils/cookie"},{"path":"src/utils/helpers.ts","kind":"import-statement","original":"./utils/helpers"},{"path":"src/providers/growthbook.ts","kind":"dynamic-import","original":"./providers/growthbook"},{"path":"src/providers/posthog.ts","kind":"dynamic-import","original":"./providers/posthog"}],"format":"esm"},"src/utils/analytics-cache.ts":{"bytes":14873,"imports":[],"format":"esm"},"src/index.ts":{"bytes":138,"imports":[{"path":"src/analytics.ts","kind":"import-statement","original":"./analytics"},{"path":"src/utils/analytics-cache.ts","kind":"import-statement","original":"./utils/analytics-cache"}],"format":"esm"}},"outputs":{"dist/browser/analytics.esm.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":76478},"dist/browser/analytics.esm.mjs":{"imports":[{"path":"dist/chunk-EMF3RT6E.mjs","kind":"import-statement"},{"path":"dist/chunk-HQX3Z7PF.mjs","kind":"import-statement"},{"path":"dist/growthbook-NJGOOJH4.mjs","kind":"dynamic-import"},{"path":"dist/posthog-OIC32FZG.mjs","kind":"dynamic-import"}],"exports":["Analytics","cacheTrackEvents"],"entryPoint":"src/index.ts","inputs":{"src/providers/rudderstack.ts":{"bytesInOutput":2243},"node_modules/js-cookie/dist/js.cookie.mjs":{"bytesInOutput":1375},"src/utils/cookie.ts":{"bytesInOutput":953},"src/utils/helpers.ts":{"bytesInOutput":959},"src/analytics.ts":{"bytesInOutput":4496},"src/index.ts":{"bytesInOutput":0},"src/utils/analytics-cache.ts":{"bytesInOutput":4793}},"bytes":15154},"dist/growthbook-NJGOOJH4.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":10234},"dist/growthbook-NJGOOJH4.mjs":{"imports":[{"path":"dist/chunk-EMF3RT6E.mjs","kind":"import-statement"},{"path":"dist/chunk-HQX3Z7PF.mjs","kind":"import-statement"},{"path":"@growthbook/growthbook","kind":"import-statement","external":true}],"exports":["Growthbook"],"entryPoint":"src/providers/growthbook.ts","inputs":{"src/providers/growthbook.ts":{"bytesInOutput":2775}},"bytes":2972},"dist/chunk-EMF3RT6E.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":423192},"dist/chunk-EMF3RT6E.mjs":{"imports":[{"path":"dist/chunk-HQX3Z7PF.mjs","kind":"import-statement"}],"exports":["a"],"inputs":{"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs":{"bytesInOutput":112434}},"bytes":112582},"dist/posthog-OIC32FZG.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":1026056},"dist/posthog-OIC32FZG.mjs":{"imports":[{"path":"dist/chunk-HQX3Z7PF.mjs","kind":"import-statement"}],"exports":["Posthog"],"entryPoint":"src/providers/posthog.ts","inputs":{"node_modules/posthog-js/dist/module.js":{"bytesInOutput":174141},"src/providers/posthog.ts":{"bytesInOutput":1317}},"bytes":175629},"dist/chunk-HQX3Z7PF.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":1339},"dist/chunk-HQX3Z7PF.mjs":{"imports":[],"exports":["a","b","c","d","e","f","g","h"],"inputs":{"src/utils/urls.ts":{"bytesInOutput":396}},"bytes":715}}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"inputs":{"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs":{"bytes":263304,"imports":[{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/utils/urls.ts":{"bytes":730,"imports":[],"format":"esm"},"src/providers/rudderstack.ts":{"bytes":6957,"imports":[{"path":"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs","kind":"import-statement","original":"@rudderstack/analytics-js"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"node_modules/js-cookie/dist/js.cookie.mjs":{"bytes":3475,"imports":[],"format":"esm"},"src/utils/cookie.ts":{"bytes":2956,"imports":[{"path":"node_modules/js-cookie/dist/js.cookie.mjs","kind":"import-statement","original":"js-cookie"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"}],"format":"esm"},"src/utils/helpers.ts":{"bytes":4070,"imports":[{"path":"node_modules/js-cookie/dist/js.cookie.mjs","kind":"import-statement","original":"js-cookie"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"./urls"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/util.mjs":{"bytes":9941,"imports":[],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/feature-repository.mjs":{"bytes":13664,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"}],"format":"esm"},"node_modules/dom-mutator/dist/dom-mutator.esm.js":{"bytes":14835,"imports":[],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/mongrule.mjs":{"bytes":7849,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/core.mjs":{"bytes":30540,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/mongrule.mjs","kind":"import-statement","original":"./mongrule.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/GrowthBook.mjs":{"bytes":26103,"imports":[{"path":"node_modules/dom-mutator/dist/dom-mutator.esm.js","kind":"import-statement","original":"dom-mutator"},{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/feature-repository.mjs","kind":"import-statement","original":"./feature-repository.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/core.mjs","kind":"import-statement","original":"./core.mjs"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/GrowthBookClient.mjs":{"bytes":8903,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/feature-repository.mjs","kind":"import-statement","original":"./feature-repository.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/core.mjs","kind":"import-statement","original":"./core.mjs"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/sticky-bucket-service.mjs":{"bytes":6878,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/core.mjs","kind":"import-statement","original":"./core.mjs"}],"format":"esm"},"node_modules/@growthbook/growthbook/dist/esm/index.mjs":{"bytes":789,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/feature-repository.mjs","kind":"import-statement","original":"./feature-repository.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/GrowthBook.mjs","kind":"import-statement","original":"./GrowthBook.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/GrowthBookClient.mjs","kind":"import-statement","original":"./GrowthBookClient.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/sticky-bucket-service.mjs","kind":"import-statement","original":"./sticky-bucket-service.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/mongrule.mjs","kind":"import-statement","original":"./mongrule.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/util.mjs","kind":"import-statement","original":"./util.mjs"},{"path":"node_modules/@growthbook/growthbook/dist/esm/core.mjs","kind":"import-statement","original":"./core.mjs"}],"format":"esm"},"src/providers/growthbook.ts":{"bytes":6572,"imports":[{"path":"node_modules/@growthbook/growthbook/dist/esm/index.mjs","kind":"import-statement","original":"@growthbook/growthbook"},{"path":"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs","kind":"import-statement","original":"@rudderstack/analytics-js"},{"path":"./growthbookTypes","kind":"import-statement","external":true},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"node_modules/posthog-js/dist/module.js":{"bytes":177040,"imports":[],"format":"esm"},"src/providers/posthog.ts":{"bytes":5108,"imports":[{"path":"node_modules/posthog-js/dist/module.js","kind":"import-statement","original":"posthog-js"},{"path":"src/utils/urls.ts","kind":"import-statement","original":"../utils/urls"}],"format":"esm"},"src/analytics.ts":{"bytes":20464,"imports":[{"path":"src/providers/rudderstack.ts","kind":"import-statement","original":"./providers/rudderstack"},{"path":"src/utils/cookie.ts","kind":"import-statement","original":"./utils/cookie"},{"path":"src/utils/helpers.ts","kind":"import-statement","original":"./utils/helpers"},{"path":"src/providers/growthbook.ts","kind":"dynamic-import","original":"./providers/growthbook"},{"path":"src/providers/posthog.ts","kind":"dynamic-import","original":"./providers/posthog"}],"format":"esm"},"src/utils/analytics-cache.ts":{"bytes":14873,"imports":[],"format":"esm"},"src/index.ts":{"bytes":138,"imports":[{"path":"src/analytics.ts","kind":"import-statement","original":"./analytics"},{"path":"src/utils/analytics-cache.ts","kind":"import-statement","original":"./utils/analytics-cache"}],"format":"esm"}},"outputs":{"dist/browser/analytics.bundle.global.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":1741324},"dist/browser/analytics.bundle.global.js":{"imports":[],"exports":[],"entryPoint":"src/index.ts","inputs":{"node_modules/@rudderstack/analytics-js/dist/npm/modern/esm/index.mjs":{"bytesInOutput":114110},"src/utils/urls.ts":{"bytesInOutput":451},"node_modules/@growthbook/growthbook/dist/esm/util.mjs":{"bytesInOutput":3635},"node_modules/@growthbook/growthbook/dist/esm/feature-repository.mjs":{"bytesInOutput":5508},"node_modules/dom-mutator/dist/dom-mutator.esm.js":{"bytesInOutput":6145},"node_modules/@growthbook/growthbook/dist/esm/mongrule.mjs":{"bytesInOutput":2996},"node_modules/@growthbook/growthbook/dist/esm/core.mjs":{"bytesInOutput":10937},"node_modules/@growthbook/growthbook/dist/esm/GrowthBook.mjs":{"bytesInOutput":14677},"node_modules/@growthbook/growthbook/dist/esm/index.mjs":{"bytesInOutput":35},"src/providers/growthbook.ts":{"bytesInOutput":2820},"node_modules/posthog-js/dist/module.js":{"bytesInOutput":175297},"src/providers/posthog.ts":{"bytesInOutput":1389},"src/index.ts":{"bytesInOutput":60},"src/providers/rudderstack.ts":{"bytesInOutput":2263},"node_modules/js-cookie/dist/js.cookie.mjs":{"bytesInOutput":1385},"src/utils/cookie.ts":{"bytesInOutput":980},"src/utils/helpers.ts":{"bytesInOutput":977},"src/analytics.ts":{"bytesInOutput":4584},"src/utils/analytics-cache.ts":{"bytesInOutput":4798}},"bytes":353897}}}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { PostHogConfig, SessionRecordingOptions } from 'posthog-js';
|
|
2
|
+
import { T as TCoreAttributes } from './types-DoMejCXv.mjs';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Extended SessionRecordingOptions to allow additional custom properties
|
|
6
|
+
*/
|
|
7
|
+
type TExtendedSessionRecordingOptions = SessionRecordingOptions & {
|
|
8
|
+
minimumDurationMilliseconds?: number;
|
|
9
|
+
[key: string]: any;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Partial version of PostHog configuration to allow flexible initialization
|
|
13
|
+
* All properties from the official PostHogConfig are optional
|
|
14
|
+
* Extends session_recording to support additional properties
|
|
15
|
+
*/
|
|
16
|
+
type TPosthogConfig = Partial<Omit<PostHogConfig, 'session_recording'>> & {
|
|
17
|
+
session_recording?: Partial<TExtendedSessionRecordingOptions>;
|
|
18
|
+
};
|
|
19
|
+
type TPosthogIdentifyTraits = {
|
|
20
|
+
language?: string;
|
|
21
|
+
country_of_residence?: string;
|
|
22
|
+
[key: string]: any;
|
|
23
|
+
};
|
|
24
|
+
type TPosthogOptions = {
|
|
25
|
+
/**
|
|
26
|
+
* PostHog API key
|
|
27
|
+
*/
|
|
28
|
+
apiKey: string;
|
|
29
|
+
/**
|
|
30
|
+
* PostHog configuration options
|
|
31
|
+
* Allows customization of PostHog behavior, session recording, etc.
|
|
32
|
+
*/
|
|
33
|
+
config?: TPosthogConfig;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* PostHog analytics wrapper with singleton pattern.
|
|
38
|
+
* Provides optional PostHog integration for event tracking and session recording.
|
|
39
|
+
*
|
|
40
|
+
* Features:
|
|
41
|
+
* - Dynamically loads PostHog SDK on demand
|
|
42
|
+
* - Domain allowlisting for security
|
|
43
|
+
* - Automatic user identification and aliasing
|
|
44
|
+
* - Custom event tracking with property sanitization
|
|
45
|
+
* - Built-in caching and retry mechanisms (handled by posthog-js library)
|
|
46
|
+
*
|
|
47
|
+
* Note: PostHog handles its own event queuing, caching, and retry logic internally.
|
|
48
|
+
* No additional caching is needed at the wrapper level.
|
|
49
|
+
*/
|
|
50
|
+
declare class Posthog {
|
|
51
|
+
has_initialized: boolean;
|
|
52
|
+
has_identified: boolean;
|
|
53
|
+
private static _instance;
|
|
54
|
+
private options;
|
|
55
|
+
constructor(options: TPosthogOptions);
|
|
56
|
+
/**
|
|
57
|
+
* Get or create the singleton instance of Posthog
|
|
58
|
+
* @param options - PostHog configuration options including API key
|
|
59
|
+
* @returns The Posthog singleton instance
|
|
60
|
+
*/
|
|
61
|
+
static getPosthogInstance: (options: TPosthogOptions) => Posthog;
|
|
62
|
+
/**
|
|
63
|
+
* Initialize PostHog with configuration
|
|
64
|
+
* Configures PostHog instance with provided options
|
|
65
|
+
*/
|
|
66
|
+
init: () => Promise<void>;
|
|
67
|
+
/**
|
|
68
|
+
* Identify a user with PostHog
|
|
69
|
+
* Creates an alias between anonymous ID and user ID, then identifies with traits
|
|
70
|
+
*
|
|
71
|
+
* @param user_id - The user ID to identify
|
|
72
|
+
* @param traits - User properties (language, country_of_residence, etc.)
|
|
73
|
+
*/
|
|
74
|
+
identifyEvent: (user_id: string, traits?: TPosthogIdentifyTraits) => void;
|
|
75
|
+
/**
|
|
76
|
+
* Reset PostHog state
|
|
77
|
+
* Clears user identification and resets the instance
|
|
78
|
+
*/
|
|
79
|
+
reset: () => void;
|
|
80
|
+
/**
|
|
81
|
+
* Capture a custom event with properties
|
|
82
|
+
* Properties are pre-flattened and cleaned by analytics.ts before being passed here
|
|
83
|
+
*
|
|
84
|
+
* @param event_name - The name of the event to track
|
|
85
|
+
* @param properties - Event properties including core attributes (already flattened and cleaned)
|
|
86
|
+
*/
|
|
87
|
+
capture: (event_name: string, properties?: Record<string, any> & Partial<TCoreAttributes>) => void;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export { Posthog as P, type TPosthogOptions as T };
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { PostHogConfig, SessionRecordingOptions } from 'posthog-js';
|
|
2
|
+
import { T as TCoreAttributes } from './types-DoMejCXv.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Extended SessionRecordingOptions to allow additional custom properties
|
|
6
|
+
*/
|
|
7
|
+
type TExtendedSessionRecordingOptions = SessionRecordingOptions & {
|
|
8
|
+
minimumDurationMilliseconds?: number;
|
|
9
|
+
[key: string]: any;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Partial version of PostHog configuration to allow flexible initialization
|
|
13
|
+
* All properties from the official PostHogConfig are optional
|
|
14
|
+
* Extends session_recording to support additional properties
|
|
15
|
+
*/
|
|
16
|
+
type TPosthogConfig = Partial<Omit<PostHogConfig, 'session_recording'>> & {
|
|
17
|
+
session_recording?: Partial<TExtendedSessionRecordingOptions>;
|
|
18
|
+
};
|
|
19
|
+
type TPosthogIdentifyTraits = {
|
|
20
|
+
language?: string;
|
|
21
|
+
country_of_residence?: string;
|
|
22
|
+
[key: string]: any;
|
|
23
|
+
};
|
|
24
|
+
type TPosthogOptions = {
|
|
25
|
+
/**
|
|
26
|
+
* PostHog API key
|
|
27
|
+
*/
|
|
28
|
+
apiKey: string;
|
|
29
|
+
/**
|
|
30
|
+
* PostHog configuration options
|
|
31
|
+
* Allows customization of PostHog behavior, session recording, etc.
|
|
32
|
+
*/
|
|
33
|
+
config?: TPosthogConfig;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* PostHog analytics wrapper with singleton pattern.
|
|
38
|
+
* Provides optional PostHog integration for event tracking and session recording.
|
|
39
|
+
*
|
|
40
|
+
* Features:
|
|
41
|
+
* - Dynamically loads PostHog SDK on demand
|
|
42
|
+
* - Domain allowlisting for security
|
|
43
|
+
* - Automatic user identification and aliasing
|
|
44
|
+
* - Custom event tracking with property sanitization
|
|
45
|
+
* - Built-in caching and retry mechanisms (handled by posthog-js library)
|
|
46
|
+
*
|
|
47
|
+
* Note: PostHog handles its own event queuing, caching, and retry logic internally.
|
|
48
|
+
* No additional caching is needed at the wrapper level.
|
|
49
|
+
*/
|
|
50
|
+
declare class Posthog {
|
|
51
|
+
has_initialized: boolean;
|
|
52
|
+
has_identified: boolean;
|
|
53
|
+
private static _instance;
|
|
54
|
+
private options;
|
|
55
|
+
constructor(options: TPosthogOptions);
|
|
56
|
+
/**
|
|
57
|
+
* Get or create the singleton instance of Posthog
|
|
58
|
+
* @param options - PostHog configuration options including API key
|
|
59
|
+
* @returns The Posthog singleton instance
|
|
60
|
+
*/
|
|
61
|
+
static getPosthogInstance: (options: TPosthogOptions) => Posthog;
|
|
62
|
+
/**
|
|
63
|
+
* Initialize PostHog with configuration
|
|
64
|
+
* Configures PostHog instance with provided options
|
|
65
|
+
*/
|
|
66
|
+
init: () => Promise<void>;
|
|
67
|
+
/**
|
|
68
|
+
* Identify a user with PostHog
|
|
69
|
+
* Creates an alias between anonymous ID and user ID, then identifies with traits
|
|
70
|
+
*
|
|
71
|
+
* @param user_id - The user ID to identify
|
|
72
|
+
* @param traits - User properties (language, country_of_residence, etc.)
|
|
73
|
+
*/
|
|
74
|
+
identifyEvent: (user_id: string, traits?: TPosthogIdentifyTraits) => void;
|
|
75
|
+
/**
|
|
76
|
+
* Reset PostHog state
|
|
77
|
+
* Clears user identification and resets the instance
|
|
78
|
+
*/
|
|
79
|
+
reset: () => void;
|
|
80
|
+
/**
|
|
81
|
+
* Capture a custom event with properties
|
|
82
|
+
* Properties are pre-flattened and cleaned by analytics.ts before being passed here
|
|
83
|
+
*
|
|
84
|
+
* @param event_name - The name of the event to track
|
|
85
|
+
* @param properties - Event properties including core attributes (already flattened and cleaned)
|
|
86
|
+
*/
|
|
87
|
+
capture: (event_name: string, properties?: Record<string, any> & Partial<TCoreAttributes>) => void;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export { Posthog as P, type TPosthogOptions as T };
|