@getmicdrop/venue-calendar 4.0.69 → 4.0.70

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/dist/{CarouselView.legacy-H5I8FG8q.js → CarouselView.legacy-CAtJAiSb.js} +3 -3
  2. package/dist/{CarouselView.legacy-H5I8FG8q.js.map → CarouselView.legacy-CAtJAiSb.js.map} +1 -1
  3. package/dist/{CartView-Bp50FEe3.js → CartView-CpA__vH7.js} +53 -53
  4. package/dist/{CartView-Bp50FEe3.js.map → CartView-CpA__vH7.js.map} +1 -1
  5. package/dist/{Checkout-C_7r24PK.js → Checkout-Bm3yGYYr.js} +278 -273
  6. package/dist/Checkout-Bm3yGYYr.js.map +1 -0
  7. package/dist/{Checkout-CbltFN5w.js → Checkout-CRBwRTOc.js} +114 -114
  8. package/dist/{Checkout-CbltFN5w.js.map → Checkout-CRBwRTOc.js.map} +1 -1
  9. package/dist/{Checkout.legacy-C8IT4aEk.js → Checkout.legacy-CpgxTxZl.js} +5 -5
  10. package/dist/{Checkout.legacy-C8IT4aEk.js.map → Checkout.legacy-CpgxTxZl.js.map} +1 -1
  11. package/dist/{CheckoutTimer-BDGvUG7s.js → CheckoutTimer-SMZRnL_T.js} +2 -2
  12. package/dist/{CheckoutTimer-BDGvUG7s.js.map → CheckoutTimer-SMZRnL_T.js.map} +1 -1
  13. package/dist/{CollectionView-BjcFcBDn.js → CollectionView-DgVzimMX.js} +5 -5
  14. package/dist/{CollectionView-BjcFcBDn.js.map → CollectionView-DgVzimMX.js.map} +1 -1
  15. package/dist/{CollectionView.legacy-DXRPPTGM.js → CollectionView.legacy-BTAS-mTd.js} +31 -31
  16. package/dist/{CollectionView.legacy-DXRPPTGM.js.map → CollectionView.legacy-BTAS-mTd.js.map} +1 -1
  17. package/dist/{Event-DNTpd-NG.js → Event-BNVO_E6j.js} +145 -145
  18. package/dist/{Event-DNTpd-NG.js.map → Event-BNVO_E6j.js.map} +1 -1
  19. package/dist/{EventDetailsView-DokL1zEd.js → EventDetailsView-CXvl9xwe.js} +6 -6
  20. package/dist/{EventDetailsView-DokL1zEd.js.map → EventDetailsView-CXvl9xwe.js.map} +1 -1
  21. package/dist/{EventPage-DfER-ohd.js → EventPage-Dc4CtBeS.js} +5 -5
  22. package/dist/{EventPage-DfER-ohd.js.map → EventPage-Dc4CtBeS.js.map} +1 -1
  23. package/dist/{EventPage.legacy-DKCXDcqQ.js → EventPage.legacy-D-9svuzb.js} +49 -49
  24. package/dist/{EventPage.legacy-DKCXDcqQ.js.map → EventPage.legacy-D-9svuzb.js.map} +1 -1
  25. package/dist/{FeaturedView.legacy-DkEiwirz.js → FeaturedView.legacy-BKF3u2sH.js} +19 -19
  26. package/dist/{FeaturedView.legacy-DkEiwirz.js.map → FeaturedView.legacy-BKF3u2sH.js.map} +1 -1
  27. package/dist/{GalleryCard-DBSyzYbv.js → GalleryCard-lNx3CEtB.js} +9 -9
  28. package/dist/{GalleryCard-DBSyzYbv.js.map → GalleryCard-lNx3CEtB.js.map} +1 -1
  29. package/dist/{GalleryView.legacy-CcqQNcMK.js → GalleryView.legacy-CMjIfp2b.js} +3 -3
  30. package/dist/{GalleryView.legacy-CcqQNcMK.js.map → GalleryView.legacy-CMjIfp2b.js.map} +1 -1
  31. package/dist/{GroupedListView.legacy-Bueg0Oxp.js → GroupedListView.legacy-BybmHzIV.js} +23 -23
  32. package/dist/{GroupedListView.legacy-Bueg0Oxp.js.map → GroupedListView.legacy-BybmHzIV.js.map} +1 -1
  33. package/dist/{OrderSummary-D_G9VNpM.js → OrderSummary-B1GhsUnc.js} +7 -7
  34. package/dist/{OrderSummary-D_G9VNpM.js.map → OrderSummary-B1GhsUnc.js.map} +1 -1
  35. package/dist/{PromoCodeInput-w7EGNs3a.js → PromoCodeInput-CrXBD0oq.js} +30 -30
  36. package/dist/{PromoCodeInput-w7EGNs3a.js.map → PromoCodeInput-CrXBD0oq.js.map} +1 -1
  37. package/dist/{SeriesPage-bCW_8Ewp.js → SeriesPage-DEDSbKuu.js} +5 -5
  38. package/dist/{SeriesPage-bCW_8Ewp.js.map → SeriesPage-DEDSbKuu.js.map} +1 -1
  39. package/dist/{SeriesPage.legacy-DZmmNEWc.js → SeriesPage.legacy-BlqTBr4n.js} +38 -38
  40. package/dist/{SeriesPage.legacy-DZmmNEWc.js.map → SeriesPage.legacy-BlqTBr4n.js.map} +1 -1
  41. package/dist/{Success-CKSUEqXp.js → Success-CD4K7aRv.js} +24 -24
  42. package/dist/{Success-CKSUEqXp.js.map → Success-CD4K7aRv.js.map} +1 -1
  43. package/dist/{Success.legacy-BnjWS130.js → Success.legacy-B1Jvy8N0.js} +2 -2
  44. package/dist/{Success.legacy-BnjWS130.js.map → Success.legacy-B1Jvy8N0.js.map} +1 -1
  45. package/dist/{VenueCalendar-n-T-MmLU.js → VenueCalendar-BoSdP7xI.js} +1472 -1457
  46. package/dist/{VenueCalendar-n-T-MmLU.js.map → VenueCalendar-BoSdP7xI.js.map} +1 -1
  47. package/dist/{ViewTicketsEmbed-CV6ipR3B.js → ViewTicketsEmbed-D1nD9zJY.js} +42 -42
  48. package/dist/{ViewTicketsEmbed-CV6ipR3B.js.map → ViewTicketsEmbed-D1nD9zJY.js.map} +1 -1
  49. package/dist/{WaitlistModal-BDzMplxL.js → WaitlistModal-DWcbQmfW.js} +35 -35
  50. package/dist/{WaitlistModal-BDzMplxL.js.map → WaitlistModal-DWcbQmfW.js.map} +1 -1
  51. package/dist/api/api.cjs +1 -1
  52. package/dist/api/api.cjs.map +1 -1
  53. package/dist/api/api.mjs +160 -157
  54. package/dist/api/api.mjs.map +1 -1
  55. package/dist/{api-Bj-wXy71.js → api-CCKXC9Qs.js} +2 -2
  56. package/dist/{api-Bj-wXy71.js.map → api-CCKXC9Qs.js.map} +1 -1
  57. package/dist/{data-toggle-store.svelte-DmcpAUWu.js → data-toggle-store.svelte-CB6WLZEE.js} +2 -2
  58. package/dist/{data-toggle-store.svelte-DmcpAUWu.js.map → data-toggle-store.svelte-CB6WLZEE.js.map} +1 -1
  59. package/dist/{transform-BLT4wYBC.js → transform-BrlBxayh.js} +2 -2
  60. package/dist/{transform-BLT4wYBC.js.map → transform-BrlBxayh.js.map} +1 -1
  61. package/dist/venue-calendar.es.js +1 -1
  62. package/dist/venue-calendar.iife.js +32 -32
  63. package/dist/venue-calendar.iife.js.map +1 -1
  64. package/dist/venue-calendar.umd.js +30 -30
  65. package/dist/venue-calendar.umd.js.map +1 -1
  66. package/package.json +1 -1
  67. package/dist/Checkout-C_7r24PK.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Checkout-CbltFN5w.js","sources":["../__SKIP_ENVIRONMENT__","../node_modules/@getmicdrop/svelte-components/dist/stripe/useStripeTheme.svelte.js","../src/lib/public-calendar-flow/CheckoutForm.svelte","../src/lib/public-calendar-flow/CheckoutSidebar.svelte","../src/lib/public-calendar-flow/CheckoutMobileFooter.svelte","../src/lib/public-calendar-flow/Checkout.svelte"],"sourcesContent":["\n export const browser = typeof window !== 'undefined';\n export const dev = false;\n export const building = false;\n export const version = '';\n ","// @storage-escape: theme persisted as a bare string for cross-app compat; the JSON-coded storage canonical would break existing persisted plain-string \"theme\" values on read.\n/**\n * Stripe Theme Utility\n *\n * Provides reactive dark mode detection for Stripe Elements.\n * Automatically watches for theme changes via MutationObserver.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n *\n * const stripeTheme = useStripeTheme();\n * // stripeTheme.current is 'stripe' | 'night'\n * // Automatically updates when theme changes\n * </script>\n *\n * <Elements theme={stripeTheme.current} {stripe} clientSecret={paymentIntent}>\n * <PaymentElement />\n * </Elements>\n * ```\n */\nimport { onMount, onDestroy } from 'svelte';\n/**\n * Detects if dark mode is active.\n *\n * Checks in order:\n * 1. localStorage 'theme' value\n * 2. Container element classes (.dark, [data-theme=\"dark\"])\n * 3. System preference (prefers-color-scheme)\n */\nexport function detectDarkMode(containerSelector) {\n if (typeof window === 'undefined')\n return false;\n try {\n // Check localStorage first\n const saved = localStorage.getItem('theme');\n if (saved === 'dark')\n return true;\n if (saved === 'light')\n return false;\n // Check for data-theme on common containers\n const selector = containerSelector || '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]';\n const containers = document.querySelectorAll(selector);\n for (const container of containers) {\n if (container.getAttribute('data-theme') === 'dark')\n return true;\n }\n // Check document root\n if (document.documentElement.getAttribute('data-theme') === 'dark')\n return true;\n // Fallback to system preference\n return window.matchMedia?.('(prefers-color-scheme: dark)')?.matches ?? false;\n }\n catch {\n return false;\n }\n}\n/**\n * Maps dark mode state to Stripe theme.\n */\nexport function getStripeTheme(isDark) {\n return isDark ? 'night' : 'stripe';\n}\n/**\n * Creates a reactive Stripe theme that watches for dark mode changes.\n *\n * Returns an object with a `current` property that is reactive and\n * automatically updates when the theme changes.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n * const stripeTheme = useStripeTheme();\n * </script>\n *\n * <Elements theme={stripeTheme.current} ...>\n * ```\n */\nexport function useStripeTheme(options = {}) {\n const { containerSelector = '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]', watchChanges = true, fallback = 'stripe', } = options;\n let current = $state(fallback);\n let observer = null;\n function updateTheme() {\n current = getStripeTheme(detectDarkMode(containerSelector));\n }\n onMount(() => {\n // Initial detection\n updateTheme();\n if (watchChanges && typeof MutationObserver !== 'undefined') {\n // Watch for class changes on potential theme containers\n const containers = document.querySelectorAll(containerSelector);\n const root = document.documentElement;\n observer = new MutationObserver(() => {\n updateTheme();\n });\n // Observe document root\n observer.observe(root, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n // Observe other containers\n containers.forEach(container => {\n observer?.observe(container, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n });\n // Also listen for system preference changes\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)');\n mediaQuery.addEventListener('change', updateTheme);\n }\n });\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n observer = null;\n }\n });\n return {\n get current() {\n return current;\n },\n /** Force refresh the theme detection */\n refresh: updateTheme,\n };\n}\n/**\n * Simple synchronous dark mode detection without reactivity.\n * Use this when you only need a one-time check.\n */\nexport function getInitialStripeTheme(containerSelector) {\n return getStripeTheme(detectDarkMode(containerSelector));\n}\n","<script lang=\"ts\">\r\n import { onMount, onDestroy } from 'svelte';\r\n import { browser } from '$app/environment';\r\n import { ChevronLeft, Warning } from 'carbon-icons-svelte';\r\n import {\r\n Button,\r\n Heading,\r\n Text,\r\n Input,\r\n Checkbox,\r\n isEmailAddress,\r\n } from '@getmicdrop/svelte-components';\r\n import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\r\n import type {\r\n EventData,\r\n OrderTotals,\r\n CheckoutFormData,\r\n } from '$lib/public-calendar-flow/types';\r\n import CheckoutTimer from './CheckoutTimer.svelte';\r\n\r\n interface Props {\r\n event: EventData;\r\n orderTotals: OrderTotals;\r\n timerSeconds: number;\r\n isExpired: boolean;\r\n isRegistration: boolean;\r\n isFreeOrder: boolean;\r\n promoApplied: boolean;\r\n promoDiscount: number;\r\n onBack: () => void;\r\n onPlaceOrder: (formData: CheckoutFormData) => void;\r\n processing: boolean;\r\n /** Incremented by parent to trigger form validation + submit from external buttons (sidebar, mobile footer) */\r\n submitRequested: number;\r\n /** Stripe instance for production mode (absence = showcase mock inputs) */\r\n stripe?: any;\r\n /** Stripe client secret for PaymentElement */\r\n paymentIntent?: string;\r\n /** Bindable Stripe elements reference for the wrapper to use during payment confirmation */\r\n elements?: any;\r\n /** Payment error message from the wrapper */\r\n paymentError?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n event,\r\n orderTotals,\r\n timerSeconds,\r\n isExpired,\r\n isRegistration,\r\n isFreeOrder,\r\n promoApplied,\r\n promoDiscount,\r\n onBack,\r\n onPlaceOrder,\r\n processing,\r\n submitRequested,\r\n stripe = undefined,\r\n paymentIntent = undefined,\r\n elements = $bindable(undefined),\r\n paymentError = '',\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // Use direct Stripe.js API instead of svelte-stripe (Svelte 5 compatibility bug).\r\n const stripeTheme = browser ? useStripeTheme() : { current: \"stripe\" as const };\r\n let paymentMountDiv = $state<HTMLElement | null>(null);\r\n let paymentElement: any = null;\r\n let stripeMounted = $state(false);\r\n\r\n function mountStripePayment() {\r\n if (\r\n !browser ||\r\n !stripe ||\r\n !paymentIntent ||\r\n !paymentMountDiv ||\r\n stripeMounted\r\n )\r\n return;\r\n elements = stripe.elements({\r\n clientSecret: paymentIntent,\r\n appearance: { theme: stripeTheme.current },\r\n });\r\n paymentElement = elements.create('payment');\r\n paymentElement.mount(paymentMountDiv);\r\n stripeMounted = true;\r\n }\r\n\r\n $effect(() => {\r\n if (stripe && paymentIntent && paymentMountDiv && !stripeMounted) {\r\n mountStripePayment();\r\n }\r\n });\r\n\r\n // Re-skin Stripe Elements when the theme changes (data-theme toggle).\r\n $effect(() => {\r\n if (stripeMounted && elements && stripeTheme.current) {\r\n try {\r\n elements.update({ appearance: { theme: stripeTheme.current } });\r\n } catch (_) {\r\n // Stripe Elements is finicky about post-mount updates; ignore.\r\n }\r\n }\r\n });\r\n\r\n onDestroy(() => {\r\n if (paymentElement) {\r\n paymentElement.destroy();\r\n paymentElement = null;\r\n }\r\n stripeMounted = false;\r\n });\r\n\r\n // --- Form state ---\r\n let firstName = $state('');\r\n let lastName = $state('');\r\n let email = $state('');\r\n let keepUpdated = $state(false);\r\n let agreeTerms = $state(false);\r\n\r\n // Payment fields (mock)\r\n let cardNumber = $state('');\r\n let cardExpiry = $state('');\r\n let cardCvc = $state('');\r\n\r\n // Per-ticket attendee fields (for registration events)\r\n let attendees = $state<\r\n Array<{\r\n firstName: string;\r\n lastName: string;\r\n email: string;\r\n sameAsPurchaser: boolean;\r\n }>\r\n >([]);\r\n\r\n // Validation state\r\n let submitted = $state(false);\r\n let errors = $derived(\r\n (() => {\r\n if (!submitted) return {};\r\n const e: Record<string, string> = {};\r\n if (!firstName.trim())\r\n e.firstName = labels.firstNameRequired || 'First name is required';\r\n if (!lastName.trim())\r\n e.lastName = labels.lastNameRequired || 'Last name is required';\r\n if (!email.trim()) e.email = labels.emailRequired || 'Email is required';\r\n else if (!isEmailAddress(email))\r\n e.email = labels.emailInvalid || 'Enter a valid email address';\r\n if (!isFreeOrder && !stripe) {\r\n // Only validate mock card fields in showcase mode\r\n if (!cardNumber.trim())\r\n e.cardNumber = labels.cardNumberRequired || 'Card number is required';\r\n if (!cardExpiry.trim())\r\n e.cardExpiry = labels.expiryRequired || 'Expiry date is required';\r\n if (!cardCvc.trim())\r\n e.cardCvc = labels.cvcRequired || 'CVC is required';\r\n }\r\n if (!agreeTerms)\r\n e.agreeTerms = labels.mustAgreeTerms || 'You must agree to the terms';\r\n\r\n // Validate attendee fields for registration events\r\n if (isRegistration) {\r\n for (let i = 0; i < attendees.length; i++) {\r\n const att = attendees[i];\r\n if (!att.sameAsPurchaser) {\r\n if (!att.firstName.trim())\r\n e[`attendee_${i}_firstName`] = 'First name is required';\r\n if (!att.lastName.trim())\r\n e[`attendee_${i}_lastName`] = 'Last name is required';\r\n if (!att.email.trim())\r\n e[`attendee_${i}_email`] =\r\n labels.emailRequired || 'Email is required';\r\n else if (!isEmailAddress(att.email))\r\n e[`attendee_${i}_email`] =\r\n labels.emailInvalidShort || 'Enter a valid email';\r\n }\r\n }\r\n }\r\n\r\n return e;\r\n })()\r\n );\r\n\r\n let hasErrors = $derived(Object.keys(errors).length > 0);\r\n\r\n let isTimerUrgent = $derived(timerSeconds > 0 && timerSeconds <= 120);\r\n\r\n // Initialize attendee list based on order lines\r\n $effect(() => {\r\n if (isRegistration) {\r\n const totalTickets = orderTotals.lines.reduce(\r\n (sum, l) => sum + l.quantity,\r\n 0\r\n );\r\n if (attendees.length !== totalTickets) {\r\n attendees = Array.from({ length: totalTickets }, (_, i) => ({\r\n firstName: '',\r\n lastName: '',\r\n email: '',\r\n sameAsPurchaser: i === 0,\r\n }));\r\n }\r\n }\r\n });\r\n\r\n // Watch for external submit requests (from sidebar/mobile footer buttons)\r\n let lastSubmitRequest = $state(0);\r\n $effect(() => {\r\n if (submitRequested > lastSubmitRequest) {\r\n lastSubmitRequest = submitRequested;\r\n handleSubmit();\r\n }\r\n });\r\n\r\n function handleSameAsPurchaser(index: number, checked: boolean) {\r\n attendees = attendees.map((att, i) => {\r\n if (i !== index) return att;\r\n return {\r\n ...att,\r\n sameAsPurchaser: checked,\r\n firstName: checked ? firstName : att.firstName,\r\n lastName: checked ? lastName : att.lastName,\r\n email: checked ? email : att.email,\r\n };\r\n });\r\n }\r\n\r\n function handleSubmit() {\r\n submitted = true;\r\n if (hasErrors) return;\r\n onPlaceOrder({\r\n firstName,\r\n lastName,\r\n email,\r\n keepMeUpdated: keepUpdated,\r\n attendees: isRegistration\r\n ? attendees.map(a => ({\r\n firstName: a.sameAsPurchaser ? firstName : a.firstName,\r\n lastName: a.sameAsPurchaser ? lastName : a.lastName,\r\n email: a.sameAsPurchaser ? email : a.email,\r\n sameAsPurchaser: a.sameAsPurchaser,\r\n }))\r\n : undefined,\r\n });\r\n }\r\n</script>\r\n\r\n<div class=\"space-y-6\">\r\n <!-- Timer header bar -->\r\n <div class=\"timer-header border-default bg-surface-secondary\">\r\n <Button\r\n variant=\"icon\"\r\n size=\"icon-sm\"\r\n onclick={onBack}\r\n aria-label={labels.goBack || 'Go back'}\r\n >\r\n <ChevronLeft size={20} />\r\n </Button>\r\n <CheckoutTimer seconds={timerSeconds} isUrgent={isTimerUrgent} />\r\n </div>\r\n\r\n <!-- Personal details -->\r\n <section class=\"space-y-4\">\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">\r\n {labels.yourDetails || 'Your details'}\r\n </Heading>\r\n\r\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.firstName || 'First name'}\r\n placeholder={labels.firstName || 'First name'}\r\n required\r\n bind:value={firstName}\r\n errorText={errors.firstName ?? ''}\r\n color={errors.firstName ? 'red' : 'base'}\r\n />\r\n <Input\r\n label={labels.lastName || 'Last name'}\r\n placeholder={labels.lastName || 'Last name'}\r\n required\r\n bind:value={lastName}\r\n errorText={errors.lastName ?? ''}\r\n color={errors.lastName ? 'red' : 'base'}\r\n />\r\n </div>\r\n\r\n <Input\r\n label={labels.emailAddress || 'Email address'}\r\n type=\"email\"\r\n placeholder={labels.emailPlaceholder || 'you@example.com'}\r\n required\r\n bind:value={email}\r\n errorText={errors.email ?? ''}\r\n color={errors.email ? 'red' : 'base'}\r\n />\r\n\r\n <Checkbox bind:checked={keepUpdated}>\r\n {labels.keepMeUpdated ||\r\n 'Keep me updated about this event and similar events'}\r\n </Checkbox>\r\n </section>\r\n\r\n <!-- Per-ticket attendee details (registration events) -->\r\n {#if isRegistration && attendees.length > 0}\r\n <section class=\"space-y-5\">\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">\r\n {labels.attendeeDetails || 'Attendee details'}\r\n </Heading>\r\n\r\n {#each attendees as attendee, i}\r\n <div class=\"attendee-card border-default bg-surface-secondary\">\r\n <div class=\"flex items-center justify-between mb-3\">\r\n <Text size=\"sm\" class=\"font-semibold\">\r\n {labels.attendee || 'Attendee'}\r\n {i + 1}\r\n </Text>\r\n <Checkbox\r\n checked={attendee.sameAsPurchaser}\r\n onchange={({ checked }) => handleSameAsPurchaser(i, checked)}\r\n >\r\n {labels.sameAsPurchaser || 'Same as purchaser'}\r\n </Checkbox>\r\n </div>\r\n\r\n <div class=\"space-y-3\">\r\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-3\">\r\n <Input\r\n label={labels.firstName || 'First name'}\r\n placeholder={labels.firstName || 'First name'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.firstName}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_firstName`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser &&\r\n errors[`attendee_${i}_firstName`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n <Input\r\n label={labels.lastName || 'Last name'}\r\n placeholder={labels.lastName || 'Last name'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.lastName}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_lastName`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser &&\r\n errors[`attendee_${i}_lastName`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n </div>\r\n <Input\r\n label={labels.email || 'Email'}\r\n type=\"email\"\r\n placeholder={labels.attendeeEmailPlaceholder ||\r\n 'attendee@example.com'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.email}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_email`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser && errors[`attendee_${i}_email`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n </div>\r\n </div>\r\n {/each}\r\n </section>\r\n {/if}\r\n\r\n <!-- Payment section -->\r\n <section class=\"space-y-4\">\r\n {#if isFreeOrder}\r\n <div class=\"free-order-notice border-default bg-surface-secondary\">\r\n <Text size=\"sm\" color=\"secondary\" class=\"font-medium block\">\r\n {labels.noPaymentRequired || 'No payment required'}\r\n </Text>\r\n <Text size=\"xs\" color=\"muted\" class=\"block mt-1\">\r\n {labels.freeEventMessage ||\r\n 'This is a free event. Complete the form above to reserve your spot.'}\r\n </Text>\r\n </div>\r\n {:else if stripe && paymentIntent}\r\n <!-- Production: Real Stripe PaymentElement -->\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\r\n {#if browser}\r\n <div bind:this={paymentMountDiv}></div>\r\n {#if !stripeMounted}\r\n <p class=\"text-sm text-color-muted py-2\">\r\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\r\n </p>\r\n {/if}\r\n {:else}\r\n <p class=\"text-sm text-color-muted py-2\">\r\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\r\n </p>\r\n {/if}\r\n {#if paymentError}\r\n <p class=\"text-sm text-accent-danger mt-2\">{paymentError}</p>\r\n {/if}\r\n {:else}\r\n <!-- Showcase: Mock card inputs -->\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\r\n\r\n <Input\r\n label={labels.cardNumber || 'Card number'}\r\n placeholder={labels.cardPlaceholder || '4242 4242 4242 4242'}\r\n type=\"creditCardNumber\"\r\n required\r\n bind:value={cardNumber}\r\n errorText={errors.cardNumber ?? ''}\r\n color={errors.cardNumber ? 'red' : 'base'}\r\n />\r\n\r\n <div class=\"grid grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.expiryDate || 'Expiry date'}\r\n placeholder={labels.expiryPlaceholder || 'MM / YY'}\r\n required\r\n bind:value={cardExpiry}\r\n errorText={errors.cardExpiry ?? ''}\r\n color={errors.cardExpiry ? 'red' : 'base'}\r\n />\r\n <Input\r\n label={labels.cvc || 'CVC'}\r\n placeholder={labels.cvcPlaceholder || '123'}\r\n required\r\n maxlength={4}\r\n bind:value={cardCvc}\r\n errorText={errors.cardCvc ?? ''}\r\n color={errors.cardCvc ? 'red' : 'base'}\r\n />\r\n </div>\r\n {/if}\r\n </section>\r\n\r\n <!-- Terms -->\r\n <section class=\"space-y-2\">\r\n <Checkbox bind:checked={agreeTerms}>\r\n {labels.agreeToTerms || 'I agree to the terms and conditions'}\r\n </Checkbox>\r\n {#if errors.agreeTerms}\r\n <div class=\"flex items-center gap-1.5\">\r\n <Warning size={16} class=\"text-accent-danger shrink-0\" />\r\n <Text size=\"xs\" class=\"text-accent-danger\">{errors.agreeTerms}</Text>\r\n </div>\r\n {/if}\r\n </section>\r\n\r\n <!-- Mobile submit is handled by CheckoutMobileFooter -->\r\n</div>\r\n\r\n<style>\r\n .timer-header {\r\n display: flex;\r\n align-items: center;\r\n gap: 0.75rem;\r\n padding: 0.75rem 1rem;\r\n margin-left: -1rem;\r\n margin-right: -1rem;\r\n border-bottom-width: 1px;\r\n border-bottom-style: solid;\r\n border-radius: 0.5rem 0.5rem 0 0;\r\n }\r\n\r\n .attendee-card {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n\r\n .free-order-notice {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n</style>\r\n","<script lang=\"ts\">\r\n\timport { Calendar } from 'carbon-icons-svelte';\r\n\timport type { USD } from '@getmicdrop/svelte-components';\r\n\timport { Button, Card, Image, Text, formatCurrency } from '@getmicdrop/svelte-components';\r\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n\timport OrderSummary from './OrderSummary.svelte';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderTotals: OrderTotals;\r\n\t\tisFreeOrder: boolean;\r\n\t\tonPlaceOrder: () => void;\r\n\t\tprocessing: boolean;\r\n\t\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { event, orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\r\n</script>\r\n\r\n<!--\r\n\tCap the sidebar card to the viewport so the Place Order button never\r\n\tfalls below the fold when many ticket types + fees + taxes + gift-card\r\n\tlines stack up. Three sections, top-to-bottom:\r\n\t 1. Event info — pinned at top so the buyer always sees what they're\r\n\t paying for.\r\n\t 2. Ticket-line list — scrolls when capacity exceeds viewport.\r\n\t 3. Totals + Place Order button — pinned at bottom so summary + CTA\r\n\t are always visible.\r\n-->\r\n<Card border padding={false} class=\"flex flex-col max-h-[calc(100vh-1.5rem)] rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\r\n\t<!-- Pinned: event info -->\r\n\t<div class=\"p-5 shrink-0\">\r\n\t\t<div class=\"flex gap-3\">\r\n\t\t\t<div class=\"shrink-0 w-20 h-14 rounded-lg overflow-hidden bg-surface-tertiary\">\r\n\t\t\t\t<Image\r\n\t\t\t\t\tsrc={event.imageUrl}\r\n\t\t\t\t\talt={event.title}\r\n\t\t\t\t\tclass=\"w-full h-full\"\r\n\t\t\t\t/>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"flex-1 min-w-0\">\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight line-clamp-2\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1\">\r\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\r\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\r\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{/if}\r\n\t\t\t\t\t</Text>\r\n\t\t\t\t</div>\r\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n\t\t\t\t\t{event.venue.name}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<!-- Scrollable: ticket-line items only -->\r\n\t<div class=\"px-5 pb-3 flex-1 overflow-y-auto min-h-0 border-t border-default pt-3\">\r\n\t\t<OrderSummary {orderTotals} mode=\"lines\" {labels} />\r\n\t</div>\r\n\r\n\t<!-- Pinned: totals + Place Order button -->\r\n\t<div class=\"px-5 pt-3 pb-5 shrink-0 border-t border-default space-y-3\">\r\n\t\t<OrderSummary {orderTotals} mode=\"totals\" {labels} />\r\n\t\t<Button\r\n\t\t\tvariant=\"default\"\r\n\t\t\tsize=\"lg\"\r\n\t\t\tclass=\"w-full\"\r\n\t\t\tdisabled={processing}\r\n\t\t\tloading={processing}\r\n\t\t\tonclick={onPlaceOrder}\r\n\t\t>\r\n\t\t\t{#if processing}\r\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\r\n\t\t\t{:else if isFreeOrder}\r\n\t\t\t\t{labels.completeOrder || 'Complete order'} &middot; {labels.free || 'Free'}\r\n\t\t\t{:else}\r\n\t\t\t\t{labels.placeOrder || 'Place order'} &middot; {formatCurrency(orderTotals.total as USD)}\r\n\t\t\t{/if}\r\n\t\t</Button>\r\n\t</div>\r\n</Card>\r\n\r\n","<script lang=\"ts\">\r\n\timport { Button, Text, formatCurrency } from '@getmicdrop/svelte-components';\r\n\timport type { USD } from '@getmicdrop/svelte-components';\r\n\timport type { OrderTotals } from '$lib/public-calendar-flow/types';\r\n\r\n\tinterface Props {\r\n\t\torderTotals: OrderTotals;\r\n\t\tisFreeOrder: boolean;\r\n\t\tonPlaceOrder: () => void;\r\n\t\tprocessing: boolean;\r\n\t\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\r\n\r\n\tlet totalTicketCount = $derived(\r\n\t\torderTotals.lines.reduce((sum, l) => sum + l.quantity, 0)\r\n\t);\r\n</script>\r\n\r\n<div\r\n\tclass=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-surface-primary border-t border-default shadow-lg\"\r\n\tstyle=\"padding-bottom: env(safe-area-inset-bottom, 0);\"\r\n>\r\n\t<div class=\"flex items-center justify-between gap-3 px-4 py-3\">\r\n\t\t<!-- Left: total info -->\r\n\t\t<div class=\"flex-1 min-w-0\">\r\n\t\t\t<Text size=\"sm\" class=\"font-semibold tabular-nums block\">\r\n\t\t\t\t{#if isFreeOrder}\r\n\t\t\t\t\t{totalTicketCount} {totalTicketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} &middot; Free\r\n\t\t\t\t{:else}\r\n\t\t\t\t\t{formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}\r\n\t\t\t\t{/if}\r\n\t\t\t</Text>\r\n\t\t</div>\r\n\r\n\t\t<!-- Right: Place order button -->\r\n\t\t<Button\r\n\t\t\tvariant=\"default\"\r\n\t\t\tsize=\"lg\"\r\n\t\t\tdisabled={processing}\r\n\t\t\tloading={processing}\r\n\t\t\tonclick={onPlaceOrder}\r\n\t\t\tclass=\"shrink-0 min-w-36\"\r\n\t\t>\r\n\t\t\t{#if processing}\r\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\r\n\t\t\t{:else if isFreeOrder}\r\n\t\t\t\t{labels.completeOrder || 'Complete order'}\r\n\t\t\t{:else}\r\n\t\t\t\t{labels.placeOrder || 'Place order'}\r\n\t\t\t{/if}\r\n\t\t</Button>\r\n\t</div>\r\n</div>\r\n\r\n","<!--\r\n @form-handling-escape: `processing` is a Stripe payment-confirmation\r\n reentrancy guard (`if (processing) return; processing = true` around\r\n confirmPayment), NOT form-submission/validation state. createFormStore\r\n cannot express a payment-intent confirmation flow, and forcing it here\r\n would risk double-charge regressions for zero user-visible benefit.\r\n Same call as PP#193. Per Atlas behavior-form-handling convergence record.\r\n-->\r\n<script module>\r\n import {\r\n type USD,\r\n createLogger,\r\n formatCurrency,\r\n } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('CheckoutMain');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { Warning, Time, Calendar } from 'carbon-icons-svelte';\r\n import {\r\n AppError,\r\n Button,\r\n Heading,\r\n Image,\r\n Modal,\r\n Text,\r\n asTicketId,\r\n roundCurrency,\r\n getCookie,\r\n COOKIE_NAMES,\r\n } from '@getmicdrop/svelte-components';\r\n import { toast } from '@getmicdrop/svelte-components/toast';\r\n import { getSessionStatus } from '$lib/api';\r\n import { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n import type {\r\n EventData,\r\n OrderTotals,\r\n OrderLine,\r\n CheckoutConfig,\r\n CheckoutFormData,\r\n } from '$lib/public-calendar-flow/types';\r\n import {\r\n mockEvent,\r\n mockFreeEvent,\r\n mockDonationEvent,\r\n mockRegistrationEvent,\r\n } from '$lib/public-calendar-flow/mock-data';\r\n import { calculateTax } from '$lib/public-calendar-flow/defaults';\r\n import { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\r\n\r\n import CheckoutForm from './CheckoutForm.svelte';\r\n import CheckoutSidebar from './CheckoutSidebar.svelte';\r\n import CheckoutMobileFooter from './CheckoutMobileFooter.svelte';\r\n import OrderSummary from './OrderSummary.svelte';\r\n import { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\r\n\r\n // mergedLabels initialized after props destructuring below\r\n\r\n // --- DataToggle types ---\r\n type CheckoutVariant =\r\n | 'default'\r\n | 'free'\r\n | 'donation'\r\n | 'registration'\r\n | 'timer_warning'\r\n | 'expired'\r\n | 'promo';\r\n\r\n const checkoutStateOptions: ToggleOption[] = [\r\n { value: 'default', label: 'Standard', color: 'bg-accent-success' },\r\n { value: 'free', label: 'Free', color: 'bg-sky-500' },\r\n { value: 'donation', label: 'Donation', color: 'bg-accent-danger' },\r\n { value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\r\n {\r\n value: 'timer_warning',\r\n label: 'Timer warning',\r\n color: 'bg-status-warning-bg0',\r\n },\r\n { value: 'expired', label: 'Expired', color: 'bg-accent-danger' },\r\n { value: 'promo', label: 'Promo discount', color: 'bg-accent-success' },\r\n ];\r\n\r\n let dataVariant = $derived(dataToggleStore.current as CheckoutVariant);\r\n\r\n // --- Props (dual-mode: showcase vs production) ---\r\n interface Props {\r\n /** Pre-built checkout config for production mode. Absence = showcase. */\r\n config?: CheckoutConfig;\r\n /** Production order submission handler. Receives form data for the wrapper to submit. */\r\n onPlaceOrder?: (formData: CheckoutFormData) => Promise<void>;\r\n /** Production back navigation handler. */\r\n onBack?: () => void;\r\n /** Production retry handler for expired sessions. */\r\n onRetryExpired?: () => void;\r\n /** Production session extension handler. Returns extension result with newExpiryTime and remainingExtensions. */\r\n onExtendSession?: () => Promise<{\r\n newExpiryTime?: string;\r\n remainingExtensions?: number;\r\n } | null | void>;\r\n /** Stripe instance passed through to CheckoutForm */\r\n stripe?: any;\r\n /** Stripe client secret passed through to CheckoutForm */\r\n paymentIntent?: string;\r\n /** Bindable Stripe elements for wrapper to access */\r\n elements?: any;\r\n /** Payment error message to display */\r\n paymentError?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n config: configProp = undefined,\r\n onPlaceOrder: onPlaceOrderProp = undefined,\r\n onBack: onBackProp = undefined,\r\n onRetryExpired: onRetryExpiredProp = undefined,\r\n onExtendSession: onExtendSessionProp = undefined,\r\n stripe = undefined,\r\n paymentIntent = undefined,\r\n elements = $bindable(undefined),\r\n paymentError = '',\r\n labels = {},\r\n }: Props = $props();\r\n\r\n const mergedLabels = $derived(mergeLabels(labels));\r\n let isShowcaseMode = $derived(!configProp);\r\n\r\n $effect(() => {\r\n if (!isShowcaseMode) return;\r\n dataToggleStore.options = checkoutStateOptions;\r\n dataToggleStore.current = 'default';\r\n dataToggleStore.isActive = true;\r\n return () => {\r\n dataToggleStore.isActive = false;\r\n dataToggleStore.options = [];\r\n };\r\n });\r\n\r\n // --- Mock order configurations per variant ---\r\n function buildConfig(variant: CheckoutVariant): CheckoutConfig {\r\n switch (variant) {\r\n case 'free':\r\n return {\r\n event: mockFreeEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(201),\r\n ticketName: 'Free Entry',\r\n quantity: 2,\r\n unitPrice: 0,\r\n fee: 0,\r\n subtotal: 0,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'donation':\r\n return {\r\n event: mockDonationEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(401),\r\n ticketName: 'Donation',\r\n quantity: 1,\r\n unitPrice: 25,\r\n fee: 0,\r\n subtotal: 25,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(402),\r\n ticketName: 'Standard Admission',\r\n quantity: 1,\r\n unitPrice: 30,\r\n fee: 3,\r\n subtotal: 30,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'registration':\r\n return {\r\n event: mockRegistrationEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(301),\r\n ticketName: 'Workshop Seat',\r\n quantity: 1,\r\n unitPrice: 75,\r\n fee: 7.5,\r\n subtotal: 75,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'timer_warning':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 33, // Just over 30s — warning modal triggers at 30s\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'expired':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 0,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: true,\r\n };\r\n\r\n case 'promo':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: true,\r\n promoDiscount: 10,\r\n forceExpired: false,\r\n };\r\n\r\n default:\r\n // Standard checkout\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n }\r\n }\r\n\r\n // --- State ---\r\n let config: CheckoutConfig = $derived(\r\n isShowcaseMode ? buildConfig(dataVariant) : configProp!\r\n );\r\n // Deadline-based timer model.\r\n //\r\n // We track an absolute deadline timestamp (ms since epoch) and compute\r\n // the displayed seconds from `deadlineMs - Date.now()` on each tick.\r\n // This is immune to backgrounded-tab throttling: when the browser\r\n // suspends our setInterval, the displayed value falls behind, but the\r\n // very next tick (or the visibilitychange handler) recomputes from\r\n // wall-clock time and the display jumps to truth. Previously we\r\n // decremented `timerSeconds -= 1`, which drifted arbitrarily far from\r\n // reality whenever the tab was backgrounded (Chrome throttles 1Hz\r\n // intervals to ~1/min after a few minutes, then pauses them entirely).\r\n //\r\n // `timerSeconds` remains an explicit state var (rather than `$derived`)\r\n // because legacy code paths still write to it (legacy demo modes); the\r\n // canonical writer is now the deadline-driven tick effect below.\r\n let deadlineMs = $state<number | null>(null);\r\n let timerSeconds = $state(900);\r\n let isExpired = $state(false);\r\n let processing = $state(false);\r\n let submitRequested = $state(0);\r\n\r\n // Cart expiration warning/expired modal states\r\n let showWarningModal = $state(false);\r\n let showExpiredModal = $state(false);\r\n let warningShown = $state(false);\r\n let isExtendingSession = $state(false);\r\n let remainingExtensions = $state(3);\r\n let canExtend = $state(true);\r\n\r\n const WARNING_THRESHOLD = 30; // Show warning modal at 30 seconds remaining\r\n\r\n // Formatted timer display for the modal\r\n let timerDisplay = $derived(\r\n (() => {\r\n const m = Math.floor(timerSeconds / 60);\r\n const s = timerSeconds % 60;\r\n return `${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`;\r\n })()\r\n );\r\n\r\n // Order totals — the server's payment-intent response is the source\r\n // of truth (it's what Stripe will actually charge). Fall back to a\r\n // local estimate only when the server hasn't responded yet (showcase\r\n // mode, or while the initial /payment-intent is in flight) so the\r\n // skeleton has something to render.\r\n let orderTotals: OrderTotals = $derived(\r\n (() => {\r\n const lines = config.lines;\r\n if (config.serverTotals) {\r\n return {\r\n lines,\r\n subtotal: config.serverTotals.subtotal,\r\n fees: config.serverTotals.fees,\r\n taxes: config.serverTotals.taxes,\r\n total: config.serverTotals.total,\r\n promoDiscount: config.serverTotals.promoDiscount,\r\n giftCardAmount: config.serverTotals.giftCardAmount,\r\n };\r\n }\r\n const subtotal = roundCurrency(\r\n lines.reduce((sum, l) => sum + l.subtotal, 0)\r\n );\r\n const fees = roundCurrency(\r\n lines.reduce((sum, l) => sum + l.fee * l.quantity, 0)\r\n );\r\n const promoDiscount = config.promoApplied ? config.promoDiscount : 0;\r\n const adjustedSubtotal = roundCurrency(\r\n Math.max(0, subtotal - promoDiscount)\r\n );\r\n const taxes = calculateTax(\r\n adjustedSubtotal + fees,\r\n config.event.venue.taxPercentage\r\n );\r\n return {\r\n lines,\r\n subtotal,\r\n fees,\r\n taxes,\r\n total: roundCurrency(adjustedSubtotal + fees + taxes),\r\n promoDiscount,\r\n giftCardAmount: 0,\r\n };\r\n })()\r\n );\r\n\r\n // Disable Place-order until the server has confirmed the totals.\r\n // Showing \"Place order · $55\" while the actual Stripe charge will be\r\n // $63.55 is worse than briefly disabling the button. Free orders\r\n // never call the payment-intent endpoint, so they're exempt.\r\n let totalsLocked = $derived(!!config.serverTotals);\r\n\r\n let isFreeOrder = $derived(\r\n orderTotals.total === 0 && orderTotals.subtotal === 0\r\n );\r\n let isRegistration = $derived(config.event.isRegistrationEvent);\r\n\r\n // Set timer ONCE on initial mount — not on every config change.\r\n // Config changes frequently (Stripe loads, quantities update, etc.)\r\n // and must not reset the timer.\r\n let timerInitialized = false;\r\n $effect(() => {\r\n const c = config;\r\n if (!timerInitialized) {\r\n timerInitialized = true;\r\n // Convert the incoming \"seconds from now\" into an absolute deadline.\r\n // From this point on, deadlineMs is the source of truth.\r\n deadlineMs = Date.now() + c.timerStart * 1000;\r\n timerSeconds = c.timerStart;\r\n isExpired = c.forceExpired;\r\n }\r\n // These are safe to reset on config change (UI state, not timer)\r\n processing = false;\r\n submitRequested = 0;\r\n });\r\n\r\n function getCartIdFromCookie(): string | null {\r\n if (typeof document === 'undefined') return null;\r\n return getCookie(COOKIE_NAMES.CHECKOUT_CARTID);\r\n }\r\n\r\n function recomputeFromDeadline(): number {\r\n if (deadlineMs == null) return timerSeconds;\r\n return Math.max(0, Math.floor((deadlineMs - Date.now()) / 1000));\r\n }\r\n\r\n /**\r\n * Re-sync the deadline from the orders-service. Called on tab focus —\r\n * a backgrounded tab might have missed an extension granted in another\r\n * tab, or the server may have already expired the cart while we slept.\r\n *\r\n * Silent on any error: the existing deadlineMs continues to drive the\r\n * display, which is no worse than the pre-resync state.\r\n */\r\n async function resyncDeadlineFromServer(): Promise<void> {\r\n const cartId = getCartIdFromCookie();\r\n if (!cartId) return;\r\n try {\r\n const status = await getSessionStatus(cartId);\r\n if (status.notFound) {\r\n // Server has already released the reservation. Surface the\r\n // expired modal so the user isn't staring at a phantom timer.\r\n deadlineMs = Date.now();\r\n timerSeconds = 0;\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n return;\r\n }\r\n if (status.expiresAt) {\r\n deadlineMs = new Date(status.expiresAt).getTime();\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n } catch {\r\n /* network error — keep current deadlineMs */\r\n }\r\n }\r\n\r\n // Timer countdown with warning and expired modal triggers.\r\n //\r\n // The interval ticks at 1 Hz, but its job is to *recompute* timerSeconds\r\n // from deadlineMs, not to decrement a counter. Backgrounded tabs throttle\r\n // this interval — that's fine; when the tab regains focus the\r\n // visibilitychange handler runs the recompute immediately and the display\r\n // jumps to truth.\r\n $effect(() => {\r\n if (isExpired || timerSeconds <= 0) {\r\n if (timerSeconds <= 0 && !isExpired) {\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n }\r\n return;\r\n }\r\n\r\n const tick = () => {\r\n const next = recomputeFromDeadline();\r\n timerSeconds = next;\r\n\r\n // Persist deadline to localStorage every 10 displayed seconds.\r\n // (Storing the deadline directly — not a recomputed end-time —\r\n // keeps reads consistent across tabs.)\r\n if (\r\n next % 10 === 0 &&\r\n deadlineMs != null &&\r\n typeof localStorage !== 'undefined'\r\n ) {\r\n try {\r\n const cartId = getCartIdFromCookie();\r\n if (cartId) {\r\n localStorage.setItem( // @storage-escape: checkout-deadline timer persistence (intentional raw localStorage)\r\n `checkout-expiry-${cartId}`,\r\n String(deadlineMs)\r\n );\r\n }\r\n } catch {\r\n /* ignore */\r\n }\r\n }\r\n\r\n // Show warning modal at 30 seconds remaining (only once per session).\r\n // We compare with <= because a backgrounded tab may have skipped over\r\n // the exact === WARNING_THRESHOLD boundary while throttled.\r\n if (next <= WARNING_THRESHOLD && next > 0 && !warningShown) {\r\n showWarningModal = true;\r\n warningShown = true;\r\n }\r\n\r\n if (next <= 0) {\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n clearInterval(interval);\r\n }\r\n };\r\n\r\n const interval = setInterval(tick, 1000);\r\n\r\n // Recompute immediately whenever the tab becomes visible — a\r\n // throttled/paused interval may have left the display many minutes\r\n // behind reality. Also kick a server resync to catch the case where\r\n // the reservation already expired (or was extended in another tab).\r\n const onVisible = () => {\r\n if (\r\n typeof document !== 'undefined' &&\r\n document.visibilityState === 'visible'\r\n ) {\r\n tick();\r\n void resyncDeadlineFromServer();\r\n }\r\n };\r\n if (typeof document !== 'undefined') {\r\n document.addEventListener('visibilitychange', onVisible);\r\n }\r\n if (typeof window !== 'undefined') {\r\n window.addEventListener('pageshow', onVisible);\r\n }\r\n\r\n // Initial server resync — catches the case where the user landed on\r\n // checkout with a stale cookie whose cart has already been released.\r\n void resyncDeadlineFromServer();\r\n\r\n return () => {\r\n clearInterval(interval);\r\n if (typeof document !== 'undefined') {\r\n document.removeEventListener('visibilitychange', onVisible);\r\n }\r\n if (typeof window !== 'undefined') {\r\n window.removeEventListener('pageshow', onVisible);\r\n }\r\n };\r\n });\r\n\r\n // --- Handlers ---\r\n function handleBack() {\r\n if (onBackProp) {\r\n onBackProp();\r\n } else {\r\n toast.info('Back button pressed — would navigate to ticket selection');\r\n }\r\n }\r\n\r\n /** Called from sidebar/mobile footer — signals the form to validate + submit */\r\n function requestPlaceOrder() {\r\n submitRequested += 1;\r\n }\r\n\r\n /** Called by CheckoutForm after successful validation */\r\n function handlePlaceOrder(formData: CheckoutFormData) {\r\n if (processing) return;\r\n processing = true;\r\n\r\n if (onPlaceOrderProp) {\r\n // Production mode: delegate to wrapper with form data\r\n onPlaceOrderProp(formData)\r\n .catch(() => {\r\n // Error handling is done by the wrapper; just reset processing\r\n })\r\n .finally(() => {\r\n processing = false;\r\n });\r\n return;\r\n }\r\n\r\n // Showcase mode: existing mock delay\r\n setTimeout(() => {\r\n processing = false;\r\n const count = orderTotals.lines.reduce((s, l) => s + l.quantity, 0);\r\n toast.success(\r\n `Order placed! ${count} ticket(s) for ${formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}`\r\n );\r\n }, 1500);\r\n }\r\n\r\n function handleRetryExpired() {\r\n showExpiredModal = false;\r\n if (onRetryExpiredProp) {\r\n onRetryExpiredProp();\r\n } else {\r\n toast.info('Would navigate back to ticket selection to start over');\r\n }\r\n }\r\n\r\n /** Extend the checkout session via the parent wrapper's onExtendSession callback */\r\n async function handleExtendSession() {\r\n if (!canExtend || isExtendingSession) return;\r\n isExtendingSession = true;\r\n\r\n try {\r\n if (onExtendSessionProp) {\r\n const result = await onExtendSessionProp();\r\n // The parent wrapper (Checkout.svelte) returns `null` when the\r\n // extend-session API call fails — e.g. when the reservation\r\n // has already expired server-side past its grace window, or\r\n // the user has used all 3 extensions. Treat null/undefined as\r\n // an unambiguous failure: don't reset the timer to +15min\r\n // locally (that would falsely show the user they still have a\r\n // valid cart when the server has already released the tickets).\r\n if (result == null) {\r\n throw new AppError('Extension request returned no result', 'lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutMain/handleExtendSession');\r\n }\r\n if (typeof result === 'object') {\r\n if (result.newExpiryTime) {\r\n // Server gave us an absolute new expiry — use it directly.\r\n deadlineMs = new Date(result.newExpiryTime).getTime();\r\n } else {\r\n // Fallback: add 15 minutes from now\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n }\r\n timerSeconds = recomputeFromDeadline();\r\n if (result.remainingExtensions !== undefined) {\r\n remainingExtensions = result.remainingExtensions;\r\n canExtend = remainingExtensions > 0;\r\n }\r\n } else {\r\n // Truthy non-object: legacy callers that just return `true`\r\n // on success. Treat as a simple 15-minute extension.\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n } else {\r\n // Showcase mode: just add 15 minutes\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n\r\n isExpired = false;\r\n warningShown = false;\r\n showWarningModal = false;\r\n showExpiredModal = false;\r\n } catch (err) {\r\n logger.error('Failed to extend session:', err);\r\n // Extension failed — close the warning but keep the expired\r\n // modal open so the user is offered \"Select tickets again\".\r\n // Disable further extend attempts on this dead cart.\r\n showWarningModal = false;\r\n canExtend = false;\r\n if (timerSeconds <= 0) {\r\n isExpired = true;\r\n showExpiredModal = true;\r\n }\r\n } finally {\r\n isExtendingSession = false;\r\n }\r\n }\r\n\r\n /** Dismiss warning modal without extending (user will hurry) */\r\n function dismissWarning() {\r\n showWarningModal = false;\r\n }\r\n\r\n</script>\r\n\r\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\r\n <div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\r\n <!-- Single CheckoutForm shared between desktop and mobile layouts.\r\n\t\t Previously there were two instances (one hidden md:grid, one md:hidden)\r\n\t\t which caused duplicate Stripe elements and broken form submission. -->\r\n <div class=\"max-w-6xl\">\r\n <!-- Desktop: two-column grid; Mobile: single column -->\r\n <div class=\"md:grid md:grid-cols-booking-split gap-8 items-start\">\r\n <!-- LEFT COLUMN (or full width on mobile): Checkout form -->\r\n <div class=\"pb-24 md:pb-0\">\r\n <CheckoutForm\r\n event={config.event}\r\n {orderTotals}\r\n {timerSeconds}\r\n {isExpired}\r\n {isRegistration}\r\n {isFreeOrder}\r\n promoApplied={config.promoApplied}\r\n promoDiscount={config.promoDiscount}\r\n onBack={handleBack}\r\n onPlaceOrder={handlePlaceOrder}\r\n {processing}\r\n {submitRequested}\r\n {stripe}\r\n {paymentIntent}\r\n bind:elements\r\n {paymentError}\r\n labels={mergedLabels}\r\n />\r\n\r\n <!-- Inline order summary for mobile (below form). Lead with the\r\n event header (poster + title + date + venue) so the buyer\r\n has visual confirmation of what they're paying for as they\r\n approach the sticky Place order button. Mirrors the desktop\r\n CheckoutSidebar layout. -->\r\n <section\r\n class=\"md:hidden mobile-order-summary border-default bg-surface-secondary mt-6\"\r\n >\r\n <div class=\"flex gap-3 pb-3 mb-3 border-b border-default\">\r\n <div class=\"shrink-0 w-20 h-14 rounded-lg overflow-hidden bg-surface-tertiary\">\r\n <Image\r\n src={config.event.imageUrl}\r\n alt={config.event.title}\r\n class=\"w-full h-full\"\r\n />\r\n </div>\r\n <div class=\"flex-1 min-w-0\">\r\n <Text size=\"sm\" class=\"font-semibold block leading-tight line-clamp-2\">\r\n {config.event.title}\r\n </Text>\r\n <div class=\"flex items-center gap-1.5 mt-1\">\r\n <Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n <Text size=\"xs\" color=\"muted\">\r\n {formatBrowseDate(config.event.startDateTime, config.event.timezone)}\r\n {#if config.event.displayStartTime !== false}\r\n &middot; {formatEventTime(config.event.startDateTime, config.event.timezone)}\r\n {/if}\r\n </Text>\r\n </div>\r\n <Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n {config.event.venue.name}\r\n </Text>\r\n </div>\r\n </div>\r\n <OrderSummary {orderTotals} labels={mergedLabels} />\r\n </section>\r\n </div>\r\n\r\n <!-- RIGHT COLUMN: Sticky order summary sidebar (desktop only) -->\r\n <div class=\"hidden md:block sticky top-6\">\r\n <CheckoutSidebar\r\n event={config.event}\r\n {orderTotals}\r\n {isFreeOrder}\r\n onPlaceOrder={requestPlaceOrder}\r\n processing={processing || (!isFreeOrder && !totalsLocked)}\r\n labels={mergedLabels}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Mobile: Fixed bottom bar -->\r\n <div class=\"md:hidden\">\r\n <CheckoutMobileFooter\r\n {orderTotals}\r\n {isFreeOrder}\r\n onPlaceOrder={requestPlaceOrder}\r\n processing={processing || (!isFreeOrder && !totalsLocked)}\r\n labels={mergedLabels}\r\n />\r\n </div>\r\n </div>\r\n\r\n <!-- Session Warning Modal (30 seconds remaining).\r\n Wrapped in `{#if}` (instead of relying on `bind:open` alone) so\r\n the Modal fully mounts/unmounts each time showWarningModal\r\n transitions. Surfaced by a wall-clock test where, after the\r\n user clicked \"Continue checkout\" on a first warning, the Modal\r\n component's internal open-state never reset cleanly — on the\r\n NEXT 30s threshold the timer text in DOM updated but the modal\r\n stayed visually hidden, so the user lost the cart with no\r\n chance to re-extend. Forcing remount with #if sidesteps that. -->\r\n {#if showWarningModal}\r\n <Modal\r\n open={true}\r\n oncancel={() => (showWarningModal = false)}\r\n size=\"sm\"\r\n aria-labelledby=\"warning-modal-title\"\r\n >\r\n {#snippet body()}\r\n <div class=\"timer-modal\" id=\"warning-modal-description\">\r\n <div class=\"timer-modal-icon warning\">\r\n <Warning size={32} />\r\n </div>\r\n <h3 id=\"warning-modal-title\" class=\"timer-modal-title\">\r\n {mergedLabels.sessionExpiringSoon || 'Session expiring soon'}\r\n </h3>\r\n <p class=\"timer-modal-text\">\r\n {(\r\n mergedLabels.sessionExpiringSoonMessage ||\r\n 'Your checkout session will expire in {time}. Your selected tickets will be released back to inventory.'\r\n ).replace('{time}', timerDisplay)}\r\n </p>\r\n {#if canExtend && remainingExtensions > 0}\r\n <p class=\"timer-modal-hint\">\r\n {(\r\n mergedLabels.extensionsRemaining ||\r\n '{count} extension{plural} remaining'\r\n )\r\n .replace('{count}', String(remainingExtensions))\r\n .replace('{plural}', remainingExtensions === 1 ? '' : 's')}\r\n </p>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n {#snippet footer()}\r\n <div class=\"timer-modal-actions\">\r\n {#if canExtend}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleExtendSession}\r\n disabled={isExtendingSession}\r\n loading={isExtendingSession}\r\n >\r\n {isExtendingSession\r\n ? mergedLabels.extendingSession || 'Extending...'\r\n : mergedLabels.continueCheckout || 'Continue checkout'}\r\n </Button>\r\n {:else}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={dismissWarning}\r\n >\r\n {mergedLabels.okIllHurry || \"OK, I'll hurry\"}\r\n </Button>\r\n <p class=\"timer-modal-hint\">\r\n {mergedLabels.maxExtensionsReached ||\r\n 'Maximum extensions reached'}\r\n </p>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n </Modal>\r\n {/if}\r\n\r\n <!-- Session Expired Modal (\"Want to keep your tickets?\").\r\n Same `{#if}` wrap as the warning modal — forces a fresh\r\n Modal mount each time so reopening after a previous extend\r\n cycle actually re-displays the dialog. -->\r\n {#if showExpiredModal}\r\n <Modal\r\n open={true}\r\n oncancel={() => (showExpiredModal = false)}\r\n size=\"sm\"\r\n aria-labelledby=\"expired-modal-title\"\r\n >\r\n {#snippet body()}\r\n <div class=\"timer-modal\" id=\"expired-modal-description\">\r\n <div class=\"timer-modal-icon expired\">\r\n <Time size={32} />\r\n </div>\r\n <h3 id=\"expired-modal-title\" class=\"timer-modal-title\">\r\n {canExtend\r\n ? mergedLabels.wantToKeepTickets || 'Want to keep your tickets?'\r\n : mergedLabels.sessionExpired || 'Session expired'}\r\n </h3>\r\n <p class=\"timer-modal-text\">\r\n {canExtend\r\n ? mergedLabels.sessionExpiredMessage ||\r\n 'Your checkout session has expired and your selected tickets have been released.'\r\n : mergedLabels.reservationTimedOut ||\r\n 'Your reservation has timed out. Please select your tickets again to continue.'}\r\n </p>\r\n </div>\r\n {/snippet}\r\n {#snippet footer()}\r\n <div class=\"timer-modal-actions\">\r\n {#if canExtend}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleExtendSession}\r\n disabled={isExtendingSession}\r\n loading={isExtendingSession}\r\n >\r\n {isExtendingSession\r\n ? mergedLabels.extendingSession || 'Extending...'\r\n : mergedLabels.keepMyTickets || 'Keep my tickets'}\r\n </Button>\r\n <Button\r\n variant=\"alternative\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleRetryExpired}\r\n >\r\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\r\n </Button>\r\n {:else}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleRetryExpired}\r\n >\r\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\r\n </Button>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n </Modal>\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n /* Mobile order summary */\r\n .mobile-order-summary {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n\r\n /* Timer modals */\r\n .timer-modal {\r\n text-align: center;\r\n padding: 0.5rem 0;\r\n }\r\n\r\n .timer-modal-icon {\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 3.5rem;\r\n height: 3.5rem;\r\n border-radius: 9999px;\r\n margin: 0 auto 1rem;\r\n }\r\n\r\n .timer-modal-icon.warning {\r\n background-color: hsl(var(--accent-warning) / 8%);\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .timer-modal-icon.expired {\r\n background-color: hsl(var(--accent-danger) / 5%);\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .timer-modal-title {\r\n font-size: 1.125rem;\r\n font-weight: 600;\r\n margin-bottom: 0.5rem;\r\n }\r\n\r\n .timer-modal-text {\r\n font-size: 0.875rem;\r\n line-height: 1.4;\r\n color: hsl(var(--text-tertiary)); /* gray-500 */\r\n }\r\n\r\n .timer-modal-hint {\r\n font-size: 0.75rem;\r\n color: hsl(var(--text-head)); /* gray-400 */\r\n margin-top: 0.5rem;\r\n }\r\n\r\n .timer-modal-actions {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.5rem;\r\n }\r\n /* The Button component's class=\"w-full\" is a Tailwind utility that\r\n isn't always emitted in the venue-calendar bundle (no scanner\r\n pass over node_modules), so force full width at the layout\r\n level. Applies to both <button> and the anchor variant. */\r\n .timer-modal-actions :global(button),\r\n .timer-modal-actions :global(a) {\r\n width: 100%;\r\n }\r\n</style>\r\n"],"names":["browser","detectDarkMode","containerSelector","saved","selector","containers","container","getStripeTheme","isDark","useStripeTheme","options","watchChanges","fallback","current","$","observer","updateTheme","onMount","root","onDestroy","stripe","paymentIntent","elements","paymentError","labels","$$props","stripeTheme","paymentMountDiv","paymentElement","stripeMounted","mountStripePayment","firstName","lastName","email","keepUpdated","agreeTerms","cardNumber","cardExpiry","cardCvc","attendees","submitted","errors","e","isEmailAddress","i","att","hasErrors","isTimerUrgent","totalTickets","sum","l","_","lastSubmitRequest","handleSubmit","handleSameAsPurchaser","index","checked","a","div","div_1","Button","node","ChevronLeft","CheckoutTimer","node_1","section","Heading","node_2","div_2","$3","Input","node_3","$$value","node_4","node_5","Checkbox","node_6","section_1","root_4","node_8","node_9","attendee","div_3","root_6","div_4","Text","node_10","node_11","div_5","div_6","node_12","node_13","node_14","$$render","consequent","section_2","node_7","div_7","root_9","node_16","node_17","node_18","div_8","fragment_9","p","root_15","consequent_2","p_1","root_16","consequent_3","alternate","p_2","root_17","consequent_4","node_22","node_23","div_9","node_24","node_25","consequent_1","consequent_5","alternate_1","section_3","node_26","div_10","root_21","Warning","node_29","text_13","consequent_6","Card","$$anchor","fragment_1","Image","Calendar","formatEventTime","formatBrowseDate","text_3","OrderSummary","$0","text_6","formatCurrency","totalTicketCount","text_1","logger","createLogger","checkoutStateOptions","dataVariant","dataToggleStore","configProp","onPlaceOrderProp","onBackProp","onRetryExpiredProp","onExtendSessionProp","mergedLabels","mergeLabels","isShowcaseMode","buildConfig","variant","mockFreeEvent","asTicketId","mockDonationEvent","mockRegistrationEvent","mockEvent","config","deadlineMs","timerSeconds","isExpired","processing","submitRequested","showWarningModal","showExpiredModal","warningShown","isExtendingSession","remainingExtensions","canExtend","WARNING_THRESHOLD","timerDisplay","m","s","orderTotals","lines","subtotal","roundCurrency","fees","promoDiscount","adjustedSubtotal","taxes","calculateTax","totalsLocked","isFreeOrder","isRegistration","timerInitialized","c","getCartIdFromCookie","getCookie","COOKIE_NAMES","recomputeFromDeadline","resyncDeadlineFromServer","cartId","status","getSessionStatus","tick","next","interval","onVisible","handleBack","toast","requestPlaceOrder","handlePlaceOrder","formData","count","handleRetryExpired","handleExtendSession","result","AppError","err","dismissWarning","CheckoutForm","CheckoutSidebar","CheckoutMobileFooter","Modal","div_11","div_12","h3","root_7","div_13","root_8","div_14","root_14","div_15","Time","h3_1","p_3","div_16","node_19"],"mappings":"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","x_google_ignoreList":[1]}
