@gengage/assistant-fe 0.3.13 → 0.3.15

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/assistant-fe.css +1 -1
  2. package/dist/chat/components/ChatDrawer.d.ts +6 -0
  3. package/dist/chat/components/ChatDrawer.d.ts.map +1 -1
  4. package/dist/chat/index.d.ts +1 -0
  5. package/dist/chat/index.d.ts.map +1 -1
  6. package/dist/chat/panel-manager.d.ts +0 -5
  7. package/dist/chat/panel-manager.d.ts.map +1 -1
  8. package/dist/chat/stream-error-display.d.ts +7 -0
  9. package/dist/chat/stream-error-display.d.ts.map +1 -0
  10. package/dist/{chat-BOhy7EbK.js → chat-DIMqb9-7.js} +608 -554
  11. package/dist/chat-DIMqb9-7.js.map +1 -0
  12. package/dist/chat-Djxk60QW.cjs +15 -0
  13. package/dist/chat-Djxk60QW.cjs.map +1 -0
  14. package/dist/chat.cjs +1 -1
  15. package/dist/chat.iife.js +7 -5
  16. package/dist/chat.iife.js.map +1 -1
  17. package/dist/chat.js +1 -1
  18. package/dist/{common-CPy4Ugp4.js → common-CEQ7JL8r.js} +2 -2
  19. package/dist/{common-CPy4Ugp4.js.map → common-CEQ7JL8r.js.map} +1 -1
  20. package/dist/{common-DAF9EBzS.cjs → common-DUmbdVSa.cjs} +2 -2
  21. package/dist/{common-DAF9EBzS.cjs.map → common-DUmbdVSa.cjs.map} +1 -1
  22. package/dist/common.cjs +1 -1
  23. package/dist/common.js +3 -3
  24. package/dist/index.cjs +1 -1
  25. package/dist/index.js +4 -4
  26. package/dist/{native-webview-zQvM9ax7.cjs → native-webview-BOmxxjcL.cjs} +2 -2
  27. package/dist/{native-webview-zQvM9ax7.cjs.map → native-webview-BOmxxjcL.cjs.map} +1 -1
  28. package/dist/{native-webview-lN2TpszQ.js → native-webview-C0Jd4QeV.js} +3 -3
  29. package/dist/{native-webview-lN2TpszQ.js.map → native-webview-C0Jd4QeV.js.map} +1 -1
  30. package/dist/native.cjs +1 -1
  31. package/dist/native.iife.js +7 -5
  32. package/dist/native.iife.js.map +1 -1
  33. package/dist/native.js +1 -1
  34. package/dist/qna/components/TextInput.d.ts.map +1 -1
  35. package/dist/qna-DvgpFom7.cjs +2 -0
  36. package/dist/qna-DvgpFom7.cjs.map +1 -0
  37. package/dist/{qna-BtNfVn3t.js → qna-c7t5suwI.js} +73 -52
  38. package/dist/qna-c7t5suwI.js.map +1 -0
  39. package/dist/qna.cjs +1 -1
  40. package/dist/qna.css +1 -1
  41. package/dist/qna.iife.js +12 -12
  42. package/dist/qna.iife.js.map +1 -1
  43. package/dist/qna.js +1 -1
  44. package/package.json +1 -1
  45. package/dist/chat-BOhy7EbK.js.map +0 -1
  46. package/dist/chat-CaIq8E2N.cjs +0 -13
  47. package/dist/chat-CaIq8E2N.cjs.map +0 -1
  48. package/dist/qna-BtNfVn3t.js.map +0 -1
  49. package/dist/qna-BzoGBbS8.cjs +0 -2
  50. package/dist/qna-BzoGBbS8.cjs.map +0 -1
package/dist/chat.js CHANGED
@@ -1,2 +1,2 @@
1
- import { a as e, d as t, f as n, i as r, n as i, o as a, r as o, s, t as c, u as l } from "./chat-BOhy7EbK.js";
1
+ import { a as e, d as t, f as n, i as r, n as i, o as a, r as o, s, t as c, u as l } from "./chat-DIMqb9-7.js";
2
2
  export { l as CHAT_SCROLL_ELEMENT_ID, r as ChatPresentationState, c as GengageChat, o as chatCatalog, i as createChatWidget, e as createDefaultChatUISpecRegistry, a as defaultChatUnknownUISpecRenderer, t as getChatScrollElement, n as invalidateChatScrollCache, s as renderUISpec };
@@ -1,5 +1,5 @@
1
1
  import { f as e } from "./schemas-DUid6HBM.js";
2
- import { h as t, l as n } from "./native-webview-lN2TpszQ.js";
2
+ import { h as t, l as n } from "./native-webview-C0Jd4QeV.js";
3
3
  //#region src/common/analytics.ts
