@paypercut/checkout-js 1.0.6 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -54,12 +54,12 @@ pnpm add @paypercut/checkout-js
54
54
 
55
55
  ```html
56
56
  <!-- jsDelivr (recommended with SRI) -->
57
- <script src="https://cdn.jsdelivr.net/npm/@paypercut/checkout-js@1.0.6/dist/paypercut-checkout.iife.min.js"
57
+ <script src="https://cdn.jsdelivr.net/npm/@paypercut/checkout-js@1.0.8/dist/paypercut-checkout.iife.min.js"
58
58
  integrity="sha384-..."
59
59
  crossorigin="anonymous"></script>
60
60
 
61
61
  <!-- or UNPKG -->
62
- <script src="https://unpkg.com/@paypercut/checkout-js@1.0.6/dist/paypercut-checkout.iife.min.js"></script>
62
+ <script src="https://unpkg.com/@paypercut/checkout-js@1.0.8/dist/paypercut-checkout.iife.min.js"></script>
63
63
  ```
64
64
 
65
65
  ---
@@ -354,8 +354,8 @@ Tip: Prefer subscribing with the SdkEvent enum for stronger typing.
354
354
  </head>
355
355
  <body>
356
356
  <div id="checkout"></div>
357
-
358
- <script src="https://cdn.jsdelivr.net/npm/@paypercut/checkout-js@1.0.6/dist/paypercut-checkout.iife.min.js"></script>
357
+
358
+ <script src="https://cdn.jsdelivr.net/npm/@paypercut/checkout-js@1.0.8/dist/paypercut-checkout.iife.min.js"></script>
359
359
  <script>
