@getmicdrop/venue-calendar 4.0.5 → 4.0.6

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 (84) hide show
  1. package/README.md +700 -700
  2. package/dist/{AirbnbSplitMain-BVNtTJc-.js → AirbnbSplitMain-CCv3Iffq.js} +4 -4
  3. package/dist/AirbnbSplitMain-CCv3Iffq.js.map +1 -0
  4. package/dist/{CarouselView.legacy-B6HtvF8d.js → CarouselView.legacy-CrRZOj_r.js} +3 -3
  5. package/dist/CarouselView.legacy-CrRZOj_r.js.map +1 -0
  6. package/dist/{CartView-DrOhr4Qi.js → CartView-iQo98Gz9.js} +92 -86
  7. package/dist/CartView-iQo98Gz9.js.map +1 -0
  8. package/dist/{Checkout-DB1Aocl-.js → Checkout-B5cpBC_C.js} +4 -4
  9. package/dist/Checkout-B5cpBC_C.js.map +1 -0
  10. package/dist/{Checkout.legacy-DpcjjHQu.js → Checkout.legacy-BbnADZBS.js} +4 -4
  11. package/dist/Checkout.legacy-BbnADZBS.js.map +1 -0
  12. package/dist/{CheckoutMain-D0_1xfR8.js → CheckoutMain-Cucw7O5q.js} +4 -4
  13. package/dist/CheckoutMain-Cucw7O5q.js.map +1 -0
  14. package/dist/{CheckoutTimer-r1HaN6b6.js → CheckoutTimer-CA8JRNNX.js} +2 -2
  15. package/dist/CheckoutTimer-CA8JRNNX.js.map +1 -0
  16. package/dist/{CollectionView-5OzqEVQg.js → CollectionView-B9vBgPTn.js} +5 -5
  17. package/dist/CollectionView-B9vBgPTn.js.map +1 -0
  18. package/dist/{CollectionView.legacy-CabEI40i.js → CollectionView.legacy-lSUeA4gS.js} +3 -3
  19. package/dist/CollectionView.legacy-lSUeA4gS.js.map +1 -0
  20. package/dist/{EventDetailsView-CiGPGPz5.js → EventDetailsView-xfnj-hRQ.js} +2 -2
  21. package/dist/EventDetailsView-xfnj-hRQ.js.map +1 -0
  22. package/dist/{FeaturedView.legacy-tTPbRxSf.js → FeaturedView.legacy-BnqQQ1Hx.js} +2 -2
  23. package/dist/FeaturedView.legacy-BnqQQ1Hx.js.map +1 -0
  24. package/dist/{GalleryCard-CBMPmdrM.js → GalleryCard-CfQenZ6B.js} +2 -2
  25. package/dist/GalleryCard-CfQenZ6B.js.map +1 -0
  26. package/dist/{GalleryView.legacy-4QPpX22O.js → GalleryView.legacy-DTSxVx10.js} +3 -3
  27. package/dist/GalleryView.legacy-DTSxVx10.js.map +1 -0
  28. package/dist/{GroupedListView.legacy-CPJRLePS.js → GroupedListView.legacy-B4a7OzQZ.js} +2 -2
  29. package/dist/GroupedListView.legacy-B4a7OzQZ.js.map +1 -0
  30. package/dist/OrderSummarySkeleton-dDKUH741.js.map +1 -1
  31. package/dist/{SeriesPage-IZWQ53xg.js → SeriesPage-BudI30aC.js} +5 -5
  32. package/dist/SeriesPage-BudI30aC.js.map +1 -0
  33. package/dist/{SeriesPage.legacy-4jSF2g-n.js → SeriesPage.legacy-Bv0HHWbw.js} +2 -2
  34. package/dist/SeriesPage.legacy-Bv0HHWbw.js.map +1 -0
  35. package/dist/{Success-DTSn26bg.js → Success-BGNZH5BM.js} +5 -5
  36. package/dist/Success-BGNZH5BM.js.map +1 -0
  37. package/dist/{Success.legacy--ABrtyII.js → Success.legacy-CRUwkdEm.js} +2 -2
  38. package/dist/Success.legacy-CRUwkdEm.js.map +1 -0
  39. package/dist/{VenueCalendar-DpZ70okH.js → VenueCalendar-DO07BAoR.js} +18 -15
  40. package/dist/{VenueCalendar-DpZ70okH.js.map → VenueCalendar-DO07BAoR.js.map} +1 -1
  41. package/dist/{ViewTicketsEmbed-CgHcn-qh.js → ViewTicketsEmbed-HD3tu9Yo.js} +2 -2
  42. package/dist/ViewTicketsEmbed-HD3tu9Yo.js.map +1 -0
  43. package/dist/api/api.cjs +1 -1
  44. package/dist/api/api.cjs.map +1 -1
  45. package/dist/api/api.mjs +4 -1
  46. package/dist/api/api.mjs.map +1 -1
  47. package/dist/api/types.d.ts +357 -353
  48. package/dist/colors-BZoMuXdh.js.map +1 -1
  49. package/dist/{labels-ClcIxHAF.js → labels-CuX0_TVA.js} +2 -2
  50. package/dist/labels-CuX0_TVA.js.map +1 -0
  51. package/dist/seo/seo.cjs.map +1 -1
  52. package/dist/seo/seo.mjs.map +1 -1
  53. package/dist/seo/types.d.ts +137 -137
  54. package/dist/{transform-DW3JR-t5.js → transform-B0K6j8y8.js} +2 -2
  55. package/dist/transform-B0K6j8y8.js.map +1 -0
  56. package/dist/types/index.d.ts +387 -387
  57. package/dist/venue-calendar.es.js +1 -1
  58. package/dist/venue-calendar.iife.js +13 -13
  59. package/dist/venue-calendar.iife.js.map +1 -1
  60. package/dist/venue-calendar.umd.js +13 -13
  61. package/dist/venue-calendar.umd.js.map +1 -1
  62. package/package.json +1 -1
  63. package/src/lib/theme.js +222 -222
  64. package/dist/AirbnbSplitMain-BVNtTJc-.js.map +0 -1
  65. package/dist/CarouselView.legacy-B6HtvF8d.js.map +0 -1
  66. package/dist/CartView-DrOhr4Qi.js.map +0 -1
  67. package/dist/Checkout-DB1Aocl-.js.map +0 -1
  68. package/dist/Checkout.legacy-DpcjjHQu.js.map +0 -1
  69. package/dist/CheckoutMain-D0_1xfR8.js.map +0 -1
  70. package/dist/CheckoutTimer-r1HaN6b6.js.map +0 -1
  71. package/dist/CollectionView-5OzqEVQg.js.map +0 -1
  72. package/dist/CollectionView.legacy-CabEI40i.js.map +0 -1
  73. package/dist/EventDetailsView-CiGPGPz5.js.map +0 -1
  74. package/dist/FeaturedView.legacy-tTPbRxSf.js.map +0 -1
  75. package/dist/GalleryCard-CBMPmdrM.js.map +0 -1
  76. package/dist/GalleryView.legacy-4QPpX22O.js.map +0 -1
  77. package/dist/GroupedListView.legacy-CPJRLePS.js.map +0 -1
  78. package/dist/SeriesPage-IZWQ53xg.js.map +0 -1
  79. package/dist/SeriesPage.legacy-4jSF2g-n.js.map +0 -1
  80. package/dist/Success-DTSn26bg.js.map +0 -1
  81. package/dist/Success.legacy--ABrtyII.js.map +0 -1
  82. package/dist/ViewTicketsEmbed-CgHcn-qh.js.map +0 -1
  83. package/dist/labels-ClcIxHAF.js.map +0 -1
  84. package/dist/transform-DW3JR-t5.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventDetailsView-CiGPGPz5.js","sources":["../src/components/Events/Details/PriceTag.svelte","../src/components/Events/Details/PriceTagSkeleton.svelte","../src/components/Events/Details/TicketActions.svelte","../src/components/Events/Details/StickySidebar.svelte","../src/components/Modals/WaitlistModal.svelte","../src/components/Events/Details/Disclaimer.svelte","../src/components/Tab/+page.svelte","../src/components/Views/EventDetailsView.svelte"],"sourcesContent":["<script>\n import { formatCurrency } from '@getmicdrop/svelte-components';\nlet {\n price,\n fee,\n tickets,\n labels = {},\n } = $props();\n\n const onlyOneFreeTicket = $derived(\n tickets.length === 1 && parseFloat(tickets[0].price) === 0\n );\n</script>\n\n<div class=\"flex flex-col items-end gap-0.5\" aria-label=\"Ticket price: {price === 0 ? (onlyOneFreeTicket ? (labels.free || 'Free') : '$0.00') : `${formatCurrency(price /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}`}{fee > 0 ? `, ${(labels.includingFee || 'including {fee} service fee').replace('{fee}', formatCurrency(fee /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */))}` : ''}\">\n {#if price === 0}\n <span class=\"text-lg font-semibold text-text-primary\">\n {onlyOneFreeTicket ? (labels.free || 'Free') : '$0.00'}\n </span>\n {:else}\n <span class=\"text-lg font-semibold text-text-primary\">\n {formatCurrency(price /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\n </span>\n {/if}\n\n {#if fee > 0}\n <span class=\"text-xs text-muted-foreground\" aria-hidden=\"true\">\n {(labels.inclFee || 'incl. {fee} fee').replace('{fee}', formatCurrency(fee /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */))}\n </span>\n {/if}\n</div>\n","<div class=\"flex items-center gap-2 animate-pulse\" role=\"status\" aria-busy=\"true\" aria-label=\"Loading price\">\n <span class=\"sr-only\">Loading price...</span>\n <div class=\"h-5 w-16 rounded-md bg-bg-tertiary\" aria-hidden=\"true\"></div>\n <div class=\"h-3 w-12 rounded-md bg-muted\" aria-hidden=\"true\"></div>\n</div>\n\n<style>\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n }\n</style>\n","<script>\n import PriceTag from './PriceTag.svelte';\n import PriceTagSkeleton from './PriceTagSkeleton.svelte';\n import { Button, formatCurrency } from '@getmicdrop/svelte-components';\n import { Locked, Time } from 'carbon-icons-svelte';\n\n let {\n dataReady = false,\n event,\n ticketType,\n availableTickets = [],\n goToCheckout,\n isMobileDrawer = false,\n isCancelled = false,\n purchasedTickets = event.purchasedTickets || 0,\n waitlistEnabled = false,\n onJoinWaitlist = () => {},\n labels = {},\n } = $props();\n\n const visibleTickets = $derived(availableTickets.filter(\n t => t.visibility === 0\n ));\n\n const totalRemainingCapacity = $derived(visibleTickets.reduce(\n (acc, t) => acc + t.remainingCapacity,\n 0\n ));\n const isSoldOut = $derived(purchasedTickets >= totalRemainingCapacity);\n const hasNoTickets = $derived(visibleTickets.length === 0);\n\n const basePrice = $derived(\n visibleTickets.length > 0\n ? Math.min(...visibleTickets.map(t => t.price))\n : 0\n );\n</script>\n\n{#if isMobileDrawer}\n <!-- Mobile drawer: compact horizontal layout -->\n <div class=\"mobile-drawer flex items-center justify-between gap-4 px-4 py-3 safe-area-bottom\" role=\"region\" aria-label={labels.ticketPurchase || \"Ticket purchase\"}>\n <div class=\"flex flex-col min-w-0\">\n <span class=\"text-xs text-muted-foreground\">{labels.from || 'From'}</span>\n {#if dataReady}\n <div class=\"flex items-baseline gap-1.5\" aria-label=\"Price: from {formatCurrency(basePrice /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\">\n <span class=\"text-xl font-semibold text-text-primary\">\n {formatCurrency(basePrice /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\n </span>\n <span class=\"text-xs text-muted-foreground\" aria-hidden=\"true\">+ {labels.fees || 'fees'}</span>\n </div>\n {:else}\n <div class=\"h-6 w-20 skeleton rounded\" role=\"status\" aria-busy=\"true\" aria-label={labels.loadingPrice || \"Loading price\"}></div>\n {/if}\n </div>\n\n <div class=\"shrink-0\">\n {#if isCancelled}\n <Button variant=\"red-outline\" disabled aria-label={labels.eventCancelled || \"Event Cancelled\"}>{labels.eventCancelled || 'Event Cancelled'}</Button>\n {:else if hasNoTickets}\n <Button variant=\"red-outline\" disabled aria-label={labels.salesEnded || \"Sales Ended\"}>{labels.salesEnded || 'Sales Ended'}</Button>\n {:else if isSoldOut}\n {#if waitlistEnabled}\n <Button onclick={onJoinWaitlist} class=\"px-6 py-3 text-base font-semibold\" aria-label={labels.joinWaitlist || \"Join waitlist for this sold out event\"}>\n <Time size={16} class=\"mr-1.5\" aria-hidden=\"true\" />\n {labels.joinWaitlist || 'Join Waitlist'}\n </Button>\n {:else}\n <Button variant=\"alternative\" disabled aria-label={labels.soldOut || \"Sold Out\"}>{labels.soldOut || 'Sold Out'}</Button>\n {/if}\n {:else}\n <Button onclick={goToCheckout} class=\"px-6 py-3 text-base font-semibold\" aria-label={ticketType === 1 ? (labels.reserve || 'Reserve a spot for this event') : (labels.getTickets || 'Get tickets for this event')}>\n {ticketType === 1 ? (labels.reserve || 'Reserve') : (labels.getTickets || 'Get tickets')}\n </Button>\n {/if}\n </div>\n </div>\n{:else}\n <!-- Desktop: full layout with trust signals -->\n <div class=\"card p-5 mt-5\" role=\"region\" aria-label={labels.ticketPurchaseOptions || \"Ticket purchase options\"}>\n <div class=\"flex flex-col gap-3\">\n <div class=\"flex items-center justify-between\">\n <span class=\"text-sm text-muted-foreground\">{labels.startsFrom || 'Starts from'}</span>\n\n {#if dataReady}\n <PriceTag\n price={basePrice}\n tickets={availableTickets}\n />\n {:else}\n <PriceTagSkeleton />\n {/if}\n </div>\n\n <div>\n {#if isCancelled}\n <Button size=\"full\" variant=\"red-outline\" disabled aria-label={labels.eventCancelled || \"Event Cancelled\"}>{labels.eventCancelled || 'Event Cancelled'}</Button>\n {:else if hasNoTickets}\n <Button size=\"full\" variant=\"red-outline\" disabled aria-label={labels.salesEnded || \"Sales Ended\"}>{labels.salesEnded || 'Sales Ended'}</Button>\n {:else if isSoldOut}\n {#if waitlistEnabled}\n <Button size=\"full\" onclick={onJoinWaitlist} aria-label={labels.joinWaitlist || \"Join waitlist for this sold out event\"}>\n <Time size={16} class=\"mr-1.5\" aria-hidden=\"true\" />\n {labels.joinWaitlist || 'Join Waitlist'}\n </Button>\n <!-- Waitlist info -->\n <div class=\"flex items-center justify-center gap-1.5 mt-3 text-color-tertiary\" aria-hidden=\"true\">\n <span class=\"caption\">{labels.getNotifiedWhenAvailable || 'Get notified when tickets are available'}</span>\n </div>\n {:else}\n <Button size=\"full\" variant=\"alternative\" disabled aria-label={labels.soldOut || \"Sold Out\"}>{labels.soldOut || 'Sold Out'}</Button>\n {/if}\n {:else}\n <Button size=\"full\" onclick={goToCheckout} aria-label={ticketType === 1 ? (labels.reserveASpot || 'Reserve a spot for this event') : (labels.getTickets || 'Get tickets for this event')}>\n {ticketType === 1 ? (labels.reserveASpot || 'Reserve a spot') : (labels.getTickets || 'Get tickets')}\n </Button>\n <!-- Trust signal -->\n <div class=\"flex items-center justify-center gap-1.5 mt-3 text-muted-foreground\" aria-hidden=\"true\">\n <Locked size={12} aria-hidden=\"true\" />\n <span class=\"text-xs\">{labels.secureCheckout || 'Secure checkout'}</span>\n </div>\n {/if}\n </div>\n </div>\n </div>\n{/if}\n\n<style>\n .safe-area-bottom {\n padding-bottom: max(0.75rem, env(safe-area-inset-bottom));\n }\n</style>\n","<script>\n import { ShowCard } from '@getmicdrop/svelte-components';\n import TicketActions from './TicketActions.svelte';\n\n let {\n dataReady = false,\n event,\n showtimes = [],\n ticketType,\n availableTickets = [],\n isSticky = false,\n sidebarLeft = 0,\n goToCheckout,\n isCancelled = false,\n waitlistEnabled = false,\n onJoinWaitlist = () => {},\n labels = {},\n } = $props();\n</script>\n\n<!-- Desktop sidebar - hidden on mobile -->\n<aside\n class=\"hidden lg:flex w-80 flex-col transition-all duration-200 {isSticky ? 'fixed top-5 max-h-[calc(100vh-40px)] overflow-y-auto' : 'relative max-h-none overflow-visible'}\"\n style:left={isSticky ? `${sidebarLeft}px` : 'auto'}\n aria-label={labels.ariaEventBooking || \"Event booking\"}\n>\n <ShowCard {event} {showtimes} />\n\n <TicketActions\n {event}\n {ticketType}\n {availableTickets}\n {goToCheckout}\n\n {dataReady}\n {isCancelled}\n {waitlistEnabled}\n {onJoinWaitlist}\n {labels}\n />\n</aside>\n\n<!-- Mobile sticky bottom CTA - only shows on mobile -->\n<div class=\"lg:hidden fixed bottom-0 left-0 right-0 z-50 bg-card border-t border-border shadow-xl\" role=\"region\" aria-label={labels.ariaGetTickets || \"Get tickets\"}>\n <TicketActions\n {event}\n {ticketType}\n {availableTickets}\n {goToCheckout}\n\n {dataReady}\n {isCancelled}\n {waitlistEnabled}\n {onJoinWaitlist}\n isMobileDrawer={true}\n {labels}\n />\n</div>\n","<script>\n import { Modal, Button, Input } from '@getmicdrop/svelte-components';\n import { Time, Email, Phone, CheckmarkFilled } from 'carbon-icons-svelte';\n import { joinWaitlist } from '$lib/api';\n\n let {\n show = $bindable(false),\n eventId,\n eventName = 'this event',\n onClose = () => {},\n labels = {},\n } = $props();\n\n // Form state\n let email = $state('');\n let phone = $state('');\n let smsOptIn = $state(false);\n let loading = $state(false);\n let error = $state('');\n let success = $state(false);\n let position = $state(0);\n\n // Validation\n let emailError = $derived(email && !isValidEmail(email) ? (labels.pleaseEnterValidEmail || 'Please enter a valid email') : '');\n let phoneError = $derived(phone && smsOptIn && !isValidPhone(phone) ? (labels.pleaseEnterValidPhone || 'Please enter a valid phone number') : '');\n\n function isValidEmail(email) {\n return /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(email);\n }\n\n function isValidPhone(phone) {\n // Allow various phone formats\n const cleaned = phone.replace(/\\D/g, '');\n return cleaned.length >= 10 && cleaned.length <= 15;\n }\n\n async function handleSubmit() {\n error = '';\n\n if (!email || !isValidEmail(email)) {\n error = labels.pleaseEnterValidEmailAddress || 'Please enter a valid email address';\n return;\n }\n\n if (smsOptIn && phone && !isValidPhone(phone)) {\n error = labels.pleaseEnterValidPhone || 'Please enter a valid phone number';\n return;\n }\n\n loading = true;\n\n const result = await joinWaitlist(\n eventId,\n email,\n smsOptIn ? phone : null,\n smsOptIn\n );\n\n loading = false;\n\n if (result.success) {\n success = true;\n position = result.position;\n } else {\n error = result.error;\n }\n }\n\n function handleClose() {\n // Reset state when closing\n email = '';\n phone = '';\n smsOptIn = false;\n error = '';\n success = false;\n position = 0;\n show = false;\n onClose();\n }\n</script>\n\n<Modal\n bind:show\n size=\"small\"\n role=\"dialog\"\n aria-labelledby=\"waitlist-title\"\n aria-describedby=\"waitlist-description\"\n>\n {#snippet body()}\n {#if success}\n <!-- Success State -->\n <div class=\"flex flex-col items-center text-center pt-6 px-4 pb-4\">\n <div class=\"w-16 h-16 rounded-full flex items-center justify-center mb-4 bg-accent-success/10 text-accent-success\" aria-hidden=\"true\">\n <CheckmarkFilled size={32} aria-hidden=\"true\" />\n </div>\n <h3 id=\"waitlist-title\" class=\"text-xl font-semibold text-text-primary mb-2\">\n {labels.youreOnTheList || \"You're on the list!\"}\n </h3>\n <p id=\"waitlist-description\" class=\"text-sm text-text-secondary leading-relaxed max-w-72\">\n {#if position > 0}\n {(labels.waitlistPosition || \"You're #{position} in line for {eventName}.\").replace('{position}', String(position)).replace('{eventName}', eventName)}\n {:else}\n {(labels.waitlistAdded || \"You've been added to the waitlist for {eventName}.\").replace('{eventName}', eventName)}\n {/if}\n {labels.waitlistNotifyByEmail || \"We'll notify you by email if tickets become available.\"}\n </p>\n {#if smsOptIn && phone}\n <p class=\"text-xs text-muted-foreground mt-2\">\n {labels.waitlistSmsAlerts || \"You'll also receive SMS alerts.\"}\n </p>\n {/if}\n </div>\n {:else}\n <!-- Form State -->\n <div class=\"flex flex-col pt-6 px-4 pb-4\">\n <div class=\"flex items-center justify-center mb-4\">\n <div class=\"w-12 h-12 rounded-full flex items-center justify-center bg-brand-primary/10 text-brand-primary\" aria-hidden=\"true\">\n <Time size={24} aria-hidden=\"true\" />\n </div>\n </div>\n <h3 id=\"waitlist-title\" class=\"text-xl font-semibold text-text-primary mb-2 text-center\">\n {labels.waitlistTitle || 'Join the Waitlist'}\n </h3>\n <p id=\"waitlist-description\" class=\"text-sm text-text-secondary leading-relaxed text-center mb-6\">\n {labels.waitlistDescription || \"This event is sold out. Join the waitlist and we'll notify you if tickets become available.\"}\n </p>\n\n <form onsubmit={(e) => { e.preventDefault(); handleSubmit(); }} class=\"space-y-4\">\n <!-- Email Input -->\n <div>\n <label for=\"waitlist-email\" class=\"block text-sm font-medium text-text-secondary mb-1\">\n {labels.waitlistEmailLabel || 'Email address'}\n </label>\n <div class=\"relative\">\n <Input\n id=\"waitlist-email\"\n type=\"email\"\n bind:value={email}\n placeholder={labels.waitlistEmailPlaceholder || \"you@example.com\"}\n required\n disabled={loading}\n class={emailError ? 'border-status-error-border' : ''}\n />\n </div>\n {#if emailError}\n <p class=\"text-xs text-accent-danger mt-1\">{emailError}</p>\n {/if}\n </div>\n\n <!-- SMS Opt-in -->\n <div class=\"space-y-2\">\n <label class=\"flex items-start gap-3 cursor-pointer\">\n <input\n type=\"checkbox\"\n bind:checked={smsOptIn}\n disabled={loading}\n class=\"mt-0.5 w-4 h-4 text-brand-primary border-stroke-primary rounded focus:ring-focus-ring\"\n />\n <span class=\"text-sm text-text-secondary\">\n {labels.smsOptIn || 'Also notify me by SMS for faster alerts'}\n </span>\n </label>\n\n {#if smsOptIn}\n <div class=\"ml-7\">\n <Input\n id=\"waitlist-phone\"\n type=\"tel\"\n bind:value={phone}\n placeholder={labels.waitlistPhonePlaceholder || \"(555) 123-4567\"}\n disabled={loading}\n class={phoneError ? 'border-status-error-border' : ''}\n />\n {#if phoneError}\n <p class=\"text-xs text-accent-danger mt-1\">{phoneError}</p>\n {/if}\n <p class=\"text-xs text-muted-foreground mt-1\">\n {labels.smsDisclaimer || 'Message & data rates may apply. Reply STOP to unsubscribe.'}\n </p>\n </div>\n {/if}\n </div>\n\n {#if error}\n <div class=\"p-3 bg-status-error-bg border border-status-error-border rounded-lg\">\n <p class=\"text-sm text-accent-danger\">{error}</p>\n </div>\n {/if}\n </form>\n </div>\n {/if}\n {/snippet}\n {#snippet footer()}\n <div class=\"flex gap-3 w-full\" role=\"group\" aria-label={labels.dialogActions || \"Dialog actions\"}>\n {#if success}\n <Button size=\"full\" variant=\"default\" onclick={handleClose}>\n {labels.done || 'Done'}\n </Button>\n {:else}\n <Button size=\"full\" variant=\"alternative\" onclick={handleClose} disabled={loading}>\n {labels.cancel || 'Cancel'}\n </Button>\n <Button\n size=\"full\"\n variant=\"default\"\n onclick={handleSubmit}\n {loading}\n disabled={!email || !!emailError || (smsOptIn && phone && !!phoneError)}\n >\n {loading ? (labels.joining || 'Joining...') : (labels.joinWaitlist || 'Join Waitlist')}\n </Button>\n {/if}\n </div>\n {/snippet}\n</Modal>\n","<script>\n let {\n disclaimer = [],\n labels = {},\n } = $props();\n\n const fullText = $derived(Array.isArray(disclaimer) ? disclaimer.join(' ') : disclaimer);\n</script>\n\n<section class=\"flex flex-col gap-3\" aria-labelledby=\"disclaimer-title\">\n <h2 id=\"disclaimer-title\" class=\"heading-lg text-color-primary\">{labels.disclaimer || 'Disclaimer'}</h2>\n\n <p class=\"body-sm text-color-secondary\">\n {fullText}\n </p>\n</section>\n","<script>\n import { onMount, onDestroy } from 'svelte';\n\n let {\n items = [],\n } = $props();\n\n /* svelte-ignore state_referenced_locally */\n let activeTab = $state(items[0]?.id || '');\n let observer;\n\n function scrollToSection(tabId) {\n activeTab = tabId;\n const section = document.getElementById(tabId);\n if (section) {\n section.scrollIntoView({ behavior: 'smooth' });\n }\n }\n\n function handleTabKeydown(e, currentIndex) {\n let newIndex = currentIndex;\n\n if (e.key === 'ArrowRight') {\n e.preventDefault();\n newIndex = (currentIndex + 1) % items.length;\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n newIndex = (currentIndex - 1 + items.length) % items.length;\n } else if (e.key === 'Home') {\n e.preventDefault();\n newIndex = 0;\n } else if (e.key === 'End') {\n e.preventDefault();\n newIndex = items.length - 1;\n } else {\n return; // Don't handle other keys\n }\n\n // Focus the new tab and activate it\n const newTabId = items[newIndex].id;\n scrollToSection(newTabId);\n document.getElementById(`tab-${newTabId}`)?.focus();\n }\n\n onMount(() => {\n // Observe sections to update active tab on scroll\n observer = new IntersectionObserver(\n (entries) => {\n entries.forEach((entry) => {\n if (entry.isIntersecting) {\n activeTab = entry.target.id;\n }\n });\n },\n { rootMargin: '-20% 0px -70% 0px' }\n );\n\n items.forEach((item) => {\n const section = document.getElementById(item.id);\n if (section) observer.observe(section);\n });\n });\n\n onDestroy(() => {\n if (observer) observer.disconnect();\n });\n </script>\n\n <div class=\"tab-container flex justify-start gap-1 sm:gap-2 border-b border-border\" role=\"tablist\" aria-label=\"Page sections\">\n {#each items as item, index}\n <button\n type=\"button\"\n onclick={() => scrollToSection(item.id)}\n onkeydown={(e) => handleTabKeydown(e, index)}\n class=\"tab-button py-3 px-3 sm:px-4 text-sm sm:text-base font-medium transition-colors relative text-muted-foreground:outline-brand-primary\"\n class:active={activeTab === item.id}\n role=\"tab\"\n aria-selected={activeTab === item.id}\n aria-controls={item.id}\n tabindex={activeTab === item.id ? 0 : -1}\n id=\"tab-{item.id}\"\n >\n {item.label}\n {#if activeTab === item.id}\n <span class=\"tab-indicator absolute bottom-0 left-0 right-0 h-0.5 bg-bg-primary\" aria-hidden=\"true\"></span>\n {/if}\n </button>\n {/each}\n </div>\n\n<style>\n /* Theme-responsive tab styles */\n .tab-button:hover {\n color: hsl(var(--text-primary)); /* gray-900 */\n }\n\n .tab-button.active {\n color: hsl(var(--text-primary)); /* gray-900 */\n }\n\n .tab-button:focus-visible {\n outline: hsl(var(--brand-primary)) solid 2px; /* blue-700 */\n outline-offset: 2px;\n }\n</style>\n ","<script module>\n\timport { createLogger } from '@getmicdrop/svelte-components';\n\tconst logger = createLogger('EventDetailsView');\n</script>\n\n<script>\n import { onMount, onDestroy } from 'svelte';\n import { goto } from '$app/navigation';\n import {\n transformEvent,\n getImageUrl,\n getVenueDetails,\n generateSlug,\n } from '$lib/utils/utils.js';\n import { fetchEventDetails, checkEventPassword } from '$lib/api';\n import StickySidebar from '../Events/Details/StickySidebar.svelte';\n import WaitlistModal from '../Modals/WaitlistModal.svelte';\n import { ArrowLeft, Locked, WarningAltFilled } from 'carbon-icons-svelte';\n import { AboutShow, FAQs, InputModal } from '@getmicdrop/svelte-components';\n import Disclaimer from '../Events/Details/Disclaimer.svelte';\n import Tab from '../Tab/+page.svelte';\n\n let {\n eventId,\n organizationId = '',\n venueId = '',\n initialEventData = null,\n onNavigateToCart,\n onNavigateBack,\n labels = {},\n } = $props();\n\n let event = $state(null);\n let rawEvent = $state(null);\n let isLoading = $state(true);\n let error = $state(null);\n let dataReady = $state(false);\n let showtimes = $state([]);\n let venueServiceCharge = $state({});\n let isMounted = $state(false);\n\n let isMobile = $state(false);\n let containerRef = $state();\n let stickyRef = $state();\n let isSticky = $state(false);\n let stickyTop = $state(0);\n let sidebarLeft = $state(0);\n let imageHeight = $state(0);\n\n // Password protection state\n let showPasswordModal = $state(false);\n let passwordValue = $state('');\n let passwordError = $state('');\n let passwordLoading = $state(false);\n let isPasswordVerified = $state(false);\n\n // Waitlist state\n let showWaitlistModal = $state(false);\n\n // Check if event is already authenticated in sessionStorage\n function isEventAuthenticated(evtId) {\n if (typeof window === 'undefined') return false;\n const authedEvents = JSON.parse(\n sessionStorage.getItem('authedEvents') || '[]'\n );\n return authedEvents.includes(evtId);\n }\n\n // Store event authentication in sessionStorage\n function setEventAuthenticated(evtId) {\n if (typeof window === 'undefined') return;\n const authedEvents = JSON.parse(\n sessionStorage.getItem('authedEvents') || '[]'\n );\n if (!authedEvents.includes(evtId)) {\n authedEvents.push(evtId);\n sessionStorage.setItem('authedEvents', JSON.stringify(authedEvents));\n }\n }\n\n // Handle password submission\n async function handlePasswordSubmit(e) {\n const password = e.detail?.value || passwordValue;\n if (!password || !eventId) return;\n\n passwordLoading = true;\n passwordError = '';\n\n try {\n const result = await checkEventPassword(eventId, password);\n if (result.valid) {\n setEventAuthenticated(eventId);\n isPasswordVerified = true;\n showPasswordModal = false;\n passwordValue = '';\n } else {\n passwordError =\n labels.incorrectPassword || 'Incorrect password. Please try again.';\n }\n } catch (err) {\n passwordError =\n labels.unableToVerifyPassword ||\n 'Unable to verify password. Please try again.';\n } finally {\n passwordLoading = false;\n }\n }\n\n // Check if password protection is required\n let requiresPassword = $derived(\n event?.password && event.password.trim() !== ''\n );\n let isLocked = $derived(\n requiresPassword && !isPasswordVerified && !isEventAuthenticated(eventId)\n );\n\n // Check if event is cancelled\n let isCancelled = $derived(\n event?.status?.toLowerCase() === 'cancelled' ||\n event?.status?.toLowerCase() === 'canceled'\n );\n\n // Check if waitlist is enabled for this event\n let waitlistEnabled = $derived(rawEvent?.waitlistEnabled === true);\n\n // Handler for joining waitlist\n function handleJoinWaitlist() {\n showWaitlistModal = true;\n }\n\n // Filter out unpublished series events from showtimes\n // Each showtime in a series may have its own published status\n function filterPublishedShowtimes(rawShowtimes) {\n if (!Array.isArray(rawShowtimes)) return [];\n return rawShowtimes.filter(showtime => {\n // Include if no published field exists (backwards compatible)\n if (\n showtime.published === undefined &&\n showtime.isPublished === undefined\n ) {\n return true;\n }\n // Check both possible field names for published status\n return showtime.published === true || showtime.isPublished === true;\n });\n }\n\n const toFaqArray = src => {\n if (!src) return [];\n if (Array.isArray(src)) {\n return src.map(item =>\n typeof item === 'string' ? { question: '', answer: item.trim() } : item\n );\n }\n return [{ question: '', answer: String(src).trim() }];\n };\n\n let venue = $derived(rawEvent?.venue || {});\n let venueFAQs = $derived(toFaqArray(venue.faq));\n let venueDisclaimer = $derived(venue.disclaimer || '');\n let parsedVenueDisclaimer = $derived(\n venueDisclaimer\n ? venueDisclaimer\n .split(/(?<=[.?!])\\s+(?=[A-Z])/g)\n .map(s => s.trim())\n .filter(Boolean)\n : []\n );\n\n let hasPerformers = $derived(\n event?.performers && event.performers.length > 0\n );\n\n let tabsData = $derived([\n { id: 'about', label: labels.tabAboutTheShow || 'About the show' },\n ...(hasPerformers\n ? [{ id: 'featuring', label: labels.tabFeaturing || 'Featuring' }]\n : []),\n ...(venueFAQs.length\n ? [{ id: 'faqs', label: labels.tabFAQs || 'FAQs' }]\n : []),\n ...(parsedVenueDisclaimer.length\n ? [{ id: 'disclaimers', label: labels.tabDisclaimers || 'Disclaimers' }]\n : []),\n ]);\n\n let ticketType = $derived(\n event?.eventTicketingType ?? event?.ticketType ?? 0\n );\n let availableTickets = $derived(event?.availableTickets || []);\n\n function goBack() {\n if (onNavigateBack) {\n onNavigateBack();\n } else {\n const params = new URLSearchParams(window.location.search);\n params.set('subroute', 'calendar');\n params.delete('event_id');\n params.delete('slug');\n const url = `/?${params.toString()}`;\n goto(url, { noScroll: false });\n }\n }\n\n function goToCheckout() {\n if (onNavigateToCart) {\n onNavigateToCart(eventId, generateSlug(event?.name || 'event'));\n } else {\n const params = new URLSearchParams(window.location.search);\n params.set('event_id', eventId);\n params.set('subroute', 'cart');\n params.set('slug', generateSlug(event?.name || 'event'));\n const url = `/?${params.toString()}`;\n goto(url, { noScroll: false });\n }\n }\n\n function updateScreenSize() {\n isMobile = window.innerWidth < 640;\n }\n\n let ticking = false;\n\n function handleScroll() {\n if (!ticking) {\n window.requestAnimationFrame(() => {\n updateStickyState();\n ticking = false;\n });\n ticking = true;\n }\n }\n\n function updateStickyState() {\n if (isMobile) {\n isSticky = false;\n return;\n }\n const rect = stickyRef?.getBoundingClientRect();\n if (!rect) return;\n\n isSticky = rect.top + imageHeight <= 20;\n\n if (isSticky && containerRef) {\n const containerBounding = containerRef.getBoundingClientRect();\n sidebarLeft =\n containerBounding.left + containerRef.clientWidth - 340 - 40;\n }\n }\n\n function getTestEventData(eventId) {\n if (!eventId) return null;\n\n const today = new Date();\n const testDate = new Date(today);\n testDate.setDate(today.getDate() + 7);\n\n return {\n id: String(eventId),\n ID: String(eventId),\n title: 'Test Comedy Show',\n name: 'Test Comedy Show',\n description:\n 'This is a test event for development and testing purposes. Join us for an amazing comedy show featuring top comedians!',\n coverImage:\n 'https://images.unsplash.com/photo-1492684223066-81342ee5ff30?w=1200&h=800&fit=crop',\n startDateTime: testDate.toISOString(),\n endDateTime: new Date(\n testDate.getTime() + 2 * 60 * 60 * 1000\n ).toISOString(),\n venueID: 'test-venue-1',\n venue: {\n name: 'Test Comedy Club',\n address: '123 Test Street, Test City',\n faq: [\n {\n question: 'What time does the show start?',\n answer: 'The show starts at 8:00 PM.',\n },\n {\n question: 'Is there parking available?',\n answer: 'Yes, free parking is available.',\n },\n ],\n disclaimer:\n 'All ticket sales are final. No refunds unless event is cancelled.',\n },\n eventTicketingType: 0,\n ticketType: 0,\n status: 'On Sale',\n availableTickets: [\n {\n ID: 'ticket-1',\n name: 'General Admission',\n price: 25,\n remainingCapacity: 50,\n visibility: 0,\n },\n {\n ID: 'ticket-2',\n name: 'VIP',\n price: 50,\n remainingCapacity: 10,\n visibility: 0,\n },\n ],\n showtimes: [\n {\n startTime: testDate.toISOString(),\n endTime: new Date(\n testDate.getTime() + 2 * 60 * 60 * 1000\n ).toISOString(),\n },\n ],\n performers: [],\n };\n }\n\n async function loadEventData() {\n if (!isMounted) {\n return;\n }\n if (!eventId) {\n error = labels.noEventIdProvided || 'No event ID provided';\n isLoading = false;\n return;\n }\n\n isLoading = true;\n error = null;\n\n try {\n if (initialEventData) {\n // Use server-provided data — skip client-side fetch\n rawEvent = initialEventData;\n if (!isMounted) return;\n event = transformEvent(rawEvent);\n showtimes = filterPublishedShowtimes(rawEvent?.showtimes || []);\n } else {\n try {\n rawEvent = await fetchEventDetails(eventId);\n if (!isMounted) return;\n event = transformEvent(rawEvent);\n showtimes = filterPublishedShowtimes(rawEvent?.showtimes || []);\n } catch (apiErr) {\n logger.error('Event fetch failed:', apiErr);\n error = labels.failedToLoadEvent || 'Failed to load event';\n isLoading = false;\n return;\n }\n }\n\n const effectiveVenueId = event?.venueID || venueId || null;\n if (effectiveVenueId) {\n try {\n const venueData = await getVenueDetails(effectiveVenueId);\n if (!isMounted) return;\n venueServiceCharge = {\n serviceFeeCents: venueData.serviceFeeCents || 0,\n serviceFeePercentage: venueData.serviceFeePercentage || 0,\n serviceFeeChargeType: venueData.serviceFeeChargeType || 'both',\n maxServiceFeeCents: venueData.maxServiceFeeCents || 0,\n taxPercentage: venueData.taxPercentage ?? 0,\n };\n } catch (err) {\n if (!isMounted) return;\n logger.error('Error fetching venue data:', err);\n }\n }\n if (isMounted) {\n dataReady = true;\n\n // Check if password protection is needed after data is ready\n if (event?.password && event.password.trim() !== '') {\n // Check if already authenticated in this session\n if (!isEventAuthenticated(eventId)) {\n showPasswordModal = true;\n } else {\n isPasswordVerified = true;\n }\n }\n }\n } catch (err) {\n if (isMounted) {\n logger.error('Error loading event:', err);\n error =\n err.message || labels.failedToLoadEvent || 'Failed to load event';\n }\n } finally {\n if (isMounted) {\n isLoading = false;\n }\n }\n }\n\n // Handle cancel - go back if password modal is cancelled\n function handlePasswordCancel() {\n showPasswordModal = false;\n goBack();\n }\n\n onMount(async () => {\n isMounted = true;\n updateScreenSize();\n window.addEventListener('resize', updateScreenSize);\n window.addEventListener('scroll', handleScroll);\n\n await loadEventData();\n\n if (stickyRef && isMounted) {\n stickyTop = stickyRef.getBoundingClientRect().top || 0;\n const imageElement = stickyRef.querySelector('img');\n if (imageElement) {\n imageHeight = imageElement.offsetHeight;\n }\n }\n\n return () => {\n window.removeEventListener('resize', updateScreenSize);\n window.removeEventListener('scroll', handleScroll);\n };\n });\n\n onDestroy(() => {\n isMounted = false;\n });\n</script>\n\n<div\n class=\"px-5 sm:px-10 py-12 bg-card\"\n bind:this={containerRef}\n data-org-id={organizationId}\n>\n <!-- Visually hidden h1 for accessibility - event name announced as page title -->\n <h1 class=\"sr-only\">\n {event?.name || labels.eventDetails || 'Event Details'}\n </h1>\n\n {#if isLoading}\n <div\n class=\"flex items-center justify-center py-12\"\n role=\"status\"\n aria-live=\"polite\"\n >\n <p class=\"loading-text\">{labels.loadingEvent || 'Loading event...'}</p>\n </div>\n {:else if error}\n <div class=\"text-center py-8\" role=\"alert\">\n <p class=\"error-text mb-2\">{labels.errorPrefix || 'Error:'} {error}</p>\n <button\n class=\"go-back-btn mt-4 px-4 py-2 rounded-lg\"\n onclick={goBack}\n aria-label={labels.goBackToCalendar || 'Go back to calendar'}\n >\n {labels.goBack || 'Go back'}\n </button>\n </div>\n {:else if event}\n <div class=\"flex flex-col w-full relative\">\n {#if isLocked}\n <!-- Locked overlay when password is required but not verified -->\n <div\n class=\"locked-overlay absolute inset-0 z-20 flex flex-col items-center justify-center bg-card/95 rounded-lg\"\n >\n <div class=\"locked-content text-center p-8\">\n <div class=\"locked-icon-wrapper mx-auto mb-4\">\n <Locked class=\"w-12 h-12 text-muted-foreground\" />\n </div>\n <h2 class=\"locked-title text-xl font-semibold mb-2\">\n {labels.passwordProtectedTitle ||\n 'This event is password protected'}\n </h2>\n <p class=\"locked-description text-sm mb-6\">\n {labels.passwordProtectedDescription ||\n 'Enter the event password to view details and purchase tickets.'}\n </p>\n <button\n class=\"unlock-btn px-6 py-3 rounded-lg font-medium\"\n onclick={() => (showPasswordModal = true)}\n >\n {labels.enterPassword || 'Enter password'}\n </button>\n </div>\n </div>\n {/if}\n\n {#if isCancelled}\n <!-- Cancelled event banner -->\n <div\n class=\"cancelled-banner mb-6 p-4 rounded-lg\"\n role=\"alert\"\n aria-live=\"assertive\"\n >\n <div class=\"flex items-start gap-3\">\n <div\n class=\"cancelled-icon-wrapper shrink-0 mt-0.5\"\n aria-hidden=\"true\"\n >\n <WarningAltFilled size={24} class=\"cancelled-icon\" />\n </div>\n <div class=\"cancelled-content\">\n <h3 class=\"cancelled-title text-base font-semibold mb-1\">\n {labels.eventCancelledTitle || 'This event has been cancelled'}\n </h3>\n <p class=\"cancelled-message text-sm mb-2\">\n {labels.eventCancelledMessage ||\n \"We're sorry, but this event is no longer taking place.\"}\n </p>\n <p class=\"cancelled-refund text-sm\">\n <strong\n >{labels.eventCancelledRefund ||\n 'Refund information:'}</strong\n >\n {labels.eventCancelledRefundDetails ||\n 'If you purchased tickets, a full refund will be processed automatically to your original payment method within 5-10 business days. Check your email for confirmation.'}\n </p>\n </div>\n </div>\n </div>\n {/if}\n\n <div\n class=\"flex-1 flex flex-col lg:flex-row w-full gap-7 relative\"\n class:blur-content={isLocked}\n class:cancelled-content={isCancelled}\n >\n <div class=\"flex-1 relative\" bind:this={stickyRef}>\n <img\n src={event.coverImage\n ? getImageUrl(event.coverImage)\n : 'https://images.unsplash.com/photo-1558618666-fcd25c85cd64?w=1200&h=800&fit=crop'}\n alt={event.name\n ? (labels.eventPoster || 'Event poster') + ' — ' + event.name\n : labels.eventPoster || 'Event poster'}\n class=\"w-full rounded-lg object-contain bg-bg-secondary\"\n />\n <button\n class=\"bg-bg-secondary rounded-full size-8 sm:size-10 flex items-center justify-center absolute top-3 left-3 z-10\"\n onclick={goBack}\n aria-label={labels.goBackToCalendar || 'Go back to calendar'}\n >\n <ArrowLeft\n class=\"size-3.5 sm:size-5 text-white\"\n aria-hidden=\"true\"\n />\n </button>\n </div>\n\n {#if isSticky}\n <!-- Spacer to maintain layout when sidebar becomes fixed -->\n <div class=\"hidden lg:block w-80 shrink-0\" aria-hidden=\"true\"></div>\n {/if}\n\n <StickySidebar\n {event}\n {showtimes}\n {ticketType}\n {availableTickets}\n {isSticky}\n {sidebarLeft}\n {goToCheckout}\n {venueServiceCharge}\n {dataReady}\n {isCancelled}\n {waitlistEnabled}\n onJoinWaitlist={handleJoinWaitlist}\n {labels}\n />\n </div>\n\n <div\n class=\"flex-1 flex flex-col lg:flex-row w-full gap-7\"\n class:blur-content={isLocked}\n class:cancelled-content={isCancelled}\n >\n <div class=\"flex-1\">\n <div class=\"my-3 px-0 sm:my-5 sm:px-4\">\n <Tab items={tabsData} />\n </div>\n\n <div id=\"about\" class=\"my-8\">\n <AboutShow\n ShowImage=\"\"\n description={event.description}\n performers={[]}\n title={labels.tabAboutTheShow || 'About the show'}\n showTitle={true}\n />\n </div>\n\n {#if hasPerformers}\n <section\n id=\"featuring\"\n class=\"my-8\"\n aria-labelledby=\"featuring-title\"\n >\n <h2\n id=\"featuring-title\"\n class=\"section-title font-medium text-2xl mb-4\"\n >\n {labels.tabFeaturing || 'Featuring'}\n </h2>\n <AboutShow\n ShowImage=\"\"\n description=\"\"\n performers={event.performers}\n showTitle={false}\n />\n </section>\n {/if}\n\n {#if venueFAQs.length}\n <section\n id=\"faqs\"\n class=\"my-8\"\n aria-label=\"Frequently asked questions\"\n >\n <FAQs faqs={venueFAQs} />\n </section>\n {/if}\n\n {#if parsedVenueDisclaimer.length}\n <section id=\"disclaimers\" class=\"my-8\" aria-label=\"Disclaimers\">\n <Disclaimer disclaimer={parsedVenueDisclaimer.join(' ')} />\n </section>\n {/if}\n </div>\n\n <!-- svelte-ignore element_invalid_self_closing_tag -->\n <div class=\"w-full sm:w-80 flex flex-col\" />\n </div>\n </div>\n {/if}\n</div>\n\n<!-- Password Protection Modal -->\n<InputModal\n bind:open={showPasswordModal}\n size=\"md\"\n title={labels.enterEventPassword || 'Enter event password'}\n description={labels.passwordModalDescription ||\n 'This event requires a password to view. Please enter the password provided by the event organizer.'}\n inputLabel={labels.passwordLabel || 'Password'}\n inputType=\"password\"\n bind:inputValue={passwordValue}\n inputRequired={true}\n errorMessage={passwordError}\n showError={!!passwordError}\n primaryButtonText={labels.unlockEvent || 'Unlock event'}\n secondaryButtonText={labels.goBack || 'Go back'}\n loading={passwordLoading}\n onconfirm={handlePasswordSubmit}\n oncancel={handlePasswordCancel}\n onclose={handlePasswordCancel}\n/>\n\n<!-- Waitlist Modal -->\n<WaitlistModal\n bind:show={showWaitlistModal}\n {eventId}\n eventName={event?.name || 'this event'}\n onClose={() => (showWaitlistModal = false)}\n {labels}\n/>\n\n<style>\n /* Theme-responsive colors */\n .loading-text {\n color: hsl(var(--text-secondary));\n }\n\n .error-text {\n color: hsl(var(--status-sold-out));\n }\n\n .go-back-btn {\n background-color: hsl(var(--brand-primary));\n color: hsl(var(--bg-primary));\n }\n\n .go-back-btn:hover {\n background-color: hsl(var(--brand-primary) / 90%);\n }\n\n .section-title {\n color: hsl(var(--text-primary));\n }\n\n /* Password protection styles */\n .blur-content {\n filter: blur(8px);\n pointer-events: none;\n user-select: none;\n }\n\n .locked-overlay {\n min-height: 400px;\n background-color: hsl(var(--bg-primary) / 95%);\n }\n\n .locked-title {\n color: hsl(var(--text-primary));\n }\n\n .locked-description {\n color: hsl(var(--text-secondary));\n max-width: 300px;\n margin-left: auto;\n margin-right: auto;\n }\n\n .locked-icon-wrapper {\n width: 80px;\n height: 80px;\n border-radius: 50%;\n background-color: hsl(var(--bg-secondary, var(--bg-primary)));\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .unlock-btn {\n background-color: hsl(var(--brand-primary));\n color: hsl(var(--bg-primary));\n transition: background-color 0.2s ease;\n }\n\n .unlock-btn:hover {\n background-color: hsl(var(--brand-primary) / 90%);\n }\n\n /* Cancelled event styles */\n .cancelled-banner {\n background-color: hsl(var(--accent-danger) / 5%);\n border: 1px solid hsl(var(--accent-danger) / 20%);\n }\n\n :global(.cancelled-icon) {\n color: hsl(var(--accent-danger));\n }\n\n .cancelled-title {\n color: hsl(var(--accent-danger));\n }\n\n .cancelled-message {\n color: hsl(var(--accent-danger));\n }\n\n .cancelled-refund {\n color: hsl(var(--accent-danger));\n line-height: 1.5;\n }\n\n .cancelled-refund strong {\n color: hsl(var(--accent-danger));\n }\n\n .cancelled-content {\n filter: grayscale(60%);\n opacity: 0.85;\n }\n\n .cancelled-content img {\n filter: grayscale(70%);\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["labels","$","$$props","onlyOneFreeTicket","div","root","span","root_1","text","span_1","root_2","formatCurrency","$$render","consequent","alternate","span_2","root_3","consequent_1","$0","$1","dataReady","availableTickets","isMobileDrawer","isCancelled","purchasedTickets","waitlistEnabled","onJoinWaitlist","visibleTickets","t","totalRemainingCapacity","acc","isSoldOut","hasNoTickets","basePrice","div_1","div_2","div_3","div_4","Button","$$anchor","Time","consequent_3","alternate_1","consequent_2","consequent_4","alternate_2","div_5","root_15","div_6","div_7","span_3","PriceTag","PriceTagSkeleton","consequent_6","alternate_3","div_8","node_8","div_9","span_4","consequent_9","alternate_4","node_10","div_10","Locked","span_5","node_11","consequent_7","consequent_8","consequent_10","alternate_5","consequent_5","alternate_6","showtimes","isSticky","sidebarLeft","aside","fragment","ShowCard","node","TicketActions","node_1","node_2","styles","show","eventName","onClose","email","phone","smsOptIn","loading","error","success","position","emailError","isValidEmail","phoneError","isValidPhone","cleaned","handleSubmit","result","joinWaitlist","handleClose","Modal","$$value","CheckmarkFilled","h3","p","p_1","root_5","root_6","h3_1","p_2","form","label","Input","node_5","p_3","root_7","label_1","input","root_8","p_4","root_9","p_5","node_9","root_10","p_6","e","root_11","node_12","node_13","disclaimer","fullText","section","h2","items","activeTab","observer","scrollToSection","tabId","handleTabKeydown","currentIndex","newIndex","newTabId","onMount","entries","entry","item","onDestroy","index","button","classes","logger","createLogger","organizationId","venueId","initialEventData","event","rawEvent","isLoading","venueServiceCharge","isMounted","isMobile","containerRef","stickyRef","stickyTop","imageHeight","showPasswordModal","passwordValue","passwordError","passwordLoading","isPasswordVerified","showWaitlistModal","isEventAuthenticated","evtId","setEventAuthenticated","authedEvents","handlePasswordSubmit","password","checkEventPassword","requiresPassword","isLocked","handleJoinWaitlist","filterPublishedShowtimes","rawShowtimes","showtime","toFaqArray","src","venue","venueFAQs","venueDisclaimer","parsedVenueDisclaimer","s","hasPerformers","tabsData","ticketType","goBack","params","url","goto","goToCheckout","generateSlug","updateScreenSize","ticking","handleScroll","updateStickyState","rect","containerBounding","loadEventData","transformEvent","fetchEventDetails","apiErr","effectiveVenueId","venueData","getVenueDetails","err","handlePasswordCancel","imageElement","h1","text_2","root_4","button_1","WarningAltFilled","strong","div_11","node_3","div_12","img","button_2","ArrowLeft","div_13","StickySidebar","node_7","div_14","div_15","div_16","Tab","div_17","AboutShow","h2_1","section_1","FAQs","section_2","Disclaimer","node_15","classes_1","getImageUrl","InputModal","node_16","WaitlistModal","node_17"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"FeaturedView.legacy-tTPbRxSf.js","sources":["../src/components/Calendar/FeaturedView.legacy.svelte"],"sourcesContent":["<script>\n import { formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n\n let {\n events = [],\n featuredItem = null,\n oneventClick,\n } = $props();\n\n // Filter to today and future, sorted chronologically\n let futureEvents = $derived(filterTodayAndFuture(events));\n\n let heroEvent = $derived(futureEvents.length > 0 ? futureEvents[0] : null);\n\n function handleClick() {\n if (heroEvent) {\n oneventClick?.(heroEvent);\n }\n }\n</script>\n\n<section class=\"w-full\" aria-label=\"Featured event\">\n {#if featuredItem}\n <!-- Series or Collection hero -->\n <div class=\"featured-hero rounded-lg border border-border bg-card overflow-hidden\">\n {#if featuredItem.image}\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\n <img\n src={featuredItem.image}\n alt=\"\"\n class=\"hero-image\"\n aria-hidden=\"true\"\n />\n </div>\n {:else}\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden flex items-center justify-center\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" class=\"w-16 h-16 text-muted-foreground\"><rect x=\"2\" y=\"2\" width=\"20\" height=\"20\" rx=\"2\"/><circle cx=\"8.5\" cy=\"8.5\" r=\"1.5\"/><path d=\"m21 15-5-5L5 21\"/></svg>\n </div>\n {/if}\n\n <div class=\"p-4 sm:p-5\">\n <div class=\"inline-flex items-center gap-1.5 text-xs font-semibold text-brand-primary uppercase tracking-wide mb-2\">\n {#if featuredItem.type === 'series'}\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\n Series\n {:else}\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\n Collection\n {/if}\n {#if featuredItem.subtitle}\n <span class=\"text-muted-foreground\">·</span>\n {featuredItem.subtitle}\n {/if}\n </div>\n\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{featuredItem.title}</h2>\n\n {#if heroEvent}\n <p class=\"text-base text-text-secondary font-medium\">\n Next: {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\n {#if heroEvent.startDateTime}\n at {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\n {/if}\n </p>\n {/if}\n </div>\n </div>\n {:else if heroEvent}\n <!-- Single event hero -->\n <div\n class=\"featured-hero featured-hero-clickable rounded-lg border border-border bg-card overflow-hidden cursor-pointer hover:border-stroke-primary focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\n onclick={handleClick}\n onkeydown={(e) => (e.key === 'Enter' || e.key === ' ') && handleClick()}\n tabindex=\"0\"\n role=\"button\"\n aria-label=\"{heroEvent.name}, {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}. Press Enter to view details.\"\n >\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\n <img\n src={heroEvent.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"hero-image\"\n aria-hidden=\"true\"\n />\n </div>\n\n <div class=\"p-4 sm:p-5\" aria-hidden=\"true\">\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{heroEvent.name}</h2>\n\n <p class=\"text-base text-text-secondary font-medium\">\n {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\n {#if heroEvent.startDateTime}\n <span class=\"text-muted-foreground mx-1\">·</span>\n {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\n {/if}\n </p>\n\n {#if heroEvent.description}\n <p class=\"hero-description text-sm text-text-secondary mt-2\">{heroEvent.description}</p>\n {/if}\n </div>\n </div>\n {:else}\n <!-- Empty state -->\n <div class=\"flex items-center justify-center py-12 rounded-lg border border-border bg-bg-secondary\">\n <p class=\"text-sm text-muted-foreground\">No upcoming events to feature</p>\n </div>\n {/if}\n</section>\n\n<style>\n .hero-image-container {\n aspect-ratio: 16 / 9;\n }\n\n .hero-image {\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .hero-title {\n line-height: 1.3;\n }\n\n .featured-hero-clickable {\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\n }\n\n .featured-hero-clickable:hover {\n box-shadow: 0 4px 12px color-mix(in srgb, black 10%, transparent);\n }\n\n .featured-hero-clickable:focus {\n outline: none;\n }\n\n .hero-description {\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .featured-hero-clickable {\n transition: none;\n }\n }\n</style>\n"],"names":["events","$","$$props","featuredItem","futureEvents","filterTodayAndFuture","heroEvent","handleClick","section","root","div","root_1","div_1","root_2","img","div_2","root_3","$$render","consequent","alternate","div_3","node_1","div_4","consequent_1","alternate_1","text","consequent_2","h2","p","root_7","formatEventTime","consequent_3","formatFullDate","consequent_4","text_1","div_5","root_9","div_6","img_1","div_7","h2_1","p_1","consequent_6","p_2","root_11","text_7","consequent_7","$0","PLACEHOLDER_IMAGE","text_4","e","div_8","root_12","consequent_8","alternate_2"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GalleryCard-CBMPmdrM.js","sources":["../src/components/Calendar/GalleryCard.svelte"],"sourcesContent":["<script>\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\n import { formatBrowseDate, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { getBrowseStatus, isEventUnavailable } from \"$lib/utils/browse-status.js\";\n import { buildEventHref } from \"$lib/url-manager/params\";\n\n let { event, oneventClick, labels = {} } = $props();\n\n let browseStatus = $derived(getBrowseStatus(event));\n let isUnavailable = $derived(isEventUnavailable(browseStatus));\n\n // Build comprehensive aria-label for event card\n function getEventAriaLabel(event) {\n const parts = [event.name];\n if (event.startDateTime) {\n parts.push(`on ${formatFullDate(event.startDateTime, event.timeZone)}`);\n }\n if (event.startDateTime) {\n parts.push(`at ${formatEventTime(event.startDateTime, event.timeZone)}`);\n }\n if (browseStatus) {\n parts.push(browseStatus.text);\n } else if (event.status && event.status !== (labels.statusOnSale || 'On Sale')) {\n parts.push(event.status);\n }\n parts.push(labels.pressEnterToView || 'Press Enter to view details');\n return parts.join(', ');\n }\n</script>\n\n<a\n href={buildEventHref(event)}\n class=\"gallery-card\"\n class:card-unavailable={isUnavailable}\n onclick={(e) => { e.preventDefault(); oneventClick?.(event); }}\n aria-label={getEventAriaLabel(event)}\n>\n <!-- Fixed height image container -->\n <div class=\"card-image-container\">\n <img\n src={event.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"card-image\"\n loading=\"lazy\"\n aria-hidden=\"true\"\n />\n <!-- Status Badge overlay -->\n {#if browseStatus}\n <div class=\"badge-overlay\" aria-hidden=\"true\">\n <span class=\"status-badge status-{browseStatus.type}\">{browseStatus.text}</span>\n </div>\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\n <div class=\"badge-overlay\" aria-hidden=\"true\">\n <ScarcityBadge\n remaining={event.ticketsRemaining ?? 0}\n total={event.ticketsTotal ?? 0}\n context=\"browse\"\n {labels}\n />\n </div>\n {/if}\n </div>\n\n <!-- Event Details -->\n <div class=\"card-content\" aria-hidden=\"true\">\n <h3 class=\"card-title\">{event.name}</h3>\n <div class=\"card-meta\">\n {#if event.startDateTime}\n <time datetime={event.startDateTime}>\n {formatBrowseDate(event.startDateTime, event.timeZone)}\n </time>\n {/if}\n {#if event.startDateTime}\n <span class=\"meta-separator\" aria-hidden=\"true\">•</span>\n <span>{formatEventTime(event.startDateTime, event.timeZone)}</span>\n {/if}\n </div>\n </div>\n</a>\n\n<style>\n @reference \"../../app.css\";\n\n .gallery-card {\n @apply rounded-lg border bg-card border-border;\n @apply overflow-hidden cursor-pointer block;\n\n text-decoration: none;\n color: inherit;\n transition: transform var(--motion-fast) var(--ease-out), box-shadow var(--motion-fast) var(--ease-out), border-color var(--motion-fast) var(--ease-out);\n }\n\n .gallery-card:hover {\n @apply border-stroke-primary;\n\n transform: translateY(-2px);\n box-shadow: 0 4px 12px color-mix(in srgb, black 10%, transparent);\n }\n\n .gallery-card:focus {\n @apply outline-none;\n }\n\n .gallery-card:focus-visible {\n @apply outline-2 outline-focus-ring outline-offset-2;\n }\n\n .gallery-card:active {\n transform: translateY(0);\n }\n\n /* Fixed height image container */\n .card-image-container {\n @apply relative w-full bg-muted overflow-hidden;\n\n height: 200px;\n }\n\n @media (width <= 639px) {\n .card-image-container {\n height: 220px;\n }\n }\n\n @media (width >= 1024px) {\n .card-image-container {\n height: 180px;\n }\n }\n\n .card-image {\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .badge-overlay {\n position: absolute;\n top: 8px;\n left: 8px;\n }\n\n .card-content {\n @apply p-3;\n }\n\n @media (width >= 640px) {\n .card-content {\n @apply p-3.5;\n }\n }\n\n .card-title {\n @apply text-base font-semibold text-text-primary mb-1.5;\n\n line-height: 1.3;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n @media (width <= 639px) {\n .card-title {\n @apply text-lg;\n }\n }\n\n .card-meta {\n @apply text-sm text-text-secondary font-medium;\n }\n\n @media (width <= 639px) {\n .card-meta {\n @apply text-base;\n }\n }\n\n .meta-separator {\n @apply text-muted-foreground mx-1;\n }\n\n /* Unavailable event dimming */\n .card-unavailable {\n @apply opacity-60;\n }\n\n .card-unavailable .card-image {\n filter: grayscale(0.5);\n }\n\n /* Status badges — distinct visual treatments for each status */\n .status-badge {\n @apply inline-flex items-center text-xs font-bold px-2.5 py-1 rounded;\n\n box-shadow: 0 2px 6px color-mix(in srgb, black 25%, transparent);\n letter-spacing: 0.02em;\n }\n\n .status-cancelled {\n @apply text-white bg-gradient-to-br from-rose-900 to-red-700;\n\n text-decoration: line-through;\n text-decoration-thickness: 1.5px;\n }\n\n .status-past {\n @apply text-muted-foreground bg-overlay-bg;\n\n backdrop-filter: blur(4px);\n }\n\n .status-sold_out {\n @apply text-white uppercase tracking-wider bg-gradient-to-br from-red-600 to-red-400;\n\n font-size: 0.65rem;\n }\n\n .status-sales_ended {\n @apply text-muted-foreground bg-bg-secondary/90 border border-stroke-primary/30;\n\n backdrop-filter: blur(4px);\n }\n\n .status-coming_soon {\n @apply text-white bg-gradient-to-br from-blue-600 to-indigo-500;\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .gallery-card {\n transition: none;\n }\n\n .gallery-card:hover {\n transform: none;\n }\n }\n</style>\n"],"names":["labels","$","$$props","browseStatus","getBrowseStatus","isUnavailable","isEventUnavailable","getEventAriaLabel","event","parts","formatFullDate","formatEventTime","a","root","div","img","div_1","root_1","span","text","div_2","root_2","$0","$1","ScarcityBadge","node_1","$$render","consequent_1","div_3","h3","div_4","time","root_3","formatBrowseDate","consequent_2","span_1","fragment","consequent_3","classes","PLACEHOLDER_IMAGE","buildEventHref","e","$$anchor"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GalleryView.legacy-4QPpX22O.js","sources":["../src/components/Calendar/GalleryView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount, onDestroy } from \"svelte\";\n import GalleryCard from \"./GalleryCard.svelte\";\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n\n let { events = [], initialCount = 12, loadMoreCount = 12, oneventClick } = $props();\n\n let displayedCount = initialCount;\n let loadMoreTrigger;\n let observer;\n\n // Filter to today and future, sorted chronologically\n let futureEvents = $derived(filterTodayAndFuture(events));\n let displayedEvents = $derived(futureEvents.slice(0, displayedCount));\n let hasMore = $derived(displayedCount < futureEvents.length);\n\n function loadMore() {\n displayedCount += loadMoreCount;\n }\n\n onMount(() => {\n observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting && hasMore) {\n loadMore();\n }\n },\n { rootMargin: '100px' }\n );\n\n if (loadMoreTrigger) {\n observer.observe(loadMoreTrigger);\n }\n });\n\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n }\n });\n\n // Re-observe when trigger element changes\n $effect(() => {\n if (observer && loadMoreTrigger) {\n observer.disconnect();\n observer.observe(loadMoreTrigger);\n }\n });\n</script>\n\n<section class=\"w-full\" aria-label=\"Events gallery\">\n <h2 class=\"sr-only\">Upcoming events</h2>\n <ul class=\"grid grid-cols-1 gap-4 bg-bg-secondary p-2 sm:grid-cols-2 sm:gap-4 sm:p-3 md:grid-cols-3 md:gap-5 md:p-4 lg:grid-cols-4 lg:gap-6 lg:p-5\" role=\"list\">\n {#each displayedEvents as event}\n <li class=\"list-none\">\n <GalleryCard {event} {oneventClick} />\n </li>\n {/each}\n </ul>\n\n <!-- Infinite scroll trigger -->\n {#if hasMore}\n <div bind:this={loadMoreTrigger} class=\"flex items-center justify-center gap-2 py-2 p-6\" role=\"status\" aria-live=\"polite\">\n <span class=\"text-sm text-muted-foreground\">Loading more events...</span>\n </div>\n {/if}\n</section>\n\n<style>\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","displayedCount","loadMoreTrigger","observer","futureEvents","filterTodayAndFuture","displayedEvents","hasMore","loadMore","onMount","entries","onDestroy","section","root","ul","$$anchor","event","li","root_1","GalleryCard","node","div","root_2","$$value","$$render","consequent"],"mappings":";;;;;;iBAAA;;MAKQA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GAAOC,iCAAe,EAAE,GAAEC,kCAAgB,EAAE,GAEpDC,IAAiBF,EAAY,GAC7BG,GACAC,GAGAC,IAAYP,EAAA,QAAA,MAAYQ,EAAqBT,EAAM,CAAA,CAAA,GACnDU,0BAA2BF,CAAY,EAAC,MAAM,GAAGH,CAAc,CAAA,GAC/DM,IAAOV,EAAA,QAAA,MAAYI,IAAcJ,EAAA,IAAGO,CAAY,EAAC,MAAM;AAElD,WAAAI,IAAW;AAClB,IAAAP,KAAkBD,EAAa;AAAA,EACjC;AAEA,EAAAS,EAAO,MAAO;AACZ,IAAAN,QAAe;AAAA,MACZ,CAAAO,MAAY;AACP,QAAAA,EAAQ,CAAC,EAAE,kBAAcb,EAAA,IAAIU,CAAO,KACtCC,EAAQ;AAAA,MAEZ;AAAA,MACE,EAAA,YAAY,QAAO;AAAA,OAGnBN,KACFC,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC,GAEDS,EAAS,MAAO;AACV,IAAAR,KACFA,EAAS,WAAU;AAAA,EAEvB,CAAC,GAGDN,EAAA,YAAO,MAAO;IACRM,KAAYD,MACdC,EAAS,WAAU,GACnBA,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC;MAGFU,IAAOC,EAAA,GAELC,sBAFFF,CAAO,GAAA,CAAA;SAELE,GAAE,IAAA,MAAAjB,EAAA,IACMS,CAAe,GAAAT,EAAA,OAAA,CAAAkB,GAAIC,MAAK;QAC5BC,IAAEC,EAAA,eAAFD,CAAE;AACA,IAAAE,EAAWC,GAAA;AAAA;qBAAEJ,CAAK;AAAA;;;;gBADpBC,CAAE,eAAFA,CAAE;AAAA,cAFNH,CAAE;oBAAFA,GAAE,CAAA;;;UAUAO,IAAGC,EAAA;kBAAHD,GAAG,CAAAE,MAAYrB,IAAeqB,GAAA,MAAfrB,CAAe,eAA9BmB,CAAG;AAAA;;YADDd,CAAO,KAAAiB,EAAAC,CAAA;AAAA;;UAXbb,CAAO,eAAPA,CAAO;AAFA;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"GroupedListView.legacy-CPJRLePS.js","sources":["../src/components/Calendar/GroupedListView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount, onDestroy } from \"svelte\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { getDateParts, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { getBrowseStatus, isEventUnavailable, filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\n\n let {\n events = [],\n initialCount = 10,\n loadMoreCount = 10,\n showDateColumn = true,\n filterFutureOnly = true,\n oneventClick\n } = $props();\n\n let displayedCount = initialCount;\n let loadMoreTrigger;\n let observer;\n\n // Filter to today and future (if enabled), then group by date\n let filteredEvents = $derived(filterFutureOnly ? filterTodayAndFuture(events) : events);\n let groupedEvents = $derived(groupEventsByDate(filteredEvents.slice(0, displayedCount)));\n let hasMore = $derived(displayedCount < filteredEvents.length);\n\n function loadMore() {\n displayedCount += loadMoreCount;\n }\n\n onMount(() => {\n observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting && hasMore) {\n loadMore();\n }\n },\n { rootMargin: '100px' }\n );\n\n if (loadMoreTrigger) {\n observer.observe(loadMoreTrigger);\n }\n });\n\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n }\n });\n\n // Re-observe when trigger element changes\n $effect(() => {\n if (observer && loadMoreTrigger) {\n observer.disconnect();\n observer.observe(loadMoreTrigger);\n }\n });\n\n function groupEventsByDate(eventList) {\n const groups = {};\n\n for (const event of eventList) {\n const dateKey = event.date; // YYYY-MM-DD format\n if (!groups[dateKey]) {\n groups[dateKey] = [];\n }\n groups[dateKey].push(event);\n }\n\n // Convert to array sorted by date\n return Object.entries(groups)\n .sort(([a], [b]) => new Date(a) - new Date(b))\n .map(([date, events]) => ({\n date,\n events,\n formattedDate: formatGroupDate(events),\n }));\n }\n\n function formatGroupDate(events) {\n // Use the first event in the group to get timezone-aware date parts\n const firstEvent = events[0];\n if (!firstEvent?.startDateTime) return { month: '', day: '', weekday: '' };\n const parts = getDateParts(firstEvent.startDateTime, firstEvent.timeZone);\n return {\n month: parts.month.toUpperCase(),\n day: String(parts.date).padStart(2, '0'),\n weekday: parts.day.toUpperCase(),\n };\n }\n\n function handleEventClick(event) {\n oneventClick?.(event);\n }\n\n function handleKeydown(e, event) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleEventClick(event);\n }\n }\n</script>\n\n<section class=\"flex flex-col gap-0\" class:no-date-column={!showDateColumn} aria-label=\"Event listings\">\n <h2 class=\"sr-only\">Event list grouped by date</h2>\n {#each groupedEvents as group}\n <div class=\"date-group flex border-b border-border last:border-b-0\" role=\"group\" aria-label=\"Events on {group.events[0]?.startDateTime ? formatFullDate(group.events[0].startDateTime, group.events[0].timeZone) : group.date}\">\n <!-- Date Column -->\n {#if showDateColumn}\n <div class=\"w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-bg-secondary border-r border-border max-sm:w-12 max-sm:min-w-12 max-sm:py-2.5 max-sm:px-1.5\" aria-hidden=\"true\">\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.month}</span>\n <span class=\"text-2xl max-sm:text-lg font-bold text-text-primary leading-tight\">{group.formattedDate.day}</span>\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.weekday}</span>\n </div>\n {/if}\n\n <!-- Events Column -->\n <ul class=\"events-column flex-1 flex flex-col list-none p-0 m-0\">\n {#each group.events as event, eventIndex}\n {@const eventStatus = getBrowseStatus(event)}\n {@const isUnavailable = isEventUnavailable(eventStatus)}\n <li class=\"list-none\">\n <div\n class=\"event-row flex gap-4 max-sm:gap-2.5 p-5 max-sm:p-3 cursor-pointer transition-colors duration-150 bg-card border-b border-border/50 last:border-b-0 hover:bg-bg-secondary focus:outline-2 focus:outline-brand-primary focus:-outline-offset-2 focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:-outline-offset-2\"\n class:row-unavailable={isUnavailable}\n onclick={() => handleEventClick(event)}\n onkeydown={(e) => handleKeydown(e, event)}\n tabindex=\"0\"\n role=\"button\"\n aria-label={`${event.name} on ${event.startDateTime ? formatFullDate(event.startDateTime, event.timeZone) : group.date} at ${event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}, ${eventStatus?.text || event.status || 'On Sale'}. Press Enter to view details.`}\n >\n <!-- Event Image -->\n <div class=\"w-36 h-24 min-w-36 max-sm:w-20 max-sm:h-16 max-sm:min-w-20 rounded-lg overflow-hidden bg-bg-secondary flex items-center justify-center\" aria-hidden=\"true\">\n <img\n src={event.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"w-full h-full object-contain\"\n loading=\"lazy\"\n />\n </div>\n\n <!-- Event Details (visually shown but also in aria-label, so hide from SR) -->\n <div class=\"flex-1 flex flex-col gap-1.5 min-w-0\" aria-hidden=\"true\">\n <h3 class=\"text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug\">{event.name}</h3>\n <time class=\"text-sm max-sm:text-xs font-medium text-text-secondary\" datetime={event.startDateTime || group.date}>{event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}</time>\n {#if event.description}\n <p class=\"event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden\">{event.description}</p>\n {/if}\n </div>\n\n <!-- Status / Scarcity Badge -->\n <div class=\"flex items-start pt-0.5\" aria-hidden=\"true\">\n {#if eventStatus}\n <span class=\"status-badge status-{eventStatus.type}\">{eventStatus.text}</span>\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\n <ScarcityBadge\n remaining={event.ticketsRemaining ?? 0}\n total={event.ticketsTotal ?? 0}\n context=\"browse\"\n />\n {/if}\n </div>\n </div>\n </li>\n {/each}\n </ul>\n </div>\n {/each}\n\n <!-- Infinite scroll trigger -->\n {#if hasMore}\n <div bind:this={loadMoreTrigger} class=\"flex justify-center items-center p-6 text-text-secondary\" role=\"status\" aria-live=\"polite\">\n <span class=\"text-sm\">Loading more events...</span>\n </div>\n {/if}\n</section>\n\n<style>\n /* When no date column, remove left border styling */\n .no-date-column .date-group {\n border-bottom: 0;\n }\n\n .no-date-column .events-column {\n border-left: 0;\n }\n\n .event-description {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n /* Unavailable row dimming */\n .row-unavailable {\n opacity: 0.6;\n }\n\n .row-unavailable img {\n filter: grayscale(0.5);\n }\n\n /* Status badges -- distinct visual treatments matching gallery cards */\n .status-badge {\n display: inline-flex;\n align-items: center;\n font-size: 0.75rem;\n line-height: 1rem;\n font-weight: 700;\n padding: 0.25rem 0.625rem;\n border-radius: 0.25rem;\n white-space: nowrap;\n letter-spacing: 0.02em;\n }\n\n .status-cancelled {\n background-color: hsl(var(--accent-danger) / 10%);\n color: hsl(var(--accent-danger));\n text-decoration: line-through;\n text-decoration-thickness: 1.5px;\n\n \n }\n\n .status-past {\n background-color: hsl(var(--bg-tertiary));\n color: hsl(var(--text-tertiary));\n\n \n }\n\n .status-sold_out {\n background-color: hsl(var(--accent-danger) / 10%);\n color: hsl(var(--accent-danger));\n text-transform: uppercase;\n letter-spacing: 0.05em;\n font-size: 0.65rem;\n\n \n }\n\n .status-sales_ended {\n background-color: hsl(var(--bg-tertiary));\n color: hsl(var(--text-tertiary));\n border: 1px solid hsl(var(--stroke-primary));\n\n \n }\n\n .status-coming_soon {\n background-color: hsl(var(--brand-primary) / 15%);\n color: hsl(var(--brand-primary));\n\n \n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .event-row {\n transition: none;\n }\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root","node","group","div","root_1","div_1","root_2","span","span_1","span_2","$$render","consequent","ul","node_1","eventStatus","getBrowseStatus","isUnavailable","isEventUnavailable","li","root_3","div_2","div_3","img","div_4","h3","time","p","root_4","text_5","consequent_1","div_5","span_3","root_5","text_6","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_3","formatFullDate","formatEventTime","div_6","root_7","$$value","consequent_4","classes"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SeriesPage-IZWQ53xg.js","sources":["../src/components/Views/SeriesPage.svelte"],"sourcesContent":["<script lang=\"ts\">\n\timport { goto } from '$app/navigation';\n\timport { createLogger } from '@getmicdrop/svelte-components';\n\timport AirbnbSplitMain from '$lib/premium-ticket-experience/variants/v3-airbnb-split/AirbnbSplitMain.svelte';\n\timport { transformSeriesPageData } from '$lib/premium-ticket-experience/transform';\n\n\tconst logger = createLogger('SeriesPage');\n\n\t// --- Legacy fallback ---\n\t// RETIREMENT: 2026-08-13 — see docs/LEGACY_RETIREMENT.md.\n\tlet useLegacy = $state(false);\n\tlet LegacyComponent: any = $state(null);\n\n\tif (typeof window !== 'undefined') {\n\t\tconst params = new URLSearchParams(window.location.search);\n\t\tif (params.get('legacy') === '1') {\n\t\t\tuseLegacy = true;\n\t\t}\n\t}\n\n\t$effect(() => {\n\t\tif (useLegacy && !LegacyComponent) {\n\t\t\tlogger.warn(\n\t\t\t\t'[VC] DEPRECATED: ?legacy=1 fallback for SeriesPage retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md.'\n\t\t\t);\n\t\t\timport('./SeriesPage.legacy.svelte').then((m) => {\n\t\t\t\tLegacyComponent = m.default;\n\t\t\t}).catch(() => {\n\t\t\t\tuseLegacy = false;\n\t\t\t});\n\t\t}\n\t});\n\n\t// --- Props (matches old SeriesPage external interface) ---\n\tinterface Props {\n\t\tseries: any;\n\t\tonNavigateToOccurrence?: (id: number, slug: string, name?: string) => void;\n\t}\n\n\tlet {\n\t\tseries,\n\t\tonNavigateToOccurrence = undefined,\n\t}: Props = $props();\n\n\t// Transform series data to EventData for AirbnbSplitMain\n\tlet eventData = $derived(series ? transformSeriesPageData(series) : null);\n\n\t// Handle occurrence click — delegate to callback or navigate directly\n\tfunction handleShowtimeClick(occurrence: { id: number; slug: string }): void {\n\t\tif (onNavigateToOccurrence) {\n\t\t\tonNavigateToOccurrence(occurrence.id, occurrence.slug);\n\t\t} else {\n\t\t\tgoto(`/${occurrence.id}/${occurrence.slug}`);\n\t\t}\n\t}\n</script>\n\n{#if useLegacy && LegacyComponent}\n\t<svelte:component this={LegacyComponent}\n\t\t{series}\n\t\t{onNavigateToOccurrence}\n\t/>\n{:else if eventData}\n\t<AirbnbSplitMain\n\t\tevent={eventData}\n\t\tonShowtimeClick={handleShowtimeClick}\n\t/>\n{/if}\n\n"],"names":["logger","createLogger","useLegacy","$","LegacyComponent","m","onNavigateToOccurrence","eventData","$$props","transformSeriesPageData","handleShowtimeClick","occurrence","goto","$$anchor","$$component","AirbnbSplitMain","$$render","consequent","consequent_1"],"mappings":";;;;;;;;;iBAAA;;QAMOA,IAASC,EAAa,YAAY;MAIpCC,IAAYC,EAAA,MAAO,EAAK,GACxBC,IAAuBD,EAAA,MAAO,IAAI;SAE3B,SAAW,WACF,gBAAgB,OAAO,SAAS,MAAM,EAC9C,IAAI,QAAQ,MAAM,OAC5BA,EAAA,IAAAD,GAAY,EAAI,GAIlBC,EAAA,YAAO,MAAO;UACTD,CAAS,KAAA,CAAAC,EAAA,IAAKC,CAAe,MAChCJ,EAAO,KACN,0GAAyG,GAEnG,OAAA,iCAA4B,EAAE,KAAI,CAAEK,MAAM;YAChDD,GAAkBC,EAAE,SAAO,EAAA;AAAA,IAC5B,CAAC,EAAE,MAAK,MAAO;AACd,MAAAF,EAAA,IAAAD,GAAY,EAAK;AAAA,IAClB,CAAC;AAAA,EAEH,CAAC;AAUA,MAAAI,2CAAyB,MAAS,GAI/BC,IAASJ,EAAA,QAAA,MAAAK,EAAA,SAAqBC,EAAuBD,EAAA,MAAA,IAAW,IAAI;WAG/DE,EAAoBC,GAAgD;AACxE,IAAAL,EAAsB,IACzBA,EAAsB,EAACK,EAAW,IAAIA,EAAW,IAAI,IAErDC,MAASD,EAAW,EAAE,IAAIA,EAAW,IAAI,EAAA;AAAA,EAE3C;;;;;iCAIwBP,CAAe,GAAA,CAAAS,GAAAC,MAAA;;;;;;mBAErCR,EAAsB;AAAA;;;;AAGvB,MAAAS,EAAcF,GAAA;AAAA;uBACPN,CAAS;AAAA;yBACCG;AAAA;;;YARdR,CAAS,KAAAC,EAAA,IAAIC,CAAe,IAAAY,EAAAC,CAAA,IAAAd,EAAA,IAKvBI,CAAS,KAAAS,EAAAE,GAAA,CAAA;AAAA;;;AAPX;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SeriesPage.legacy-4jSF2g-n.js","sources":["../src/components/Views/SeriesPage.legacy.svelte"],"sourcesContent":["<script>\n import { getImageUrl } from '$lib/utils/utils.js';\n import { formatDate as scFormatDate,\n formatTime as scFormatTime, getDefaultTimezone, formatFullName } from '@getmicdrop/svelte-components';\n import { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\n\n let { series, onNavigateToOccurrence } = $props();\n\n let imageLoaded = $state(false);\n\n let seriesImage = $derived(\n series?.image ? getImageUrl(series.image) : PLACEHOLDER_IMAGE\n );\n\n let tz = $derived(series?.timeZone || getDefaultTimezone());\n\n function formatDate(iso) {\n return scFormatDate(iso, { timeZone: tz });\n }\n\n function formatTime(iso) {\n return scFormatTime(iso, { timeZone: tz });\n }\n\n function handleOccurrenceClick(occurrence) {\n if (!occurrence.ctaState?.disabled && onNavigateToOccurrence) {\n onNavigateToOccurrence(\n occurrence.id,\n occurrence.slug || '',\n occurrence.name || ''\n );\n }\n }\n</script>\n\n{#if series}\n <div class=\"series-page\">\n <!-- Hero Image -->\n <div class=\"hero\">\n <div class=\"hero-skeleton\" class:hidden={imageLoaded}></div>\n <img\n src={seriesImage}\n alt={series.title}\n class=\"hero-image\"\n onload={() => (imageLoaded = true)}\n />\n <div class=\"hero-overlay\">\n <div class=\"hero-content\">\n <span class=\"series-badge\">Recurring Event</span>\n <h1 class=\"series-title\">{series.title}</h1>\n <div class=\"series-venue\">\n <span>{series.venue?.name}</span>\n {#if series.venue?.googleLocationNameCache}\n <span class=\"venue-separator\">&#183;</span>\n <span class=\"venue-location\"\n >{series.venue.googleLocationNameCache}</span\n >\n {/if}\n </div>\n </div>\n </div>\n </div>\n\n <!-- Content Grid -->\n <div class=\"content-grid\">\n <!-- Main Column -->\n <div class=\"main-column\">\n <!-- About Section -->\n <section class=\"section\">\n <h2 class=\"section-heading\">About this Series</h2>\n {#if series.eventSummary}\n <p class=\"series-summary\">{series.eventSummary}</p>\n {/if}\n {#if series.description}\n <div class=\"series-description\">{series.description}</div>\n {/if}\n </section>\n\n <!-- Upcoming Dates -->\n <section class=\"section\">\n <div class=\"dates-header\">\n <h2 class=\"section-heading\">Upcoming Dates</h2>\n <span class=\"dates-count\"\n >{series.occurrences?.length || 0} events</span\n >\n </div>\n\n {#if !series.occurrences?.length}\n <div class=\"empty-dates\">\n <p class=\"empty-text\">\n No upcoming dates scheduled at this time.\n </p>\n <p class=\"empty-subtext\">\n Check back soon for new announcements.\n </p>\n </div>\n {:else}\n <div class=\"dates-list\">\n {#each series.occurrences as occurrence}\n <div class=\"occurrence-card\">\n <div class=\"occurrence-info\">\n <div class=\"occurrence-date\">\n {formatDate(occurrence.startDateTime)}\n </div>\n <div class=\"occurrence-time\">\n {formatTime(occurrence.startDateTime)} - {formatTime(\n occurrence.endDateTime\n )}\n </div>\n </div>\n <div class=\"occurrence-action\">\n <button\n class=\"cta-button\"\n class:cta-disabled={occurrence.ctaState?.disabled}\n disabled={occurrence.ctaState?.disabled}\n onclick={() => handleOccurrenceClick(occurrence)}\n >\n {occurrence.ctaState?.text || 'Get tickets'}\n </button>\n </div>\n </div>\n {/each}\n </div>\n {/if}\n </section>\n\n <!-- Performers -->\n {#if series.performers?.length}\n <section class=\"section\">\n <h2 class=\"section-heading\">Performers</h2>\n <div class=\"performers-grid\">\n {#each series.performers as performer}\n <div class=\"performer-card\">\n <div class=\"performer-avatar\">\n {#if performer.profileImage}\n <img\n src={getImageUrl(performer.profileImage)}\n alt={performer.displayName ||\n formatFullName(performer.firstName, performer.lastName)}\n class=\"performer-image\"\n />\n {:else}\n <div class=\"performer-placeholder\">\n <svg\n class=\"placeholder-icon\"\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z\"\n />\n </svg>\n </div>\n {/if}\n </div>\n <h3 class=\"performer-name\">\n {performer.displayName ||\n formatFullName(performer.firstName, performer.lastName)}\n </h3>\n </div>\n {/each}\n </div>\n </section>\n {/if}\n </div>\n\n <!-- Sidebar -->\n <div class=\"sidebar\">\n <div class=\"sidebar-sticky\">\n {#if series.venue?.faq || series.venue?.disclaimer}\n <div class=\"sidebar-card\">\n {#if series.venue.faq}\n <div class=\"sidebar-section\">\n <h3 class=\"sidebar-heading\">FAQ</h3>\n <div class=\"faq-content\">\n {#if Array.isArray(series.venue.faq)}\n {#each series.venue.faq as item}\n <div class=\"faq-item\">\n <p class=\"faq-question\">{item.question}</p>\n <p class=\"faq-answer\">{item.answer}</p>\n </div>\n {/each}\n {:else}\n <p>{series.venue.faq}</p>\n {/if}\n </div>\n </div>\n {/if}\n\n {#if series.venue.disclaimer}\n <div class=\"sidebar-section\">\n <h3 class=\"sidebar-heading\">Important Info</h3>\n <div class=\"disclaimer-text\">{series.venue.disclaimer}</div>\n </div>\n {/if}\n </div>\n {/if}\n </div>\n </div>\n </div>\n </div>\n{/if}\n\n<style>\n .series-page {\n min-height: 100vh;\n padding-bottom: 5rem;\n background: hsl(var(--surface-primary, 0 0% 100%));\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n /* Hero */\n .hero {\n position: relative;\n width: 100%;\n overflow: hidden;\n height: 500px;\n }\n\n @media (width <= 768px) {\n .hero {\n height: 256px;\n }\n }\n\n .hero-skeleton {\n position: absolute;\n inset: 0;\n animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n }\n\n @keyframes pulse {\n 0%,\n 100% {\n opacity: 1;\n }\n\n 50% {\n opacity: 0.5;\n }\n }\n\n .hero-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n transition: transform 0.7s ease;\n }\n\n .hero:hover .hero-image {\n transform: scale(1.05);\n }\n\n .hero-overlay {\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n padding: 1.5rem;\n background: linear-gradient(\n to top,\n color-mix(in srgb, black 90%, transparent),\n color-mix(in srgb, black 50%, transparent),\n transparent\n );\n }\n\n @media (width >= 768px) {\n .hero-overlay {\n padding: 3rem;\n }\n }\n\n .hero-content {\n max-width: 64rem;\n margin-left: auto;\n margin-right: auto;\n width: 100%;\n }\n\n .series-badge {\n display: inline-flex;\n align-items: center;\n padding: 0.25rem 0.75rem;\n margin-bottom: 1rem;\n font-size: 0.75rem;\n line-height: 1rem;\n font-weight: 700;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n border-radius: 9999px;\n box-shadow:\n 0 10px 15px -3px rgb(0 0 0 / 10%),\n 0 4px 6px -4px rgb(0 0 0 / 10%);\n background: hsl(var(--brand-primary, 224 76% 48%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n .series-title {\n font-size: 2.25rem;\n line-height: 1.1;\n font-weight: 700;\n margin-bottom: 0.75rem;\n letter-spacing: -0.025em;\n color: hsl(var(--bg-primary));\n text-shadow: 0 2px 8px color-mix(in srgb, black 30%, transparent);\n }\n\n @media (width >= 768px) {\n .series-title {\n font-size: 3.75rem;\n line-height: 1;\n }\n }\n\n .series-venue {\n font-size: 1.125rem;\n line-height: 1.75rem;\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: 0.5rem;\n font-weight: 500;\n color: color-mix(in srgb, white 90%, transparent);\n }\n\n @media (width >= 768px) {\n .series-venue {\n font-size: 1.25rem;\n line-height: 1.75rem;\n }\n }\n\n .venue-separator {\n display: none;\n opacity: 0.6;\n }\n\n @media (width >= 768px) {\n .venue-separator {\n display: inline;\n }\n }\n\n .venue-location {\n opacity: 0.75;\n }\n\n /* Content Grid */\n .content-grid {\n max-width: 64rem;\n margin-left: auto;\n margin-right: auto;\n padding: 3rem 1.5rem;\n display: grid;\n grid-template-columns: 1fr;\n gap: 3rem;\n }\n\n @media (width >= 768px) {\n .content-grid {\n padding-top: 5rem;\n padding-bottom: 5rem;\n }\n }\n\n @media (width >= 1024px) {\n .content-grid {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n .main-column {\n display: flex;\n flex-direction: column;\n gap: 4rem;\n }\n\n @media (width >= 1024px) {\n .main-column {\n grid-column: span 2 / span 2;\n }\n }\n\n .section {\n display: flex;\n flex-direction: column;\n gap: 1.5rem;\n }\n\n .section-heading {\n font-size: 1.875rem;\n line-height: 2.25rem;\n font-weight: 700;\n letter-spacing: -0.025em;\n padding-bottom: 1rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n border-bottom: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n .series-summary {\n font-size: 1.25rem;\n font-weight: 500;\n line-height: 1.625;\n color: hsl(var(--text-primary, 0 0% 20%));\n }\n\n .series-description {\n max-width: none;\n white-space: pre-line;\n line-height: 1.625;\n color: hsl(var(--text-secondary, 0 0% 40%));\n }\n\n /* Upcoming Dates */\n .dates-header {\n display: flex;\n align-items: baseline;\n justify-content: space-between;\n padding-bottom: 1rem;\n border-bottom: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n .dates-count {\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .empty-dates {\n padding: 3rem;\n border-radius: 1rem;\n text-align: center;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n border: 2px dashed hsl(var(--stroke-secondary, 0 0% 85%));\n }\n\n .empty-text {\n font-size: 1.125rem;\n line-height: 1.75rem;\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .empty-subtext {\n margin-top: 0.5rem;\n color: hsl(var(--text-secondary, 0 0% 55%));\n }\n\n .dates-list {\n display: flex;\n flex-direction: column;\n gap: 1rem;\n }\n\n .occurrence-card {\n position: relative;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n padding: 1.5rem;\n border-radius: 1rem;\n transition: all 0.2s;\n background: hsl(var(--surface-primary, 0 0% 100%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n @media (width >= 640px) {\n .occurrence-card {\n flex-direction: row;\n align-items: center;\n }\n }\n\n .occurrence-card:hover {\n border-color: hsl(var(--brand-primary, 224 76% 48%));\n box-shadow: 0 4px 12px color-mix(in srgb, black 8%, transparent);\n }\n\n .occurrence-info {\n margin-bottom: 1rem;\n }\n\n @media (width >= 640px) {\n .occurrence-info {\n margin-bottom: 0;\n }\n }\n\n .occurrence-date {\n font-size: 1.25rem;\n line-height: 1.75rem;\n font-weight: 700;\n margin-bottom: 0.25rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .occurrence-time {\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .occurrence-action {\n padding-left: 0;\n }\n\n @media (width >= 640px) {\n .occurrence-action {\n padding-left: 1.5rem;\n }\n }\n\n .cta-button {\n width: 100%;\n padding: 0.75rem 1.5rem;\n border-radius: 0.5rem;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n transition: transform 0.15s;\n background: hsl(var(--brand-primary, 224 76% 48%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n @media (width >= 640px) {\n .cta-button {\n width: auto;\n }\n }\n\n .cta-button:hover:not(:disabled) {\n transform: scale(1.05);\n }\n\n .cta-disabled {\n cursor: not-allowed;\n background: hsl(var(--surface-secondary, 0 0% 90%));\n color: hsl(var(--text-secondary, 0 0% 55%));\n }\n\n /* Performers */\n .performers-grid {\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n gap: 2rem;\n }\n\n @media (width >= 640px) {\n .performers-grid {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n .performer-card {\n display: flex;\n flex-direction: column;\n align-items: center;\n text-align: center;\n padding: 1rem;\n border-radius: 0.75rem;\n transition: background-color 0.15s;\n }\n\n .performer-card:hover {\n background: hsl(var(--surface-secondary, 0 0% 96%));\n }\n\n .performer-avatar {\n width: 7rem;\n height: 7rem;\n margin-bottom: 1rem;\n border-radius: 9999px;\n overflow: hidden;\n box-shadow:\n 0 4px 6px -1px rgb(0 0 0 / 10%),\n 0 2px 4px -2px rgb(0 0 0 / 10%);\n background: hsl(var(--surface-secondary, 0 0% 92%));\n }\n\n .performer-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n transition: transform 0.5s ease;\n }\n\n .performer-card:hover .performer-image {\n transform: scale(1.1);\n }\n\n .performer-placeholder {\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: center;\n color: hsl(var(--text-secondary, 0 0% 60%));\n }\n\n .placeholder-icon {\n width: 3rem;\n height: 3rem;\n opacity: 0.5;\n }\n\n .performer-name {\n font-size: 1.125rem;\n line-height: 1.75rem;\n font-weight: 600;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n /* Sidebar */\n .sidebar {\n display: flex;\n flex-direction: column;\n gap: 2rem;\n }\n\n @media (width >= 1024px) {\n .sidebar {\n grid-column: span 1 / span 1;\n }\n }\n\n .sidebar-sticky {\n position: sticky;\n top: 6rem;\n display: flex;\n flex-direction: column;\n gap: 2rem;\n }\n\n .sidebar-card {\n border-radius: 1rem;\n padding: 2rem;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 92%));\n }\n\n .sidebar-section {\n margin-bottom: 2rem;\n }\n\n .sidebar-section:last-child {\n margin-bottom: 0;\n }\n\n .sidebar-heading {\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.1em;\n margin-bottom: 1rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .faq-content {\n color: hsl(var(--text-secondary, 0 0% 40%));\n }\n\n .faq-item {\n margin-bottom: 0.75rem;\n }\n\n .faq-question {\n font-weight: 700;\n color: hsl(var(--text-primary, 0 0% 20%));\n }\n\n .faq-answer {\n font-size: 0.875rem;\n line-height: 1.25rem;\n }\n\n .disclaimer-text {\n font-size: 0.875rem;\n line-height: 1.625;\n padding: 1rem;\n border-radius: 0.5rem;\n background: hsl(var(--surface-primary, 0 0% 100%));\n color: hsl(var(--text-secondary, 0 0% 40%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n</style>\n"],"names":["imageLoaded","$","seriesImage","getImageUrl","$$props","PLACEHOLDER_IMAGE","tz","getDefaultTimezone","formatDate","iso","scFormatDate","formatTime","scFormatTime","handleOccurrenceClick","occurrence","div","root_1","div_1","div_2","img","div_3","div_4","h1","div_5","span","span_1","fragment_1","text_2","$$render","consequent","div_6","div_7","section","p","root_3","consequent_1","div_8","root_4","consequent_2","section_1","div_9","span_2","div_10","root_5","div_11","root_6","$$anchor","div_12","root_7","div_13","div_14","div_15","div_16","button","classes_1","text_8","alternate","consequent_3","section_2","root_8","div_17","performer","div_18","root_9","div_19","img_1","root_10","$0","$1","formatFullName","div_20","root_11","consequent_4","alternate_1","h3","consequent_5","div_21","div_22","div_23","root_12","div_24","root_13","div_25","item","div_26","root_15","p_1","p_2","text_10","text_11","d","p_3","root_16","text_12","consequent_7","div_27","root_17","div_28","text_13","consequent_8","consequent_9","classes","text_1"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Success-DTSn26bg.js","sources":["../src/lib/premium-ticket-experience/variants/v3-airbnb-split/SuccessTicket.svelte","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/SuccessActions.svelte","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/SuccessMain.svelte","../src/components/Views/Success.svelte"],"sourcesContent":["<script lang=\"ts\">\n\timport { Email } from 'carbon-icons-svelte';\n\timport { Card, Heading, Text } from '@getmicdrop/svelte-components';\n\timport type { EventData, OrderTotals } from '$lib/premium-ticket-experience/types';\n\timport OrderSummary from './OrderSummary.svelte';\n\n\tinterface Props {\n\t\tevent: EventData;\n\t\torderId: string;\n\t\torderTotals: OrderTotals;\n\t\tcustomerEmail: string;\n\t\tshowCheckmark: boolean;\n\t\tshowContent: boolean;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tevent, orderId, orderTotals, customerEmail, showCheckmark, showContent, labels = {},\n\t}: Props = $props();\n\n\tlet ticketCount = $derived(orderTotals.lines.reduce((sum, l) => sum + l.quantity, 0));\n\n\tlet headingText = $derived(\n\t\tevent.isRegistrationEvent ? (labels.youreRegistered || \"You're registered!\") : (labels.youreIn || \"You're in!\")\n\t);\n\n</script>\n\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-primary\">\n\t<div class=\"p-6 md:p-8\">\n\t\t<!-- Spinner → Checkmark animation -->\n\t\t<div class=\"flex justify-center mb-6\">\n\t\t\t<div class=\"indicator-container\">\n\t\t\t\t<!-- Spinner (visible while loading) -->\n\t\t\t\t<div class=\"processing-spinner\" class:fade-out={showCheckmark}></div>\n\n\t\t\t\t<!-- Animated checkmark (appears after spinner) -->\n\t\t\t\t<svg class=\"checkmark-svg\" class:active={showCheckmark} viewBox=\"0 0 52 52\" aria-hidden=\"true\">\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-circle\" />\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-fill\" />\n\t\t\t\t\t<path d=\"M14 27l7 7 17-17\" class=\"checkmark-check\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<!-- Content (fades in after checkmark completes) -->\n\t\t<div class=\"content-section\" class:visible={showContent}>\n\t\t\t<!-- Heading -->\n\t\t\t<div class=\"text-center mb-6\">\n\t\t\t\t<Heading level={1} size=\"xl\" weight=\"bold\" class=\"mb-3\">\n\t\t\t\t\t{headingText}\n\t\t\t\t</Heading>\n\t\t\t\t<Text size=\"lg\" class=\"font-semibold block mb-1\">\n\t\t\t\t\t{event.title}\n\t\t\t\t</Text>\n\t\t\t\t<Text size=\"sm\" color=\"secondary\" class=\"block\">\n\t\t\t\t\t{ticketCount} {ticketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} confirmed\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Order summary (same format as checkout) -->\n\t\t\t<div class=\"mb-6\">\n\t\t\t\t<OrderSummary {orderTotals}\n\t\t\t\t{labels} />\n\t\t\t</div>\n\n\t\t\t<!-- Order info -->\n\t\t\t<div class=\"flex justify-between items-center py-3 border-t border-default\">\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold font-mono\">#{orderId}</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Email confirmation -->\n\t\t\t<div class=\"flex items-center justify-center gap-2 p-3 rounded-lg bg-surface-secondary mt-4\">\n\t\t\t\t<Email size={16} class=\"shrink-0 text-color-muted\" />\n\t\t\t\t<Text size=\"xs\" color=\"secondary\">\n\t\t\t\t\t{labels.confirmationSentTo || 'Confirmation sent to'} {customerEmail}\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t</div>\n\t</div>\n</Card>\n\n<style>\n\t/* Indicator container — holds spinner and checkmark in same space */\n\t.indicator-container {\n\t\tposition: relative;\n\t\twidth: 64px;\n\t\theight: 64px;\n\t}\n\n\t/* Spinner — rotating partial circle */\n\t.processing-spinner {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder: 3px solid hsl(var(--stroke-primary) / 15%);\n\t\tborder-top-color: hsl(var(--accent-success));\n\t\tborder-radius: 50%;\n\t\tanimation: spin 0.7s linear infinite;\n\t\ttransition: opacity 0.2s ease;\n\t}\n\n\t.processing-spinner.fade-out {\n\t\topacity: 0;\n\t}\n\n\t@keyframes spin {\n\t\tto { transform: rotate(360deg); }\n\t}\n\n\t/* Checkmark SVG — scales in when active */\n\t.checkmark-svg {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\topacity: 0;\n\t\ttransform: scale(0.6);\n\t\ttransition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);\n\t}\n\n\t.checkmark-svg.active {\n\t\topacity: 1;\n\t\ttransform: scale(1);\n\t}\n\n\t/* Circle outline — draws itself */\n\t.checkmark-circle {\n\t\tstroke-dasharray: 151;\n\t\tstroke-dashoffset: 151;\n\t\tstroke-width: 2;\n\t\tstroke: hsl(var(--accent-success));\n\t\tfill: none;\n\t\ttransform-origin: center;\n\t}\n\n\t.checkmark-svg.active .checkmark-circle {\n\t\tanimation: circle-draw 0.5s ease-out 0.1s forwards;\n\t}\n\n\t@keyframes circle-draw {\n\t\tto { stroke-dashoffset: 0; }\n\t}\n\n\t/* Circle fill — fades in after outline completes */\n\t.checkmark-fill {\n\t\tfill: hsl(var(--accent-success));\n\t\topacity: 0;\n\t}\n\n\t.checkmark-svg.active .checkmark-fill {\n\t\tanimation: fill-in 0.25s ease-out 0.5s forwards;\n\t}\n\n\t@keyframes fill-in {\n\t\tto { opacity: 1; }\n\t}\n\n\t/* Checkmark stroke — draws after fill */\n\t.checkmark-check {\n\t\tstroke-dasharray: 36;\n\t\tstroke-dashoffset: 36;\n\t\tstroke-width: 3;\n\t\tstroke: hsl(var(--bg-primary));\n\t\tfill: none;\n\t\tstroke-linecap: round;\n\t\tstroke-linejoin: round;\n\t}\n\n\t.checkmark-svg.active .checkmark-check {\n\t\tanimation: check-draw 0.3s ease-out 0.6s forwards;\n\t}\n\n\t@keyframes check-draw {\n\t\tto { stroke-dashoffset: 0; }\n\t}\n\n\t/* Content section — fades in after checkmark */\n\t.content-section {\n\t\topacity: 0;\n\t\ttransform: translateY(8px);\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\n\t}\n\n\t.content-section.visible {\n\t\topacity: 1;\n\t\ttransform: translateY(0);\n\t}\n\n\t/* Reduced motion */\n\t@media (prefers-reduced-motion: reduce) {\n\t\t.processing-spinner {\n\t\t\tanimation-duration: 0s;\n\t\t}\n\n\t\t.checkmark-svg {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\n\t\t.checkmark-svg .checkmark-circle,\n\t\t.checkmark-svg .checkmark-fill,\n\t\t.checkmark-svg .checkmark-check {\n\t\t\tanimation-duration: 0s;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\n\t\t.content-section {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\t}\n</style>\n","<script lang=\"ts\">\n\timport { onMount } from 'svelte';\n\timport {\n\t\tShare,\n\t\tHelp,\n\t\tArrowLeft,\n\t\tApple,\n\t\tCalendar,\n\t\tChevronDown,\n\t\tLocationFilled,\n\t} from 'carbon-icons-svelte';\n\timport { Button, Card, Text } from '@getmicdrop/svelte-components';\n\timport type { EventData } from '$lib/premium-ticket-experience/types';\n\timport { formatBrowseDate, formatEventTime } from '$lib/premium-ticket-experience/defaults';\n\n\tinterface Props {\n\t\tevent: EventData;\n\t\torderId: string;\n\t\teventUrl: string;\n\t\tshowContent: boolean;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet { event, orderId, eventUrl, showContent, labels = {} }: Props = $props();\n\n\t// --- Calendar dropdown ---\n\tlet calendarOpen = $state(false);\n\n\tfunction toggleCalendar() {\n\t\tcalendarOpen = !calendarOpen;\n\t}\n\n\t// Close calendar dropdown when clicking outside\n\tonMount(() => {\n\t\tfunction handleClickOutside(e: MouseEvent) {\n\t\t\tconst target = e.target as HTMLElement;\n\t\t\tif (!target.closest('.calendar-dropdown')) {\n\t\t\t\tcalendarOpen = false;\n\t\t\t}\n\t\t}\n\t\tdocument.addEventListener('click', handleClickOutside);\n\t\treturn () => document.removeEventListener('click', handleClickOutside);\n\t});\n\n\t// --- Google Calendar URL ---\n\tlet googleCalendarUrl = $derived((() => {\n\t\tconst startDate = new Date(event.startDateTime);\n\t\tconst endDate = event.endDateTime\n\t\t\t? new Date(event.endDateTime)\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\n\n\t\tconst formatForGoogle = (date: Date): string => {\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, '');\n\t\t};\n\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst fullLocation = locationParts.join(', ');\n\n\t\tconst params = new URLSearchParams({\n\t\t\taction: 'TEMPLATE',\n\t\t\ttext: event.title,\n\t\t\tdates: `${formatForGoogle(startDate)}/${formatForGoogle(endDate)}`,\n\t\t\tlocation: fullLocation,\n\t\t\tdetails: `Event: ${eventUrl}\\n\\nTicket confirmation #${orderId}`\n\t\t});\n\n\t\treturn `https://calendar.google.com/calendar/render?${params.toString()}`;\n\t})());\n\n\t// --- ICS file download (Apple Calendar) ---\n\tfunction downloadICS() {\n\t\tconst startDate = new Date(event.startDateTime);\n\t\tconst endDate = event.endDateTime\n\t\t\t? new Date(event.endDateTime)\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\n\n\t\tconst formatForICS = (date: Date): string => {\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, '');\n\t\t};\n\n\t\tconst uid = `order-${orderId}-event-${event.id}@micdrop.com`;\n\t\tconst now = formatForICS(new Date());\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst fullLocation = locationParts.join(', ');\n\n\t\tconst escapeICS = (str: string): string => {\n\t\t\tif (!str) return '';\n\t\t\treturn str.replace(/\\\\/g, '\\\\\\\\').replace(/;/g, '\\\\;').replace(/,/g, '\\\\,').replace(/\\n/g, '\\\\n');\n\t\t};\n\n\t\tconst icsContent = `BEGIN:VCALENDAR\nVERSION:2.0\nPRODID:-//MicDrop//Ticket Confirmation//EN\nCALSCALE:GREGORIAN\nMETHOD:PUBLISH\nBEGIN:VEVENT\nUID:${uid}\nDTSTAMP:${now}\nDTSTART:${formatForICS(startDate)}\nDTEND:${formatForICS(endDate)}\nSUMMARY:${escapeICS(event.title)}\nLOCATION:${escapeICS(fullLocation)}\nDESCRIPTION:${escapeICS(`Order #${orderId}\\n\\nView event: ${eventUrl}`)}\nURL:${eventUrl}\nSTATUS:CONFIRMED\nEND:VEVENT\nEND:VCALENDAR`;\n\n\t\tconst blob = new Blob([icsContent], { type: 'text/calendar;charset=utf-8' });\n\t\tconst url = URL.createObjectURL(blob);\n\t\tconst link = document.createElement('a');\n\t\tlink.href = url;\n\t\tconst safeFilename = (event.title || 'event').replace(/[^a-zA-Z0-9\\s-]/g, '').replace(/\\s+/g, '-');\n\t\tlink.download = `${safeFilename}.ics`;\n\t\tdocument.body.appendChild(link);\n\t\tlink.click();\n\t\tdocument.body.removeChild(link);\n\t\tURL.revokeObjectURL(url);\n\n\t\tcalendarOpen = false;\n\t}\n\n\tfunction handleGoogleCalendar() {\n\t\tcalendarOpen = false;\n\t}\n\n\t// --- Share event ---\n\tasync function shareEvent() {\n\t\tconst shareData = { url: eventUrl };\n\n\t\tif (navigator.share) {\n\t\t\ttry {\n\t\t\t\tawait navigator.share(shareData);\n\t\t\t} catch (err: unknown) {\n\t\t\t\tif (err instanceof Error && err.name !== 'AbortError') {\n\t\t\t\t\tfallbackShare();\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfallbackShare();\n\t\t}\n\t}\n\n\tfunction fallbackShare() {\n\t\tnavigator.clipboard.writeText(eventUrl).then(() => {\n\t\t\talert(labels.linkCopied || 'Link copied to clipboard!');\n\t\t}).catch(() => {\n\t\t\tprompt(labels.copyLink || 'Copy this link:', eventUrl);\n\t\t});\n\t}\n\n\t// --- Wallet handlers (mock — requires backend in production) ---\n\tfunction handleAppleWallet() {\n\t\talert('Apple Wallet integration requires backend signing infrastructure.\\nIn production, this would generate a .pkpass file and add it to your Apple Wallet.');\n\t}\n\n\tfunction handleGoogleWallet() {\n\t\talert('Google Wallet integration requires backend signing infrastructure.\\nIn production, this would create a Google Wallet pass via the Google Pay API.');\n\t}\n\n\t// --- Directions ---\n\tlet directionsUrl = $derived((() => {\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst query = encodeURIComponent(locationParts.join(', '));\n\t\treturn `https://www.google.com/maps/search/?api=1&query=${query}`;\n\t})());\n\n\t// --- Navigation ---\n\tfunction handleBackToEvent() {\n\t\twindow.location.href = eventUrl;\n\t}\n</script>\n\n<!--\n\tSuccessActions: Sidebar card matching BookingWidget / CheckoutSidebar pattern.\n\tSingle Card with event thumbnail, date summary, wallet badges, action buttons, and links.\n-->\n<div class=\"actions-wrapper\" class:visible={showContent}>\n\t<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\n\t\t<!-- Event poster (same treatment as HeroImage — object-contain, no crop) -->\n\t\t<div class=\"rounded-t-xl overflow-hidden bg-surface-tertiary\">\n\t\t\t<img\n\t\t\t\tsrc={event.imageUrl}\n\t\t\t\talt={event.title}\n\t\t\t\tclass=\"sidebar-poster w-full object-contain\"\n\t\t\t/>\n\t\t</div>\n\n\t\t<div class=\"p-5 space-y-4\">\n\t\t\t<!-- Event info -->\n\t\t\t<div>\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight\">\n\t\t\t\t\t{event.title}\n\t\t\t\t</Text>\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1.5\">\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\n\t\t\t\t\t\t{/if}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\n\t\t\t\t\t{event.venue.name}\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Wallet badges (official brand assets) -->\n\t\t\t<div class=\"flex flex-col items-center gap-3\">\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleAppleWallet}>\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/apple-wallet.svg\"\n\t\t\t\t\t\talt={labels.addToAppleWallet || 'Add to Apple Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img\"\n\t\t\t\t\t/>\n\t\t\t\t</button>\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleGoogleWallet}>\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-dark.svg\"\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img google-dark\"\n\t\t\t\t\t/>\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-light.svg\"\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img google-light\"\n\t\t\t\t\t/>\n\t\t\t\t</button>\n\t\t\t</div>\n\n\t\t\t<!-- Divider -->\n\t\t\t<div class=\"divider\"></div>\n\n\t\t\t<!-- Calendar dropdown (full width) -->\n\t\t\t<div class=\"calendar-dropdown relative\">\n\t\t\t\t<Button\n\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\tsize=\"md\"\n\t\t\t\t\tclass=\"w-full\"\n\t\t\t\t\tonclick={toggleCalendar}\n\t\t\t\t>\n\t\t\t\t\t<Calendar size={16} />\n\t\t\t\t\t{labels.addToCalendar || 'Add to Calendar'}\n\t\t\t\t\t<ChevronDown size={16} class=\"ml-auto transition-transform {calendarOpen ? 'rotate-180' : ''}\" />\n\t\t\t\t</Button>\n\n\t\t\t\t{#if calendarOpen}\n\t\t\t\t\t<div class=\"dropdown-menu bg-surface-primary border-default\">\n\t\t\t\t\t\t<a\n\t\t\t\t\t\t\thref={googleCalendarUrl}\n\t\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t\t\trel=\"noopener noreferrer\"\n\t\t\t\t\t\t\tclass=\"dropdown-item text-color-primary hover:bg-surface-secondary\"\n\t\t\t\t\t\t\tonclick={handleGoogleCalendar}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<svg class=\"shrink-0\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\">\n\t\t\t\t\t\t\t\t<path d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92a5.06 5.06 0 0 1-2.2 3.32v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.1z\" fill=\"#4285F4\"/>\n\t\t\t\t\t\t\t\t<path d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\" fill=\"#34A853\"/>\n\t\t\t\t\t\t\t\t<path d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18A10.96 10.96 0 0 0 1 12c0 1.77.42 3.45 1.18 4.93l3.66-2.84z\" fill=\"#FBBC05\"/>\n\t\t\t\t\t\t\t\t<path d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\" fill=\"#EA4335\"/>\n\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t\t\t{labels.googleCalendar || 'Google Calendar'}\n\t\t\t\t\t\t</a>\n\t\t\t\t\t\t<button type=\"button\" class=\"dropdown-item text-color-primary hover:bg-surface-secondary\" onclick={downloadICS}>\n\t\t\t\t\t\t\t<Apple size={16} class=\"shrink-0\" />\n\t\t\t\t\t\t\t{labels.appleCalendar || 'Apple Calendar (.ics)'}\n\t\t\t\t\t\t</button>\n\t\t\t\t\t</div>\n\t\t\t\t{/if}\n\t\t\t</div>\n\n\t\t\t<!-- Share + Directions row -->\n\t\t\t<div class=\"flex gap-2\">\n\t\t\t\t<Button variant=\"default\" size=\"md\" class=\"flex-1\" onclick={shareEvent}>\n\t\t\t\t\t<Share size={16} />\n\t\t\t\t\t{labels.share || 'Share'}\n\t\t\t\t</Button>\n\n\t\t\t\t{#if event.venue.address}\n\t\t\t\t\t<Button\n\t\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\t\tsize=\"md\"\n\t\t\t\t\t\tclass=\"flex-1\"\n\t\t\t\t\t\thref={directionsUrl}\n\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<LocationFilled size={16} />\n\t\t\t\t\t\t{labels.map || 'Map'}\n\t\t\t\t\t</Button>\n\t\t\t\t{/if}\n\t\t\t</div>\n\n\t\t\t<!-- Text links -->\n\t\t\t<div class=\"flex items-center justify-center gap-4 pt-1\">\n\t\t\t\t<button type=\"button\" class=\"text-link text-color-muted hover:text-color-secondary\" onclick={handleBackToEvent}>\n\t\t\t\t\t<ArrowLeft size={16} class=\"shrink-0\" />\n\t\t\t\t\t{labels.backToEvent || 'Back to event'}\n\t\t\t\t</button>\n\n\t\t\t\t{#if event.venue.contactEmail}\n\t\t\t\t\t<span class=\"text-color-muted\">·</span>\n\t\t\t\t\t<a\n\t\t\t\t\t\thref=\"mailto:{event.venue.contactEmail}?subject=Help with Order {orderId}\"\n\t\t\t\t\t\tclass=\"text-link text-color-muted hover:text-color-secondary\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<Help size={16} class=\"shrink-0\" />\n\t\t\t\t\t\t{labels.needHelp || 'Need help?'}\n\t\t\t\t\t</a>\n\t\t\t\t{/if}\n\t\t\t</div>\n\t\t</div>\n\t</Card>\n</div>\n\n<style>\n\t/* Wrapper — fades in with content */\n\t.actions-wrapper {\n\t\topacity: 0;\n\t\ttransform: translateY(8px);\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\n\t}\n\n\t.actions-wrapper.visible {\n\t\topacity: 1;\n\t\ttransform: translateY(0);\n\t}\n\n\t/* Sidebar poster — same object-contain treatment as HeroImage */\n\t.sidebar-poster {\n\t\tmax-height: 15rem;\n\t\tmin-height: 6rem;\n\t}\n\n\t/* Wallet badges — official brand assets, no modifications per guidelines */\n\t.wallet-badge-btn {\n\t\tdisplay: block;\n\t\ttransition-property: opacity;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t.wallet-badge-btn:hover {\n\t\topacity: 0.85;\n\t}\n\n\t.wallet-badge-btn:active {\n\t\topacity: 0.7;\n\t}\n\n\t.wallet-badge-img {\n\t\theight: 44px;\n\t\twidth: auto;\n\t}\n\n\t/* Google badge: show dark variant in light mode, light variant in dark mode */\n\t.google-light {\n\t\tdisplay: none;\n\t}\n\n\t/* Calendar dropdown menu */\n\t.dropdown-menu {\n\t\tposition: absolute;\n\t\ttop: 100%;\n\t\tleft: 0;\n\t\tright: 0;\n\t\tmargin-top: 0.25rem;\n\t\tpadding-top: 0.25rem;\n\t\tpadding-bottom: 0.25rem;\n\t\tborder-radius: 0.5rem;\n\t\tbox-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -4px rgb(0 0 0 / 10%);\n\t\tz-index: var(--z-navigation);\n\t\tborder-width: 1px;\n\t\tborder-style: solid;\n\t}\n\n\t.dropdown-item {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tgap: 0.625rem;\n\t\twidth: 100%;\n\t\tpadding: 0.5rem 0.75rem;\n\t\tfont-size: 0.875rem;\n\t\tline-height: 1.25rem;\n\t\ttext-align: left;\n\t\ttransition-property: color, background-color;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t/* Text links */\n\t.text-link {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tgap: 0.25rem;\n\t\tfont-size: 0.75rem;\n\t\tline-height: 1rem;\n\t\ttransition-property: color;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t/* Reduced motion */\n\t@media (prefers-reduced-motion: reduce) {\n\t\t.actions-wrapper {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\t}\n</style>\n","<script lang=\"ts\">\n\timport { onMount } from 'svelte';\n\timport type { EventData, OrderTotals, OrderLine, SuccessData } from '$lib/premium-ticket-experience/types';\n\timport {\n\t\tmockEvent,\n\t\tmockFreeEvent,\n\t\tmockRegistrationEvent,\n\t\tmockDonationEvent\n\t} from '$lib/premium-ticket-experience/mock-data';\n\timport { calculateTax } from '$lib/premium-ticket-experience/defaults';\n\n\timport SuccessTicket from './SuccessTicket.svelte';\n\timport SuccessActions from './SuccessActions.svelte';\n\timport { mergeLabels } from '$lib/premium-ticket-experience/i18n/labels.js';\n\n\t// --- DataToggle ---\n\ttype SuccessVariant = 'default' | 'free' | 'registration' | 'donation';\n\tlet dataVariant = $state<SuccessVariant>('default');\n\n\tconst toggleOptions: { value: SuccessVariant; label: string; color: string }[] = [\n\t\t{ value: 'default', label: 'Standard', color: 'bg-accent-success' },\n\t\t{ value: 'free', label: 'Free', color: 'bg-sky-500' },\n\t\t{ value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\n\t\t{ value: 'donation', label: 'Donation', color: 'bg-accent-danger' }\n\t];\n\n\t// --- Props (dual-mode: showcase vs production) ---\n\tinterface Props {\n\t\t/** Pre-built success data for production mode. Absence = showcase. */\n\t\tdata?: SuccessData;\n\t\t/** Event page URL for production navigation and sharing. */\n\t\teventUrl?: string;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tdata: dataProp = undefined,\n\t\teventUrl: eventUrlProp = undefined,\n\t\tlabels = {},\n\t}: Props = $props();\n\n\tconst mergedLabels = $derived(mergeLabels(labels));\n\n\tlet isShowcaseMode = $derived(!dataProp);\n\n\t// --- Mock data per variant ---\n\tconst variantData: Record<SuccessVariant, SuccessData> = {\n\t\tdefault: {\n\t\t\tevent: mockEvent,\n\t\t\torderId: '12847',\n\t\t\tlines: [\n\t\t\t\t{ ticketId: 101, ticketName: 'General Admission', quantity: 2, unitPrice: 25, fee: 2.5, subtotal: 50 },\n\t\t\t\t{ ticketId: 102, ticketName: 'VIP Front Row', quantity: 1, unitPrice: 55, fee: 5.5, subtotal: 55 }\n\t\t\t],\n\t\t\tcustomerEmail: 'customer@example.com'\n\t\t},\n\t\tfree: {\n\t\t\tevent: mockFreeEvent,\n\t\t\torderId: '12848',\n\t\t\tlines: [\n\t\t\t\t{ ticketId: 201, ticketName: 'Free Entry', quantity: 2, unitPrice: 0, fee: 0, subtotal: 0 }\n\t\t\t],\n\t\t\tcustomerEmail: 'comedy.fan@gmail.com'\n\t\t},\n\t\tregistration: {\n\t\t\tevent: mockRegistrationEvent,\n\t\t\torderId: '12849',\n\t\t\tlines: [\n\t\t\t\t{ ticketId: 301, ticketName: 'Workshop Seat', quantity: 1, unitPrice: 75, fee: 7.5, subtotal: 75 }\n\t\t\t],\n\t\t\tcustomerEmail: 'learner@example.com'\n\t\t},\n\t\tdonation: {\n\t\t\tevent: mockDonationEvent,\n\t\t\torderId: '12850',\n\t\t\tlines: [\n\t\t\t\t{ ticketId: 401, ticketName: 'Donation', quantity: 1, unitPrice: 25, fee: 0, subtotal: 25 },\n\t\t\t\t{ ticketId: 402, ticketName: 'Standard Admission', quantity: 1, unitPrice: 30, fee: 3, subtotal: 30 }\n\t\t\t],\n\t\t\tcustomerEmail: 'generous@example.com'\n\t\t}\n\t};\n\n\tlet current: SuccessData = $derived(isShowcaseMode ? variantData[dataVariant] : dataProp!);\n\n\t// Build OrderTotals from the mock order lines\n\tlet orderTotals: OrderTotals = $derived((() => {\n\t\tconst lines = current.lines;\n\t\tconst subtotal = lines.reduce((sum, l) => sum + l.subtotal, 0);\n\t\tconst fees = lines.reduce((sum, l) => sum + l.fee * l.quantity, 0);\n\t\tconst taxes = calculateTax(subtotal + fees, current.event.venue.taxPercentage);\n\t\treturn {\n\t\t\tlines,\n\t\t\tsubtotal,\n\t\t\tfees,\n\t\t\ttaxes,\n\t\t\ttotal: subtotal + fees + taxes,\n\t\t\tpromoDiscount: 0,\n\t\t\tgiftCardAmount: 0\n\t\t};\n\t})());\n\n\tlet eventUrl = $derived(\n\t\tisShowcaseMode\n\t\t\t? (() => {\n\t\t\t\tif (typeof window === 'undefined') return '#';\n\t\t\t\treturn `${window.location.origin}/e/${current.event.id}-${current.event.slug}`;\n\t\t\t})()\n\t\t\t: (eventUrlProp || '#')\n\t);\n\n\t// --- Animation ---\n\tlet showCheckmark = $state(false);\n\tlet showContent = $state(false);\n\tlet reducedMotion = $state(false);\n\n\tfunction runAnimations() {\n\t\tif (reducedMotion) {\n\t\t\tshowCheckmark = true;\n\t\t\tshowContent = true;\n\t\t\treturn;\n\t\t}\n\t\tshowCheckmark = false;\n\t\tshowContent = false;\n\t\tsetTimeout(() => { showCheckmark = true; }, 800);\n\t\tsetTimeout(() => { showContent = true; }, 1600);\n\t}\n\n\t$effect(() => {\n\t\tif (!isShowcaseMode) return;\n\t\tconst _v = dataVariant;\n\t\trunAnimations();\n\t});\n\n\tonMount(() => {\n\t\treducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n\t\trunAnimations();\n\t});\n</script>\n\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\n\t<!-- DataToggle (showcase mode only) -->\n\t{#if isShowcaseMode}\n\t\t<div class=\"toggle-bar bg-surface-primary border-default\">\n\t\t\t<span class=\"toggle-label text-color-muted\">Success</span>\n\t\t\t{#each toggleOptions as option}\n\t\t\t\t{@const isActive = dataVariant === option.value}\n\t\t\t\t<button\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\tclass=\"toggle-btn {isActive ? 'active bg-surface-secondary text-color-primary font-medium' : 'text-color-tertiary hover:bg-surface-secondary hover:text-color-secondary'}\"\n\t\t\t\t\tonclick={() => { dataVariant = option.value; }}\n\t\t\t\t>\n\t\t\t\t\t<span class=\"w-1.5 h-1.5 rounded-full {option.color} shrink-0\"></span>\n\t\t\t\t\t{option.label}\n\t\t\t\t</button>\n\t\t\t{/each}\n\t\t</div>\n\t{/if}\n\n\t<div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\n\n\t\t<!-- ============================================== -->\n\t\t<!-- DESKTOP: Two-column layout (1fr 360px) -->\n\t\t<!-- ============================================== -->\n\t\t<div class=\"hidden md:grid gap-8 items-start\" style=\"grid-template-columns: 1fr 360px;\">\n\n\t\t\t<!-- LEFT COLUMN: Confirmation card -->\n\t\t\t<SuccessTicket\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{orderTotals}\n\t\t\t\tcustomerEmail={current.customerEmail}\n\t\t\t\t{showCheckmark}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\n\t\t\t<!-- RIGHT COLUMN: Sticky sidebar with event info + actions -->\n\t\t\t<div class=\"sticky top-6\">\n\t\t\t\t<SuccessActions\n\t\t\t\t\tevent={current.event}\n\t\t\t\t\torderId={current.orderId}\n\t\t\t\t\t{eventUrl}\n\t\t\t\t\t{showContent}\n\t\t\t\t\tlabels={mergedLabels}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<!-- ============================================== -->\n\t\t<!-- MOBILE: Single column -->\n\t\t<!-- ============================================== -->\n\t\t<div class=\"md:hidden space-y-6\">\n\t\t\t<SuccessTicket\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{orderTotals}\n\t\t\t\tcustomerEmail={current.customerEmail}\n\t\t\t\t{showCheckmark}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\n\t\t\t<SuccessActions\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{eventUrl}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\t\t</div>\n\t</div>\n</div>\n\n<style>\n\t/* DataToggle bar */\n\t.toggle-bar {\n\t\tposition: sticky;\n\t\ttop: 0;\n\t\tz-index: var(--z-dropdown);\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tgap: 0.25rem;\n\t\tpadding: 0.5rem 0.75rem;\n\t\toverflow-x: auto;\n\t\tborder-bottom-width: 1px;\n\t\tborder-bottom-style: solid;\n\t}\n\n\t.toggle-label {\n\t\tpadding-left: 0.375rem;\n\t\tpadding-right: 0.375rem;\n\t\tflex-shrink: 0;\n\t\ttext-transform: uppercase;\n\t\tletter-spacing: 0.05em;\n\t\tfont-size: 0.625rem;\n\t}\n\n\t.toggle-btn {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tgap: 0.375rem;\n\t\tpadding: 0.25rem 0.5rem;\n\t\tborder-radius: 0.375rem;\n\t\tfont-size: 0.75rem;\n\t\tline-height: 1rem;\n\t\twhite-space: nowrap;\n\t\ttransition-property: all;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n</style>\n","<script module>\n\timport { createLogger } from '@getmicdrop/svelte-components';\n\tconst logger = createLogger('Success');\n</script>\n\n<script lang=\"ts\">\n\timport { onMount } from 'svelte';\n\timport { getOrder, clearCheckoutCookies, removeCookie } from '$lib/utils/utils.js';\n\timport { transformApiEvent } from '$lib/premium-ticket-experience/transform';\n\timport SuccessMain from '$lib/premium-ticket-experience/variants/v3-airbnb-split/SuccessMain.svelte';\n\timport type { SuccessData, OrderLine } from '$lib/premium-ticket-experience/types';\n\n\t// --- Legacy fallback ---\n\tlet useLegacy = $state(false);\n\tlet LegacyComponent: any = $state(null);\n\n\tif (typeof window !== 'undefined') {\n\t\tconst params = new URLSearchParams(window.location.search);\n\t\tif (params.get('legacy') === '1') {\n\t\t\tuseLegacy = true;\n\t\t}\n\t}\n\n\t$effect(() => {\n\t\tif (useLegacy && !LegacyComponent) {\n\t\t\tlogger.warn(\n\t\t\t\t'[VC] DEPRECATED: ?legacy=1 fallback for Success retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md.'\n\t\t\t);\n\t\t\timport('./Success.legacy.svelte').then((m) => {\n\t\t\t\tLegacyComponent = m.default;\n\t\t\t}).catch(() => {\n\t\t\t\tuseLegacy = false;\n\t\t\t});\n\t\t}\n\t});\n\n\t// --- Props ---\n\tinterface Props {\n\t\tdata?: any;\n\t\tbrowseUrl?: string;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tdata = {},\n\t\tbrowseUrl = '/',\n\t\tlabels = {},\n\t}: Props = $props();\n\n\t// --- State ---\n\tlet successData = $state<SuccessData | null>(null);\n\tlet eventUrl = $state('');\n\tlet loadError = $state<string | null>(null);\n\tlet loading = $state(true);\n\n\tonMount(async () => {\n\t\tconst {\n\t\t\tid,\n\t\t\tslug,\n\t\t\tevent: rawEvent,\n\t\t\torderId: paramOrderId,\n\t\t\torderUuid: paramOrderUuid,\n\t\t\tcustomerEmail: paramEmail,\n\t\t\tticketCount: paramTicketCount,\n\t\t} = data || {};\n\n\t\t// Build event URL\n\t\teventUrl = `${window.location.origin}/e/${id}-${slug}`;\n\n\t\t// Transform event data\n\t\tlet eventData;\n\t\ttry {\n\t\t\teventData = transformApiEvent(rawEvent);\n\t\t} catch (e) {\n\t\t\tlogger.warn('Success: transformApiEvent failed:', e);\n\t\t\tloadError = labels.failedToLoadEventData || 'Failed to load event data.';\n\t\t\tloading = false;\n\t\t\treturn;\n\t\t}\n\n\t\t// Fetch order data\n\t\tlet resolvedOrderId = paramOrderId || '';\n\t\tlet resolvedEmail = paramEmail || '';\n\t\tlet orderLines: OrderLine[] = [];\n\n\t\tif (resolvedOrderId) {\n\t\t\ttry {\n\t\t\t\tconst order = await getOrder(resolvedOrderId);\n\t\t\t\tif (order) {\n\t\t\t\t\t// Extract email\n\t\t\t\t\tresolvedEmail = order.customerEmail || resolvedEmail;\n\t\t\t\t\t// Map purchased tickets to OrderLine[] by grouping by ticketTypeId + ticketName\n\t\t\t\t\tconst tickets = order.purchasedTickets || order.tickets || [];\n\t\t\t\t\tconst grouped = new Map<string, OrderLine>();\n\n\t\t\t\t\tfor (const ticket of tickets) {\n\t\t\t\t\t\tconst key = `${ticket.ticketTypeId || ticket.ticketId || 0}-${ticket.ticketName || ticket.name || ''}`;\n\t\t\t\t\t\tconst existing = grouped.get(key);\n\t\t\t\t\t\tif (existing) {\n\t\t\t\t\t\t\texisting.quantity += 1;\n\t\t\t\t\t\t\texisting.subtotal += (ticket.purchasePrice || ticket.price || 0);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tgrouped.set(key, {\n\t\t\t\t\t\t\t\tticketId: ticket.ticketTypeId || ticket.ticketId || 0,\n\t\t\t\t\t\t\t\tticketName: ticket.ticketName || ticket.name || labels.ticketFallbackName || 'Ticket',\n\t\t\t\t\t\t\t\tquantity: 1,\n\t\t\t\t\t\t\t\tunitPrice: ticket.purchasePrice || ticket.price || 0,\n\t\t\t\t\t\t\t\tfee: 0,\n\t\t\t\t\t\t\t\tsubtotal: ticket.purchasePrice || ticket.price || 0,\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\torderLines = Array.from(grouped.values());\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tlogger.warn('Success: getOrder failed, using route params:', e);\n\t\t\t\t// Graceful degradation -- continue with whatever data we have\n\t\t\t}\n\t\t}\n\n\t\t// If no order lines from API, build a placeholder from route params\n\t\tif (orderLines.length === 0 && paramTicketCount > 0) {\n\t\t\torderLines = [{\n\t\t\t\tticketId: 0,\n\t\t\t\tticketName: labels.ticketFallbackName || 'Ticket',\n\t\t\t\tquantity: paramTicketCount,\n\t\t\t\tunitPrice: 0,\n\t\t\t\tfee: 0,\n\t\t\t\tsubtotal: 0,\n\t\t\t}];\n\t\t}\n\n\t\t// Build SuccessData\n\t\tsuccessData = {\n\t\t\tevent: eventData,\n\t\t\torderId: String(resolvedOrderId),\n\t\t\tlines: orderLines,\n\t\t\tcustomerEmail: resolvedEmail,\n\t\t};\n\n\t\t// Clear checkout cookies AFTER data is loaded (Pitfall 4)\n\t\tclearCheckoutCookies(String(id));\n\t\tremoveCookie('checkout-cartid');\n\n\t\tloading = false;\n\t});\n</script>\n\n{#if useLegacy && LegacyComponent}\n\t<LegacyComponent\n\t\t{data}\n\t\t{browseUrl}\n\t/>\n{:else if loadError}\n\t<div class=\"flex flex-col items-center justify-center py-24 text-center gap-4 error-container\">\n\t\t<p>{loadError}</p>\n\t</div>\n{:else if loading || !successData}\n\t<div class=\"flex items-center justify-center py-24 text-center loading-container\">\n\t\t<p>{labels.loadingYourOrder || 'Loading your order'}</p>\n\t</div>\n{:else}\n\t<SuccessMain data={successData} {eventUrl} />\n{/if}\n\n<style>\n\t.loading-container {\n\t\tcolor: hsl(var(--text-secondary, 215 16% 47%));\n\t}\n\n\t.error-container p {\n\t\tcolor: hsl(var(--status-sold-out, 0 72% 51%));\n\t}\n</style>\n"],"names":["labels","$","$$props","ticketCount","sum","l","headingText","Card","$$anchor","div","root_1","div_1","div_2","div_3","svg","div_4","div_5","Heading","node","Text","node_1","node_2","div_6","OrderSummary","node_3","div_7","node_4","div_8","Email","node_6","classes","classes_1","classes_2","calendarOpen","toggleCalendar","onMount","handleClickOutside","e","googleCalendarUrl","startDate","endDate","formatForGoogle","date","fullLocation","downloadICS","formatForICS","uid","now","escapeICS","str","icsContent","blob","url","link","safeFilename","handleGoogleCalendar","shareEvent","shareData","err","fallbackShare","handleAppleWallet","handleGoogleWallet","directionsUrl","locationParts","handleBackToEvent","root","fragment","img","Calendar","formatEventTime","$$render","consequent","formatBrowseDate","node_5","text_3","button","img_1","button_1","img_2","img_3","Button","ChevronDown","node_8","root_7","a","text_5","button_2","Apple","consequent_1","node_11","Share","LocationFilled","consequent_2","div_9","button_3","ArrowLeft","a_1","fragment_9","node_17","Help","consequent_3","dataVariant","toggleOptions","dataProp","eventUrlProp","mergedLabels","mergeLabels","isShowcaseMode","variantData","mockEvent","mockFreeEvent","mockRegistrationEvent","mockDonationEvent","current","orderTotals","lines","subtotal","fees","taxes","calculateTax","eventUrl","showCheckmark","showContent","reducedMotion","runAnimations","option","isActive","root_2","span","text","SuccessTicket","SuccessActions","logger","createLogger","useLegacy","LegacyComponent","m","data","browseUrl","successData","loadError","loading","id","slug","rawEvent","paramOrderId","paramOrderUuid","paramEmail","paramTicketCount","eventData","transformApiEvent","resolvedOrderId","resolvedEmail","orderLines","order","getOrder","tickets","grouped","ticket","key","existing","clearCheckoutCookies","removeCookie","LegacyComponent_1","p","root_3","p_1","SuccessMain","alternate"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Success.legacy--ABrtyII.js","sources":["../src/components/Views/Success.legacy.svelte"],"sourcesContent":["<script module>\n\timport { createLogger } from '@getmicdrop/svelte-components';\n\tconst logger = createLogger('Success.legacy');\n</script>\n\n<script>\n import { onMount } from 'svelte';\n import { transformEvent, getOrder } from '$lib/utils/utils.js';\n import { formatDateTime } from '@getmicdrop/svelte-components';\n import { CheckmarkFilled } from 'carbon-icons-svelte';\n import { ACCENT, DARK } from '$lib/constants/colors.ts';\n\n let { data = {}, eventUrl = '', browseUrl = '/' } = $props();\n\n const {\n organizationID,\n orgSlug,\n slug,\n event: rawEvent,\n orderId: providedOrderId,\n customerEmail: providedCustomerEmail,\n eventName: providedEventName,\n eventDateTime: providedEventDateTime,\n eventLocation: providedEventLocation,\n } = data || {};\n\n let event = null;\n if (rawEvent) {\n try {\n event = transformEvent(rawEvent);\n } catch (e) {\n logger.warn('transformEvent failed in Success component:', e);\n event = rawEvent;\n }\n }\n\n let order = null;\n let error = null;\n let Email = $state('');\n let id = $state('');\n let name = $state('');\n let time = $state('');\n let Location = $state('');\n let orderId = providedOrderId || data?.orderId || '';\n\n // Animation states\n let showConfetti = $state(false);\n let showTicket = $state(false);\n let showDetails = $state(false);\n\n function formatEventDateTime(dateTimeString) {\n if (!dateTimeString) return '';\n // Use event timezone if available, otherwise fall back to UTC\n const tz = event?.timeZone || 'UTC';\n return formatDateTime(dateTimeString, {\n weekday: 'short',\n hour12: true,\n timeZone: tz,\n });\n }\n\n // Generate confetti particles\n const confettiColors = [\n ACCENT.coral,\n ACCENT.sky.light,\n ACCENT.sky[400],\n ACCENT.mint[600],\n ACCENT.yellow[300],\n ACCENT.plum,\n ACCENT.mint[500],\n ACCENT.yellow[500],\n ];\n const confettiParticles = Array.from({ length: 50 }, (_, i) => ({\n id: i,\n color: confettiColors[Math.floor(Math.random() * confettiColors.length)],\n left: Math.random() * 100,\n delay: Math.random() * 0.5,\n duration: 2 + Math.random() * 2,\n size: 6 + Math.random() * 8,\n rotation: Math.random() * 360,\n }));\n\n onMount(async () => {\n // Start animations\n setTimeout(() => {\n showConfetti = true;\n }, 100);\n\n setTimeout(() => {\n showTicket = true;\n }, 300);\n\n setTimeout(() => {\n showDetails = true;\n }, 800);\n\n try {\n let orderData = null;\n try {\n if (typeof getOrder === 'function' && orderId) {\n orderData = await getOrder(orderId);\n }\n } catch (e) {\n logger.warn(\n 'getOrder failed in Success component, falling back to provided data:',\n e\n );\n }\n\n if (orderData) {\n order = orderData;\n Email = orderData.customerEmail || providedCustomerEmail || '';\n id = orderData.id || orderId;\n name = orderData.eventName || event?.name || providedEventName || '';\n time = formatEventDateTime(\n orderData.eventDateTime ||\n event?.startDateTime ||\n providedEventDateTime\n );\n Location =\n orderData.eventLocation ||\n event?.location ||\n providedEventLocation ||\n '';\n } else {\n Email = providedCustomerEmail || '';\n id = orderId;\n name = providedEventName || event?.name || '';\n time = formatEventDateTime(\n providedEventDateTime || event?.startDateTime\n );\n Location = providedEventLocation || event?.location || '';\n }\n } catch (err) {\n logger.error('Error fetching order data:', err);\n error = err.message;\n Email = providedCustomerEmail || 'your-email@example.com';\n id = orderId;\n name = event?.name || providedEventName || '';\n time = formatEventDateTime(event?.startDateTime || providedEventDateTime);\n Location = event?.location || providedEventLocation || '';\n }\n });\n</script>\n\n<div class=\"success-container\" role=\"main\" aria-labelledby=\"success-title\">\n <!-- Confetti -->\n {#if showConfetti}\n <div class=\"confetti-container\" aria-hidden=\"true\">\n {#each confettiParticles as particle (particle.id)}\n <div\n class=\"confetti\"\n style=\"\n left: {particle.left}%;\n background-color: {particle.color};\n animation-delay: {particle.delay}s;\n animation-duration: {particle.duration}s;\n width: {particle.size}px;\n height: {particle.size}px;\n transform: rotate({particle.rotation}deg);\n \"\n ></div>\n {/each}\n </div>\n {/if}\n\n <div class=\"content-wrapper\">\n <!-- Ticket Machine Animation -->\n <div class=\"ticket-machine\" class:animate={showTicket}>\n <!-- Machine slot -->\n <div class=\"machine-slot\">\n <div class=\"slot-inner\"></div>\n </div>\n\n <!-- Ticket coming out -->\n <div class=\"ticket\" class:slide-out={showTicket}>\n <div class=\"ticket-content\">\n <div class=\"ticket-header\">\n <div class=\"success-badge\" aria-hidden=\"true\">\n <CheckmarkFilled class=\"check-icon\" />\n </div>\n <h1 id=\"success-title\" class=\"success-title\">You're all set!</h1>\n <p class=\"success-subtitle\">Your tickets have been confirmed</p>\n </div>\n\n <div class=\"ticket-divider\">\n <div class=\"divider-notch left\"></div>\n <div class=\"divider-line\"></div>\n <div class=\"divider-notch right\"></div>\n </div>\n\n <dl\n class=\"ticket-details\"\n class:fade-in={showDetails}\n aria-label=\"Order details\"\n >\n <div class=\"detail-row\">\n <dt class=\"detail-label\">Email</dt>\n <dd class=\"detail-value\">{Email || 'Loading...'}</dd>\n </div>\n\n {#if id}\n <div class=\"detail-row\">\n <dt class=\"detail-label\">Order ID</dt>\n <dd class=\"detail-value order-id\">#{id}</dd>\n </div>\n {/if}\n\n {#if name}\n <div class=\"detail-row\">\n <dt class=\"detail-label\">Event</dt>\n <dd class=\"detail-value event-name\">{name}</dd>\n </div>\n {/if}\n\n {#if time}\n <div class=\"detail-row\">\n <dt class=\"detail-label\">When</dt>\n <dd class=\"detail-value\"><time>{time}</time></dd>\n </div>\n {/if}\n\n {#if Location}\n <div class=\"detail-row\">\n <dt class=\"detail-label\">Where</dt>\n <dd class=\"detail-value\">{Location}</dd>\n </div>\n {/if}\n </dl>\n\n <div class=\"ticket-footer\">\n <p class=\"footer-text\">Check your email for your tickets</p>\n </div>\n </div>\n\n <!-- Ticket stub pattern -->\n <div class=\"ticket-stub\"></div>\n </div>\n </div>\n\n <!-- Navigation CTAs -->\n {#if eventUrl || browseUrl}\n <nav class=\"nav-ctas\" class:fade-in={showDetails} aria-label=\"Next steps\">\n {#if eventUrl}\n <a href={eventUrl} class=\"nav-link secondary\">Back to event</a>\n {/if}\n {#if browseUrl}\n <a href={browseUrl} class=\"nav-link primary\">Browse more events</a>\n {/if}\n </nav>\n {/if}\n </div>\n</div>\n\n<style>\n .success-container {\n position: relative;\n min-height: 100vh;\n overflow: hidden;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 1.25rem;\n background: linear-gradient(\n 180deg,\n hsl(var(--bg-primary)) 0%,\n hsl(var(--bg-secondary)) 100%\n );\n\n &:is([data-theme=\"dark\"], [data-theme=\"dark\"] *) {\n background: linear-gradient(\n 180deg,\n hsl(var(--bg-primary)) 0%,\n hsl(var(--bg-primary)) 100%\n );\n }\n }\n\n /* Confetti */\n .confetti-container {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n height: 100%;\n pointer-events: none;\n overflow: hidden;\n }\n\n .confetti {\n position: absolute;\n top: -20px;\n border-radius: 2px;\n animation: confetti-fall linear forwards;\n }\n\n @keyframes confetti-fall {\n 0% {\n transform: translateY(0) rotate(0deg);\n opacity: 1;\n }\n\n 100% {\n transform: translateY(100vh) rotate(720deg);\n opacity: 0;\n }\n }\n\n /* Content wrapper */\n .content-wrapper {\n position: relative;\n z-index: var(--z-sticky);\n width: 100%;\n max-width: 380px;\n }\n\n /* Ticket machine */\n .ticket-machine {\n position: relative;\n display: flex;\n flex-direction: column;\n align-items: center;\n }\n\n .machine-slot {\n width: 100%;\n height: 16px;\n background: linear-gradient(\n 180deg,\n hsl(var(--muted)) 0%,\n hsl(var(--bg-primary)) 100%\n );\n border-radius: 8px 8px 0 0;\n display: flex;\n align-items: center;\n justify-content: center;\n box-shadow: 0 4px 12px color-mix(in srgb, black 20%, transparent);\n position: relative;\n z-index: var(--z-base);\n }\n\n .slot-inner {\n width: 80%;\n height: 4px;\n background: hsl(var(--bg-primary));\n border-radius: 2px;\n }\n\n /* Ticket */\n .ticket {\n width: 100%;\n background: hsl(var(--bg-primary));\n border-radius: 0 0 16px 16px;\n box-shadow: 0 8px 32px color-mix(in srgb, black 12%, transparent);\n overflow: hidden;\n transform: translateY(-100%);\n opacity: 0;\n transition:\n transform 0.8s cubic-bezier(0.34, 1.56, 0.64, 1),\n opacity 0.3s ease;\n }\n\n .ticket.slide-out {\n transform: translateY(0);\n opacity: 1;\n }\n\n .ticket-content {\n padding: 32px 24px 24px;\n }\n\n .ticket-header {\n text-align: center;\n margin-bottom: 24px;\n }\n\n .success-badge {\n width: 64px;\n height: 64px;\n background: linear-gradient(\n 135deg,\n hsl(var(--accent-success)) 0%,\n hsl(var(--accent-success)) 100%\n );\n border-radius: 50%;\n display: flex;\n align-items: center;\n justify-content: center;\n margin: 0 auto 16px;\n animation: badge-pop 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) 0.5s both;\n }\n\n @keyframes badge-pop {\n 0% {\n transform: scale(0);\n }\n\n 100% {\n transform: scale(1);\n }\n }\n\n .success-badge :global(.check-icon) {\n width: 32px;\n height: 32px;\n color: hsl(var(--bg-primary));\n }\n\n .success-title {\n font-size: 1.5rem;\n line-height: 2rem;\n font-weight: 600;\n color: hsl(var(--text-primary));\n margin-bottom: 0.5rem;\n }\n\n .success-subtitle {\n font-size: 0.875rem;\n line-height: 1.25rem;\n color: hsl(var(--text-secondary));\n margin: 0;\n }\n\n /* Ticket divider */\n .ticket-divider {\n position: relative;\n display: flex;\n align-items: center;\n margin: 0 -24px 24px;\n padding: 0 24px;\n }\n\n .divider-notch {\n width: 1rem;\n height: 1rem;\n border-radius: 9999px;\n position: absolute;\n background-color: hsl(var(--bg-primary));\n }\n\n .divider-notch.left {\n left: -8px;\n }\n\n .divider-notch.right {\n right: -8px;\n }\n\n .divider-line {\n flex: 1 1 0%;\n height: 0.125rem;\n background: repeating-linear-gradient(\n 90deg,\n hsl(var(--stroke-primary)) 0,\n hsl(var(--stroke-primary)) 8px,\n transparent 8px,\n transparent 16px\n );\n\n &:is([data-theme=\"dark\"], [data-theme=\"dark\"] *) {\n background: repeating-linear-gradient(\n 90deg,\n hsl(var(--text-secondary)) 0,\n hsl(var(--text-secondary)) 8px,\n transparent 8px,\n transparent 16px\n );\n }\n }\n\n /* Ticket details */\n .ticket-details {\n opacity: 0;\n transform: translateY(10px);\n transition:\n opacity 0.4s ease,\n transform 0.4s ease;\n }\n\n .ticket-details.fade-in {\n opacity: 1;\n transform: translateY(0);\n }\n\n .detail-row {\n display: flex;\n flex-direction: column;\n gap: 0.25rem;\n padding-top: 0.75rem;\n padding-bottom: 0.75rem;\n border-bottom: 1px solid hsl(var(--stroke-primary) / 50%);\n }\n\n .detail-row:last-child {\n border-bottom: 0;\n }\n\n .detail-label {\n font-size: 0.75rem;\n line-height: 1rem;\n font-weight: 600;\n color: hsl(var(--text-tertiary));\n text-transform: uppercase;\n letter-spacing: 0.025em;\n }\n\n .detail-value {\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 500;\n color: hsl(var(--text-primary));\n overflow-wrap: break-word;\n }\n\n .detail-value.order-id {\n color: hsl(var(--brand-primary));\n font-family: 'SF Mono', Consolas, monospace;\n }\n\n .detail-value.event-name {\n font-size: 1rem;\n line-height: 1.5rem;\n font-weight: 600;\n }\n\n /* Ticket footer */\n .ticket-footer {\n margin-top: 1.5rem;\n padding: 1rem;\n border-radius: 0.5rem;\n text-align: center;\n background-color: hsl(var(--bg-secondary) / 50%);\n }\n\n .footer-text {\n font-size: 0.875rem;\n line-height: 1.25rem;\n color: hsl(var(--text-secondary));\n margin: 0;\n }\n\n /* Ticket stub pattern */\n .ticket-stub {\n height: 1.5rem;\n background: linear-gradient(\n 90deg,\n transparent 0,\n transparent 8px,\n hsl(var(--stroke-primary) / 30%) 8px,\n hsl(var(--stroke-primary) / 30%) 16px\n );\n background-size: 16px 100%;\n }\n\n /* Navigation CTAs */\n .nav-ctas {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n margin-top: 1.5rem;\n opacity: 0;\n transform: translateY(10px);\n transition:\n opacity 0.4s ease 0.2s,\n transform 0.4s ease 0.2s;\n }\n\n .nav-ctas.fade-in {\n opacity: 1;\n transform: translateY(0);\n }\n\n .nav-link {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0.75rem 1rem;\n border-radius: 0.5rem;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n text-decoration: none;\n transition:\n background-color 0.15s,\n color 0.15s;\n }\n\n .nav-link.primary {\n background: hsl(var(--brand-primary, 220 90% 56%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n .nav-link.primary:hover {\n filter: brightness(0.95);\n }\n\n .nav-link.secondary {\n background-color: hsl(var(--bg-tertiary));\n color: hsl(var(--text-secondary));\n }\n\n .nav-link.secondary:hover {\n background-color: hsl(var(--bg-quaternary));\n }\n\n /* Responsive */\n @media (width <= 480px) {\n .success-container {\n padding: 16px;\n }\n\n .ticket-content {\n padding: 24px 20px 20px;\n }\n\n .success-title {\n font-size: 20px;\n }\n\n .success-badge {\n width: 56px;\n height: 56px;\n }\n\n .success-badge :global(.check-icon) {\n width: 28px;\n height: 28px;\n }\n }\n</style>\n"],"names":["logger","createLogger","data","$","$$props","eventUrl","browseUrl","organizationID","orgSlug","slug","rawEvent","providedOrderId","providedCustomerEmail","providedEventName","providedEventDateTime","providedEventLocation","event","transformEvent","e","order","Email","id","name","time","Location","orderId","showConfetti","showTicket","showDetails","formatEventDateTime","dateTimeString","tz","formatDateTime","confettiColors","ACCENT","confettiParticles","_","i","onMount","orderData","getOrder","err","div","root","div_1","root_1","particle","$$anchor","div_2","root_2","$$render","consequent","div_3","node","div_4","div_5","div_6","div_7","div_8","CheckmarkFilled","node_1","dl","div_9","dd","div_10","root_3","dd_1","consequent_1","div_11","root_4","dd_2","consequent_2","div_12","root_5","dd_3","time_1","consequent_3","div_13","root_6","dd_4","consequent_4","nav","root_7","a","root_8","consequent_5","a_1","root_9","consequent_6","classes_3","consequent_7","classes","classes_1","classes_2","text"],"mappings":"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"}