4
4
  var r = {
5
5
  enabled: !0,
@@ -354,4 +354,4 @@ function w(e) {
354
354
  //#endregion
355
355
  export { _ as a, h as c, m as d, a as f, b as i, f as l, S as n, u as o, o as p, C as r, d as s, w as t, p as u };
356
356
 
357
- //# sourceMappingURL=common-CPy4Ugp4.js.map
357
+ //# sourceMappingURL=common-CEQ7JL8r.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"common-CPy4Ugp4.js","names":[],"sources":["../src/common/analytics.ts","../src/common/customization-factories.ts","../src/common/preflight.ts","../src/common/client.ts","../src/common/page-detect.ts"],"sourcesContent":["import { normalizeMiddlewareUrl } from './api-paths.js';\nimport type { AnalyticsAuthMode } from './config-schema.js';\n\nexport interface AnalyticsEnvelope {\n event_name: string;\n event_version: '1';\n timestamp_ms: number;\n account_id: string;\n session_id: string;\n correlation_id: string;\n view_id?: string;\n user_id?: string;\n widget?: 'chat' | 'qna' | 'simrel';\n page_type?: string;\n sku?: string;\n payload: Record<string, unknown>;\n}\n\nexport interface AnalyticsAuthConfig {\n mode?: AnalyticsAuthMode;\n key?: string;\n headerName?: string;\n bodyField?: string;\n}\n\nexport interface AnalyticsClientConfig {\n enabled?: boolean;\n middlewareUrl: string;\n endpoint?: string;\n auth?: AnalyticsAuthConfig;\n fireAndForget?: boolean;\n useBeacon?: boolean;\n keepaliveFetch?: boolean;\n timeoutMs?: number;\n maxRetries?: number;\n batchSize?: number;\n flushIntervalMs?: number;\n}\n\nexport type AnalyticsInput = Omit<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'> &\n Partial<Pick<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'>>;\n\ninterface AnalyticsTransportBody {\n events: AnalyticsEnvelope[];\n [extra: string]: unknown;\n}\n\nconst DEFAULT_ANALYTICS_CONFIG: Required<Omit<AnalyticsClientConfig, 'auth' | 'middlewareUrl'>> = {\n enabled: true,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n keepaliveFetch: true,\n timeoutMs: 4000,\n maxRetries: 0,\n batchSize: 10,\n flushIntervalMs: 250,\n};\n\nconst DEFAULT_AUTH: Required<AnalyticsAuthConfig> = {\n mode: 'none',\n key: '',\n headerName: 'X-API-Key',\n bodyField: 'api_key',\n};\n\n/**\n * Fire-and-forget analytics client.\n *\n * All transport errors are silently suppressed — the backend analytics\n * endpoint is not yet implemented, so callers must never observe failures.\n */\nexport class AnalyticsClient {\n private readonly config: Required<Omit<AnalyticsClientConfig, 'auth'>> & { auth: Required<AnalyticsAuthConfig> };\n private readonly queue: AnalyticsEnvelope[] = [];\n private flushTimer: ReturnType<typeof setTimeout> | null = null;\n private readonly onPageHideBound: () => void;\n\n constructor(config: AnalyticsClientConfig) {\n this.config = {\n ...DEFAULT_ANALYTICS_CONFIG,\n ...config,\n auth: {\n ...DEFAULT_AUTH,\n ...(config.auth ?? {}),\n },\n };\n\n this.onPageHideBound = () => {\n if (this.queue.length === 0) return;\n this.flushAllSync();\n };\n\n if (typeof window !== 'undefined') {\n window.addEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n track(input: AnalyticsInput): void {\n if (!this.config.enabled) return;\n const envelope = normalizeAnalyticsInput(input);\n this.queue.push(envelope);\n\n if (this.queue.length >= this.config.batchSize) {\n this.scheduleImmediateFlush();\n return;\n }\n\n this.scheduleFlush();\n }\n\n flush(): void {\n if (!this.config.enabled || this.queue.length === 0) return;\n\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n\n this.send(endpoint, body);\n }\n\n /** Drain the entire queue synchronously (used on page hide). */\n flushAll(): void {\n while (this.queue.length > 0) {\n this.flush();\n }\n }\n\n destroy(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n if (this.queue.length > 0) {\n this.flushAllSync();\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n private scheduleFlush(): void {\n if (this.flushTimer) return;\n this.flushTimer = setTimeout(() => {\n this.flushTimer = null;\n this.flush();\n }, this.config.flushIntervalMs);\n }\n\n private scheduleImmediateFlush(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n this.flush();\n }\n\n private buildTransportBody(events: AnalyticsEnvelope[]): AnalyticsTransportBody {\n const body: AnalyticsTransportBody = { events };\n if (this.config.auth.mode === 'body-api-key' && this.config.auth.key) {\n body[this.config.auth.bodyField] = this.config.auth.key;\n }\n return body;\n }\n\n /** Best-effort send — all errors silently suppressed. */\n private send(endpoint: string, body: AnalyticsTransportBody): void {\n try {\n const payload = JSON.stringify(body);\n\n // Prefer sendBeacon (works during page unload, no response needed)\n if (\n this.config.useBeacon &&\n this.config.auth.mode !== 'x-api-key-header' &&\n this.config.auth.mode !== 'bearer-header' &&\n hasSendBeacon()\n ) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n return;\n }\n\n if (typeof fetch === 'undefined') return;\n\n const headers: Record<string, string> = { 'Content-Type': 'application/json' };\n if (this.config.auth.mode === 'x-api-key-header' && this.config.auth.key) {\n headers[this.config.auth.headerName] = this.config.auth.key;\n }\n if (this.config.auth.mode === 'bearer-header' && this.config.auth.key) {\n headers.Authorization = `Bearer ${this.config.auth.key}`;\n }\n\n // Fire-and-forget: no await, no error handling, keepalive for page unload\n void fetch(endpoint, {\n method: 'POST',\n headers,\n body: payload,\n keepalive: true,\n }).catch(() => {\n // Silently suppress — backend not implemented yet\n });\n } catch {\n // Silently suppress all errors\n }\n }\n\n /** Synchronous flush using sendBeacon only (for page unload). */\n private flushAllSync(): void {\n if (!this.config.enabled) return;\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n while (this.queue.length > 0) {\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n try {\n const payload = JSON.stringify(body);\n if (hasSendBeacon()) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n }\n } catch {\n // Silently suppress\n }\n }\n }\n}\n\nexport function createAnalyticsClient(config: AnalyticsClientConfig): AnalyticsClient {\n return new AnalyticsClient(config);\n}\n\nfunction normalizeAnalyticsInput(input: AnalyticsInput): AnalyticsEnvelope {\n const envelope: AnalyticsEnvelope = {\n event_name: input.event_name,\n event_version: input.event_version ?? '1',\n timestamp_ms: input.timestamp_ms ?? Date.now(),\n account_id: input.account_id,\n session_id: input.session_id,\n correlation_id: input.correlation_id,\n payload: input.payload,\n };\n\n if (input.view_id !== undefined) envelope.view_id = input.view_id;\n if (input.user_id !== undefined) envelope.user_id = input.user_id;\n if (input.widget !== undefined) envelope.widget = input.widget;\n if (input.page_type !== undefined) envelope.page_type = input.page_type;\n if (input.sku !== undefined) envelope.sku = input.sku;\n\n return envelope;\n}\n\nfunction resolveAnalyticsEndpoint(endpoint: string, middlewareUrl: string): string {\n if (/^https?:\\/\\//i.test(endpoint)) return endpoint;\n const baseUrl = normalizeMiddlewareUrl(middlewareUrl);\n const normalizedEndpoint = endpoint.startsWith('/') ? endpoint : `/${endpoint}`;\n return `${baseUrl}${normalizedEndpoint}`;\n}\n\nfunction hasSendBeacon(): boolean {\n return typeof navigator !== 'undefined' && typeof navigator.sendBeacon === 'function';\n}\n","import type { ChatWidgetConfig } from '../chat/types.js';\nimport type { QNAWidgetConfig } from '../qna/types.js';\nimport type { SimRelWidgetConfig } from '../simrel/types.js';\nimport type { AnalyticsClientConfig } from './analytics.js';\nimport type { WidgetTheme } from './types.js';\n\nexport const DEFAULT_CUSTOMIZATION_LOCALE = 'tr';\n\nexport interface AccountIdentityConfig {\n accountId: string;\n middlewareUrl: string;\n locale?: string;\n}\n\nexport interface AccountIdentity {\n ACCOUNT_ID: string;\n MIDDLEWARE_URL: string;\n LOCALE: string;\n}\n\ninterface BaseAccountWidgetConfigInput {\n accountId: string;\n middlewareUrl: string;\n sessionId: string;\n theme?: WidgetTheme;\n}\n\nexport interface FloatingChatConfigInput extends BaseAccountWidgetConfigInput {\n locale?: string;\n}\n\nexport interface PdpQnaConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: QNAWidgetConfig['mountTarget'];\n}\n\nexport interface PdpSimRelConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: SimRelWidgetConfig['mountTarget'];\n}\n\ntype FloatingChatConfigOverrides = Omit<\n Partial<ChatWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'variant' | 'theme' | 'locale'\n>;\ntype PdpQnaConfigOverrides = Omit<\n Partial<QNAWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'pageContext' | 'mountTarget' | 'theme'\n>;\ntype SimRelAccountConfig = Omit<SimRelWidgetConfig, 'onAddToCart' | 'onProductNavigate'>;\ntype PdpSimRelConfigOverrides = Omit<\n Partial<SimRelAccountConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'sku' | 'mountTarget' | 'theme'\n>;\ntype DefaultAnalyticsConfigOverrides = Omit<AnalyticsClientConfig, 'middlewareUrl'>;\n\n/**\n * Shared account identity factory used by all customization folders.\n * Keeps middleware URL + locale defaults centralized in the SDK layer.\n */\nexport function createAccountIdentity(config: AccountIdentityConfig): AccountIdentity {\n return {\n ACCOUNT_ID: config.accountId,\n MIDDLEWARE_URL: config.middlewareUrl,\n LOCALE: config.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n };\n}\n\n/**\n * Shared floating-chat baseline used by account customizations.\n * Account files only pass differences via `overrides`.\n */\nexport function createFloatingChatConfig(\n input: FloatingChatConfigInput,\n overrides: FloatingChatConfigOverrides = {},\n): ChatWidgetConfig {\n const config: ChatWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n variant: 'floating',\n locale: input.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP QNA baseline used by account customizations.\n */\nexport function createPdpQnaConfig(input: PdpQnaConfigInput, overrides: PdpQnaConfigOverrides = {}): QNAWidgetConfig {\n const config: QNAWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n pageContext: { pageType: 'pdp', sku: input.sku },\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP SimRel baseline used by account customizations.\n * Host-level commerce callbacks stay in account init wrappers.\n */\nexport function createPdpSimRelConfig(\n input: PdpSimRelConfigInput,\n overrides: PdpSimRelConfigOverrides = {},\n): SimRelAccountConfig {\n const config: SimRelAccountConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n sku: input.sku,\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared analytics defaults for account customization wrappers.\n */\nexport function createDefaultAnalyticsConfig(\n middlewareUrl: string,\n overrides: DefaultAnalyticsConfigOverrides = {},\n): AnalyticsClientConfig {\n return {\n enabled: true,\n middlewareUrl,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n ...overrides,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\n\nexport interface PreflightWarning {\n code: string;\n message: string;\n severity: 'warn' | 'error';\n}\n\nexport interface PreflightResult {\n ok: boolean;\n warnings: PreflightWarning[];\n}\n\nfunction isValidSelector(selector: string): boolean {\n try {\n document.querySelector(selector);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function preflightDiagnostics(\n config: AccountRuntimeConfig,\n options?: { skipCspCheck?: boolean },\n): PreflightResult {\n const warnings: PreflightWarning[] = [];\n\n const mounts = config.mounts;\n const mountEntries: Array<[string, string | undefined]> = [\n ['qna', mounts.qna],\n ['simrel', mounts.simrel],\n ['chat', mounts.chat],\n ];\n\n for (const [widget, selector] of mountEntries) {\n if (selector === undefined) continue;\n\n if (!isValidSelector(selector)) {\n warnings.push({\n code: 'INVALID_SELECTOR',\n message: `[gengage preflight] ${widget} mount selector is invalid CSS: \"${selector}\"`,\n severity: 'error',\n });\n continue;\n }\n\n if (!document.querySelector(selector)) {\n warnings.push({\n code: 'MOUNT_NOT_FOUND',\n message: `[gengage preflight] ${widget} mount target not found: \"${selector}\" — widget will skip or wait for DOM`,\n severity: 'warn',\n });\n }\n }\n\n const idempotencyKey = config.gtm.idempotencyKey;\n if ((window as unknown as Record<string, unknown>)[idempotencyKey] !== undefined) {\n warnings.push({\n code: 'DUPLICATE_IDEMPOTENCY',\n message: `[gengage preflight] window[\"${idempotencyKey}\"] already exists — widgets may have already initialized`,\n severity: 'warn',\n });\n }\n\n // CSP connect-src probe: detect if the middleware URL is blocked.\n // Uses a synchronous SecurityPolicyViolationEvent listener to catch CSP blocks.\n if (!options?.skipCspCheck) {\n let cspBlocked = false;\n const cspListener = (e: SecurityPolicyViolationEvent) => {\n if (e.blockedURI && config.middlewareUrl.startsWith(e.blockedURI)) {\n cspBlocked = true;\n }\n };\n document.addEventListener('securitypolicyviolation', cspListener);\n try {\n // A HEAD request with mode 'no-cors' is cheap and triggers CSP if connect-src blocks it.\n void fetch(config.middlewareUrl, { method: 'HEAD', mode: 'no-cors' }).catch(() => {\n /* swallow — we only care about CSP violations, not network errors */\n });\n } catch {\n // fetch itself may throw if CSP blocks it synchronously\n cspBlocked = true;\n }\n // Give the browser a tick to fire the violation event synchronously.\n // If it fired, cspBlocked is already true.\n document.removeEventListener('securitypolicyviolation', cspListener);\n if (cspBlocked) {\n warnings.push({\n code: 'CSP_BLOCKED',\n message: `[gengage preflight] middleware URL may be blocked by Content-Security-Policy: \"${config.middlewareUrl}\". Add it to connect-src.`,\n severity: 'warn',\n });\n }\n }\n\n for (const w of warnings) {\n if (w.severity === 'error') {\n console.error(w.message);\n } else {\n console.warn(w.message);\n }\n }\n\n return {\n ok: warnings.every((w) => w.severity !== 'error'),\n warnings,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\nimport { safeParseAccountRuntimeConfig } from './config-schema.js';\nimport { initOverlayWidgets } from './overlay.js';\nimport type { OverlayWidgetsController, OverlayWidgetsOptions } from './overlay.js';\nimport { preflightDiagnostics } from './preflight.js';\nimport type { PageContext } from './types.js';\n\nexport interface HostActions {\n onAddToCart?: (params: import('./types.js').AddToCartParams) => void;\n onProductNavigate?: (url: string, sku: string, sessionId: string | null) => void;\n onScriptCall?: (params: { name: string; payload?: Record<string, unknown> }) => void;\n}\n\nexport interface GengageClientOptions {\n runtimeConfig: AccountRuntimeConfig | unknown;\n contextResolver?: () => Partial<PageContext>;\n hostActions?: HostActions;\n preflight?: boolean;\n}\n\nfunction parseConfig(raw: AccountRuntimeConfig | unknown): AccountRuntimeConfig {\n const result = safeParseAccountRuntimeConfig(raw);\n if (!result.success) {\n const messages = result.error.issues.map((i) => `${i.path.join('.')}: ${i.message}`).join('; ');\n throw new Error(`[gengage] Invalid runtime config: ${messages}`);\n }\n return result.data;\n}\n\nfunction mapConfigToOverlayOptions(\n config: AccountRuntimeConfig,\n hostActions?: HostActions,\n initialContext?: Partial<PageContext>,\n): OverlayWidgetsOptions {\n const options: OverlayWidgetsOptions = {\n accountId: config.accountId,\n middlewareUrl: config.middlewareUrl,\n idempotencyKey: config.gtm.idempotencyKey,\n };\n\n if (config.locale !== undefined) options.locale = config.locale;\n\n if (initialContext !== undefined) {\n options.pageContext = initialContext;\n if (initialContext.sku !== undefined) options.sku = initialContext.sku;\n }\n\n options.chat = {\n enabled: config.widgets.chat.enabled,\n };\n if (config.mounts.chat !== undefined) {\n options.chat.mountTarget = config.mounts.chat;\n }\n\n options.qna = {\n enabled: config.widgets.qna.enabled,\n };\n if (config.mounts.qna !== undefined) {\n options.qna.mountTarget = config.mounts.qna;\n }\n\n options.simrel = {\n enabled: config.widgets.simrel.enabled,\n };\n if (config.mounts.simrel !== undefined) {\n options.simrel.mountTarget = config.mounts.simrel;\n }\n\n if (hostActions?.onAddToCart !== undefined) {\n options.onAddToCart = hostActions.onAddToCart;\n }\n\n if (hostActions?.onProductNavigate !== undefined) {\n options.onProductNavigate = hostActions.onProductNavigate;\n }\n\n if (hostActions?.onScriptCall !== undefined) {\n options.onScriptCall = hostActions.onScriptCall;\n }\n\n return options;\n}\n\nexport async function initGengageClient(options: GengageClientOptions): Promise<OverlayWidgetsController> {\n const config = parseConfig(options.runtimeConfig);\n\n if (options.preflight !== false) {\n const result = preflightDiagnostics(config);\n if (!result.ok) {\n const errors = result.warnings.filter((w) => w.severity === 'error');\n throw new Error(`[gengage] Preflight failed: ${errors.map((e) => e.message).join('; ')}`);\n }\n }\n\n const initialContext = options.contextResolver?.();\n\n const overlayOptions = mapConfigToOverlayOptions(config, options.hostActions, initialContext);\n const controller = await initOverlayWidgets(overlayOptions);\n\n if (options.contextResolver !== undefined) {\n const resolver = options.contextResolver;\n const listener = () => {\n const ctx = resolver();\n void controller.updateContext(ctx);\n };\n window.addEventListener('gengage:context:update', listener);\n\n // Wrap destroy to remove the listener and prevent a memory leak.\n const originalDestroy = controller.destroy.bind(controller);\n controller.destroy = () => {\n window.removeEventListener('gengage:context:update', listener);\n originalDestroy();\n };\n }\n\n return controller;\n}\n","/**\n * URL-based page type detection.\n *\n * Provides auto-detection of page type from URL patterns and DOM signals.\n * Falls back to 'other' when no rule matches.\n */\n\nimport type { PageContext } from './types.js';\n\nexport type DetectablePageType = PageContext['pageType'];\n\nexport interface PageDetectionRule {\n /** Page type to assign when this rule matches. */\n pageType: DetectablePageType;\n /** URL pathname patterns (tested with `new RegExp(pattern)`). */\n urlPatterns?: string[];\n /** If present, page type is detected only when this query param exists. */\n queryParam?: string;\n /** DOM selector — if an element matching this exists, rule matches. */\n selector?: string;\n}\n\n/** Default rules covering common Turkish e-commerce URL patterns. */\nconst DEFAULT_RULES: PageDetectionRule[] = [\n {\n pageType: 'home',\n urlPatterns: ['^/$', '^/index\\\\.html?$', '^/anasayfa$'],\n },\n {\n pageType: 'search',\n urlPatterns: ['/arama', '/search', '/ara\\\\?'],\n queryParam: 'q',\n },\n {\n pageType: 'cart',\n urlPatterns: ['/sepet', '/cart', '/basket', '/sepetim'],\n },\n {\n pageType: 'plp',\n urlPatterns: ['/kategori/', '/category/', '/c/', '/koleksiyon/', '/collection/'],\n },\n {\n pageType: 'pdp',\n urlPatterns: ['/urun/', '/product/', '/p/', '/-p-', '/-pm-'],\n },\n];\n\n/**\n * Detects page type from the current URL and optional DOM signals.\n *\n * @param rules - Custom rules (defaults to common Turkish e-commerce patterns).\n * @param url - URL to analyze (defaults to window.location).\n * @returns Detected page type, or 'other' if no rule matches.\n */\nexport function detectPageType(rules?: PageDetectionRule[], url?: URL): DetectablePageType {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return 'other';\n\n const effectiveRules = rules ?? DEFAULT_RULES;\n const pathname = loc.pathname;\n\n for (const rule of effectiveRules) {\n // Check URL patterns\n if (rule.urlPatterns) {\n const urlMatch = rule.urlPatterns.some((pattern) => {\n try {\n return new RegExp(pattern, 'i').test(pathname);\n } catch {\n return false;\n }\n });\n if (!urlMatch) continue;\n }\n\n // Check query param requirement\n if (rule.queryParam && !loc.searchParams.has(rule.queryParam)) {\n continue;\n }\n\n // Check DOM selector\n if (rule.selector && typeof document !== 'undefined') {\n if (!document.querySelector(rule.selector)) continue;\n }\n\n return rule.pageType;\n }\n\n return 'other';\n}\n\n/**\n * Attempts to extract a product SKU from the URL path.\n * Looks for common patterns like `/p/SKU`, `/urun/SKU`, `/-p-SKU`.\n */\nexport function extractSkuFromUrl(url?: URL): string | undefined {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return undefined;\n\n const pathname = loc.pathname;\n\n // Pattern: /p/SKU or /urun/SKU or /product/SKU\n const segmentMatch = pathname.match(/\\/(?:p|urun|product)\\/([^/?#]+)/i);\n if (segmentMatch?.[1]) return segmentMatch[1];\n\n // Pattern: -p-SKU at end of path (Trendyol style)\n const suffixMatch = pathname.match(/-p-(\\d+)/i);\n if (suffixMatch?.[1]) return suffixMatch[1];\n\n return undefined;\n}\n\n/**\n * Auto-detects page context from URL and DOM signals.\n * Use as a fallback when the host page doesn't set pageContext explicitly.\n */\nexport function autoDetectPageContext(rules?: PageDetectionRule[]): Partial<PageContext> {\n const pageType = detectPageType(rules);\n const result: Partial<PageContext> = { pageType };\n\n if (pageType === 'pdp') {\n const sku = extractSkuFromUrl();\n if (sku) result.sku = sku;\n }\n\n if (typeof window !== 'undefined') {\n result.url = window.location.href;\n }\n\n return result;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"common-CEQ7JL8r.js","names":[],"sources":["../src/common/analytics.ts","../src/common/customization-factories.ts","../src/common/preflight.ts","../src/common/client.ts","../src/common/page-detect.ts"],"sourcesContent":["import { normalizeMiddlewareUrl } from './api-paths.js';\nimport type { AnalyticsAuthMode } from './config-schema.js';\n\nexport interface AnalyticsEnvelope {\n event_name: string;\n event_version: '1';\n timestamp_ms: number;\n account_id: string;\n session_id: string;\n correlation_id: string;\n view_id?: string;\n user_id?: string;\n widget?: 'chat' | 'qna' | 'simrel';\n page_type?: string;\n sku?: string;\n payload: Record<string, unknown>;\n}\n\nexport interface AnalyticsAuthConfig {\n mode?: AnalyticsAuthMode;\n key?: string;\n headerName?: string;\n bodyField?: string;\n}\n\nexport interface AnalyticsClientConfig {\n enabled?: boolean;\n middlewareUrl: string;\n endpoint?: string;\n auth?: AnalyticsAuthConfig;\n fireAndForget?: boolean;\n useBeacon?: boolean;\n keepaliveFetch?: boolean;\n timeoutMs?: number;\n maxRetries?: number;\n batchSize?: number;\n flushIntervalMs?: number;\n}\n\nexport type AnalyticsInput = Omit<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'> &\n Partial<Pick<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'>>;\n\ninterface AnalyticsTransportBody {\n events: AnalyticsEnvelope[];\n [extra: string]: unknown;\n}\n\nconst DEFAULT_ANALYTICS_CONFIG: Required<Omit<AnalyticsClientConfig, 'auth' | 'middlewareUrl'>> = {\n enabled: true,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n keepaliveFetch: true,\n timeoutMs: 4000,\n maxRetries: 0,\n batchSize: 10,\n flushIntervalMs: 250,\n};\n\nconst DEFAULT_AUTH: Required<AnalyticsAuthConfig> = {\n mode: 'none',\n key: '',\n headerName: 'X-API-Key',\n bodyField: 'api_key',\n};\n\n/**\n * Fire-and-forget analytics client.\n *\n * All transport errors are silently suppressed — the backend analytics\n * endpoint is not yet implemented, so callers must never observe failures.\n */\nexport class AnalyticsClient {\n private readonly config: Required<Omit<AnalyticsClientConfig, 'auth'>> & { auth: Required<AnalyticsAuthConfig> };\n private readonly queue: AnalyticsEnvelope[] = [];\n private flushTimer: ReturnType<typeof setTimeout> | null = null;\n private readonly onPageHideBound: () => void;\n\n constructor(config: AnalyticsClientConfig) {\n this.config = {\n ...DEFAULT_ANALYTICS_CONFIG,\n ...config,\n auth: {\n ...DEFAULT_AUTH,\n ...(config.auth ?? {}),\n },\n };\n\n this.onPageHideBound = () => {\n if (this.queue.length === 0) return;\n this.flushAllSync();\n };\n\n if (typeof window !== 'undefined') {\n window.addEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n track(input: AnalyticsInput): void {\n if (!this.config.enabled) return;\n const envelope = normalizeAnalyticsInput(input);\n this.queue.push(envelope);\n\n if (this.queue.length >= this.config.batchSize) {\n this.scheduleImmediateFlush();\n return;\n }\n\n this.scheduleFlush();\n }\n\n flush(): void {\n if (!this.config.enabled || this.queue.length === 0) return;\n\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n\n this.send(endpoint, body);\n }\n\n /** Drain the entire queue synchronously (used on page hide). */\n flushAll(): void {\n while (this.queue.length > 0) {\n this.flush();\n }\n }\n\n destroy(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n if (this.queue.length > 0) {\n this.flushAllSync();\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n private scheduleFlush(): void {\n if (this.flushTimer) return;\n this.flushTimer = setTimeout(() => {\n this.flushTimer = null;\n this.flush();\n }, this.config.flushIntervalMs);\n }\n\n private scheduleImmediateFlush(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n this.flush();\n }\n\n private buildTransportBody(events: AnalyticsEnvelope[]): AnalyticsTransportBody {\n const body: AnalyticsTransportBody = { events };\n if (this.config.auth.mode === 'body-api-key' && this.config.auth.key) {\n body[this.config.auth.bodyField] = this.config.auth.key;\n }\n return body;\n }\n\n /** Best-effort send — all errors silently suppressed. */\n private send(endpoint: string, body: AnalyticsTransportBody): void {\n try {\n const payload = JSON.stringify(body);\n\n // Prefer sendBeacon (works during page unload, no response needed)\n if (\n this.config.useBeacon &&\n this.config.auth.mode !== 'x-api-key-header' &&\n this.config.auth.mode !== 'bearer-header' &&\n hasSendBeacon()\n ) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n return;\n }\n\n if (typeof fetch === 'undefined') return;\n\n const headers: Record<string, string> = { 'Content-Type': 'application/json' };\n if (this.config.auth.mode === 'x-api-key-header' && this.config.auth.key) {\n headers[this.config.auth.headerName] = this.config.auth.key;\n }\n if (this.config.auth.mode === 'bearer-header' && this.config.auth.key) {\n headers.Authorization = `Bearer ${this.config.auth.key}`;\n }\n\n // Fire-and-forget: no await, no error handling, keepalive for page unload\n void fetch(endpoint, {\n method: 'POST',\n headers,\n body: payload,\n keepalive: true,\n }).catch(() => {\n // Silently suppress — backend not implemented yet\n });\n } catch {\n // Silently suppress all errors\n }\n }\n\n /** Synchronous flush using sendBeacon only (for page unload). */\n private flushAllSync(): void {\n if (!this.config.enabled) return;\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n while (this.queue.length > 0) {\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n try {\n const payload = JSON.stringify(body);\n if (hasSendBeacon()) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n }\n } catch {\n // Silently suppress\n }\n }\n }\n}\n\nexport function createAnalyticsClient(config: AnalyticsClientConfig): AnalyticsClient {\n return new AnalyticsClient(config);\n}\n\nfunction normalizeAnalyticsInput(input: AnalyticsInput): AnalyticsEnvelope {\n const envelope: AnalyticsEnvelope = {\n event_name: input.event_name,\n event_version: input.event_version ?? '1',\n timestamp_ms: input.timestamp_ms ?? Date.now(),\n account_id: input.account_id,\n session_id: input.session_id,\n correlation_id: input.correlation_id,\n payload: input.payload,\n };\n\n if (input.view_id !== undefined) envelope.view_id = input.view_id;\n if (input.user_id !== undefined) envelope.user_id = input.user_id;\n if (input.widget !== undefined) envelope.widget = input.widget;\n if (input.page_type !== undefined) envelope.page_type = input.page_type;\n if (input.sku !== undefined) envelope.sku = input.sku;\n\n return envelope;\n}\n\nfunction resolveAnalyticsEndpoint(endpoint: string, middlewareUrl: string): string {\n if (/^https?:\\/\\//i.test(endpoint)) return endpoint;\n const baseUrl = normalizeMiddlewareUrl(middlewareUrl);\n const normalizedEndpoint = endpoint.startsWith('/') ? endpoint : `/${endpoint}`;\n return `${baseUrl}${normalizedEndpoint}`;\n}\n\nfunction hasSendBeacon(): boolean {\n return typeof navigator !== 'undefined' && typeof navigator.sendBeacon === 'function';\n}\n","import type { ChatWidgetConfig } from '../chat/types.js';\nimport type { QNAWidgetConfig } from '../qna/types.js';\nimport type { SimRelWidgetConfig } from '../simrel/types.js';\nimport type { AnalyticsClientConfig } from './analytics.js';\nimport type { WidgetTheme } from './types.js';\n\nexport const DEFAULT_CUSTOMIZATION_LOCALE = 'tr';\n\nexport interface AccountIdentityConfig {\n accountId: string;\n middlewareUrl: string;\n locale?: string;\n}\n\nexport interface AccountIdentity {\n ACCOUNT_ID: string;\n MIDDLEWARE_URL: string;\n LOCALE: string;\n}\n\ninterface BaseAccountWidgetConfigInput {\n accountId: string;\n middlewareUrl: string;\n sessionId: string;\n theme?: WidgetTheme;\n}\n\nexport interface FloatingChatConfigInput extends BaseAccountWidgetConfigInput {\n locale?: string;\n}\n\nexport interface PdpQnaConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: QNAWidgetConfig['mountTarget'];\n}\n\nexport interface PdpSimRelConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: SimRelWidgetConfig['mountTarget'];\n}\n\ntype FloatingChatConfigOverrides = Omit<\n Partial<ChatWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'variant' | 'theme' | 'locale'\n>;\ntype PdpQnaConfigOverrides = Omit<\n Partial<QNAWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'pageContext' | 'mountTarget' | 'theme'\n>;\ntype SimRelAccountConfig = Omit<SimRelWidgetConfig, 'onAddToCart' | 'onProductNavigate'>;\ntype PdpSimRelConfigOverrides = Omit<\n Partial<SimRelAccountConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'sku' | 'mountTarget' | 'theme'\n>;\ntype DefaultAnalyticsConfigOverrides = Omit<AnalyticsClientConfig, 'middlewareUrl'>;\n\n/**\n * Shared account identity factory used by all customization folders.\n * Keeps middleware URL + locale defaults centralized in the SDK layer.\n */\nexport function createAccountIdentity(config: AccountIdentityConfig): AccountIdentity {\n return {\n ACCOUNT_ID: config.accountId,\n MIDDLEWARE_URL: config.middlewareUrl,\n LOCALE: config.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n };\n}\n\n/**\n * Shared floating-chat baseline used by account customizations.\n * Account files only pass differences via `overrides`.\n */\nexport function createFloatingChatConfig(\n input: FloatingChatConfigInput,\n overrides: FloatingChatConfigOverrides = {},\n): ChatWidgetConfig {\n const config: ChatWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n variant: 'floating',\n locale: input.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP QNA baseline used by account customizations.\n */\nexport function createPdpQnaConfig(input: PdpQnaConfigInput, overrides: PdpQnaConfigOverrides = {}): QNAWidgetConfig {\n const config: QNAWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n pageContext: { pageType: 'pdp', sku: input.sku },\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP SimRel baseline used by account customizations.\n * Host-level commerce callbacks stay in account init wrappers.\n */\nexport function createPdpSimRelConfig(\n input: PdpSimRelConfigInput,\n overrides: PdpSimRelConfigOverrides = {},\n): SimRelAccountConfig {\n const config: SimRelAccountConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n sku: input.sku,\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared analytics defaults for account customization wrappers.\n */\nexport function createDefaultAnalyticsConfig(\n middlewareUrl: string,\n overrides: DefaultAnalyticsConfigOverrides = {},\n): AnalyticsClientConfig {\n return {\n enabled: true,\n middlewareUrl,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n ...overrides,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\n\nexport interface PreflightWarning {\n code: string;\n message: string;\n severity: 'warn' | 'error';\n}\n\nexport interface PreflightResult {\n ok: boolean;\n warnings: PreflightWarning[];\n}\n\nfunction isValidSelector(selector: string): boolean {\n try {\n document.querySelector(selector);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function preflightDiagnostics(\n config: AccountRuntimeConfig,\n options?: { skipCspCheck?: boolean },\n): PreflightResult {\n const warnings: PreflightWarning[] = [];\n\n const mounts = config.mounts;\n const mountEntries: Array<[string, string | undefined]> = [\n ['qna', mounts.qna],\n ['simrel', mounts.simrel],\n ['chat', mounts.chat],\n ];\n\n for (const [widget, selector] of mountEntries) {\n if (selector === undefined) continue;\n\n if (!isValidSelector(selector)) {\n warnings.push({\n code: 'INVALID_SELECTOR',\n message: `[gengage preflight] ${widget} mount selector is invalid CSS: \"${selector}\"`,\n severity: 'error',\n });\n continue;\n }\n\n if (!document.querySelector(selector)) {\n warnings.push({\n code: 'MOUNT_NOT_FOUND',\n message: `[gengage preflight] ${widget} mount target not found: \"${selector}\" — widget will skip or wait for DOM`,\n severity: 'warn',\n });\n }\n }\n\n const idempotencyKey = config.gtm.idempotencyKey;\n if ((window as unknown as Record<string, unknown>)[idempotencyKey] !== undefined) {\n warnings.push({\n code: 'DUPLICATE_IDEMPOTENCY',\n message: `[gengage preflight] window[\"${idempotencyKey}\"] already exists — widgets may have already initialized`,\n severity: 'warn',\n });\n }\n\n // CSP connect-src probe: detect if the middleware URL is blocked.\n // Uses a synchronous SecurityPolicyViolationEvent listener to catch CSP blocks.\n if (!options?.skipCspCheck) {\n let cspBlocked = false;\n const cspListener = (e: SecurityPolicyViolationEvent) => {\n if (e.blockedURI && config.middlewareUrl.startsWith(e.blockedURI)) {\n cspBlocked = true;\n }\n };\n document.addEventListener('securitypolicyviolation', cspListener);\n try {\n // A HEAD request with mode 'no-cors' is cheap and triggers CSP if connect-src blocks it.\n void fetch(config.middlewareUrl, { method: 'HEAD', mode: 'no-cors' }).catch(() => {\n /* swallow — we only care about CSP violations, not network errors */\n });\n } catch {\n // fetch itself may throw if CSP blocks it synchronously\n cspBlocked = true;\n }\n // Give the browser a tick to fire the violation event synchronously.\n // If it fired, cspBlocked is already true.\n document.removeEventListener('securitypolicyviolation', cspListener);\n if (cspBlocked) {\n warnings.push({\n code: 'CSP_BLOCKED',\n message: `[gengage preflight] middleware URL may be blocked by Content-Security-Policy: \"${config.middlewareUrl}\". Add it to connect-src.`,\n severity: 'warn',\n });\n }\n }\n\n for (const w of warnings) {\n if (w.severity === 'error') {\n console.error(w.message);\n } else {\n console.warn(w.message);\n }\n }\n\n return {\n ok: warnings.every((w) => w.severity !== 'error'),\n warnings,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\nimport { safeParseAccountRuntimeConfig } from './config-schema.js';\nimport { initOverlayWidgets } from './overlay.js';\nimport type { OverlayWidgetsController, OverlayWidgetsOptions } from './overlay.js';\nimport { preflightDiagnostics } from './preflight.js';\nimport type { PageContext } from './types.js';\n\nexport interface HostActions {\n onAddToCart?: (params: import('./types.js').AddToCartParams) => void;\n onProductNavigate?: (url: string, sku: string, sessionId: string | null) => void;\n onScriptCall?: (params: { name: string; payload?: Record<string, unknown> }) => void;\n}\n\nexport interface GengageClientOptions {\n runtimeConfig: AccountRuntimeConfig | unknown;\n contextResolver?: () => Partial<PageContext>;\n hostActions?: HostActions;\n preflight?: boolean;\n}\n\nfunction parseConfig(raw: AccountRuntimeConfig | unknown): AccountRuntimeConfig {\n const result = safeParseAccountRuntimeConfig(raw);\n if (!result.success) {\n const messages = result.error.issues.map((i) => `${i.path.join('.')}: ${i.message}`).join('; ');\n throw new Error(`[gengage] Invalid runtime config: ${messages}`);\n }\n return result.data;\n}\n\nfunction mapConfigToOverlayOptions(\n config: AccountRuntimeConfig,\n hostActions?: HostActions,\n initialContext?: Partial<PageContext>,\n): OverlayWidgetsOptions {\n const options: OverlayWidgetsOptions = {\n accountId: config.accountId,\n middlewareUrl: config.middlewareUrl,\n idempotencyKey: config.gtm.idempotencyKey,\n };\n\n if (config.locale !== undefined) options.locale = config.locale;\n\n if (initialContext !== undefined) {\n options.pageContext = initialContext;\n if (initialContext.sku !== undefined) options.sku = initialContext.sku;\n }\n\n options.chat = {\n enabled: config.widgets.chat.enabled,\n };\n if (config.mounts.chat !== undefined) {\n options.chat.mountTarget = config.mounts.chat;\n }\n\n options.qna = {\n enabled: config.widgets.qna.enabled,\n };\n if (config.mounts.qna !== undefined) {\n options.qna.mountTarget = config.mounts.qna;\n }\n\n options.simrel = {\n enabled: config.widgets.simrel.enabled,\n };\n if (config.mounts.simrel !== undefined) {\n options.simrel.mountTarget = config.mounts.simrel;\n }\n\n if (hostActions?.onAddToCart !== undefined) {\n options.onAddToCart = hostActions.onAddToCart;\n }\n\n if (hostActions?.onProductNavigate !== undefined) {\n options.onProductNavigate = hostActions.onProductNavigate;\n }\n\n if (hostActions?.onScriptCall !== undefined) {\n options.onScriptCall = hostActions.onScriptCall;\n }\n\n return options;\n}\n\nexport async function initGengageClient(options: GengageClientOptions): Promise<OverlayWidgetsController> {\n const config = parseConfig(options.runtimeConfig);\n\n if (options.preflight !== false) {\n const result = preflightDiagnostics(config);\n if (!result.ok) {\n const errors = result.warnings.filter((w) => w.severity === 'error');\n throw new Error(`[gengage] Preflight failed: ${errors.map((e) => e.message).join('; ')}`);\n }\n }\n\n const initialContext = options.contextResolver?.();\n\n const overlayOptions = mapConfigToOverlayOptions(config, options.hostActions, initialContext);\n const controller = await initOverlayWidgets(overlayOptions);\n\n if (options.contextResolver !== undefined) {\n const resolver = options.contextResolver;\n const listener = () => {\n const ctx = resolver();\n void controller.updateContext(ctx);\n };\n window.addEventListener('gengage:context:update', listener);\n\n // Wrap destroy to remove the listener and prevent a memory leak.\n const originalDestroy = controller.destroy.bind(controller);\n controller.destroy = () => {\n window.removeEventListener('gengage:context:update', listener);\n originalDestroy();\n };\n }\n\n return controller;\n}\n","/**\n * URL-based page type detection.\n *\n * Provides auto-detection of page type from URL patterns and DOM signals.\n * Falls back to 'other' when no rule matches.\n */\n\nimport type { PageContext } from './types.js';\n\nexport type DetectablePageType = PageContext['pageType'];\n\nexport interface PageDetectionRule {\n /** Page type to assign when this rule matches. */\n pageType: DetectablePageType;\n /** URL pathname patterns (tested with `new RegExp(pattern)`). */\n urlPatterns?: string[];\n /** If present, page type is detected only when this query param exists. */\n queryParam?: string;\n /** DOM selector — if an element matching this exists, rule matches. */\n selector?: string;\n}\n\n/** Default rules covering common Turkish e-commerce URL patterns. */\nconst DEFAULT_RULES: PageDetectionRule[] = [\n {\n pageType: 'home',\n urlPatterns: ['^/$', '^/index\\\\.html?$', '^/anasayfa$'],\n },\n {\n pageType: 'search',\n urlPatterns: ['/arama', '/search', '/ara\\\\?'],\n queryParam: 'q',\n },\n {\n pageType: 'cart',\n urlPatterns: ['/sepet', '/cart', '/basket', '/sepetim'],\n },\n {\n pageType: 'plp',\n urlPatterns: ['/kategori/', '/category/', '/c/', '/koleksiyon/', '/collection/'],\n },\n {\n pageType: 'pdp',\n urlPatterns: ['/urun/', '/product/', '/p/', '/-p-', '/-pm-'],\n },\n];\n\n/**\n * Detects page type from the current URL and optional DOM signals.\n *\n * @param rules - Custom rules (defaults to common Turkish e-commerce patterns).\n * @param url - URL to analyze (defaults to window.location).\n * @returns Detected page type, or 'other' if no rule matches.\n */\nexport function detectPageType(rules?: PageDetectionRule[], url?: URL): DetectablePageType {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return 'other';\n\n const effectiveRules = rules ?? DEFAULT_RULES;\n const pathname = loc.pathname;\n\n for (const rule of effectiveRules) {\n // Check URL patterns\n if (rule.urlPatterns) {\n const urlMatch = rule.urlPatterns.some((pattern) => {\n try {\n return new RegExp(pattern, 'i').test(pathname);\n } catch {\n return false;\n }\n });\n if (!urlMatch) continue;\n }\n\n // Check query param requirement\n if (rule.queryParam && !loc.searchParams.has(rule.queryParam)) {\n continue;\n }\n\n // Check DOM selector\n if (rule.selector && typeof document !== 'undefined') {\n if (!document.querySelector(rule.selector)) continue;\n }\n\n return rule.pageType;\n }\n\n return 'other';\n}\n\n/**\n * Attempts to extract a product SKU from the URL path.\n * Looks for common patterns like `/p/SKU`, `/urun/SKU`, `/-p-SKU`.\n */\nexport function extractSkuFromUrl(url?: URL): string | undefined {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return undefined;\n\n const pathname = loc.pathname;\n\n // Pattern: /p/SKU or /urun/SKU or /product/SKU\n const segmentMatch = pathname.match(/\\/(?:p|urun|product)\\/([^/?#]+)/i);\n if (segmentMatch?.[1]) return segmentMatch[1];\n\n // Pattern: -p-SKU at end of path (Trendyol style)\n const suffixMatch = pathname.match(/-p-(\\d+)/i);\n if (suffixMatch?.[1]) return suffixMatch[1];\n\n return undefined;\n}\n\n/**\n * Auto-detects page context from URL and DOM signals.\n * Use as a fallback when the host page doesn't set pageContext explicitly.\n */\nexport function autoDetectPageContext(rules?: PageDetectionRule[]): Partial<PageContext> {\n const pageType = detectPageType(rules);\n const result: Partial<PageContext> = { pageType };\n\n if (pageType === 'pdp') {\n const sku = extractSkuFromUrl();\n if (sku) result.sku = sku;\n }\n\n if (typeof window !== 'undefined') {\n result.url = window.location.href;\n }\n\n return result;\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./native-webview-zQvM9ax7.cjs`);var n={enabled:!0,endpoint:`/analytics`,fireAndForget:!0,useBeacon:!0,keepaliveFetch:!0,timeoutMs:4e3,maxRetries:0,batchSize:10,flushIntervalMs:250},r={mode:`none`,key:``,headerName:`X-API-Key`,bodyField:`api_key`},i=class{constructor(e){this.queue=[],this.flushTimer=null,this.config={...n,...e,auth:{...r,...e.auth??{}}},this.onPageHideBound=()=>{this.queue.length!==0&&this.flushAllSync()},typeof window<`u`&&window.addEventListener(`pagehide`,this.onPageHideBound)}track(e){if(!this.config.enabled)return;let t=o(e);if(this.queue.push(t),this.queue.length>=this.config.batchSize){this.scheduleImmediateFlush();return}this.scheduleFlush()}flush(){if(!this.config.enabled||this.queue.length===0)return;let e=this.queue.splice(0,this.config.batchSize),t=this.buildTransportBody(e),n=s(this.config.endpoint,this.config.middlewareUrl);this.send(n,t)}flushAll(){for(;this.queue.length>0;)this.flush()}destroy(){this.flushTimer&&=(clearTimeout(this.flushTimer),null),this.queue.length>0&&this.flushAllSync(),typeof window<`u`&&window.removeEventListener(`pagehide`,this.onPageHideBound)}scheduleFlush(){this.flushTimer||=setTimeout(()=>{this.flushTimer=null,this.flush()},this.config.flushIntervalMs)}scheduleImmediateFlush(){this.flushTimer&&=(clearTimeout(this.flushTimer),null),this.flush()}buildTransportBody(e){let t={events:e};return this.config.auth.mode===`body-api-key`&&this.config.auth.key&&(t[this.config.auth.bodyField]=this.config.auth.key),t}send(e,t){try{let n=JSON.stringify(t);if(this.config.useBeacon&&this.config.auth.mode!==`x-api-key-header`&&this.config.auth.mode!==`bearer-header`&&c()){let t=new Blob([n],{type:`application/json`});navigator.sendBeacon(e,t);return}if(typeof fetch>`u`)return;let r={"Content-Type":`application/json`};this.config.auth.mode===`x-api-key-header`&&this.config.auth.key&&(r[this.config.auth.headerName]=this.config.auth.key),this.config.auth.mode===`bearer-header`&&this.config.auth.key&&(r.Authorization=`Bearer ${this.config.auth.key}`),fetch(e,{method:`POST`,headers:r,body:n,keepalive:!0}).catch(()=>{})}catch{}}flushAllSync(){if(!this.config.enabled)return;let e=s(this.config.endpoint,this.config.middlewareUrl);for(;this.queue.length>0;){let t=this.queue.splice(0,this.config.batchSize),n=this.buildTransportBody(t);try{let t=JSON.stringify(n);if(c()){let n=new Blob([t],{type:`application/json`});navigator.sendBeacon(e,n)}}catch{}}}};function a(e){return new i(e)}function o(e){let t={event_name:e.event_name,event_version:e.event_version??`1`,timestamp_ms:e.timestamp_ms??Date.now(),account_id:e.account_id,session_id:e.session_id,correlation_id:e.correlation_id,payload:e.payload};return e.view_id!==void 0&&(t.view_id=e.view_id),e.user_id!==void 0&&(t.user_id=e.user_id),e.widget!==void 0&&(t.widget=e.widget),e.page_type!==void 0&&(t.page_type=e.page_type),e.sku!==void 0&&(t.sku=e.sku),t}function s(t,n){return/^https?:\/\//i.test(t)?t:`${e.f(n)}${t.startsWith(`/`)?t:`/${t}`}`}function c(){return typeof navigator<`u`&&typeof navigator.sendBeacon==`function`}var l=`tr`;function u(e){return{ACCOUNT_ID:e.accountId,MIDDLEWARE_URL:e.middlewareUrl,LOCALE:e.locale??`tr`}}function d(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},variant:`floating`,locale:e.locale??`tr`,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function f(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},pageContext:{pageType:`pdp`,sku:e.sku},mountTarget:e.mountTarget,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function p(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},sku:e.sku,mountTarget:e.mountTarget,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function m(e,t={}){return{enabled:!0,middlewareUrl:e,endpoint:`/analytics`,fireAndForget:!0,useBeacon:!0,...t}}function h(e){try{return document.querySelector(e),!0}catch{return!1}}function g(e,t){let n=[],r=e.mounts,i=[[`qna`,r.qna],[`simrel`,r.simrel],[`chat`,r.chat]];for(let[e,t]of i)if(t!==void 0){if(!h(t)){n.push({code:`INVALID_SELECTOR`,message:`[gengage preflight] ${e} mount selector is invalid CSS: "${t}"`,severity:`error`});continue}document.querySelector(t)||n.push({code:`MOUNT_NOT_FOUND`,message:`[gengage preflight] ${e} mount target not found: "${t}" — widget will skip or wait for DOM`,severity:`warn`})}let a=e.gtm.idempotencyKey;if(window[a]!==void 0&&n.push({code:`DUPLICATE_IDEMPOTENCY`,message:`[gengage preflight] window["${a}"] already exists — widgets may have already initialized`,severity:`warn`}),!t?.skipCspCheck){let t=!1,r=n=>{n.blockedURI&&e.middlewareUrl.startsWith(n.blockedURI)&&(t=!0)};document.addEventListener(`securitypolicyviolation`,r);try{fetch(e.middlewareUrl,{method:`HEAD`,mode:`no-cors`}).catch(()=>{})}catch{t=!0}document.removeEventListener(`securitypolicyviolation`,r),t&&n.push({code:`CSP_BLOCKED`,message:`[gengage preflight] middleware URL may be blocked by Content-Security-Policy: "${e.middlewareUrl}". Add it to connect-src.`,severity:`warn`})}for(let e of n)e.severity===`error`?console.error(e.message):console.warn(e.message);return{ok:n.every(e=>e.severity!==`error`),warnings:n}}function _(e){let n=t.h(e);if(!n.success){let e=n.error.issues.map(e=>`${e.path.join(`.`)}: ${e.message}`).join(`; `);throw Error(`[gengage] Invalid runtime config: ${e}`)}return n.data}function v(e,t,n){let r={accountId:e.accountId,middlewareUrl:e.middlewareUrl,idempotencyKey:e.gtm.idempotencyKey};return e.locale!==void 0&&(r.locale=e.locale),n!==void 0&&(r.pageContext=n,n.sku!==void 0&&(r.sku=n.sku)),r.chat={enabled:e.widgets.chat.enabled},e.mounts.chat!==void 0&&(r.chat.mountTarget=e.mounts.chat),r.qna={enabled:e.widgets.qna.enabled},e.mounts.qna!==void 0&&(r.qna.mountTarget=e.mounts.qna),r.simrel={enabled:e.widgets.simrel.enabled},e.mounts.simrel!==void 0&&(r.simrel.mountTarget=e.mounts.simrel),t?.onAddToCart!==void 0&&(r.onAddToCart=t.onAddToCart),t?.onProductNavigate!==void 0&&(r.onProductNavigate=t.onProductNavigate),t?.onScriptCall!==void 0&&(r.onScriptCall=t.onScriptCall),r}async function y(e){let n=_(e.runtimeConfig);if(e.preflight!==!1){let e=g(n);if(!e.ok){let t=e.warnings.filter(e=>e.severity===`error`);throw Error(`[gengage] Preflight failed: ${t.map(e=>e.message).join(`; `)}`)}}let r=e.contextResolver?.(),i=await t.l(v(n,e.hostActions,r));if(e.contextResolver!==void 0){let t=e.contextResolver,n=()=>{let e=t();i.updateContext(e)};window.addEventListener(`gengage:context:update`,n);let r=i.destroy.bind(i);i.destroy=()=>{window.removeEventListener(`gengage:context:update`,n),r()}}return i}var b=[{pageType:`home`,urlPatterns:[`^/$`,`^/index\\.html?$`,`^/anasayfa$`]},{pageType:`search`,urlPatterns:[`/arama`,`/search`,`/ara\\?`],queryParam:`q`},{pageType:`cart`,urlPatterns:[`/sepet`,`/cart`,`/basket`,`/sepetim`]},{pageType:`plp`,urlPatterns:[`/kategori/`,`/category/`,`/c/`,`/koleksiyon/`,`/collection/`]},{pageType:`pdp`,urlPatterns:[`/urun/`,`/product/`,`/p/`,`/-p-`,`/-pm-`]}];function x(e,t){let n=t??(typeof window<`u`?new URL(window.location.href):null);if(!n)return`other`;let r=e??b,i=n.pathname;for(let e of r)if(!(e.urlPatterns&&!e.urlPatterns.some(e=>{try{return new RegExp(e,`i`).test(i)}catch{return!1}}))&&!(e.queryParam&&!n.searchParams.has(e.queryParam))&&!(e.selector&&typeof document<`u`&&!document.querySelector(e.selector)))return e.pageType;return`other`}function S(e){let t=e??(typeof window<`u`?new URL(window.location.href):null);if(!t)return;let n=t.pathname,r=n.match(/\/(?:p|urun|product)\/([^/?#]+)/i);if(r?.[1])return r[1];let i=n.match(/-p-(\d+)/i);if(i?.[1])return i[1]}function C(e){let t=x(e),n={pageType:t};if(t===`pdp`){let e=S();e&&(n.sku=e)}return typeof window<`u`&&(n.url=window.location.href),n}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return x}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return f}});
2
- //# sourceMappingURL=common-DAF9EBzS.cjs.map
1
+ const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./native-webview-BOmxxjcL.cjs`);var n={enabled:!0,endpoint:`/analytics`,fireAndForget:!0,useBeacon:!0,keepaliveFetch:!0,timeoutMs:4e3,maxRetries:0,batchSize:10,flushIntervalMs:250},r={mode:`none`,key:``,headerName:`X-API-Key`,bodyField:`api_key`},i=class{constructor(e){this.queue=[],this.flushTimer=null,this.config={...n,...e,auth:{...r,...e.auth??{}}},this.onPageHideBound=()=>{this.queue.length!==0&&this.flushAllSync()},typeof window<`u`&&window.addEventListener(`pagehide`,this.onPageHideBound)}track(e){if(!this.config.enabled)return;let t=o(e);if(this.queue.push(t),this.queue.length>=this.config.batchSize){this.scheduleImmediateFlush();return}this.scheduleFlush()}flush(){if(!this.config.enabled||this.queue.length===0)return;let e=this.queue.splice(0,this.config.batchSize),t=this.buildTransportBody(e),n=s(this.config.endpoint,this.config.middlewareUrl);this.send(n,t)}flushAll(){for(;this.queue.length>0;)this.flush()}destroy(){this.flushTimer&&=(clearTimeout(this.flushTimer),null),this.queue.length>0&&this.flushAllSync(),typeof window<`u`&&window.removeEventListener(`pagehide`,this.onPageHideBound)}scheduleFlush(){this.flushTimer||=setTimeout(()=>{this.flushTimer=null,this.flush()},this.config.flushIntervalMs)}scheduleImmediateFlush(){this.flushTimer&&=(clearTimeout(this.flushTimer),null),this.flush()}buildTransportBody(e){let t={events:e};return this.config.auth.mode===`body-api-key`&&this.config.auth.key&&(t[this.config.auth.bodyField]=this.config.auth.key),t}send(e,t){try{let n=JSON.stringify(t);if(this.config.useBeacon&&this.config.auth.mode!==`x-api-key-header`&&this.config.auth.mode!==`bearer-header`&&c()){let t=new Blob([n],{type:`application/json`});navigator.sendBeacon(e,t);return}if(typeof fetch>`u`)return;let r={"Content-Type":`application/json`};this.config.auth.mode===`x-api-key-header`&&this.config.auth.key&&(r[this.config.auth.headerName]=this.config.auth.key),this.config.auth.mode===`bearer-header`&&this.config.auth.key&&(r.Authorization=`Bearer ${this.config.auth.key}`),fetch(e,{method:`POST`,headers:r,body:n,keepalive:!0}).catch(()=>{})}catch{}}flushAllSync(){if(!this.config.enabled)return;let e=s(this.config.endpoint,this.config.middlewareUrl);for(;this.queue.length>0;){let t=this.queue.splice(0,this.config.batchSize),n=this.buildTransportBody(t);try{let t=JSON.stringify(n);if(c()){let n=new Blob([t],{type:`application/json`});navigator.sendBeacon(e,n)}}catch{}}}};function a(e){return new i(e)}function o(e){let t={event_name:e.event_name,event_version:e.event_version??`1`,timestamp_ms:e.timestamp_ms??Date.now(),account_id:e.account_id,session_id:e.session_id,correlation_id:e.correlation_id,payload:e.payload};return e.view_id!==void 0&&(t.view_id=e.view_id),e.user_id!==void 0&&(t.user_id=e.user_id),e.widget!==void 0&&(t.widget=e.widget),e.page_type!==void 0&&(t.page_type=e.page_type),e.sku!==void 0&&(t.sku=e.sku),t}function s(t,n){return/^https?:\/\//i.test(t)?t:`${e.f(n)}${t.startsWith(`/`)?t:`/${t}`}`}function c(){return typeof navigator<`u`&&typeof navigator.sendBeacon==`function`}var l=`tr`;function u(e){return{ACCOUNT_ID:e.accountId,MIDDLEWARE_URL:e.middlewareUrl,LOCALE:e.locale??`tr`}}function d(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},variant:`floating`,locale:e.locale??`tr`,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function f(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},pageContext:{pageType:`pdp`,sku:e.sku},mountTarget:e.mountTarget,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function p(e,t={}){let n={accountId:e.accountId,middlewareUrl:e.middlewareUrl,session:{sessionId:e.sessionId},sku:e.sku,mountTarget:e.mountTarget,...t};return e.theme!==void 0&&(n.theme=e.theme),n}function m(e,t={}){return{enabled:!0,middlewareUrl:e,endpoint:`/analytics`,fireAndForget:!0,useBeacon:!0,...t}}function h(e){try{return document.querySelector(e),!0}catch{return!1}}function g(e,t){let n=[],r=e.mounts,i=[[`qna`,r.qna],[`simrel`,r.simrel],[`chat`,r.chat]];for(let[e,t]of i)if(t!==void 0){if(!h(t)){n.push({code:`INVALID_SELECTOR`,message:`[gengage preflight] ${e} mount selector is invalid CSS: "${t}"`,severity:`error`});continue}document.querySelector(t)||n.push({code:`MOUNT_NOT_FOUND`,message:`[gengage preflight] ${e} mount target not found: "${t}" — widget will skip or wait for DOM`,severity:`warn`})}let a=e.gtm.idempotencyKey;if(window[a]!==void 0&&n.push({code:`DUPLICATE_IDEMPOTENCY`,message:`[gengage preflight] window["${a}"] already exists — widgets may have already initialized`,severity:`warn`}),!t?.skipCspCheck){let t=!1,r=n=>{n.blockedURI&&e.middlewareUrl.startsWith(n.blockedURI)&&(t=!0)};document.addEventListener(`securitypolicyviolation`,r);try{fetch(e.middlewareUrl,{method:`HEAD`,mode:`no-cors`}).catch(()=>{})}catch{t=!0}document.removeEventListener(`securitypolicyviolation`,r),t&&n.push({code:`CSP_BLOCKED`,message:`[gengage preflight] middleware URL may be blocked by Content-Security-Policy: "${e.middlewareUrl}". Add it to connect-src.`,severity:`warn`})}for(let e of n)e.severity===`error`?console.error(e.message):console.warn(e.message);return{ok:n.every(e=>e.severity!==`error`),warnings:n}}function _(e){let n=t.h(e);if(!n.success){let e=n.error.issues.map(e=>`${e.path.join(`.`)}: ${e.message}`).join(`; `);throw Error(`[gengage] Invalid runtime config: ${e}`)}return n.data}function v(e,t,n){let r={accountId:e.accountId,middlewareUrl:e.middlewareUrl,idempotencyKey:e.gtm.idempotencyKey};return e.locale!==void 0&&(r.locale=e.locale),n!==void 0&&(r.pageContext=n,n.sku!==void 0&&(r.sku=n.sku)),r.chat={enabled:e.widgets.chat.enabled},e.mounts.chat!==void 0&&(r.chat.mountTarget=e.mounts.chat),r.qna={enabled:e.widgets.qna.enabled},e.mounts.qna!==void 0&&(r.qna.mountTarget=e.mounts.qna),r.simrel={enabled:e.widgets.simrel.enabled},e.mounts.simrel!==void 0&&(r.simrel.mountTarget=e.mounts.simrel),t?.onAddToCart!==void 0&&(r.onAddToCart=t.onAddToCart),t?.onProductNavigate!==void 0&&(r.onProductNavigate=t.onProductNavigate),t?.onScriptCall!==void 0&&(r.onScriptCall=t.onScriptCall),r}async function y(e){let n=_(e.runtimeConfig);if(e.preflight!==!1){let e=g(n);if(!e.ok){let t=e.warnings.filter(e=>e.severity===`error`);throw Error(`[gengage] Preflight failed: ${t.map(e=>e.message).join(`; `)}`)}}let r=e.contextResolver?.(),i=await t.l(v(n,e.hostActions,r));if(e.contextResolver!==void 0){let t=e.contextResolver,n=()=>{let e=t();i.updateContext(e)};window.addEventListener(`gengage:context:update`,n);let r=i.destroy.bind(i);i.destroy=()=>{window.removeEventListener(`gengage:context:update`,n),r()}}return i}var b=[{pageType:`home`,urlPatterns:[`^/$`,`^/index\\.html?$`,`^/anasayfa$`]},{pageType:`search`,urlPatterns:[`/arama`,`/search`,`/ara\\?`],queryParam:`q`},{pageType:`cart`,urlPatterns:[`/sepet`,`/cart`,`/basket`,`/sepetim`]},{pageType:`plp`,urlPatterns:[`/kategori/`,`/category/`,`/c/`,`/koleksiyon/`,`/collection/`]},{pageType:`pdp`,urlPatterns:[`/urun/`,`/product/`,`/p/`,`/-p-`,`/-pm-`]}];function x(e,t){let n=t??(typeof window<`u`?new URL(window.location.href):null);if(!n)return`other`;let r=e??b,i=n.pathname;for(let e of r)if(!(e.urlPatterns&&!e.urlPatterns.some(e=>{try{return new RegExp(e,`i`).test(i)}catch{return!1}}))&&!(e.queryParam&&!n.searchParams.has(e.queryParam))&&!(e.selector&&typeof document<`u`&&!document.querySelector(e.selector)))return e.pageType;return`other`}function S(e){let t=e??(typeof window<`u`?new URL(window.location.href):null);if(!t)return;let n=t.pathname,r=n.match(/\/(?:p|urun|product)\/([^/?#]+)/i);if(r?.[1])return r[1];let i=n.match(/-p-(\d+)/i);if(i?.[1])return i[1]}function C(e){let t=x(e),n={pageType:t};if(t===`pdp`){let e=S();e&&(n.sku=e)}return typeof window<`u`&&(n.url=window.location.href),n}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return g}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return p}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return d}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return x}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return a}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return u}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return f}});
2
+ //# sourceMappingURL=common-DUmbdVSa.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"common-DAF9EBzS.cjs","names":[],"sources":["../src/common/analytics.ts","../src/common/customization-factories.ts","../src/common/preflight.ts","../src/common/client.ts","../src/common/page-detect.ts"],"sourcesContent":["import { normalizeMiddlewareUrl } from './api-paths.js';\nimport type { AnalyticsAuthMode } from './config-schema.js';\n\nexport interface AnalyticsEnvelope {\n event_name: string;\n event_version: '1';\n timestamp_ms: number;\n account_id: string;\n session_id: string;\n correlation_id: string;\n view_id?: string;\n user_id?: string;\n widget?: 'chat' | 'qna' | 'simrel';\n page_type?: string;\n sku?: string;\n payload: Record<string, unknown>;\n}\n\nexport interface AnalyticsAuthConfig {\n mode?: AnalyticsAuthMode;\n key?: string;\n headerName?: string;\n bodyField?: string;\n}\n\nexport interface AnalyticsClientConfig {\n enabled?: boolean;\n middlewareUrl: string;\n endpoint?: string;\n auth?: AnalyticsAuthConfig;\n fireAndForget?: boolean;\n useBeacon?: boolean;\n keepaliveFetch?: boolean;\n timeoutMs?: number;\n maxRetries?: number;\n batchSize?: number;\n flushIntervalMs?: number;\n}\n\nexport type AnalyticsInput = Omit<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'> &\n Partial<Pick<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'>>;\n\ninterface AnalyticsTransportBody {\n events: AnalyticsEnvelope[];\n [extra: string]: unknown;\n}\n\nconst DEFAULT_ANALYTICS_CONFIG: Required<Omit<AnalyticsClientConfig, 'auth' | 'middlewareUrl'>> = {\n enabled: true,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n keepaliveFetch: true,\n timeoutMs: 4000,\n maxRetries: 0,\n batchSize: 10,\n flushIntervalMs: 250,\n};\n\nconst DEFAULT_AUTH: Required<AnalyticsAuthConfig> = {\n mode: 'none',\n key: '',\n headerName: 'X-API-Key',\n bodyField: 'api_key',\n};\n\n/**\n * Fire-and-forget analytics client.\n *\n * All transport errors are silently suppressed — the backend analytics\n * endpoint is not yet implemented, so callers must never observe failures.\n */\nexport class AnalyticsClient {\n private readonly config: Required<Omit<AnalyticsClientConfig, 'auth'>> & { auth: Required<AnalyticsAuthConfig> };\n private readonly queue: AnalyticsEnvelope[] = [];\n private flushTimer: ReturnType<typeof setTimeout> | null = null;\n private readonly onPageHideBound: () => void;\n\n constructor(config: AnalyticsClientConfig) {\n this.config = {\n ...DEFAULT_ANALYTICS_CONFIG,\n ...config,\n auth: {\n ...DEFAULT_AUTH,\n ...(config.auth ?? {}),\n },\n };\n\n this.onPageHideBound = () => {\n if (this.queue.length === 0) return;\n this.flushAllSync();\n };\n\n if (typeof window !== 'undefined') {\n window.addEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n track(input: AnalyticsInput): void {\n if (!this.config.enabled) return;\n const envelope = normalizeAnalyticsInput(input);\n this.queue.push(envelope);\n\n if (this.queue.length >= this.config.batchSize) {\n this.scheduleImmediateFlush();\n return;\n }\n\n this.scheduleFlush();\n }\n\n flush(): void {\n if (!this.config.enabled || this.queue.length === 0) return;\n\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n\n this.send(endpoint, body);\n }\n\n /** Drain the entire queue synchronously (used on page hide). */\n flushAll(): void {\n while (this.queue.length > 0) {\n this.flush();\n }\n }\n\n destroy(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n if (this.queue.length > 0) {\n this.flushAllSync();\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n private scheduleFlush(): void {\n if (this.flushTimer) return;\n this.flushTimer = setTimeout(() => {\n this.flushTimer = null;\n this.flush();\n }, this.config.flushIntervalMs);\n }\n\n private scheduleImmediateFlush(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n this.flush();\n }\n\n private buildTransportBody(events: AnalyticsEnvelope[]): AnalyticsTransportBody {\n const body: AnalyticsTransportBody = { events };\n if (this.config.auth.mode === 'body-api-key' && this.config.auth.key) {\n body[this.config.auth.bodyField] = this.config.auth.key;\n }\n return body;\n }\n\n /** Best-effort send — all errors silently suppressed. */\n private send(endpoint: string, body: AnalyticsTransportBody): void {\n try {\n const payload = JSON.stringify(body);\n\n // Prefer sendBeacon (works during page unload, no response needed)\n if (\n this.config.useBeacon &&\n this.config.auth.mode !== 'x-api-key-header' &&\n this.config.auth.mode !== 'bearer-header' &&\n hasSendBeacon()\n ) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n return;\n }\n\n if (typeof fetch === 'undefined') return;\n\n const headers: Record<string, string> = { 'Content-Type': 'application/json' };\n if (this.config.auth.mode === 'x-api-key-header' && this.config.auth.key) {\n headers[this.config.auth.headerName] = this.config.auth.key;\n }\n if (this.config.auth.mode === 'bearer-header' && this.config.auth.key) {\n headers.Authorization = `Bearer ${this.config.auth.key}`;\n }\n\n // Fire-and-forget: no await, no error handling, keepalive for page unload\n void fetch(endpoint, {\n method: 'POST',\n headers,\n body: payload,\n keepalive: true,\n }).catch(() => {\n // Silently suppress — backend not implemented yet\n });\n } catch {\n // Silently suppress all errors\n }\n }\n\n /** Synchronous flush using sendBeacon only (for page unload). */\n private flushAllSync(): void {\n if (!this.config.enabled) return;\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n while (this.queue.length > 0) {\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n try {\n const payload = JSON.stringify(body);\n if (hasSendBeacon()) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n }\n } catch {\n // Silently suppress\n }\n }\n }\n}\n\nexport function createAnalyticsClient(config: AnalyticsClientConfig): AnalyticsClient {\n return new AnalyticsClient(config);\n}\n\nfunction normalizeAnalyticsInput(input: AnalyticsInput): AnalyticsEnvelope {\n const envelope: AnalyticsEnvelope = {\n event_name: input.event_name,\n event_version: input.event_version ?? '1',\n timestamp_ms: input.timestamp_ms ?? Date.now(),\n account_id: input.account_id,\n session_id: input.session_id,\n correlation_id: input.correlation_id,\n payload: input.payload,\n };\n\n if (input.view_id !== undefined) envelope.view_id = input.view_id;\n if (input.user_id !== undefined) envelope.user_id = input.user_id;\n if (input.widget !== undefined) envelope.widget = input.widget;\n if (input.page_type !== undefined) envelope.page_type = input.page_type;\n if (input.sku !== undefined) envelope.sku = input.sku;\n\n return envelope;\n}\n\nfunction resolveAnalyticsEndpoint(endpoint: string, middlewareUrl: string): string {\n if (/^https?:\\/\\//i.test(endpoint)) return endpoint;\n const baseUrl = normalizeMiddlewareUrl(middlewareUrl);\n const normalizedEndpoint = endpoint.startsWith('/') ? endpoint : `/${endpoint}`;\n return `${baseUrl}${normalizedEndpoint}`;\n}\n\nfunction hasSendBeacon(): boolean {\n return typeof navigator !== 'undefined' && typeof navigator.sendBeacon === 'function';\n}\n","import type { ChatWidgetConfig } from '../chat/types.js';\nimport type { QNAWidgetConfig } from '../qna/types.js';\nimport type { SimRelWidgetConfig } from '../simrel/types.js';\nimport type { AnalyticsClientConfig } from './analytics.js';\nimport type { WidgetTheme } from './types.js';\n\nexport const DEFAULT_CUSTOMIZATION_LOCALE = 'tr';\n\nexport interface AccountIdentityConfig {\n accountId: string;\n middlewareUrl: string;\n locale?: string;\n}\n\nexport interface AccountIdentity {\n ACCOUNT_ID: string;\n MIDDLEWARE_URL: string;\n LOCALE: string;\n}\n\ninterface BaseAccountWidgetConfigInput {\n accountId: string;\n middlewareUrl: string;\n sessionId: string;\n theme?: WidgetTheme;\n}\n\nexport interface FloatingChatConfigInput extends BaseAccountWidgetConfigInput {\n locale?: string;\n}\n\nexport interface PdpQnaConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: QNAWidgetConfig['mountTarget'];\n}\n\nexport interface PdpSimRelConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: SimRelWidgetConfig['mountTarget'];\n}\n\ntype FloatingChatConfigOverrides = Omit<\n Partial<ChatWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'variant' | 'theme' | 'locale'\n>;\ntype PdpQnaConfigOverrides = Omit<\n Partial<QNAWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'pageContext' | 'mountTarget' | 'theme'\n>;\ntype SimRelAccountConfig = Omit<SimRelWidgetConfig, 'onAddToCart' | 'onProductNavigate'>;\ntype PdpSimRelConfigOverrides = Omit<\n Partial<SimRelAccountConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'sku' | 'mountTarget' | 'theme'\n>;\ntype DefaultAnalyticsConfigOverrides = Omit<AnalyticsClientConfig, 'middlewareUrl'>;\n\n/**\n * Shared account identity factory used by all customization folders.\n * Keeps middleware URL + locale defaults centralized in the SDK layer.\n */\nexport function createAccountIdentity(config: AccountIdentityConfig): AccountIdentity {\n return {\n ACCOUNT_ID: config.accountId,\n MIDDLEWARE_URL: config.middlewareUrl,\n LOCALE: config.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n };\n}\n\n/**\n * Shared floating-chat baseline used by account customizations.\n * Account files only pass differences via `overrides`.\n */\nexport function createFloatingChatConfig(\n input: FloatingChatConfigInput,\n overrides: FloatingChatConfigOverrides = {},\n): ChatWidgetConfig {\n const config: ChatWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n variant: 'floating',\n locale: input.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP QNA baseline used by account customizations.\n */\nexport function createPdpQnaConfig(input: PdpQnaConfigInput, overrides: PdpQnaConfigOverrides = {}): QNAWidgetConfig {\n const config: QNAWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n pageContext: { pageType: 'pdp', sku: input.sku },\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP SimRel baseline used by account customizations.\n * Host-level commerce callbacks stay in account init wrappers.\n */\nexport function createPdpSimRelConfig(\n input: PdpSimRelConfigInput,\n overrides: PdpSimRelConfigOverrides = {},\n): SimRelAccountConfig {\n const config: SimRelAccountConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n sku: input.sku,\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared analytics defaults for account customization wrappers.\n */\nexport function createDefaultAnalyticsConfig(\n middlewareUrl: string,\n overrides: DefaultAnalyticsConfigOverrides = {},\n): AnalyticsClientConfig {\n return {\n enabled: true,\n middlewareUrl,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n ...overrides,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\n\nexport interface PreflightWarning {\n code: string;\n message: string;\n severity: 'warn' | 'error';\n}\n\nexport interface PreflightResult {\n ok: boolean;\n warnings: PreflightWarning[];\n}\n\nfunction isValidSelector(selector: string): boolean {\n try {\n document.querySelector(selector);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function preflightDiagnostics(\n config: AccountRuntimeConfig,\n options?: { skipCspCheck?: boolean },\n): PreflightResult {\n const warnings: PreflightWarning[] = [];\n\n const mounts = config.mounts;\n const mountEntries: Array<[string, string | undefined]> = [\n ['qna', mounts.qna],\n ['simrel', mounts.simrel],\n ['chat', mounts.chat],\n ];\n\n for (const [widget, selector] of mountEntries) {\n if (selector === undefined) continue;\n\n if (!isValidSelector(selector)) {\n warnings.push({\n code: 'INVALID_SELECTOR',\n message: `[gengage preflight] ${widget} mount selector is invalid CSS: \"${selector}\"`,\n severity: 'error',\n });\n continue;\n }\n\n if (!document.querySelector(selector)) {\n warnings.push({\n code: 'MOUNT_NOT_FOUND',\n message: `[gengage preflight] ${widget} mount target not found: \"${selector}\" — widget will skip or wait for DOM`,\n severity: 'warn',\n });\n }\n }\n\n const idempotencyKey = config.gtm.idempotencyKey;\n if ((window as unknown as Record<string, unknown>)[idempotencyKey] !== undefined) {\n warnings.push({\n code: 'DUPLICATE_IDEMPOTENCY',\n message: `[gengage preflight] window[\"${idempotencyKey}\"] already exists — widgets may have already initialized`,\n severity: 'warn',\n });\n }\n\n // CSP connect-src probe: detect if the middleware URL is blocked.\n // Uses a synchronous SecurityPolicyViolationEvent listener to catch CSP blocks.\n if (!options?.skipCspCheck) {\n let cspBlocked = false;\n const cspListener = (e: SecurityPolicyViolationEvent) => {\n if (e.blockedURI && config.middlewareUrl.startsWith(e.blockedURI)) {\n cspBlocked = true;\n }\n };\n document.addEventListener('securitypolicyviolation', cspListener);\n try {\n // A HEAD request with mode 'no-cors' is cheap and triggers CSP if connect-src blocks it.\n void fetch(config.middlewareUrl, { method: 'HEAD', mode: 'no-cors' }).catch(() => {\n /* swallow — we only care about CSP violations, not network errors */\n });\n } catch {\n // fetch itself may throw if CSP blocks it synchronously\n cspBlocked = true;\n }\n // Give the browser a tick to fire the violation event synchronously.\n // If it fired, cspBlocked is already true.\n document.removeEventListener('securitypolicyviolation', cspListener);\n if (cspBlocked) {\n warnings.push({\n code: 'CSP_BLOCKED',\n message: `[gengage preflight] middleware URL may be blocked by Content-Security-Policy: \"${config.middlewareUrl}\". Add it to connect-src.`,\n severity: 'warn',\n });\n }\n }\n\n for (const w of warnings) {\n if (w.severity === 'error') {\n console.error(w.message);\n } else {\n console.warn(w.message);\n }\n }\n\n return {\n ok: warnings.every((w) => w.severity !== 'error'),\n warnings,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\nimport { safeParseAccountRuntimeConfig } from './config-schema.js';\nimport { initOverlayWidgets } from './overlay.js';\nimport type { OverlayWidgetsController, OverlayWidgetsOptions } from './overlay.js';\nimport { preflightDiagnostics } from './preflight.js';\nimport type { PageContext } from './types.js';\n\nexport interface HostActions {\n onAddToCart?: (params: import('./types.js').AddToCartParams) => void;\n onProductNavigate?: (url: string, sku: string, sessionId: string | null) => void;\n onScriptCall?: (params: { name: string; payload?: Record<string, unknown> }) => void;\n}\n\nexport interface GengageClientOptions {\n runtimeConfig: AccountRuntimeConfig | unknown;\n contextResolver?: () => Partial<PageContext>;\n hostActions?: HostActions;\n preflight?: boolean;\n}\n\nfunction parseConfig(raw: AccountRuntimeConfig | unknown): AccountRuntimeConfig {\n const result = safeParseAccountRuntimeConfig(raw);\n if (!result.success) {\n const messages = result.error.issues.map((i) => `${i.path.join('.')}: ${i.message}`).join('; ');\n throw new Error(`[gengage] Invalid runtime config: ${messages}`);\n }\n return result.data;\n}\n\nfunction mapConfigToOverlayOptions(\n config: AccountRuntimeConfig,\n hostActions?: HostActions,\n initialContext?: Partial<PageContext>,\n): OverlayWidgetsOptions {\n const options: OverlayWidgetsOptions = {\n accountId: config.accountId,\n middlewareUrl: config.middlewareUrl,\n idempotencyKey: config.gtm.idempotencyKey,\n };\n\n if (config.locale !== undefined) options.locale = config.locale;\n\n if (initialContext !== undefined) {\n options.pageContext = initialContext;\n if (initialContext.sku !== undefined) options.sku = initialContext.sku;\n }\n\n options.chat = {\n enabled: config.widgets.chat.enabled,\n };\n if (config.mounts.chat !== undefined) {\n options.chat.mountTarget = config.mounts.chat;\n }\n\n options.qna = {\n enabled: config.widgets.qna.enabled,\n };\n if (config.mounts.qna !== undefined) {\n options.qna.mountTarget = config.mounts.qna;\n }\n\n options.simrel = {\n enabled: config.widgets.simrel.enabled,\n };\n if (config.mounts.simrel !== undefined) {\n options.simrel.mountTarget = config.mounts.simrel;\n }\n\n if (hostActions?.onAddToCart !== undefined) {\n options.onAddToCart = hostActions.onAddToCart;\n }\n\n if (hostActions?.onProductNavigate !== undefined) {\n options.onProductNavigate = hostActions.onProductNavigate;\n }\n\n if (hostActions?.onScriptCall !== undefined) {\n options.onScriptCall = hostActions.onScriptCall;\n }\n\n return options;\n}\n\nexport async function initGengageClient(options: GengageClientOptions): Promise<OverlayWidgetsController> {\n const config = parseConfig(options.runtimeConfig);\n\n if (options.preflight !== false) {\n const result = preflightDiagnostics(config);\n if (!result.ok) {\n const errors = result.warnings.filter((w) => w.severity === 'error');\n throw new Error(`[gengage] Preflight failed: ${errors.map((e) => e.message).join('; ')}`);\n }\n }\n\n const initialContext = options.contextResolver?.();\n\n const overlayOptions = mapConfigToOverlayOptions(config, options.hostActions, initialContext);\n const controller = await initOverlayWidgets(overlayOptions);\n\n if (options.contextResolver !== undefined) {\n const resolver = options.contextResolver;\n const listener = () => {\n const ctx = resolver();\n void controller.updateContext(ctx);\n };\n window.addEventListener('gengage:context:update', listener);\n\n // Wrap destroy to remove the listener and prevent a memory leak.\n const originalDestroy = controller.destroy.bind(controller);\n controller.destroy = () => {\n window.removeEventListener('gengage:context:update', listener);\n originalDestroy();\n };\n }\n\n return controller;\n}\n","/**\n * URL-based page type detection.\n *\n * Provides auto-detection of page type from URL patterns and DOM signals.\n * Falls back to 'other' when no rule matches.\n */\n\nimport type { PageContext } from './types.js';\n\nexport type DetectablePageType = PageContext['pageType'];\n\nexport interface PageDetectionRule {\n /** Page type to assign when this rule matches. */\n pageType: DetectablePageType;\n /** URL pathname patterns (tested with `new RegExp(pattern)`). */\n urlPatterns?: string[];\n /** If present, page type is detected only when this query param exists. */\n queryParam?: string;\n /** DOM selector — if an element matching this exists, rule matches. */\n selector?: string;\n}\n\n/** Default rules covering common Turkish e-commerce URL patterns. */\nconst DEFAULT_RULES: PageDetectionRule[] = [\n {\n pageType: 'home',\n urlPatterns: ['^/$', '^/index\\\\.html?$', '^/anasayfa$'],\n },\n {\n pageType: 'search',\n urlPatterns: ['/arama', '/search', '/ara\\\\?'],\n queryParam: 'q',\n },\n {\n pageType: 'cart',\n urlPatterns: ['/sepet', '/cart', '/basket', '/sepetim'],\n },\n {\n pageType: 'plp',\n urlPatterns: ['/kategori/', '/category/', '/c/', '/koleksiyon/', '/collection/'],\n },\n {\n pageType: 'pdp',\n urlPatterns: ['/urun/', '/product/', '/p/', '/-p-', '/-pm-'],\n },\n];\n\n/**\n * Detects page type from the current URL and optional DOM signals.\n *\n * @param rules - Custom rules (defaults to common Turkish e-commerce patterns).\n * @param url - URL to analyze (defaults to window.location).\n * @returns Detected page type, or 'other' if no rule matches.\n */\nexport function detectPageType(rules?: PageDetectionRule[], url?: URL): DetectablePageType {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return 'other';\n\n const effectiveRules = rules ?? DEFAULT_RULES;\n const pathname = loc.pathname;\n\n for (const rule of effectiveRules) {\n // Check URL patterns\n if (rule.urlPatterns) {\n const urlMatch = rule.urlPatterns.some((pattern) => {\n try {\n return new RegExp(pattern, 'i').test(pathname);\n } catch {\n return false;\n }\n });\n if (!urlMatch) continue;\n }\n\n // Check query param requirement\n if (rule.queryParam && !loc.searchParams.has(rule.queryParam)) {\n continue;\n }\n\n // Check DOM selector\n if (rule.selector && typeof document !== 'undefined') {\n if (!document.querySelector(rule.selector)) continue;\n }\n\n return rule.pageType;\n }\n\n return 'other';\n}\n\n/**\n * Attempts to extract a product SKU from the URL path.\n * Looks for common patterns like `/p/SKU`, `/urun/SKU`, `/-p-SKU`.\n */\nexport function extractSkuFromUrl(url?: URL): string | undefined {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return undefined;\n\n const pathname = loc.pathname;\n\n // Pattern: /p/SKU or /urun/SKU or /product/SKU\n const segmentMatch = pathname.match(/\\/(?:p|urun|product)\\/([^/?#]+)/i);\n if (segmentMatch?.[1]) return segmentMatch[1];\n\n // Pattern: -p-SKU at end of path (Trendyol style)\n const suffixMatch = pathname.match(/-p-(\\d+)/i);\n if (suffixMatch?.[1]) return suffixMatch[1];\n\n return undefined;\n}\n\n/**\n * Auto-detects page context from URL and DOM signals.\n * Use as a fallback when the host page doesn't set pageContext explicitly.\n */\nexport function autoDetectPageContext(rules?: PageDetectionRule[]): Partial<PageContext> {\n const pageType = detectPageType(rules);\n const result: Partial<PageContext> = { pageType };\n\n if (pageType === 'pdp') {\n const sku = extractSkuFromUrl();\n if (sku) result.sku = sku;\n }\n\n if (typeof window !== 'undefined') {\n result.url = window.location.href;\n }\n\n return result;\n}\n"],"mappings":"qFA+CA,IAAM,EAA4F,CAChG,QAAS,GACT,SAAU,aACV,cAAe,GACf,UAAW,GACX,eAAgB,GAChB,UAAW,IACX,WAAY,EACZ,UAAW,GACX,gBAAiB,IAClB,CAEK,EAA8C,CAClD,KAAM,OACN,IAAK,GACL,WAAY,YACZ,UAAW,UACZ,CAQY,EAAb,KAA6B,CAM3B,YAAY,EAA+B,YAJG,EAAE,iBACW,KAIzD,KAAK,OAAS,CACZ,GAAG,EACH,GAAG,EACH,KAAM,CACJ,GAAG,EACH,GAAI,EAAO,MAAQ,EAAE,CACtB,CACF,CAED,KAAK,oBAAwB,CACvB,KAAK,MAAM,SAAW,GAC1B,KAAK,cAAc,EAGjB,OAAO,OAAW,KACpB,OAAO,iBAAiB,WAAY,KAAK,gBAAgB,CAI7D,MAAM,EAA6B,CACjC,GAAI,CAAC,KAAK,OAAO,QAAS,OAC1B,IAAM,EAAW,EAAwB,EAAM,CAG/C,GAFA,KAAK,MAAM,KAAK,EAAS,CAErB,KAAK,MAAM,QAAU,KAAK,OAAO,UAAW,CAC9C,KAAK,wBAAwB,CAC7B,OAGF,KAAK,eAAe,CAGtB,OAAc,CACZ,GAAI,CAAC,KAAK,OAAO,SAAW,KAAK,MAAM,SAAW,EAAG,OAErD,IAAM,EAAQ,KAAK,MAAM,OAAO,EAAG,KAAK,OAAO,UAAU,CACnD,EAAO,KAAK,mBAAmB,EAAM,CACrC,EAAW,EAAyB,KAAK,OAAO,SAAU,KAAK,OAAO,cAAc,CAE1F,KAAK,KAAK,EAAU,EAAK,CAI3B,UAAiB,CACf,KAAO,KAAK,MAAM,OAAS,GACzB,KAAK,OAAO,CAIhB,SAAgB,CACd,AAEE,KAAK,cADL,aAAa,KAAK,WAAW,CACX,MAEhB,KAAK,MAAM,OAAS,GACtB,KAAK,cAAc,CAEjB,OAAO,OAAW,KACpB,OAAO,oBAAoB,WAAY,KAAK,gBAAgB,CAIhE,eAA8B,CACxB,AACJ,KAAK,aAAa,eAAiB,CACjC,KAAK,WAAa,KAClB,KAAK,OAAO,EACX,KAAK,OAAO,gBAAgB,CAGjC,wBAAuC,CACrC,AAEE,KAAK,cADL,aAAa,KAAK,WAAW,CACX,MAEpB,KAAK,OAAO,CAGd,mBAA2B,EAAqD,CAC9E,IAAM,EAA+B,CAAE,SAAQ,CAI/C,OAHI,KAAK,OAAO,KAAK,OAAS,gBAAkB,KAAK,OAAO,KAAK,MAC/D,EAAK,KAAK,OAAO,KAAK,WAAa,KAAK,OAAO,KAAK,KAE/C,EAIT,KAAa,EAAkB,EAAoC,CACjE,GAAI,CACF,IAAM,EAAU,KAAK,UAAU,EAAK,CAGpC,GACE,KAAK,OAAO,WACZ,KAAK,OAAO,KAAK,OAAS,oBAC1B,KAAK,OAAO,KAAK,OAAS,iBAC1B,GAAe,CACf,CACA,IAAM,EAAO,IAAI,KAAK,CAAC,EAAQ,CAAE,CAAE,KAAM,mBAAoB,CAAC,CAC9D,UAAU,WAAW,EAAU,EAAK,CACpC,OAGF,GAAI,OAAO,MAAU,IAAa,OAElC,IAAM,EAAkC,CAAE,eAAgB,mBAAoB,CAC1E,KAAK,OAAO,KAAK,OAAS,oBAAsB,KAAK,OAAO,KAAK,MACnE,EAAQ,KAAK,OAAO,KAAK,YAAc,KAAK,OAAO,KAAK,KAEtD,KAAK,OAAO,KAAK,OAAS,iBAAmB,KAAK,OAAO,KAAK,MAChE,EAAQ,cAAgB,UAAU,KAAK,OAAO,KAAK,OAIhD,MAAM,EAAU,CACnB,OAAQ,OACR,UACA,KAAM,EACN,UAAW,GACZ,CAAC,CAAC,UAAY,GAEb,MACI,GAMV,cAA6B,CAC3B,GAAI,CAAC,KAAK,OAAO,QAAS,OAC1B,IAAM,EAAW,EAAyB,KAAK,OAAO,SAAU,KAAK,OAAO,cAAc,CAC1F,KAAO,KAAK,MAAM,OAAS,GAAG,CAC5B,IAAM,EAAQ,KAAK,MAAM,OAAO,EAAG,KAAK,OAAO,UAAU,CACnD,EAAO,KAAK,mBAAmB,EAAM,CAC3C,GAAI,CACF,IAAM,EAAU,KAAK,UAAU,EAAK,CACpC,GAAI,GAAe,CAAE,CACnB,IAAM,EAAO,IAAI,KAAK,CAAC,EAAQ,CAAE,CAAE,KAAM,mBAAoB,CAAC,CAC9D,UAAU,WAAW,EAAU,EAAK,OAEhC,MAOd,SAAgB,EAAsB,EAAgD,CACpF,OAAO,IAAI,EAAgB,EAAO,CAGpC,SAAS,EAAwB,EAA0C,CACzE,IAAM,EAA8B,CAClC,WAAY,EAAM,WAClB,cAAe,EAAM,eAAiB,IACtC,aAAc,EAAM,cAAgB,KAAK,KAAK,CAC9C,WAAY,EAAM,WAClB,WAAY,EAAM,WAClB,eAAgB,EAAM,eACtB,QAAS,EAAM,QAChB,CAQD,OANI,EAAM,UAAY,IAAA,KAAW,EAAS,QAAU,EAAM,SACtD,EAAM,UAAY,IAAA,KAAW,EAAS,QAAU,EAAM,SACtD,EAAM,SAAW,IAAA,KAAW,EAAS,OAAS,EAAM,QACpD,EAAM,YAAc,IAAA,KAAW,EAAS,UAAY,EAAM,WAC1D,EAAM,MAAQ,IAAA,KAAW,EAAS,IAAM,EAAM,KAE3C,EAGT,SAAS,EAAyB,EAAkB,EAA+B,CAIjF,MAHI,gBAAgB,KAAK,EAAS,CAAS,EAGpC,GAFS,EAAA,EAAuB,EAAc,GAC1B,EAAS,WAAW,IAAI,CAAG,EAAW,IAAI,MAIvE,SAAS,GAAyB,CAChC,OAAO,OAAO,UAAc,KAAe,OAAO,UAAU,YAAe,WC5P7E,IAAa,EAA+B,KAsD5C,SAAgB,EAAsB,EAAgD,CACpF,MAAO,CACL,WAAY,EAAO,UACnB,eAAgB,EAAO,cACvB,OAAQ,EAAO,QAAA,KAChB,CAOH,SAAgB,EACd,EACA,EAAyC,EAAE,CACzB,CAClB,IAAM,EAA2B,CAC/B,UAAW,EAAM,UACjB,cAAe,EAAM,cACrB,QAAS,CAAE,UAAW,EAAM,UAAW,CACvC,QAAS,WACT,OAAQ,EAAM,QAAA,KACd,GAAG,EACJ,CAID,OAHI,EAAM,QAAU,IAAA,KAClB,EAAO,MAAQ,EAAM,OAEhB,EAMT,SAAgB,EAAmB,EAA0B,EAAmC,EAAE,CAAmB,CACnH,IAAM,EAA0B,CAC9B,UAAW,EAAM,UACjB,cAAe,EAAM,cACrB,QAAS,CAAE,UAAW,EAAM,UAAW,CACvC,YAAa,CAAE,SAAU,MAAO,IAAK,EAAM,IAAK,CAChD,YAAa,EAAM,YACnB,GAAG,EACJ,CAID,OAHI,EAAM,QAAU,IAAA,KAClB,EAAO,MAAQ,EAAM,OAEhB,EAOT,SAAgB,EACd,EACA,EAAsC,EAAE,CACnB,CACrB,IAAM,EAA8B,CAClC,UAAW,EAAM,UACjB,cAAe,EAAM,cACrB,QAAS,CAAE,UAAW,EAAM,UAAW,CACvC,IAAK,EAAM,IACX,YAAa,EAAM,YACnB,GAAG,EACJ,CAID,OAHI,EAAM,QAAU,IAAA,KAClB,EAAO,MAAQ,EAAM,OAEhB,EAMT,SAAgB,EACd,EACA,EAA6C,EAAE,CACxB,CACvB,MAAO,CACL,QAAS,GACT,gBACA,SAAU,aACV,cAAe,GACf,UAAW,GACX,GAAG,EACJ,CCnIH,SAAS,EAAgB,EAA2B,CAClD,GAAI,CAEF,OADA,SAAS,cAAc,EAAS,CACzB,QACD,CACN,MAAO,IAIX,SAAgB,EACd,EACA,EACiB,CACjB,IAAM,EAA+B,EAAE,CAEjC,EAAS,EAAO,OAChB,EAAoD,CACxD,CAAC,MAAO,EAAO,IAAI,CACnB,CAAC,SAAU,EAAO,OAAO,CACzB,CAAC,OAAQ,EAAO,KAAK,CACtB,CAED,IAAK,GAAM,CAAC,EAAQ,KAAa,EAC3B,OAAa,IAAA,GAEjB,IAAI,CAAC,EAAgB,EAAS,CAAE,CAC9B,EAAS,KAAK,CACZ,KAAM,mBACN,QAAS,uBAAuB,EAAO,mCAAmC,EAAS,GACnF,SAAU,QACX,CAAC,CACF,SAGG,SAAS,cAAc,EAAS,EACnC,EAAS,KAAK,CACZ,KAAM,kBACN,QAAS,uBAAuB,EAAO,4BAA4B,EAAS,sCAC5E,SAAU,OACX,CAAC,CAIN,IAAM,EAAiB,EAAO,IAAI,eAWlC,GAVK,OAA8C,KAAoB,IAAA,IACrE,EAAS,KAAK,CACZ,KAAM,wBACN,QAAS,+BAA+B,EAAe,0DACvD,SAAU,OACX,CAAC,CAKA,CAAC,GAAS,aAAc,CAC1B,IAAI,EAAa,GACX,EAAe,GAAoC,CACnD,EAAE,YAAc,EAAO,cAAc,WAAW,EAAE,WAAW,GAC/D,EAAa,KAGjB,SAAS,iBAAiB,0BAA2B,EAAY,CACjE,GAAI,CAEG,MAAM,EAAO,cAAe,CAAE,OAAQ,OAAQ,KAAM,UAAW,CAAC,CAAC,UAAY,GAEhF,MACI,CAEN,EAAa,GAIf,SAAS,oBAAoB,0BAA2B,EAAY,CAChE,GACF,EAAS,KAAK,CACZ,KAAM,cACN,QAAS,kFAAkF,EAAO,cAAc,2BAChH,SAAU,OACX,CAAC,CAIN,IAAK,IAAM,KAAK,EACV,EAAE,WAAa,QACjB,QAAQ,MAAM,EAAE,QAAQ,CAExB,QAAQ,KAAK,EAAE,QAAQ,CAI3B,MAAO,CACL,GAAI,EAAS,MAAO,GAAM,EAAE,WAAa,QAAQ,CACjD,WACD,CCvFH,SAAS,EAAY,EAA2D,CAC9E,IAAM,EAAS,EAAA,EAA8B,EAAI,CACjD,GAAI,CAAC,EAAO,QAAS,CACnB,IAAM,EAAW,EAAO,MAAM,OAAO,IAAK,GAAM,GAAG,EAAE,KAAK,KAAK,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,KAAK,KAAK,CAC/F,MAAU,MAAM,qCAAqC,IAAW,CAElE,OAAO,EAAO,KAGhB,SAAS,EACP,EACA,EACA,EACuB,CACvB,IAAM,EAAiC,CACrC,UAAW,EAAO,UAClB,cAAe,EAAO,cACtB,eAAgB,EAAO,IAAI,eAC5B,CA0CD,OAxCI,EAAO,SAAW,IAAA,KAAW,EAAQ,OAAS,EAAO,QAErD,IAAmB,IAAA,KACrB,EAAQ,YAAc,EAClB,EAAe,MAAQ,IAAA,KAAW,EAAQ,IAAM,EAAe,MAGrE,EAAQ,KAAO,CACb,QAAS,EAAO,QAAQ,KAAK,QAC9B,CACG,EAAO,OAAO,OAAS,IAAA,KACzB,EAAQ,KAAK,YAAc,EAAO,OAAO,MAG3C,EAAQ,IAAM,CACZ,QAAS,EAAO,QAAQ,IAAI,QAC7B,CACG,EAAO,OAAO,MAAQ,IAAA,KACxB,EAAQ,IAAI,YAAc,EAAO,OAAO,KAG1C,EAAQ,OAAS,CACf,QAAS,EAAO,QAAQ,OAAO,QAChC,CACG,EAAO,OAAO,SAAW,IAAA,KAC3B,EAAQ,OAAO,YAAc,EAAO,OAAO,QAGzC,GAAa,cAAgB,IAAA,KAC/B,EAAQ,YAAc,EAAY,aAGhC,GAAa,oBAAsB,IAAA,KACrC,EAAQ,kBAAoB,EAAY,mBAGtC,GAAa,eAAiB,IAAA,KAChC,EAAQ,aAAe,EAAY,cAG9B,EAGT,eAAsB,EAAkB,EAAkE,CACxG,IAAM,EAAS,EAAY,EAAQ,cAAc,CAEjD,GAAI,EAAQ,YAAc,GAAO,CAC/B,IAAM,EAAS,EAAqB,EAAO,CAC3C,GAAI,CAAC,EAAO,GAAI,CACd,IAAM,EAAS,EAAO,SAAS,OAAQ,GAAM,EAAE,WAAa,QAAQ,CACpE,MAAU,MAAM,+BAA+B,EAAO,IAAK,GAAM,EAAE,QAAQ,CAAC,KAAK,KAAK,GAAG,EAI7F,IAAM,EAAiB,EAAQ,mBAAmB,CAG5C,EAAa,MAAM,EAAA,EADF,EAA0B,EAAQ,EAAQ,YAAa,EAAe,CAClC,CAE3D,GAAI,EAAQ,kBAAoB,IAAA,GAAW,CACzC,IAAM,EAAW,EAAQ,gBACnB,MAAiB,CACrB,IAAM,EAAM,GAAU,CACjB,EAAW,cAAc,EAAI,EAEpC,OAAO,iBAAiB,yBAA0B,EAAS,CAG3D,IAAM,EAAkB,EAAW,QAAQ,KAAK,EAAW,CAC3D,EAAW,YAAgB,CACzB,OAAO,oBAAoB,yBAA0B,EAAS,CAC9D,GAAiB,EAIrB,OAAO,EC5FT,IAAM,EAAqC,CACzC,CACE,SAAU,OACV,YAAa,CAAC,MAAO,mBAAoB,cAAc,CACxD,CACD,CACE,SAAU,SACV,YAAa,CAAC,SAAU,UAAW,UAAU,CAC7C,WAAY,IACb,CACD,CACE,SAAU,OACV,YAAa,CAAC,SAAU,QAAS,UAAW,WAAW,CACxD,CACD,CACE,SAAU,MACV,YAAa,CAAC,aAAc,aAAc,MAAO,eAAgB,eAAe,CACjF,CACD,CACE,SAAU,MACV,YAAa,CAAC,SAAU,YAAa,MAAO,OAAQ,QAAQ,CAC7D,CACF,CASD,SAAgB,EAAe,EAA6B,EAA+B,CACzF,IAAM,EAAM,IAAQ,OAAO,OAAW,IAAc,IAAI,IAAI,OAAO,SAAS,KAAK,CAAG,MACpF,GAAI,CAAC,EAAK,MAAO,QAEjB,IAAM,EAAiB,GAAS,EAC1B,EAAW,EAAI,SAErB,IAAK,IAAM,KAAQ,OAEb,EAAK,aAQH,CAPa,EAAK,YAAY,KAAM,GAAY,CAClD,GAAI,CACF,OAAO,IAAI,OAAO,EAAS,IAAI,CAAC,KAAK,EAAS,MACxC,CACN,MAAO,KAET,GAKA,IAAK,YAAc,CAAC,EAAI,aAAa,IAAI,EAAK,WAAW,KAKzD,EAAK,UAAY,OAAO,SAAa,KACnC,CAAC,SAAS,cAAc,EAAK,SAAS,EAG5C,OAAO,EAAK,SAGd,MAAO,QAOT,SAAgB,EAAkB,EAA+B,CAC/D,IAAM,EAAM,IAAQ,OAAO,OAAW,IAAc,IAAI,IAAI,OAAO,SAAS,KAAK,CAAG,MACpF,GAAI,CAAC,EAAK,OAEV,IAAM,EAAW,EAAI,SAGf,EAAe,EAAS,MAAM,mCAAmC,CACvE,GAAI,IAAe,GAAI,OAAO,EAAa,GAG3C,IAAM,EAAc,EAAS,MAAM,YAAY,CAC/C,GAAI,IAAc,GAAI,OAAO,EAAY,GAS3C,SAAgB,EAAsB,EAAmD,CACvF,IAAM,EAAW,EAAe,EAAM,CAChC,EAA+B,CAAE,WAAU,CAEjD,GAAI,IAAa,MAAO,CACtB,IAAM,EAAM,GAAmB,CAC3B,IAAK,EAAO,IAAM,GAOxB,OAJI,OAAO,OAAW,MACpB,EAAO,IAAM,OAAO,SAAS,MAGxB"}
1
+ {"version":3,"file":"common-DUmbdVSa.cjs","names":[],"sources":["../src/common/analytics.ts","../src/common/customization-factories.ts","../src/common/preflight.ts","../src/common/client.ts","../src/common/page-detect.ts"],"sourcesContent":["import { normalizeMiddlewareUrl } from './api-paths.js';\nimport type { AnalyticsAuthMode } from './config-schema.js';\n\nexport interface AnalyticsEnvelope {\n event_name: string;\n event_version: '1';\n timestamp_ms: number;\n account_id: string;\n session_id: string;\n correlation_id: string;\n view_id?: string;\n user_id?: string;\n widget?: 'chat' | 'qna' | 'simrel';\n page_type?: string;\n sku?: string;\n payload: Record<string, unknown>;\n}\n\nexport interface AnalyticsAuthConfig {\n mode?: AnalyticsAuthMode;\n key?: string;\n headerName?: string;\n bodyField?: string;\n}\n\nexport interface AnalyticsClientConfig {\n enabled?: boolean;\n middlewareUrl: string;\n endpoint?: string;\n auth?: AnalyticsAuthConfig;\n fireAndForget?: boolean;\n useBeacon?: boolean;\n keepaliveFetch?: boolean;\n timeoutMs?: number;\n maxRetries?: number;\n batchSize?: number;\n flushIntervalMs?: number;\n}\n\nexport type AnalyticsInput = Omit<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'> &\n Partial<Pick<AnalyticsEnvelope, 'event_version' | 'timestamp_ms'>>;\n\ninterface AnalyticsTransportBody {\n events: AnalyticsEnvelope[];\n [extra: string]: unknown;\n}\n\nconst DEFAULT_ANALYTICS_CONFIG: Required<Omit<AnalyticsClientConfig, 'auth' | 'middlewareUrl'>> = {\n enabled: true,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n keepaliveFetch: true,\n timeoutMs: 4000,\n maxRetries: 0,\n batchSize: 10,\n flushIntervalMs: 250,\n};\n\nconst DEFAULT_AUTH: Required<AnalyticsAuthConfig> = {\n mode: 'none',\n key: '',\n headerName: 'X-API-Key',\n bodyField: 'api_key',\n};\n\n/**\n * Fire-and-forget analytics client.\n *\n * All transport errors are silently suppressed — the backend analytics\n * endpoint is not yet implemented, so callers must never observe failures.\n */\nexport class AnalyticsClient {\n private readonly config: Required<Omit<AnalyticsClientConfig, 'auth'>> & { auth: Required<AnalyticsAuthConfig> };\n private readonly queue: AnalyticsEnvelope[] = [];\n private flushTimer: ReturnType<typeof setTimeout> | null = null;\n private readonly onPageHideBound: () => void;\n\n constructor(config: AnalyticsClientConfig) {\n this.config = {\n ...DEFAULT_ANALYTICS_CONFIG,\n ...config,\n auth: {\n ...DEFAULT_AUTH,\n ...(config.auth ?? {}),\n },\n };\n\n this.onPageHideBound = () => {\n if (this.queue.length === 0) return;\n this.flushAllSync();\n };\n\n if (typeof window !== 'undefined') {\n window.addEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n track(input: AnalyticsInput): void {\n if (!this.config.enabled) return;\n const envelope = normalizeAnalyticsInput(input);\n this.queue.push(envelope);\n\n if (this.queue.length >= this.config.batchSize) {\n this.scheduleImmediateFlush();\n return;\n }\n\n this.scheduleFlush();\n }\n\n flush(): void {\n if (!this.config.enabled || this.queue.length === 0) return;\n\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n\n this.send(endpoint, body);\n }\n\n /** Drain the entire queue synchronously (used on page hide). */\n flushAll(): void {\n while (this.queue.length > 0) {\n this.flush();\n }\n }\n\n destroy(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n if (this.queue.length > 0) {\n this.flushAllSync();\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('pagehide', this.onPageHideBound);\n }\n }\n\n private scheduleFlush(): void {\n if (this.flushTimer) return;\n this.flushTimer = setTimeout(() => {\n this.flushTimer = null;\n this.flush();\n }, this.config.flushIntervalMs);\n }\n\n private scheduleImmediateFlush(): void {\n if (this.flushTimer) {\n clearTimeout(this.flushTimer);\n this.flushTimer = null;\n }\n this.flush();\n }\n\n private buildTransportBody(events: AnalyticsEnvelope[]): AnalyticsTransportBody {\n const body: AnalyticsTransportBody = { events };\n if (this.config.auth.mode === 'body-api-key' && this.config.auth.key) {\n body[this.config.auth.bodyField] = this.config.auth.key;\n }\n return body;\n }\n\n /** Best-effort send — all errors silently suppressed. */\n private send(endpoint: string, body: AnalyticsTransportBody): void {\n try {\n const payload = JSON.stringify(body);\n\n // Prefer sendBeacon (works during page unload, no response needed)\n if (\n this.config.useBeacon &&\n this.config.auth.mode !== 'x-api-key-header' &&\n this.config.auth.mode !== 'bearer-header' &&\n hasSendBeacon()\n ) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n return;\n }\n\n if (typeof fetch === 'undefined') return;\n\n const headers: Record<string, string> = { 'Content-Type': 'application/json' };\n if (this.config.auth.mode === 'x-api-key-header' && this.config.auth.key) {\n headers[this.config.auth.headerName] = this.config.auth.key;\n }\n if (this.config.auth.mode === 'bearer-header' && this.config.auth.key) {\n headers.Authorization = `Bearer ${this.config.auth.key}`;\n }\n\n // Fire-and-forget: no await, no error handling, keepalive for page unload\n void fetch(endpoint, {\n method: 'POST',\n headers,\n body: payload,\n keepalive: true,\n }).catch(() => {\n // Silently suppress — backend not implemented yet\n });\n } catch {\n // Silently suppress all errors\n }\n }\n\n /** Synchronous flush using sendBeacon only (for page unload). */\n private flushAllSync(): void {\n if (!this.config.enabled) return;\n const endpoint = resolveAnalyticsEndpoint(this.config.endpoint, this.config.middlewareUrl);\n while (this.queue.length > 0) {\n const batch = this.queue.splice(0, this.config.batchSize);\n const body = this.buildTransportBody(batch);\n try {\n const payload = JSON.stringify(body);\n if (hasSendBeacon()) {\n const blob = new Blob([payload], { type: 'application/json' });\n navigator.sendBeacon(endpoint, blob);\n }\n } catch {\n // Silently suppress\n }\n }\n }\n}\n\nexport function createAnalyticsClient(config: AnalyticsClientConfig): AnalyticsClient {\n return new AnalyticsClient(config);\n}\n\nfunction normalizeAnalyticsInput(input: AnalyticsInput): AnalyticsEnvelope {\n const envelope: AnalyticsEnvelope = {\n event_name: input.event_name,\n event_version: input.event_version ?? '1',\n timestamp_ms: input.timestamp_ms ?? Date.now(),\n account_id: input.account_id,\n session_id: input.session_id,\n correlation_id: input.correlation_id,\n payload: input.payload,\n };\n\n if (input.view_id !== undefined) envelope.view_id = input.view_id;\n if (input.user_id !== undefined) envelope.user_id = input.user_id;\n if (input.widget !== undefined) envelope.widget = input.widget;\n if (input.page_type !== undefined) envelope.page_type = input.page_type;\n if (input.sku !== undefined) envelope.sku = input.sku;\n\n return envelope;\n}\n\nfunction resolveAnalyticsEndpoint(endpoint: string, middlewareUrl: string): string {\n if (/^https?:\\/\\//i.test(endpoint)) return endpoint;\n const baseUrl = normalizeMiddlewareUrl(middlewareUrl);\n const normalizedEndpoint = endpoint.startsWith('/') ? endpoint : `/${endpoint}`;\n return `${baseUrl}${normalizedEndpoint}`;\n}\n\nfunction hasSendBeacon(): boolean {\n return typeof navigator !== 'undefined' && typeof navigator.sendBeacon === 'function';\n}\n","import type { ChatWidgetConfig } from '../chat/types.js';\nimport type { QNAWidgetConfig } from '../qna/types.js';\nimport type { SimRelWidgetConfig } from '../simrel/types.js';\nimport type { AnalyticsClientConfig } from './analytics.js';\nimport type { WidgetTheme } from './types.js';\n\nexport const DEFAULT_CUSTOMIZATION_LOCALE = 'tr';\n\nexport interface AccountIdentityConfig {\n accountId: string;\n middlewareUrl: string;\n locale?: string;\n}\n\nexport interface AccountIdentity {\n ACCOUNT_ID: string;\n MIDDLEWARE_URL: string;\n LOCALE: string;\n}\n\ninterface BaseAccountWidgetConfigInput {\n accountId: string;\n middlewareUrl: string;\n sessionId: string;\n theme?: WidgetTheme;\n}\n\nexport interface FloatingChatConfigInput extends BaseAccountWidgetConfigInput {\n locale?: string;\n}\n\nexport interface PdpQnaConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: QNAWidgetConfig['mountTarget'];\n}\n\nexport interface PdpSimRelConfigInput extends BaseAccountWidgetConfigInput {\n sku: string;\n mountTarget: SimRelWidgetConfig['mountTarget'];\n}\n\ntype FloatingChatConfigOverrides = Omit<\n Partial<ChatWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'variant' | 'theme' | 'locale'\n>;\ntype PdpQnaConfigOverrides = Omit<\n Partial<QNAWidgetConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'pageContext' | 'mountTarget' | 'theme'\n>;\ntype SimRelAccountConfig = Omit<SimRelWidgetConfig, 'onAddToCart' | 'onProductNavigate'>;\ntype PdpSimRelConfigOverrides = Omit<\n Partial<SimRelAccountConfig>,\n 'accountId' | 'middlewareUrl' | 'session' | 'sku' | 'mountTarget' | 'theme'\n>;\ntype DefaultAnalyticsConfigOverrides = Omit<AnalyticsClientConfig, 'middlewareUrl'>;\n\n/**\n * Shared account identity factory used by all customization folders.\n * Keeps middleware URL + locale defaults centralized in the SDK layer.\n */\nexport function createAccountIdentity(config: AccountIdentityConfig): AccountIdentity {\n return {\n ACCOUNT_ID: config.accountId,\n MIDDLEWARE_URL: config.middlewareUrl,\n LOCALE: config.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n };\n}\n\n/**\n * Shared floating-chat baseline used by account customizations.\n * Account files only pass differences via `overrides`.\n */\nexport function createFloatingChatConfig(\n input: FloatingChatConfigInput,\n overrides: FloatingChatConfigOverrides = {},\n): ChatWidgetConfig {\n const config: ChatWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n variant: 'floating',\n locale: input.locale ?? DEFAULT_CUSTOMIZATION_LOCALE,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP QNA baseline used by account customizations.\n */\nexport function createPdpQnaConfig(input: PdpQnaConfigInput, overrides: PdpQnaConfigOverrides = {}): QNAWidgetConfig {\n const config: QNAWidgetConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n pageContext: { pageType: 'pdp', sku: input.sku },\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared PDP SimRel baseline used by account customizations.\n * Host-level commerce callbacks stay in account init wrappers.\n */\nexport function createPdpSimRelConfig(\n input: PdpSimRelConfigInput,\n overrides: PdpSimRelConfigOverrides = {},\n): SimRelAccountConfig {\n const config: SimRelAccountConfig = {\n accountId: input.accountId,\n middlewareUrl: input.middlewareUrl,\n session: { sessionId: input.sessionId },\n sku: input.sku,\n mountTarget: input.mountTarget,\n ...overrides,\n };\n if (input.theme !== undefined) {\n config.theme = input.theme;\n }\n return config;\n}\n\n/**\n * Shared analytics defaults for account customization wrappers.\n */\nexport function createDefaultAnalyticsConfig(\n middlewareUrl: string,\n overrides: DefaultAnalyticsConfigOverrides = {},\n): AnalyticsClientConfig {\n return {\n enabled: true,\n middlewareUrl,\n endpoint: '/analytics',\n fireAndForget: true,\n useBeacon: true,\n ...overrides,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\n\nexport interface PreflightWarning {\n code: string;\n message: string;\n severity: 'warn' | 'error';\n}\n\nexport interface PreflightResult {\n ok: boolean;\n warnings: PreflightWarning[];\n}\n\nfunction isValidSelector(selector: string): boolean {\n try {\n document.querySelector(selector);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function preflightDiagnostics(\n config: AccountRuntimeConfig,\n options?: { skipCspCheck?: boolean },\n): PreflightResult {\n const warnings: PreflightWarning[] = [];\n\n const mounts = config.mounts;\n const mountEntries: Array<[string, string | undefined]> = [\n ['qna', mounts.qna],\n ['simrel', mounts.simrel],\n ['chat', mounts.chat],\n ];\n\n for (const [widget, selector] of mountEntries) {\n if (selector === undefined) continue;\n\n if (!isValidSelector(selector)) {\n warnings.push({\n code: 'INVALID_SELECTOR',\n message: `[gengage preflight] ${widget} mount selector is invalid CSS: \"${selector}\"`,\n severity: 'error',\n });\n continue;\n }\n\n if (!document.querySelector(selector)) {\n warnings.push({\n code: 'MOUNT_NOT_FOUND',\n message: `[gengage preflight] ${widget} mount target not found: \"${selector}\" — widget will skip or wait for DOM`,\n severity: 'warn',\n });\n }\n }\n\n const idempotencyKey = config.gtm.idempotencyKey;\n if ((window as unknown as Record<string, unknown>)[idempotencyKey] !== undefined) {\n warnings.push({\n code: 'DUPLICATE_IDEMPOTENCY',\n message: `[gengage preflight] window[\"${idempotencyKey}\"] already exists — widgets may have already initialized`,\n severity: 'warn',\n });\n }\n\n // CSP connect-src probe: detect if the middleware URL is blocked.\n // Uses a synchronous SecurityPolicyViolationEvent listener to catch CSP blocks.\n if (!options?.skipCspCheck) {\n let cspBlocked = false;\n const cspListener = (e: SecurityPolicyViolationEvent) => {\n if (e.blockedURI && config.middlewareUrl.startsWith(e.blockedURI)) {\n cspBlocked = true;\n }\n };\n document.addEventListener('securitypolicyviolation', cspListener);\n try {\n // A HEAD request with mode 'no-cors' is cheap and triggers CSP if connect-src blocks it.\n void fetch(config.middlewareUrl, { method: 'HEAD', mode: 'no-cors' }).catch(() => {\n /* swallow — we only care about CSP violations, not network errors */\n });\n } catch {\n // fetch itself may throw if CSP blocks it synchronously\n cspBlocked = true;\n }\n // Give the browser a tick to fire the violation event synchronously.\n // If it fired, cspBlocked is already true.\n document.removeEventListener('securitypolicyviolation', cspListener);\n if (cspBlocked) {\n warnings.push({\n code: 'CSP_BLOCKED',\n message: `[gengage preflight] middleware URL may be blocked by Content-Security-Policy: \"${config.middlewareUrl}\". Add it to connect-src.`,\n severity: 'warn',\n });\n }\n }\n\n for (const w of warnings) {\n if (w.severity === 'error') {\n console.error(w.message);\n } else {\n console.warn(w.message);\n }\n }\n\n return {\n ok: warnings.every((w) => w.severity !== 'error'),\n warnings,\n };\n}\n","import type { AccountRuntimeConfig } from './config-schema.js';\nimport { safeParseAccountRuntimeConfig } from './config-schema.js';\nimport { initOverlayWidgets } from './overlay.js';\nimport type { OverlayWidgetsController, OverlayWidgetsOptions } from './overlay.js';\nimport { preflightDiagnostics } from './preflight.js';\nimport type { PageContext } from './types.js';\n\nexport interface HostActions {\n onAddToCart?: (params: import('./types.js').AddToCartParams) => void;\n onProductNavigate?: (url: string, sku: string, sessionId: string | null) => void;\n onScriptCall?: (params: { name: string; payload?: Record<string, unknown> }) => void;\n}\n\nexport interface GengageClientOptions {\n runtimeConfig: AccountRuntimeConfig | unknown;\n contextResolver?: () => Partial<PageContext>;\n hostActions?: HostActions;\n preflight?: boolean;\n}\n\nfunction parseConfig(raw: AccountRuntimeConfig | unknown): AccountRuntimeConfig {\n const result = safeParseAccountRuntimeConfig(raw);\n if (!result.success) {\n const messages = result.error.issues.map((i) => `${i.path.join('.')}: ${i.message}`).join('; ');\n throw new Error(`[gengage] Invalid runtime config: ${messages}`);\n }\n return result.data;\n}\n\nfunction mapConfigToOverlayOptions(\n config: AccountRuntimeConfig,\n hostActions?: HostActions,\n initialContext?: Partial<PageContext>,\n): OverlayWidgetsOptions {\n const options: OverlayWidgetsOptions = {\n accountId: config.accountId,\n middlewareUrl: config.middlewareUrl,\n idempotencyKey: config.gtm.idempotencyKey,\n };\n\n if (config.locale !== undefined) options.locale = config.locale;\n\n if (initialContext !== undefined) {\n options.pageContext = initialContext;\n if (initialContext.sku !== undefined) options.sku = initialContext.sku;\n }\n\n options.chat = {\n enabled: config.widgets.chat.enabled,\n };\n if (config.mounts.chat !== undefined) {\n options.chat.mountTarget = config.mounts.chat;\n }\n\n options.qna = {\n enabled: config.widgets.qna.enabled,\n };\n if (config.mounts.qna !== undefined) {\n options.qna.mountTarget = config.mounts.qna;\n }\n\n options.simrel = {\n enabled: config.widgets.simrel.enabled,\n };\n if (config.mounts.simrel !== undefined) {\n options.simrel.mountTarget = config.mounts.simrel;\n }\n\n if (hostActions?.onAddToCart !== undefined) {\n options.onAddToCart = hostActions.onAddToCart;\n }\n\n if (hostActions?.onProductNavigate !== undefined) {\n options.onProductNavigate = hostActions.onProductNavigate;\n }\n\n if (hostActions?.onScriptCall !== undefined) {\n options.onScriptCall = hostActions.onScriptCall;\n }\n\n return options;\n}\n\nexport async function initGengageClient(options: GengageClientOptions): Promise<OverlayWidgetsController> {\n const config = parseConfig(options.runtimeConfig);\n\n if (options.preflight !== false) {\n const result = preflightDiagnostics(config);\n if (!result.ok) {\n const errors = result.warnings.filter((w) => w.severity === 'error');\n throw new Error(`[gengage] Preflight failed: ${errors.map((e) => e.message).join('; ')}`);\n }\n }\n\n const initialContext = options.contextResolver?.();\n\n const overlayOptions = mapConfigToOverlayOptions(config, options.hostActions, initialContext);\n const controller = await initOverlayWidgets(overlayOptions);\n\n if (options.contextResolver !== undefined) {\n const resolver = options.contextResolver;\n const listener = () => {\n const ctx = resolver();\n void controller.updateContext(ctx);\n };\n window.addEventListener('gengage:context:update', listener);\n\n // Wrap destroy to remove the listener and prevent a memory leak.\n const originalDestroy = controller.destroy.bind(controller);\n controller.destroy = () => {\n window.removeEventListener('gengage:context:update', listener);\n originalDestroy();\n };\n }\n\n return controller;\n}\n","/**\n * URL-based page type detection.\n *\n * Provides auto-detection of page type from URL patterns and DOM signals.\n * Falls back to 'other' when no rule matches.\n */\n\nimport type { PageContext } from './types.js';\n\nexport type DetectablePageType = PageContext['pageType'];\n\nexport interface PageDetectionRule {\n /** Page type to assign when this rule matches. */\n pageType: DetectablePageType;\n /** URL pathname patterns (tested with `new RegExp(pattern)`). */\n urlPatterns?: string[];\n /** If present, page type is detected only when this query param exists. */\n queryParam?: string;\n /** DOM selector — if an element matching this exists, rule matches. */\n selector?: string;\n}\n\n/** Default rules covering common Turkish e-commerce URL patterns. */\nconst DEFAULT_RULES: PageDetectionRule[] = [\n {\n pageType: 'home',\n urlPatterns: ['^/$', '^/index\\\\.html?$', '^/anasayfa$'],\n },\n {\n pageType: 'search',\n urlPatterns: ['/arama', '/search', '/ara\\\\?'],\n queryParam: 'q',\n },\n {\n pageType: 'cart',\n urlPatterns: ['/sepet', '/cart', '/basket', '/sepetim'],\n },\n {\n pageType: 'plp',\n urlPatterns: ['/kategori/', '/category/', '/c/', '/koleksiyon/', '/collection/'],\n },\n {\n pageType: 'pdp',\n urlPatterns: ['/urun/', '/product/', '/p/', '/-p-', '/-pm-'],\n },\n];\n\n/**\n * Detects page type from the current URL and optional DOM signals.\n *\n * @param rules - Custom rules (defaults to common Turkish e-commerce patterns).\n * @param url - URL to analyze (defaults to window.location).\n * @returns Detected page type, or 'other' if no rule matches.\n */\nexport function detectPageType(rules?: PageDetectionRule[], url?: URL): DetectablePageType {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return 'other';\n\n const effectiveRules = rules ?? DEFAULT_RULES;\n const pathname = loc.pathname;\n\n for (const rule of effectiveRules) {\n // Check URL patterns\n if (rule.urlPatterns) {\n const urlMatch = rule.urlPatterns.some((pattern) => {\n try {\n return new RegExp(pattern, 'i').test(pathname);\n } catch {\n return false;\n }\n });\n if (!urlMatch) continue;\n }\n\n // Check query param requirement\n if (rule.queryParam && !loc.searchParams.has(rule.queryParam)) {\n continue;\n }\n\n // Check DOM selector\n if (rule.selector && typeof document !== 'undefined') {\n if (!document.querySelector(rule.selector)) continue;\n }\n\n return rule.pageType;\n }\n\n return 'other';\n}\n\n/**\n * Attempts to extract a product SKU from the URL path.\n * Looks for common patterns like `/p/SKU`, `/urun/SKU`, `/-p-SKU`.\n */\nexport function extractSkuFromUrl(url?: URL): string | undefined {\n const loc = url ?? (typeof window !== 'undefined' ? new URL(window.location.href) : null);\n if (!loc) return undefined;\n\n const pathname = loc.pathname;\n\n // Pattern: /p/SKU or /urun/SKU or /product/SKU\n const segmentMatch = pathname.match(/\\/(?:p|urun|product)\\/([^/?#]+)/i);\n if (segmentMatch?.[1]) return segmentMatch[1];\n\n // Pattern: -p-SKU at end of path (Trendyol style)\n const suffixMatch = pathname.match(/-p-(\\d+)/i);\n if (suffixMatch?.[1]) return suffixMatch[1];\n\n return undefined;\n}\n\n/**\n * Auto-detects page context from URL and DOM signals.\n * Use as a fallback when the host page doesn't set pageContext explicitly.\n */\nexport function autoDetectPageContext(rules?: PageDetectionRule[]): Partial<PageContext> {\n const pageType = detectPageType(rules);\n const result: Partial<PageContext> = { pageType };\n\n if (pageType === 'pdp') {\n const sku = extractSkuFromUrl();\n if (sku) result.sku = sku;\n }\n\n if (typeof window !== 'undefined') {\n result.url = window.location.href;\n }\n\n return result;\n}\n"],"mappings":"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"}
package/dist/common.cjs CHANGED
@@ -1 +1 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-CaIq8E2N.cjs`),r=require(`./connection-warning-fwHynNgu.cjs`),i=require(`./native-webview-zQvM9ax7.cjs`),a=require(`./common-DAF9EBzS.cjs`);exports.AccountRuntimeConfigSchema=i.u,exports.AnalyticsAuthModeSchema=i.d,exports.AnalyticsClient=a.f,exports.BASE_WIDGET_THEME=t.E,exports.BaseWidget=t.y,exports.DEFAULT_CUSTOMIZATION_LOCALE=a.o,exports.DEFAULT_WIDGET_THEME_TOKENS=t.O,exports.UnknownActionPolicySchema=i.f,exports.VoiceInput=n.c,exports.adaptBackendEvent=e.p,exports.applyNativeSession=i.n,exports.autoDetectPageContext=a.t,exports.basketAddEvent=t.H,exports.bootstrapSession=t.A,exports.buildChatEndpointUrl=e.d,exports.buildOverlayIdempotencyKey=i.o,exports.chatHistorySnapshotEvent=t.U,exports.checkoutCompleteEvent=t.W,exports.checkoutStartEvent=t.G,exports.configureConnectionWarning=r.t,exports.consumeStream=e.y,exports.createAccountIdentity=a.s,exports.createAnalyticsClient=a.p,exports.createDefaultAccountRuntimeConfig=i.p,exports.createDefaultAnalyticsConfig=a.c,exports.createFloatingChatConfig=a.l,exports.createNativeWebViewBridge=i.r,exports.createPdpQnaConfig=a.u,exports.createPdpSimRelConfig=a.d,exports.defaultUnknownUISpecRenderer=e.S,exports.destroyOverlayWidgets=i.s,exports.detectNativeEnvironment=i.i,exports.detectPageType=a.n,exports.dismissGlobalErrorToast=t.x,exports.dispatch=t.P,exports.extractSkuFromUrl=a.r,exports.getGlobalErrorMessage=t.S,exports.getOverlayWidgets=i.c,exports.getSuggestedSearchKeywords=e._,exports.getSuggestedSearchKeywordsText=e.v,exports.getWindowPageContext=t.j,exports.initGengageClient=a.i,exports.initNativeOverlayWidgets=i.a,exports.initOverlayWidgets=i.l,exports.isVoiceInputSupported=n.l,exports.listen=t.F,exports.llmUsageEvent=t.K,exports.mergeUISpecRegistry=e.x,exports.meteringIncrementEvent=t.q,exports.meteringSummaryEvent=t.J,exports.normalizeMiddlewareUrl=e.f,exports.normalizeProductGroupingsResponse=e.m,exports.normalizeSimilarProductsResponse=e.h,exports.parseAccountRuntimeConfig=i.m,exports.preflightDiagnostics=a.a,exports.productToNormalized=e.g,exports.registerGlobalErrorToastListener=t.w,exports.renderUISpecWithRegistry=e.C,exports.resolveSession=t.M,exports.routeStreamAction=n.p,exports.safeParseAccountRuntimeConfig=i.h,exports.sanitizeHtml=t.V,exports.showGlobalErrorToast=t.T,exports.streamChunkEvent=t.Y,exports.streamDoneEvent=t.X,exports.streamErrorEvent=t.Z,exports.streamPost=e.b,exports.streamStartEvent=t.Q,exports.streamUiSpecEvent=t.$,exports.trackConnectionWarningRequest=r.n,exports.updatePageContext=t.N,exports.widgetHistorySnapshotEvent=t.et,exports.wireGADataLayer=t.v,exports.wireQNAToChat=t.I,exports.wireSimilarToChat=t.L,exports.withBaseTheme=t.D,exports.withDefaultWidgetTheme=t.k;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-Djxk60QW.cjs`),r=require(`./connection-warning-fwHynNgu.cjs`),i=require(`./native-webview-BOmxxjcL.cjs`),a=require(`./common-DUmbdVSa.cjs`);exports.AccountRuntimeConfigSchema=i.u,exports.AnalyticsAuthModeSchema=i.d,exports.AnalyticsClient=a.f,exports.BASE_WIDGET_THEME=t.E,exports.BaseWidget=t.y,exports.DEFAULT_CUSTOMIZATION_LOCALE=a.o,exports.DEFAULT_WIDGET_THEME_TOKENS=t.O,exports.UnknownActionPolicySchema=i.f,exports.VoiceInput=n.c,exports.adaptBackendEvent=e.p,exports.applyNativeSession=i.n,exports.autoDetectPageContext=a.t,exports.basketAddEvent=t.H,exports.bootstrapSession=t.A,exports.buildChatEndpointUrl=e.d,exports.buildOverlayIdempotencyKey=i.o,exports.chatHistorySnapshotEvent=t.U,exports.checkoutCompleteEvent=t.W,exports.checkoutStartEvent=t.G,exports.configureConnectionWarning=r.t,exports.consumeStream=e.y,exports.createAccountIdentity=a.s,exports.createAnalyticsClient=a.p,exports.createDefaultAccountRuntimeConfig=i.p,exports.createDefaultAnalyticsConfig=a.c,exports.createFloatingChatConfig=a.l,exports.createNativeWebViewBridge=i.r,exports.createPdpQnaConfig=a.u,exports.createPdpSimRelConfig=a.d,exports.defaultUnknownUISpecRenderer=e.S,exports.destroyOverlayWidgets=i.s,exports.detectNativeEnvironment=i.i,exports.detectPageType=a.n,exports.dismissGlobalErrorToast=t.x,exports.dispatch=t.P,exports.extractSkuFromUrl=a.r,exports.getGlobalErrorMessage=t.S,exports.getOverlayWidgets=i.c,exports.getSuggestedSearchKeywords=e._,exports.getSuggestedSearchKeywordsText=e.v,exports.getWindowPageContext=t.j,exports.initGengageClient=a.i,exports.initNativeOverlayWidgets=i.a,exports.initOverlayWidgets=i.l,exports.isVoiceInputSupported=n.l,exports.listen=t.F,exports.llmUsageEvent=t.K,exports.mergeUISpecRegistry=e.x,exports.meteringIncrementEvent=t.q,exports.meteringSummaryEvent=t.J,exports.normalizeMiddlewareUrl=e.f,exports.normalizeProductGroupingsResponse=e.m,exports.normalizeSimilarProductsResponse=e.h,exports.parseAccountRuntimeConfig=i.m,exports.preflightDiagnostics=a.a,exports.productToNormalized=e.g,exports.registerGlobalErrorToastListener=t.w,exports.renderUISpecWithRegistry=e.C,exports.resolveSession=t.M,exports.routeStreamAction=n.p,exports.safeParseAccountRuntimeConfig=i.h,exports.sanitizeHtml=t.V,exports.showGlobalErrorToast=t.T,exports.streamChunkEvent=t.Y,exports.streamDoneEvent=t.X,exports.streamErrorEvent=t.Z,exports.streamPost=e.b,exports.streamStartEvent=t.Q,exports.streamUiSpecEvent=t.$,exports.trackConnectionWarningRequest=r.n,exports.updatePageContext=t.N,exports.widgetHistorySnapshotEvent=t.et,exports.wireGADataLayer=t.v,exports.wireQNAToChat=t.I,exports.wireSimilarToChat=t.L,exports.withBaseTheme=t.D,exports.withDefaultWidgetTheme=t.k;
package/dist/common.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { C as e, S as t, _ as n, b as r, d as i, f as a, g as o, h as s, m as c, p as l, v as u, x as d, y as f } from "./schemas-DUid6HBM.js";
2
2
  import { $ as p, A as m, D as h, E as g, F as _, G as v, H as y, I as b, J as x, K as S, L as C, M as w, N as T, O as E, P as D, Q as O, S as k, T as A, U as j, V as M, W as N, X as P, Y as F, Z as I, et as L, j as R, k as z, q as B, v as V, w as H, x as U, y as W } from "./ga-datalayer-DdTUkXC3.js";