360
360
  const checkout = PaypercutCheckout({
361
361
  id: 'CHK_12345',
package/dist/index.cjs CHANGED
@@ -84,7 +84,7 @@ class Emitter {
84
84
  * Production configuration (for merchants)
85
85
  */
86
86
  const productionConfig = {
87
- version: "1.0.6",
87
+ version: "1.0.8",
88
88
  defaultCheckoutOrigin: 'https://buy.paypercut.io',
89
89
  allowedOrigins: [
90
90
  'https://buy.paypercut.io',
@@ -178,12 +178,8 @@ function normalizeLocale(locale) {
178
178
  */
179
179
  exports.UIMode = void 0;
180
180
  (function (UIMode) {
181
- /** Custom UI mode - merchant provides their own submit button */
182
- UIMode["CUSTOM"] = "custom";
183
181
  /** Embedded mode - checkout embedded in merchant page */
184
182
  UIMode["EMBEDDED"] = "embedded";
185
- /** Hosted mode - full-page checkout experience */
186
- UIMode["HOSTED"] = "hosted";
187
183
  })(exports.UIMode || (exports.UIMode = {}));
188
184
  /**
189
185
  * Type guard for UIMode
@@ -312,11 +308,11 @@ class CheckoutImpl {
312
308
  const normalizedLocale = normalizeLocale(this.options.locale);
313
309
  url.searchParams.set('locale', normalizedLocale);
314
310
  }
315
- // Add ui_mode parameter
316
- if (this.options.ui_mode) {
317
- const validatedUIMode = validateUIMode(this.options.ui_mode);
318
- if (validatedUIMode) {
319
- url.searchParams.set('ui_mode', validatedUIMode);
311
+ // Add ui_mode parameter (default to 'embedded')
312
+ {
313
+ const selected = validateUIMode(this.options.ui_mode ?? exports.UIMode.EMBEDDED);
314
+ if (selected) {
315
+ url.searchParams.set('ui_mode', selected);
320
316
  }
321
317
  }
322
318
  // Add payment_methods parameters (repeated for each method)
@@ -491,20 +487,11 @@ class CheckoutImpl {
491
487
  left: '0',
492
488
  width: '100%',
493
489
  height: '100%',
494
- // backgroundColor: 'rgba(0, 0, 0, 0.5)',
495
490
  display: 'flex',
496
491
  alignItems: 'center',
497
492
  justifyContent: 'center',
498
493
  zIndex: '999999',
499
- });
500
- // Create container for iframe + close button
501
- const modalContainer = document.createElement('div');
502
- Object.assign(modalContainer.style, {
503
- position: 'relative',
504
- display: 'flex',
505
- flexDirection: 'column',
506
- backgroundColor: '#ffffff',
507
- borderRadius: '24px',
494
+ background: 'rgba(0, 0, 0, 0.4)',
508
495
  });
509
496
  // Create iframe for 3DS page
510
497
  this.threeDSIframe = document.createElement('iframe');
@@ -522,26 +509,22 @@ class CheckoutImpl {
522
509
  if (data.threeDSVersion) {
523
510
  threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);
524
511
  }
512
+ // Always include liveMode; default to false when undefined
513
+ threeDSUrl.searchParams.set('liveMode', String(data.liveMode ?? false));
525
514
  this.threeDSIframe.src = threeDSUrl.toString();
526
515
  this.threeDSIframe.allow = 'payment *';
527
516
  this.threeDSIframe.setAttribute('frameborder', '0');
528
- // Responsive modal sizing (60% of viewport, min 400px, max 800px width / 600px height)
529
- const viewportWidth = window.innerWidth;
530
- const viewportHeight = window.innerHeight;
531
- const modalWidth = Math.min(Math.max(viewportWidth * 0.6, 400), 800);
532
- const modalHeight = Math.min(Math.max(viewportHeight * 0.6, 400), 600);
517
+ // Fixed dimensions: follow 3DS component size (500x500)
533
518
  Object.assign(this.threeDSIframe.style, {
534
- width: `${modalWidth}px`,
535
- height: `${modalHeight}px`,
519
+ minWidth: '400px',
520
+ minHeight: '400px',
536
521
  border: 'none',
537
- borderRadius: '24px',
538
- backgroundColor: 'white',
539
- overflow: 'auto',
522
+ borderRadius: '8px',
523
+ display: 'block',
524
+ background: 'transparent',
540
525
  });
541
- // Append iframe
542
- modalContainer.appendChild(this.threeDSIframe);
543
- // Append container to modal backdrop
544
- this.threeDSModal.appendChild(modalContainer);
526
+ // Append iframe directly to modal backdrop
527
+ this.threeDSModal.appendChild(this.threeDSIframe);
545
528
  document.body.appendChild(this.threeDSModal);
546
529
  // Store 3DS data for later use
547
530
  this.pending3DSData = data;
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Custom UI mode - merchant provides their own submit button */\n CUSTOM = 'custom',\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n /** Hosted mode - full-page checkout experience */\n HOSTED = 'hosted',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter\n if (this.options.ui_mode) {\n const validatedUIMode = validateUIMode(this.options.ui_mode);\n if (validatedUIMode) {\n url.searchParams.set('ui_mode', validatedUIMode);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n // backgroundColor: 'rgba(0, 0, 0, 0.5)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n });\n\n // Create container for iframe + close button\n const modalContainer = document.createElement('div');\n Object.assign(modalContainer.style, {\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n backgroundColor: '#ffffff',\n borderRadius: '24px',\n });\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Responsive modal sizing (60% of viewport, min 400px, max 800px width / 600px height)\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const modalWidth = Math.min(Math.max(viewportWidth * 0.6, 400), 800);\n const modalHeight = Math.min(Math.max(viewportHeight * 0.6, 400), 600);\n\n Object.assign(this.threeDSIframe.style, {\n width: `${modalWidth}px`,\n height: `${modalHeight}px`,\n border: 'none',\n borderRadius: '24px',\n backgroundColor: 'white',\n overflow: 'auto',\n });\n\n // Append iframe\n modalContainer.appendChild(this.threeDSIframe);\n\n // Append container to modal backdrop\n this.threeDSModal.appendChild(modalContainer);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":["UIMode","PaymentMethod","WalletOption","SdkEvent"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n UIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter (default to 'embedded')\n {\n const selected = validateUIMode(this.options.ui_mode ?? UIMode.EMBEDDED);\n if (selected) {\n url.searchParams.set('ui_mode', selected);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n liveMode?: boolean;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n background: 'rgba(0, 0, 0, 0.4)',\n });\n\n\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n // Always include liveMode; default to false when undefined\n threeDSUrl.searchParams.set('liveMode', String(data.liveMode ?? false));\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Fixed dimensions: follow 3DS component size (500x500)\n Object.assign(this.threeDSIframe.style, {\n minWidth: '400px',\n minHeight: '400px',\n border: 'none',\n borderRadius: '8px',\n display: 'block',\n background: 'transparent',\n });\n\n // Append iframe directly to modal backdrop\n this.threeDSModal.appendChild(this.threeDSIframe);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":["UIMode","PaymentMethod","WalletOption","SdkEvent"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -37,12 +37,8 @@ type Locale = typeof LOCALES[number] | 'auto';
37
37
  * UI mode for checkout
38
38
  */
39
39
  declare enum UIMode {
40
- /** Custom UI mode - merchant provides their own submit button */
41
- CUSTOM = "custom",
42
40
  /** Embedded mode - checkout embedded in merchant page */
43
- EMBEDDED = "embedded",
44
- /** Hosted mode - full-page checkout experience */
45
- HOSTED = "hosted"
41
+ EMBEDDED = "embedded"
46
42
  }
47
43
  /**
48
44
  * Payment method types
package/dist/index.mjs CHANGED
@@ -80,7 +80,7 @@ class Emitter {
80
80
  * Production configuration (for merchants)
81
81
  */
82
82
  const productionConfig = {
83
- version: "1.0.6",
83
+ version: "1.0.8",
84
84
  defaultCheckoutOrigin: 'https://buy.paypercut.io',
85
85
  allowedOrigins: [
86
86
  'https://buy.paypercut.io',
@@ -174,12 +174,8 @@ function normalizeLocale(locale) {
174
174
  */
175
175
  var UIMode;
176
176
  (function (UIMode) {
177
- /** Custom UI mode - merchant provides their own submit button */
178
- UIMode["CUSTOM"] = "custom";
179
177
  /** Embedded mode - checkout embedded in merchant page */
180
178
  UIMode["EMBEDDED"] = "embedded";
181
- /** Hosted mode - full-page checkout experience */
182
- UIMode["HOSTED"] = "hosted";
183
179
  })(UIMode || (UIMode = {}));
184
180
  /**
185
181
  * Type guard for UIMode
@@ -308,11 +304,11 @@ class CheckoutImpl {
308
304
  const normalizedLocale = normalizeLocale(this.options.locale);
309
305
  url.searchParams.set('locale', normalizedLocale);
310
306
  }
311
- // Add ui_mode parameter
312
- if (this.options.ui_mode) {
313
- const validatedUIMode = validateUIMode(this.options.ui_mode);
314
- if (validatedUIMode) {
315
- url.searchParams.set('ui_mode', validatedUIMode);
307
+ // Add ui_mode parameter (default to 'embedded')
308
+ {
309
+ const selected = validateUIMode(this.options.ui_mode ?? UIMode.EMBEDDED);
310
+ if (selected) {
311
+ url.searchParams.set('ui_mode', selected);
316
312
  }
317
313
  }
318
314
  // Add payment_methods parameters (repeated for each method)
@@ -487,20 +483,11 @@ class CheckoutImpl {
487
483
  left: '0',
488
484
  width: '100%',
489
485
  height: '100%',
490
- // backgroundColor: 'rgba(0, 0, 0, 0.5)',
491
486
  display: 'flex',
492
487
  alignItems: 'center',
493
488
  justifyContent: 'center',
494
489
  zIndex: '999999',
495
- });
496
- // Create container for iframe + close button
497
- const modalContainer = document.createElement('div');
498
- Object.assign(modalContainer.style, {
499
- position: 'relative',
500
- display: 'flex',
501
- flexDirection: 'column',
502
- backgroundColor: '#ffffff',
503
- borderRadius: '24px',
490
+ background: 'rgba(0, 0, 0, 0.4)',
504
491
  });
505
492
  // Create iframe for 3DS page
506
493
  this.threeDSIframe = document.createElement('iframe');
@@ -518,26 +505,22 @@ class CheckoutImpl {
518
505
  if (data.threeDSVersion) {
519
506
  threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);
520
507
  }
508
+ // Always include liveMode; default to false when undefined
509
+ threeDSUrl.searchParams.set('liveMode', String(data.liveMode ?? false));
521
510
  this.threeDSIframe.src = threeDSUrl.toString();
522
511
  this.threeDSIframe.allow = 'payment *';
523
512
  this.threeDSIframe.setAttribute('frameborder', '0');
524
- // Responsive modal sizing (60% of viewport, min 400px, max 800px width / 600px height)
525
- const viewportWidth = window.innerWidth;
526
- const viewportHeight = window.innerHeight;
527
- const modalWidth = Math.min(Math.max(viewportWidth * 0.6, 400), 800);
528
- const modalHeight = Math.min(Math.max(viewportHeight * 0.6, 400), 600);
513
+ // Fixed dimensions: follow 3DS component size (500x500)
529
514
  Object.assign(this.threeDSIframe.style, {
530
- width: `${modalWidth}px`,
531
- height: `${modalHeight}px`,
515
+ minWidth: '400px',
516
+ minHeight: '400px',
532
517
  border: 'none',
533
- borderRadius: '24px',
534
- backgroundColor: 'white',
535
- overflow: 'auto',
518
+ borderRadius: '8px',
519
+ display: 'block',
520
+ background: 'transparent',
536
521
  });
537
- // Append iframe
538
- modalContainer.appendChild(this.threeDSIframe);
539
- // Append container to modal backdrop
540
- this.threeDSModal.appendChild(modalContainer);
522
+ // Append iframe directly to modal backdrop
523
+ this.threeDSModal.appendChild(this.threeDSIframe);
541
524
  document.body.appendChild(this.threeDSModal);
542
525
  // Store 3DS data for later use
543
526
  this.pending3DSData = data;
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Custom UI mode - merchant provides their own submit button */\n CUSTOM = 'custom',\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n /** Hosted mode - full-page checkout experience */\n HOSTED = 'hosted',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter\n if (this.options.ui_mode) {\n const validatedUIMode = validateUIMode(this.options.ui_mode);\n if (validatedUIMode) {\n url.searchParams.set('ui_mode', validatedUIMode);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n // backgroundColor: 'rgba(0, 0, 0, 0.5)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n });\n\n // Create container for iframe + close button\n const modalContainer = document.createElement('div');\n Object.assign(modalContainer.style, {\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n backgroundColor: '#ffffff',\n borderRadius: '24px',\n });\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Responsive modal sizing (60% of viewport, min 400px, max 800px width / 600px height)\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const modalWidth = Math.min(Math.max(viewportWidth * 0.6, 400), 800);\n const modalHeight = Math.min(Math.max(viewportHeight * 0.6, 400), 600);\n\n Object.assign(this.threeDSIframe.style, {\n width: `${modalWidth}px`,\n height: `${modalHeight}px`,\n border: 'none',\n borderRadius: '24px',\n backgroundColor: 'white',\n overflow: 'auto',\n });\n\n // Append iframe\n modalContainer.appendChild(this.threeDSIframe);\n\n // Append container to modal backdrop\n this.threeDSModal.appendChild(modalContainer);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n UIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter (default to 'embedded')\n {\n const selected = validateUIMode(this.options.ui_mode ?? UIMode.EMBEDDED);\n if (selected) {\n url.searchParams.set('ui_mode', selected);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n liveMode?: boolean;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n background: 'rgba(0, 0, 0, 0.4)',\n });\n\n\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n // Always include liveMode; default to false when undefined\n threeDSUrl.searchParams.set('liveMode', String(data.liveMode ?? false));\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Fixed dimensions: follow 3DS component size (500x500)\n Object.assign(this.threeDSIframe.style, {\n minWidth: '400px',\n minHeight: '400px',\n border: 'none',\n borderRadius: '8px',\n display: 'block',\n background: 'transparent',\n });\n\n // Append iframe directly to modal backdrop\n this.threeDSModal.appendChild(this.threeDSIframe);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":[],"mappings":"AAAA;;;AAGG;MACU,OAAO,CAAA;AAApB,IAAA,WAAA,GAAA;AACU,QAAA,IAAA,CAAA,QAAQ,GAAG,IAAI,GAAG,EAAoB;IAmEhD;AAjEE;;;;;AAKG;IACH,EAAE,CAAC,KAAQ,EAAE,OAAiB,EAAA;QAC5B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YAC7B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,GAAG,EAAE,CAAC;QACrC;AACA,QAAA,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAE,CAAC,GAAG,CAAC,OAAO,CAAC;;QAGtC,OAAO,MAAM,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC;IACvC;AAEA;;;;;;;;;;AAUG;IACH,IAAI,CAAC,KAAQ,EAAE,OAAiB,EAAA;AAC9B,QAAA,MAAM,cAAc,GAAG,CAAC,GAAG,IAAW,KAAI;AACxC,YAAA,OAAO,CAAC,GAAG,IAAI,CAAC;AAChB,YAAA,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,cAAc,CAAC;AACjC,QAAA,CAAC;QACD,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,CAAC;IACvC;AAEA;;;;AAIG;IACH,GAAG,CAAC,KAAQ,EAAE,OAAiB,EAAA;AAC7B,QAAA,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,OAAO,CAAC;IAC3C;AAEA;;;;AAIG;AACH,IAAA,IAAI,CAAC,KAAQ,EAAE,GAAG,IAAW,EAAA;AAC3B,QAAA,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC,IAAG;AACpC,YAAA,IAAI;AACF,gBAAA,CAAC,CAAC,GAAG,IAAI,CAAC;YACZ;YAAE,OAAO,GAAG,EAAE;gBACZ,OAAO,CAAC,KAAK,CAAC,CAAA,mBAAA,EAAsB,KAAK,CAAA,SAAA,CAAW,EAAE,GAAG,CAAC;YAC5D;AACF,QAAA,CAAC,CAAC;IACJ;AAEA;;AAEG;IACH,KAAK,GAAA;AACH,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;IACvB;AACD;;ACxED;;;;;;AAMG;AAgCH;;AAEG;AACH,MAAM,gBAAgB,GAAgB;AACpC,IAAA,OAAO,EAAE,OAAW;AACpB,IACA,qBAAqB,EAAE,0BAA0B;AACjD,IAAA,cAAc,EAAE;QACd,0BAA0B;AAC3B,MAEF;AAmBD;;AAEG;AACI,MAAM,MAAM,GAEf,gBAAgB;AAEpB;;AAEG;AACG,SAAU,eAAe,CAAC,MAAc,EAAA;IAC5C,OAAO,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC;AAC/C;AAEA;;AAEG;AACG,SAAU,iBAAiB,CAAC,QAAiB,EAAA;IAMjD,OAAO,MAAM,CAAC,qBAAqB;AACrC;;AC5FA;;;;;;;;;;;;;;;;;;;;;;;AAuBG;AACI,MAAM,OAAO,GAAG;AACrB,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;AACb,IAAA,IAAI,EAAE,OAAO;;AAaf;;;AAGG;AACH,MAAM,UAAU,GAAwB,IAAI,GAAG,CAAC,OAAO,CAAC;AAExD;;;;;;;;;;;;;;;;;AAiBG;AACG,SAAU,eAAe,CAAC,MAAuB,EAAA;AACrD,IAAA,IAAI,CAAC,MAAM,IAAI,MAAM,KAAK,MAAM;AAAE,QAAA,OAAO,IAAI;AAC7C,IAAA,IAAI,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC;AAAE,QAAA,OAAO,MAAgC;AACnE,IAAA,OAAO,CAAC,IAAI,CAAC,+BAA+B,MAAM,CAAA,yCAAA,CAA2C,CAAC;AAC9F,IAAA,OAAO,IAAI;AACb;;ACzEA;;AAEG;IACS;AAAZ,CAAA,UAAY,MAAM,EAAA;;AAEhB,IAAA,MAAA,CAAA,UAAA,CAAA,GAAA,UAAqB;AACvB,CAAC,EAHW,MAAM,KAAN,MAAM,GAAA,EAAA,CAAA,CAAA;AAKlB;;AAEG;AACG,SAAU,aAAa,CAAC,KAAa,EAAA;IACzC,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,KAAe,CAAC;AACxD;AAEA;;AAEG;IACS;AAAZ,CAAA,UAAY,aAAa,EAAA;;AAEvB,IAAA,aAAA,CAAA,MAAA,CAAA,GAAA,MAAa;AACf,CAAC,EAHW,aAAa,KAAb,aAAa,GAAA,EAAA,CAAA,CAAA;AAKzB;;AAEG;AACG,SAAU,oBAAoB,CAAC,KAAa,EAAA;IAChD,OAAO,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,KAAsB,CAAC;AACtE;AAEA;;AAEG;IACS;AAAZ,CAAA,UAAY,YAAY,EAAA;;AAEtB,IAAA,YAAA,CAAA,WAAA,CAAA,GAAA,WAAuB;;AAEvB,IAAA,YAAA,CAAA,YAAA,CAAA,GAAA,YAAyB;AAC3B,CAAC,EALW,YAAY,KAAZ,YAAY,GAAA,EAAA,CAAA,CAAA;AAOxB;;AAEG;AACG,SAAU,mBAAmB,CAAC,KAAa,EAAA;IAC/C,OAAO,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,KAAqB,CAAC;AACpE;AAEA;;AAEG;AACG,SAAU,sBAAsB,CAAC,OAAiB,EAAA;IACtD,MAAM,SAAS,GAAoB,EAAE;AAErC,IAAA,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;AAC5B,QAAA,IAAI,oBAAoB,CAAC,MAAM,CAAC,EAAE;AAChC,YAAA,SAAS,CAAC,IAAI,CAAC,MAAuB,CAAC;QACzC;aAAO;AACL,YAAA,OAAO,CAAC,IAAI,CAAC,gDAAgD,MAAM,CAAA,YAAA,CAAc,CAAC;QACpF;IACF;;AAGA,IAAA,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;AAC1B,QAAA,OAAO,CAAC,IAAI,CAAC,8EAA8E,CAAC;AAC5F,QAAA,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;IACpC;AAEA,IAAA,OAAO,SAAS;AAClB;AAEA;;AAEG;AACG,SAAU,qBAAqB,CAAC,OAAiB,EAAA;IACrD,MAAM,SAAS,GAAmB,EAAE;AAEpC,IAAA,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;AAC5B,QAAA,IAAI,mBAAmB,CAAC,MAAM,CAAC,EAAE;AAC/B,YAAA,SAAS,CAAC,IAAI,CAAC,MAAsB,CAAC;QACxC;aAAO;AACL,YAAA,OAAO,CAAC,IAAI,CAAC,+CAA+C,MAAM,CAAA,YAAA,CAAc,CAAC;QACnF;IACF;AAEA,IAAA,OAAO,SAAS;AAClB;AAEA;;AAEG;AACG,SAAU,cAAc,CAAC,IAAwB,EAAA;IACrD,IAAI,CAAC,IAAI,EAAE;AACT,QAAA,OAAO,SAAS;IAClB;AAEA,IAAA,IAAI,aAAa,CAAC,IAAI,CAAC,EAAE;AACvB,QAAA,OAAO,IAAc;IACvB;AAEA,IAAA,OAAO,CAAC,IAAI,CACV,yCAAyC,IAAI,CAAA,kBAAA,EAAqB,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA,CAAE,CACrG;AACD,IAAA,OAAO,SAAS;AAClB;AAwEA;;AAEG;IACS;AAAZ,CAAA,UAAY,QAAQ,EAAA;AAClB,IAAA,QAAA,CAAA,QAAA,CAAA,GAAA,QAAiB;AACjB,IAAA,QAAA,CAAA,SAAA,CAAA,GAAA,SAAmB;AACnB,IAAA,QAAA,CAAA,OAAA,CAAA,GAAA,OAAe;AACf,IAAA,QAAA,CAAA,SAAA,CAAA,GAAA,SAAmB;AACnB,IAAA,QAAA,CAAA,iBAAA,CAAA,GAAA,kBAAoC;AACpC,IAAA,QAAA,CAAA,cAAA,CAAA,GAAA,eAA8B;AAC9B,IAAA,QAAA,CAAA,iBAAA,CAAA,GAAA,kBAAoC;AACpC,IAAA,QAAA,CAAA,gBAAA,CAAA,GAAA,iBAAkC;AACpC,CAAC,EATW,QAAQ,KAAR,QAAQ,GAAA,EAAA,CAAA,CAAA;;ACxJpB;;AAEG;AACH,MAAM,YAAY,CAAA;AAWhB,IAAA,WAAA,CAAoB,OAAiC,EAAA;QAAjC,IAAA,CAAA,OAAO,GAAP,OAAO;AAVnB,QAAA,IAAA,CAAA,OAAO,GAAG,IAAI,OAAO,EAAa;QAClC,IAAA,CAAA,OAAO,GAAG,KAAK;QACf,IAAA,CAAA,SAAS,GAAG,KAAK;QACjB,IAAA,CAAA,MAAM,GAA6B,IAAI;;QAIvC,IAAA,CAAA,YAAY,GAA0B,IAAI;QAC1C,IAAA,CAAA,aAAa,GAA6B,IAAI;;QAIpD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC;QAC/C,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC;IACzD;AAEA;;AAEG;IACK,QAAQ,GAAA;QACd,MAAM,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;AACjE,QAAA,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,CAAA,GAAA,EAAM,IAAI,CAAC,OAAO,CAAC,EAAE,CAAA,CAAE,EAAE,OAAO,CAAC;;AAGrD,QAAA,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YACvB,MAAM,gBAAgB,GAAG,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YAC7D,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,EAAE,gBAAgB,CAAC;QAClD;;QAGA;AACE,YAAA,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,MAAM,CAAC,QAAQ,CAAC;YACxE,IAAI,QAAQ,EAAE;gBACZ,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC;YAC3C;QACF;;AAGA,QAAA,IAAI,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3E,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,eAA2B,CAAC;AACzF,YAAA,gBAAgB,CAAC,OAAO,CAAC,CAAC,MAAM,KAAI;gBAClC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,iBAAiB,EAAE,MAAM,CAAC;AACpD,YAAA,CAAC,CAAC;QACJ;;AAGA,QAAA,IAAI,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;YACzE,MAAM,gBAAgB,GAAG,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,cAA0B,CAAC;AACvF,YAAA,gBAAgB,CAAC,OAAO,CAAC,CAAC,MAAM,KAAI;gBAClC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,gBAAgB,EAAE,MAAM,CAAC;AACnD,YAAA,CAAC,CAAC;QACJ;QAEA,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE;AACnC,YAAA,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC;QAChE;QAEA,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,SAAS,EAAE;AACxC,YAAA,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACnE;AAEA,QAAA,OAAO,GAAG,CAAC,QAAQ,EAAE;IACvB;AAEA;;AAEG;IACK,YAAY,GAAA;QAClB,MAAM,SAAS,GACb,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,KAAK;cAChC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW;AACjD,cAAE,IAAI,CAAC,OAAO,CAAC,WAAW;QAE9B,IAAI,CAAC,SAAS,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,CAAA,qBAAA,EAAwB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAA,CAAE,CAAC;QACrE;AAEA,QAAA,OAAO,SAAwB;IACjC;AAEA;;AAEG;AACK,IAAA,SAAS,CAAC,GAAiB,EAAA;;QAEjC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YAChC;QACF;;AAGA,QAAA,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI;AACrB,QAAA,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,EAAE,MAAM,IAAI,IAAI,CAAC,EAAE;YAC1D;QACF;;;AAIA,QAAA,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE;AAC1D,YAAA,OAAO;QACT;;AAGA,QAAA,QAAQ,IAAI,CAAC,IAAI;AACf,YAAA,KAAK,iBAAiB;gBACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAClC;AACF,YAAA,KAAK,kBAAkB;gBACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACnC;AACF,YAAA,KAAK,gBAAgB;;AAEnB,gBAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,IAAI,IAAK,IAAY,CAAC,KAAK,KAAK,IAAI,CAAC;gBACxE;AACF,YAAA,KAAK,kBAAkB;gBACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACnC;AACF,YAAA,KAAK,oBAAoB;AACvB,gBAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;gBAC1C;AACF,YAAA,KAAK,eAAe;gBAClB,IAAI,CAAC,cAAc,EAAE;gBACrB;AACF,YAAA,KAAK,kBAAkB;AACrB,gBAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACvB,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;gBAC3C;AACF,YAAA,KAAK,kBAAkB;AACrB,gBAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACvB,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;gBAC3C;AACF,YAAA,KAAK,eAAe;AAClB,gBAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACvB,IAAI,CAAC,aAAa,EAAE;AACpB,gBAAA,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC;gBACpD;;IAEN;AAEA;;AAEG;IACH,MAAM,GAAA;AACJ,QAAA,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB;QACF;AAEA,QAAA,IAAI;AACF,YAAA,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE;;YAGrC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;AAC9C,YAAA,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,2BAA2B;YAC5C,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE;AACjC,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,4BAA4B;YAChD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,aAAa,EAAE,GAAG,CAAC;;YAE5C,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,qBAAqB,EAAE,MAAM,CAAC;YACvD,IAAI,CAAC,MAAM,CAAC,YAAY,CACtB,SAAS,EACT,yFAAyF,CAC1F;;YAID,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;AAC/B,gBAAA,KAAK,EAAE,MAAM;AACb,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,MAAM,EAAE,MAAM;AACd,gBAAA,OAAO,EAAE,OAAO;AACjB,aAAA,CAAC;;;;AAKF;;AAEK;AAEL,YAAA,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC;AAClC,YAAA,IAAI,CAAC,OAAO,GAAG,IAAI;QACrB;QAAE,OAAO,GAAG,EAAE;AACZ,YAAA,OAAO,CAAC,KAAK,CAAC,uCAAuC,EAAE,GAAG,CAAC;AAC3D,YAAA,MAAM,GAAG;QACX;IACF;AAEA;;AAEG;IACH,MAAM,GAAA;AACJ,QAAA,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB;QACF;AAEA,QAAA,IAAI;YACF,IAAI,CAAC,YAAY,CAAC;AAChB,gBAAA,IAAI,EAAE,kBAAkB;AACxB,gBAAA,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;AAC5B,aAAA,CAAC;QACJ;QAAE,OAAO,GAAG,EAAE;AACZ,YAAA,OAAO,CAAC,KAAK,CAAC,+CAA+C,EAAE,GAAG,CAAC;AACnE,YAAA,MAAM,GAAG;QACX;IACF;AAEA;;AAEG;AACK,IAAA,YAAY,CAAC,OAAY,EAAA;AAC/B,QAAA,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,EAAE;AAC/B,YAAA,OAAO,CAAC,KAAK,CAAC,6DAA6D,CAAC;YAC5E;QACF;QAEA,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,CAAC;IAChE;AAEA;;AAEG;AACK,IAAA,YAAY,CAAC,IAQpB,EAAA;;QAGC,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC;AACjD,QAAA,IAAI,CAAC,YAAY,CAAC,EAAE,GAAG,qBAAqB;QAC5C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE;AACrC,YAAA,QAAQ,EAAE,OAAO;AACjB,YAAA,GAAG,EAAE,GAAG;AACR,YAAA,IAAI,EAAE,GAAG;AACT,YAAA,KAAK,EAAE,MAAM;AACb,YAAA,MAAM,EAAE,MAAM;AACd,YAAA,OAAO,EAAE,MAAM;AACf,YAAA,UAAU,EAAE,QAAQ;AACpB,YAAA,cAAc,EAAE,QAAQ;AACxB,YAAA,MAAM,EAAE,QAAQ;AAChB,YAAA,UAAU,EAAE,oBAAoB;AACjC,SAAA,CAAC;;QAKF,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;QACrD,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;;AAGxE,QAAA,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,CAAA,GAAA,EAAM,IAAI,CAAC,OAAO,CAAC,EAAE,CAAA,QAAA,CAAU,EAAE,cAAc,CAAC;QAC3E,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC;QACxD,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC;AAE9C,QAAA,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,EAAE,IAAI,CAAC,YAAY,CAAC;QAChE;AACA,QAAA,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,kBAAkB,EAAE,IAAI,CAAC,gBAAgB,CAAC;QACxE;AACA,QAAA,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,gBAAgB,EAAE,IAAI,CAAC,cAAc,CAAC;QACpE;;AAEA,QAAA,UAAU,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,CAAC;QAEvE,IAAI,CAAC,aAAa,CAAC,GAAG,GAAG,UAAU,CAAC,QAAQ,EAAE;AAC9C,QAAA,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,WAAW;QACtC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,aAAa,EAAE,GAAG,CAAC;;QAGnD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE;AACtC,YAAA,QAAQ,EAAE,OAAO;AACjB,YAAA,SAAS,EAAE,OAAO;AAClB,YAAA,MAAM,EAAE,MAAM;AACd,YAAA,YAAY,EAAE,KAAK;AACnB,YAAA,OAAO,EAAE,OAAO;AAChB,YAAA,UAAU,EAAE,aAAa;AAC1B,SAAA,CAAC;;QAGF,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC;QACjD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC;;AAG3C,QAAA,IAAY,CAAC,cAAc,GAAG,IAAI;IACrC;AAEA;;AAEG;IACK,cAAc,GAAA;AACpB,QAAA,MAAM,IAAI,GAAI,IAAY,CAAC,cAAc;QACzC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,aAAa,EAAE;AAC/C,YAAA,OAAO,CAAC,KAAK,CAAC,6DAA6D,CAAC;YAC5E;QACF;QAEA,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;AACxE,QAAA,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAC1C;AACE,YAAA,IAAI,EAAE,cAAc;AACpB,YAAA,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;SAC5B,EACD,cAAc,CACf;IACH;AAEA;;AAEG;IACK,aAAa,GAAA;AACnB,QAAA,IAAI,IAAI,CAAC,YAAY,EAAE;AACrB,YAAA,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;AAC1B,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI;QAC1B;AAEA,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI;QACzB,OAAQ,IAAY,CAAC,cAAc;IACrC;AAEA;;AAEG;IACH,OAAO,GAAA;;AAEL,QAAA,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB;QACF;;AAGA,QAAA,IAAI,IAAI,CAAC,MAAM,EAAE;AACf,YAAA,IAAI;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;AACpB,gBAAA,IAAI,CAAC,MAAM,GAAG,IAAI;YACpB;YAAE,OAAO,GAAG,EAAE;AACZ,gBAAA,OAAO,CAAC,KAAK,CAAC,4CAA4C,EAAE,GAAG,CAAC;YAClE;QACF;;QAGA,IAAI,CAAC,aAAa,EAAE;;AAGpB,QAAA,IAAI,CAAC,OAAO,GAAG,KAAK;AACpB,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI;;QAGrB,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC;AAC1D,QAAA,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;IACtB;AAEA;;AAEG;IACH,EAAE,CAAC,KAAgB,EAAE,OAAiC,EAAA;QACpD,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;IACxC;AAEA;;AAEG;IACH,IAAI,CAAC,KAAgB,EAAE,OAAiC,EAAA;QACtD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC;IAC1C;AAEA;;AAEG;IACH,GAAG,CAAC,KAAgB,EAAE,OAAiC,EAAA;QACrD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC;IAClC;AAEA;;AAEG;IACH,SAAS,GAAA;QACP,OAAO,IAAI,CAAC,OAAO;IACrB;AACD;AAED;;;AAGG;AACH,MAAM,iBAAiB,GAA4B,UAEjD,OAAiC,EAAA;;AAGjC,IAAA,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC;AAClC;AAEA;AACC,iBAAyB,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO;;;;"}
@@ -1,2 +1,2 @@
1
- var PaypercutCheckout=function(){"use strict";class e{constructor(){this.handlers=new Map}on(e,t){return this.handlers.has(e)||this.handlers.set(e,new Set),this.handlers.get(e).add(t),()=>this.off(e,t)}once(e,t){const s=(...o)=>{t(...o),this.off(e,s)};return this.on(e,s)}off(e,t){this.handlers.get(e)?.delete(t)}emit(e,...t){this.handlers.get(e)?.forEach(s=>{try{s(...t)}catch(t){console.error(`[Emitter] Error in ${e} handler:`,t)}})}clear(){this.handlers.clear()}}const t={version:"1.0.6",defaultCheckoutOrigin:"https://buy.paypercut.io",allowedOrigins:["https://buy.paypercut.io"]};function s(e){return t.defaultCheckoutOrigin}const o=new Set(["bg","bg-BG","en","en-GB","el","el-GR","ro","ro-RO","hr","hr-HR","pl","pl-PL","cs","cs-CZ","sl","sl-SI","sk","sk-SK"]);var r,i,n,a;function h(e){return Object.values(i).includes(e)}function c(e){return Object.values(n).includes(e)}function d(e){var t;if(e)return t=e,Object.values(r).includes(t)?e:void console.warn(`[PaypercutCheckout] Invalid ui_mode: "${e}". Valid options: ${Object.values(r).join(", ")}`)}!function(e){e.CUSTOM="custom",e.EMBEDDED="embedded",e.HOSTED="hosted"}(r||(r={})),function(e){e.CARD="card"}(i||(i={})),function(e){e.APPLE_PAY="apple_pay",e.GOOGLE_PAY="google_pay"}(n||(n={})),function(e){e.Loaded="loaded",e.Success="success",e.Error="error",e.Expired="expired",e.ThreeDSComplete="threeds_complete",e.ThreeDSError="threeds_error",e.ThreeDSCanceled="threeds_canceled",e.ThreeDSStarted="threeds_started"}(a||(a={}));class l{constructor(t){this.options=t,this.emitter=new e,this.mounted=!1,this.destroyed=!1,this.iframe=null,this.threeDSModal=null,this.threeDSIframe=null,this.messageHandler=this.onMessage.bind(this),window.addEventListener("message",this.messageHandler)}buildSrc(){const e=s(this.options.hostedCheckoutUrl),t=new URL(`/c/${this.options.id}`,e);if(this.options.locale){const e=(r=this.options.locale)&&"auto"!==r?o.has(r)?r:(console.warn(`[PaypercutCheckout] Locale "${r}" is not supported. Falling back to "en".`),"en"):"en";t.searchParams.set("locale",e)}var r;if(this.options.ui_mode){const e=d(this.options.ui_mode);e&&t.searchParams.set("ui_mode",e)}if(this.options.payment_methods&&this.options.payment_methods.length>0){(function(e){const t=[];for(const s of e)h(s)?t.push(s):console.warn(`[PaypercutCheckout] Invalid payment method: "${s}". Skipping.`);return 0===t.length&&(console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to "card".'),t.push(i.CARD)),t})(this.options.payment_methods).forEach(e=>{t.searchParams.append("payment_methods",e)})}if(this.options.wallet_options&&this.options.wallet_options.length>0){(function(e){const t=[];for(const s of e)c(s)?t.push(s):console.warn(`[PaypercutCheckout] Invalid wallet option: "${s}". Skipping.`);return t})(this.options.wallet_options).forEach(e=>{t.searchParams.append("wallet_options",e)})}return this.options.appearance?.preset&&t.searchParams.set("preset",this.options.appearance.preset),void 0!==this.options.form_only&&t.searchParams.set("form_only",String(this.options.form_only)),t.toString()}getContainer(){const e="string"==typeof this.options.containerId?document.querySelector(this.options.containerId):this.options.containerId;if(!e)throw new Error(`Container not found: ${this.options.containerId}`);return e}onMessage(e){if(s=e.origin,!t.allowedOrigins.includes(s))return;var s;const o=e.data;if(o&&"object"==typeof o&&"type"in o&&(!o.checkoutId||o.checkoutId===this.options.id))switch(o.type){case"CHECKOUT_LOADED":this.emitter.emit(a.Loaded);break;case"CHECKOUT_SUCCESS":this.emitter.emit(a.Success);break;case"CHECKOUT_ERROR":this.emitter.emit(a.Error,(o&&o.error)??o);break;case"CHECKOUT_EXPIRED":this.emitter.emit(a.Expired);break;case"THREEDS_START_FLOW":this.show3DSModal(o),this.emitter.emit(a.ThreeDSStarted);break;case"THREEDS_READY":this.handle3DSReady();break;case"THREEDS_COMPLETE":this.postToIframe(o),this.close3DSModal(),this.emitter.emit(a.ThreeDSComplete);break;case"THREEDS_CANCELED":this.postToIframe(o),this.close3DSModal(),this.emitter.emit(a.ThreeDSCanceled);break;case"THREEDS_ERROR":this.postToIframe(o),this.close3DSModal(),this.emitter.emit(a.ThreeDSError,o.error)}}render(){if(!this.mounted)try{const e=this.getContainer();this.iframe=document.createElement("iframe"),this.iframe.id="paypercut-checkout-iframe",this.iframe.src=this.buildSrc(),this.iframe.allow="payment *; clipboard-write",this.iframe.setAttribute("frameborder","0"),this.iframe.setAttribute("allowpaymentrequest","true"),this.iframe.setAttribute("sandbox","allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox"),Object.assign(this.iframe.style,{width:"100%",height:"100%",border:"none",display:"block"}),e.appendChild(this.iframe),this.mounted=!0}catch(e){throw console.error("[PaypercutCheckout] Failed to render:",e),e}}submit(){if(this.mounted)try{this.postToIframe({type:"START_PROCESSING",checkoutId:this.options.id})}catch(e){throw console.error("[PaypercutCheckout] Failed to submit payment:",e),e}}postToIframe(e){if(!this.iframe?.contentWindow)return void console.error("[PaypercutCheckout] Cannot post message: iframe not mounted");const t=s(this.options.hostedCheckoutUrl);this.iframe.contentWindow.postMessage(e,t)}show3DSModal(e){this.threeDSModal=document.createElement("div"),this.threeDSModal.id="paypercut-3ds-modal",Object.assign(this.threeDSModal.style,{position:"fixed",top:"0",left:"0",width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center",zIndex:"999999"});const t=document.createElement("div");Object.assign(t.style,{position:"relative",display:"flex",flexDirection:"column",backgroundColor:"#ffffff",borderRadius:"24px"}),this.threeDSIframe=document.createElement("iframe");const o=s(this.options.hostedCheckoutUrl),r=new URL(`/c/${this.options.id}/threeds`,o);r.searchParams.set("sessionId",e.sessionId),r.searchParams.set("step",e.step),e.challengeUrl&&r.searchParams.set("challengeUrl",e.challengeUrl),e.acsTransactionId&&r.searchParams.set("acsTransactionId",e.acsTransactionId),e.threeDSVersion&&r.searchParams.set("threeDSVersion",e.threeDSVersion),this.threeDSIframe.src=r.toString(),this.threeDSIframe.allow="payment *",this.threeDSIframe.setAttribute("frameborder","0");const i=window.innerWidth,n=window.innerHeight,a=Math.min(Math.max(.6*i,400),800),h=Math.min(Math.max(.6*n,400),600);Object.assign(this.threeDSIframe.style,{width:`${a}px`,height:`${h}px`,border:"none",borderRadius:"24px",backgroundColor:"white",overflow:"auto"}),t.appendChild(this.threeDSIframe),this.threeDSModal.appendChild(t),document.body.appendChild(this.threeDSModal),this.pending3DSData=e}handle3DSReady(){if(!this.pending3DSData||!this.threeDSIframe?.contentWindow)return void console.error("[PaypercutCheckout] No pending 3DS data or iframe not ready");const e=s(this.options.hostedCheckoutUrl);this.threeDSIframe.contentWindow.postMessage({type:"THREEDS_INIT",checkoutId:this.options.id},e)}close3DSModal(){this.threeDSModal&&(this.threeDSModal.remove(),this.threeDSModal=null),this.threeDSIframe=null,delete this.pending3DSData}destroy(){if(!this.destroyed){if(this.iframe)try{this.iframe.remove(),this.iframe=null}catch(e){console.error("[PaypercutCheckout] Error removing iframe:",e)}this.close3DSModal(),this.mounted=!1,this.destroyed=!0,window.removeEventListener("message",this.messageHandler),this.emitter.clear()}}on(e,t){return this.emitter.on(e,t)}once(e,t){return this.emitter.once(e,t)}off(e,t){this.emitter.off(e,t)}isMounted(){return this.mounted}}const p=function(e){return new l(e)};return p.version=t.version,p}();
1
+ var PaypercutCheckout=function(){"use strict";class e{constructor(){this.handlers=new Map}on(e,t){return this.handlers.has(e)||this.handlers.set(e,new Set),this.handlers.get(e).add(t),()=>this.off(e,t)}once(e,t){const s=(...r)=>{t(...r),this.off(e,s)};return this.on(e,s)}off(e,t){this.handlers.get(e)?.delete(t)}emit(e,...t){this.handlers.get(e)?.forEach(s=>{try{s(...t)}catch(t){console.error(`[Emitter] Error in ${e} handler:`,t)}})}clear(){this.handlers.clear()}}const t={version:"1.0.8",defaultCheckoutOrigin:"https://buy.paypercut.io",allowedOrigins:["https://buy.paypercut.io"]};function s(e){return t.defaultCheckoutOrigin}const r=new Set(["bg","bg-BG","en","en-GB","el","el-GR","ro","ro-RO","hr","hr-HR","pl","pl-PL","cs","cs-CZ","sl","sl-SI","sk","sk-SK"]);var o,i,n,a;function h(e){return Object.values(i).includes(e)}function c(e){return Object.values(n).includes(e)}function d(e){var t;if(e)return t=e,Object.values(o).includes(t)?e:void console.warn(`[PaypercutCheckout] Invalid ui_mode: "${e}". Valid options: ${Object.values(o).join(", ")}`)}!function(e){e.EMBEDDED="embedded"}(o||(o={})),function(e){e.CARD="card"}(i||(i={})),function(e){e.APPLE_PAY="apple_pay",e.GOOGLE_PAY="google_pay"}(n||(n={})),function(e){e.Loaded="loaded",e.Success="success",e.Error="error",e.Expired="expired",e.ThreeDSComplete="threeds_complete",e.ThreeDSError="threeds_error",e.ThreeDSCanceled="threeds_canceled",e.ThreeDSStarted="threeds_started"}(a||(a={}));class l{constructor(t){this.options=t,this.emitter=new e,this.mounted=!1,this.destroyed=!1,this.iframe=null,this.threeDSModal=null,this.threeDSIframe=null,this.messageHandler=this.onMessage.bind(this),window.addEventListener("message",this.messageHandler)}buildSrc(){const e=s(this.options.hostedCheckoutUrl),t=new URL(`/c/${this.options.id}`,e);if(this.options.locale){const e=(n=this.options.locale)&&"auto"!==n?r.has(n)?n:(console.warn(`[PaypercutCheckout] Locale "${n}" is not supported. Falling back to "en".`),"en"):"en";t.searchParams.set("locale",e)}var n;{const e=d(this.options.ui_mode??o.EMBEDDED);e&&t.searchParams.set("ui_mode",e)}if(this.options.payment_methods&&this.options.payment_methods.length>0){(function(e){const t=[];for(const s of e)h(s)?t.push(s):console.warn(`[PaypercutCheckout] Invalid payment method: "${s}". Skipping.`);return 0===t.length&&(console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to "card".'),t.push(i.CARD)),t})(this.options.payment_methods).forEach(e=>{t.searchParams.append("payment_methods",e)})}if(this.options.wallet_options&&this.options.wallet_options.length>0){(function(e){const t=[];for(const s of e)c(s)?t.push(s):console.warn(`[PaypercutCheckout] Invalid wallet option: "${s}". Skipping.`);return t})(this.options.wallet_options).forEach(e=>{t.searchParams.append("wallet_options",e)})}return this.options.appearance?.preset&&t.searchParams.set("preset",this.options.appearance.preset),void 0!==this.options.form_only&&t.searchParams.set("form_only",String(this.options.form_only)),t.toString()}getContainer(){const e="string"==typeof this.options.containerId?document.querySelector(this.options.containerId):this.options.containerId;if(!e)throw new Error(`Container not found: ${this.options.containerId}`);return e}onMessage(e){if(s=e.origin,!t.allowedOrigins.includes(s))return;var s;const r=e.data;if(r&&"object"==typeof r&&"type"in r&&(!r.checkoutId||r.checkoutId===this.options.id))switch(r.type){case"CHECKOUT_LOADED":this.emitter.emit(a.Loaded);break;case"CHECKOUT_SUCCESS":this.emitter.emit(a.Success);break;case"CHECKOUT_ERROR":this.emitter.emit(a.Error,(r&&r.error)??r);break;case"CHECKOUT_EXPIRED":this.emitter.emit(a.Expired);break;case"THREEDS_START_FLOW":this.show3DSModal(r),this.emitter.emit(a.ThreeDSStarted);break;case"THREEDS_READY":this.handle3DSReady();break;case"THREEDS_COMPLETE":this.postToIframe(r),this.close3DSModal(),this.emitter.emit(a.ThreeDSComplete);break;case"THREEDS_CANCELED":this.postToIframe(r),this.close3DSModal(),this.emitter.emit(a.ThreeDSCanceled);break;case"THREEDS_ERROR":this.postToIframe(r),this.close3DSModal(),this.emitter.emit(a.ThreeDSError,r.error)}}render(){if(!this.mounted)try{const e=this.getContainer();this.iframe=document.createElement("iframe"),this.iframe.id="paypercut-checkout-iframe",this.iframe.src=this.buildSrc(),this.iframe.allow="payment *; clipboard-write",this.iframe.setAttribute("frameborder","0"),this.iframe.setAttribute("allowpaymentrequest","true"),this.iframe.setAttribute("sandbox","allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox"),Object.assign(this.iframe.style,{width:"100%",height:"100%",border:"none",display:"block"}),e.appendChild(this.iframe),this.mounted=!0}catch(e){throw console.error("[PaypercutCheckout] Failed to render:",e),e}}submit(){if(this.mounted)try{this.postToIframe({type:"START_PROCESSING",checkoutId:this.options.id})}catch(e){throw console.error("[PaypercutCheckout] Failed to submit payment:",e),e}}postToIframe(e){if(!this.iframe?.contentWindow)return void console.error("[PaypercutCheckout] Cannot post message: iframe not mounted");const t=s(this.options.hostedCheckoutUrl);this.iframe.contentWindow.postMessage(e,t)}show3DSModal(e){this.threeDSModal=document.createElement("div"),this.threeDSModal.id="paypercut-3ds-modal",Object.assign(this.threeDSModal.style,{position:"fixed",top:"0",left:"0",width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center",zIndex:"999999",background:"rgba(0, 0, 0, 0.4)"}),this.threeDSIframe=document.createElement("iframe");const t=s(this.options.hostedCheckoutUrl),r=new URL(`/c/${this.options.id}/threeds`,t);r.searchParams.set("sessionId",e.sessionId),r.searchParams.set("step",e.step),e.challengeUrl&&r.searchParams.set("challengeUrl",e.challengeUrl),e.acsTransactionId&&r.searchParams.set("acsTransactionId",e.acsTransactionId),e.threeDSVersion&&r.searchParams.set("threeDSVersion",e.threeDSVersion),r.searchParams.set("liveMode",String(e.liveMode??!1)),this.threeDSIframe.src=r.toString(),this.threeDSIframe.allow="payment *",this.threeDSIframe.setAttribute("frameborder","0"),Object.assign(this.threeDSIframe.style,{minWidth:"400px",minHeight:"400px",border:"none",borderRadius:"8px",display:"block",background:"transparent"}),this.threeDSModal.appendChild(this.threeDSIframe),document.body.appendChild(this.threeDSModal),this.pending3DSData=e}handle3DSReady(){if(!this.pending3DSData||!this.threeDSIframe?.contentWindow)return void console.error("[PaypercutCheckout] No pending 3DS data or iframe not ready");const e=s(this.options.hostedCheckoutUrl);this.threeDSIframe.contentWindow.postMessage({type:"THREEDS_INIT",checkoutId:this.options.id},e)}close3DSModal(){this.threeDSModal&&(this.threeDSModal.remove(),this.threeDSModal=null),this.threeDSIframe=null,delete this.pending3DSData}destroy(){if(!this.destroyed){if(this.iframe)try{this.iframe.remove(),this.iframe=null}catch(e){console.error("[PaypercutCheckout] Error removing iframe:",e)}this.close3DSModal(),this.mounted=!1,this.destroyed=!0,window.removeEventListener("message",this.messageHandler),this.emitter.clear()}}on(e,t){return this.emitter.on(e,t)}once(e,t){return this.emitter.once(e,t)}off(e,t){this.emitter.off(e,t)}isMounted(){return this.mounted}}const p=function(e){return new l(e)};return p.version=t.version,p}();
2
2
  //# sourceMappingURL=paypercut-checkout.iife.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"paypercut-checkout.iife.min.js","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Custom UI mode - merchant provides their own submit button */\n CUSTOM = 'custom',\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n /** Hosted mode - full-page checkout experience */\n HOSTED = 'hosted',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter\n if (this.options.ui_mode) {\n const validatedUIMode = validateUIMode(this.options.ui_mode);\n if (validatedUIMode) {\n url.searchParams.set('ui_mode', validatedUIMode);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n // backgroundColor: 'rgba(0, 0, 0, 0.5)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n });\n\n // Create container for iframe + close button\n const modalContainer = document.createElement('div');\n Object.assign(modalContainer.style, {\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n backgroundColor: '#ffffff',\n borderRadius: '24px',\n });\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Responsive modal sizing (60% of viewport, min 400px, max 800px width / 600px height)\n const viewportWidth = window.innerWidth;\n const viewportHeight = window.innerHeight;\n const modalWidth = Math.min(Math.max(viewportWidth * 0.6, 400), 800);\n const modalHeight = Math.min(Math.max(viewportHeight * 0.6, 400), 600);\n\n Object.assign(this.threeDSIframe.style, {\n width: `${modalWidth}px`,\n height: `${modalHeight}px`,\n border: 'none',\n borderRadius: '24px',\n backgroundColor: 'white',\n overflow: 'auto',\n });\n\n // Append iframe\n modalContainer.appendChild(this.threeDSIframe);\n\n // Append container to modal backdrop\n this.threeDSModal.appendChild(modalContainer);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":["Emitter","constructor","this","handlers","Map","on","event","handler","has","set","Set","get","add","off","once","wrappedHandler","args","delete","emit","forEach","h","err","console","error","clear","config","version","defaultCheckoutOrigin","allowedOrigins","getCheckoutOrigin","override","LOCALE_SET","UIMode","PaymentMethod","WalletOption","SdkEvent","isValidPaymentMethod","value","Object","values","includes","isValidWalletOption","validateUIMode","mode","warn","join","CheckoutImpl","options","emitter","mounted","destroyed","iframe","threeDSModal","threeDSIframe","messageHandler","onMessage","bind","window","addEventListener","buildSrc","baseUrl","hostedCheckoutUrl","url","URL","id","locale","normalizedLocale","searchParams","ui_mode","validatedUIMode","payment_methods","length","methods","validated","method","push","CARD","validatePaymentMethods","append","wallet_options","option","validateWalletOptions","wallet","appearance","preset","undefined","form_only","String","toString","getContainer","container","containerId","document","querySelector","Error","evt","origin","data","checkoutId","type","Loaded","Success","Expired","show3DSModal","ThreeDSStarted","handle3DSReady","postToIframe","close3DSModal","ThreeDSComplete","ThreeDSCanceled","ThreeDSError","render","createElement","src","allow","setAttribute","assign","style","width","height","border","display","appendChild","submit","message","contentWindow","checkoutOrigin","postMessage","position","top","left","alignItems","justifyContent","zIndex","modalContainer","flexDirection","backgroundColor","borderRadius","threeDSUrl","sessionId","step","challengeUrl","acsTransactionId","threeDSVersion","viewportWidth","innerWidth","viewportHeight","innerHeight","modalWidth","Math","min","max","modalHeight","overflow","body","pending3DSData","remove","destroy","removeEventListener","isMounted","PaypercutCheckout"],"mappings":"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"}
1
+ {"version":3,"file":"paypercut-checkout.iife.min.js","sources":["../src/utils/emitter.ts","../src/config.ts","../src/types/locales.ts","../src/types/checkout.ts","../src/index.ts"],"sourcesContent":["/**\n * Simple event emitter for handling checkout events\n * Supports subscribing, unsubscribing, and emitting events\n */\nexport class Emitter<T extends string = string> {\n private handlers = new Map<T, Set<Function>>();\n\n /**\n * Subscribe to an event\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n on(event: T, handler: Function): () => void {\n if (!this.handlers.has(event)) {\n this.handlers.set(event, new Set());\n }\n this.handlers.get(event)!.add(handler);\n\n // Return unsubscribe function\n return () => this.off(event, handler);\n }\n\n /**\n * Subscribe to an event that auto-unsubscribes after first emission\n *\n * Common use case: waiting for 'loaded' event or handling first 'success'.\n * Without this helper, developers would need to manually unsubscribe inside\n * their handler, which is error-prone and leads to memory leaks if forgotten.\n *\n * @param event - Event name to listen to\n * @param handler - Callback function to execute when event is emitted\n * @returns Unsubscribe function\n */\n once(event: T, handler: Function): () => void {\n const wrappedHandler = (...args: any[]) => {\n handler(...args);\n this.off(event, wrappedHandler);\n };\n return this.on(event, wrappedHandler);\n }\n\n /**\n * Unsubscribe from an event\n * @param event - Event name to stop listening to\n * @param handler - Callback function to remove\n */\n off(event: T, handler: Function): void {\n this.handlers.get(event)?.delete(handler);\n }\n\n /**\n * Emit an event with optional arguments\n * @param event - Event name to emit\n * @param args - Arguments to pass to event handlers\n */\n emit(event: T, ...args: any[]): void {\n this.handlers.get(event)?.forEach(h => {\n try {\n h(...args);\n } catch (err) {\n console.error(`[Emitter] Error in ${event} handler:`, err);\n }\n });\n }\n\n /**\n * Clear all event handlers\n */\n clear(): void {\n this.handlers.clear();\n }\n}\n\n","/**\n * Build-time configuration\n * \n * This file is processed at build time with different values for:\n * - Production build (for merchants)\n * - Internal build (for team development)\n */\n\n/**\n * Build mode - replaced at build time\n */\ndeclare const __BUILD_MODE__: 'production' | 'internal';\n\n/**\n * SDK version - replaced at build time\n */\ndeclare const __VERSION__: string;\n\n/**\n * Configuration interface\n */\nexport interface BuildConfig {\n /** SDK version */\n version: string;\n \n /** Build mode */\n mode: 'production' | 'internal';\n \n /** Default checkout origin (production URL) */\n defaultCheckoutOrigin: string;\n \n /** Allowed origins for postMessage validation */\n allowedOrigins: string[];\n \n /** Whether hostedCheckoutUrl override is allowed */\n allowOriginOverride: boolean;\n}\n\n/**\n * Production configuration (for merchants)\n */\nconst productionConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'production',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n ],\n allowOriginOverride: false\n};\n\n/**\n * Internal configuration (for team development)\n */\nconst internalConfig: BuildConfig = {\n version: __VERSION__,\n mode: 'internal',\n defaultCheckoutOrigin: 'https://buy.paypercut.io',\n allowedOrigins: [\n 'https://buy.paypercut.io',\n 'http://localhost:3000',\n 'http://localhost:3001',\n 'http://127.0.0.1:3000',\n 'http://127.0.0.1:3001'\n ],\n allowOriginOverride: true\n};\n\n/**\n * Active configuration (selected at build time)\n */\nexport const config: BuildConfig = __BUILD_MODE__ === 'internal' \n ? internalConfig \n : productionConfig;\n\n/**\n * Helper to check if origin is allowed\n */\nexport function isOriginAllowed(origin: string): boolean {\n return config.allowedOrigins.includes(origin);\n}\n\n/**\n * Get the checkout origin (with optional override for internal builds)\n */\nexport function getCheckoutOrigin(override?: string): string {\n // Only allow override in internal builds\n if (override && config.allowOriginOverride) {\n return override;\n }\n \n return config.defaultCheckoutOrigin;\n}\n\n","/**\n * Supported locales for Paypercut Checkout\n * \n * @remarks\n * Single source of truth for all supported locale codes.\n * \n * Supported languages:\n * - Bulgarian: 'bg', 'bg-BG'\n * - English: 'en', 'en-GB'\n * - Greek: 'el', 'el-GR'\n * - Romanian: 'ro', 'ro-RO'\n * - Croatian: 'hr', 'hr-HR'\n * - Polish: 'pl', 'pl-PL'\n * - Czech: 'cs', 'cs-CZ'\n * - Slovenian: 'sl', 'sl-SI'\n * - Slovak: 'sk', 'sk-SK'\n * \n * @example\n * ```typescript\n * const checkout = PaypercutCheckout({\n * locale: 'bg' // or 'bg-BG', 'en', 'en-GB', etc.\n * });\n * ```\n */\nexport const LOCALES = [\n 'bg', 'bg-BG',\n 'en', 'en-GB',\n 'el', 'el-GR',\n 'ro', 'ro-RO',\n 'hr', 'hr-HR',\n 'pl', 'pl-PL',\n 'cs', 'cs-CZ',\n 'sl', 'sl-SI',\n 'sk', 'sk-SK',\n] as const;\n\n/**\n * Locale type - union of all supported locale codes plus 'auto'\n * @example\n * ```typescript\n * const locale: Locale = 'bg';\n * const autoLocale: Locale = 'auto';\n * ```\n */\nexport type Locale = typeof LOCALES[number] | 'auto';\n\n/**\n * Fast runtime check using Set for O(1) lookup\n * @internal\n */\nconst LOCALE_SET: ReadonlySet<string> = new Set(LOCALES);\n\n/**\n * Normalize and validate locale\n * \n * @param locale - Locale code to normalize\n * @returns Normalized locale code or 'en' as fallback\n * \n * @remarks\n * - 'auto' or empty → 'en'\n * - Unsupported locale → 'en' with console warning\n * - Supported locale → original value\n * \n * @example\n * ```typescript\n * normalizeLocale('auto') // → 'en'\n * normalizeLocale('bg') // → 'bg'\n * normalizeLocale('de') // → 'en' (with warning)\n * ```\n */\nexport function normalizeLocale(locale: string | Locale): typeof LOCALES[number] | 'en' {\n if (!locale || locale === 'auto') return 'en';\n if (LOCALE_SET.has(locale)) return locale as typeof LOCALES[number];\n console.warn(`[PaypercutCheckout] Locale \"${locale}\" is not supported. Falling back to \"en\".`);\n return 'en';\n}\n\n","import { Locale } from './locales';\n\n/**\n * UI mode for checkout\n */\nexport enum UIMode {\n /** Embedded mode - checkout embedded in merchant page */\n EMBEDDED = 'embedded',\n}\n\n/**\n * Type guard for UIMode\n */\nexport function isValidUIMode(value: string): value is UIMode {\n return Object.values(UIMode).includes(value as UIMode);\n}\n\n/**\n * Payment method types\n */\nexport enum PaymentMethod {\n /** Card payment (credit/debit) */\n CARD = 'card',\n}\n\n/**\n * Type guard for PaymentMethod\n */\nexport function isValidPaymentMethod(value: string): value is PaymentMethod {\n return Object.values(PaymentMethod).includes(value as PaymentMethod);\n}\n\n/**\n * Wallet options for digital wallets\n */\nexport enum WalletOption {\n /** Apple Pay */\n APPLE_PAY = 'apple_pay',\n /** Google Pay */\n GOOGLE_PAY = 'google_pay',\n}\n\n/**\n * Type guard for WalletOption\n */\nexport function isValidWalletOption(value: string): value is WalletOption {\n return Object.values(WalletOption).includes(value as WalletOption);\n}\n\n/**\n * Validate payment methods array\n */\nexport function validatePaymentMethods(methods: string[]): PaymentMethod[] {\n const validated: PaymentMethod[] = [];\n\n for (const method of methods) {\n if (isValidPaymentMethod(method)) {\n validated.push(method as PaymentMethod);\n } else {\n console.warn(`[PaypercutCheckout] Invalid payment method: \"${method}\". Skipping.`);\n }\n }\n\n // Default to card if no valid methods\n if (validated.length === 0) {\n console.warn('[PaypercutCheckout] No valid payment methods provided. Defaulting to \"card\".');\n validated.push(PaymentMethod.CARD);\n }\n\n return validated;\n}\n\n/**\n * Validate wallet options array\n */\nexport function validateWalletOptions(options: string[]): WalletOption[] {\n const validated: WalletOption[] = [];\n\n for (const option of options) {\n if (isValidWalletOption(option)) {\n validated.push(option as WalletOption);\n } else {\n console.warn(`[PaypercutCheckout] Invalid wallet option: \"${option}\". Skipping.`);\n }\n }\n\n return validated;\n}\n\n/**\n * Validate UI mode\n */\nexport function validateUIMode(mode: string | undefined): UIMode | undefined {\n if (!mode) {\n return undefined;\n }\n\n if (isValidUIMode(mode)) {\n return mode as UIMode;\n }\n\n console.warn(\n `[PaypercutCheckout] Invalid ui_mode: \"${mode}\". Valid options: ${Object.values(UIMode).join(', ')}`,\n );\n return undefined;\n}\n\n/**\n * Configuration options for PaypercutCheckout\n */\nexport interface PaypercutCheckoutOptions {\n /** Checkout session identifier (e.g., 'CHK_12345') */\n id: string;\n\n /** CSS selector or HTMLElement where iframe mounts (required) */\n containerId: string | HTMLElement;\n\n /**\n * Optional: Custom hosted checkout URL (only available in internal builds)\n * Production builds will ignore this option for security\n */\n hostedCheckoutUrl?: string;\n\n /**\n * Optional: Locale for checkout UI\n * @default 'en'\n */\n locale?: Locale | string;\n\n /**\n * Optional: UI mode for checkout\n */\n ui_mode?: UIMode | `${UIMode}`;\n\n /**\n * Optional: Payment methods to enable\n * @default ['card']\n */\n payment_methods?: (PaymentMethod | `${PaymentMethod}`)[];\n\n /**\n * Optional: Digital wallet options\n * Can include both or just one\n */\n wallet_options?: (WalletOption | `${WalletOption}`)[];\n\n /**\n * Optional: Show only the payment form without header/footer\n * @default false\n */\n form_only?: boolean;\n\n /**\n * Optional: Appearance options\n */\n appearance?: {\n preset?: 'inline' | 'modal';\n theme?: 'light' | 'dark' | 'none' | 'flat';\n variables: {};\n rules: {};\n labels: 'floating' | 'above' | 'none';\n };\n}\n\n/**\n * Event names that can be emitted by the checkout\n */\nexport type EventName =\n | 'loaded' // iframe finished loading\n | 'success' // payment successful\n | 'error' // payment or system error\n | 'expired' // checkout expired or already paid\n | 'threeds_complete' // checkout paid successfully\n | 'threeds_error' // checkout threeds error\n | 'threeds_canceled' // checkout threeds canceled\n | 'threeds_started'; // checkout threeds started\n\n/**\n * Preferred enum for SDK event names (use instead of hardcoded strings)\n */\nexport enum SdkEvent {\n Loaded = 'loaded',\n Success = 'success',\n Error = 'error',\n Expired = 'expired',\n ThreeDSComplete = 'threeds_complete',\n ThreeDSError = 'threeds_error',\n ThreeDSCanceled = 'threeds_canceled',\n ThreeDSStarted = 'threeds_started',\n}\n\n/**\n * Checkout instance interface\n */\nexport interface CheckoutInstance {\n /** Mount and render the iframe into the container */\n render(): void;\n\n /** Submit payment - sends message to hosted checkout to confirm payment */\n submit(): void;\n\n /** Destroy instance and cleanup all listeners */\n destroy(): void;\n\n /** Subscribe to events. Returns unsubscribe function */\n on(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Subscribe to event that auto-unsubscribes after first emission */\n once(event: EventName | SdkEvent, handler: (...args: any[]) => void): () => void;\n\n /** Unsubscribe from events */\n off(event: EventName | SdkEvent, handler: (...args: any[]) => void): void;\n\n /** Check if checkout is currently mounted */\n isMounted(): boolean;\n}\n\n/**\n * PaypercutCheckout static interface (callable and constructable)\n */\nexport interface PaypercutCheckoutStatic {\n /** Callable factory function */\n (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** Constructor support */\n new (options: PaypercutCheckoutOptions): CheckoutInstance;\n\n /** SDK version */\n version: string;\n}\n","import { Emitter } from './utils/emitter';\nimport { config, isOriginAllowed, getCheckoutOrigin } from './config';\n\nimport {\n PaypercutCheckoutOptions,\n CheckoutInstance,\n PaypercutCheckoutStatic,\n EventName,\n SdkEvent,\n validatePaymentMethods,\n validateWalletOptions,\n validateUIMode,\n UIMode,\n} from './types';\nimport { normalizeLocale } from './types';\n\n// Re-export types and enums for consumers\nexport type { PaypercutCheckoutOptions, CheckoutInstance, PaypercutCheckoutStatic, EventName };\n\nexport { UIMode, PaymentMethod, WalletOption } from './types/checkout';\n\n\n// Re-export SDK event enums for consumers\nexport { SdkEvent } from './types/checkout';\n\nexport type { Locale } from './types/locales';\nexport { LOCALES } from './types/locales';\n\n/**\n * Internal implementation of CheckoutInstance\n */\nclass CheckoutImpl implements CheckoutInstance {\n private emitter = new Emitter<EventName>();\n private mounted = false;\n private destroyed = false;\n private iframe: HTMLIFrameElement | null = null;\n private messageHandler: (evt: MessageEvent) => void;\n\n // 3DS Modal state\n private threeDSModal: HTMLDivElement | null = null;\n private threeDSIframe: HTMLIFrameElement | null = null;\n\n constructor(private options: PaypercutCheckoutOptions) {\n // Bind message handler\n this.messageHandler = this.onMessage.bind(this);\n window.addEventListener('message', this.messageHandler);\n }\n\n /**\n * Build the iframe source URL with query parameters\n */\n private buildSrc(): string {\n const baseUrl = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n const url = new URL(`/c/${this.options.id}`, baseUrl);\n\n // Add locale parameter\n if (this.options.locale) {\n const normalizedLocale = normalizeLocale(this.options.locale);\n url.searchParams.set('locale', normalizedLocale);\n }\n\n // Add ui_mode parameter (default to 'embedded')\n {\n const selected = validateUIMode(this.options.ui_mode ?? UIMode.EMBEDDED);\n if (selected) {\n url.searchParams.set('ui_mode', selected);\n }\n }\n\n // Add payment_methods parameters (repeated for each method)\n if (this.options.payment_methods && this.options.payment_methods.length > 0) {\n const validatedMethods = validatePaymentMethods(this.options.payment_methods as string[]);\n validatedMethods.forEach((method) => {\n url.searchParams.append('payment_methods', method);\n });\n }\n\n // Add wallet_options parameters (repeated for each wallet)\n if (this.options.wallet_options && this.options.wallet_options.length > 0) {\n const validatedWallets = validateWalletOptions(this.options.wallet_options as string[]);\n validatedWallets.forEach((wallet) => {\n url.searchParams.append('wallet_options', wallet);\n });\n }\n\n if (this.options.appearance?.preset) {\n url.searchParams.set('preset', this.options.appearance.preset);\n }\n\n if (this.options.form_only !== undefined) {\n url.searchParams.set('form_only', String(this.options.form_only));\n }\n\n return url.toString();\n }\n\n /**\n * Get the container element from selector or HTMLElement\n */\n private getContainer(): HTMLElement {\n const container =\n typeof this.options.containerId === 'string'\n ? document.querySelector(this.options.containerId)\n : this.options.containerId;\n\n if (!container) {\n throw new Error(`Container not found: ${this.options.containerId}`);\n }\n\n return container as HTMLElement;\n }\n\n /**\n * Handle incoming postMessage events from iframe\n */\n private onMessage(evt: MessageEvent): void {\n // Validate origin against allowed origins (build-time whitelist)\n if (!isOriginAllowed(evt.origin)) {\n return;\n }\n\n // Validate structure\n const data = evt.data;\n if (!data || typeof data !== 'object' || !('type' in data)) {\n return;\n }\n\n // Filter messages by checkout session ID to prevent cross-instance message handling\n // This ensures each checkout instance only processes its own messages\n if (data.checkoutId && data.checkoutId !== this.options.id) {\n return; // Message is for a different checkout instance\n }\n\n // Handle specific events\n switch (data.type) {\n case 'CHECKOUT_LOADED':\n this.emitter.emit(SdkEvent.Loaded);\n break;\n case 'CHECKOUT_SUCCESS':\n this.emitter.emit(SdkEvent.Success);\n break;\n case 'CHECKOUT_ERROR':\n // Forward error payload (if provided) to SDK consumers\n this.emitter.emit(SdkEvent.Error, (data && (data as any).error) ?? data);\n break;\n case 'CHECKOUT_EXPIRED':\n this.emitter.emit(SdkEvent.Expired);\n break;\n case 'THREEDS_START_FLOW':\n this.show3DSModal(data);\n this.emitter.emit(SdkEvent.ThreeDSStarted);\n break;\n case 'THREEDS_READY':\n this.handle3DSReady();\n break;\n case 'THREEDS_COMPLETE':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSComplete);\n break;\n case 'THREEDS_CANCELED':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSCanceled);\n break;\n case 'THREEDS_ERROR':\n this.postToIframe(data);\n this.close3DSModal();\n this.emitter.emit(SdkEvent.ThreeDSError, data.error);\n break;\n }\n }\n\n /**\n * Render the checkout iframe into the container\n */\n render(): void {\n if (this.mounted) {\n return;\n }\n\n try {\n const container = this.getContainer();\n\n // Create iframe\n this.iframe = document.createElement('iframe');\n this.iframe.id = 'paypercut-checkout-iframe';\n this.iframe.src = this.buildSrc();\n this.iframe.allow = 'payment *; clipboard-write';\n this.iframe.setAttribute('frameborder', '0');\n // Allow Payment Request API inside iframe and necessary sandbox permissions for wallets\n this.iframe.setAttribute('allowpaymentrequest', 'true');\n this.iframe.setAttribute(\n 'sandbox',\n 'allow-scripts allow-forms allow-same-origin allow-popups allow-popups-to-escape-sandbox',\n );\n\n\n // Apply default styles - just construct URL and assign to iframe\n Object.assign(this.iframe.style, {\n width: '100%',\n height: '100%',\n border: 'none',\n display: 'block',\n });\n\n // Listen for iframe load event (fallback)\n // This ensures 'loaded' event is always emitted even if hosted checkout\n // doesn't send CHECKOUT_LOADED message\n /*this.iframe.addEventListener('load', () => {\n this.emitter.emit('loaded');\n });*/\n\n container.appendChild(this.iframe);\n this.mounted = true;\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to render:', err);\n throw err;\n }\n }\n\n /**\n * Submit payment - sends message to hosted checkout to confirm payment\n */\n submit(): void {\n if (!this.mounted) {\n return;\n }\n\n try {\n this.postToIframe({\n type: 'START_PROCESSING',\n checkoutId: this.options.id,\n });\n } catch (err) {\n console.error('[PaypercutCheckout] Failed to submit payment:', err);\n throw err;\n }\n }\n\n /**\n * Send message to hosted/embedded checkout iframe - used for submit payment and communicating 3DS events\n */\n private postToIframe(message: any): void {\n if (!this.iframe?.contentWindow) {\n console.error('[PaypercutCheckout] Cannot post message: iframe not mounted');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.iframe.contentWindow.postMessage(message, checkoutOrigin);\n }\n\n /**\n * Show 3DS modal with challenge/decoupled flow\n */\n private show3DSModal(data: {\n sessionId: string;\n step: 'challenge' | 'decoupled_waiting';\n challengeUrl?: string;\n acsTransactionId?: string;\n threeDSVersion?: string;\n cardBrand?: string;\n liveMode?: boolean;\n }): void {\n\n // Create modal backdrop\n this.threeDSModal = document.createElement('div');\n this.threeDSModal.id = 'paypercut-3ds-modal';\n Object.assign(this.threeDSModal.style, {\n position: 'fixed',\n top: '0',\n left: '0',\n width: '100%',\n height: '100%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n zIndex: '999999',\n background: 'rgba(0, 0, 0, 0.4)',\n });\n\n\n\n // Create iframe for 3DS page\n this.threeDSIframe = document.createElement('iframe');\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n\n // Build URL: baseUrl/c/{checkoutId}/threeds with query params\n const threeDSUrl = new URL(`/c/${this.options.id}/threeds`, checkoutOrigin);\n threeDSUrl.searchParams.set('sessionId', data.sessionId);\n threeDSUrl.searchParams.set('step', data.step);\n\n if (data.challengeUrl) {\n threeDSUrl.searchParams.set('challengeUrl', data.challengeUrl);\n }\n if (data.acsTransactionId) {\n threeDSUrl.searchParams.set('acsTransactionId', data.acsTransactionId);\n }\n if (data.threeDSVersion) {\n threeDSUrl.searchParams.set('threeDSVersion', data.threeDSVersion);\n }\n // Always include liveMode; default to false when undefined\n threeDSUrl.searchParams.set('liveMode', String(data.liveMode ?? false));\n\n this.threeDSIframe.src = threeDSUrl.toString();\n this.threeDSIframe.allow = 'payment *';\n this.threeDSIframe.setAttribute('frameborder', '0');\n\n // Fixed dimensions: follow 3DS component size (500x500)\n Object.assign(this.threeDSIframe.style, {\n minWidth: '400px',\n minHeight: '400px',\n border: 'none',\n borderRadius: '8px',\n display: 'block',\n background: 'transparent',\n });\n\n // Append iframe directly to modal backdrop\n this.threeDSModal.appendChild(this.threeDSIframe);\n document.body.appendChild(this.threeDSModal);\n\n // Store 3DS data for later use\n (this as any).pending3DSData = data;\n }\n\n /**\n * Handle THREEDS_READY message - send THREEDS_INIT with challenge data\n */\n private handle3DSReady(): void {\n const data = (this as any).pending3DSData;\n if (!data || !this.threeDSIframe?.contentWindow) {\n console.error('[PaypercutCheckout] No pending 3DS data or iframe not ready');\n return;\n }\n\n const checkoutOrigin = getCheckoutOrigin(this.options.hostedCheckoutUrl);\n this.threeDSIframe.contentWindow.postMessage(\n {\n type: 'THREEDS_INIT',\n checkoutId: this.options.id,\n },\n checkoutOrigin,\n );\n }\n\n /**\n * Close 3DS modal and cleanup\n */\n private close3DSModal(): void {\n if (this.threeDSModal) {\n this.threeDSModal.remove();\n this.threeDSModal = null;\n }\n\n this.threeDSIframe = null;\n delete (this as any).pending3DSData;\n }\n\n /**\n * Destroy the checkout instance and cleanup (idempotent)\n */\n destroy(): void {\n // Early return if already destroyed\n if (this.destroyed) {\n return;\n }\n\n // Remove iframe from DOM\n if (this.iframe) {\n try {\n this.iframe.remove();\n this.iframe = null;\n } catch (err) {\n console.error('[PaypercutCheckout] Error removing iframe:', err);\n }\n }\n\n // Cleanup 3DS modal if open\n this.close3DSModal();\n\n // Only set mounted = false after successful DOM removal\n this.mounted = false;\n this.destroyed = true;\n\n // Cleanup event listeners\n window.removeEventListener('message', this.messageHandler);\n this.emitter.clear();\n }\n\n /**\n * Subscribe to an event\n */\n on(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.on(event, handler);\n }\n\n /**\n * Subscribe to event that auto-unsubscribes after first emission\n */\n once(event: EventName, handler: (...args: any[]) => void): () => void {\n return this.emitter.once(event, handler);\n }\n\n /**\n * Unsubscribe from an event\n */\n off(event: EventName, handler: (...args: any[]) => void): void {\n this.emitter.off(event, handler);\n }\n\n /**\n * Check if checkout is currently mounted\n */\n isMounted(): boolean {\n return this.mounted;\n }\n}\n\n/**\n * Factory function that works both as callable and constructable.\n * Always returns a new CheckoutImpl instance - no prototype manipulation needed.\n */\nconst PaypercutCheckout: PaypercutCheckoutStatic = function (\n this: unknown,\n options: PaypercutCheckoutOptions,\n): CheckoutInstance {\n // Always return a new instance, regardless of how it's called\n return new CheckoutImpl(options);\n} as unknown as PaypercutCheckoutStatic;\n\n// Add static version property\n(PaypercutCheckout as any).version = config.version;\n\n// Export as default and named\nexport default PaypercutCheckout;\nexport { PaypercutCheckout };\n"],"names":["Emitter","constructor","this","handlers","Map","on","event","handler","has","set","Set","get","add","off","once","wrappedHandler","args","delete","emit","forEach","h","err","console","error","clear","config","version","defaultCheckoutOrigin","allowedOrigins","getCheckoutOrigin","override","LOCALE_SET","UIMode","PaymentMethod","WalletOption","SdkEvent","isValidPaymentMethod","value","Object","values","includes","isValidWalletOption","validateUIMode","mode","warn","join","CheckoutImpl","options","emitter","mounted","destroyed","iframe","threeDSModal","threeDSIframe","messageHandler","onMessage","bind","window","addEventListener","buildSrc","baseUrl","hostedCheckoutUrl","url","URL","id","locale","normalizedLocale","searchParams","selected","ui_mode","EMBEDDED","payment_methods","length","methods","validated","method","push","CARD","validatePaymentMethods","append","wallet_options","option","validateWalletOptions","wallet","appearance","preset","undefined","form_only","String","toString","getContainer","container","containerId","document","querySelector","Error","evt","origin","data","checkoutId","type","Loaded","Success","Expired","show3DSModal","ThreeDSStarted","handle3DSReady","postToIframe","close3DSModal","ThreeDSComplete","ThreeDSCanceled","ThreeDSError","render","createElement","src","allow","setAttribute","assign","style","width","height","border","display","appendChild","submit","message","contentWindow","checkoutOrigin","postMessage","position","top","left","alignItems","justifyContent","zIndex","background","threeDSUrl","sessionId","step","challengeUrl","acsTransactionId","threeDSVersion","liveMode","minWidth","minHeight","borderRadius","body","pending3DSData","remove","destroy","removeEventListener","isMounted","PaypercutCheckout"],"mappings":"oDAIaA,EAAb,WAAAC,GACUC,KAAAC,SAAW,IAAIC,GAmEzB,CA3DE,EAAAC,CAAGC,EAAUC,GAOX,OANKL,KAAKC,SAASK,IAAIF,IACrBJ,KAAKC,SAASM,IAAIH,EAAO,IAAII,KAE/BR,KAAKC,SAASQ,IAAIL,GAAQM,IAAIL,GAGvB,IAAML,KAAKW,IAAIP,EAAOC,EAC/B,CAaA,IAAAO,CAAKR,EAAUC,GACb,MAAMQ,EAAiB,IAAIC,KACzBT,KAAWS,GACXd,KAAKW,IAAIP,EAAOS,IAElB,OAAOb,KAAKG,GAAGC,EAAOS,EACxB,CAOA,GAAAF,CAAIP,EAAUC,GACZL,KAAKC,SAASQ,IAAIL,IAAQW,OAAOV,EACnC,CAOA,IAAAW,CAAKZ,KAAaU,GAChBd,KAAKC,SAASQ,IAAIL,IAAQa,QAAQC,IAChC,IACEA,KAAKJ,EACP,CAAE,MAAOK,GACPC,QAAQC,MAAM,sBAAsBjB,aAAkBe,EACxD,GAEJ,CAKA,KAAAG,GACEtB,KAAKC,SAASqB,OAChB,EC9BF,MA8BaC,EA9ByB,CACpCC,QAAS,QAETC,sBAAuB,2BACvBC,eAAgB,CACd,6BAuCE,SAAUC,EAAkBC,GAMhC,OAAOL,EAAOE,qBAChB,CCpEO,MA0BDI,EAAkC,IAAIrB,IA1BrB,CACrB,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,QACN,KAAM,UC5BR,IAAYsB,EAeAC,EAeAC,EAiJAC,EAxJN,SAAUC,EAAqBC,GACnC,OAAOC,OAAOC,OAAON,GAAeO,SAASH,EAC/C,CAeM,SAAUI,EAAoBJ,GAClC,OAAOC,OAAOC,OAAOL,GAAcM,SAASH,EAC9C,CA6CM,SAAUK,EAAeC,GA/EzB,IAAwBN,EAgF5B,GAAKM,EAIL,OApF4BN,EAoFVM,EAnFXL,OAAOC,OAAOP,GAAQQ,SAASH,GAoF7BM,OAGTrB,QAAQsB,KACN,yCAAyCD,sBAAyBL,OAAOC,OAAOP,GAAQa,KAAK,QAGjG,EApGA,SAAYb,GAEVA,EAAA,SAAA,UACD,CAHD,CAAYA,IAAAA,EAAM,CAAA,IAelB,SAAYC,GAEVA,EAAA,KAAA,MACD,CAHD,CAAYA,IAAAA,EAAa,CAAA,IAezB,SAAYC,GAEVA,EAAA,UAAA,YAEAA,EAAA,WAAA,YACD,CALD,CAAYA,IAAAA,EAAY,CAAA,IAiJxB,SAAYC,GACVA,EAAA,OAAA,SACAA,EAAA,QAAA,UACAA,EAAA,MAAA,QACAA,EAAA,QAAA,UACAA,EAAA,gBAAA,mBACAA,EAAA,aAAA,gBACAA,EAAA,gBAAA,mBACAA,EAAA,eAAA,iBACD,CATD,CAAYA,IAAAA,EAAQ,CAAA,ICrJpB,MAAMW,EAWJ,WAAA7C,CAAoB8C,GAAA7C,KAAA6C,QAAAA,EAVZ7C,KAAA8C,QAAU,IAAIhD,EACdE,KAAA+C,SAAU,EACV/C,KAAAgD,WAAY,EACZhD,KAAAiD,OAAmC,KAInCjD,KAAAkD,aAAsC,KACtClD,KAAAmD,cAA0C,KAIhDnD,KAAKoD,eAAiBpD,KAAKqD,UAAUC,KAAKtD,MAC1CuD,OAAOC,iBAAiB,UAAWxD,KAAKoD,eAC1C,CAKQ,QAAAK,GACN,MAAMC,EAAU/B,EAAkB3B,KAAK6C,QAAQc,mBACzCC,EAAM,IAAIC,IAAI,MAAM7D,KAAK6C,QAAQiB,KAAMJ,GAG7C,GAAI1D,KAAK6C,QAAQkB,OAAQ,CACvB,MAAMC,GFaoBD,EEbe/D,KAAK6C,QAAQkB,SFchC,SAAXA,EACXlC,EAAWvB,IAAIyD,GAAgBA,GACnC3C,QAAQsB,KAAK,+BAA+BqB,8CACrC,MAHkC,KEbrCH,EAAIK,aAAa1D,IAAI,SAAUyD,EACjC,CFWE,IAA0BD,EER5B,CACE,MAAMG,EAAW1B,EAAexC,KAAK6C,QAAQsB,SAAWrC,EAAOsC,UAC3DF,GACFN,EAAIK,aAAa1D,IAAI,UAAW2D,EAEpC,CAGA,GAAIlE,KAAK6C,QAAQwB,iBAAmBrE,KAAK6C,QAAQwB,gBAAgBC,OAAS,EAAG,EDlB3E,SAAiCC,GACrC,MAAMC,EAA6B,GAEnC,IAAK,MAAMC,KAAUF,EACfrC,EAAqBuC,GACvBD,EAAUE,KAAKD,GAEfrD,QAAQsB,KAAK,gDAAgD+B,iBAUjE,OALyB,IAArBD,EAAUF,SACZlD,QAAQsB,KAAK,gFACb8B,EAAUE,KAAK3C,EAAc4C,OAGxBH,CACT,ECC+BI,CAAuB5E,KAAK6C,QAAQwB,iBAC5CpD,QAASwD,IACxBb,EAAIK,aAAaY,OAAO,kBAAmBJ,IAE/C,CAGA,GAAIzE,KAAK6C,QAAQiC,gBAAkB9E,KAAK6C,QAAQiC,eAAeR,OAAS,EAAG,EDHzE,SAAgCzB,GACpC,MAAM2B,EAA4B,GAElC,IAAK,MAAMO,KAAUlC,EACfN,EAAoBwC,GACtBP,EAAUE,KAAKK,GAEf3D,QAAQsB,KAAK,+CAA+CqC,iBAIhE,OAAOP,CACT,ECR+BQ,CAAsBhF,KAAK6C,QAAQiC,gBAC3C7D,QAASgE,IACxBrB,EAAIK,aAAaY,OAAO,iBAAkBI,IAE9C,CAUA,OARIjF,KAAK6C,QAAQqC,YAAYC,QAC3BvB,EAAIK,aAAa1D,IAAI,SAAUP,KAAK6C,QAAQqC,WAAWC,aAG1BC,IAA3BpF,KAAK6C,QAAQwC,WACfzB,EAAIK,aAAa1D,IAAI,YAAa+E,OAAOtF,KAAK6C,QAAQwC,YAGjDzB,EAAI2B,UACb,CAKQ,YAAAC,GACN,MAAMC,EACgC,iBAA7BzF,KAAK6C,QAAQ6C,YAChBC,SAASC,cAAc5F,KAAK6C,QAAQ6C,aACpC1F,KAAK6C,QAAQ6C,YAEnB,IAAKD,EACH,MAAM,IAAII,MAAM,wBAAwB7F,KAAK6C,QAAQ6C,eAGvD,OAAOD,CACT,CAKQ,SAAApC,CAAUyC,GAEhB,GHvC4BC,EGuCPD,EAAIC,QHtCpBxE,EAAOG,eAAeY,SAASyD,GGuClC,OHxCA,IAA0BA,EG4C5B,MAAMC,EAAOF,EAAIE,KACjB,GAAKA,GAAwB,iBAATA,GAAuB,SAAUA,KAMjDA,EAAKC,YAAcD,EAAKC,aAAejG,KAAK6C,QAAQiB,IAKxD,OAAQkC,EAAKE,MACX,IAAK,kBACHlG,KAAK8C,QAAQ9B,KAAKiB,EAASkE,QAC3B,MACF,IAAK,mBACHnG,KAAK8C,QAAQ9B,KAAKiB,EAASmE,SAC3B,MACF,IAAK,iBAEHpG,KAAK8C,QAAQ9B,KAAKiB,EAAS4D,OAAQG,GAASA,EAAa3E,QAAU2E,GACnE,MACF,IAAK,mBACHhG,KAAK8C,QAAQ9B,KAAKiB,EAASoE,SAC3B,MACF,IAAK,qBACHrG,KAAKsG,aAAaN,GAClBhG,KAAK8C,QAAQ9B,KAAKiB,EAASsE,gBAC3B,MACF,IAAK,gBACHvG,KAAKwG,iBACL,MACF,IAAK,mBACHxG,KAAKyG,aAAaT,GAClBhG,KAAK0G,gBACL1G,KAAK8C,QAAQ9B,KAAKiB,EAAS0E,iBAC3B,MACF,IAAK,mBACH3G,KAAKyG,aAAaT,GAClBhG,KAAK0G,gBACL1G,KAAK8C,QAAQ9B,KAAKiB,EAAS2E,iBAC3B,MACF,IAAK,gBACH5G,KAAKyG,aAAaT,GAClBhG,KAAK0G,gBACL1G,KAAK8C,QAAQ9B,KAAKiB,EAAS4E,aAAcb,EAAK3E,OAGpD,CAKA,MAAAyF,GACE,IAAI9G,KAAK+C,QAIT,IACE,MAAM0C,EAAYzF,KAAKwF,eAGvBxF,KAAKiD,OAAS0C,SAASoB,cAAc,UACrC/G,KAAKiD,OAAOa,GAAK,4BACjB9D,KAAKiD,OAAO+D,IAAMhH,KAAKyD,WACvBzD,KAAKiD,OAAOgE,MAAQ,6BACpBjH,KAAKiD,OAAOiE,aAAa,cAAe,KAExClH,KAAKiD,OAAOiE,aAAa,sBAAuB,QAChDlH,KAAKiD,OAAOiE,aACV,UACA,2FAKF9E,OAAO+E,OAAOnH,KAAKiD,OAAOmE,MAAO,CAC/BC,MAAO,OACPC,OAAQ,OACRC,OAAQ,OACRC,QAAS,UAUX/B,EAAUgC,YAAYzH,KAAKiD,QAC3BjD,KAAK+C,SAAU,CACjB,CAAE,MAAO5B,GAEP,MADAC,QAAQC,MAAM,wCAAyCF,GACjDA,CACR,CACF,CAKA,MAAAuG,GACE,GAAK1H,KAAK+C,QAIV,IACE/C,KAAKyG,aAAa,CAChBP,KAAM,mBACND,WAAYjG,KAAK6C,QAAQiB,IAE7B,CAAE,MAAO3C,GAEP,MADAC,QAAQC,MAAM,gDAAiDF,GACzDA,CACR,CACF,CAKQ,YAAAsF,CAAakB,GACnB,IAAK3H,KAAKiD,QAAQ2E,cAEhB,YADAxG,QAAQC,MAAM,+DAIhB,MAAMwG,EAAiBlG,EAAkB3B,KAAK6C,QAAQc,mBACtD3D,KAAKiD,OAAO2E,cAAcE,YAAYH,EAASE,EACjD,CAKQ,YAAAvB,CAAaN,GAWnBhG,KAAKkD,aAAeyC,SAASoB,cAAc,OAC3C/G,KAAKkD,aAAaY,GAAK,sBACvB1B,OAAO+E,OAAOnH,KAAKkD,aAAakE,MAAO,CACrCW,SAAU,QACVC,IAAK,IACLC,KAAM,IACNZ,MAAO,OACPC,OAAQ,OACRE,QAAS,OACTU,WAAY,SACZC,eAAgB,SAChBC,OAAQ,SACRC,WAAY,uBAMdrI,KAAKmD,cAAgBwC,SAASoB,cAAc,UAC5C,MAAMc,EAAiBlG,EAAkB3B,KAAK6C,QAAQc,mBAGhD2E,EAAa,IAAIzE,IAAI,MAAM7D,KAAK6C,QAAQiB,aAAc+D,GAC5DS,EAAWrE,aAAa1D,IAAI,YAAayF,EAAKuC,WAC9CD,EAAWrE,aAAa1D,IAAI,OAAQyF,EAAKwC,MAErCxC,EAAKyC,cACPH,EAAWrE,aAAa1D,IAAI,eAAgByF,EAAKyC,cAE/CzC,EAAK0C,kBACPJ,EAAWrE,aAAa1D,IAAI,mBAAoByF,EAAK0C,kBAEnD1C,EAAK2C,gBACPL,EAAWrE,aAAa1D,IAAI,iBAAkByF,EAAK2C,gBAGrDL,EAAWrE,aAAa1D,IAAI,WAAY+E,OAAOU,EAAK4C,WAAY,IAEhE5I,KAAKmD,cAAc6D,IAAMsB,EAAW/C,WACpCvF,KAAKmD,cAAc8D,MAAQ,YAC3BjH,KAAKmD,cAAc+D,aAAa,cAAe,KAG/C9E,OAAO+E,OAAOnH,KAAKmD,cAAciE,MAAO,CACtCyB,SAAU,QACVC,UAAW,QACXvB,OAAQ,OACRwB,aAAc,MACdvB,QAAS,QACTa,WAAY,gBAIdrI,KAAKkD,aAAauE,YAAYzH,KAAKmD,eACnCwC,SAASqD,KAAKvB,YAAYzH,KAAKkD,cAG9BlD,KAAaiJ,eAAiBjD,CACjC,CAKQ,cAAAQ,GAEN,IADcxG,KAAaiJ,iBACbjJ,KAAKmD,eAAeyE,cAEhC,YADAxG,QAAQC,MAAM,+DAIhB,MAAMwG,EAAiBlG,EAAkB3B,KAAK6C,QAAQc,mBACtD3D,KAAKmD,cAAcyE,cAAcE,YAC/B,CACE5B,KAAM,eACND,WAAYjG,KAAK6C,QAAQiB,IAE3B+D,EAEJ,CAKQ,aAAAnB,GACF1G,KAAKkD,eACPlD,KAAKkD,aAAagG,SAClBlJ,KAAKkD,aAAe,MAGtBlD,KAAKmD,cAAgB,YACbnD,KAAaiJ,cACvB,CAKA,OAAAE,GAEE,IAAInJ,KAAKgD,UAAT,CAKA,GAAIhD,KAAKiD,OACP,IACEjD,KAAKiD,OAAOiG,SACZlJ,KAAKiD,OAAS,IAChB,CAAE,MAAO9B,GACPC,QAAQC,MAAM,6CAA8CF,EAC9D,CAIFnB,KAAK0G,gBAGL1G,KAAK+C,SAAU,EACf/C,KAAKgD,WAAY,EAGjBO,OAAO6F,oBAAoB,UAAWpJ,KAAKoD,gBAC3CpD,KAAK8C,QAAQxB,OArBb,CAsBF,CAKA,EAAAnB,CAAGC,EAAkBC,GACnB,OAAOL,KAAK8C,QAAQ3C,GAAGC,EAAOC,EAChC,CAKA,IAAAO,CAAKR,EAAkBC,GACrB,OAAOL,KAAK8C,QAAQlC,KAAKR,EAAOC,EAClC,CAKA,GAAAM,CAAIP,EAAkBC,GACpBL,KAAK8C,QAAQnC,IAAIP,EAAOC,EAC1B,CAKA,SAAAgJ,GACE,OAAOrJ,KAAK+C,OACd,EAOF,MAAMuG,EAA6C,SAEjDzG,GAGA,OAAO,IAAID,EAAaC,EAC1B,SAGCyG,EAA0B9H,QAAUD,EAAOC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@paypercut/checkout-js",
3
- "version": "1.0.6",
3
+ "version": "1.0.8",
4
4
  "description": "Lightweight JavaScript SDK for Paypercut Checkout",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",