@getmicdrop/venue-calendar 4.0.9 → 4.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +700 -700
- package/dist/{AirbnbSplitMain-BF9Md8qq.js → AirbnbSplitMain-BwFA51F6.js} +4 -4
- package/dist/AirbnbSplitMain-BwFA51F6.js.map +1 -0
- package/dist/{CarouselView.legacy-BFGIAx7l.js → CarouselView.legacy-BHeZe5LX.js} +3 -3
- package/dist/CarouselView.legacy-BHeZe5LX.js.map +1 -0
- package/dist/CartView-BUzE0wp2.js +1682 -0
- package/dist/CartView-BUzE0wp2.js.map +1 -0
- package/dist/{Checkout-CpPb5Ifu.js → Checkout-pzohnvrX.js} +4 -4
- package/dist/Checkout-pzohnvrX.js.map +1 -0
- package/dist/{Checkout.legacy-C9yyEf3S.js → Checkout.legacy-ZKJN-dMX.js} +4 -4
- package/dist/Checkout.legacy-ZKJN-dMX.js.map +1 -0
- package/dist/CheckoutMain-5LdQDph1.js +1436 -0
- package/dist/CheckoutMain-5LdQDph1.js.map +1 -0
- package/dist/{CheckoutTimer-DJnOIPo_.js → CheckoutTimer-D6LfPX7c.js} +2 -2
- package/dist/CheckoutTimer-D6LfPX7c.js.map +1 -0
- package/dist/{CollectionView-CYrzlsQM.js → CollectionView-BwQTF9Df.js} +5 -5
- package/dist/CollectionView-BwQTF9Df.js.map +1 -0
- package/dist/{CollectionView.legacy-Dps9inGG.js → CollectionView.legacy-Cz6XX6Ly.js} +3 -3
- package/dist/CollectionView.legacy-Cz6XX6Ly.js.map +1 -0
- package/dist/{EventDetailsView-DBbu150l.js → EventDetailsView-Cp5IRJam.js} +2 -2
- package/dist/EventDetailsView-Cp5IRJam.js.map +1 -0
- package/dist/{FeaturedView.legacy-BrtaOt9e.js → FeaturedView.legacy-DKOl806x.js} +2 -2
- package/dist/FeaturedView.legacy-DKOl806x.js.map +1 -0
- package/dist/{GalleryCard-jocj0pr5.js → GalleryCard-MO80JCq7.js} +2 -2
- package/dist/GalleryCard-MO80JCq7.js.map +1 -0
- package/dist/{GalleryView.legacy-HgqtBg4h.js → GalleryView.legacy-pSihGXaa.js} +3 -3
- package/dist/GalleryView.legacy-pSihGXaa.js.map +1 -0
- package/dist/{GroupedListView.legacy-DOE0hObl.js → GroupedListView.legacy-CC1kcrgF.js} +2 -2
- package/dist/GroupedListView.legacy-CC1kcrgF.js.map +1 -0
- package/dist/OrderSummarySkeleton-dDKUH741.js.map +1 -1
- package/dist/{SeriesPage-CpmkUQkM.js → SeriesPage-rUuL4Pdb.js} +5 -5
- package/dist/SeriesPage-rUuL4Pdb.js.map +1 -0
- package/dist/{SeriesPage.legacy-DdBGxKik.js → SeriesPage.legacy-BxPGQaCo.js} +2 -2
- package/dist/SeriesPage.legacy-BxPGQaCo.js.map +1 -0
- package/dist/{Success-CFFLbHnY.js → Success-BAHe8E_8.js} +5 -5
- package/dist/Success-BAHe8E_8.js.map +1 -0
- package/dist/{Success.legacy-CbRz2zxG.js → Success.legacy-COO3pzj4.js} +2 -2
- package/dist/Success.legacy-COO3pzj4.js.map +1 -0
- package/dist/{VenueCalendar-DUIJZSTv.js → VenueCalendar-Djc3e2j2.js} +14 -14
- package/dist/{VenueCalendar-DUIJZSTv.js.map → VenueCalendar-Djc3e2j2.js.map} +1 -1
- package/dist/{ViewTicketsEmbed-BtskVW7X.js → ViewTicketsEmbed-CBk3cg3u.js} +2 -2
- package/dist/ViewTicketsEmbed-CBk3cg3u.js.map +1 -0
- package/dist/api/api.cjs.map +1 -1
- package/dist/api/api.mjs.map +1 -1
- package/dist/api/types.d.ts +357 -357
- package/dist/colors-BZoMuXdh.js.map +1 -1
- package/dist/{labels-yD6EDNLO.js → labels-DySnOPVE.js} +2 -2
- package/dist/labels-DySnOPVE.js.map +1 -0
- package/dist/seo/seo.cjs.map +1 -1
- package/dist/seo/seo.mjs.map +1 -1
- package/dist/seo/types.d.ts +137 -137
- package/dist/{transform-D00wPQAM.js → transform-DKVmquzJ.js} +2 -2
- package/dist/transform-DKVmquzJ.js.map +1 -0
- package/dist/types/index.d.ts +387 -387
- package/dist/venue-calendar.es.js +1 -1
- package/dist/venue-calendar.iife.js +37 -37
- package/dist/venue-calendar.iife.js.map +1 -1
- package/dist/venue-calendar.umd.js +37 -37
- package/dist/venue-calendar.umd.js.map +1 -1
- package/package.json +1 -1
- package/src/lib/theme.js +222 -222
- package/dist/AirbnbSplitMain-BF9Md8qq.js.map +0 -1
- package/dist/CarouselView.legacy-BFGIAx7l.js.map +0 -1
- package/dist/CartView-C_4nNeRc.js +0 -1675
- package/dist/CartView-C_4nNeRc.js.map +0 -1
- package/dist/Checkout-CpPb5Ifu.js.map +0 -1
- package/dist/Checkout.legacy-C9yyEf3S.js.map +0 -1
- package/dist/CheckoutMain-BRBejJSN.js +0 -1422
- package/dist/CheckoutMain-BRBejJSN.js.map +0 -1
- package/dist/CheckoutTimer-DJnOIPo_.js.map +0 -1
- package/dist/CollectionView-CYrzlsQM.js.map +0 -1
- package/dist/CollectionView.legacy-Dps9inGG.js.map +0 -1
- package/dist/EventDetailsView-DBbu150l.js.map +0 -1
- package/dist/FeaturedView.legacy-BrtaOt9e.js.map +0 -1
- package/dist/GalleryCard-jocj0pr5.js.map +0 -1
- package/dist/GalleryView.legacy-HgqtBg4h.js.map +0 -1
- package/dist/GroupedListView.legacy-DOE0hObl.js.map +0 -1
- package/dist/SeriesPage-CpmkUQkM.js.map +0 -1
- package/dist/SeriesPage.legacy-DdBGxKik.js.map +0 -1
- package/dist/Success-CFFLbHnY.js.map +0 -1
- package/dist/Success.legacy-CbRz2zxG.js.map +0 -1
- package/dist/ViewTicketsEmbed-BtskVW7X.js.map +0 -1
- package/dist/labels-yD6EDNLO.js.map +0 -1
- package/dist/transform-D00wPQAM.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheckoutMain-5LdQDph1.js","sources":["../__SKIP_ENVIRONMENT__","../node_modules/@getmicdrop/svelte-components/dist/stripe/useStripeTheme.svelte.js","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutForm.svelte","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutSidebar.svelte","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutMobileFooter.svelte","../src/lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutMain.svelte"],"sourcesContent":["\n export const browser = typeof window !== 'undefined';\n export const dev = false;\n export const building = false;\n export const version = '';\n ","/**\n * Stripe Theme Utility\n *\n * Provides reactive dark mode detection for Stripe Elements.\n * Automatically watches for theme changes via MutationObserver.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n *\n * const stripeTheme = useStripeTheme();\n * // stripeTheme.current is 'stripe' | 'night'\n * // Automatically updates when theme changes\n * </script>\n *\n * <Elements theme={stripeTheme.current} {stripe} clientSecret={paymentIntent}>\n * <PaymentElement />\n * </Elements>\n * ```\n */\nimport { onMount, onDestroy } from 'svelte';\n/**\n * Detects if dark mode is active.\n *\n * Checks in order:\n * 1. localStorage 'theme' value\n * 2. Container element classes (.dark, [data-theme=\"dark\"])\n * 3. System preference (prefers-color-scheme)\n */\nexport function detectDarkMode(containerSelector) {\n if (typeof window === 'undefined')\n return false;\n try {\n // Check localStorage first\n const saved = localStorage.getItem('theme');\n if (saved === 'dark')\n return true;\n if (saved === 'light')\n return false;\n // Check for data-theme on common containers\n const selector = containerSelector || '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]';\n const containers = document.querySelectorAll(selector);\n for (const container of containers) {\n if (container.getAttribute('data-theme') === 'dark')\n return true;\n }\n // Check document root\n if (document.documentElement.getAttribute('data-theme') === 'dark')\n return true;\n // Fallback to system preference\n return window.matchMedia?.('(prefers-color-scheme: dark)')?.matches ?? false;\n }\n catch {\n return false;\n }\n}\n/**\n * Maps dark mode state to Stripe theme.\n */\nexport function getStripeTheme(isDark) {\n return isDark ? 'night' : 'stripe';\n}\n/**\n * Creates a reactive Stripe theme that watches for dark mode changes.\n *\n * Returns an object with a `current` property that is reactive and\n * automatically updates when the theme changes.\n *\n * @example\n * ```svelte\n * <script>\n * import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n * const stripeTheme = useStripeTheme();\n * </script>\n *\n * <Elements theme={stripeTheme.current} ...>\n * ```\n */\nexport function useStripeTheme(options = {}) {\n const { containerSelector = '[data-theme=\"dark\"], [data-theme=\"light\"], .micdrop, [data-theme]', watchChanges = true, fallback = 'stripe', } = options;\n let current = $state(fallback);\n let observer = null;\n function updateTheme() {\n current = getStripeTheme(detectDarkMode(containerSelector));\n }\n onMount(() => {\n // Initial detection\n updateTheme();\n if (watchChanges && typeof MutationObserver !== 'undefined') {\n // Watch for class changes on potential theme containers\n const containers = document.querySelectorAll(containerSelector);\n const root = document.documentElement;\n observer = new MutationObserver(() => {\n updateTheme();\n });\n // Observe document root\n observer.observe(root, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n // Observe other containers\n containers.forEach(container => {\n observer?.observe(container, {\n attributes: true,\n attributeFilter: ['class', 'data-theme'],\n });\n });\n // Also listen for system preference changes\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)');\n mediaQuery.addEventListener('change', updateTheme);\n }\n });\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n observer = null;\n }\n });\n return {\n get current() {\n return current;\n },\n /** Force refresh the theme detection */\n refresh: updateTheme,\n };\n}\n/**\n * Simple synchronous dark mode detection without reactivity.\n * Use this when you only need a one-time check.\n */\nexport function getInitialStripeTheme(containerSelector) {\n return getStripeTheme(detectDarkMode(containerSelector));\n}\n","<script lang=\"ts\">\n import { onMount, onDestroy } from 'svelte';\n import { browser } from '$app/environment';\n import { ChevronLeft, Warning } from 'carbon-icons-svelte';\n import {\n Button,\n Heading,\n Text,\n Input,\n Checkbox,\n } from '@getmicdrop/svelte-components';\n import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n import type {\n EventData,\n OrderTotals,\n CheckoutFormData,\n } from '$lib/premium-ticket-experience/types';\n import CheckoutTimer from './CheckoutTimer.svelte';\n\n interface Props {\n event: EventData;\n orderTotals: OrderTotals;\n timerSeconds: number;\n isExpired: boolean;\n isRegistration: boolean;\n isFreeOrder: boolean;\n promoApplied: boolean;\n promoDiscount: number;\n onBack: () => void;\n onPlaceOrder: (formData: CheckoutFormData) => void;\n processing: boolean;\n /** Incremented by parent to trigger form validation + submit from external buttons (sidebar, mobile footer) */\n submitRequested: number;\n /** Stripe instance for production mode (absence = showcase mock inputs) */\n stripe?: any;\n /** Stripe client secret for PaymentElement */\n paymentIntent?: string;\n /** Bindable Stripe elements reference for the wrapper to use during payment confirmation */\n elements?: any;\n /** Payment error message from the wrapper */\n paymentError?: string;\n labels?: Record<string, string>;\n }\n\n let {\n event,\n orderTotals,\n timerSeconds,\n isExpired,\n isRegistration,\n isFreeOrder,\n promoApplied,\n promoDiscount,\n onBack,\n onPlaceOrder,\n processing,\n submitRequested,\n stripe = undefined,\n paymentIntent = undefined,\n elements = $bindable(undefined),\n paymentError = '',\n labels = {},\n }: Props = $props();\n\n // Use direct Stripe.js API instead of svelte-stripe (Svelte 5 compatibility bug).\n const stripeTheme = browser ? useStripeTheme() : { current: \"stripe\" as const };\n let paymentMountDiv = $state<HTMLElement | null>(null);\n let paymentElement: any = null;\n let stripeMounted = $state(false);\n\n function mountStripePayment() {\n if (\n !browser ||\n !stripe ||\n !paymentIntent ||\n !paymentMountDiv ||\n stripeMounted\n )\n return;\n elements = stripe.elements({\n clientSecret: paymentIntent,\n appearance: { theme: stripeTheme.current },\n });\n paymentElement = elements.create('payment');\n paymentElement.mount(paymentMountDiv);\n stripeMounted = true;\n }\n\n $effect(() => {\n if (stripe && paymentIntent && paymentMountDiv && !stripeMounted) {\n mountStripePayment();\n }\n });\n\n // Re-skin Stripe Elements when the theme changes (data-theme toggle).\n $effect(() => {\n if (stripeMounted && elements && stripeTheme.current) {\n try {\n elements.update({ appearance: { theme: stripeTheme.current } });\n } catch (_) {\n // Stripe Elements is finicky about post-mount updates; ignore.\n }\n }\n });\n\n onDestroy(() => {\n if (paymentElement) {\n paymentElement.destroy();\n paymentElement = null;\n }\n stripeMounted = false;\n });\n\n // --- Form state ---\n let firstName = $state('');\n let lastName = $state('');\n let email = $state('');\n let keepUpdated = $state(false);\n let agreeTerms = $state(false);\n\n // Payment fields (mock)\n let cardNumber = $state('');\n let cardExpiry = $state('');\n let cardCvc = $state('');\n\n // Per-ticket attendee fields (for registration events)\n let attendees = $state<\n Array<{\n firstName: string;\n lastName: string;\n email: string;\n sameAsPurchaser: boolean;\n }>\n >([]);\n\n // Validation state\n let submitted = $state(false);\n let errors = $derived(\n (() => {\n if (!submitted) return {};\n const e: Record<string, string> = {};\n if (!firstName.trim())\n e.firstName = labels.firstNameRequired || 'First name is required';\n if (!lastName.trim())\n e.lastName = labels.lastNameRequired || 'Last name is required';\n if (!email.trim()) e.email = labels.emailRequired || 'Email is required';\n else if (!/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(email))\n e.email = labels.emailInvalid || 'Enter a valid email address';\n if (!isFreeOrder && !stripe) {\n // Only validate mock card fields in showcase mode\n if (!cardNumber.trim())\n e.cardNumber = labels.cardNumberRequired || 'Card number is required';\n if (!cardExpiry.trim())\n e.cardExpiry = labels.expiryRequired || 'Expiry date is required';\n if (!cardCvc.trim())\n e.cardCvc = labels.cvcRequired || 'CVC is required';\n }\n if (!agreeTerms)\n e.agreeTerms = labels.mustAgreeTerms || 'You must agree to the terms';\n\n // Validate attendee fields for registration events\n if (isRegistration) {\n for (let i = 0; i < attendees.length; i++) {\n const att = attendees[i];\n if (!att.sameAsPurchaser) {\n if (!att.firstName.trim())\n e[`attendee_${i}_firstName`] = 'First name is required';\n if (!att.lastName.trim())\n e[`attendee_${i}_lastName`] = 'Last name is required';\n if (!att.email.trim())\n e[`attendee_${i}_email`] =\n labels.emailRequired || 'Email is required';\n else if (!/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(att.email))\n e[`attendee_${i}_email`] =\n labels.emailInvalidShort || 'Enter a valid email';\n }\n }\n }\n\n return e;\n })()\n );\n\n let hasErrors = $derived(Object.keys(errors).length > 0);\n\n let isTimerUrgent = $derived(timerSeconds > 0 && timerSeconds <= 120);\n\n // Initialize attendee list based on order lines\n $effect(() => {\n if (isRegistration) {\n const totalTickets = orderTotals.lines.reduce(\n (sum, l) => sum + l.quantity,\n 0\n );\n if (attendees.length !== totalTickets) {\n attendees = Array.from({ length: totalTickets }, (_, i) => ({\n firstName: '',\n lastName: '',\n email: '',\n sameAsPurchaser: i === 0,\n }));\n }\n }\n });\n\n // Watch for external submit requests (from sidebar/mobile footer buttons)\n let lastSubmitRequest = $state(0);\n $effect(() => {\n if (submitRequested > lastSubmitRequest) {\n lastSubmitRequest = submitRequested;\n handleSubmit();\n }\n });\n\n function handleSameAsPurchaser(index: number, checked: boolean) {\n attendees = attendees.map((att, i) => {\n if (i !== index) return att;\n return {\n ...att,\n sameAsPurchaser: checked,\n firstName: checked ? firstName : att.firstName,\n lastName: checked ? lastName : att.lastName,\n email: checked ? email : att.email,\n };\n });\n }\n\n function handleSubmit() {\n submitted = true;\n if (hasErrors) return;\n onPlaceOrder({\n firstName,\n lastName,\n email,\n keepMeUpdated: keepUpdated,\n attendees: isRegistration\n ? attendees.map(a => ({\n firstName: a.sameAsPurchaser ? firstName : a.firstName,\n lastName: a.sameAsPurchaser ? lastName : a.lastName,\n email: a.sameAsPurchaser ? email : a.email,\n sameAsPurchaser: a.sameAsPurchaser,\n }))\n : undefined,\n });\n }\n</script>\n\n<div class=\"space-y-6\">\n <!-- Timer header bar -->\n <div class=\"timer-header border-default bg-surface-secondary\">\n <Button\n variant=\"icon\"\n size=\"icon-sm\"\n onclick={onBack}\n aria-label={labels.goBack || 'Go back'}\n >\n <ChevronLeft size={20} />\n </Button>\n <CheckoutTimer seconds={timerSeconds} isUrgent={isTimerUrgent} />\n </div>\n\n <!-- Personal details -->\n <section class=\"space-y-4\">\n <Heading level={2} size=\"lg\" weight=\"semibold\">\n {labels.yourDetails || 'Your details'}\n </Heading>\n\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-4\">\n <Input\n label={labels.firstName || 'First name'}\n placeholder={labels.firstName || 'First name'}\n required\n bind:value={firstName}\n errorText={errors.firstName ?? ''}\n color={errors.firstName ? 'red' : 'base'}\n />\n <Input\n label={labels.lastName || 'Last name'}\n placeholder={labels.lastName || 'Last name'}\n required\n bind:value={lastName}\n errorText={errors.lastName ?? ''}\n color={errors.lastName ? 'red' : 'base'}\n />\n </div>\n\n <Input\n label={labels.emailAddress || 'Email address'}\n type=\"email\"\n placeholder={labels.emailPlaceholder || 'you@example.com'}\n required\n bind:value={email}\n errorText={errors.email ?? ''}\n color={errors.email ? 'red' : 'base'}\n />\n\n <Checkbox bind:checked={keepUpdated}>\n {labels.keepMeUpdated ||\n 'Keep me updated about this event and similar events'}\n </Checkbox>\n </section>\n\n <!-- Per-ticket attendee details (registration events) -->\n {#if isRegistration && attendees.length > 0}\n <section class=\"space-y-5\">\n <Heading level={2} size=\"lg\" weight=\"semibold\">\n {labels.attendeeDetails || 'Attendee details'}\n </Heading>\n\n {#each attendees as attendee, i}\n <div class=\"attendee-card border-default bg-surface-secondary\">\n <div class=\"flex items-center justify-between mb-3\">\n <Text size=\"sm\" class=\"font-semibold\">\n {labels.attendee || 'Attendee'}\n {i + 1}\n </Text>\n <Checkbox\n checked={attendee.sameAsPurchaser}\n onchange={({ checked }) => handleSameAsPurchaser(i, checked)}\n >\n {labels.sameAsPurchaser || 'Same as purchaser'}\n </Checkbox>\n </div>\n\n <div class=\"space-y-3\">\n <div class=\"grid grid-cols-1 sm:grid-cols-2 gap-3\">\n <Input\n label={labels.firstName || 'First name'}\n placeholder={labels.firstName || 'First name'}\n required\n disabled={attendee.sameAsPurchaser}\n bind:value={attendee.firstName}\n errorText={!attendee.sameAsPurchaser\n ? (errors[`attendee_${i}_firstName`] ?? '')\n : ''}\n color={!attendee.sameAsPurchaser &&\n errors[`attendee_${i}_firstName`]\n ? 'red'\n : 'base'}\n />\n <Input\n label={labels.lastName || 'Last name'}\n placeholder={labels.lastName || 'Last name'}\n required\n disabled={attendee.sameAsPurchaser}\n bind:value={attendee.lastName}\n errorText={!attendee.sameAsPurchaser\n ? (errors[`attendee_${i}_lastName`] ?? '')\n : ''}\n color={!attendee.sameAsPurchaser &&\n errors[`attendee_${i}_lastName`]\n ? 'red'\n : 'base'}\n />\n </div>\n <Input\n label={labels.email || 'Email'}\n type=\"email\"\n placeholder={labels.attendeeEmailPlaceholder ||\n 'attendee@example.com'}\n required\n disabled={attendee.sameAsPurchaser}\n bind:value={attendee.email}\n errorText={!attendee.sameAsPurchaser\n ? (errors[`attendee_${i}_email`] ?? '')\n : ''}\n color={!attendee.sameAsPurchaser && errors[`attendee_${i}_email`]\n ? 'red'\n : 'base'}\n />\n </div>\n </div>\n {/each}\n </section>\n {/if}\n\n <!-- Payment section -->\n <section class=\"space-y-4\">\n {#if isFreeOrder}\n <div class=\"free-order-notice border-default bg-surface-secondary\">\n <Text size=\"sm\" color=\"secondary\" class=\"font-medium block\">\n {labels.noPaymentRequired || 'No payment required'}\n </Text>\n <Text size=\"xs\" color=\"muted\" class=\"block mt-1\">\n {labels.freeEventMessage ||\n 'This is a free event. Complete the form above to reserve your spot.'}\n </Text>\n </div>\n {:else if stripe && paymentIntent}\n <!-- Production: Real Stripe PaymentElement -->\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\n {#if browser}\n <div bind:this={paymentMountDiv}></div>\n {#if !stripeMounted}\n <p class=\"text-sm text-color-muted py-2\">\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\n </p>\n {/if}\n {:else}\n <p class=\"text-sm text-color-muted py-2\">\n {labels.loadingPaymentForm || 'Loading secure payment form...'}\n </p>\n {/if}\n {#if paymentError}\n <p class=\"text-sm text-accent-danger mt-2\">{paymentError}</p>\n {/if}\n {:else}\n <!-- Showcase: Mock card inputs -->\n <Heading level={2} size=\"lg\" weight=\"semibold\">Payment</Heading>\n\n <Input\n label={labels.cardNumber || 'Card number'}\n placeholder={labels.cardPlaceholder || '4242 4242 4242 4242'}\n type=\"creditCardNumber\"\n required\n bind:value={cardNumber}\n errorText={errors.cardNumber ?? ''}\n color={errors.cardNumber ? 'red' : 'base'}\n />\n\n <div class=\"grid grid-cols-2 gap-4\">\n <Input\n label={labels.expiryDate || 'Expiry date'}\n placeholder={labels.expiryPlaceholder || 'MM / YY'}\n required\n bind:value={cardExpiry}\n errorText={errors.cardExpiry ?? ''}\n color={errors.cardExpiry ? 'red' : 'base'}\n />\n <Input\n label={labels.cvc || 'CVC'}\n placeholder={labels.cvcPlaceholder || '123'}\n required\n maxlength={4}\n bind:value={cardCvc}\n errorText={errors.cardCvc ?? ''}\n color={errors.cardCvc ? 'red' : 'base'}\n />\n </div>\n {/if}\n </section>\n\n <!-- Terms -->\n <section class=\"space-y-2\">\n <Checkbox bind:checked={agreeTerms}>\n {labels.agreeToTerms || 'I agree to the terms and conditions'}\n </Checkbox>\n {#if errors.agreeTerms}\n <div class=\"flex items-center gap-1.5\">\n <Warning size={16} class=\"text-accent-danger shrink-0\" />\n <Text size=\"xs\" class=\"text-accent-danger\">{errors.agreeTerms}</Text>\n </div>\n {/if}\n </section>\n\n <!-- Mobile submit is handled by CheckoutMobileFooter -->\n</div>\n\n<style>\n .timer-header {\n display: flex;\n align-items: center;\n gap: 0.75rem;\n padding: 0.75rem 1rem;\n margin-left: -1rem;\n margin-right: -1rem;\n border-bottom-width: 1px;\n border-bottom-style: solid;\n border-radius: 0.5rem 0.5rem 0 0;\n }\n\n .attendee-card {\n padding: 1rem;\n border-radius: 0.5rem;\n border-width: 1px;\n border-style: solid;\n }\n\n .free-order-notice {\n padding: 1rem;\n border-radius: 0.5rem;\n border-width: 1px;\n border-style: solid;\n }\n</style>\n","<script lang=\"ts\">\n\timport type { USD } from '@getmicdrop/svelte-components';\nimport { Calendar } from 'carbon-icons-svelte';\n\timport { Button, Card, Text, formatCurrency } from '@getmicdrop/svelte-components';\n\timport type { EventData, OrderTotals } from '$lib/premium-ticket-experience/types';\n\timport { formatBrowseDate, formatEventTime } from '$lib/premium-ticket-experience/defaults';\n\timport OrderSummary from './OrderSummary.svelte';\n\n\tinterface Props {\n\t\tevent: EventData;\n\t\torderTotals: OrderTotals;\n\t\tisFreeOrder: boolean;\n\t\tonPlaceOrder: () => void;\n\t\tprocessing: boolean;\n\t\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet { event, orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\n</script>\n\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\n\t<div class=\"p-5 space-y-4\">\n\t\t<!-- Event info -->\n\t\t<div class=\"flex gap-3\">\n\t\t\t<div class=\"shrink-0 w-20 h-14 rounded-lg overflow-hidden bg-surface-tertiary\">\n\t\t\t\t<img\n\t\t\t\t\tsrc={event.imageUrl}\n\t\t\t\t\talt={event.title}\n\t\t\t\t\tclass=\"w-full h-full object-contain\"\n\t\t\t\t/>\n\t\t\t</div>\n\t\t\t<div class=\"flex-1 min-w-0\">\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight line-clamp-2\">\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\">\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· {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\t\t</div>\n\n\t\t<!-- Divider -->\n\t\t<div class=\"divider\"></div>\n\n\t\t<!-- Order summary -->\n\t\t<OrderSummary {orderTotals}\n\t\t\t\t{labels} />\n\n\t\t<!-- Place order button -->\n\t\t<Button\n\t\t\tvariant=\"default\"\n\t\t\tsize=\"lg\"\n\t\t\tclass=\"w-full\"\n\t\t\tdisabled={processing}\n\t\t\tloading={processing}\n\t\t\tonclick={onPlaceOrder}\n\t\t>\n\t\t\t{#if processing}\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\n\t\t\t{:else if isFreeOrder}\n\t\t\t\t{labels.completeOrder || 'Complete order'} · {labels.free || 'Free'}\n\t\t\t{:else}\n\t\t\t\t{labels.placeOrder || 'Place order'} · {formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}\n\t\t\t{/if}\n\t\t</Button>\n\t</div>\n</Card>\n","<script lang=\"ts\">\n\timport type { USD } from '@getmicdrop/svelte-components';\nimport { Button, Text, formatCurrency } from '@getmicdrop/svelte-components';\n\timport type { OrderTotals } from '$lib/premium-ticket-experience/types';\n\n\tinterface Props {\n\t\torderTotals: OrderTotals;\n\t\tisFreeOrder: boolean;\n\t\tonPlaceOrder: () => void;\n\t\tprocessing: boolean;\n\t\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet { orderTotals, isFreeOrder, onPlaceOrder, processing, labels = {}, }: Props = $props();\n\n\tlet totalTicketCount = $derived(\n\t\torderTotals.lines.reduce((sum, l) => sum + l.quantity, 0)\n\t);\n</script>\n\n<div\n\tclass=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-surface-primary border-t border-default shadow-lg\"\n\tstyle=\"padding-bottom: env(safe-area-inset-bottom, 0);\"\n>\n\t<div class=\"flex items-center justify-between gap-3 px-4 py-3\">\n\t\t<!-- Left: total info -->\n\t\t<div class=\"flex-1 min-w-0\">\n\t\t\t<Text size=\"sm\" class=\"font-semibold tabular-nums block\">\n\t\t\t\t{#if isFreeOrder}\n\t\t\t\t\t{totalTicketCount} {totalTicketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} · Free\n\t\t\t\t{:else}\n\t\t\t\t\t{formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}\n\t\t\t\t{/if}\n\t\t\t</Text>\n\t\t</div>\n\n\t\t<!-- Right: Place order button -->\n\t\t<Button\n\t\t\tvariant=\"default\"\n\t\t\tsize=\"lg\"\n\t\t\tdisabled={processing}\n\t\t\tloading={processing}\n\t\t\tonclick={onPlaceOrder}\n\t\t\tclass=\"shrink-0 min-w-36\"\n\t\t>\n\t\t\t{#if processing}\n\t\t\t\t{labels.placingOrder || 'Placing order...'}\n\t\t\t{:else if isFreeOrder}\n\t\t\t\t{labels.completeOrder || 'Complete order'}\n\t\t\t{:else}\n\t\t\t\t{labels.placeOrder || 'Place order'}\n\t\t\t{/if}\n\t\t</Button>\n\t</div>\n</div>\n\n","<script module>\n import type { USD } from '@getmicdrop/svelte-components';\n import { createLogger, formatCurrency } from '@getmicdrop/svelte-components';\n const logger = createLogger('CheckoutMain');\n</script>\n\n<script lang=\"ts\">\n import { Warning, Time } from 'carbon-icons-svelte';\n import { Button, Heading, Text, Modal } from '@getmicdrop/svelte-components';\n import { roundCurrency } from '$lib/utils/currency.js';\n import type {\n EventData,\n OrderTotals,\n OrderLine,\n CheckoutConfig,\n CheckoutFormData,\n } from '$lib/premium-ticket-experience/types';\n import {\n mockEvent,\n mockFreeEvent,\n mockDonationEvent,\n mockRegistrationEvent,\n } from '$lib/premium-ticket-experience/mock-data';\n import { calculateTax } from '$lib/premium-ticket-experience/defaults';\n import { getSessionStatus } from '$lib/api/orders';\n\n import CheckoutForm from './CheckoutForm.svelte';\n import CheckoutSidebar from './CheckoutSidebar.svelte';\n import CheckoutMobileFooter from './CheckoutMobileFooter.svelte';\n import OrderSummary from './OrderSummary.svelte';\n import { mergeLabels } from '$lib/premium-ticket-experience/i18n/labels.js';\n\n // mergedLabels initialized after props destructuring below\n\n // --- DataToggle types ---\n type CheckoutVariant =\n | 'default'\n | 'free'\n | 'donation'\n | 'registration'\n | 'timer_warning'\n | 'expired'\n | 'promo';\n let dataVariant = $state<CheckoutVariant>('default');\n\n const toggleOptions: {\n value: CheckoutVariant;\n label: string;\n color: string;\n }[] = [\n { value: 'default', label: 'Standard', color: 'bg-accent-success' },\n { value: 'free', label: 'Free', color: 'bg-sky-500' },\n { value: 'donation', label: 'Donation', color: 'bg-accent-danger' },\n { value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\n {\n value: 'timer_warning',\n label: 'Timer warning',\n color: 'bg-status-warning-bg0',\n },\n { value: 'expired', label: 'Expired', color: 'bg-accent-danger' },\n { value: 'promo', label: 'Promo discount', color: 'bg-accent-success' },\n ];\n\n // --- Props (dual-mode: showcase vs production) ---\n interface Props {\n /** Pre-built checkout config for production mode. Absence = showcase. */\n config?: CheckoutConfig;\n /** Production order submission handler. Receives form data for the wrapper to submit. */\n onPlaceOrder?: (formData: CheckoutFormData) => Promise<void>;\n /** Production back navigation handler. */\n onBack?: () => void;\n /** Production retry handler for expired sessions. */\n onRetryExpired?: () => void;\n /** Production session extension handler. Returns extension result with newExpiryTime and remainingExtensions. */\n onExtendSession?: () => Promise<{\n newExpiryTime?: string;\n remainingExtensions?: number;\n } | null | void>;\n /** Stripe instance passed through to CheckoutForm */\n stripe?: any;\n /** Stripe client secret passed through to CheckoutForm */\n paymentIntent?: string;\n /** Bindable Stripe elements for wrapper to access */\n elements?: any;\n /** Payment error message to display */\n paymentError?: string;\n labels?: Record<string, string>;\n }\n\n let {\n config: configProp = undefined,\n onPlaceOrder: onPlaceOrderProp = undefined,\n onBack: onBackProp = undefined,\n onRetryExpired: onRetryExpiredProp = undefined,\n onExtendSession: onExtendSessionProp = undefined,\n stripe = undefined,\n paymentIntent = undefined,\n elements = $bindable(undefined),\n paymentError = '',\n labels = {},\n }: Props = $props();\n\n const mergedLabels = $derived(mergeLabels(labels));\n let isShowcaseMode = $derived(!configProp);\n\n // --- Mock order configurations per variant ---\n function buildConfig(variant: CheckoutVariant): CheckoutConfig {\n switch (variant) {\n case 'free':\n return {\n event: mockFreeEvent,\n lines: [\n {\n ticketId: 201,\n ticketName: 'Free Entry',\n quantity: 2,\n unitPrice: 0,\n fee: 0,\n subtotal: 0,\n },\n ],\n timerStart: 900,\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: false,\n };\n\n case 'donation':\n return {\n event: mockDonationEvent,\n lines: [\n {\n ticketId: 401,\n ticketName: 'Donation',\n quantity: 1,\n unitPrice: 25,\n fee: 0,\n subtotal: 25,\n },\n {\n ticketId: 402,\n ticketName: 'Standard Admission',\n quantity: 1,\n unitPrice: 30,\n fee: 3,\n subtotal: 30,\n },\n ],\n timerStart: 900,\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: false,\n };\n\n case 'registration':\n return {\n event: mockRegistrationEvent,\n lines: [\n {\n ticketId: 301,\n ticketName: 'Workshop Seat',\n quantity: 1,\n unitPrice: 75,\n fee: 7.5,\n subtotal: 75,\n },\n ],\n timerStart: 900,\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: false,\n };\n\n case 'timer_warning':\n return {\n event: mockEvent,\n lines: [\n {\n ticketId: 101,\n ticketName: 'General Admission',\n quantity: 2,\n unitPrice: 25,\n fee: 2.5,\n subtotal: 50,\n },\n {\n ticketId: 102,\n ticketName: 'VIP Front Row',\n quantity: 1,\n unitPrice: 55,\n fee: 5.5,\n subtotal: 55,\n },\n ],\n timerStart: 33, // Just over 30s — warning modal triggers at 30s\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: false,\n };\n\n case 'expired':\n return {\n event: mockEvent,\n lines: [\n {\n ticketId: 101,\n ticketName: 'General Admission',\n quantity: 2,\n unitPrice: 25,\n fee: 2.5,\n subtotal: 50,\n },\n {\n ticketId: 102,\n ticketName: 'VIP Front Row',\n quantity: 1,\n unitPrice: 55,\n fee: 5.5,\n subtotal: 55,\n },\n ],\n timerStart: 0,\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: true,\n };\n\n case 'promo':\n return {\n event: mockEvent,\n lines: [\n {\n ticketId: 101,\n ticketName: 'General Admission',\n quantity: 2,\n unitPrice: 25,\n fee: 2.5,\n subtotal: 50,\n },\n {\n ticketId: 102,\n ticketName: 'VIP Front Row',\n quantity: 1,\n unitPrice: 55,\n fee: 5.5,\n subtotal: 55,\n },\n ],\n timerStart: 900,\n promoApplied: true,\n promoDiscount: 10,\n forceExpired: false,\n };\n\n default:\n // Standard checkout\n return {\n event: mockEvent,\n lines: [\n {\n ticketId: 101,\n ticketName: 'General Admission',\n quantity: 2,\n unitPrice: 25,\n fee: 2.5,\n subtotal: 50,\n },\n {\n ticketId: 102,\n ticketName: 'VIP Front Row',\n quantity: 1,\n unitPrice: 55,\n fee: 5.5,\n subtotal: 55,\n },\n ],\n timerStart: 900,\n promoApplied: false,\n promoDiscount: 0,\n forceExpired: false,\n };\n }\n }\n\n // --- State ---\n let config: CheckoutConfig = $derived(\n isShowcaseMode ? buildConfig(dataVariant) : configProp!\n );\n // Deadline-based timer model.\n //\n // We track an absolute deadline timestamp (ms since epoch) and compute\n // the displayed seconds from `deadlineMs - Date.now()` on each tick.\n // This is immune to backgrounded-tab throttling: when the browser\n // suspends our setInterval, the displayed value falls behind, but the\n // very next tick (or the visibilitychange handler) recomputes from\n // wall-clock time and the display jumps to truth. Previously we\n // decremented `timerSeconds -= 1`, which drifted arbitrarily far from\n // reality whenever the tab was backgrounded (Chrome throttles 1Hz\n // intervals to ~1/min after a few minutes, then pauses them entirely).\n //\n // `timerSeconds` remains an explicit state var (rather than `$derived`)\n // because legacy code paths still write to it (legacy demo modes); the\n // canonical writer is now the deadline-driven tick effect below.\n let deadlineMs = $state<number | null>(null);\n let timerSeconds = $state(900);\n let isExpired = $state(false);\n let processing = $state(false);\n let submitRequested = $state(0);\n\n // Cart expiration warning/expired modal states\n let showWarningModal = $state(false);\n let showExpiredModal = $state(false);\n let warningShown = $state(false);\n let isExtendingSession = $state(false);\n let remainingExtensions = $state(3);\n let canExtend = $state(true);\n\n const WARNING_THRESHOLD = 30; // Show warning modal at 30 seconds remaining\n\n // Formatted timer display for the modal\n let timerDisplay = $derived(\n (() => {\n const m = Math.floor(timerSeconds / 60);\n const s = timerSeconds % 60;\n return `${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`;\n })()\n );\n\n // Order totals — the server's payment-intent response is the source\n // of truth (it's what Stripe will actually charge). Fall back to a\n // local estimate only when the server hasn't responded yet (showcase\n // mode, or while the initial /payment-intent is in flight) so the\n // skeleton has something to render.\n let orderTotals: OrderTotals = $derived(\n (() => {\n const lines = config.lines;\n if (config.serverTotals) {\n return {\n lines,\n subtotal: config.serverTotals.subtotal,\n fees: config.serverTotals.fees,\n taxes: config.serverTotals.taxes,\n total: config.serverTotals.total,\n promoDiscount: config.serverTotals.promoDiscount,\n giftCardAmount: config.serverTotals.giftCardAmount,\n };\n }\n const subtotal = roundCurrency(\n lines.reduce((sum, l) => sum + l.subtotal, 0)\n );\n const fees = roundCurrency(\n lines.reduce((sum, l) => sum + l.fee * l.quantity, 0)\n );\n const promoDiscount = config.promoApplied ? config.promoDiscount : 0;\n const adjustedSubtotal = roundCurrency(\n Math.max(0, subtotal - promoDiscount)\n );\n const taxes = calculateTax(\n adjustedSubtotal + fees,\n config.event.venue.taxPercentage\n );\n return {\n lines,\n subtotal,\n fees,\n taxes,\n total: roundCurrency(adjustedSubtotal + fees + taxes),\n promoDiscount,\n giftCardAmount: 0,\n };\n })()\n );\n\n // Disable Place-order until the server has confirmed the totals.\n // Showing \"Place order · $55\" while the actual Stripe charge will be\n // $63.55 is worse than briefly disabling the button. Free orders\n // never call the payment-intent endpoint, so they're exempt.\n let totalsLocked = $derived(!!config.serverTotals);\n\n let isFreeOrder = $derived(\n orderTotals.total === 0 && orderTotals.subtotal === 0\n );\n let isRegistration = $derived(config.event.isRegistrationEvent);\n\n // Set timer ONCE on initial mount — not on every config change.\n // Config changes frequently (Stripe loads, quantities update, etc.)\n // and must not reset the timer.\n let timerInitialized = false;\n $effect(() => {\n const c = config;\n if (!timerInitialized) {\n timerInitialized = true;\n // Convert the incoming \"seconds from now\" into an absolute deadline.\n // From this point on, deadlineMs is the source of truth.\n deadlineMs = Date.now() + c.timerStart * 1000;\n timerSeconds = c.timerStart;\n isExpired = c.forceExpired;\n }\n // These are safe to reset on config change (UI state, not timer)\n processing = false;\n submitRequested = 0;\n });\n\n function getCartIdFromCookie(): string | null {\n if (typeof document === 'undefined') return null;\n return document.cookie.match(/checkout-cartid=([^;]+)/)?.[1] ?? null;\n }\n\n function recomputeFromDeadline(): number {\n if (deadlineMs == null) return timerSeconds;\n return Math.max(0, Math.floor((deadlineMs - Date.now()) / 1000));\n }\n\n /**\n * Re-sync the deadline from the orders-service. Called on tab focus —\n * a backgrounded tab might have missed an extension granted in another\n * tab, or the server may have already expired the cart while we slept.\n *\n * Silent on any error: the existing deadlineMs continues to drive the\n * display, which is no worse than the pre-resync state.\n */\n async function resyncDeadlineFromServer(): Promise<void> {\n const cartId = getCartIdFromCookie();\n if (!cartId) return;\n try {\n const status = await getSessionStatus(cartId);\n if (status.notFound) {\n // Server has already released the reservation. Surface the\n // expired modal so the user isn't staring at a phantom timer.\n deadlineMs = Date.now();\n timerSeconds = 0;\n isExpired = true;\n showWarningModal = false;\n showExpiredModal = true;\n return;\n }\n if (status.expiresAt) {\n deadlineMs = new Date(status.expiresAt).getTime();\n timerSeconds = recomputeFromDeadline();\n }\n } catch {\n /* network error — keep current deadlineMs */\n }\n }\n\n // Timer countdown with warning and expired modal triggers.\n //\n // The interval ticks at 1 Hz, but its job is to *recompute* timerSeconds\n // from deadlineMs, not to decrement a counter. Backgrounded tabs throttle\n // this interval — that's fine; when the tab regains focus the\n // visibilitychange handler runs the recompute immediately and the display\n // jumps to truth.\n $effect(() => {\n if (isExpired || timerSeconds <= 0) {\n if (timerSeconds <= 0 && !isExpired) {\n isExpired = true;\n showWarningModal = false;\n showExpiredModal = true;\n }\n return;\n }\n\n const tick = () => {\n const next = recomputeFromDeadline();\n timerSeconds = next;\n\n // Persist deadline to localStorage every 10 displayed seconds.\n // (Storing the deadline directly — not a recomputed end-time —\n // keeps reads consistent across tabs.)\n if (\n next % 10 === 0 &&\n deadlineMs != null &&\n typeof localStorage !== 'undefined'\n ) {\n try {\n const cartId = getCartIdFromCookie();\n if (cartId) {\n localStorage.setItem(\n `checkout-expiry-${cartId}`,\n String(deadlineMs)\n );\n }\n } catch {\n /* ignore */\n }\n }\n\n // Show warning modal at 30 seconds remaining (only once per session).\n // We compare with <= because a backgrounded tab may have skipped over\n // the exact === WARNING_THRESHOLD boundary while throttled.\n if (next <= WARNING_THRESHOLD && next > 0 && !warningShown) {\n showWarningModal = true;\n warningShown = true;\n }\n\n if (next <= 0) {\n isExpired = true;\n showWarningModal = false;\n showExpiredModal = true;\n clearInterval(interval);\n }\n };\n\n const interval = setInterval(tick, 1000);\n\n // Recompute immediately whenever the tab becomes visible — a\n // throttled/paused interval may have left the display many minutes\n // behind reality. Also kick a server resync to catch the case where\n // the reservation already expired (or was extended in another tab).\n const onVisible = () => {\n if (\n typeof document !== 'undefined' &&\n document.visibilityState === 'visible'\n ) {\n tick();\n void resyncDeadlineFromServer();\n }\n };\n if (typeof document !== 'undefined') {\n document.addEventListener('visibilitychange', onVisible);\n }\n if (typeof window !== 'undefined') {\n window.addEventListener('pageshow', onVisible);\n }\n\n // Initial server resync — catches the case where the user landed on\n // checkout with a stale cookie whose cart has already been released.\n void resyncDeadlineFromServer();\n\n return () => {\n clearInterval(interval);\n if (typeof document !== 'undefined') {\n document.removeEventListener('visibilitychange', onVisible);\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('pageshow', onVisible);\n }\n };\n });\n\n // --- Handlers ---\n function handleBack() {\n if (onBackProp) {\n onBackProp();\n } else {\n alert('Back button pressed — would navigate to ticket selection');\n }\n }\n\n /** Called from sidebar/mobile footer — signals the form to validate + submit */\n function requestPlaceOrder() {\n submitRequested += 1;\n }\n\n /** Called by CheckoutForm after successful validation */\n function handlePlaceOrder(formData: CheckoutFormData) {\n if (processing) return;\n processing = true;\n\n if (onPlaceOrderProp) {\n // Production mode: delegate to wrapper with form data\n onPlaceOrderProp(formData)\n .catch(() => {\n // Error handling is done by the wrapper; just reset processing\n })\n .finally(() => {\n processing = false;\n });\n return;\n }\n\n // Showcase mode: existing mock delay\n setTimeout(() => {\n processing = false;\n const count = orderTotals.lines.reduce((s, l) => s + l.quantity, 0);\n alert(\n `Order placed! ${count} ticket(s) for {formatCurrency(orderTotals.total as USD /* FIXME(canonical-cleanup:toFixed): this cast bypasses the brand boundary; replace with toCents/toUSD at the API-response-transform layer. */)}`\n );\n }, 1500);\n }\n\n function handleRetryExpired() {\n showExpiredModal = false;\n if (onRetryExpiredProp) {\n onRetryExpiredProp();\n } else {\n alert('Would navigate back to ticket selection to start over');\n }\n }\n\n /** Extend the checkout session via the parent wrapper's onExtendSession callback */\n async function handleExtendSession() {\n if (!canExtend || isExtendingSession) return;\n isExtendingSession = true;\n\n try {\n if (onExtendSessionProp) {\n const result = await onExtendSessionProp();\n // Parent returns extension result with newExpiryTime and remainingExtensions\n if (result && typeof result === 'object') {\n if (result.newExpiryTime) {\n // Server gave us an absolute new expiry — use it directly.\n deadlineMs = new Date(result.newExpiryTime).getTime();\n } else {\n // Fallback: add 15 minutes from now\n deadlineMs = Date.now() + 15 * 60 * 1000;\n }\n timerSeconds = recomputeFromDeadline();\n if (result.remainingExtensions !== undefined) {\n remainingExtensions = result.remainingExtensions;\n canExtend = remainingExtensions > 0;\n }\n } else {\n // Simple success (no structured result): add 15 minutes\n deadlineMs = Date.now() + 15 * 60 * 1000;\n timerSeconds = recomputeFromDeadline();\n }\n } else {\n // Showcase mode: just add 15 minutes\n deadlineMs = Date.now() + 15 * 60 * 1000;\n timerSeconds = recomputeFromDeadline();\n }\n\n isExpired = false;\n warningShown = false;\n showWarningModal = false;\n showExpiredModal = false;\n } catch (err) {\n logger.error('Failed to extend session:', err);\n // If extension fails, close modal and let timer continue\n showWarningModal = false;\n } finally {\n isExtendingSession = false;\n }\n }\n\n /** Dismiss warning modal without extending (user will hurry) */\n function dismissWarning() {\n showWarningModal = false;\n }\n\n function handleVariantChange(v: string) {\n dataVariant = v as CheckoutVariant;\n }\n</script>\n\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\n <!-- Dev: mock data toggle (showcase mode only) -->\n {#if isShowcaseMode}\n <div class=\"toggle-bar bg-surface-primary border-default\">\n <span class=\"toggle-label text-color-muted\">Checkout</span>\n {#each toggleOptions as option}\n {@const isActive = dataVariant === option.value}\n <button\n type=\"button\"\n class=\"toggle-btn {isActive\n ? 'active bg-surface-secondary text-color-primary font-medium'\n : 'text-color-tertiary hover:bg-surface-secondary hover:text-color-secondary'}\"\n onclick={() => handleVariantChange(option.value)}\n >\n <span class=\"w-1.5 h-1.5 rounded-full {option.color} shrink-0\"></span>\n {option.label}\n </button>\n {/each}\n </div>\n {/if}\n\n <div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\n <!-- Single CheckoutForm shared between desktop and mobile layouts.\n\t\t Previously there were two instances (one hidden md:grid, one md:hidden)\n\t\t which caused duplicate Stripe elements and broken form submission. -->\n <div class=\"max-w-6xl\">\n <!-- Desktop: two-column grid; Mobile: single column -->\n <div\n class=\"md:grid gap-8 items-start\"\n style=\"grid-template-columns: 1fr 360px;\"\n >\n <!-- LEFT COLUMN (or full width on mobile): Checkout form -->\n <div class=\"pb-24 md:pb-0\">\n <CheckoutForm\n event={config.event}\n {orderTotals}\n {timerSeconds}\n {isExpired}\n {isRegistration}\n {isFreeOrder}\n promoApplied={config.promoApplied}\n promoDiscount={config.promoDiscount}\n onBack={handleBack}\n onPlaceOrder={handlePlaceOrder}\n {processing}\n {submitRequested}\n {stripe}\n {paymentIntent}\n bind:elements\n {paymentError}\n labels={mergedLabels}\n />\n\n <!-- Inline order summary for mobile (below form) -->\n <section\n class=\"md:hidden mobile-order-summary border-default bg-surface-secondary mt-6\"\n >\n <Heading level={3} size=\"sm\" weight=\"semibold\" class=\"mb-3\">\n {mergedLabels.orderSummary || 'Order summary'}\n </Heading>\n <OrderSummary {orderTotals} />\n </section>\n </div>\n\n <!-- RIGHT COLUMN: Sticky order summary sidebar (desktop only) -->\n <div class=\"hidden md:block sticky top-6\">\n <CheckoutSidebar\n event={config.event}\n {orderTotals}\n {isFreeOrder}\n onPlaceOrder={requestPlaceOrder}\n processing={processing || (!isFreeOrder && !totalsLocked)}\n labels={mergedLabels}\n />\n </div>\n </div>\n </div>\n\n <!-- Mobile: Fixed bottom bar -->\n <div class=\"md:hidden\">\n <CheckoutMobileFooter\n {orderTotals}\n {isFreeOrder}\n onPlaceOrder={requestPlaceOrder}\n processing={processing || (!isFreeOrder && !totalsLocked)}\n labels={mergedLabels}\n />\n </div>\n </div>\n\n <!-- Session Warning Modal (30 seconds remaining) -->\n <Modal\n bind:open={showWarningModal}\n size=\"sm\"\n role=\"alertdialog\"\n aria-labelledby=\"warning-modal-title\"\n aria-describedby=\"warning-modal-description\"\n >\n {#snippet body()}\n <div class=\"timer-modal\" id=\"warning-modal-description\">\n <div class=\"timer-modal-icon warning\">\n <Warning size={32} />\n </div>\n <h3 id=\"warning-modal-title\" class=\"timer-modal-title\">\n {mergedLabels.sessionExpiringSoon || 'Session expiring soon'}\n </h3>\n <p class=\"timer-modal-text\">\n {(\n mergedLabels.sessionExpiringSoonMessage ||\n 'Your checkout session will expire in {time}. Your selected tickets will be released back to inventory.'\n ).replace('{time}', timerDisplay)}\n </p>\n {#if canExtend && remainingExtensions > 0}\n <p class=\"timer-modal-hint\">\n {(\n mergedLabels.extensionsRemaining ||\n '{count} extension{plural} remaining'\n )\n .replace('{count}', String(remainingExtensions))\n .replace('{plural}', remainingExtensions === 1 ? '' : 's')}\n </p>\n {/if}\n </div>\n {/snippet}\n {#snippet footer()}\n <div class=\"timer-modal-actions\">\n {#if canExtend}\n <Button\n variant=\"default\"\n size=\"lg\"\n class=\"w-full\"\n onclick={handleExtendSession}\n disabled={isExtendingSession}\n loading={isExtendingSession}\n >\n {isExtendingSession\n ? mergedLabels.extendingSession || 'Extending...'\n : mergedLabels.continueCheckout || 'Continue checkout'}\n </Button>\n {:else}\n <Button\n variant=\"default\"\n size=\"lg\"\n class=\"w-full\"\n onclick={dismissWarning}\n >\n {mergedLabels.okIllHurry || \"OK, I'll hurry\"}\n </Button>\n <p class=\"timer-modal-hint\">\n {mergedLabels.maxExtensionsReached || 'Maximum extensions reached'}\n </p>\n {/if}\n </div>\n {/snippet}\n </Modal>\n\n <!-- Session Expired Modal (\"Want to keep your tickets?\") -->\n <Modal\n bind:open={showExpiredModal}\n size=\"sm\"\n role=\"alertdialog\"\n aria-labelledby=\"expired-modal-title\"\n aria-describedby=\"expired-modal-description\"\n >\n {#snippet body()}\n <div class=\"timer-modal\" id=\"expired-modal-description\">\n <div class=\"timer-modal-icon expired\">\n <Time size={32} />\n </div>\n <h3 id=\"expired-modal-title\" class=\"timer-modal-title\">\n {canExtend\n ? mergedLabels.wantToKeepTickets || 'Want to keep your tickets?'\n : mergedLabels.sessionExpired || 'Session expired'}\n </h3>\n <p class=\"timer-modal-text\">\n {canExtend\n ? mergedLabels.sessionExpiredMessage ||\n 'Your checkout session has expired and your selected tickets have been released.'\n : mergedLabels.reservationTimedOut ||\n 'Your reservation has timed out. Please select your tickets again to continue.'}\n </p>\n </div>\n {/snippet}\n {#snippet footer()}\n <div class=\"timer-modal-actions\">\n {#if canExtend}\n <Button\n variant=\"default\"\n size=\"lg\"\n class=\"w-full\"\n onclick={handleExtendSession}\n disabled={isExtendingSession}\n loading={isExtendingSession}\n >\n {isExtendingSession\n ? mergedLabels.extendingSession || 'Extending...'\n : mergedLabels.keepMyTickets || 'Keep my tickets'}\n </Button>\n <Button\n variant=\"alternative\"\n size=\"lg\"\n class=\"w-full\"\n onclick={handleRetryExpired}\n >\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\n </Button>\n {:else}\n <Button\n variant=\"default\"\n size=\"lg\"\n class=\"w-full\"\n onclick={handleRetryExpired}\n >\n {mergedLabels.selectTicketsAgain || 'Select tickets again'}\n </Button>\n {/if}\n </div>\n {/snippet}\n </Modal>\n</div>\n\n<style>\n /* DataToggle inline (matches DataToggle.svelte pattern) */\n .toggle-bar {\n position: sticky;\n top: 0;\n z-index: var(--z-dropdown);\n display: flex;\n align-items: center;\n gap: 0.25rem;\n padding: 0.5rem 0.75rem;\n overflow-x: auto;\n border-bottom-width: 1px;\n border-bottom-style: solid;\n }\n\n .toggle-label {\n padding-left: 0.375rem;\n padding-right: 0.375rem;\n flex-shrink: 0;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n font-size: 0.625rem;\n }\n\n .toggle-btn {\n display: flex;\n align-items: center;\n gap: 0.375rem;\n padding: 0.25rem 0.5rem;\n border-radius: 0.375rem;\n font-size: 0.75rem;\n line-height: 1rem;\n white-space: nowrap;\n transition-property: all;\n transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n transition-duration: 150ms;\n }\n\n /* Mobile order summary */\n .mobile-order-summary {\n padding: 1rem;\n border-radius: 0.5rem;\n border-width: 1px;\n border-style: solid;\n }\n\n /* Timer modals */\n .timer-modal {\n text-align: center;\n padding: 0.5rem 0;\n }\n\n .timer-modal-icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 3.5rem;\n height: 3.5rem;\n border-radius: 9999px;\n margin: 0 auto 1rem;\n }\n\n .timer-modal-icon.warning {\n background-color: hsl(var(--accent-warning) / 8%);\n color: hsl(var(--accent-warning));\n }\n\n .timer-modal-icon.expired {\n background-color: hsl(var(--accent-danger) / 5%);\n color: hsl(var(--accent-danger));\n }\n\n .timer-modal-title {\n font-size: 1.125rem;\n font-weight: 600;\n margin-bottom: 0.5rem;\n }\n\n .timer-modal-text {\n font-size: 0.875rem;\n line-height: 1.4;\n color: hsl(var(--text-tertiary)); /* gray-500 */\n }\n\n .timer-modal-hint {\n font-size: 0.75rem;\n color: hsl(var(--text-head)); /* gray-400 */\n margin-top: 0.5rem;\n }\n\n .timer-modal-actions {\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n }\n</style>\n"],"names":["browser","detectDarkMode","containerSelector","saved","selector","containers","container","getStripeTheme","isDark","useStripeTheme","options","watchChanges","fallback","current","$","observer","updateTheme","onMount","root","onDestroy","stripe","paymentIntent","elements","paymentError","labels","$$props","stripeTheme","paymentMountDiv","paymentElement","stripeMounted","mountStripePayment","firstName","lastName","email","keepUpdated","agreeTerms","cardNumber","cardExpiry","cardCvc","attendees","submitted","errors","e","i","att","hasErrors","isTimerUrgent","totalTickets","sum","l","_","lastSubmitRequest","handleSubmit","handleSameAsPurchaser","index","checked","a","div","div_1","Button","node","ChevronLeft","CheckoutTimer","node_1","section","Heading","node_2","div_2","$3","Input","node_3","$$value","node_4","node_5","Checkbox","node_6","section_1","root_4","node_8","node_9","attendee","div_3","root_6","div_4","Text","node_10","node_11","div_5","div_6","node_12","node_13","node_14","$$render","consequent","section_2","node_7","div_7","root_9","node_16","node_17","node_18","div_8","fragment_9","p","root_15","consequent_2","p_1","root_16","consequent_3","alternate","p_2","root_17","consequent_4","node_22","node_23","div_9","node_24","node_25","consequent_1","consequent_5","alternate_1","section_3","node_26","div_10","root_21","Warning","node_29","text_13","consequent_6","Card","$$anchor","root_1","img","Calendar","formatEventTime","formatBrowseDate","text_3","OrderSummary","$0","text_6","formatCurrency","totalTicketCount","text_1","logger","createLogger","dataVariant","toggleOptions","configProp","onPlaceOrderProp","onBackProp","onRetryExpiredProp","onExtendSessionProp","mergedLabels","mergeLabels","isShowcaseMode","buildConfig","variant","mockFreeEvent","mockDonationEvent","mockRegistrationEvent","mockEvent","config","deadlineMs","timerSeconds","isExpired","processing","submitRequested","showWarningModal","showExpiredModal","warningShown","isExtendingSession","remainingExtensions","canExtend","WARNING_THRESHOLD","timerDisplay","m","s","orderTotals","lines","subtotal","roundCurrency","fees","promoDiscount","adjustedSubtotal","taxes","calculateTax","totalsLocked","isFreeOrder","isRegistration","timerInitialized","c","getCartIdFromCookie","recomputeFromDeadline","resyncDeadlineFromServer","cartId","status","getSessionStatus","tick","next","interval","onVisible","handleBack","requestPlaceOrder","handlePlaceOrder","formData","count","handleRetryExpired","handleExtendSession","result","err","dismissWarning","handleVariantChange","v","option","isActive","button","root_2","span","text","CheckoutForm","CheckoutSidebar","CheckoutMobileFooter","Modal","h3","root_5","div_11","root_11","div_12","Time","h3_1","p_3","div_13","root_12","node_15"],"mappings":"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","x_google_ignoreList":[1]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as t from "svelte/internal/client";
|
|
3
|
-
import { T as p } from "./VenueCalendar-
|
|
3
|
+
import { T as p } from "./VenueCalendar-Djc3e2j2.js";
|
|
4
4
|
import { T as u } from "./Text-CXR2fhx6.js";
|
|
5
5
|
import "svelte/internal/flags/legacy";
|
|
6
6
|
import "svelte/transition";
|
|
@@ -31,4 +31,4 @@ function b(n, e) {
|
|
|
31
31
|
export {
|
|
32
32
|
b as C
|
|
33
33
|
};
|
|
34
|
-
//# sourceMappingURL=CheckoutTimer-
|
|
34
|
+
//# sourceMappingURL=CheckoutTimer-D6LfPX7c.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheckoutTimer-D6LfPX7c.js","sources":["../src/lib/premium-ticket-experience/variants/v3-airbnb-split/CheckoutTimer.svelte"],"sourcesContent":["<script lang=\"ts\">\n\timport { Time } from 'carbon-icons-svelte';\n\timport { Text } from '@getmicdrop/svelte-components';\n\n\tinterface Props {\n\t\tseconds: number;\n\t\tisUrgent: boolean;\n\t\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet { seconds, isUrgent, labels = {}, }: Props = $props();\n\n\tlet display = $derived((() => {\n\t\tconst m = Math.floor(seconds / 60);\n\t\tconst s = seconds % 60;\n\t\treturn `${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`;\n\t})());\n\n\tlet label = $derived(isUrgent ? 'Complete soon' : 'Reservation held');\n</script>\n\n<div class=\"timer-display text-color-secondary\" class:urgent={isUrgent}>\n\t<Time size={16} class=\"shrink-0\" />\n\t<Text size=\"sm\" class=\"font-medium tabular-nums\">\n\t\t{label} · {display}\n\t</Text>\n</div>\n\n<style>\n\t.timer-display {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tgap: 0.5rem;\n\t}\n\n\t.timer-display.urgent {\n\t\tcolor: hsl(var(--accent-warning)); /* orange-500 */\n\t}\n</style>\n"],"names":["$","$$props","display","m","s","label","div","root","Time","Text","node_1","text","classes"],"mappings":";;;;;;;;iBAAA;iBAUgCA,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA;AAE3B,MAAAC,IAAOF,EAAA,QAAA,OAAA,MAAmB;AACvB,UAAAG,IAAI,KAAK,kBAAgB,EAAE,GAC3BC,gBAAc;AACV,WAAA,GAAAD,EAAE,SAAQ,EAAG,SAAS,GAAG,GAAG,CAAA,IAAKC,EAAE,SAAQ,EAAG,SAAS,GAAG,GAAG,CAAA;AAAA,EACxE,IAAC,GAEGC,IAAKL,EAAA,QAAA,MAAAC,EAAA,WAAuB,kBAAkB,kBAAkB;MAGpEK,IAAGC,EAAA;;kBAAHD,CAAG;AACF,EAAAE,aAAW,IAAE,OAAA,YAAA;;AACb,EAAAC,EAAIC,GAAA;AAAA;;;;;AACH,MAAAV,EAAA,gBAAA,MAAAA,EAAA,SAAAW,GAAA,GAAAX,EAAA,IAAAK,CAAK,mBAAYH,CAAO,KAAA,EAAA,EAAA,CAAA;;;cAH1BI,CAAG,2CAAHA,GAAG,GAAA,qDAAA,MAAAM,GAAA,EAAA,QAAAX,EAAA,SAAA,CAAA,CAAA,eAAHK,CAAG;AAFI;"}
|
|
@@ -2,19 +2,19 @@ import "svelte/internal/disclose-version";
|
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as B, onDestroy as H } from "svelte";
|
|
4
4
|
import { g as J } from "./__SKIP_NAVIGATION__-CJ96TTPE.js";
|
|
5
|
-
import { h as K, am as X } from "./VenueCalendar-
|
|
5
|
+
import { h as K, am as X } from "./VenueCalendar-Djc3e2j2.js";
|
|
6
6
|
import "svelte/internal/flags/legacy";
|
|
7
7
|
import "svelte/transition";
|
|
8
8
|
import "svelte/easing";
|
|
9
|
-
import { A as Z } from "./AirbnbSplitMain-
|
|
10
|
-
import { b as $ } from "./transform-
|
|
9
|
+
import { A as Z } from "./AirbnbSplitMain-BwFA51F6.js";
|
|
10
|
+
import { b as $ } from "./transform-DKVmquzJ.js";
|
|
11
11
|
var ee = e.from_html('<div class="flex items-center justify-center py-12 text-center loading-container svelte-q4dz4y"><p> </p></div>'), te = e.from_html('<p class="password-error-text text-xs svelte-q4dz4y"> </p>'), re = e.from_html('<div class="flex flex-col items-center justify-center min-h-[50vh] text-center"><div class="password-card rounded-lg p-8 max-w-sm w-full svelte-q4dz4y"><h2 class="password-title text-xl font-bold mb-2 svelte-q4dz4y"> </h2> <p class="password-description text-sm mb-6 svelte-q4dz4y"> </p> <form class="flex flex-col gap-3"><input type="password"/> <!> <button type="submit" class="password-submit px-4 py-2 rounded-lg text-sm font-semibold svelte-q4dz4y"> </button></form></div></div>'), oe = e.from_html('<div class="flex flex-col items-center justify-center min-h-[50vh] text-center"><p class="error-text svelte-q4dz4y"> </p></div>');
|
|
12
12
|
function pe(T, l) {
|
|
13
13
|
e.push(l, !0);
|
|
14
14
|
const L = K("CollectionView");
|
|
15
15
|
let p = e.state(!1), v = e.state(null);
|
|
16
16
|
typeof window < "u" && new URLSearchParams(window.location.search).get("legacy") === "1" && e.set(p, !0), e.user_effect(() => {
|
|
17
|
-
e.get(p) && !e.get(v) && (L.warn("[VC] DEPRECATED: ?legacy=1 fallback for CollectionView retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md."), import("./CollectionView.legacy-
|
|
17
|
+
e.get(p) && !e.get(v) && (L.warn("[VC] DEPRECATED: ?legacy=1 fallback for CollectionView retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md."), import("./CollectionView.legacy-Cz6XX6Ly.js").then((t) => {
|
|
18
18
|
e.set(v, t.default, !0);
|
|
19
19
|
}).catch(() => {
|
|
20
20
|
e.set(p, !1);
|
|
@@ -139,4 +139,4 @@ function pe(T, l) {
|
|
|
139
139
|
export {
|
|
140
140
|
pe as default
|
|
141
141
|
};
|
|
142
|
-
//# sourceMappingURL=CollectionView-
|
|
142
|
+
//# sourceMappingURL=CollectionView-BwQTF9Df.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CollectionView-BwQTF9Df.js","sources":["../src/components/Views/CollectionView.svelte"],"sourcesContent":["<script lang=\"ts\">\n\timport { onMount, onDestroy } from 'svelte';\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 { transformCollectionData } from '$lib/premium-ticket-experience/transform';\n\timport { fetchPublicCollection } from '$lib/api/events';\n\timport type { PublicCollectionData } from '$lib/api/types';\n\n\tconst logger = createLogger('CollectionView');\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 CollectionView retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md.'\n\t\t\t);\n\t\t\timport('./CollectionView.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 CollectionView external interface) ---\n\tinterface Props {\n\t\tcollectionId: string | number;\n\t\torganizationId?: string;\n\t\tonNavigateToEvent?: (id: number, slug: string) => void;\n\t\tpassword?: string;\n\t\tdisplayMode?: string;\n\t\tshowViewSwitcher?: boolean;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tcollectionId,\n\t\torganizationId = '',\n\t\tonNavigateToEvent = undefined,\n\t\tpassword = undefined,\n\t\tdisplayMode = 'gallery',\n\t\tshowViewSwitcher = true,\n\t\tlabels = {},\n\t}: Props = $props();\n\n\t// --- State ---\n\tlet collection = $state<PublicCollectionData | null>(null);\n\tlet isLoading = $state(true);\n\tlet error = $state<string | null>(null);\n\tlet isMounted = $state(false);\n\tlet passwordRequired = $state(false);\n\tlet passwordInput = $state('');\n\tlet passwordError = $state(false);\n\n\t// --- Derived ---\n\tlet eventData = $derived(collection ? transformCollectionData(collection) : null);\n\n\t// --- Load collection data ---\n\tasync function loadCollection(pwd?: string): Promise<void> {\n\t\tif (!isMounted) return;\n\t\tif (!collectionId) {\n\t\t\terror = labels.noCollectionIdProvided || 'No collection ID provided';\n\t\t\tisLoading = false;\n\t\t\treturn;\n\t\t}\n\n\t\tisLoading = true;\n\t\terror = null;\n\t\tpasswordError = false;\n\n\t\ttry {\n\t\t\tconst data = await fetchPublicCollection(collectionId, pwd);\n\t\t\tif (!isMounted) return;\n\n\t\t\tif (data) {\n\t\t\t\tif ((data as any).passwordRequired || (data as any).error?.code === 'PASSWORD_REQUIRED') {\n\t\t\t\t\tpasswordRequired = true;\n\t\t\t\t\tisLoading = false;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tcollection = data;\n\t\t\t\tpasswordRequired = false;\n\t\t\t} else {\n\t\t\t\tif (pwd) {\n\t\t\t\t\tpasswordRequired = true;\n\t\t\t\t\tpasswordError = true;\n\t\t\t\t\tisLoading = false;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\terror = labels.failedToLoadCollection || 'Failed to load collection';\n\t\t\t}\n\t\t} catch (err: any) {\n\t\t\tif (isMounted) {\n\t\t\t\tconst msg = err.message || '';\n\t\t\t\tif (msg.includes('401') || msg.includes('403') || msg.includes('password')) {\n\t\t\t\t\tpasswordRequired = true;\n\t\t\t\t} else {\n\t\t\t\t\terror = msg || labels.failedToLoadCollection || 'Failed to load collection';\n\t\t\t\t}\n\t\t\t}\n\t\t} finally {\n\t\t\tif (isMounted) {\n\t\t\t\tisLoading = false;\n\t\t\t}\n\t\t}\n\t}\n\n\tfunction handlePasswordSubmit(e: Event): void {\n\t\te.preventDefault();\n\t\tif (!passwordInput.trim()) return;\n\t\tloadCollection(passwordInput);\n\t}\n\n\tfunction handleCollectionEventClick(galleryEvent: { id?: number | string; slug: string }): void {\n\t\tif (onNavigateToEvent && galleryEvent.id) {\n\t\t\tonNavigateToEvent(Number(galleryEvent.id), galleryEvent.slug);\n\t\t} else {\n\t\t\tgoto(`/${galleryEvent.id}/${galleryEvent.slug}`);\n\t\t}\n\t}\n\n\t// --- Lifecycle ---\n\tonMount(() => {\n\t\tisMounted = true;\n\t\tloadCollection(password);\n\t});\n\n\tonDestroy(() => {\n\t\tisMounted = false;\n\t});\n</script>\n\n{#if useLegacy && LegacyComponent}\n\t<svelte:component this={LegacyComponent}\n\t\t{collectionId}\n\t\t{organizationId}\n\t\t{onNavigateToEvent}\n\t\t{password}\n\t\t{displayMode}\n\t\t{showViewSwitcher}\n\t\t{labels}\n\t/>\n{:else if isLoading}\n\t<div class=\"flex items-center justify-center py-12 text-center loading-container\">\n\t\t<p>{labels.loadingCollection || 'Loading collection...'}</p>\n\t</div>\n{:else if passwordRequired}\n\t<div class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\">\n\t\t<div class=\"password-card rounded-lg p-8 max-w-sm w-full\">\n\t\t\t<h2 class=\"password-title text-xl font-bold mb-2\">{labels.collectionPrivateTitle || 'This collection is private'}</h2>\n\t\t\t<p class=\"password-description text-sm mb-6\">{labels.collectionPrivateDescription || 'Please enter the password to view this collection.'}</p>\n\t\t\t<form onsubmit={handlePasswordSubmit} class=\"flex flex-col gap-3\">\n\t\t\t\t<input\n\t\t\t\t\ttype=\"password\"\n\t\t\t\t\tbind:value={passwordInput}\n\t\t\t\t\tplaceholder={labels.enterPassword || \"Enter password\"}\n\t\t\t\t\tclass=\"password-input w-full px-3 py-2 rounded-lg text-sm\"\n\t\t\t\t\tclass:password-input-error={passwordError}\n\t\t\t\t/>\n\t\t\t\t{#if passwordError}\n\t\t\t\t\t<p class=\"password-error-text text-xs\">{labels.incorrectPassword || 'Incorrect password. Please try again.'}</p>\n\t\t\t\t{/if}\n\t\t\t\t<button type=\"submit\" class=\"password-submit px-4 py-2 rounded-lg text-sm font-semibold\">{labels.viewCollection || 'View Collection'}</button>\n\t\t\t</form>\n\t\t</div>\n\t</div>\n{:else if error}\n\t<div class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\">\n\t\t<p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\n\t</div>\n{:else if eventData}\n\t<AirbnbSplitMain\n\t\tevent={eventData}\n\t\tonCollectionEventClick={handleCollectionEventClick}\n\t/>\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-text {\n\t\tcolor: hsl(var(--status-sold-out, 0 72% 51%));\n\t}\n\n\t.password-card {\n\t\tbackground: hsl(var(--surface-primary, 0 0% 100%));\n\t\tbox-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\n\t}\n\n\t.password-title {\n\t\tcolor: hsl(var(--text-primary, 0 0% 10%));\n\t}\n\n\t.password-description {\n\t\tcolor: hsl(var(--text-secondary, 0 0% 45%));\n\t}\n\n\t.password-input {\n\t\tborder: 1px solid hsl(var(--stroke-secondary, 0 0% 85%));\n\t\tcolor: hsl(var(--text-primary, 0 0% 10%));\n\t\tbackground: hsl(var(--surface-primary, 0 0% 100%));\n\t}\n\n\t.password-input:focus {\n\t\toutline: none;\n\t\tborder-color: hsl(var(--brand-primary, 220 90% 56%));\n\t\tbox-shadow: 0 0 0 2px hsl(var(--brand-primary, 220 90% 56%) / 20%);\n\t}\n\n\t.password-input-error {\n\t\tborder-color: hsl(var(--status-sold-out, 0 72% 51%));\n\t}\n\n\t.password-error-text {\n\t\tcolor: hsl(var(--status-sold-out, 0 72% 51%));\n\t}\n\n\t.password-submit {\n\t\tbackground: hsl(var(--brand-primary, 220 90% 56%));\n\t\tcolor: hsl(var(--text-on-primary, 0 0% 100%));\n\t}\n\n\t.password-submit:hover {\n\t\tfilter: brightness(0.95);\n\t}\n</style>\n"],"names":["logger","createLogger","useLegacy","$","LegacyComponent","m","organizationId","onNavigateToEvent","password","displayMode","showViewSwitcher","labels","$$props","collection","isLoading","error","isMounted","passwordRequired","passwordInput","passwordError","eventData","transformCollectionData","loadCollection","pwd","data","fetchPublicCollection","err","msg","handlePasswordSubmit","e","handleCollectionEventClick","galleryEvent","goto","onMount","onDestroy","$$anchor","$$component","div","root_2","p","div_1","root_3","div_2","h2","p_1","form","input","p_2","root_4","$$render","consequent_2","button","node_2","classes","$$value","div_3","root_5","p_3","text_5","AirbnbSplitMain","consequent","consequent_3","consequent_4","consequent_5"],"mappings":"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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as ne, onDestroy as de } from "svelte";
|
|
4
|
-
import { ax as ce, ay as ve, az as ge, aA as me, aB as ue, a3 as le, J as oe, _ as fe, e as ie, am as pe, aJ as _e, aK as he } from "./VenueCalendar-
|
|
4
|
+
import { ax as ce, ay as ve, az as ge, aA as me, aB as ue, a3 as le, J as oe, _ as fe, e as ie, am as pe, aJ as _e, aK as he } from "./VenueCalendar-Djc3e2j2.js";
|
|
5
5
|
import "svelte/internal/flags/legacy";
|
|
6
6
|
import "svelte/transition";
|
|
7
7
|
import "svelte/easing";
|
|
8
|
-
import { G as xe } from "./GalleryCard-
|
|
8
|
+
import { G as xe } from "./GalleryCard-MO80JCq7.js";
|
|
9
9
|
var be = e.from_html('<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"><span class="text-xs font-semibold text-text-secondary uppercase tracking-tight"> </span> <span class="text-2xl max-sm:text-lg font-bold text-text-primary leading-tight"> </span> <span class="text-xs font-semibold text-text-secondary uppercase tracking-tight"> </span></div>'), we = e.from_html('<p class="event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden svelte-1aw0ssq"> </p>'), ye = e.from_html("<span> </span>"), De = e.from_html('<li class="list-none"><div tabindex="0" role="button"><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"><img alt="" class="w-full h-full object-contain svelte-1aw0ssq" loading="lazy"/></div> <div class="flex-1 flex flex-col gap-1.5 min-w-0" aria-hidden="true"><h3 class="text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug"> </h3> <time class="text-sm max-sm:text-xs font-medium text-text-secondary"> </time> <!></div> <div class="flex items-start pt-0.5" aria-hidden="true"><!></div></div></li>'), Te = e.from_html('<div class="date-group flex border-b border-border last:border-b-0 svelte-1aw0ssq" role="group"><!> <ul class="events-column flex-1 flex flex-col list-none p-0 m-0 svelte-1aw0ssq"></ul></div>'), ke = e.from_html('<div class="flex justify-center items-center p-6 text-text-secondary" role="status" aria-live="polite"><span class="text-sm"> </span></div>'), qe = e.from_html('<section><h2 class="sr-only svelte-1aw0ssq"> </h2> <!> <!></section>');
|
|
10
10
|
function Ee(J, d) {
|
|
11
11
|
e.push(d, !0);
|
|
@@ -373,4 +373,4 @@ e.delegate(["click"]);
|
|
|
373
373
|
export {
|
|
374
374
|
ze as default
|
|
375
375
|
};
|
|
376
|
-
//# sourceMappingURL=CollectionView.legacy-
|
|
376
|
+
//# sourceMappingURL=CollectionView.legacy-Cz6XX6Ly.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CollectionView.legacy-Cz6XX6Ly.js","sources":["../src/components/Calendar/GroupedListView.svelte","../src/components/Views/CollectionView.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 labels = {},\n } = $props();\n\n let displayedCount = $state(initialCount);\n let loadMoreTrigger = $state();\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={labels.eventListings || 'Event listings'}>\n <h2 class=\"sr-only\">{labels.eventListGroupedByDate || '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 || labels.statusOnSale || 'On Sale'}. ${labels.pressEnterToView || '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 {labels}\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\">{labels.loadingMoreEvents || '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","<script>\n import { onMount, onDestroy } from 'svelte';\n import { fetchPublicCollection } from '../../lib/api/events.ts';\n import { getImageUrl } from '$lib/utils/utils.js';\n import { EmptyState } from '@getmicdrop/svelte-components';\n import GalleryCard from '../Calendar/GalleryCard.svelte';\n import GroupedListView from '../Calendar/GroupedListView.svelte';\n import SkeletonLoader from '../SkeletonLoader/SkeletonLoader.svelte';\n\n let {\n collectionId,\n organizationId = '',\n onNavigateToEvent,\n password: initialPassword = undefined,\n displayMode: initialDisplayMode = 'gallery',\n showViewSwitcher = true,\n labels = {},\n } = $props();\n\n let collection = $state(null);\n let isLoading = $state(true);\n let error = $state(null);\n let isMounted = $state(false);\n let passwordRequired = $state(false);\n let passwordInput = $state('');\n let passwordError = $state(false);\n let activeDisplayMode = $state(initialDisplayMode);\n\n // Transform collection events into the shape GalleryCard expects\n function toGalleryEvent(event) {\n return {\n id: event.id,\n name: event.title || event.name || '',\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\n image: event.image ? getImageUrl(event.image) : '',\n timeline: event.startDateTime ? formatTimeline(event.startDateTime) : '',\n status: event.status || 'on_sale',\n slug: event.slug || '',\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\n ticketsTotal: event.ticketsTotal ?? event.capacity,\n };\n }\n\n // Transform collection events into the shape GroupedListView expects\n function toListEvent(event) {\n return {\n id: event.id,\n name: event.title || event.name || '',\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\n startDateTime: event.startDateTime || '',\n image: event.image ? getImageUrl(event.image) : '',\n status: event.status || 'on_sale',\n slug: event.slug || '',\n description: event.description || '',\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\n ticketsTotal: event.ticketsTotal ?? event.capacity,\n };\n }\n\n function formatTimeline(iso) {\n if (!iso) return '';\n const date = new Date(iso);\n return date.toLocaleTimeString('en-US', {\n hour: 'numeric',\n minute: '2-digit',\n hour12: true,\n });\n }\n\n let displayEvents = $derived(\n collection ? sortByStartTime(collection.events || []) : []\n );\n\n let galleryEvents = $derived(displayEvents.map(toGalleryEvent));\n let listEvents = $derived(displayEvents.map(toListEvent));\n\n // Only show view switcher when there are 2+ events\n let canShowSwitcher = $derived(showViewSwitcher && displayEvents.length >= 2);\n\n function sortByStartTime(events) {\n return [...events].sort((a, b) => {\n if (!a.startDateTime && !b.startDateTime) return 0;\n if (!a.startDateTime) return 1;\n if (!b.startDateTime) return -1;\n return new Date(a.startDateTime).getTime() - new Date(b.startDateTime).getTime();\n });\n }\n\n function handleEventClick(galleryEvent) {\n if (onNavigateToEvent) {\n const eventData = galleryEvent.detail || galleryEvent;\n onNavigateToEvent(eventData.id, eventData.slug || '');\n }\n }\n\n async function loadCollection(pwd) {\n if (!isMounted) return;\n if (!collectionId) {\n error = labels.noCollectionIdProvided || 'No collection ID provided';\n isLoading = false;\n return;\n }\n\n isLoading = true;\n error = null;\n passwordError = false;\n\n try {\n const data = await fetchPublicCollection(collectionId, pwd);\n if (!isMounted) return;\n\n if (data) {\n // Check if the response indicates password is required\n if (data.passwordRequired || data.error?.code === 'PASSWORD_REQUIRED') {\n passwordRequired = true;\n isLoading = false;\n return;\n }\n collection = data;\n passwordRequired = false;\n } else {\n // A null response after providing a password likely means wrong password\n if (pwd) {\n passwordRequired = true;\n passwordError = true;\n isLoading = false;\n return;\n }\n error = labels.failedToLoadCollection || 'Failed to load collection';\n }\n } catch (err) {\n if (isMounted) {\n // Check for password-related error responses\n const msg = err.message || '';\n if (msg.includes('401') || msg.includes('403') || msg.includes('password')) {\n passwordRequired = true;\n } else {\n error = msg || 'Failed to load collection';\n }\n }\n } finally {\n if (isMounted) {\n isLoading = false;\n }\n }\n }\n\n function handlePasswordSubmit(e) {\n e.preventDefault();\n if (!passwordInput.trim()) return;\n loadCollection(passwordInput);\n }\n\n onMount(async () => {\n isMounted = true;\n await loadCollection(initialPassword);\n });\n\n onDestroy(() => {\n isMounted = false;\n });\n</script>\n\n<div class=\"collection-view\">\n {#if isLoading}\n <SkeletonLoader type=\"gallery\" />\n {:else if passwordRequired}\n <div class=\"password-container\">\n <div class=\"password-card\">\n <h2 class=\"password-title\">{labels.collectionPrivateTitle || 'This collection is private'}</h2>\n <p class=\"password-description\">{labels.collectionPrivateDescription || 'Please enter the password to view this collection.'}</p>\n <form onsubmit={handlePasswordSubmit} class=\"password-form\">\n <input\n type=\"password\"\n bind:value={passwordInput}\n placeholder={labels.enterPassword || \"Enter password\"}\n class=\"password-input\"\n class:password-input-error={passwordError}\n />\n {#if passwordError}\n <p class=\"password-error-text\">{labels.incorrectPassword || 'Incorrect password. Please try again.'}</p>\n {/if}\n <button type=\"submit\" class=\"password-submit\">{labels.viewCollection || 'View Collection'}</button>\n </form>\n </div>\n </div>\n {:else if error}\n <div class=\"error-container\">\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\n </div>\n {:else if collection}\n <!-- Cover Image with Blur -->\n {#if collection.coverImage}\n {@const imageUrl = getImageUrl(collection.coverImage)}\n <div class=\"cover-image\">\n <div class=\"cover-blur\" style=\"background-image: url({imageUrl})\"></div>\n <img src={imageUrl} alt={collection.collectionTitle} />\n </div>\n {/if}\n\n <!-- Collection Header -->\n <div class=\"collection-header\">\n <h1 class=\"collection-title\">{collection.collectionTitle}</h1>\n {#if collection.summary}\n <p class=\"collection-summary\">{collection.summary}</p>\n {/if}\n {#if collection.description}\n <div class=\"collection-description\">{collection.description}</div>\n {/if}\n </div>\n\n <!-- Events Section -->\n <div class=\"events-section\">\n <div class=\"events-section-header\">\n <h2 class=\"events-heading\">Events ({displayEvents.length})</h2>\n\n {#if canShowSwitcher}\n <div class=\"view-switcher\" role=\"group\" aria-label={labels.viewOptions || \"Display mode\"}>\n <button\n type=\"button\"\n class=\"view-switcher-btn\"\n class:view-switcher-btn-active={activeDisplayMode === 'gallery'}\n onclick={() => activeDisplayMode = 'gallery'}\n aria-label={labels.galleryView || \"Gallery view\"}\n aria-pressed={activeDisplayMode === 'gallery'}\n >\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"3\" y=\"3\" width=\"7\" height=\"7\"></rect>\n <rect x=\"14\" y=\"3\" width=\"7\" height=\"7\"></rect>\n <rect x=\"3\" y=\"14\" width=\"7\" height=\"7\"></rect>\n <rect x=\"14\" y=\"14\" width=\"7\" height=\"7\"></rect>\n </svg>\n </button>\n <button\n type=\"button\"\n class=\"view-switcher-btn\"\n class:view-switcher-btn-active={activeDisplayMode === 'list'}\n onclick={() => activeDisplayMode = 'list'}\n aria-label={labels.listView || \"List view\"}\n aria-pressed={activeDisplayMode === 'list'}\n >\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <line x1=\"8\" y1=\"6\" x2=\"21\" y2=\"6\"></line>\n <line x1=\"8\" y1=\"12\" x2=\"21\" y2=\"12\"></line>\n <line x1=\"8\" y1=\"18\" x2=\"21\" y2=\"18\"></line>\n <line x1=\"3\" y1=\"6\" x2=\"3.01\" y2=\"6\"></line>\n <line x1=\"3\" y1=\"12\" x2=\"3.01\" y2=\"12\"></line>\n <line x1=\"3\" y1=\"18\" x2=\"3.01\" y2=\"18\"></line>\n </svg>\n </button>\n </div>\n {/if}\n </div>\n\n {#if displayEvents.length === 0}\n <EmptyState\n message={labels.noUpcomingEvents || \"No upcoming events\"}\n subtext={labels.noUpcomingEventsSubtext || \"There are no events in this collection right now. Check back soon!\"}\n />\n {:else if activeDisplayMode === 'list'}\n <GroupedListView\n events={listEvents}\n filterFutureOnly={false}\n oneventClick={handleEventClick}\n />\n {:else}\n <div class=\"events-grid\">\n {#each galleryEvents as event (event.id)}\n <GalleryCard {event} oneventClick={handleEventClick} />\n {/each}\n </div>\n {/if}\n </div>\n {/if}\n</div>\n\n<style>\n .collection-view {\n width: 100%;\n max-width: 64rem;\n margin-left: auto;\n margin-right: auto;\n padding-left: 1rem;\n padding-right: 1rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .error-container,\n .password-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n min-height: 50vh;\n text-align: center;\n }\n\n .error-text {\n color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n\n /* Password gate */\n .password-card {\n border-radius: 0.5rem;\n padding: 2rem;\n max-width: 24rem;\n width: 100%;\n background: hsl(var(--surface-primary, 0 0% 100%));\n box-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\n }\n\n .password-title {\n font-size: 1.25rem;\n line-height: 1.75rem;\n font-weight: 700;\n margin-bottom: 0.5rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .password-description {\n font-size: 0.875rem;\n line-height: 1.25rem;\n margin-bottom: 1.5rem;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .password-form {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n }\n\n .password-input {\n width: 100%;\n padding: 0.5rem 0.75rem;\n border-radius: 0.5rem;\n font-size: 0.875rem;\n line-height: 1.25rem;\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 85%));\n color: hsl(var(--text-primary, 0 0% 10%));\n background: hsl(var(--surface-primary, 0 0% 100%));\n }\n\n .password-input:focus {\n outline: none;\n border-color: hsl(var(--brand-primary, 220 90% 56%));\n box-shadow: 0 0 0 2px hsl(var(--brand-primary, 220 90% 56%) / 20%);\n }\n\n .password-input-error {\n border-color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n\n .password-error-text {\n font-size: 0.75rem;\n line-height: 1rem;\n color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n\n .password-submit {\n padding: 0.5rem 1rem;\n border-radius: 0.5rem;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n background: hsl(var(--brand-primary, 220 90% 56%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n .password-submit:hover {\n filter: brightness(0.95);\n }\n\n /* Cover Image with blur background */\n .cover-image {\n position: relative;\n width: 100%;\n overflow: hidden;\n border-radius: 0.5rem;\n margin-bottom: 2rem;\n height: 350px;\n }\n\n .cover-blur {\n position: absolute;\n inset: 0;\n background-size: cover;\n background-position: center;\n filter: blur(24px) saturate(1.2);\n transform: scale(1.15);\n }\n\n .cover-image img {\n position: relative;\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n /* Header */\n .collection-header {\n margin-bottom: 2rem;\n }\n\n .collection-title {\n font-size: 1.875rem;\n line-height: 2.25rem;\n font-weight: 700;\n margin-bottom: 0.5rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .collection-summary {\n font-size: 1.125rem;\n line-height: 1.75rem;\n margin-bottom: 1rem;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .collection-description {\n line-height: 1.625;\n color: hsl(var(--text-secondary, 0 0% 35%));\n }\n\n /* Events Section */\n .events-section {\n margin-bottom: 2rem;\n }\n\n .events-section-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 1rem;\n }\n\n .events-heading {\n font-size: 1.5rem;\n line-height: 2rem;\n font-weight: 700;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n /* View Switcher */\n .view-switcher {\n display: flex;\n gap: 0.25rem;\n padding: 0.25rem;\n border-radius: 0.5rem;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n }\n\n .view-switcher-btn {\n padding: 0.375rem;\n border-radius: 0.375rem;\n transition: color 0.15s;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .view-switcher-btn:hover {\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .view-switcher-btn-active {\n color: hsl(var(--text-primary, 0 0% 10%));\n background: hsl(var(--surface-primary, 0 0% 100%));\n box-shadow: 0 1px 2px color-mix(in srgb, black 8%, transparent);\n }\n\n .events-grid {\n display: grid;\n gap: 1.5rem;\n grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));\n }\n\n /* Responsive */\n @media (width <= 640px) {\n .cover-image {\n height: 250px;\n }\n\n .collection-title {\n font-size: 1.5rem;\n line-height: 2rem;\n }\n\n .events-grid {\n grid-template-columns: repeat(2, 1fr);\n }\n }\n\n @media (width <= 400px) {\n .events-grid {\n grid-template-columns: 1fr;\n }\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","labels","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","h2","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_6","consequent_1","div_5","span_3","root_5","text_7","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_4","formatFullDate","formatEventTime","div_6","root_7","span_4","$$value","consequent_4","classes","initialPassword","initialDisplayMode","showViewSwitcher","collection","isLoading","error","isMounted","passwordRequired","passwordInput","passwordError","activeDisplayMode","toGalleryEvent","getImageUrl","formatTimeline","toListEvent","iso","displayEvents","sortByStartTime","galleryEvents","listEvents","canShowSwitcher","galleryEvent","eventData","loadCollection","pwd","data","fetchPublicCollection","err","msg","handlePasswordSubmit","SkeletonLoader","form","input","p_1","button","p_2","imageUrl","root_6","node_2","h1","p_3","consequent_5","div_7","root_8","consequent_6","div_8","div_9","h2_1","div_10","root_9","button_1","button_2","classes_2","consequent_7","EmptyState","GroupedListView","div_11","root_12","GalleryCard","consequent_8","consequent_9","alternate","text_5","text_8","consequent_10"],"mappings":";;;;;;;;;kBAAA;;MAQIA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GACNC,iCAAe,EAAE,GACjBC,kCAAgB,EAAE,GAClBC,mCAAiB,EAAI,GACrBC,qCAAmB,EAAI,GAEvBC,IAAMN,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA,GAGJM,IAAiBP,EAAA,MAAMA,EAAA,MAACE,EAAY,CAAA,CAAA,GACpCM,IAAkBR,EAAA,MAAM,MAAA,GACxBS,GAGAC,oBAA0BL,MAAmBM,GAAqBZ,EAAM,KAAIA,GAAM,GAClFa,IAAaZ,EAAA,QAAA,MAAYa,EAAiBb,EAAA,IAACU,CAAc,EAAC,MAAM,GAACV,EAAA,IAAEO,CAAc,CAAA,CAAA,CAAA,GACjFO,IAAOd,EAAA,QAAA,MAAAA,EAAA,IAAYO,CAAc,IAAAP,EAAA,IAAGU,CAAc,EAAC,MAAM;AAEpD,WAAAK,IAAW;UAClBR,GAAcP,EAAA,IAAdO,CAAc,IAAIJ,GAAa;AAAA,EACjC;AAEA,EAAAa,GAAO,MAAO;AACZ,IAAAP,QAAe;AAAA,MACZ,CAAAQ,MAAY;AACP,QAAAA,EAAQ,CAAC,EAAE,kBAAcjB,EAAA,IAAIc,CAAO,KACtCC,EAAQ;AAAA,MAEZ;AAAA,MACE,EAAA,YAAY,QAAO;AAAA,OAGnBf,EAAA,IAAAQ,CAAe,KACjBC,EAAS,QAAOT,EAAA,IAACQ,CAAe,CAAA;AAAA,EAEpC,CAAC,GAEDU,GAAS,MAAO;AACV,IAAAT,KACFA,EAAS,WAAU;AAAA,EAEvB,CAAC,GAGDT,EAAA,YAAO,MAAO;IACRS,KAAQT,EAAA,IAAIQ,CAAe,MAC7BC,EAAS,WAAU,GACnBA,EAAS,QAAOT,EAAA,IAACQ,CAAe,CAAA;AAAA,EAEpC,CAAC;WAEQK,EAAkBM,GAAW;UAC9BC,IAAM,CAAA;eAEDC,KAASF,GAAW;YACvBG,IAAUD,EAAM;MACjBD,EAAOE,CAAO,MACjBF,EAAOE,CAAO,IAAA,CAAA,IAEhBF,EAAOE,CAAO,EAAE,KAAKD,CAAK;AAAA,IAC5B;AAGO,WAAA,OAAO,QAAQD,CAAM,EACzB,KAAI,CAAA,CAAGG,CAAC,GAAA,CAAIC,CAAC,MAAA,IAAU,KAAKD,CAAC,IAAA,IAAQ,KAAKC,CAAC,CAAA,EAC3C,IAAG,CAAA,CAAGC,GAAM1B,CAAM,OAAA,EACjB,MAAA0B,GACA,QAAA1B,GACA,eAAe2B,EAAgB3B,CAAM,EAAA,EAAA;AAAA,EAE3C;WAES2B,EAAgB3B,GAAQ;UAEzB4B,IAAa5B,EAAO,CAAC;AACtB,QAAA,CAAA4B,GAAY,cAAa,QAAA,EAAW,OAAO,IAAI,KAAK,IAAI,SAAS,GAAE;UAClEC,IAAQC,GAAaF,EAAW,eAAeA,EAAW,QAAQ;;MAEtE,OAAOC,EAAM,MAAM,YAAW;AAAA,MAC9B,KAAK,OAAOA,EAAM,IAAI,EAAE,SAAS,GAAG,GAAG;AAAA,MACvC,SAASA,EAAM,IAAI,YAAW;AAAA;EAElC;WAESE,EAAiBT,GAAO;qBAChBA,CAAK;AAAA,EACtB;AAES,WAAAU,EAAcC,GAAGX,GAAO;KAC3BW,EAAE,QAAQ,WAAWA,EAAE,QAAQ,SACjCA,EAAE,eAAc,GAChBF,EAAiBT,CAAK;AAAA,EAE1B;MAGDY,IAAOC,GAAA;;AACL,MAAAC,YADFF,CAAO,eACLE,GAAE,EAAA;UAAFA,CAAE;oBAAFA,GAAE,CAAA;AACI,EAAAnC,EAAA,KAAAoC,GAAA,IAAA,MAAApC,EAAA,IAAAY,CAAa,gBAAIyB,MAAK;QAC1BC,IAAGC,GAAA,eAAHD,CAAG;;;YAGCE,IAAGC,GAAA,GACDC,YADFF,CAAG,eACDE,GAAI,EAAA;gBAAJA,CAAI;AACJ,YAAAC,cADAD,GAAI,CAAA,eACJC,GAAI,EAAA;gBAAJA,CAAI;AACJ,YAAAC,cADAD,GAAI,CAAA,eACJC,GAAI,EAAA;gBAAJA,CAAI,WAHNJ,CAAG;8BACgFH,CAAK,EAAC,cAAc,KAAK,uBAC1BA,CAAK,EAAC,cAAc,GAAG,uBACtBA,CAAK,EAAC,cAAc,OAAO;AAAA,wBAH9GG,CAAG;AAAA;;QADDpC,EAAc,KAAAyC,EAAAC,CAAA;AAAA;;QASlBC,IAAE/C,EAAA,QAAAgD,GAAA,CAAA;AAAF,IAAAhD,EAAA,KAAA+C,GAAE,IAAA,MAAA/C,EAAA,IACMqC,CAAK,EAAC,qBAAUhB,MAAK;YAClB4B,IAAWjD,EAAA,QAAA,MAAGkD,GAAelD,EAAA,IAACqB,CAAK,CAAA,CAAA,GACnC8B,IAAanD,EAAA,QAAA,MAAGoD,GAAkBpD,EAAA,IAACiD,CAAW,CAAA,CAAA;UACrDI,IAAEC,GAAA,GACAC,YADFF,CAAE;;AAWE,UAAAG,YAVFD,CAAE,GAWEE,YADFD,CAAG;cAAHA,CAAG;AAUH,UAAAE,cAVAF,GAAG,CAAA,GAWDG,YADFD,CAAG,eACDC,GAAE,EAAA;cAAFA,CAAE;AACF,UAAAC,cADAD,GAAE,CAAA,eACFC,GAAI,EAAA;cAAJA,CAAI;wBAAJA,GAAI,CAAA;;;cAEFC,IAACC,GAAA,eAADD,GAAC,EAAA;kBAADA,CAAC,GAA+F7D,EAAA,gBAAA,MAAAA,EAAA,SAAA+D,GAAA/D,EAAA,IAAAqB,CAAK,EAAC,WAAW,CAAA,eAAjHwC,CAAC;AAAA;;AADC,UAAA7D,EAAA,IAAAqB,CAAK,EAAC,eAAWwB,EAAAmB,CAAA;AAAA;;cAHvBN,CAAG;AASH,UAAAO,cATAP,GAAG,CAAA,gBASHO,CAAG;;;cAECC,IAAIC,GAAA,eAAJD,GAAI,EAAA;kBAAJA,CAAI;wBAAJA,GAAI,GAAA,uBAAAlE,EAAA,IAA6BiD,CAAW,EAAC,QAAI,EAAA,IAAA,gBAAA,GAAIjD,EAAA,SAAAoE,GAAApE,EAAA,IAAAiD,CAAW,EAAC,IAAI;AAAA,0BAArEiB,CAAI;AAAA;;0CAGQ7C,CAAK,EAAC,oBAAoB,CAAC,6BAC/BA,CAAK,EAAC,gBAAgB,CAAC;AAF/B,YAAAgD,GAAYC,GAAA;AAAA;;;;;;;;uBAIVhE,EAAM;AAAA;;;;;gBAPN2C,CAAW,IAAAJ,EAAA0B,EAAA,KAAAvE,EAAA,IAENqB,CAAK,EAAC,eAAe,KAACrB,EAAA,IAAIqB,CAAK,EAAC,qBAAqB,MAACwB,EAAA2B,IAAA,CAAA;AAAA;;cAHjEP,CAAG,WA7BLV,CAAE,WADJF,CAAE;;AACA,UAAAoB,IAAAzE,EAAA,UAAAuD,2ZAEwBJ,CAAa,EAAA,CAAA,mBAFrCI,GAAE,cAAAmB,CAAA,GAWE1E,EAAA,cAAAyD,GAAE,OAAAzD,EAAA,IACIqB,CAAK,EAAC,SAASsD,EAAiB,GAS8C3E,EAAA,SAAA4E,GAAA5E,EAAA,IAAAqB,CAAK,EAAC,IAAI,GAC9FrB,EAAA,cAAA4D,qBAA8EvC,CAAK,EAAC,iBAAarB,EAAA,IAAIqC,CAAK,EAAC,IAAI;;;UAfnG,MAAA,GAAArC,EAAA,IAAAqB,CAAK,EAAC,IAAI,OAAArB,EAAA,IAAOqB,CAAK,EAAC,gBAAgBwD,SAAexD,CAAK,EAAC,eAAarB,EAAA,IAAEqB,CAAK,EAAC,QAAQ,IAAIrB,EAAA,IAAAqC,CAAK,EAAC,IAAI,OAAArC,EAAA,IAAOqB,CAAK,EAAC,gBAAgByD,SAAgBzD,CAAK,EAAC,eAAarB,EAAA,IAAEqB,CAAK,EAAC,QAAQ,IAAI,EAAE,WAAK4B,CAAW,GAAE,QAAIjD,EAAA,IAAIqB,CAAK,EAAC,UAAUf,EAAM,EAAC,gBAAgB,SAAS,KAAKA,EAAM,EAAC,oBAAoB,6BAA6B;AAAA,UAe9N,MAAAN,EAAA,IAAAqB,CAAK,EAAC,gBAAgByD,SAAgBzD,CAAK,EAAC,eAAarB,EAAA,IAAEqB,CAAK,EAAC,QAAQ,IAAI;AAAA;8BAtBnMkC,GAAE,MAGczB,EAAgB9B,EAAA,IAACqB,CAAK,CAAA,CAAA,GAHtCrB,EAAA,UAAA,WAAAuD,IAIavB,MAAMD,EAAcC,SAAGX,CAAK,CAAA,CAAA,eAL3CgC,CAAE;AAAA,gBAJNN,CAAE,WAXJT,CAAG,4CAAHA,GAAG,cAAA,aAAAoC,KAAA,EAAA,EAAA,GAAA;AAAA,MAAoG,MAAA1E,EAAA,IAAAqC,CAAK,EAAC,OAAO,CAAC,GAAG,gBAAgBwC,GAAc7E,EAAA,IAACqC,CAAK,EAAC,OAAO,CAAC,EAAE,eAAarC,EAAA,IAAEqC,CAAK,EAAC,OAAO,CAAC,EAAE,QAAQ,IAAIrC,EAAA,IAAAqC,CAAK,EAAC;AAAA,oBAAxNC,CAAG;AAAA;;;;UAkEHyC,IAAGC,GAAA,GACDC,YADFF,CAAG,eACDE,GAAI,EAAA;cAAJA,CAAI,WADNF,CAAG,eAAHA,GAAG,CAAAG,MAAAlF,EAAA,IAAYQ,GAAe0E,CAAA,GAAA,MAAAlF,EAAA,IAAfQ,CAAe,CAAA,yCACNF,EAAM,EAAC,qBAAqB,wBAAwB,CAAA,eAD5EyE,CAAG;AAAA;;YADDjE,CAAO,KAAA+B,EAAAsC,CAAA;AAAA;;UApEblD,CAAO;AAAP,IAAAmD,IAAApF,EAAA,UAAAiC,0EAA2D7B,EAAc,EAAA,CAAA,GAAzEJ,EAAA,cAAAiC,GAAO,cAAgF3B,EAAM,EAAC,iBAAiB,gBAAgB,iBACzGA,EAAM,EAAC,0BAA0B,4BAA4B;AAAA,kBADnF2B,CAAO;AAFA;;;kBCtGR;gDAWqB,EAAE;AAET,MAAAoD,6BAAkB,MAAS,GACxBC,gCAAqB,SAAS,GAC3CC,qCAAmB,EAAI,GACvBjF,IAAMN,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,GAAA,GAGJuF,IAAaxF,EAAA,MAAO,IAAI,GACxByF,IAAYzF,EAAA,MAAO,EAAI,GACvB0F,IAAQ1F,EAAA,MAAO,IAAI,GACnB2F,IAAY3F,EAAA,MAAO,EAAK,GACxB4F,IAAmB5F,EAAA,MAAO,EAAK,GAC/B6F,IAAgB7F,EAAA,MAAO,EAAE,GACzB8F,IAAgB9F,EAAA,MAAO,EAAK,GAC5B+F,IAAoB/F,EAAA,MAAMA,EAAA,MAACsF,EAAkB,CAAA,CAAA;WAGxCU,EAAe3E,GAAO;;MAE3B,IAAIA,EAAM;AAAA,MACV,MAAMA,EAAM,SAASA,EAAM,QAAQ;AAAA,MACnC,MAAMA,EAAM,gBAAgBA,EAAM,cAAc,MAAM,GAAG,EAAE,CAAC,IAAI;AAAA,MAChE,OAAOA,EAAM,QAAQ4E,GAAY5E,EAAM,KAAK,IAAI;AAAA,MAChD,UAAUA,EAAM,gBAAgB6E,EAAe7E,EAAM,aAAa,IAAI;AAAA,MACtE,QAAQA,EAAM,UAAU;AAAA,MACxB,MAAMA,EAAM,QAAQ;AAAA,MACpB,kBAAkBA,EAAM,oBAAoBA,EAAM;AAAA,MAClD,cAAcA,EAAM,gBAAgBA,EAAM;AAAA;EAE9C;WAGS8E,EAAY9E,GAAO;;MAExB,IAAIA,EAAM;AAAA,MACV,MAAMA,EAAM,SAASA,EAAM,QAAQ;AAAA,MACnC,MAAMA,EAAM,gBAAgBA,EAAM,cAAc,MAAM,GAAG,EAAE,CAAC,IAAI;AAAA,MAChE,eAAeA,EAAM,iBAAiB;AAAA,MACtC,OAAOA,EAAM,QAAQ4E,GAAY5E,EAAM,KAAK,IAAI;AAAA,MAChD,QAAQA,EAAM,UAAU;AAAA,MACxB,MAAMA,EAAM,QAAQ;AAAA,MACpB,aAAaA,EAAM,eAAe;AAAA,MAClC,kBAAkBA,EAAM,oBAAoBA,EAAM;AAAA,MAClD,cAAcA,EAAM,gBAAgBA,EAAM;AAAA;EAE9C;WAES6E,EAAeE,GAAK;AACtB,WAAAA,IACK,IAAO,KAAKA,CAAG,EACb,mBAAmB,WAC7B,MAAM,WACN,QAAQ,WACR,QAAQ,IAAI,IALG;AAAA,EAOnB;AAEI,MAAAC,0BACFb,CAAU,IAAGc,EAAetG,EAAA,IAACwF,CAAU,EAAC,UAAM,CAAA,CAAA,IAAA,EAAA,GAG5Ce,IAAavG,EAAA,QAAA,MAAAA,EAAA,IAAYqG,CAAa,EAAC,IAAIL,CAAc,CAAA,GACzDQ,IAAUxG,EAAA,QAAA,MAAAA,EAAA,IAAYqG,CAAa,EAAC,IAAIF,CAAW,CAAA,GAGnDM,oBAA2BlB,EAAgB,KAAAvF,EAAA,IAAIqG,CAAa,EAAC,UAAU,CAAC;WAEnEC,EAAgBvG,GAAQ;AACpB,WAAA,CAAA,GAAAA,CAAM,EAAE,KAAI,CAAEwB,GAAGC,MACrB,CAAAD,EAAE,iBAAa,CAAKC,EAAE,gBAAsB,IAC5CD,EAAE,gBACFC,EAAE,gBACI,IAAA,KAAKD,EAAE,aAAa,EAAE,YAAO,IAAS,KAAKC,EAAE,aAAa,EAAE,QAAO,IAD1D,KADS,CAG9B;AAAA,EACH;WAESM,EAAiB4E,GAAc;AACf,QAAAzG,EAAA,mBAAA;AACf,YAAA0G,IAAYD,EAAa,UAAUA;AACvB,MAAAzG,EAAA,kBAAA0G,EAAU,IAAIA,EAAU,QAAQ,EAAE;AAAA,IACtD;AAAA,EACF;iBAEeC,EAAeC,GAAK;cAC5BlB,CAAS,GACK;AAAA,UAAA,CAAA1F,EAAA,cAAA;AACjB,QAAAD,EAAA,IAAA0F,GAAQpF,EAAM,EAAC,0BAA0B,6BAA2B,EAAA,GACpEN,EAAA,IAAAyF,GAAY,EAAK;;MAEnB;AAEA,MAAAzF,EAAA,IAAAyF,GAAY,EAAI,GAChBzF,EAAA,IAAA0F,GAAQ,IAAI,GACZ1F,EAAA,IAAA8F,GAAgB,EAAK;AAEjB,UAAA;cACIgB,IAAI,MAASC,GAAqB9G,EAAA,cAAe4G,CAAG;mBACrDlB,CAAS,EAAA;AAEV,YAAAmB,GAAM;cAEJA,EAAK,oBAAoBA,EAAK,OAAO,SAAS,qBAAqB;AACrE,YAAA9G,EAAA,IAAA4F,GAAmB,EAAI,GACvB5F,EAAA,IAAAyF,GAAY,EAAK;;UAEnB;AACA,UAAAzF,EAAA,IAAAwF,GAAasB,GAAI,EAAA,GACjB9G,EAAA,IAAA4F,GAAmB,EAAK;AAAA,QAC1B,OAAO;AAED,cAAAiB,GAAK;AACP,YAAA7G,EAAA,IAAA4F,GAAmB,EAAI,GACvB5F,EAAA,IAAA8F,GAAgB,EAAI,GACpB9F,EAAA,IAAAyF,GAAY,EAAK;;UAEnB;AACA,UAAAzF,EAAA,IAAA0F,GAAQpF,EAAM,EAAC,0BAA0B,6BAA2B,EAAA;AAAA,QACtE;AAAA,MACF,SAAS0G,GAAK;AACR,YAAAhH,EAAA,IAAA2F,CAAS,GAAE;AAEP,gBAAAsB,IAAMD,EAAI,WAAW;AACvB,UAAAC,EAAI,SAAS,KAAK,KAAKA,EAAI,SAAS,KAAK,KAAKA,EAAI,SAAS,UAAU,IACvEjH,EAAA,IAAA4F,GAAmB,EAAI,UAEvBF,GAAQuB,KAAO,6BAA2B,EAAA;AAAA,QAE9C;AAAA,MACF,UAAC;AACK,QAAAjH,EAAA,IAAA2F,CAAS,KACX3F,EAAA,IAAAyF,GAAY,EAAK;AAAA,MAErB;AAAA;AAAA,EACF;WAESyB,GAAqBlF,GAAG;AAE1B,IADLA,EAAE,eAAc,GACXhC,EAAA,IAAA6F,CAAa,EAAC,KAAI,KACvBe,QAAef,CAAa,CAAA;AAAA,EAC9B;AAEA,EAAA7E,GAAO,YAAa;AAClB,IAAAhB,EAAA,IAAA2F,GAAY,EAAI,GACV,MAAAiB,EAAevB,GAAe;AAAA,EACtC,CAAC,GAEDnE,GAAS,MAAO;AACd,IAAAlB,EAAA,IAAA2F,GAAY,EAAK;AAAA,EACnB,CAAC;MAGFrD,IAAGJ,GAAA,eAAHI,CAAG;;;AAEC,MAAA6E,GAAc7C,GAAA,EAAA,MAAA,UAAA,CAAA;AAAA;UAEd9B,IAAGC,GAAA,GACDc,YADFf,CAAG,GAECL,YADFoB,CAAG,eACDpB,GAAE,EAAA;cAAFA,CAAE;AACF,UAAA0B,cADA1B,GAAE,CAAA,eACF0B,GAAC,EAAA;cAADA,CAAC;AACD,UAAAuD,cADAvD,GAAC,CAAA,GAECwD,YADFD,CAAI;8BACFC,CAAI;;wBAAJA,GAAI,CAAA;;;cAQFC,IAAChE,GAAA,eAADgE,GAAC,EAAA;kBAADA,CAAC,yCAA8BhH,EAAM,EAAC,qBAAqB,uCAAuC,CAAA,eAAlGgH,CAAC;AAAA;;gBADCxB,CAAa,KAAAjD,EAAAmB,CAAA;AAAA;;UAGjBuD,IAAMvH,EAAA,QAAAgD,GAAA,CAAA,eAANuE,GAAM,EAAA;cAANA,CAAM,WAXRH,CAAI,WAHN7D,CAAG,WADLf,CAAG;sBAE4BlC,EAAM,EAAC,0BAA0B,4BAA4B,iBACxDA,EAAM,EAAC,gCAAgC,oDAAoD,GAEzHN,EAAA,cAAAqH,GAAI,eAGU/G,EAAM,EAAC,iBAAiB,gBAAgB,GAHtD8E,IAAApF,EAAA,UAAAqH,+EAK6BvB,CAAa,EAAA,CAAA,iBAKIxF,EAAM,EAAC,kBAAkB,iBAAiB;AAAA,UAX1FN,EAAA,MAAA,UAAAoH,GAAeF,EAAoB,gBACjCG,GAAI,MAAArH,EAAA,IAES6F,CAAa,GAAA,CAAAX,MAAAlF,EAAA,IAAb6F,GAAaX,CAAA,CAAA,eAPhC1C,CAAG;AAAA;UAoBHgB,IAAGM,GAAA,GACD0D,YADFhE,CAAG,eACDgE,CAAC;cAADA,CAAC,WADHhE,CAAG,GACqBxD,EAAA,gBAAA,MAAAA,EAAA,SAAA4E,GAAA,IAAAtE,IAAO,eAAe,yBAAWoF,CAAK,KAAA,EAAA,EAAA,CAAA,eAD9DlC,CAAG;AAAA;;;;AAMM,gBAAAiE,IAAQzH,EAAA,QAAA,MAAGiG,GAAWjG,EAAA,IAACwF,CAAU,EAAC,UAAU,CAAA;cACnD9B,IAAGgE,GAAA,GACDzD,YADFP,CAAG,GAEDD,cADAQ,GAAG,CAAA;kBADLP,CAAG;AACD,YAAA1D,EAAA,UAAAiE,kCAAqDwD,CAAQ,KAAA,EAAA,GAAA,GAC7DzH,EAAA,cAAAyD,gBAASgE,CAAQ,CAAA,mBAAjBhE,GAAG,OAAAzD,EAAA,IAAqBwF,CAAU,EAAC,eAAe;AAAA,0BAFpD9B,CAAG;AAAA;;AAFD,UAAA1D,EAAA,IAAAwF,CAAU,EAAC,cAAU3C,EAAAsC,CAAA;AAAA;;UASzBJ,IAAG/E,EAAA,QAAA2H,GAAA,CAAA,GACDC,YADF7C,CAAG,eACD6C,GAAE,EAAA;cAAFA,CAAE;wBAAFA,GAAE,CAAA;;;cAEAC,IAAC7C,GAAA,eAAD6C,GAAC,EAAA;kBAADA,CAAC,GAA6B7H,EAAA,gBAAA,MAAAA,EAAA,SAAA+D,GAAA/D,EAAA,IAAAwF,CAAU,EAAC,OAAO,CAAA,eAAhDqC,CAAC;AAAA;;AADC,UAAA7H,EAAA,IAAAwF,CAAU,EAAC,WAAO3C,EAAAiF,CAAA;AAAA;;;;;cAIpBC,IAAGC,GAAA,eAAHD,GAAG,EAAA;kBAAHA,CAAG,GAAiC/H,EAAA,gBAAA,MAAAA,EAAA,SAAAoE,GAAApE,EAAA,IAAAwF,CAAU,EAAC,WAAW,CAAA,eAA1DuC,CAAG;AAAA;;AADD,UAAA/H,EAAA,IAAAwF,CAAU,EAAC,eAAW3C,EAAAoF,CAAA;AAAA;;cAL5BlD,CAAG;AAWH,UAAAmD,cAXAnD,GAAG,CAAA,GAYDoD,YADFD,CAAG,GAECE,YADFD,CAAG,eACDC,CAAE;cAAFA,CAAE;wBAAFA,GAAE,CAAA;;;cAGAC,IAAGC,GAAA,GACDC,YADFF,CAAG;;AAgBD,cAAAG,cAfAD,GAAK,CAAA;;kBADPF,CAAG;AAAH,YAAArI,EAAA,cAAAqI,GAAG,cAAgD/H,EAAM,EAAC,eAAe,cAAc,mBACrFiI,GAAK,GAAA,mCAAA,MAAA9D,GAAA;AAAA,cAG4B,4BAAAzE,EAAA,IAAA+F,CAAiB,MAAK;AAAA,gBAHvD/F,EAAA,cAAAuI,GAAK,cAKQjI,EAAM,EAAC,eAAe,cAAc,mBALjDiI,GAAK,gBAAAvI,EAAA,IAMU+F,CAAiB,MAAK,SAAS,oBAS9CyC,GAAK,GAAA,mCAAA,MAAAC,IAAA;AAAA,cAG4B,4BAAAzI,EAAA,IAAA+F,CAAiB,MAAK;AAAA,gBAHvD/F,EAAA,cAAAwI,GAAK,cAKQlI,EAAM,EAAC,YAAY,WAAW,mBAL3CkI,GAAK,gBAAAxI,EAAA,IAMU+F,CAAiB,MAAK,MAAM;AAAA,mCArB3CwC,GAAK,MAAAvI,EAAA,IAIW+F,GAAoB,SAAS,CAAA,wBAW7CyC,GAAK,MAAAxI,EAAA,IAIW+F,GAAoB,MAAM,CAAA,eApB5CsC,CAAG;AAAA;;gBADD5B,CAAe,KAAA5D,EAAA6F,CAAA;AAAA;;cAHrBP,CAAG;wBAAHA,GAAG,CAAA;;;;oCA2CS7H,EAAM,EAAC,oBAAoB,oBAAoB,uBAC/CA,EAAM,EAAC,2BAA2B,oEAAoE;AAFhH,YAAAqI,GAASrE,GAAA;AAAA;;;;;;;;;AAKT,UAAAsE,GAActE,GAAA;AAAA;2BACLkC,CAAU;AAAA;8BACA;AAAA,0BACJ1E;AAAA;;cAGf+G,IAAGC,GAAA;iBAAHD,GAAG,IAAA,MAAA7I,EAAA,IACKuG,CAAa,GAAA,CAAIlF,MAAOA,EAAM,IAAE,CAAAiD,GAAfjD,MAAK;AAC1B,YAAA0H,GAAWzE,GAAA;AAAA;6BAAEjD,CAAK;AAAA;4BAAgBS;AAAA;sBAFtC+G,CAAG,eAAHA,CAAG;AAAA;;AAZD,UAAA7I,EAAA,IAAAqG,CAAa,EAAC,WAAW,IAACxD,EAAAmG,EAAA,IAAAhJ,EAAA,IAKrB+F,CAAiB,MAAK,SAAMlD,EAAAoG,IAAA,CAAA,IAAApG,EAAAqG,IAAA,EAAA;AAAA;;cA/CvChB,CAAG;AAV4B,QAAAlI,EAAA,SAAAmJ,GAAAnJ,EAAA,IAAAwF,CAAU,EAAC,eAAe,GAYlBxF,EAAA,SAAAoJ,GAAA,WAAApJ,EAAA,IAAAqG,CAAa,EAAC,UAAM,EAAA,GAAA;AAAA;;;AAlDzD,MAAArG,EAAA,IAAAyF,CAAS,IAAA5C,EAAAC,CAAA,IAAA9C,EAAA,IAEJ4F,CAAgB,IAAA/C,EAAA0B,GAAA,CAAA,IAAAvE,EAAA,IAoBhB0F,CAAK,oBAILF,CAAU,KAAA3C,EAAAwG,GAAA,CAAA;AAAA;;UA3BrB/G,CAAG,eAAHA,CAAG;AAFI;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
|
-
import { f as me, B as Z, L as Ke, T as je, S as vt, M as ut, C as ft, I as qe, j as gt, a as pt, c as mt, t as Ge, b as ht, g as bt, A as _t, d as Ue, e as xt, h as yt, i as Qe, W as wt, F as kt } from "./VenueCalendar-
|
|
2
|
+
import { f as me, B as Z, L as Ke, T as je, S as vt, M as ut, C as ft, I as qe, j as gt, a as pt, c as mt, t as Ge, b as ht, g as bt, A as _t, d as Ue, e as xt, h as yt, i as Qe, W as wt, F as kt } from "./VenueCalendar-Djc3e2j2.js";
|
|
3
3
|
import * as e from "svelte/internal/client";
|
|
4
4
|
import "svelte/internal/flags/legacy";
|
|
5
5
|
import "svelte/transition";
|
|
@@ -1184,4 +1184,4 @@ e.delegate(["click"]);
|
|
|
1184
1184
|
export {
|
|
1185
1185
|
xa as default
|
|
1186
1186
|
};
|
|
1187
|
-
//# sourceMappingURL=EventDetailsView-
|
|
1187
|
+
//# sourceMappingURL=EventDetailsView-Cp5IRJam.js.map
|