3
- import { c as G, l as K, p as q } from "./chat-BOhy7EbK.js";
3
+ import { c as G, l as K, p as q } from "./chat-DIMqb9-7.js";
4
4
  import { n as J, t as Y } from "./connection-warning-COW6YXlM.js";
5
- import { a as X, c as Z, d as Q, f as $, h as ee, i as te, l as ne, m as re, n as ie, o as ae, p as oe, r as se, s as ce, u as le } from "./native-webview-lN2TpszQ.js";
6
- import { a as ue, c as de, d as fe, f as pe, i as me, l as he, n as ge, o as _e, p as ve, r as ye, s as be, t as xe, u as Se } from "./common-CPy4Ugp4.js";
5
+ import { a as X, c as Z, d as Q, f as $, h as ee, i as te, l as ne, m as re, n as ie, o as ae, p as oe, r as se, s as ce, u as le } from "./native-webview-C0Jd4QeV.js";
6
+ import { a as ue, c as de, d as fe, f as pe, i as me, l as he, n as ge, o as _e, p as ve, r as ye, s as be, t as xe, u as Se } from "./common-CEQ7JL8r.js";
7
7
  export { le as AccountRuntimeConfigSchema, Q as AnalyticsAuthModeSchema, pe as AnalyticsClient, g as BASE_WIDGET_THEME, W as BaseWidget, _e as DEFAULT_CUSTOMIZATION_LOCALE, E as DEFAULT_WIDGET_THEME_TOKENS, $ as UnknownActionPolicySchema, G as VoiceInput, l as adaptBackendEvent, ie as applyNativeSession, xe as autoDetectPageContext, y as basketAddEvent, m as bootstrapSession, i as buildChatEndpointUrl, ae as buildOverlayIdempotencyKey, j as chatHistorySnapshotEvent, N as checkoutCompleteEvent, v as checkoutStartEvent, Y as configureConnectionWarning, f as consumeStream, be as createAccountIdentity, ve as createAnalyticsClient, oe as createDefaultAccountRuntimeConfig, de as createDefaultAnalyticsConfig, he as createFloatingChatConfig, se as createNativeWebViewBridge, Se as createPdpQnaConfig, fe as createPdpSimRelConfig, t as defaultUnknownUISpecRenderer, ce as destroyOverlayWidgets, te as detectNativeEnvironment, ge as detectPageType, U as dismissGlobalErrorToast, D as dispatch, ye as extractSkuFromUrl, k as getGlobalErrorMessage, Z as getOverlayWidgets, n as getSuggestedSearchKeywords, u as getSuggestedSearchKeywordsText, R as getWindowPageContext, me as initGengageClient, X as initNativeOverlayWidgets, ne as initOverlayWidgets, K as isVoiceInputSupported, _ as listen, S as llmUsageEvent, d as mergeUISpecRegistry, B as meteringIncrementEvent, x as meteringSummaryEvent, a as normalizeMiddlewareUrl, c as normalizeProductGroupingsResponse, s as normalizeSimilarProductsResponse, re as parseAccountRuntimeConfig, ue as preflightDiagnostics, o as productToNormalized, H as registerGlobalErrorToastListener, e as renderUISpecWithRegistry, w as resolveSession, q as routeStreamAction, ee as safeParseAccountRuntimeConfig, M as sanitizeHtml, A as showGlobalErrorToast, F as streamChunkEvent, P as streamDoneEvent, I as streamErrorEvent, r as streamPost, O as streamStartEvent, p as streamUiSpecEvent, J as trackConnectionWarningRequest, T as updatePageContext, L as widgetHistorySnapshotEvent, V as wireGADataLayer, b as wireQNAToChat, C as wireSimilarToChat, h as withBaseTheme, z as withDefaultWidgetTheme };
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-CaIq8E2N.cjs`),r=require(`./connection-warning-fwHynNgu.cjs`),i=require(`./qna-BzoGBbS8.cjs`),a=require(`./simrel-CT26hFlJ.cjs`),o=require(`./simbut-C8KPNxO1.cjs`),s=require(`./native-webview-zQvM9ax7.cjs`),c=require(`./common-DAF9EBzS.cjs`);exports.AccountRuntimeConfigSchema=s.u,exports.AnalyticsAuthModeSchema=s.d,exports.BASE_WIDGET_THEME=t.E,exports.DEFAULT_CUSTOMIZATION_LOCALE=c.o,exports.DEFAULT_WIDGET_THEME_TOKENS=t.O,exports.GengageChat=n.t,exports.GengageQNA=i.t,exports.GengageSimBut=o.t,exports.GengageSimRel=a.t,exports.UnknownActionPolicySchema=s.f,exports.VoiceInput=n.c,exports.applyNativeSession=s.n,exports.autoDetectPageContext=c.t,exports.bootstrapSession=t.A,exports.buildChatEndpointUrl=e.d,exports.buildOverlayIdempotencyKey=s.o,exports.configureConnectionWarning=r.t,exports.consumeStream=e.y,exports.createAccountIdentity=c.s,exports.createAnalyticsClient=c.p,exports.createChatWidget=n.n,exports.createDefaultAccountRuntimeConfig=s.p,exports.createDefaultAnalyticsConfig=c.c,exports.createDefaultChatUISpecRegistry=n.a,exports.createDefaultQnaUISpecRegistry=i.i,exports.createDefaultSimRelUISpecRegistry=a.i,exports.createFloatingChatConfig=c.l,exports.createNativeWebViewBridge=s.r,exports.createPdpQnaConfig=c.u,exports.createPdpSimRelConfig=c.d,exports.createQNAWidget=i.n,exports.createSimButWidget=o.n,exports.createSimRelWidget=a.n,exports.defaultChatUnknownUISpecRenderer=n.o,exports.defaultQnaUnknownUISpecRenderer=i.a,exports.defaultSimRelUnknownUISpecRenderer=a.a,exports.defaultUnknownUISpecRenderer=e.S,exports.destroyOverlayWidgets=s.s,exports.detectNativeEnvironment=s.i,exports.detectPageType=c.n,exports.dispatch=t.P,exports.extractSkuFromUrl=c.r,exports.getOverlayWidgets=s.c,exports.initGengageClient=c.i,exports.initNativeOverlayWidgets=s.a,exports.initOverlayWidgets=s.l,exports.isVoiceInputSupported=n.l,exports.listen=t.F,exports.normalizeMiddlewareUrl=e.f,exports.parseAccountRuntimeConfig=s.m,exports.preflightDiagnostics=c.a,exports.renderChatUISpec=n.s,exports.renderQnaUISpec=i.o,exports.renderSimRelUISpec=a.o,exports.renderUISpecWithRegistry=e.C,exports.routeStreamAction=n.p,exports.safeParseAccountRuntimeConfig=s.h,exports.streamPost=e.b,exports.updatePageContext=t.N,exports.wireGADataLayer=t.v,exports.wireQNAToChat=t.I,exports.wireSimilarToChat=t.L,exports.withBaseTheme=t.D,exports.withDefaultWidgetTheme=t.k;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-Djxk60QW.cjs`),r=require(`./connection-warning-fwHynNgu.cjs`),i=require(`./qna-DvgpFom7.cjs`),a=require(`./simrel-CT26hFlJ.cjs`),o=require(`./simbut-C8KPNxO1.cjs`),s=require(`./native-webview-BOmxxjcL.cjs`),c=require(`./common-DUmbdVSa.cjs`);exports.AccountRuntimeConfigSchema=s.u,exports.AnalyticsAuthModeSchema=s.d,exports.BASE_WIDGET_THEME=t.E,exports.DEFAULT_CUSTOMIZATION_LOCALE=c.o,exports.DEFAULT_WIDGET_THEME_TOKENS=t.O,exports.GengageChat=n.t,exports.GengageQNA=i.t,exports.GengageSimBut=o.t,exports.GengageSimRel=a.t,exports.UnknownActionPolicySchema=s.f,exports.VoiceInput=n.c,exports.applyNativeSession=s.n,exports.autoDetectPageContext=c.t,exports.bootstrapSession=t.A,exports.buildChatEndpointUrl=e.d,exports.buildOverlayIdempotencyKey=s.o,exports.configureConnectionWarning=r.t,exports.consumeStream=e.y,exports.createAccountIdentity=c.s,exports.createAnalyticsClient=c.p,exports.createChatWidget=n.n,exports.createDefaultAccountRuntimeConfig=s.p,exports.createDefaultAnalyticsConfig=c.c,exports.createDefaultChatUISpecRegistry=n.a,exports.createDefaultQnaUISpecRegistry=i.i,exports.createDefaultSimRelUISpecRegistry=a.i,exports.createFloatingChatConfig=c.l,exports.createNativeWebViewBridge=s.r,exports.createPdpQnaConfig=c.u,exports.createPdpSimRelConfig=c.d,exports.createQNAWidget=i.n,exports.createSimButWidget=o.n,exports.createSimRelWidget=a.n,exports.defaultChatUnknownUISpecRenderer=n.o,exports.defaultQnaUnknownUISpecRenderer=i.a,exports.defaultSimRelUnknownUISpecRenderer=a.a,exports.defaultUnknownUISpecRenderer=e.S,exports.destroyOverlayWidgets=s.s,exports.detectNativeEnvironment=s.i,exports.detectPageType=c.n,exports.dispatch=t.P,exports.extractSkuFromUrl=c.r,exports.getOverlayWidgets=s.c,exports.initGengageClient=c.i,exports.initNativeOverlayWidgets=s.a,exports.initOverlayWidgets=s.l,exports.isVoiceInputSupported=n.l,exports.listen=t.F,exports.normalizeMiddlewareUrl=e.f,exports.parseAccountRuntimeConfig=s.m,exports.preflightDiagnostics=c.a,exports.renderChatUISpec=n.s,exports.renderQnaUISpec=i.o,exports.renderSimRelUISpec=a.o,exports.renderUISpecWithRegistry=e.C,exports.routeStreamAction=n.p,exports.safeParseAccountRuntimeConfig=s.h,exports.streamPost=e.b,exports.updatePageContext=t.N,exports.wireGADataLayer=t.v,exports.wireQNAToChat=t.I,exports.wireSimilarToChat=t.L,exports.withBaseTheme=t.D,exports.withDefaultWidgetTheme=t.k;
package/dist/index.js CHANGED
@@ -1,10 +1,10 @@
1
1
  import { C as e, S as t, b as n, d as r, f as i, y as a } from "./schemas-DUid6HBM.js";