1
+ {"version":3,"file":"Checkout-CRBwRTOc.js","sources":["../__SKIP_ENVIRONMENT__","../node_modules/@getmicdrop/svelte-components/dist/stripe/useStripeTheme.svelte.js","../src/lib/public-calendar-flow/CheckoutForm.svelte","../src/lib/public-calendar-flow/CheckoutSidebar.svelte","../src/lib/public-calendar-flow/CheckoutMobileFooter.svelte","../src/lib/public-calendar-flow/Checkout.svelte"],"sourcesContent":["\n export const browser = typeof window !== 'undefined';\n export const dev = false;\n export const building = false;\n export const version = '';\n ","// @storage-escape: theme persisted as a bare string for cross-app compat; the JSON-coded storage canonical would break existing persisted plain-string \"theme\" values on read.\n/**\n * Stripe Theme Utility\n *\n * Provides reactive dark mode detection for Stripe Elements.\n * Automatically watches for theme changes via MutationObserver.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n *\n * const stripeTheme = useStripeTheme();\n * // stripeTheme.current is 'stripe' | 'night'\n * // Automatically updates when theme changes\n * </script>\n *\n * <Elements theme={stripeTheme.current} {stripe} clientSecret={paymentIntent}>\n * <PaymentElement />\n * </Elements>\n * ```\n */\nimport { onMount, onDestroy } from 'svelte';\n/**\n * Detects if dark mode is active.\n *\n * Checks in order:\n * 1. localStorage 'theme' value\n * 2. Container element classes (.dark, [data-theme=\"dark\"])\n * 3. System preference (prefers-color-scheme)\n */\nexport function detectDarkMode(containerSelector) {\n if (typeof window === 'undefined')\n return false;\n try {\n // Check localStorage first\n const saved = localStorage.getItem('theme');\n if (saved === 'dark')\n return true;\n if (saved === 'light')\n return false;\n // Check for data-theme on common containers\n const selector = containerSelector || '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]';\n const containers = document.querySelectorAll(selector);\n for (const container of containers) {\n if (container.getAttribute('data-theme') === 'dark')\n return true;\n }\n // Check document root\n if (document.documentElement.getAttribute('data-theme') === 'dark')\n return true;\n // Fallback to system preference\n return window.matchMedia?.('(prefers-color-scheme: dark)')?.matches ?? false;\n }\n catch {\n return false;\n }\n}\n/**\n * Maps dark mode state to Stripe theme.\n */\nexport function getStripeTheme(isDark) {\n return isDark ? 'night' : 'stripe';\n}\n/**\n * Creates a reactive Stripe theme that watches for dark mode changes.\n *\n * Returns an object with a `current` property that is reactive and\n * automatically updates when the theme changes.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n * const stripeTheme = useStripeTheme();\n * </script>\n *\n * <Elements theme={stripeTheme.current} ...>\n * ```\n */\nexport function useStripeTheme(options = {}) {\n const { containerSelector = '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]', watchChanges = true, fallback = 'stripe', } = options;\n let current = $state(fallback);\n let observer = null;\n function updateTheme() {\n current = getStripeTheme(detectDarkMode(containerSelector));\n }\n onMount(() => {\n // Initial detection\n updateTheme();\n if (watchChanges && typeof MutationObserver !== 'undefined') {\n // Watch for class changes on potential theme containers\n const containers = document.querySelectorAll(containerSelector);\n const root = document.documentElement;\n observer = new MutationObserver(() => {\n updateTheme();\n });\n // Observe document root\n observer.observe(root, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n // Observe other containers\n containers.forEach(container => {\n observer?.observe(container, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n });\n // Also listen for system preference changes\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)');\n mediaQuery.addEventListener('change', updateTheme);\n }\n });\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n observer = null;\n }\n });\n return {\n get current() {\n return current;\n },\n /** Force refresh the theme detection */\n refresh: updateTheme,\n };\n}\n/**\n * Simple synchronous dark mode detection without reactivity.\n * Use this when you only need a one-time check.\n */\nexport function getInitialStripeTheme(containerSelector) {\n return getStripeTheme(detectDarkMode(containerSelector));\n}\n","<script lang=\"ts\">\r\n import { onMount, onDestroy } from 'svelte';\r\n import { browser } from '$app/environment';\r\n import { ChevronLeft, Warning } from 'carbon-icons-svelte';\r\n import {\r\n Button,\r\n Heading,\r\n Text,\r\n Input,\r\n Checkbox,\r\n isEmailAddress,\r\n } from '@getmicdrop/svelte-components';\r\n import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\r\n import type {\r\n EventData,\r\n OrderTotals,\r\n CheckoutFormData,\r\n } from '$lib/public-calendar-flow/types';\r\n import CheckoutTimer from './CheckoutTimer.svelte';\r\n\r\n interface Props {\r\n event: EventData;\r\n orderTotals: OrderTotals;\r\n timerSeconds: number;\r\n isExpired: boolean;\r\n isRegistration: boolean;\r\n isFreeOrder: boolean;\r\n promoApplied: boolean;\r\n promoDiscount: number;\r\n onBack: () => void;\r\n onPlaceOrder: (formData: CheckoutFormData) => void;\r\n processing: boolean;\r\n /** Incremented by parent to trigger form validation + submit from external buttons (sidebar, mobile footer) */\r\n submitRequested: number;\r\n /** Stripe instance for production mode (absence = showcase mock inputs) */\r\n stripe?: any;\r\n /** Stripe client secret for PaymentElement */\r\n paymentIntent?: string;\r\n /** Bindable Stripe elements reference for the wrapper to use during payment confirmation */\r\n elements?: any;\r\n /** Payment error message from the wrapper */\r\n paymentError?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n event,\r\n orderTotals,\r\n timerSeconds,\r\n isExpired,\r\n isRegistration,\r\n isFreeOrder,\r\n promoApplied,\r\n promoDiscount,\r\n onBack,\r\n onPlaceOrder,\r\n processing,\r\n submitRequested,\r\n stripe = undefined,\r\n paymentIntent = undefined,\r\n elements = $bindable(undefined),\r\n paymentError = '',\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // Use direct Stripe.js API instead of svelte-stripe (Svelte 5 compatibility bug).\r\n const stripeTheme = browser ? useStripeTheme() : { current: \"stripe\" as const };\r\n let paymentMountDiv = $state<HTMLElement | null>(null);\r\n let paymentElement: any = null;\r\n let stripeMounted = $state(false);\r\n\r\n function mountStripePayment() {\r\n if (\r\n !browser ||\r\n !stripe ||\r\n !paymentIntent ||\r\n !paymentMountDiv ||\r\n stripeMounted\r\n )\r\n return;\r\n elements = stripe.elements({\r\n clientSecret: paymentIntent,\r\n appearance: { theme: stripeTheme.current },\r\n });\r\n paymentElement = elements.create('payment');\r\n paymentElement.mount(paymentMountDiv);\r\n stripeMounted = true;\r\n }\r\n\r\n $effect(() => {\r\n if (stripe && paymentIntent && paymentMountDiv && !stripeMounted) {\r\n mountStripePayment();\r\n }\r\n });\r\n\r\n // Re-skin Stripe Elements when the theme changes (data-theme toggle).\r\n $effect(() => {\r\n if (stripeMounted && elements && stripeTheme.current) {\r\n try {\r\n elements.update({ appearance: { theme: stripeTheme.current } });\r\n } catch (_) {\r\n // Stripe Elements is finicky about post-mount updates; ignore.\r\n }\r\n }\r\n });\r\n\r\n onDestroy(() => {\r\n if (paymentElement) {\r\n paymentElement.destroy();\r\n paymentElement = null;\r\n }\r\n stripeMounted = false;\r\n });\r\n\r\n // --- Form state ---\r\n let firstName = $state('');\r\n let lastName = $state('');\r\n let email = $state('');\r\n let keepUpdated = $state(false);\r\n let agreeTerms = $state(false);\r\n\r\n // Payment fields (mock)\r\n let cardNumber = $state('');\r\n let cardExpiry = $state('');\r\n let cardCvc = $state('');\r\n\r\n // Per-ticket attendee fields (for registration events)\r\n let attendees = $state<\r\n Array<{\r\n firstName: string;\r\n lastName: string;\r\n email: string;\r\n sameAsPurchaser: boolean;\r\n }>\r\n >([]);\r\n\r\n // Validation state\r\n let submitted = $state(false);\r\n let errors = $derived(\r\n (() => {\r\n if (!submitted) return {};\r\n const e: Record<string, string> = {};\r\n if (!firstName.trim())\r\n e.firstName = labels.firstNameRequired || 'First name is required';\r\n if (!lastName.trim())\r\n e.lastName = labels.lastNameRequired || 'Last name is required';\r\n if (!email.trim()) e.email = labels.emailRequired || 'Email is required';\r\n else if (!isEmailAddress(email))\r\n e.email = labels.emailInvalid || 'Enter a valid email address';\r\n if (!isFreeOrder && !stripe) {\r\n // Only validate mock card fields in showcase mode\r\n if (!cardNumber.trim())\r\n e.cardNumber = labels.cardNumberRequired || 'Card number is required';\r\n if (!cardExpiry.trim())\r\n e.cardExpiry = labels.expiryRequired || 'Expiry date is required';\r\n if (!cardCvc.trim())\r\n e.cardCvc = labels.cvcRequired || 'CVC is required';\r\n }\r\n if (!agreeTerms)\r\n e.agreeTerms = labels.mustAgreeTerms || 'You must agree to the terms';\r\n\r\n // Validate attendee fields for registration events\r\n if (isRegistration) {\r\n for (let i = 0; i < attendees.length; i++) {\r\n const att = attendees[i];\r\n if (!att.sameAsPurchaser) {\r\n if (!att.firstName.trim())\r\n e[`attendee_${i}_firstName`] = 'First name is required';\r\n if (!att.lastName.trim())\r\n e[`attendee_${i}_lastName`] = 'Last name is required';\r\n if (!att.email.trim())\r\n e[`attendee_${i}_email`] =\r\n labels.emailRequired || 'Email is required';\r\n else if (!isEmailAddress(att.email))\r\n e[`attendee_${i}_email`] =\r\n labels.emailInvalidShort || 'Enter a valid email';\r\n }\r\n }\r\n }\r\n\r\n return e;\r\n })()\r\n );\r\n\r\n let hasErrors = $derived(Object.keys(errors).length > 0);\r\n\r\n let isTimerUrgent = $derived(timerSeconds > 0 && timerSeconds <= 120);\r\n\r\n // Initialize attendee list based on order lines\r\n $effect(() => {\r\n if (isRegistration) {\r\n const totalTickets = orderTotals.lines.reduce(\r\n (sum, l) => sum + l.quantity,\r\n 0\r\n );\r\n if (attendees.length !== totalTickets) {\r\n attendees = Array.from({ length: totalTickets }, (_, i) => ({\r\n firstName: '',\r\n lastName: '',\r\n email: '',\r\n sameAsPurchaser: i === 0,\r\n }));\r\n }\r\n }\r\n });\r\n\r\n // Watch for external submit requests (from sidebar/mobile footer buttons)\r\n let lastSubmitRequest = $state(0);\r\n $effect(() => {\r\n if (submitRequested > lastSubmitRequest) {\r\n lastSubmitRequest = submitRequested;\r\n handleSubmit();\r\n }\r\n });\r\n\r\n function handleSameAsPurchaser(index: number, checked: boolean) {\r\n attendees = attendees.map((att, i) => {\r\n if (i !== index) return att;\r\n return {\r\n ...att,\r\n sameAsPurchaser: checked,\r\n firstName: checked ? firstName : att.firstName,\r\n lastName: checked ? lastName : att.lastName,\r\n email: checked ? email : att.email,\r\n };\r\n });\r\n }\r\n\r\n function handleSubmit() {\r\n submitted = true;\r\n if (hasErrors) return;\r\n onPlaceOrder({\r\n firstName,\r\n lastName,\r\n email,\r\n keepMeUpdated: keepUpdated,\r\n attendees: isRegistration\r\n ? attendees.map(a => ({\r\n firstName: a.sameAsPurchaser ? firstName : a.firstName,\r\n lastName: a.sameAsPurchaser ? lastName : a.lastName,\r\n email: a.sameAsPurchaser ? email : a.email,\r\n sameAsPurchaser: a.sameAsPurchaser,\r\n }))\r\n : undefined,\r\n });\r\n }\r\n</script>\r\n\r\n<div class=\"space-y-6\">\r\n <!-- Timer header bar -->\r\n <div class=\"timer-header border-default bg-surface-secondary\">\r\n <Button\r\n variant=\"icon\"\r\n size=\"icon-sm\"\r\n onclick={onBack}\r\n aria-label={labels.goBack || 'Go back'}\r\n >\r\n <ChevronLeft size={20} />\r\n </Button>\r\n <CheckoutTimer seconds={timerSeconds} isUrgent={isTimerUrgent} />\r\n </div>\r\n\r\n <!-- Personal details -->\r\n <section class=\"space-y-4\">\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">\r\n {labels.yourDetails || 'Your details'}\r\n </Heading>\r\n\r\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.firstName || 'First name'}\r\n placeholder={labels.firstName || 'First name'}\r\n required\r\n bind:value={firstName}\r\n errorText={errors.firstName ?? ''}\r\n color={errors.firstName ? 'red' : 'base'}\r\n />\r\n <Input\r\n label={labels.lastName || 'Last name'}\r\n placeholder={labels.lastName || 'Last name'}\r\n required\r\n bind:value={lastName}\r\n errorText={errors.lastName ?? ''}\r\n color={errors.lastName ? 'red' : 'base'}\r\n />\r\n </div>\r\n\r\n <Input\r\n label={labels.emailAddress || 'Email address'}\r\n type=\"email\"\r\n placeholder={labels.emailPlaceholder || 'you@example.com'}\r\n required\r\n bind:value={email}\r\n errorText={errors.email ?? ''}\r\n color={errors.email ? 'red' : 'base'}\r\n />\r\n\r\n <Checkbox bind:checked={keepUpdated}>\r\n {labels.keepMeUpdated ||\r\n 'Keep me updated about this event and similar events'}\r\n </Checkbox>\r\n </section>\r\n\r\n <!-- Per-ticket attendee details (registration events) -->\r\n {#if isRegistration && attendees.length > 0}\r\n <section class=\"space-y-5\">\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">\r\n {labels.attendeeDetails || 'Attendee details'}\r\n </Heading>\r\n\r\n {#each attendees as attendee, i}\r\n <div class=\"attendee-card border-default bg-surface-secondary\">\r\n <div class=\"flex items-center justify-between mb-3\">\r\n <Text size=\"sm\" class=\"font-semibold\">\r\n {labels.attendee || 'Attendee'}\r\n {i + 1}\r\n </Text>\r\n <Checkbox\r\n checked={attendee.sameAsPurchaser}\r\n onchange={({ checked }) => handleSameAsPurchaser(i, checked)}\r\n >\r\n {labels.sameAsPurchaser || 'Same as purchaser'}\r\n </Checkbox>\r\n </div>\r\n\r\n <div class=\"space-y-3\">\r\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-3\">\r\n <Input\r\n label={labels.firstName || 'First name'}\r\n placeholder={labels.firstName || 'First name'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.firstName}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_firstName`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser &&\r\n errors[`attendee_${i}_firstName`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n <Input\r\n label={labels.lastName || 'Last name'}\r\n placeholder={labels.lastName || 'Last name'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.lastName}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_lastName`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser &&\r\n errors[`attendee_${i}_lastName`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n </div>\r\n <Input\r\n label={labels.email || 'Email'}\r\n type=\"email\"\r\n placeholder={labels.attendeeEmailPlaceholder ||\r\n 'attendee@example.com'}\r\n required\r\n disabled={attendee.sameAsPurchaser}\r\n bind:value={attendee.email}\r\n errorText={!attendee.sameAsPurchaser\r\n ? (errors[`attendee_${i}_email`] ?? '')\r\n : ''}\r\n color={!attendee.sameAsPurchaser && errors[`attendee_${i}_email`]\r\n ? 'red'\r\n : 'base'}\r\n />\r\n </div>\r\n </div>\r\n {/each}\r\n </section>\r\n {/if}\r\n\r\n <!-- Payment section -->\r\n <section class=\"space-y-4\">\r\n {#if isFreeOrder}\r\n <div class=\"free-order-notice border-default bg-surface-secondary\">\r\n <Text size=\"sm\" color=\"secondary\" class=\"font-medium block\">\r\n {labels.noPaymentRequired || 'No payment required'}\r\n </Text>\r\n <Text size=\"xs\" color=\"muted\" class=\"block mt-1\">\r\n {labels.freeEventMessage ||\r\n 'This is a free event. Complete the form above to reserve your spot.'}\r\n </Text>\r\n </div>\r\n {:else if stripe && paymentIntent}\r\n <!-- Production: Real Stripe PaymentElement -->\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\r\n {#if browser}\r\n <div bind:this={paymentMountDiv}></div>\r\n {#if !stripeMounted}\r\n <p class=\"text-sm text-color-muted py-2\">\r\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\r\n </p>\r\n {/if}\r\n {:else}\r\n <p class=\"text-sm text-color-muted py-2\">\r\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\r\n </p>\r\n {/if}\r\n {#if paymentError}\r\n <p class=\"text-sm text-accent-danger mt-2\">{paymentError}</p>\r\n {/if}\r\n {:else}\r\n <!-- Showcase: Mock card inputs -->\r\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\r\n\r\n <Input\r\n label={labels.cardNumber || 'Card number'}\r\n placeholder={labels.cardPlaceholder || '4242 4242 4242 4242'}\r\n type=\"creditCardNumber\"\r\n required\r\n bind:value={cardNumber}\r\n errorText={errors.cardNumber ?? ''}\r\n color={errors.cardNumber ? 'red' : 'base'}\r\n />\r\n\r\n <div class=\"grid grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.expiryDate || 'Expiry date'}\r\n placeholder={labels.expiryPlaceholder || 'MM / YY'}\r\n required\r\n bind:value={cardExpiry}\r\n errorText={errors.cardExpiry ?? ''}\r\n color={errors.cardExpiry ? 'red' : 'base'}\r\n />\r\n <Input\r\n label={labels.cvc || 'CVC'}\r\n placeholder={labels.cvcPlaceholder || '123'}\r\n required\r\n maxlength={4}\r\n bind:value={cardCvc}\r\n errorText={errors.cardCvc ?? ''}\r\n color={errors.cardCvc ? 'red' : 'base'}\r\n />\r\n </div>\r\n {/if}\r\n </section>\r\n\r\n <!-- Terms -->\r\n <section class=\"space-y-2\">\r\n <Checkbox bind:checked={agreeTerms}>\r\n {labels.agreeToTerms || 'I agree to the terms and conditions'}\r\n </Checkbox>\r\n {#if errors.agreeTerms}\r\n <div class=\"flex items-center gap-1.5\">\r\n <Warning size={16} class=\"text-accent-danger shrink-0\" />\r\n <Text size=\"xs\" class=\"text-accent-danger\">{errors.agreeTerms}</Text>\r\n </div>\r\n {/if}\r\n </section>\r\n\r\n <!-- Mobile submit is handled by CheckoutMobileFooter -->\r\n</div>\r\n\r\n<style>\r\n .timer-header {\r\n display: flex;\r\n align-items: center;\r\n gap: 0.75rem;\r\n padding: 0.75rem 1rem;\r\n margin-left: -1rem;\r\n margin-right: -1rem;\r\n border-bottom-width: 1px;\r\n border-bottom-style: solid;\r\n border-radius: 0.5rem 0.5rem 0 0;\r\n }\r\n\r\n .attendee-card {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n\r\n .free-order-notice {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n</style>\r\n","<script lang=\"ts\">\r\n\timport { Calendar } from 'carbon-icons-svelte';\r\n\timport type { USD } from '@getmicdrop/svelte-components';\r\n\timport { Button, Card, Image, Text, formatCurrency } from '@getmicdrop/svelte-components';\r\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n\timport OrderSummary from './OrderSummary.svelte';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderTotals: OrderTotals;\r\n\t\tisFreeOrder: boolean;\r\n\t\tonPlaceOrder: () => void;\r\n\t\tprocessing: boolean;\r\n\t\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { event, orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\r\n</script>\r\n\r\n<!--\r\n\tCap the sidebar card to the viewport so the Place Order button never\r\n\tfalls below the fold when many ticket types + fees + taxes + gift-card\r\n\tlines stack up. Three sections, top-to-bottom:\r\n\t 1. Event info — pinned at top so the buyer always sees what they're\r\n\t paying for.\r\n\t 2. Ticket-line list — scrolls when capacity exceeds viewport.\r\n\t 3. Totals + Place Order button — pinned at bottom so summary + CTA\r\n\t are always visible.\r\n-->\r\n<Card border padding={false} class=\"flex flex-col max-h-[calc(100vh-1.5rem)] rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\r\n\t<!-- Pinned: event info -->\r\n\t<div class=\"p-5 shrink-0\">\r\n\t\t<div class=\"flex gap-3\">\r\n\t\t\t<div class=\"shrink-0 w-20 h-14 rounded-lg overflow-hidden bg-surface-tertiary\">\r\n\t\t\t\t<Image\r\n\t\t\t\t\tsrc={event.imageUrl}\r\n\t\t\t\t\talt={event.title}\r\n\t\t\t\t\tclass=\"w-full h-full\"\r\n\t\t\t\t/>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"flex-1 min-w-0\">\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight line-clamp-2\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1\">\r\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\r\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\r\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{/if}\r\n\t\t\t\t\t</Text>\r\n\t\t\t\t</div>\r\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n\t\t\t\t\t{event.venue.name}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<!-- Scrollable: ticket-line items only -->\r\n\t<div class=\"px-5 pb-3 flex-1 overflow-y-auto min-h-0 border-t border-default pt-3\">\r\n\t\t<OrderSummary {orderTotals} mode=\"lines\" {labels} />\r\n\t</div>\r\n\r\n\t<!-- Pinned: totals + Place Order button -->\r\n\t<div class=\"px-5 pt-3 pb-5 shrink-0 border-t border-default space-y-3\">\r\n\t\t<OrderSummary {orderTotals} mode=\"totals\" {labels} />\r\n\t\t<Button\r\n\t\t\tvariant=\"default\"\r\n\t\t\tsize=\"lg\"\r\n\t\t\tclass=\"w-full\"\r\n\t\t\tdisabled={processing}\r\n\t\t\tloading={processing}\r\n\t\t\tonclick={onPlaceOrder}\r\n\t\t>\r\n\t\t\t{#if processing}\r\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\r\n\t\t\t{:else if isFreeOrder}\r\n\t\t\t\t{labels.completeOrder || 'Complete order'} &middot; {labels.free || 'Free'}\r\n\t\t\t{:else}\r\n\t\t\t\t{labels.placeOrder || 'Place order'} &middot; {formatCurrency(orderTotals.total as USD)}\r\n\t\t\t{/if}\r\n\t\t</Button>\r\n\t</div>\r\n</Card>\r\n\r\n","<script lang=\"ts\">\r\n\timport { Button, Text, formatCurrency } from '@getmicdrop/svelte-components';\r\n\timport type { USD } from '@getmicdrop/svelte-components';\r\n\timport type { OrderTotals } from '$lib/public-calendar-flow/types';\r\n\r\n\tinterface Props {\r\n\t\torderTotals: OrderTotals;\r\n\t\tisFreeOrder: boolean;\r\n\t\tonPlaceOrder: () => void;\r\n\t\tprocessing: boolean;\r\n\t\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\r\n\r\n\tlet totalTicketCount = $derived(\r\n\t\torderTotals.lines.reduce((sum, l) => sum + l.quantity, 0)\r\n\t);\r\n</script>\r\n\r\n<div\r\n\tclass=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-surface-primary border-t border-default shadow-lg\"\r\n\tstyle=\"padding-bottom: env(safe-area-inset-bottom, 0);\"\r\n>\r\n\t<div class=\"flex items-center justify-between gap-3 px-4 py-3\">\r\n\t\t<!-- Left: total info -->\r\n\t\t<div class=\"flex-1 min-w-0\">\r\n\t\t\t<Text size=\"sm\" class=\"font-semibold tabular-nums block\">\r\n\t\t\t\t{#if isFreeOrder}\r\n\t\t\t\t\t{totalTicketCount} {totalTicketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} &middot; Free\r\n\t\t\t\t{:else}\r\n\t\t\t\t\t{formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}\r\n\t\t\t\t{/if}\r\n\t\t\t</Text>\r\n\t\t</div>\r\n\r\n\t\t<!-- Right: Place order button -->\r\n\t\t<Button\r\n\t\t\tvariant=\"default\"\r\n\t\t\tsize=\"lg\"\r\n\t\t\tdisabled={processing}\r\n\t\t\tloading={processing}\r\n\t\t\tonclick={onPlaceOrder}\r\n\t\t\tclass=\"shrink-0 min-w-36\"\r\n\t\t>\r\n\t\t\t{#if processing}\r\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\r\n\t\t\t{:else if isFreeOrder}\r\n\t\t\t\t{labels.completeOrder || 'Complete order'}\r\n\t\t\t{:else}\r\n\t\t\t\t{labels.placeOrder || 'Place order'}\r\n\t\t\t{/if}\r\n\t\t</Button>\r\n\t</div>\r\n</div>\r\n\r\n","<!--\r\n @form-handling-escape: `processing` is a Stripe payment-confirmation\r\n reentrancy guard (`if (processing) return; processing = true` around\r\n confirmPayment), NOT form-submission/validation state. createFormStore\r\n cannot express a payment-intent confirmation flow, and forcing it here\r\n would risk double-charge regressions for zero user-visible benefit.\r\n Same call as PP#193. Per Atlas behavior-form-handling convergence record.\r\n-->\r\n<script module>\r\n import {\r\n type USD,\r\n createLogger,\r\n formatCurrency,\r\n } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('CheckoutMain');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { Warning, Time, Calendar } from 'carbon-icons-svelte';\r\n import {\r\n AppError,\r\n Button,\r\n Heading,\r\n Image,\r\n Modal,\r\n Text,\r\n asTicketId,\r\n roundCurrency,\r\n getCookie,\r\n COOKIE_NAMES,\r\n } from '@getmicdrop/svelte-components';\r\n import { toast } from '@getmicdrop/svelte-components/toast';\r\n import { getSessionStatus } from '$lib/api';\r\n import { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n import type {\r\n EventData,\r\n OrderTotals,\r\n OrderLine,\r\n CheckoutConfig,\r\n CheckoutFormData,\r\n } from '$lib/public-calendar-flow/types';\r\n import {\r\n mockEvent,\r\n mockFreeEvent,\r\n mockDonationEvent,\r\n mockRegistrationEvent,\r\n } from '$lib/public-calendar-flow/mock-data';\r\n import { calculateTax } from '$lib/public-calendar-flow/defaults';\r\n import { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\r\n\r\n import CheckoutForm from './CheckoutForm.svelte';\r\n import CheckoutSidebar from './CheckoutSidebar.svelte';\r\n import CheckoutMobileFooter from './CheckoutMobileFooter.svelte';\r\n import OrderSummary from './OrderSummary.svelte';\r\n import { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\r\n\r\n // mergedLabels initialized after props destructuring below\r\n\r\n // --- DataToggle types ---\r\n type CheckoutVariant =\r\n | 'default'\r\n | 'free'\r\n | 'donation'\r\n | 'registration'\r\n | 'timer_warning'\r\n | 'expired'\r\n | 'promo';\r\n\r\n const checkoutStateOptions: ToggleOption[] = [\r\n { value: 'default', label: 'Standard', color: 'bg-accent-success' },\r\n { value: 'free', label: 'Free', color: 'bg-sky-500' },\r\n { value: 'donation', label: 'Donation', color: 'bg-accent-danger' },\r\n { value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\r\n {\r\n value: 'timer_warning',\r\n label: 'Timer warning',\r\n color: 'bg-status-warning-bg0',\r\n },\r\n { value: 'expired', label: 'Expired', color: 'bg-accent-danger' },\r\n { value: 'promo', label: 'Promo discount', color: 'bg-accent-success' },\r\n ];\r\n\r\n let dataVariant = $derived(dataToggleStore.current as CheckoutVariant);\r\n\r\n // --- Props (dual-mode: showcase vs production) ---\r\n interface Props {\r\n /** Pre-built checkout config for production mode. Absence = showcase. */\r\n config?: CheckoutConfig;\r\n /** Production order submission handler. Receives form data for the wrapper to submit. */\r\n onPlaceOrder?: (formData: CheckoutFormData) => Promise<void>;\r\n /** Production back navigation handler. */\r\n onBack?: () => void;\r\n /** Production retry handler for expired sessions. */\r\n onRetryExpired?: () => void;\r\n /** Production session extension handler. Returns extension result with newExpiryTime and remainingExtensions. */\r\n onExtendSession?: () => Promise<{\r\n newExpiryTime?: string;\r\n remainingExtensions?: number;\r\n } | null | void>;\r\n /** Stripe instance passed through to CheckoutForm */\r\n stripe?: any;\r\n /** Stripe client secret passed through to CheckoutForm */\r\n paymentIntent?: string;\r\n /** Bindable Stripe elements for wrapper to access */\r\n elements?: any;\r\n /** Payment error message to display */\r\n paymentError?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n config: configProp = undefined,\r\n onPlaceOrder: onPlaceOrderProp = undefined,\r\n onBack: onBackProp = undefined,\r\n onRetryExpired: onRetryExpiredProp = undefined,\r\n onExtendSession: onExtendSessionProp = undefined,\r\n stripe = undefined,\r\n paymentIntent = undefined,\r\n elements = $bindable(undefined),\r\n paymentError = '',\r\n labels = {},\r\n }: Props = $props();\r\n\r\n const mergedLabels = $derived(mergeLabels(labels));\r\n let isShowcaseMode = $derived(!configProp);\r\n\r\n $effect(() => {\r\n if (!isShowcaseMode) return;\r\n dataToggleStore.options = checkoutStateOptions;\r\n dataToggleStore.current = 'default';\r\n dataToggleStore.isActive = true;\r\n return () => {\r\n dataToggleStore.isActive = false;\r\n dataToggleStore.options = [];\r\n };\r\n });\r\n\r\n // --- Mock order configurations per variant ---\r\n function buildConfig(variant: CheckoutVariant): CheckoutConfig {\r\n switch (variant) {\r\n case 'free':\r\n return {\r\n event: mockFreeEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(201),\r\n ticketName: 'Free Entry',\r\n quantity: 2,\r\n unitPrice: 0,\r\n fee: 0,\r\n subtotal: 0,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'donation':\r\n return {\r\n event: mockDonationEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(401),\r\n ticketName: 'Donation',\r\n quantity: 1,\r\n unitPrice: 25,\r\n fee: 0,\r\n subtotal: 25,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(402),\r\n ticketName: 'Standard Admission',\r\n quantity: 1,\r\n unitPrice: 30,\r\n fee: 3,\r\n subtotal: 30,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'registration':\r\n return {\r\n event: mockRegistrationEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(301),\r\n ticketName: 'Workshop Seat',\r\n quantity: 1,\r\n unitPrice: 75,\r\n fee: 7.5,\r\n subtotal: 75,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'timer_warning':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 33, // Just over 30s — warning modal triggers at 30s\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n\r\n case 'expired':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 0,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: true,\r\n };\r\n\r\n case 'promo':\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: true,\r\n promoDiscount: 10,\r\n forceExpired: false,\r\n };\r\n\r\n default:\r\n // Standard checkout\r\n return {\r\n event: mockEvent,\r\n lines: [\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(101),\r\n ticketName: 'General Admission',\r\n quantity: 2,\r\n unitPrice: 25,\r\n fee: 2.5,\r\n subtotal: 50,\r\n },\r\n {\r\n // eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n ticketId: asTicketId(102),\r\n ticketName: 'VIP Front Row',\r\n quantity: 1,\r\n unitPrice: 55,\r\n fee: 5.5,\r\n subtotal: 55,\r\n },\r\n ],\r\n timerStart: 900,\r\n promoApplied: false,\r\n promoDiscount: 0,\r\n forceExpired: false,\r\n };\r\n }\r\n }\r\n\r\n // --- State ---\r\n let config: CheckoutConfig = $derived(\r\n isShowcaseMode ? buildConfig(dataVariant) : configProp!\r\n );\r\n // Deadline-based timer model.\r\n //\r\n // We track an absolute deadline timestamp (ms since epoch) and compute\r\n // the displayed seconds from `deadlineMs - Date.now()` on each tick.\r\n // This is immune to backgrounded-tab throttling: when the browser\r\n // suspends our setInterval, the displayed value falls behind, but the\r\n // very next tick (or the visibilitychange handler) recomputes from\r\n // wall-clock time and the display jumps to truth. Previously we\r\n // decremented `timerSeconds -= 1`, which drifted arbitrarily far from\r\n // reality whenever the tab was backgrounded (Chrome throttles 1Hz\r\n // intervals to ~1/min after a few minutes, then pauses them entirely).\r\n //\r\n // `timerSeconds` remains an explicit state var (rather than `$derived`)\r\n // because legacy code paths still write to it (legacy demo modes); the\r\n // canonical writer is now the deadline-driven tick effect below.\r\n let deadlineMs = $state<number | null>(null);\r\n let timerSeconds = $state(900);\r\n let isExpired = $state(false);\r\n let processing = $state(false);\r\n let submitRequested = $state(0);\r\n\r\n // Cart expiration warning/expired modal states\r\n let showWarningModal = $state(false);\r\n let showExpiredModal = $state(false);\r\n let warningShown = $state(false);\r\n let isExtendingSession = $state(false);\r\n let remainingExtensions = $state(3);\r\n let canExtend = $state(true);\r\n\r\n const WARNING_THRESHOLD = 30; // Show warning modal at 30 seconds remaining\r\n\r\n // Formatted timer display for the modal\r\n let timerDisplay = $derived(\r\n (() => {\r\n const m = Math.floor(timerSeconds / 60);\r\n const s = timerSeconds % 60;\r\n return `${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`;\r\n })()\r\n );\r\n\r\n // Order totals — the server's payment-intent response is the source\r\n // of truth (it's what Stripe will actually charge). Fall back to a\r\n // local estimate only when the server hasn't responded yet (showcase\r\n // mode, or while the initial /payment-intent is in flight) so the\r\n // skeleton has something to render.\r\n let orderTotals: OrderTotals = $derived(\r\n (() => {\r\n const lines = config.lines;\r\n if (config.serverTotals) {\r\n return {\r\n lines,\r\n subtotal: config.serverTotals.subtotal,\r\n fees: config.serverTotals.fees,\r\n taxes: config.serverTotals.taxes,\r\n total: config.serverTotals.total,\r\n promoDiscount: config.serverTotals.promoDiscount,\r\n giftCardAmount: config.serverTotals.giftCardAmount,\r\n };\r\n }\r\n const subtotal = roundCurrency(\r\n lines.reduce((sum, l) => sum + l.subtotal, 0)\r\n );\r\n const fees = roundCurrency(\r\n lines.reduce((sum, l) => sum + l.fee * l.quantity, 0)\r\n );\r\n const promoDiscount = config.promoApplied ? config.promoDiscount : 0;\r\n const adjustedSubtotal = roundCurrency(\r\n Math.max(0, subtotal - promoDiscount)\r\n );\r\n const taxes = calculateTax(\r\n adjustedSubtotal + fees,\r\n config.event.venue.taxPercentage\r\n );\r\n return {\r\n lines,\r\n subtotal,\r\n fees,\r\n taxes,\r\n total: roundCurrency(adjustedSubtotal + fees + taxes),\r\n promoDiscount,\r\n giftCardAmount: 0,\r\n };\r\n })()\r\n );\r\n\r\n // Disable Place-order until the server has confirmed the totals.\r\n // Showing \"Place order · $55\" while the actual Stripe charge will be\r\n // $63.55 is worse than briefly disabling the button. Free orders\r\n // never call the payment-intent endpoint, so they're exempt.\r\n let totalsLocked = $derived(!!config.serverTotals);\r\n\r\n let isFreeOrder = $derived(\r\n orderTotals.total === 0 && orderTotals.subtotal === 0\r\n );\r\n let isRegistration = $derived(config.event.isRegistrationEvent);\r\n\r\n // Set timer ONCE on initial mount — not on every config change.\r\n // Config changes frequently (Stripe loads, quantities update, etc.)\r\n // and must not reset the timer.\r\n let timerInitialized = false;\r\n $effect(() => {\r\n const c = config;\r\n if (!timerInitialized) {\r\n timerInitialized = true;\r\n // Convert the incoming \"seconds from now\" into an absolute deadline.\r\n // From this point on, deadlineMs is the source of truth.\r\n deadlineMs = Date.now() + c.timerStart * 1000;\r\n timerSeconds = c.timerStart;\r\n isExpired = c.forceExpired;\r\n }\r\n // These are safe to reset on config change (UI state, not timer)\r\n processing = false;\r\n submitRequested = 0;\r\n });\r\n\r\n function getCartIdFromCookie(): string | null {\r\n if (typeof document === 'undefined') return null;\r\n return getCookie(COOKIE_NAMES.CHECKOUT_CARTID);\r\n }\r\n\r\n function recomputeFromDeadline(): number {\r\n if (deadlineMs == null) return timerSeconds;\r\n return Math.max(0, Math.floor((deadlineMs - Date.now()) / 1000));\r\n }\r\n\r\n /**\r\n * Re-sync the deadline from the orders-service. Called on tab focus —\r\n * a backgrounded tab might have missed an extension granted in another\r\n * tab, or the server may have already expired the cart while we slept.\r\n *\r\n * Silent on any error: the existing deadlineMs continues to drive the\r\n * display, which is no worse than the pre-resync state.\r\n */\r\n async function resyncDeadlineFromServer(): Promise<void> {\r\n const cartId = getCartIdFromCookie();\r\n if (!cartId) return;\r\n try {\r\n const status = await getSessionStatus(cartId);\r\n if (status.notFound) {\r\n // Server has already released the reservation. Surface the\r\n // expired modal so the user isn't staring at a phantom timer.\r\n deadlineMs = Date.now();\r\n timerSeconds = 0;\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n return;\r\n }\r\n if (status.expiresAt) {\r\n deadlineMs = new Date(status.expiresAt).getTime();\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n } catch {\r\n /* network error — keep current deadlineMs */\r\n }\r\n }\r\n\r\n // Timer countdown with warning and expired modal triggers.\r\n //\r\n // The interval ticks at 1 Hz, but its job is to *recompute* timerSeconds\r\n // from deadlineMs, not to decrement a counter. Backgrounded tabs throttle\r\n // this interval — that's fine; when the tab regains focus the\r\n // visibilitychange handler runs the recompute immediately and the display\r\n // jumps to truth.\r\n $effect(() => {\r\n if (isExpired || timerSeconds <= 0) {\r\n if (timerSeconds <= 0 && !isExpired) {\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n }\r\n return;\r\n }\r\n\r\n const tick = () => {\r\n const next = recomputeFromDeadline();\r\n timerSeconds = next;\r\n\r\n // Persist deadline to localStorage every 10 displayed seconds.\r\n // (Storing the deadline directly — not a recomputed end-time —\r\n // keeps reads consistent across tabs.)\r\n if (\r\n next % 10 === 0 &&\r\n deadlineMs != null &&\r\n typeof localStorage !== 'undefined'\r\n ) {\r\n try {\r\n const cartId = getCartIdFromCookie();\r\n if (cartId) {\r\n localStorage.setItem( // @storage-escape: checkout-deadline timer persistence (intentional raw localStorage)\r\n `checkout-expiry-${cartId}`,\r\n String(deadlineMs)\r\n );\r\n }\r\n } catch {\r\n /* ignore */\r\n }\r\n }\r\n\r\n // Show warning modal at 30 seconds remaining (only once per session).\r\n // We compare with <= because a backgrounded tab may have skipped over\r\n // the exact === WARNING_THRESHOLD boundary while throttled.\r\n if (next <= WARNING_THRESHOLD && next > 0 && !warningShown) {\r\n showWarningModal = true;\r\n warningShown = true;\r\n }\r\n\r\n if (next <= 0) {\r\n isExpired = true;\r\n showWarningModal = false;\r\n showExpiredModal = true;\r\n clearInterval(interval);\r\n }\r\n };\r\n\r\n const interval = setInterval(tick, 1000);\r\n\r\n // Recompute immediately whenever the tab becomes visible — a\r\n // throttled/paused interval may have left the display many minutes\r\n // behind reality. Also kick a server resync to catch the case where\r\n // the reservation already expired (or was extended in another tab).\r\n const onVisible = () => {\r\n if (\r\n typeof document !== 'undefined' &&\r\n document.visibilityState === 'visible'\r\n ) {\r\n tick();\r\n void resyncDeadlineFromServer();\r\n }\r\n };\r\n if (typeof document !== 'undefined') {\r\n document.addEventListener('visibilitychange', onVisible);\r\n }\r\n if (typeof window !== 'undefined') {\r\n window.addEventListener('pageshow', onVisible);\r\n }\r\n\r\n // Initial server resync — catches the case where the user landed on\r\n // checkout with a stale cookie whose cart has already been released.\r\n void resyncDeadlineFromServer();\r\n\r\n return () => {\r\n clearInterval(interval);\r\n if (typeof document !== 'undefined') {\r\n document.removeEventListener('visibilitychange', onVisible);\r\n }\r\n if (typeof window !== 'undefined') {\r\n window.removeEventListener('pageshow', onVisible);\r\n }\r\n };\r\n });\r\n\r\n // --- Handlers ---\r\n function handleBack() {\r\n if (onBackProp) {\r\n onBackProp();\r\n } else {\r\n toast.info('Back button pressed — would navigate to ticket selection');\r\n }\r\n }\r\n\r\n /** Called from sidebar/mobile footer — signals the form to validate + submit */\r\n function requestPlaceOrder() {\r\n submitRequested += 1;\r\n }\r\n\r\n /** Called by CheckoutForm after successful validation */\r\n function handlePlaceOrder(formData: CheckoutFormData) {\r\n if (processing) return;\r\n processing = true;\r\n\r\n if (onPlaceOrderProp) {\r\n // Production mode: delegate to wrapper with form data\r\n onPlaceOrderProp(formData)\r\n .catch(() => {\r\n // Error handling is done by the wrapper; just reset processing\r\n })\r\n .finally(() => {\r\n processing = false;\r\n });\r\n return;\r\n }\r\n\r\n // Showcase mode: existing mock delay\r\n setTimeout(() => {\r\n processing = false;\r\n const count = orderTotals.lines.reduce((s, l) => s + l.quantity, 0);\r\n toast.success(\r\n `Order placed! ${count} ticket(s) for ${formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}`\r\n );\r\n }, 1500);\r\n }\r\n\r\n function handleRetryExpired() {\r\n showExpiredModal = false;\r\n if (onRetryExpiredProp) {\r\n onRetryExpiredProp();\r\n } else {\r\n toast.info('Would navigate back to ticket selection to start over');\r\n }\r\n }\r\n\r\n /** Extend the checkout session via the parent wrapper's onExtendSession callback */\r\n async function handleExtendSession() {\r\n if (!canExtend || isExtendingSession) return;\r\n isExtendingSession = true;\r\n\r\n try {\r\n if (onExtendSessionProp) {\r\n const result = await onExtendSessionProp();\r\n // The parent wrapper (Checkout.svelte) returns `null` when the\r\n // extend-session API call fails — e.g. when the reservation\r\n // has already expired server-side past its grace window, or\r\n // the user has used all 3 extensions. Treat null/undefined as\r\n // an unambiguous failure: don't reset the timer to +15min\r\n // locally (that would falsely show the user they still have a\r\n // valid cart when the server has already released the tickets).\r\n if (result == null) {\r\n throw new AppError('Extension request returned no result', 'lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutMain/handleExtendSession');\r\n }\r\n if (typeof result === 'object') {\r\n if (result.newExpiryTime) {\r\n // Server gave us an absolute new expiry — use it directly.\r\n deadlineMs = new Date(result.newExpiryTime).getTime();\r\n } else {\r\n // Fallback: add 15 minutes from now\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n }\r\n timerSeconds = recomputeFromDeadline();\r\n if (result.remainingExtensions !== undefined) {\r\n remainingExtensions = result.remainingExtensions;\r\n canExtend = remainingExtensions > 0;\r\n }\r\n } else {\r\n // Truthy non-object: legacy callers that just return `true`\r\n // on success. Treat as a simple 15-minute extension.\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n } else {\r\n // Showcase mode: just add 15 minutes\r\n deadlineMs = Date.now() + 15 * 60 * 1000;\r\n timerSeconds = recomputeFromDeadline();\r\n }\r\n\r\n isExpired = false;\r\n warningShown = false;\r\n showWarningModal = false;\r\n showExpiredModal = false;\r\n } catch (err) {\r\n logger.error('Failed to extend session:', err);\r\n // Extension failed — close the warning but keep the expired\r\n // modal open so the user is offered \"Select tickets again\".\r\n // Disable further extend attempts on this dead cart.\r\n showWarningModal = false;\r\n canExtend = false;\r\n if (timerSeconds <= 0) {\r\n isExpired = true;\r\n showExpiredModal = true;\r\n }\r\n } finally {\r\n isExtendingSession = false;\r\n }\r\n }\r\n\r\n /** Dismiss warning modal without extending (user will hurry) */\r\n function dismissWarning() {\r\n showWarningModal = false;\r\n }\r\n\r\n</script>\r\n\r\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\r\n <div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\r\n <!-- Single CheckoutForm shared between desktop and mobile layouts.\r\n\t\t Previously there were two instances (one hidden md:grid, one md:hidden)\r\n\t\t which caused duplicate Stripe elements and broken form submission. -->\r\n <div class=\"max-w-6xl\">\r\n <!-- Desktop: two-column grid; Mobile: single column -->\r\n <div class=\"md:grid md:grid-cols-booking-split gap-8 items-start\">\r\n <!-- LEFT COLUMN (or full width on mobile): Checkout form -->\r\n <div class=\"pb-24 md:pb-0\">\r\n <CheckoutForm\r\n event={config.event}\r\n {orderTotals}\r\n {timerSeconds}\r\n {isExpired}\r\n {isRegistration}\r\n {isFreeOrder}\r\n promoApplied={config.promoApplied}\r\n promoDiscount={config.promoDiscount}\r\n onBack={handleBack}\r\n onPlaceOrder={handlePlaceOrder}\r\n {processing}\r\n {submitRequested}\r\n {stripe}\r\n {paymentIntent}\r\n bind:elements\r\n {paymentError}\r\n labels={mergedLabels}\r\n />\r\n\r\n <!-- Inline order summary for mobile (below form). Lead with the\r\n event header (poster + title + date + venue) so the buyer\r\n has visual confirmation of what they're paying for as they\r\n approach the sticky Place order button. Mirrors the desktop\r\n CheckoutSidebar layout. -->\r\n <section\r\n class=\"md:hidden mobile-order-summary border-default bg-surface-secondary mt-6\"\r\n >\r\n <div class=\"flex gap-3 pb-3 mb-3 border-b border-default\">\r\n <div class=\"shrink-0 w-20 h-14 rounded-lg overflow-hidden bg-surface-tertiary\">\r\n <Image\r\n src={config.event.imageUrl}\r\n alt={config.event.title}\r\n class=\"w-full h-full\"\r\n />\r\n </div>\r\n <div class=\"flex-1 min-w-0\">\r\n <Text size=\"sm\" class=\"font-semibold block leading-tight line-clamp-2\">\r\n {config.event.title}\r\n </Text>\r\n <div class=\"flex items-center gap-1.5 mt-1\">\r\n <Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n <Text size=\"xs\" color=\"muted\">\r\n {formatBrowseDate(config.event.startDateTime, config.event.timezone)}\r\n {#if config.event.displayStartTime !== false}\r\n &middot; {formatEventTime(config.event.startDateTime, config.event.timezone)}\r\n {/if}\r\n </Text>\r\n </div>\r\n <Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n {config.event.venue.name}\r\n </Text>\r\n </div>\r\n </div>\r\n <OrderSummary {orderTotals} labels={mergedLabels} />\r\n </section>\r\n </div>\r\n\r\n <!-- RIGHT COLUMN: Sticky order summary sidebar (desktop only) -->\r\n <div class=\"hidden md:block sticky top-6\">\r\n <CheckoutSidebar\r\n event={config.event}\r\n {orderTotals}\r\n {isFreeOrder}\r\n onPlaceOrder={requestPlaceOrder}\r\n processing={processing || (!isFreeOrder && !totalsLocked)}\r\n labels={mergedLabels}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Mobile: Fixed bottom bar -->\r\n <div class=\"md:hidden\">\r\n <CheckoutMobileFooter\r\n {orderTotals}\r\n {isFreeOrder}\r\n onPlaceOrder={requestPlaceOrder}\r\n processing={processing || (!isFreeOrder && !totalsLocked)}\r\n labels={mergedLabels}\r\n />\r\n </div>\r\n </div>\r\n\r\n <!-- Session Warning Modal (30 seconds remaining).\r\n Wrapped in `{#if}` (instead of relying on `bind:open` alone) so\r\n the Modal fully mounts/unmounts each time showWarningModal\r\n transitions. Surfaced by a wall-clock test where, after the\r\n user clicked \"Continue checkout\" on a first warning, the Modal\r\n component's internal open-state never reset cleanly — on the\r\n NEXT 30s threshold the timer text in DOM updated but the modal\r\n stayed visually hidden, so the user lost the cart with no\r\n chance to re-extend. Forcing remount with #if sidesteps that. -->\r\n {#if showWarningModal}\r\n <Modal\r\n open={true}\r\n oncancel={() => (showWarningModal = false)}\r\n size=\"sm\"\r\n aria-labelledby=\"warning-modal-title\"\r\n >\r\n {#snippet body()}\r\n <div class=\"timer-modal\" id=\"warning-modal-description\">\r\n <div class=\"timer-modal-icon warning\">\r\n <Warning size={32} />\r\n </div>\r\n <h3 id=\"warning-modal-title\" class=\"timer-modal-title\">\r\n {mergedLabels.sessionExpiringSoon || 'Session expiring soon'}\r\n </h3>\r\n <p class=\"timer-modal-text\">\r\n {(\r\n mergedLabels.sessionExpiringSoonMessage ||\r\n 'Your checkout session will expire in {time}. Your selected tickets will be released back to inventory.'\r\n ).replace('{time}', timerDisplay)}\r\n </p>\r\n {#if canExtend && remainingExtensions > 0}\r\n <p class=\"timer-modal-hint\">\r\n {(\r\n mergedLabels.extensionsRemaining ||\r\n '{count} extension{plural} remaining'\r\n )\r\n .replace('{count}', String(remainingExtensions))\r\n .replace('{plural}', remainingExtensions === 1 ? '' : 's')}\r\n </p>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n {#snippet footer()}\r\n <div class=\"timer-modal-actions\">\r\n {#if canExtend}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleExtendSession}\r\n disabled={isExtendingSession}\r\n loading={isExtendingSession}\r\n >\r\n {isExtendingSession\r\n ? mergedLabels.extendingSession || 'Extending...'\r\n : mergedLabels.continueCheckout || 'Continue checkout'}\r\n </Button>\r\n {:else}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={dismissWarning}\r\n >\r\n {mergedLabels.okIllHurry || \"OK, I'll hurry\"}\r\n </Button>\r\n <p class=\"timer-modal-hint\">\r\n {mergedLabels.maxExtensionsReached ||\r\n 'Maximum extensions reached'}\r\n </p>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n </Modal>\r\n {/if}\r\n\r\n <!-- Session Expired Modal (\"Want to keep your tickets?\").\r\n Same `{#if}` wrap as the warning modal — forces a fresh\r\n Modal mount each time so reopening after a previous extend\r\n cycle actually re-displays the dialog. -->\r\n {#if showExpiredModal}\r\n <Modal\r\n open={true}\r\n oncancel={() => (showExpiredModal = false)}\r\n size=\"sm\"\r\n aria-labelledby=\"expired-modal-title\"\r\n >\r\n {#snippet body()}\r\n <div class=\"timer-modal\" id=\"expired-modal-description\">\r\n <div class=\"timer-modal-icon expired\">\r\n <Time size={32} />\r\n </div>\r\n <h3 id=\"expired-modal-title\" class=\"timer-modal-title\">\r\n {canExtend\r\n ? mergedLabels.wantToKeepTickets || 'Want to keep your tickets?'\r\n : mergedLabels.sessionExpired || 'Session expired'}\r\n </h3>\r\n <p class=\"timer-modal-text\">\r\n {canExtend\r\n ? mergedLabels.sessionExpiredMessage ||\r\n 'Your checkout session has expired and your selected tickets have been released.'\r\n : mergedLabels.reservationTimedOut ||\r\n 'Your reservation has timed out. Please select your tickets again to continue.'}\r\n </p>\r\n </div>\r\n {/snippet}\r\n {#snippet footer()}\r\n <div class=\"timer-modal-actions\">\r\n {#if canExtend}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleExtendSession}\r\n disabled={isExtendingSession}\r\n loading={isExtendingSession}\r\n >\r\n {isExtendingSession\r\n ? mergedLabels.extendingSession || 'Extending...'\r\n : mergedLabels.keepMyTickets || 'Keep my tickets'}\r\n </Button>\r\n <Button\r\n variant=\"alternative\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleRetryExpired}\r\n >\r\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\r\n </Button>\r\n {:else}\r\n <Button\r\n variant=\"default\"\r\n size=\"lg\"\r\n class=\"w-full\"\r\n onclick={handleRetryExpired}\r\n >\r\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\r\n </Button>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n </Modal>\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n /* Mobile order summary */\r\n .mobile-order-summary {\r\n padding: 1rem;\r\n border-radius: 0.5rem;\r\n border-width: 1px;\r\n border-style: solid;\r\n }\r\n\r\n /* Timer modals */\r\n .timer-modal {\r\n text-align: center;\r\n padding: 0.5rem 0;\r\n }\r\n\r\n .timer-modal-icon {\r\n display: inline-flex;\r\n align-items: center;\r\n justify-content: center;\r\n width: 3.5rem;\r\n height: 3.5rem;\r\n border-radius: 9999px;\r\n margin: 0 auto 1rem;\r\n }\r\n\r\n .timer-modal-icon.warning {\r\n background-color: hsl(var(--accent-warning) / 8%);\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .timer-modal-icon.expired {\r\n background-color: hsl(var(--accent-danger) / 5%);\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .timer-modal-title {\r\n font-size: 1.125rem;\r\n font-weight: 600;\r\n margin-bottom: 0.5rem;\r\n }\r\n\r\n .timer-modal-text {\r\n font-size: 0.875rem;\r\n line-height: 1.4;\r\n color: hsl(var(--text-tertiary)); /* gray-500 */\r\n }\r\n\r\n .timer-modal-hint {\r\n font-size: 0.75rem;\r\n color: hsl(var(--text-head)); /* gray-400 */\r\n margin-top: 0.5rem;\r\n }\r\n\r\n .timer-modal-actions {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.5rem;\r\n }\r\n /* The Button component's class=\"w-full\" is a Tailwind utility that\r\n isn't always emitted in the venue-calendar bundle (no scanner\r\n pass over node_modules), so force full width at the layout\r\n level. Applies to both <button> and the anchor variant. */\r\n .timer-modal-actions :global(button),\r\n .timer-modal-actions :global(a) {\r\n width: 100%;\r\n }\r\n</style>\r\n"],"names":["browser","detectDarkMode","containerSelector","saved","selector","containers","container","getStripeTheme","isDark","useStripeTheme","options","watchChanges","fallback","current","$","observer","updateTheme","onMount","root","onDestroy","stripe","paymentIntent","elements","paymentError","labels","$$props","stripeTheme","paymentMountDiv","paymentElement","stripeMounted","mountStripePayment","firstName","lastName","email","keepUpdated","agreeTerms","cardNumber","cardExpiry","cardCvc","attendees","submitted","errors","e","isEmailAddress","i","att","hasErrors","isTimerUrgent","totalTickets","sum","l","_","lastSubmitRequest","handleSubmit","handleSameAsPurchaser","index","checked","a","div","div_1","Button","node","ChevronLeft","CheckoutTimer","node_1","section","Heading","node_2","div_2","$3","Input","node_3","$$value","node_4","node_5","Checkbox","node_6","section_1","root_4","node_8","node_9","attendee","div_3","root_6","div_4","Text","node_10","node_11","div_5","div_6","node_12","node_13","node_14","$$render","consequent","section_2","node_7","div_7","root_9","node_16","node_17","node_18","div_8","fragment_9","p","root_15","consequent_2","p_1","root_16","consequent_3","alternate","p_2","root_17","consequent_4","node_22","node_23","div_9","node_24","node_25","consequent_1","consequent_5","alternate_1","section_3","node_26","div_10","root_21","Warning","node_29","text_13","consequent_6","Card","$$anchor","fragment_1","Image","Calendar","formatEventTime","formatBrowseDate","text_3","OrderSummary","$0","text_6","formatCurrency","totalTicketCount","text_1","logger","createLogger","checkoutStateOptions","dataVariant","dataToggleStore","configProp","onPlaceOrderProp","onBackProp","onRetryExpiredProp","onExtendSessionProp","mergedLabels","mergeLabels","isShowcaseMode","buildConfig","variant","mockFreeEvent","asTicketId","mockDonationEvent","mockRegistrationEvent","mockEvent","config","deadlineMs","timerSeconds","isExpired","processing","submitRequested","showWarningModal","showExpiredModal","warningShown","isExtendingSession","remainingExtensions","canExtend","WARNING_THRESHOLD","timerDisplay","m","s","orderTotals","lines","subtotal","roundCurrency","fees","promoDiscount","adjustedSubtotal","taxes","calculateTax","totalsLocked","isFreeOrder","isRegistration","timerInitialized","c","getCartIdFromCookie","getCookie","COOKIE_NAMES","recomputeFromDeadline","resyncDeadlineFromServer","cartId","status","getSessionStatus","tick","next","interval","onVisible","handleBack","toast","requestPlaceOrder","handlePlaceOrder","formData","count","handleRetryExpired","handleExtendSession","result","AppError","err","dismissWarning","CheckoutForm","CheckoutSidebar","CheckoutMobileFooter","Modal","div_11","div_12","h3","root_7","div_13","root_8","div_14","root_14","div_15","Time","h3_1","p_3","div_16","node_19"],"mappings":"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","x_google_ignoreList":[1]}
@@ -1,14 +1,14 @@
1
1
  import "svelte/internal/disclose-version";
2
- import { ac as pe, aB as rt, w as Zt, D as $t, q as er, H as tr, J as rr, r as ar, y as ft, b4 as sr, aq as ir, b5 as et, B as ht, c as nr, R as lr, U as or, b6 as dr, b7 as cr } from "./VenueCalendar-n-T-MmLU.js";
2
+ import { ad as pe, aC as rt, w as Zt, D as $t, q as er, H as tr, J as rr, r as ar, y as ft, b5 as sr, ar as ir, b6 as et, B as ht, c as nr, U as lr, V as or, b7 as dr, b8 as cr } from "./VenueCalendar-BoSdP7xI.js";
3
3
  import * as e from "svelte/internal/client";
4
4
  import "svelte/transition";
5
5
  import "svelte/easing";
6
6
  import { onDestroy as ur, onMount as gr } from "svelte";
7
7
  import { g as yt } from "./__SKIP_NAVIGATION__-CJ96TTPE.js";
8
- import "./api-Bj-wXy71.js";
8
+ import "./api-CCKXC9Qs.js";
9
9
  import { O as mr } from "./OrderSummarySkeleton-dDKUH741.js";
10
- import { b as tt, u as vr } from "./Checkout-CbltFN5w.js";
11
- import { G as pr, l as fr } from "./Checkout-C_7r24PK.js";
10
+ import { b as tt, u as vr } from "./Checkout-CRBwRTOc.js";
11
+ import { G as pr, l as fr } from "./Checkout-Bm3yGYYr.js";
12
12
  import { A as hr } from "./colors-CmP-sSZD.js";
13
13
  var yr = e.from_html('<section class="p-4 md:p-5"><div class="grid grid-row-3 gap-3"><h2 class="text-base font-medium leading-6 text-text-primary mb-4"> </h2> <!> <div class="grid grid-cols-2 gap-4"><!> <!> <div class="col-span-2"><!></div></div></div></section>'), _r = e.from_html('<form><section class="p-4 md:p-5" aria-labelledby="billing-section-title"><div class="space-y-4"><h2 id="billing-section-title" class="section-title text-lg font-semibold text-text-primary mb-4"> </h2> <div class="grid grid-cols-2 gap-4"><!> <!> <div class="col-span-2"><!></div> <div class="col-span-2"><!></div></div> <!> <span id="mailing-list-description" class="sr-only svelte-1vqwkpf"> </span></div></section> <!></form>');
14
14
  function br(ie, a) {
@@ -1149,4 +1149,4 @@ e.delegate(["click"]);
1149
1149
  export {
1150
1150
  Jr as default
1151
1151
  };
1152
- //# sourceMappingURL=Checkout.legacy-C8IT4aEk.js.map
1152
+ //# sourceMappingURL=Checkout.legacy-CpgxTxZl.js.map