2
2
  import { A as o, D as s, E as c, F as l, I as u, L as d, N as f, O as p, P as m, k as h, v as g } from "./ga-datalayer-DdTUkXC3.js";
3
- import { a as _, c as v, l as y, n as b, o as x, p as S, s as C, t as w } from "./chat-BOhy7EbK.js";
3
+ import { a as _, c as v, l as y, n as b, o as x, p as S, s as C, t as w } from "./chat-DIMqb9-7.js";
4
4
  import { t as T } from "./connection-warning-COW6YXlM.js";
5
- import { a as E, i as D, n as O, o as k, t as A } from "./qna-BtNfVn3t.js";
5
+ import { a as E, i as D, n as O, o as k, t as A } from "./qna-c7t5suwI.js";
6
6
  import { a as j, i as M, n as N, o as P, t as F } from "./simrel-1J9Ph5k5.js";
7
7
  import { n as I, t as L } from "./simbut-Bk7shcTX.js";
8
- import { a as R, c as z, d as B, f as V, h as H, i as U, l as W, m as G, n as K, o as q, p as J, r as Y, s as X, u as Z } from "./native-webview-lN2TpszQ.js";
9
- import { a as Q, c as $, d as ee, i as te, l as ne, n as re, o as ie, p as ae, r as oe, s as se, t as ce, u as le } from "./common-CPy4Ugp4.js";
8
+ import { a as R, c as z, d as B, f as V, h as H, i as U, l as W, m as G, n as K, o as q, p as J, r as Y, s as X, u as Z } from "./native-webview-C0Jd4QeV.js";
9
+ import { a as Q, c as $, d as ee, i as te, l as ne, n as re, o as ie, p as ae, r as oe, s as se, t as ce, u as le } from "./common-CEQ7JL8r.js";
10
10
  export { Z as AccountRuntimeConfigSchema, B as AnalyticsAuthModeSchema, c as BASE_WIDGET_THEME, ie as DEFAULT_CUSTOMIZATION_LOCALE, p as DEFAULT_WIDGET_THEME_TOKENS, w as GengageChat, A as GengageQNA, L as GengageSimBut, F as GengageSimRel, V as UnknownActionPolicySchema, v as VoiceInput, K as applyNativeSession, ce as autoDetectPageContext, o as bootstrapSession, r as buildChatEndpointUrl, q as buildOverlayIdempotencyKey, T as configureConnectionWarning, a as consumeStream, se as createAccountIdentity, ae as createAnalyticsClient, b as createChatWidget, J as createDefaultAccountRuntimeConfig, $ as createDefaultAnalyticsConfig, _ as createDefaultChatUISpecRegistry, D as createDefaultQnaUISpecRegistry, M as createDefaultSimRelUISpecRegistry, ne as createFloatingChatConfig, Y as createNativeWebViewBridge, le as createPdpQnaConfig, ee as createPdpSimRelConfig, O as createQNAWidget, I as createSimButWidget, N as createSimRelWidget, x as defaultChatUnknownUISpecRenderer, E as defaultQnaUnknownUISpecRenderer, j as defaultSimRelUnknownUISpecRenderer, t as defaultUnknownUISpecRenderer, X as destroyOverlayWidgets, U as detectNativeEnvironment, re as detectPageType, m as dispatch, oe as extractSkuFromUrl, z as getOverlayWidgets, te as initGengageClient, R as initNativeOverlayWidgets, W as initOverlayWidgets, y as isVoiceInputSupported, l as listen, i as normalizeMiddlewareUrl, G as parseAccountRuntimeConfig, Q as preflightDiagnostics, C as renderChatUISpec, k as renderQnaUISpec, P as renderSimRelUISpec, e as renderUISpecWithRegistry, S as routeStreamAction, H as safeParseAccountRuntimeConfig, n as streamPost, f as updatePageContext, g as wireGADataLayer, u as wireQNAToChat, d as wireSimilarToChat, s as withBaseTheme, h as withDefaultWidgetTheme };
@@ -1,2 +1,2 @@
1
- const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-CaIq8E2N.cjs`),r=require(`./qna-BzoGBbS8.cjs`),i=require(`./simrel-CT26hFlJ.cjs`),a=require(`./simbut-C8KPNxO1.cjs`);var o=e.o({enabled:e.r().default(!0)}),s=e.o({chat:e.c().optional(),qna:e.c().optional(),simrel:e.c().optional()}),c=e.o({}),l=e.t([`none`,`x-api-key-header`,`bearer-header`,`body-api-key`]),u=e.o({mode:l.default(`none`),key:e.c().optional(),headerName:e.c().optional(),bodyField:e.c().default(`api_key`)}),d=e.o({enabled:e.r().default(!0),endpoint:e.c().default(`/analytics`),auth:u.default({mode:`none`,bodyField:`api_key`}),fireAndForget:e.r().default(!0),useBeacon:e.r().default(!0),keepaliveFetch:e.r().default(!0),timeoutMs:e.a().int().positive().default(4e3),maxRetries:e.a().int().min(0).max(5).default(1)}),f=`__gengageWidgetsInit`,p=e.o({idempotencyKey:e.c().default(f),requireDomReady:e.r().default(!0)}),m=e.t([`log-and-ignore`,`throw`,`delegate`]),h=e.o({unknownActionPolicy:m.default(`log-and-ignore`),allowScriptCall:e.r().default(!1)}),g=e.o({version:e.i(`1`,{error:`version must be "1"`}),accountId:e.c({error:`accountId must be a non-empty string`}).min(1,{error:`accountId must be a non-empty string`}),middlewareUrl:e.c({error:`middlewareUrl must be a valid URL (e.g. "https://your-backend.example.com")`}).url({error:`middlewareUrl must be a valid URL (e.g. "https://your-backend.example.com")`}),locale:e.c().optional(),widgets:e.o({chat:o.default({enabled:!0}),qna:o.default({enabled:!0}),simrel:o.default({enabled:!0})}),mounts:s.default({}),transport:c.default({}),analytics:d.default({enabled:!0,endpoint:`/analytics`,auth:{mode:`none`,bodyField:`api_key`},fireAndForget:!0,useBeacon:!0,keepaliveFetch:!0,timeoutMs:4e3,maxRetries:1}),gtm:p.default({idempotencyKey:`__gengageWidgetsInit`,requireDomReady:!0}),actionHandling:h.default({unknownActionPolicy:`log-and-ignore`,allowScriptCall:!1})});function _(e){t.b(`config`,`parsing account runtime config`,e);let n=g.parse(e);return t.b(`config`,`config resolved`,{accountId:n.accountId,middlewareUrl:n.middlewareUrl}),n}function v(e){return g.safeParse(e)}function y(e){return _({version:`1`,accountId:e.accountId,middlewareUrl:e.middlewareUrl,locale:e.locale,widgets:{chat:{enabled:!0},qna:{enabled:!0},simrel:{enabled:!0}}})}var b=`${f}_overlay_`,x=`#gengage-qna`,S=`#gengage-simrel`,C=`#gengage-simbut`;function w(){let e=window;return e.__gengageOverlayRegistry||={instances:{},pending:{}},e.__gengageOverlayRegistry}function T(e){let t={pageType:e.pageContext?.pageType??(e.sku===void 0?`other`:`pdp`)},n=e.pageContext;return n?.sku!==void 0&&(t.sku=n.sku),n?.price!==void 0&&(t.price=n.price),n?.categoryTree!==void 0&&(t.categoryTree=n.categoryTree),n?.url!==void 0&&(t.url=n.url),n?.extra!==void 0&&(t.extra=n.extra),e.sku!==void 0&&(t.sku=e.sku),t}function E(e,t){let n={...e,...t,pageType:t.pageType??e.pageType};return t.sku===void 0&&e.sku!==void 0&&(n.sku=e.sku),n}function D(e){return e instanceof HTMLElement||document.querySelector(e)?e:null}function O(e){return e.idempotencyKey??`${b}${e.accountId}`}var k=class{constructor(e,n){this.options=e,this.onDestroy=n,this._chat=null,this._qna=null,this._simrel=null,this._simbut=null,this._analyticsClient=null,this._offQnaWire=null,this._destroyed=!1,this._queue=Promise.resolve(),this._warnedQnaMountMissing=!1,this._warnedSimRelMountMissing=!1,this._warnedSimButMountMissing=!1,this._warnedSimButNoChat=!1,this.idempotencyKey=O(e),this.session=t.M(e.session),this._pageContext=T(e)}get chat(){return this._chat}get qna(){return this._qna}get simrel(){return this._simrel}get simbut(){return this._simbut}get analyticsClient(){return this._analyticsClient}async init(){window.gengage||(window.gengage={}),window.gengage.sessionId=this.session.sessionId,window.gengage.pageContext=this._pageContext,await this._initChat(),this.options.wireQnaToChat!==!1&&(this._offQnaWire=t.I()),await this._syncPdpWidgets(),window.gengage.overlay=this}openChat(e){this._chat?.open(e)}closeChat(){this._chat?.close()}async updateContext(e){this._destroyed||await this._enqueue(async()=>{this._pageContext=E(this._pageContext,e),window.gengage||(window.gengage={}),window.gengage.pageContext=this._pageContext,this._chat?.update(e),this._qna?.update(e),this._simrel?.update(e),this._simbut?.update(e),await this._syncPdpWidgets()})}async updateSku(e,t=`pdp`){await this.updateContext({sku:e,pageType:t})}destroy(){this._destroyed||(this._destroyed=!0,this._offQnaWire?.(),this._offQnaWire=null,this._chat?.destroy(),this._qna?.destroy(),this._simrel?.destroy(),this._simbut?.destroy(),this._chat=null,this._qna=null,this._simrel=null,this._simbut=null,window.gengage?.overlay===this&&delete window.gengage.overlay,this.onDestroy())}async _initChat(){if(this.options.chat?.enabled===!1)return;let e=this.options.middlewareUrl,t={accountId:this.options.accountId,middlewareUrl:e,session:this.session,pageContext:this._pageContext,variant:this.options.chat?.variant??`floating`};this.options.theme!==void 0&&(t.theme=this.options.theme),this.options.locale!==void 0&&(t.locale=this.options.locale),this.options.pricing!==void 0&&(t.pricing=this.options.pricing),this.options.chat?.mountTarget!==void 0&&(t.mountTarget=this.options.chat.mountTarget),this.options.chat?.launcherImageUrl===void 0?this.options.chat?.launcherSvg!==void 0&&(t.launcherSvg=this.options.chat.launcherSvg):t.launcherImageUrl=this.options.chat.launcherImageUrl,this.options.chat?.headerTitle!==void 0&&(t.headerTitle=this.options.chat.headerTitle),this.options.chat?.headerAvatarUrl!==void 0&&(t.headerAvatarUrl=this.options.chat.headerAvatarUrl),this.options.chat?.headerBadge!==void 0&&(t.headerBadge=this.options.chat.headerBadge),this.options.chat?.headerCartUrl!==void 0&&(t.headerCartUrl=this.options.chat.headerCartUrl),this.options.chat?.headerFavoritesToggle!==void 0&&(t.headerFavoritesToggle=this.options.chat.headerFavoritesToggle),this.options.chat?.onFavoritesClick!==void 0&&(t.onFavoritesClick=this.options.chat.onFavoritesClick),this.options.chat?.hideMobileLauncher!==void 0&&(t.hideMobileLauncher=this.options.chat.hideMobileLauncher),this.options.chat?.mobileBreakpoint!==void 0&&(t.mobileBreakpoint=this.options.chat.mobileBreakpoint),this.options.chat?.mobileInitialState!==void 0&&(t.mobileInitialState=this.options.chat.mobileInitialState),this.options.chat?.i18n!==void 0&&(t.i18n=this.options.chat.i18n),this.options.chat?.actionHandling!==void 0&&(t.actionHandling=this.options.chat.actionHandling),this.options.chat?.renderer!==void 0&&(t.renderer=this.options.chat.renderer),this.options.chat?.productDetailsExtended!==void 0&&(t.productDetailsExtended=this.options.chat.productDetailsExtended),this.options.onScriptCall!==void 0&&(t.onScriptCall=this.options.onScriptCall),this.options.onAddToCart!==void 0&&(t.onAddToCart=this.options.onAddToCart),this._chat=new n.t,await this._chat.init(t)}async _syncPdpWidgets(){if(this._destroyed)return;let e=this._pageContext.sku;if(!(this._pageContext.pageType===`pdp`&&e!==void 0&&e.length>0)){this._qna?.hide(),this._simrel?.hide(),this._simbut?.hide();return}let n=this.options.middlewareUrl;if(this.options.qna?.enabled!==!1){let t=this.options.qna?.mountTarget??x,i=D(t);if(i)if(this._warnedQnaMountMissing=!1,this._qna)this._qna.show(),this._qna.update({pageType:`pdp`,sku:e});else{let t=new r.t,a={accountId:this.options.accountId,middlewareUrl:n,session:this.session,pageContext:{pageType:`pdp`,sku:e},mountTarget:i};this.options.theme!==void 0&&(a.theme=this.options.theme),this.options.qna?.ctaText!==void 0&&(a.ctaText=this.options.qna.ctaText),this.options.qna?.hideButtonRowCta!==void 0&&(a.hideButtonRowCta=this.options.qna.hideButtonRowCta),this.options.qna?.inputPlaceholder!==void 0&&(a.inputPlaceholder=this.options.qna.inputPlaceholder),this.options.qna?.i18n!==void 0&&(a.i18n=this.options.qna.i18n),this.options.qna?.renderer!==void 0&&(a.renderer=this.options.qna.renderer),await t.init(a),this._qna=t}else this._qna?.destroy(),this._qna=null,this._warnedQnaMountMissing||=(console.warn(`[gengage] QNA mount target not found: ${t}`),!0)}else this._qna?.destroy(),this._qna=null;if(this.options.simrel?.enabled!==!1){let r=this.options.simrel?.mountTarget??S,a=D(r);if(a)if(this._warnedSimRelMountMissing=!1,this._simrel)this._simrel.show(),this._simrel.update({pageType:`pdp`,sku:e});else{let r=new i.t,o={accountId:this.options.accountId,middlewareUrl:n,session:this.session,sku:e,mountTarget:a};this.options.theme!==void 0&&(o.theme=this.options.theme),this.options.pricing!==void 0&&(o.pricing=this.options.pricing),this.options.simrel?.discountType!==void 0&&(o.discountType=this.options.simrel.discountType),this.options.simrel?.renderCardElement!==void 0&&(o.renderCardElement=this.options.simrel.renderCardElement),this.options.simrel?.renderer!==void 0&&(o.renderer=this.options.simrel.renderer),this.options.onAddToCart!==void 0&&(o.onAddToCart=this.options.onAddToCart),this.options.onProductNavigate===void 0?o.onProductNavigate=(e,n,r)=>{t.z(e)&&(this._chat?.saveSession(r??this.session.sessionId,n),window.location.href=e)}:o.onProductNavigate=this.options.onProductNavigate,await r.init(o),this._simrel=r}else this._simrel?.destroy(),this._simrel=null,this._warnedSimRelMountMissing||=(console.warn(`[gengage] SimRel mount target not found: ${r}`),!0)}else this._simrel?.destroy(),this._simrel=null;if(this.options.simbut&&this.options.simbut.enabled!==!1){let t=this.options.simbut.mountTarget??C,r=D(t),i=this._chat??this.options.simbut.onFindSimilar;if(r&&i)if(this._warnedSimButMountMissing=!1,this._warnedSimButNoChat=!1,this._simbut)this._simbut.show(),this._simbut.setChat(this._chat),this._simbut.update({pageType:`pdp`,sku:e});else{let t=new a.t,i={accountId:this.options.accountId,middlewareUrl:n,session:this.session,pageContext:{pageType:`pdp`,sku:e},mountTarget:r,chat:this._chat};this.options.theme!==void 0&&(i.theme=this.options.theme),this.options.locale!==void 0&&(i.locale=this.options.locale),this.options.simbut.imageUrl!==void 0&&(i.imageUrl=this.options.simbut.imageUrl),this.options.simbut.i18n!==void 0&&(i.i18n=this.options.simbut.i18n),this.options.simbut.onFindSimilar!==void 0&&(i.onFindSimilar=this.options.simbut.onFindSimilar),await t.init(i),this._simbut=t}else this._simbut?.destroy(),this._simbut=null,!r&&!this._warnedSimButMountMissing?(console.warn(`[gengage] SimBut mount target not found: ${t}`),this._warnedSimButMountMissing=!0):!i&&!this._warnedSimButNoChat&&(console.warn(`[gengage] SimBut requires chat to be enabled or simbut.onFindSimilar`),this._warnedSimButNoChat=!0)}else this._simbut?.destroy(),this._simbut=null}_enqueue(e){let t=this._queue.then(e);return this._queue=t.catch(e=>{}),t}};async function A(e){let t=O(e),n=w(),r=n.instances[t];if(r)return r;let i=n.pending[t];if(i)return i;let a=new k(e,()=>{let e=w();delete e.instances[t],delete e.pending[t]}),o=a.init().then(()=>(n.instances[t]=a,delete n.pending[t],a)).catch(e=>{throw delete n.pending[t],e});return n.pending[t]=o,o}function j(e){return w().instances[e]??null}function M(e){j(e)?.destroy()}function N(e){return`${b}${e}`}var P=[`gengage:chat:open`,`gengage:chat:close`,`gengage:chat:ready`,`gengage:chat:add-to-cart`,`gengage:qna:action`,`gengage:qna:open-chat`,`gengage:similar:product-click`,`gengage:similar:add-to-cart`,`gengage:global:error`,`gengage:context:update`],F=32,I=`#gengage-qna`,L=`#gengage-simrel`;function R(e){return e}function z(e){let t=e;if(typeof e==`string`){let n=e.trim();if(n.length===0)return null;if(!n.startsWith(`{`)&&!n.startsWith(`[`))return{type:n};try{t=JSON.parse(n)}catch{return null}}if(!t||typeof t!=`object`)return null;let n=t,r=[n.type,n.command,n.action,n.event].find(e=>typeof e==`string`&&e.length>0);if(!r)return null;let i=n.payload;if(i===void 0&&`data`in n&&(i=n.data),r===`setSession`&&i===void 0){let e={};typeof n.sessionId==`string`&&(e.sessionId=n.sessionId),typeof n.userId==`string`&&(e.userId=n.userId),(e.sessionId!==void 0||e.userId!==void 0)&&(i=e)}return i===void 0?{type:r}:{type:r,payload:i}}function B(e){if(typeof e==`string`&&e.length>0)return{sku:e};if(e&&typeof e==`object`&&`sku`in e){let t=e.sku;if(typeof t==`string`&&t.length>0){let n=e.pageType;return n===void 0?{sku:t}:{sku:t,pageType:n}}}return null}function V(e,t){return t instanceof HTMLElement?!0:typeof t==`string`?e.document.querySelector(t)!==null:!1}function H(e,t,n){if(t instanceof HTMLElement||V(e,t)||typeof t!=`string`)return t;if(t.startsWith(`#`)){let n=t.slice(1);if(n.length>0){let t=e.document.getElementById(n);if(t)return t;let r=e.document.createElement(`div`);return r.id=n,e.document.body.appendChild(r),r}}let r=e.document.getElementById(n);if(r)return r;let i=e.document.createElement(`div`);return i.id=n,e.document.body.appendChild(i),i}function U(e,t){let n=R(e).webkit?.messageHandlers?.[t];return n&&typeof n.postMessage==`function`?n.postMessage.bind(n):null}function W(e,t){let n=e[t];return n&&typeof n==`object`&&typeof n.postMessage==`function`?n:null}function G(e={}){let t=e.win??window,n=e.iosHandlerName??`gengage`,r=e.androidInterfaceName??`GengageNative`,i=e.reactNativeInterfaceName??`ReactNativeWebView`;return U(t,n)?`ios`:W(t,r)?`android`:W(t,i)?`react-native`:`browser`}function K(e,t={}){let n=t.win??window;if(e.sessionId!==void 0){n.__gengageSessionId=e.sessionId,n.gengage||={},n.gengage.sessionId=e.sessionId;try{n.sessionStorage.setItem(`gengage_session_id`,e.sessionId)}catch{}}if(e.userId!==void 0){n.gengage||={};let t=n.gengage,r=t.session??{};r.userId=e.userId,t.session=r}}function q(e={}){let t=e.win??window,n=R(t);if(n.gengageNative)return n.gengageNative;let r=e.iosHandlerName??`gengage`,i=e.androidInterfaceName??`GengageNative`,a=e.reactNativeInterfaceName??`ReactNativeWebView`,o=e.trackedEvents??[...P],s=G({win:t,iosHandlerName:r,androidInterfaceName:i,reactNativeInterfaceName:a}),c=t.gengage?.overlay??null,l=[],u=(e,n)=>{let o=n===void 0?{type:e}:{type:e,payload:n};if(s===`ios`){U(t,r)?.(o);return}if(s===`android`){W(t,i)?.postMessage(JSON.stringify(o));return}if(s===`react-native`){W(t,a)?.postMessage(JSON.stringify(o));return}},d=e=>{let t=e.detail;!t||typeof t.namespace!=`string`||typeof t.type!=`string`||u(`bridge_message`,{namespace:t.namespace,type:t.type,payload:t.payload})};t.addEventListener(`gengage:bridge:message`,d);let f=o.map(e=>{let n=t=>{let n=t.detail;u(`widget_event`,{event:e,detail:n})};return t.addEventListener(e,n),{event:e,handler:n}}),p=e=>{l.length>=F&&l.shift(),l.push(e)},m=()=>{if(!c||l.length===0)return;let e=l.splice(0,l.length);for(let t of e)h(t)},h=n=>{let r=z(n);if(!r||typeof r.type!=`string`){console.warn(`[gengage:native-bridge] Invalid message:`,n);return}let i=r.type,a=r.payload;switch(i){case`openChat`:c?c.openChat(a&&typeof a==`object`?a:a===`half`||a===`full`?{state:a}:void 0):p(r);return;case`closeChat`:c?c.closeChat():p(r);return;case`updateContext`:c&&a&&typeof a==`object`?c.updateContext(a):c?console.warn(`[gengage:native-bridge] updateContext: missing payload`):p(r);return;case`updateSku`:{let e=B(a);if(c&&e){c.updateSku(e.sku,e.pageType);return}c?console.warn(`[gengage:native-bridge] updateSku: missing sku`):p(r);return}case`setSession`:a&&typeof a==`object`&&K(a,{win:t});return;case`destroy`:c?.destroy();return;default:t.postMessage({gengage:`native`,type:i,payload:a},t.location.origin),e.logUnhandled&&console.warn(`[gengage:native-bridge] Unhandled inbound type forwarded:`,i)}},g={env:s,sendToNative:u,receive:h,setController(e){c=e,m()},destroy(){t.removeEventListener(`gengage:bridge:message`,d);for(let e of f)t.removeEventListener(e.event,e.handler);l.splice(0,l.length),R(t).gengageNative===g&&delete R(t).gengageNative}};return n.gengageNative=g,g}async function J(e){let{nativeBridge:t,emitReadyEvent:n=!0,...r}=e,i=q(t),a={...r};a.onAddToCart||=e=>{i.sendToNative(`addToCart`,{sku:e.sku,quantity:e.quantity,cartCode:e.cartCode})},a.onProductNavigate||=(e,t,n)=>{i.sendToNative(`productNavigate`,{url:e,sku:t,sessionId:n})};let o=a.qna?.enabled===!0||a.qna?.mountTarget!==void 0;if(a.qna?.enabled!==!1)if(o){let e=H(window,a.qna?.mountTarget??I,`gengage-qna`);a.qna={...a.qna,enabled:!0,mountTarget:e}}else V(window,I)||(a.qna={enabled:!1});let s=a.simrel?.enabled===!0||a.simrel?.mountTarget!==void 0;if(a.simrel?.enabled!==!1)if(s){let e=H(window,a.simrel?.mountTarget??L,`gengage-simrel`);a.simrel={...a.simrel,enabled:!0,mountTarget:e}}else V(window,L)||(a.simrel={enabled:!1});let c=await A(a);return i.setController(c),n&&i.sendToNative(`ready`,{sessionId:c.session.sessionId,widgets:{chat:c.chat!==null,qna:c.qna!==null,simrel:c.simrel!==null}}),{controller:c,bridge:i,destroy(){c.destroy(),i.destroy()}}}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return j}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return G}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return A}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return K}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return N}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return g}});
2
- //# sourceMappingURL=native-webview-zQvM9ax7.cjs.map
1
+ const e=require(`./schemas-C-giAkv4.cjs`),t=require(`./ga-datalayer-D3upAPs9.cjs`),n=require(`./chat-Djxk60QW.cjs`),r=require(`./qna-DvgpFom7.cjs`),i=require(`./simrel-CT26hFlJ.cjs`),a=require(`./simbut-C8KPNxO1.cjs`);var o=e.o({enabled:e.r().default(!0)}),s=e.o({chat:e.c().optional(),qna:e.c().optional(),simrel:e.c().optional()}),c=e.o({}),l=e.t([`none`,`x-api-key-header`,`bearer-header`,`body-api-key`]),u=e.o({mode:l.default(`none`),key:e.c().optional(),headerName:e.c().optional(),bodyField:e.c().default(`api_key`)}),d=e.o({enabled:e.r().default(!0),endpoint:e.c().default(`/analytics`),auth:u.default({mode:`none`,bodyField:`api_key`}),fireAndForget:e.r().default(!0),useBeacon:e.r().default(!0),keepaliveFetch:e.r().default(!0),timeoutMs:e.a().int().positive().default(4e3),maxRetries:e.a().int().min(0).max(5).default(1)}),f=`__gengageWidgetsInit`,p=e.o({idempotencyKey:e.c().default(f),requireDomReady:e.r().default(!0)}),m=e.t([`log-and-ignore`,`throw`,`delegate`]),h=e.o({unknownActionPolicy:m.default(`log-and-ignore`),allowScriptCall:e.r().default(!1)}),g=e.o({version:e.i(`1`,{error:`version must be "1"`}),accountId:e.c({error:`accountId must be a non-empty string`}).min(1,{error:`accountId must be a non-empty string`}),middlewareUrl:e.c({error:`middlewareUrl must be a valid URL (e.g. "https://your-backend.example.com")`}).url({error:`middlewareUrl must be a valid URL (e.g. "https://your-backend.example.com")`}),locale:e.c().optional(),widgets:e.o({chat:o.default({enabled:!0}),qna:o.default({enabled:!0}),simrel:o.default({enabled:!0})}),mounts:s.default({}),transport:c.default({}),analytics:d.default({enabled:!0,endpoint:`/analytics`,auth:{mode:`none`,bodyField:`api_key`},fireAndForget:!0,useBeacon:!0,keepaliveFetch:!0,timeoutMs:4e3,maxRetries:1}),gtm:p.default({idempotencyKey:`__gengageWidgetsInit`,requireDomReady:!0}),actionHandling:h.default({unknownActionPolicy:`log-and-ignore`,allowScriptCall:!1})});function _(e){t.b(`config`,`parsing account runtime config`,e);let n=g.parse(e);return t.b(`config`,`config resolved`,{accountId:n.accountId,middlewareUrl:n.middlewareUrl}),n}function v(e){return g.safeParse(e)}function y(e){return _({version:`1`,accountId:e.accountId,middlewareUrl:e.middlewareUrl,locale:e.locale,widgets:{chat:{enabled:!0},qna:{enabled:!0},simrel:{enabled:!0}}})}var b=`${f}_overlay_`,x=`#gengage-qna`,S=`#gengage-simrel`,C=`#gengage-simbut`;function w(){let e=window;return e.__gengageOverlayRegistry||={instances:{},pending:{}},e.__gengageOverlayRegistry}function T(e){let t={pageType:e.pageContext?.pageType??(e.sku===void 0?`other`:`pdp`)},n=e.pageContext;return n?.sku!==void 0&&(t.sku=n.sku),n?.price!==void 0&&(t.price=n.price),n?.categoryTree!==void 0&&(t.categoryTree=n.categoryTree),n?.url!==void 0&&(t.url=n.url),n?.extra!==void 0&&(t.extra=n.extra),e.sku!==void 0&&(t.sku=e.sku),t}function E(e,t){let n={...e,...t,pageType:t.pageType??e.pageType};return t.sku===void 0&&e.sku!==void 0&&(n.sku=e.sku),n}function D(e){return e instanceof HTMLElement||document.querySelector(e)?e:null}function O(e){return e.idempotencyKey??`${b}${e.accountId}`}var k=class{constructor(e,n){this.options=e,this.onDestroy=n,this._chat=null,this._qna=null,this._simrel=null,this._simbut=null,this._analyticsClient=null,this._offQnaWire=null,this._destroyed=!1,this._queue=Promise.resolve(),this._warnedQnaMountMissing=!1,this._warnedSimRelMountMissing=!1,this._warnedSimButMountMissing=!1,this._warnedSimButNoChat=!1,this.idempotencyKey=O(e),this.session=t.M(e.session),this._pageContext=T(e)}get chat(){return this._chat}get qna(){return this._qna}get simrel(){return this._simrel}get simbut(){return this._simbut}get analyticsClient(){return this._analyticsClient}async init(){window.gengage||(window.gengage={}),window.gengage.sessionId=this.session.sessionId,window.gengage.pageContext=this._pageContext,await this._initChat(),this.options.wireQnaToChat!==!1&&(this._offQnaWire=t.I()),await this._syncPdpWidgets(),window.gengage.overlay=this}openChat(e){this._chat?.open(e)}closeChat(){this._chat?.close()}async updateContext(e){this._destroyed||await this._enqueue(async()=>{this._pageContext=E(this._pageContext,e),window.gengage||(window.gengage={}),window.gengage.pageContext=this._pageContext,this._chat?.update(e),this._qna?.update(e),this._simrel?.update(e),this._simbut?.update(e),await this._syncPdpWidgets()})}async updateSku(e,t=`pdp`){await this.updateContext({sku:e,pageType:t})}destroy(){this._destroyed||(this._destroyed=!0,this._offQnaWire?.(),this._offQnaWire=null,this._chat?.destroy(),this._qna?.destroy(),this._simrel?.destroy(),this._simbut?.destroy(),this._chat=null,this._qna=null,this._simrel=null,this._simbut=null,window.gengage?.overlay===this&&delete window.gengage.overlay,this.onDestroy())}async _initChat(){if(this.options.chat?.enabled===!1)return;let e=this.options.middlewareUrl,t={accountId:this.options.accountId,middlewareUrl:e,session:this.session,pageContext:this._pageContext,variant:this.options.chat?.variant??`floating`};this.options.theme!==void 0&&(t.theme=this.options.theme),this.options.locale!==void 0&&(t.locale=this.options.locale),this.options.pricing!==void 0&&(t.pricing=this.options.pricing),this.options.chat?.mountTarget!==void 0&&(t.mountTarget=this.options.chat.mountTarget),this.options.chat?.launcherImageUrl===void 0?this.options.chat?.launcherSvg!==void 0&&(t.launcherSvg=this.options.chat.launcherSvg):t.launcherImageUrl=this.options.chat.launcherImageUrl,this.options.chat?.headerTitle!==void 0&&(t.headerTitle=this.options.chat.headerTitle),this.options.chat?.headerAvatarUrl!==void 0&&(t.headerAvatarUrl=this.options.chat.headerAvatarUrl),this.options.chat?.headerBadge!==void 0&&(t.headerBadge=this.options.chat.headerBadge),this.options.chat?.headerCartUrl!==void 0&&(t.headerCartUrl=this.options.chat.headerCartUrl),this.options.chat?.headerFavoritesToggle!==void 0&&(t.headerFavoritesToggle=this.options.chat.headerFavoritesToggle),this.options.chat?.onFavoritesClick!==void 0&&(t.onFavoritesClick=this.options.chat.onFavoritesClick),this.options.chat?.hideMobileLauncher!==void 0&&(t.hideMobileLauncher=this.options.chat.hideMobileLauncher),this.options.chat?.mobileBreakpoint!==void 0&&(t.mobileBreakpoint=this.options.chat.mobileBreakpoint),this.options.chat?.mobileInitialState!==void 0&&(t.mobileInitialState=this.options.chat.mobileInitialState),this.options.chat?.i18n!==void 0&&(t.i18n=this.options.chat.i18n),this.options.chat?.actionHandling!==void 0&&(t.actionHandling=this.options.chat.actionHandling),this.options.chat?.renderer!==void 0&&(t.renderer=this.options.chat.renderer),this.options.chat?.productDetailsExtended!==void 0&&(t.productDetailsExtended=this.options.chat.productDetailsExtended),this.options.onScriptCall!==void 0&&(t.onScriptCall=this.options.onScriptCall),this.options.onAddToCart!==void 0&&(t.onAddToCart=this.options.onAddToCart),this._chat=new n.t,await this._chat.init(t)}async _syncPdpWidgets(){if(this._destroyed)return;let e=this._pageContext.sku;if(!(this._pageContext.pageType===`pdp`&&e!==void 0&&e.length>0)){this._qna?.hide(),this._simrel?.hide(),this._simbut?.hide();return}let n=this.options.middlewareUrl;if(this.options.qna?.enabled!==!1){let t=this.options.qna?.mountTarget??x,i=D(t);if(i)if(this._warnedQnaMountMissing=!1,this._qna)this._qna.show(),this._qna.update({pageType:`pdp`,sku:e});else{let t=new r.t,a={accountId:this.options.accountId,middlewareUrl:n,session:this.session,pageContext:{pageType:`pdp`,sku:e},mountTarget:i};this.options.theme!==void 0&&(a.theme=this.options.theme),this.options.qna?.ctaText!==void 0&&(a.ctaText=this.options.qna.ctaText),this.options.qna?.hideButtonRowCta!==void 0&&(a.hideButtonRowCta=this.options.qna.hideButtonRowCta),this.options.qna?.inputPlaceholder!==void 0&&(a.inputPlaceholder=this.options.qna.inputPlaceholder),this.options.qna?.i18n!==void 0&&(a.i18n=this.options.qna.i18n),this.options.qna?.renderer!==void 0&&(a.renderer=this.options.qna.renderer),await t.init(a),this._qna=t}else this._qna?.destroy(),this._qna=null,this._warnedQnaMountMissing||=(console.warn(`[gengage] QNA mount target not found: ${t}`),!0)}else this._qna?.destroy(),this._qna=null;if(this.options.simrel?.enabled!==!1){let r=this.options.simrel?.mountTarget??S,a=D(r);if(a)if(this._warnedSimRelMountMissing=!1,this._simrel)this._simrel.show(),this._simrel.update({pageType:`pdp`,sku:e});else{let r=new i.t,o={accountId:this.options.accountId,middlewareUrl:n,session:this.session,sku:e,mountTarget:a};this.options.theme!==void 0&&(o.theme=this.options.theme),this.options.pricing!==void 0&&(o.pricing=this.options.pricing),this.options.simrel?.discountType!==void 0&&(o.discountType=this.options.simrel.discountType),this.options.simrel?.renderCardElement!==void 0&&(o.renderCardElement=this.options.simrel.renderCardElement),this.options.simrel?.renderer!==void 0&&(o.renderer=this.options.simrel.renderer),this.options.onAddToCart!==void 0&&(o.onAddToCart=this.options.onAddToCart),this.options.onProductNavigate===void 0?o.onProductNavigate=(e,n,r)=>{t.z(e)&&(this._chat?.saveSession(r??this.session.sessionId,n),window.location.href=e)}:o.onProductNavigate=this.options.onProductNavigate,await r.init(o),this._simrel=r}else this._simrel?.destroy(),this._simrel=null,this._warnedSimRelMountMissing||=(console.warn(`[gengage] SimRel mount target not found: ${r}`),!0)}else this._simrel?.destroy(),this._simrel=null;if(this.options.simbut&&this.options.simbut.enabled!==!1){let t=this.options.simbut.mountTarget??C,r=D(t),i=this._chat??this.options.simbut.onFindSimilar;if(r&&i)if(this._warnedSimButMountMissing=!1,this._warnedSimButNoChat=!1,this._simbut)this._simbut.show(),this._simbut.setChat(this._chat),this._simbut.update({pageType:`pdp`,sku:e});else{let t=new a.t,i={accountId:this.options.accountId,middlewareUrl:n,session:this.session,pageContext:{pageType:`pdp`,sku:e},mountTarget:r,chat:this._chat};this.options.theme!==void 0&&(i.theme=this.options.theme),this.options.locale!==void 0&&(i.locale=this.options.locale),this.options.simbut.imageUrl!==void 0&&(i.imageUrl=this.options.simbut.imageUrl),this.options.simbut.i18n!==void 0&&(i.i18n=this.options.simbut.i18n),this.options.simbut.onFindSimilar!==void 0&&(i.onFindSimilar=this.options.simbut.onFindSimilar),await t.init(i),this._simbut=t}else this._simbut?.destroy(),this._simbut=null,!r&&!this._warnedSimButMountMissing?(console.warn(`[gengage] SimBut mount target not found: ${t}`),this._warnedSimButMountMissing=!0):!i&&!this._warnedSimButNoChat&&(console.warn(`[gengage] SimBut requires chat to be enabled or simbut.onFindSimilar`),this._warnedSimButNoChat=!0)}else this._simbut?.destroy(),this._simbut=null}_enqueue(e){let t=this._queue.then(e);return this._queue=t.catch(e=>{}),t}};async function A(e){let t=O(e),n=w(),r=n.instances[t];if(r)return r;let i=n.pending[t];if(i)return i;let a=new k(e,()=>{let e=w();delete e.instances[t],delete e.pending[t]}),o=a.init().then(()=>(n.instances[t]=a,delete n.pending[t],a)).catch(e=>{throw delete n.pending[t],e});return n.pending[t]=o,o}function j(e){return w().instances[e]??null}function M(e){j(e)?.destroy()}function N(e){return`${b}${e}`}var P=[`gengage:chat:open`,`gengage:chat:close`,`gengage:chat:ready`,`gengage:chat:add-to-cart`,`gengage:qna:action`,`gengage:qna:open-chat`,`gengage:similar:product-click`,`gengage:similar:add-to-cart`,`gengage:global:error`,`gengage:context:update`],F=32,I=`#gengage-qna`,L=`#gengage-simrel`;function R(e){return e}function z(e){let t=e;if(typeof e==`string`){let n=e.trim();if(n.length===0)return null;if(!n.startsWith(`{`)&&!n.startsWith(`[`))return{type:n};try{t=JSON.parse(n)}catch{return null}}if(!t||typeof t!=`object`)return null;let n=t,r=[n.type,n.command,n.action,n.event].find(e=>typeof e==`string`&&e.length>0);if(!r)return null;let i=n.payload;if(i===void 0&&`data`in n&&(i=n.data),r===`setSession`&&i===void 0){let e={};typeof n.sessionId==`string`&&(e.sessionId=n.sessionId),typeof n.userId==`string`&&(e.userId=n.userId),(e.sessionId!==void 0||e.userId!==void 0)&&(i=e)}return i===void 0?{type:r}:{type:r,payload:i}}function B(e){if(typeof e==`string`&&e.length>0)return{sku:e};if(e&&typeof e==`object`&&`sku`in e){let t=e.sku;if(typeof t==`string`&&t.length>0){let n=e.pageType;return n===void 0?{sku:t}:{sku:t,pageType:n}}}return null}function V(e,t){return t instanceof HTMLElement?!0:typeof t==`string`?e.document.querySelector(t)!==null:!1}function H(e,t,n){if(t instanceof HTMLElement||V(e,t)||typeof t!=`string`)return t;if(t.startsWith(`#`)){let n=t.slice(1);if(n.length>0){let t=e.document.getElementById(n);if(t)return t;let r=e.document.createElement(`div`);return r.id=n,e.document.body.appendChild(r),r}}let r=e.document.getElementById(n);if(r)return r;let i=e.document.createElement(`div`);return i.id=n,e.document.body.appendChild(i),i}function U(e,t){let n=R(e).webkit?.messageHandlers?.[t];return n&&typeof n.postMessage==`function`?n.postMessage.bind(n):null}function W(e,t){let n=e[t];return n&&typeof n==`object`&&typeof n.postMessage==`function`?n:null}function G(e={}){let t=e.win??window,n=e.iosHandlerName??`gengage`,r=e.androidInterfaceName??`GengageNative`,i=e.reactNativeInterfaceName??`ReactNativeWebView`;return U(t,n)?`ios`:W(t,r)?`android`:W(t,i)?`react-native`:`browser`}function K(e,t={}){let n=t.win??window;if(e.sessionId!==void 0){n.__gengageSessionId=e.sessionId,n.gengage||={},n.gengage.sessionId=e.sessionId;try{n.sessionStorage.setItem(`gengage_session_id`,e.sessionId)}catch{}}if(e.userId!==void 0){n.gengage||={};let t=n.gengage,r=t.session??{};r.userId=e.userId,t.session=r}}function q(e={}){let t=e.win??window,n=R(t);if(n.gengageNative)return n.gengageNative;let r=e.iosHandlerName??`gengage`,i=e.androidInterfaceName??`GengageNative`,a=e.reactNativeInterfaceName??`ReactNativeWebView`,o=e.trackedEvents??[...P],s=G({win:t,iosHandlerName:r,androidInterfaceName:i,reactNativeInterfaceName:a}),c=t.gengage?.overlay??null,l=[],u=(e,n)=>{let o=n===void 0?{type:e}:{type:e,payload:n};if(s===`ios`){U(t,r)?.(o);return}if(s===`android`){W(t,i)?.postMessage(JSON.stringify(o));return}if(s===`react-native`){W(t,a)?.postMessage(JSON.stringify(o));return}},d=e=>{let t=e.detail;!t||typeof t.namespace!=`string`||typeof t.type!=`string`||u(`bridge_message`,{namespace:t.namespace,type:t.type,payload:t.payload})};t.addEventListener(`gengage:bridge:message`,d);let f=o.map(e=>{let n=t=>{let n=t.detail;u(`widget_event`,{event:e,detail:n})};return t.addEventListener(e,n),{event:e,handler:n}}),p=e=>{l.length>=F&&l.shift(),l.push(e)},m=()=>{if(!c||l.length===0)return;let e=l.splice(0,l.length);for(let t of e)h(t)},h=n=>{let r=z(n);if(!r||typeof r.type!=`string`){console.warn(`[gengage:native-bridge] Invalid message:`,n);return}let i=r.type,a=r.payload;switch(i){case`openChat`:c?c.openChat(a&&typeof a==`object`?a:a===`half`||a===`full`?{state:a}:void 0):p(r);return;case`closeChat`:c?c.closeChat():p(r);return;case`updateContext`:c&&a&&typeof a==`object`?c.updateContext(a):c?console.warn(`[gengage:native-bridge] updateContext: missing payload`):p(r);return;case`updateSku`:{let e=B(a);if(c&&e){c.updateSku(e.sku,e.pageType);return}c?console.warn(`[gengage:native-bridge] updateSku: missing sku`):p(r);return}case`setSession`:a&&typeof a==`object`&&K(a,{win:t});return;case`destroy`:c?.destroy();return;default:t.postMessage({gengage:`native`,type:i,payload:a},t.location.origin),e.logUnhandled&&console.warn(`[gengage:native-bridge] Unhandled inbound type forwarded:`,i)}},g={env:s,sendToNative:u,receive:h,setController(e){c=e,m()},destroy(){t.removeEventListener(`gengage:bridge:message`,d);for(let e of f)t.removeEventListener(e.event,e.handler);l.splice(0,l.length),R(t).gengageNative===g&&delete R(t).gengageNative}};return n.gengageNative=g,g}async function J(e){let{nativeBridge:t,emitReadyEvent:n=!0,...r}=e,i=q(t),a={...r};a.onAddToCart||=e=>{i.sendToNative(`addToCart`,{sku:e.sku,quantity:e.quantity,cartCode:e.cartCode})},a.onProductNavigate||=(e,t,n)=>{i.sendToNative(`productNavigate`,{url:e,sku:t,sessionId:n})};let o=a.qna?.enabled===!0||a.qna?.mountTarget!==void 0;if(a.qna?.enabled!==!1)if(o){let e=H(window,a.qna?.mountTarget??I,`gengage-qna`);a.qna={...a.qna,enabled:!0,mountTarget:e}}else V(window,I)||(a.qna={enabled:!1});let s=a.simrel?.enabled===!0||a.simrel?.mountTarget!==void 0;if(a.simrel?.enabled!==!1)if(s){let e=H(window,a.simrel?.mountTarget??L,`gengage-simrel`);a.simrel={...a.simrel,enabled:!0,mountTarget:e}}else V(window,L)||(a.simrel={enabled:!1});let c=await A(a);return i.setController(c),n&&i.sendToNative(`ready`,{sessionId:c.session.sessionId,widgets:{chat:c.chat!==null,qna:c.qna!==null,simrel:c.simrel!==null}}),{controller:c,bridge:i,destroy(){c.destroy(),i.destroy()}}}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return J}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return j}}),Object.defineProperty(exports,`d`,{enumerable:!0,get:function(){return l}}),Object.defineProperty(exports,`f`,{enumerable:!0,get:function(){return m}}),Object.defineProperty(exports,`h`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return G}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return A}}),Object.defineProperty(exports,`m`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return K}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return N}}),Object.defineProperty(exports,`p`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return q}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return g}});
2
+ //# sourceMappingURL=native-webview-BOmxxjcL.cjs.map