@getmicdrop/venue-calendar 3.4.8 → 3.5.0
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 +661 -661
- package/dist/{CarouselView.legacy-DOaevebR.js → CarouselView.legacy-fAmsAKLi.js} +3 -3
- package/dist/CarouselView.legacy-fAmsAKLi.js.map +1 -0
- package/dist/{Checkout.legacy-nETM-IMW.js → Checkout.legacy-DqNypQ8O.js} +2 -2
- package/dist/Checkout.legacy-DqNypQ8O.js.map +1 -0
- package/dist/{FeaturedView.legacy-ukM7qVzM.js → FeaturedView.legacy-BNysXCtk.js} +2 -2
- package/dist/FeaturedView.legacy-BNysXCtk.js.map +1 -0
- package/dist/GalleryCard-RBMkn3Va.js +92 -0
- package/dist/GalleryCard-RBMkn3Va.js.map +1 -0
- package/dist/{GalleryView.legacy-LhMmiGMD.js → GalleryView.legacy-BDKpD6lT.js} +3 -3
- package/dist/GalleryView.legacy-BDKpD6lT.js.map +1 -0
- package/dist/{GroupedListView.legacy-Ce-hzjBr.js → GroupedListView.legacy-fL2kRm35.js} +2 -2
- package/dist/GroupedListView.legacy-fL2kRm35.js.map +1 -0
- package/dist/{Success.legacy-CHqoM06M.js → Success.legacy-D9MZwTCk.js} +2 -2
- package/dist/Success.legacy-D9MZwTCk.js.map +1 -0
- package/dist/{VenueCalendar-mBg8Hi0c.js → VenueCalendar-DsXtZNAR.js} +11523 -10897
- package/dist/VenueCalendar-DsXtZNAR.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 +349 -349
- package/dist/colors-BZoMuXdh.js.map +1 -1
- package/dist/seo/HostSeoController.d.ts +59 -0
- package/dist/seo/buildCollectionJsonLd.d.ts +7 -0
- package/dist/seo/buildEventJsonLd.d.ts +9 -0
- package/dist/seo/buildSeriesJsonLd.d.ts +6 -0
- package/dist/seo/helpers.d.ts +40 -0
- package/dist/seo/index.d.ts +9 -0
- package/dist/seo/seo.cjs +2 -0
- package/dist/seo/seo.cjs.map +1 -0
- package/dist/seo/seo.mjs +460 -0
- package/dist/seo/seo.mjs.map +1 -0
- package/dist/seo/types.d.ts +135 -0
- package/dist/types/index.d.ts +387 -387
- package/dist/venue-calendar.css +1 -1
- package/dist/venue-calendar.es.js +2 -2
- package/dist/venue-calendar.iife.js +29 -29
- package/dist/venue-calendar.iife.js.map +1 -1
- package/dist/venue-calendar.umd.js +29 -29
- package/dist/venue-calendar.umd.js.map +1 -1
- package/package.json +110 -102
- package/src/lib/theme.js +217 -217
- package/dist/CarouselView.legacy-DOaevebR.js.map +0 -1
- package/dist/Checkout.legacy-nETM-IMW.js.map +0 -1
- package/dist/FeaturedView.legacy-ukM7qVzM.js.map +0 -1
- package/dist/GalleryCard-BEkb_B91.js +0 -87
- package/dist/GalleryCard-BEkb_B91.js.map +0 -1
- package/dist/GalleryView.legacy-LhMmiGMD.js.map +0 -1
- package/dist/GroupedListView.legacy-Ce-hzjBr.js.map +0 -1
- package/dist/Success.legacy-CHqoM06M.js.map +0 -1
- package/dist/VenueCalendar-mBg8Hi0c.js.map +0 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as y } from "svelte";
|
|
4
|
-
import { G as C } from "./GalleryCard-
|
|
5
|
-
import { f as S } from "./VenueCalendar-
|
|
4
|
+
import { G as C } from "./GalleryCard-RBMkn3Va.js";
|
|
5
|
+
import { f as S } from "./VenueCalendar-DsXtZNAR.js";
|
|
6
6
|
var x = e.from_html('<button class="carousel-arrow carousel-arrow-left svelte-1lcnwer" aria-label="Scroll left"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="arrow-icon svelte-1lcnwer"><polyline points="15 18 9 12 15 6"></polyline></svg></button>'), B = e.from_html('<div class="carousel-item svelte-1lcnwer" role="listitem"><!></div>'), W = e.from_html('<button class="carousel-arrow carousel-arrow-right svelte-1lcnwer" aria-label="Scroll right"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="arrow-icon svelte-1lcnwer"><polyline points="9 18 15 12 9 6"></polyline></svg></button>'), j = e.from_html('<section class="carousel-view svelte-1lcnwer" aria-label="Events carousel"><h2 class="sr-only svelte-1lcnwer">Upcoming events</h2> <div class="carousel-wrapper svelte-1lcnwer"><!> <div class="carousel-scroll svelte-1lcnwer" role="list"></div> <!></div></section>');
|
|
7
7
|
function R(p, n) {
|
|
8
8
|
e.push(n, !0);
|
|
@@ -62,4 +62,4 @@ e.delegate(["click"]);
|
|
|
62
62
|
export {
|
|
63
63
|
R as default
|
|
64
64
|
};
|
|
65
|
-
//# sourceMappingURL=CarouselView.legacy-
|
|
65
|
+
//# sourceMappingURL=CarouselView.legacy-fAmsAKLi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CarouselView.legacy-fAmsAKLi.js","sources":["../src/components/Calendar/CarouselView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount } from \"svelte\";\n import GalleryCard from \"./GalleryCard.svelte\";\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n\n let { events = [], oneventClick } = $props();\n\n let scrollContainer;\n let canScrollLeft = $state(false);\n let canScrollRight = $state(false);\n let showArrows = $state(false);\n\n // Filter to today and future, sorted chronologically\n let futureEvents = $derived(filterTodayAndFuture(events));\n\n function updateScrollState() {\n if (!scrollContainer) return;\n const { scrollLeft, scrollWidth, clientWidth } = scrollContainer;\n canScrollLeft = scrollLeft > 1;\n canScrollRight = scrollLeft + clientWidth < scrollWidth - 1;\n showArrows = scrollWidth > clientWidth + 1;\n }\n\n function scrollByCard(direction) {\n if (!scrollContainer) return;\n // Get the width of the first card item\n const firstCard = scrollContainer.querySelector('.carousel-item');\n if (!firstCard) return;\n const cardWidth = firstCard.offsetWidth + 16; // card width + gap\n scrollContainer.scrollBy({ left: direction * cardWidth, behavior: 'smooth' });\n }\n\n onMount(() => {\n updateScrollState();\n // Use ResizeObserver to update on container resize\n const observer = new ResizeObserver(() => updateScrollState());\n if (scrollContainer) {\n observer.observe(scrollContainer);\n }\n return () => observer.disconnect();\n });\n</script>\n\n<section class=\"carousel-view\" aria-label=\"Events carousel\">\n <h2 class=\"sr-only\">Upcoming events</h2>\n\n <div class=\"carousel-wrapper\">\n <!-- Left arrow -->\n {#if showArrows && canScrollLeft}\n <button\n class=\"carousel-arrow carousel-arrow-left\"\n onclick={() => scrollByCard(-1)}\n aria-label=\"Scroll left\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"arrow-icon\"><polyline points=\"15 18 9 12 15 6\"></polyline></svg>\n </button>\n {/if}\n\n <!-- Scroll container -->\n <div\n class=\"carousel-scroll\"\n bind:this={scrollContainer}\n onscroll={updateScrollState}\n role=\"list\"\n >\n {#each futureEvents as event}\n <div class=\"carousel-item\" role=\"listitem\">\n <GalleryCard {event} {oneventClick} />\n </div>\n {/each}\n </div>\n\n <!-- Right arrow -->\n {#if showArrows && canScrollRight}\n <button\n class=\"carousel-arrow carousel-arrow-right\"\n onclick={() => scrollByCard(1)}\n aria-label=\"Scroll right\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"arrow-icon\"><polyline points=\"9 18 15 12 9 6\"></polyline></svg>\n </button>\n {/if}\n </div>\n</section>\n\n<style>\n @reference \"../../app.css\";\n\n .carousel-view {\n width: 100%;\n }\n\n .carousel-wrapper {\n @apply relative;\n }\n\n .carousel-scroll {\n @apply flex gap-4 overflow-x-auto p-2;\n scroll-snap-type: x mandatory;\n -webkit-overflow-scrolling: touch;\n scrollbar-width: none;\n }\n\n .carousel-scroll::-webkit-scrollbar {\n display: none;\n }\n\n .carousel-item {\n scroll-snap-align: start;\n flex: 0 0 85%;\n }\n\n /* Tablet: 2 visible cards with peek */\n @media (min-width: 640px) {\n .carousel-item {\n flex: 0 0 calc(50% - 8px);\n }\n\n .carousel-scroll {\n @apply p-3;\n }\n }\n\n /* Desktop: 3 visible cards with peek */\n @media (min-width: 1024px) {\n .carousel-item {\n flex: 0 0 calc(33.333% - 11px);\n }\n\n .carousel-scroll {\n @apply p-4;\n }\n }\n\n /* Arrow buttons */\n .carousel-arrow {\n @apply absolute top-1/2 -translate-y-1/2 z-10;\n @apply w-10 h-10 rounded-full flex items-center justify-center;\n @apply bg-white/90 dark:bg-gray-800/90 border border-gray-200 dark:border-gray-600;\n @apply shadow-lg cursor-pointer;\n @apply transition-opacity duration-200;\n }\n\n .carousel-arrow:hover {\n @apply bg-white dark:bg-gray-700;\n }\n\n .carousel-arrow:focus-visible {\n @apply outline-2 outline-blue-700 dark:outline-blue-500 outline-offset-2;\n }\n\n .carousel-arrow-left {\n left: 8px;\n }\n\n .carousel-arrow-right {\n right: 8px;\n }\n\n .arrow-icon {\n @apply w-5 h-5 text-gray-700 dark:text-gray-200;\n }\n\n /* Hide arrows on mobile — touch scrolling is natural */\n @media (max-width: 639px) {\n .carousel-arrow {\n display: none;\n }\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .carousel-scroll {\n scroll-behavior: auto;\n }\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","scrollContainer","canScrollLeft","canScrollRight","showArrows","futureEvents","filterTodayAndFuture","updateScrollState","scrollLeft","scrollWidth","clientWidth","scrollByCard","direction","firstCard","cardWidth","onMount","observer","section","root","div","button","root_1","$$render","consequent","div_1","node","$$anchor","event","div_2","root_2","GalleryCard","node_1","$$value","button_1","root_3","consequent_1"],"mappings":";;;;;;iBAAA;;MAKQA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GAERC,GACAC,IAAgBH,EAAA,MAAO,EAAK,GAC5BI,IAAiBJ,EAAA,MAAO,EAAK,GAC7BK,IAAaL,EAAA,MAAO,EAAK,GAGzBM,IAAYN,EAAA,QAAA,MAAYO,EAAqBR,EAAM,CAAA,CAAA;AAE9C,WAAAS,IAAoB;SACtBN,EAAe;AACZ,UAAA,EAAA,YAAAO,GAAY,aAAAC,GAAa,aAAAC,EAAW,IAAKT;UACjDC,GAAgBM,IAAa,CAAC,GAC9BT,EAAA,IAAAI,GAAiBK,IAAaE,IAAcD,IAAc,CAAC,GAC3DV,EAAA,IAAAK,GAAaK,IAAcC,IAAc,CAAC;AAAA,EAC5C;WAESC,EAAaC,GAAW;SAC1BX,EAAe;AAEd,UAAAY,IAAYZ,EAAgB,cAAc,gBAAgB;SAC3DY,EAAS;AACR,UAAAC,IAAYD,EAAU,cAAc;AAC1C,IAAAZ,EAAgB,SAAQ,EAAG,MAAMW,IAAYE,GAAW,UAAU,UAAQ;AAAA,EAC5E;AAEA,EAAAC,EAAO,MAAO;AACZ,IAAAR,EAAiB;UAEXS,IAAQ,IAAO,eAAc,MAAOT,EAAiB,CAAA;AACvD,WAAAN,KACFe,EAAS,QAAQf,CAAe,GAErB,MAAAe,EAAS,WAAU;AAAA,EAClC,CAAC;MAGFC,IAAOC,EAAA,GAGLC,sBAHFF,CAAO,GAAA,CAAA,eAGLE,CAAG;;;UAGCC,IAAKC,EAAA;2BAALD,GAAK,MAEWT,EAAY,EAAG,CAAA,eAF/BS,CAAK;AAAA;;AADH,MAAArB,EAAA,IAAAK,CAAU,WAAIF,CAAa,KAAAoB,EAAAC,CAAA;AAAA;;MAW/BC,IAAEzB,EAAA,QAAA0B,GAAA,CAAA;SAAFD,GAAE,IAAA,MAAAzB,EAAA,IAMMM,CAAY,GAAAN,EAAA,OAAA,CAAA2B,GAAIC,MAAK;QACzBC,IAAGC,EAAA,eAAHD,CAAG;AACD,IAAAE,EAAWC,GAAA;AAAA;qBAAEJ,CAAK;AAAA;;;;gBADpBC,CAAG,eAAHA,CAAG;AAAA,cAPPJ,CAAE,eAAFA,GAAE,CAAAQ,MAEU/B,IAAe+B,GAAA,MAAf/B,CAAe;oBAF3BuB,GAAE,CAAA;;;UAeAS,IAAKC,EAAA;2BAALD,GAAK,MAEWtB,EAAa,CAAC,CAAA,eAF9BsB,CAAK;AAAA;;AADH,MAAAlC,EAAA,IAAAK,CAAU,WAAID,CAAc,KAAAmB,EAAAa,CAAA;AAAA;;UA3BlChB,CAAG,WAHLF,CAAO,GAgBHlB,EAAA,MAAA,UAAAyB,GAGWjB,CAAiB,eAnBhCU,CAAO;AAFA;;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
|
-
import { I as he, C as st, u as Jt,
|
|
3
|
+
import { I as he, C as st, u as Jt, h as Zt, t as $t, j as er, l as tr, k as ht, m as rr, n as yt, G as ar, o as sr, p as ir, O as lr, q as nr, W as at, B as _t, v as or, r as dr, E as cr, R as ur } from "./VenueCalendar-DsXtZNAR.js";
|
|
4
4
|
import { onMount as bt } from "svelte";
|
|
5
5
|
import { slide as gr } from "svelte/transition";
|
|
6
6
|
import "svelte/easing";
|
|
@@ -1214,4 +1214,4 @@ e.delegate(["click"]);
|
|
|
1214
1214
|
export {
|
|
1215
1215
|
Rr as default
|
|
1216
1216
|
};
|
|
1217
|
-
//# sourceMappingURL=Checkout.legacy-
|
|
1217
|
+
//# sourceMappingURL=Checkout.legacy-DqNypQ8O.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkout.legacy-DqNypQ8O.js","sources":["../src/components/Events/Checkout/PersonalDetails.svelte","../src/components/Events/Checkout/TermsAndConditions.svelte","../src/components/Events/Checkout/PaymentSection.svelte","../src/components/Views/Checkout.legacy.svelte"],"sourcesContent":["<script>\n import { Input, Checkbox } from '@getmicdrop/svelte-components';\n\n let {\n firstName = $bindable(''),\n lastName = $bindable(''),\n email = $bindable(''),\n phoneNumber = $bindable(''),\n keepMeUpdated = $bindable(false),\n termsAgreed = $bindable(false),\n ticketsInfo = [],\n ticketType = 0,\n updateTicketDetails,\n updateTicketField,\n firstNameError = $bindable(''),\n lastNameError = $bindable(''),\n emailError = $bindable(''),\n phoneError = $bindable(''),\n termsError = $bindable(''),\n firstNameTouched = $bindable(false),\n lastNameTouched = $bindable(false),\n emailTouched = $bindable(false),\n phoneTouched = $bindable(false),\n labels = {},\n } = $props();\n</script>\n\n<form aria-label={labels.checkoutFormLabel || \"Checkout form\"}>\n <section class=\"p-4 md:p-5\" aria-labelledby=\"billing-section-title\">\n <div class=\"space-y-4\">\n <h2 id=\"billing-section-title\" class=\"section-title\">\n {labels.billingInformation || 'Billing information'}\n </h2>\n <div class=\"grid grid-cols-2 gap-4\">\n <Input\n label={labels.firstName || \"First name\"}\n size=\"full\"\n type=\"text\"\n required\n autocomplete=\"given-name\"\n bind:value={firstName}\n bind:displayErrorText={firstNameError}\n bind:touched={firstNameTouched}\n />\n <Input\n label={labels.lastName || \"Last name\"}\n size=\"full\"\n type=\"text\"\n required\n autocomplete=\"family-name\"\n bind:value={lastName}\n bind:displayErrorText={lastNameError}\n bind:touched={lastNameTouched}\n />\n <div class=\"col-span-2\">\n <Input\n label={labels.emailAddress || \"Email address\"}\n size=\"full\"\n type=\"email\"\n required\n autocomplete=\"email\"\n bind:value={email}\n bind:displayErrorText={emailError}\n bind:touched={emailTouched}\n />\n </div>\n <div class=\"col-span-2\">\n <Input\n label={labels.phoneNumber || \"Phone number\"}\n size=\"full\"\n type=\"phoneNumber\"\n autocomplete=\"tel\"\n bind:value={phoneNumber}\n bind:displayErrorText={phoneError}\n bind:touched={phoneTouched}\n />\n </div>\n </div>\n <Checkbox bind:checked={keepMeUpdated} class=\"mailing-list-checkbox\" aria-describedby=\"mailing-list-description\">\n {labels.keepMeUpdated || 'Keep me updated on more events and news'}\n </Checkbox>\n <span id=\"mailing-list-description\" class=\"sr-only\">{labels.subscribeToUpdates || 'Subscribe to event updates and news'}</span>\n </div>\n </section>\n\n <!-- Ticket-wise Attendee Details (Only if ticketType === 1) -->\n {#if ticketType === 1}\n {#each ticketsInfo as ticket, index (ticket.ticketId + '-' + index)}\n <section class=\"p-4 md:p-5\" aria-labelledby=\"ticket-section-{index}\">\n <div class=\"grid grid-row-3 gap-3\">\n <h2 id=\"ticket-section-{index}\" class=\"section-title text-base font-medium leading-6\">\n {(labels.ticketN || 'Ticket {index} - {name}').replace('{index}', String(index + 1)).replace('{name}', ticket.ticketName)}\n </h2>\n <Checkbox\n checked={ticket.sameAsPersonal}\n onchange={e => updateTicketDetails(index, e.detail.checked)}\n class=\"same-as-personal-checkbox\"\n >\n {labels.sameAsPersonalDetails || 'Same as personal details'}\n </Checkbox>\n <div class=\"grid grid-cols-2 gap-4\">\n <Input\n label={labels.firstName || \"First name\"}\n size=\"full\"\n type=\"text\"\n value={ticket.firstName}\n oninput={e => updateTicketField(index, 'firstName', e.target.value)}\n displayErrorText={ticket.touched && ticket.errors.firstName ? ticket.errors.firstName : ''}\n touched={ticket.touched}\n />\n <Input\n label={labels.lastName || \"Last name\"}\n size=\"full\"\n type=\"text\"\n value={ticket.lastName}\n oninput={e => updateTicketField(index, 'lastName', e.target.value)}\n displayErrorText={ticket.touched && ticket.errors.lastName ? ticket.errors.lastName : ''}\n touched={ticket.touched}\n />\n <div class=\"col-span-2\">\n <Input\n label={labels.emailAddress || \"Email address\"}\n size=\"full\"\n type=\"email\"\n value={ticket.email}\n oninput={e => updateTicketField(index, 'email', e.target.value)}\n displayErrorText={ticket.touched && ticket.errors.email ? ticket.errors.email : ''}\n touched={ticket.touched}\n />\n </div>\n </div>\n </div>\n </section>\n {/each}\n {/if}\n</form>\n\n<style>\n @reference \"../../../app.css\";\n\n /* Theme-responsive colors using Tailwind */\n .section-title {\n @apply text-lg font-semibold text-gray-900 dark:text-white mb-4;\n }\n\n /* Checkbox label styling for shared component */\n :global(.mailing-list-checkbox .checkbox__label),\n :global(.same-as-personal-checkbox .checkbox__label) {\n @apply text-gray-500 dark:text-gray-400 font-normal text-sm;\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: 0;\n }\n</style>\n","<script>\n import { Checkbox } from '@getmicdrop/svelte-components';\n\n let {\n InputValue = $bindable(false),\n terms = [],\n showScrollbar = false,\n scrollContainer,\n handleScroll = () => {},\n checkScrollable = () => {},\n termsError = '',\n labels = {},\n } = $props();\n</script>\n\n<section class=\"space-y-4\" aria-labelledby=\"terms-section-title\">\n <h2 id=\"terms-section-title\" class=\"heading-md text-color-primary\">\n {labels.termsAndConditions || 'Terms and conditions'}\n </h2>\n\n <Checkbox\n bind:checked={InputValue}\n class=\"terms-checkbox\"\n aria-required=\"true\"\n aria-describedby={termsError ? 'terms-error' : undefined}\n >\n {labels.agreeToTerms || 'I agree to the'} <a href=\"https://get-micdrop.com/tos\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-blue-700 dark:text-blue-500 underline hover:opacity-80\">{labels.termsAndConditionsLink || 'terms and conditions'}<span class=\"sr-only\"> (opens in new tab)</span></a>\n </Checkbox>\n\n {#if termsError}\n <p id=\"terms-error\" class=\"body-sm mt-1 text-error\" role=\"alert\" aria-live=\"assertive\">{termsError}</p>\n {/if}\n</section>\n\n<style>\n @reference \"../../../app.css\";\n\n :global(.terms-checkbox .checkbox__label) {\n @apply text-gray-600 dark:text-gray-300;\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: 0;\n }\n</style>\n","<script>\n import { onMount } from 'svelte';\n import { slide } from 'svelte/transition';\n import { browser } from '$app/environment';\n import { useStripeTheme } from '@getmicdrop/svelte-components/stripe';\n import { GOOGLE_PAY } from '$lib/constants/colors.ts';\n\n let {\n selectedPayment = $bindable(), // Start with nothing selected\n stripe,\n paymentIntent,\n error = '',\n processing = false,\n executePurchase = () => {},\n elements = $bindable(),\n labels = {},\n } = $props();\n\n // Dynamic imports for Stripe components\n let StripeElementsComp = $state(null);\n let PaymentElementComp = $state(null);\n\n // Reactive Stripe theme - automatically updates on dark mode changes\n const stripeTheme = useStripeTheme({\n containerSelector: '.light, .dark, .micdrop, [data-theme]',\n });\n\n onMount(async () => {\n try {\n const mod = await import('svelte-stripe');\n StripeElementsComp = mod.Elements;\n PaymentElementComp = mod.PaymentElement;\n } catch (err) {\n console.error('Failed to load Stripe components:', err);\n }\n });\n\n function selectPayment(method) {\n selectedPayment = method;\n }\n</script>\n\n<section class=\"pay-with-section\" aria-labelledby=\"payment-section-title\">\n <h2 id=\"payment-section-title\" class=\"section-title\">{labels.payWith || 'Pay with'}</h2>\n\n <div class=\"payment-options\" role=\"radiogroup\" aria-label={labels.paymentMethodSelection || \"Payment method selection\"}>\n <!-- Credit or Debit Card -->\n <div class=\"payment-option-wrapper\">\n <button\n type=\"button\"\n class=\"payment-option\"\n class:selected={selectedPayment === 'card'}\n onclick={() => selectPayment('card')}\n role=\"radio\"\n aria-checked={selectedPayment === 'card'}\n aria-label={labels.payWithCard || \"Pay with credit or debit card\"}\n >\n <div class=\"payment-option-header\">\n <svg class=\"payment-icon\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" aria-hidden=\"true\">\n <rect x=\"1\" y=\"4\" width=\"22\" height=\"16\" rx=\"2\" ry=\"2\"/>\n <line x1=\"1\" y1=\"10\" x2=\"23\" y2=\"10\"/>\n </svg>\n <span class=\"payment-label\">{labels.creditOrDebitCard || 'Credit or debit card'}</span>\n <img src=\"/stripe-logo.png\" alt=\"\" class=\"stripe-logo\" aria-hidden=\"true\" />\n </div>\n </button>\n\n {#if selectedPayment === 'card'}\n <div class=\"card-form\" transition:slide={{ duration: 200 }} role=\"region\" aria-label={labels.cardPaymentForm || \"Card payment form\"}>\n {#if browser && stripe && paymentIntent}\n {#if StripeElementsComp && PaymentElementComp}\n <StripeElementsComp\n appearance={{ theme: stripeTheme.current }}\n {stripe}\n clientSecret={paymentIntent}\n bind:elements\n >\n <PaymentElementComp />\n </StripeElementsComp>\n {:else}\n <p class=\"loading-text\" role=\"status\" aria-live=\"polite\">Loading secure payment form...</p>\n {/if}\n {:else}\n <p class=\"loading-text\" role=\"status\" aria-live=\"polite\">Loading secure payment form...</p>\n {/if}\n\n {#if error}\n <p class=\"error-text\" role=\"alert\" aria-live=\"assertive\">{error}</p>\n {/if}\n </div>\n {/if}\n </div>\n\n <!-- Apple Pay -->\n <button\n type=\"button\"\n class=\"payment-option standalone\"\n class:selected={selectedPayment === 'apple'}\n onclick={() => selectPayment('apple')}\n role=\"radio\"\n aria-checked={selectedPayment === 'apple'}\n aria-label={labels.payWithApplePay || \"Pay with Apple Pay\"}\n >\n <div class=\"payment-option-header\">\n <svg class=\"payment-icon apple-icon\" viewBox=\"0 0 24 24\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M17.05 20.28c-.98.95-2.05.8-3.08.35-1.09-.46-2.09-.48-3.24 0-1.44.62-2.2.44-3.06-.35C2.79 15.25 3.51 7.59 9.05 7.31c1.35.07 2.29.74 3.08.8 1.18-.24 2.31-.93 3.57-.84 1.51.12 2.65.72 3.4 1.8-3.12 1.87-2.38 5.98.48 7.13-.57 1.5-1.31 2.99-2.54 4.09l.01-.01zM12.03 7.25c-.15-2.23 1.66-4.07 3.74-4.25.29 2.58-2.34 4.5-3.74 4.25z\"/>\n </svg>\n <span class=\"payment-label\">{labels.applePay || 'Apple Pay'}</span>\n </div>\n </button>\n\n <!-- Google Pay -->\n <button\n type=\"button\"\n class=\"payment-option standalone\"\n class:selected={selectedPayment === 'google'}\n onclick={() => selectPayment('google')}\n role=\"radio\"\n aria-checked={selectedPayment === 'google'}\n aria-label={labels.payWithGooglePay || \"Pay with Google Pay\"}\n >\n <div class=\"payment-option-header\">\n <svg class=\"payment-icon google-icon\" viewBox=\"0 0 24 24\" aria-hidden=\"true\">\n <path fill={GOOGLE_PAY.blue} d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"/>\n <path fill={GOOGLE_PAY.green} d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"/>\n <path fill={GOOGLE_PAY.yellow} d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"/>\n <path fill={GOOGLE_PAY.red} d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"/>\n </svg>\n <span class=\"payment-label\">{labels.googlePay || 'Google Pay'}</span>\n </div>\n </button>\n\n </div>\n</section>\n\n<style>\n @reference \"../../../app.css\";\n\n .pay-with-section {\n @apply pt-2;\n }\n\n .section-title {\n @apply text-lg font-semibold text-gray-900 dark:text-white mb-4;\n }\n\n .payment-options {\n @apply flex flex-col gap-3;\n }\n\n .payment-option-wrapper {\n @apply flex flex-col;\n }\n\n .payment-option {\n @apply flex flex-col w-full p-4 rounded-lg cursor-pointer text-left;\n @apply bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700;\n transition: all 0.15s ease;\n }\n\n .payment-option-wrapper .payment-option {\n @apply rounded-lg;\n }\n\n .payment-option-wrapper .payment-option.selected {\n border-radius: 8px 8px 0 0;\n }\n\n .payment-option.standalone {\n @apply rounded-lg;\n }\n\n .payment-option.selected {\n @apply bg-white dark:bg-gray-900 z-10 relative;\n border-color: hsl(var(--Brand-Primary, 224 76% 48%));\n }\n\n .payment-option:not(.selected):hover {\n @apply bg-gray-50 dark:bg-gray-800;\n }\n\n .payment-option-header {\n @apply flex items-center gap-3;\n }\n\n .payment-icon {\n @apply w-6 h-6 shrink-0 text-gray-900 dark:text-white;\n }\n\n .apple-icon {\n @apply text-gray-900 dark:text-white;\n }\n\n .payment-label {\n @apply text-base font-normal text-gray-900 dark:text-white;\n font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;\n }\n\n .stripe-logo {\n @apply h-9 w-auto ml-auto opacity-60;\n }\n\n /* Card form styling */\n .card-form {\n @apply p-4 bg-white dark:bg-gray-900 border border-t-0;\n border-color: hsl(var(--Brand-Primary, 224 76% 48%));\n border-radius: 0 0 8px 8px;\n }\n\n .loading-text {\n @apply text-sm text-gray-500 dark:text-gray-400 py-2;\n }\n\n .error-text {\n @apply text-sm text-red-600 dark:text-red-500 mt-2;\n }\n</style>\n","<script>\n import Cookies from 'js-cookie';\n import { onMount } from 'svelte';\n import { goto } from '$app/navigation';\n import { Close, WarningFilled, ErrorFilled, Renew } from 'carbon-icons-svelte';\n import { transformEvent, loadCheckoutStateFromCookies, getVenueDetails, createPaymentIntent, validatePaymentIntent } from '$lib/utils/utils.js';\n import { completeGiftCardPayment } from '$lib/utils/api.js';\n import OrderSummarySkeleton from \"../Events/Tickets/OrderSummarySkeleton.svelte\";\n import PersonalDetails from \"../Events/Checkout/PersonalDetails.svelte\";\n import TermsAndConditions from \"../Events/Checkout/TermsAndConditions.svelte\";\n import PaymentSection from \"../Events/Checkout/PaymentSection.svelte\";\n import GiftCardInput from \"../Events/Checkout/GiftCardInput.svelte\";\n import { OrderSummary, Button } from '@getmicdrop/svelte-components';\n import { loadStripe } from '@stripe/stripe-js';\n import { ACCENT } from '$lib/constants/colors.ts';\n\n let {\n data,\n availableTickets = [],\n value = '',\n venueId = '',\n organizationId = '',\n onNavigateToSuccess,\n initialError = undefined,\n labels = {},\n } = $props();\n\n const { id, orgSlug, slug, event: rawEvent } = data || {};\n let event = $derived(\n rawEvent\n ? transformEvent(rawEvent)\n : data && (data.id || id)\n ? {\n id: data.id || id,\n eventID: data.id || id,\n venueID: data.venueID ?? data.venueId ?? null,\n venueId: data.venueId ?? data.venueID ?? null,\n eventTicketingType: 0,\n ticketType: 0,\n availableTickets: [],\n }\n : null\n );\n \n let venueFeesReady = $state(false);\n\n let quantities = $state({});\n let promocode = $state('');\n let promoDiscountAmount = $state(0);\n let tickets = $state([]);\n\n let ticketsInfo = $state([]);\n\n let firstNameTouched = $state(false);\n let lastNameTouched = $state(false);\n let emailTouched = $state(false);\n let confirmEmailTouched = $state(false);\n\n let InputValue = $state(false);\n let selectedPayment = $state('card');\n let firstName = $state('');\n let lastName = $state('');\n let email = $state('');\n let confirmEmail = $state('');\n let phoneNumber = $state('');\n let keepMeUpdated = $state(false);\n let scrollContainer = $state();\n let showScrollbar = $state(false);\n let heading = $derived(' ' + (labels.checkout || 'Checkout'));\n let timerDuration = $state(15 * 60);\n let Timing = $state(`${labels.timeLeft || 'Time left'} ${formatTime(15 * 60)}`);\n let feePerTicket = 4.48;\n\n // Session extension popup state\n let showExtendSessionPopup = $state(false);\n let sessionExtensionOffered = false;\n const SESSION_WARNING_THRESHOLD = 2 * 60; // 2 minutes\n const SESSION_EXTENSION_AMOUNT = 5 * 60; // 5 minutes extension\n \n let inputValue = value;\n \n const terms = [\n 'All ticket sales are final and non-refundable unless the event is canceled or rescheduled by the organizer.',\n 'Tickets are valid only for the event, date, time, and venue specified. Unauthorized resale of tickets is prohibited.',\n 'The event organizer reserves the right to refuse entry or remove any individual from the venue without refund.',\n 'Attendees must comply with all venue rules and regulations, including any age restrictions or dress codes.',\n 'Photography and recording policies may vary; please check the event details for specific guidelines.',\n ];\n \n let error = $state(null);\n\n let isMobile = $state(false);\n let containerRef = $state();\n let stickyRef = $state();\n let isSticky = $state(false);\n let stickyTop = $state(0);\n let sidebarLeft = $state(0);\n let cartId = $state('');\n let isScrollable = $state(false);\n\n // Gift card state\n let giftCardApplied = $state(null); // { code, giftCardAmount, giftCardBalance, paymentType, stripeAmount, requiresStripe }\n \n let elements = $state();\n\n let stripe = $state(null);\n let calculatedTax = $state(0);\n let calculatedServiceFee = $state(0);\n let calculatedTotal = $state(0);\n let processing = $state(false);\n let paymentIntent = $state('');\n let isCompleteOrder = $state(false);\n let isInCompleteOrder = $state(false);\n\n async function initializeStripePayment() {\n if (!cartId) {\n console.error('Missing cartId!');\n return;\n }\n\n const filteredQuantities = Object.fromEntries(\n Object.entries(quantities).filter(([_, val]) => val > 0)\n );\n\n try {\n const paymentData = await createPaymentIntent(cartId, filteredQuantities);\n\n if (paymentData && paymentData.client_secret) {\n stripe = await loadStripe(\n 'pk_test_51RJLygPlXDynGkUGKI0vaVT0DXCDdf2wLp3BVNGtdulddY8jG5qBlDUuQuArbTW1dPh19wfZngGeABvH35XIjjMz00NwnD7ydB'\n );\n \n if (stripe) {\n paymentIntent = paymentData.client_secret;\n \n elements = stripe.elements({\n appearance: {\n theme: 'stripe',\n variables: {\n colorDanger: ACCENT.red[600],\n fontSizeBase: '16px',\n },\n },\n clientSecret: paymentData.client_secret,\n });\n\n calculatedTax = (paymentData.tax_amount_exclusive || 0) / 100;\n calculatedServiceFee = (paymentData.service_fee || 0) / 100;\n calculatedTotal = (paymentData.amount_total || 0) / 100;\n }\n } else {\n stripeError = labels.failedToCreatePaymentIntent || 'Failed to create payment intent. Please try again.';\n }\n } catch (err) {\n console.error('Failed to initialize Stripe payment:', err);\n stripeError = err.message || labels.failedToInitPayment || 'Failed to initialize payment. Please check your connection and try again.';\n }\n }\n\n let venueServiceCharge = $state({\n serviceFeeCents: 0,\n serviceFeePercentage: 0,\n serviceFeeChargeType: 'both',\n maxServiceFeeCents: 0,\n taxPercentage: 0,\n });\n\n // Gift card event handlers\n function handleGiftCardApplied(appliedCard) {\n giftCardApplied = appliedCard;\n // If gift card covers full amount, no need for Stripe\n if (!appliedCard.requiresStripe) {\n // Clear Stripe elements if they exist\n elements = null;\n stripe = null;\n }\n }\n\n function handleGiftCardRemoved() {\n giftCardApplied = null;\n // Re-initialize Stripe payment if needed\n if (cartId && Object.keys(quantities).length > 0) {\n initializeStripePayment();\n }\n }\n\n function formatTime(seconds) {\n const minutes = Math.floor(seconds / 60);\n const remainingSeconds = seconds % 60;\n return `${String(minutes).padStart(2, '0')}:${String(remainingSeconds).padStart(2, '0')}`;\n }\n\n function extendSession() {\n timerDuration += SESSION_EXTENSION_AMOUNT;\n Timing = `${labels.timeLeft || 'Time left'} ${formatTime(timerDuration)}`;\n showExtendSessionPopup = false;\n // Allow extending again if time runs low again\n sessionExtensionOffered = false;\n }\n\n function dismissExtendPopup() {\n showExtendSessionPopup = false;\n // Don't offer again for this session\n sessionExtensionOffered = true;\n }\n\n function checkScrollable() {\n if (scrollContainer) {\n isScrollable =\n scrollContainer.scrollHeight > scrollContainer.clientHeight;\n showScrollbar = isScrollable;\n }\n }\n \n let firstNameError = $state('');\n let lastNameError = $state('');\n let emailError = $state('');\n let confirmEmailError = $state('');\n let termsError = $state('');\n let attendeeError = $state('');\n let stripeError = $state('');\n\n // Enhanced error state for better UX\n let paymentErrorType = $state(''); // 'card_declined', 'network', 'validation', 'general'\n let paymentErrorDetails = $state({\n title: '',\n message: '',\n suggestion: '',\n retryable: true\n });\n\n // Map Stripe error codes to user-friendly messages\n function getPaymentErrorDetails(error) {\n const errorCode = error?.code || error?.decline_code || '';\n const errorType = error?.type || '';\n const errorMessage = error?.message || '';\n\n // Card declined errors\n if (errorCode === 'card_declined' || errorType === 'card_error') {\n const declineCode = error?.decline_code || '';\n\n if (declineCode === 'insufficient_funds') {\n return {\n type: 'card_declined',\n title: 'Insufficient funds',\n message: 'Your card has insufficient funds to complete this purchase.',\n suggestion: 'Please try a different payment method or contact your bank.',\n retryable: true\n };\n }\n\n if (declineCode === 'lost_card' || declineCode === 'stolen_card') {\n return {\n type: 'card_declined',\n title: 'Card cannot be used',\n message: 'This card cannot be used for this transaction.',\n suggestion: 'Please use a different payment method.',\n retryable: true\n };\n }\n\n if (declineCode === 'expired_card') {\n return {\n type: 'card_declined',\n title: 'Card expired',\n message: 'Your card has expired.',\n suggestion: 'Please use a different card or update your card details.',\n retryable: true\n };\n }\n\n return {\n type: 'card_declined',\n title: 'Card declined',\n message: 'Your card was declined by your bank.',\n suggestion: 'Please try a different card or contact your bank for more information.',\n retryable: true\n };\n }\n\n // Network/connection errors\n if (errorType === 'api_connection_error' || errorMessage.includes('network') || errorMessage.includes('connection')) {\n return {\n type: 'network',\n title: 'Connection error',\n message: 'We couldn\\'t connect to the payment server.',\n suggestion: 'Please check your internet connection and try again.',\n retryable: true\n };\n }\n\n // Rate limiting\n if (errorCode === 'rate_limit') {\n return {\n type: 'rate_limit',\n title: 'Too many attempts',\n message: 'Too many payment attempts. Please wait a moment.',\n suggestion: 'Wait 30 seconds before trying again.',\n retryable: true\n };\n }\n\n // Invalid card details\n if (errorCode === 'incorrect_number' || errorCode === 'invalid_number') {\n return {\n type: 'validation',\n title: 'Invalid card number',\n message: 'The card number you entered is invalid.',\n suggestion: 'Please check your card number and try again.',\n retryable: true\n };\n }\n\n if (errorCode === 'incorrect_cvc' || errorCode === 'invalid_cvc') {\n return {\n type: 'validation',\n title: 'Invalid security code',\n message: 'The security code (CVC) is incorrect.',\n suggestion: 'Please check the 3-digit code on the back of your card.',\n retryable: true\n };\n }\n\n if (errorCode === 'invalid_expiry_month' || errorCode === 'invalid_expiry_year') {\n return {\n type: 'validation',\n title: 'Invalid expiration date',\n message: 'The expiration date is invalid.',\n suggestion: 'Please check your card\\'s expiration date.',\n retryable: true\n };\n }\n\n // Default error\n return {\n type: 'general',\n title: 'Payment failed',\n message: errorMessage || 'Something went wrong with your payment.',\n suggestion: 'Please try again or use a different payment method.',\n retryable: true\n };\n }\n\n function clearPaymentError() {\n stripeError = '';\n paymentErrorType = '';\n paymentErrorDetails = {\n title: '',\n message: '',\n suggestion: '',\n retryable: true\n };\n }\n\n function setPaymentError(error) {\n const details = getPaymentErrorDetails(error);\n paymentErrorType = details.type;\n paymentErrorDetails = details;\n stripeError = details.message;\n }\n \n function validateBeforeSubmit() {\n let hasError = false;\n \n firstNameTouched =\n lastNameTouched =\n emailTouched =\n confirmEmailTouched =\n true;\n firstNameError =\n lastNameError =\n emailError =\n confirmEmailError =\n termsError =\n attendeeError =\n '';\n \n if (!firstName.trim()) {\n firstNameError = 'First name is required.';\n hasError = true;\n }\n \n if (!lastName.trim()) {\n lastNameError = 'Last name is required.';\n hasError = true;\n }\n \n if (!email.trim()) {\n emailError = 'Email is required.';\n hasError = true;\n }\n \n if (!confirmEmail.trim()) {\n confirmEmailError = 'Confirm email is required.';\n hasError = true;\n } else if (\n email.trim() &&\n confirmEmail.trim() &&\n email.trim() !== confirmEmail.trim()\n ) {\n confirmEmailError = 'Email addresses do not match.';\n hasError = true;\n }\n \n if (!isAgreed) {\n termsError = 'You must agree to the terms and conditions above.';\n hasError = true;\n }\n \n if (event.ticketType === 1) {\n let ticketErrorCount = 0;\n \n ticketsInfo = ticketsInfo.map((t, index) => {\n const errors = {\n firstName: '',\n lastName: '',\n email: '',\n };\n \n if (!t.sameAsPersonal) {\n if (!t.firstName.trim()) {\n errors.firstName = 'First name is required.';\n ticketErrorCount++;\n }\n if (!t.lastName.trim()) {\n errors.lastName = 'Last name is required.';\n ticketErrorCount++;\n }\n if (!t.email.trim()) {\n errors.email = 'Email is required.';\n ticketErrorCount++;\n }\n }\n \n return {\n ...t,\n errors,\n qtouched: true,\n };\n });\n \n if (ticketErrorCount > 0) {\n attendeeError = 'Please fill in all attendee details.';\n hasError = true;\n }\n }\n \n return !hasError;\n }\n \n async function executePurchase(elementsParam) {\n if (processing) return;\n\n // Clear any previous errors before attempting\n clearPaymentError();\n\n const elementsToUse = elementsParam || elements;\n\n if (!elementsToUse) {\n setPaymentError({\n type: 'validation',\n message: labels.paymentFormNotReady || 'Payment form is not ready. Please wait a moment and try again.'\n });\n return;\n }\n\n if (!stripe) {\n setPaymentError({\n type: 'general',\n message: labels.paymentSystemNotInitialized || 'Payment system is not initialized. Please refresh the page.'\n });\n return;\n }\n\n processing = true;\n\n const isValid = validateBeforeSubmit();\n\n if (!isValid) {\n processing = false;\n return;\n }\n\n try {\n const { error: validationError } = await elementsToUse.submit();\n if (validationError) {\n setPaymentError(validationError);\n processing = false;\n return;\n }\n\n const result = await stripe.confirmPayment({\n elements: elementsToUse,\n redirect: 'if_required',\n });\n\n if (result.error) {\n setPaymentError(result.error);\n processing = false;\n return;\n }\n\n const paymentPayload = {\n id: cartId,\n paymentIntentId: result.paymentIntent.id,\n tickets: quantities,\n firstName,\n lastName,\n email: confirmEmail,\n phoneNumber: phoneNumber || null,\n paymentMethod: 'credit-card',\n mailingList: keepMeUpdated,\n saleType: 'online',\n };\n\n const response = await validatePaymentIntent(cartId, paymentPayload);\n\n if (response?.status === 'Payment succeeded') {\n isCompleteOrder = true;\n\n try {\n const successData = {\n orderId: cartId,\n eventId: event?.id || event?.eventID || null,\n event: event || null,\n venueId: venueId || event?.venueId || null,\n organizationId: organizationId || event?.organizationId || null\n };\n dispatch('success', successData);\n\n if (onNavigateToSuccess) {\n onNavigateToSuccess(successData);\n }\n } catch(e) {\n console.warn('Failed to dispatch success event', e);\n }\n } else if (\n response?.status === 'Payment amount does not match the total price'\n ) {\n isInCompleteOrder = true;\n setPaymentError({\n type: 'general',\n message: labels.paymentAmountMismatch || 'Payment amount mismatch. Please refresh and try again.'\n });\n }\n } catch (err) {\n console.error('Payment execution error:', err);\n setPaymentError(err);\n } finally {\n processing = false;\n }\n }\n\n async function executeGiftCardOnlyPurchase() {\n if (processing) return;\n\n processing = true;\n clearPaymentError();\n\n const isValid = validateBeforeSubmit();\n if (!isValid) {\n processing = false;\n return;\n }\n\n try {\n const result = await completeGiftCardPayment(cartId, {\n firstName,\n lastName,\n email: confirmEmail,\n phoneNumber: phoneNumber || null,\n mailingList: keepMeUpdated,\n });\n\n if (result?.success) {\n isCompleteOrder = true;\n\n const successData = {\n orderId: result.orderId || cartId,\n eventId: event?.id || event?.eventID || null,\n event: event || null,\n venueId: venueId || event?.venueId || null,\n organizationId: organizationId || event?.organizationId || null,\n paymentType: 'gift_card_only',\n };\n\n if (onNavigateToSuccess) {\n onNavigateToSuccess(successData);\n }\n } else {\n setPaymentError({\n type: 'general',\n message: result?.error || labels.failedToCompleteOrder || 'Failed to complete order. Please try again.',\n });\n }\n } catch (err) {\n console.error('Gift card payment error:', err);\n setPaymentError(err);\n } finally {\n processing = false;\n }\n }\n\n function goBack() {\n const params = new URLSearchParams(window.location.search);\n params.set(\"subroute\", \"cart\");\n const url = `/?${params.toString()}`;\n goto(url, { noScroll: false });\n }\n \n function updateScreenSize() {\n isMobile = window.innerWidth < 640;\n }\n \n function handleScroll() {\n if (isMobile) {\n isSticky = false;\n return;\n }\n \n const rect = stickyRef?.getBoundingClientRect();\n if (!rect) return;\n \n isSticky = rect.top <= 20;\n \n if (isSticky && containerRef) {\n const containerBounding = containerRef.getBoundingClientRect();\n sidebarLeft =\n containerBounding.left + containerRef.clientWidth - 340 - 40;\n }\n }\n \n function updateTicketField(index, field, value) {\n ticketsInfo = ticketsInfo.map((ticket, i) => {\n if (i === index) {\n if (field === 'touched') {\n return { ...ticket, touched: true };\n }\n const updatedTicket = {\n ...ticket,\n [field]: value,\n sameAsPersonal: false,\n errors: {\n ...ticket.errors,\n [field]: value.trim()\n ? ''\n : `${field[0].toUpperCase() + field.slice(1)} is required.`,\n },\n };\n \n return updatedTicket;\n }\n return ticket;\n });\n }\n \n function updateTicketDetails(index, checked) {\n ticketsInfo = ticketsInfo.map((ticket, i) => {\n if (i === index) {\n return {\n ...ticket,\n sameAsPersonal: checked,\n firstName: checked ? firstName : ticket.firstName,\n lastName: checked ? lastName : ticket.lastName,\n email: checked ? email : ticket.email,\n };\n }\n return ticket;\n });\n }\n \n function syncSameAsPersonalAttendees() {\n ticketsInfo = ticketsInfo.map(t =>\n t.sameAsPersonal ? { ...t, firstName, lastName, email } : t\n );\n }\n\n let normalizedEmail = $derived(email?.trim().toLowerCase());\n let normalizedConfirmEmail = $derived(confirmEmail?.trim().toLowerCase());\n\n let emailMatchError = $derived(\n normalizedEmail !== normalizedConfirmEmail && confirmEmail !== ''\n );\n\n let isAgreed = $derived(InputValue);\n\n $effect(() => {\n email = email?.trim();\n confirmEmail = confirmEmail?.trim();\n });\n\n $effect(() => {\n inputValue = value;\n });\n\n $effect(() => {\n processing = false;\n });\n\n $effect(() => {\n paymentIntent = '';\n });\n\n $effect(() => {\n if (tickets?.length > 0) {\n if (event) {\n event.availableTickets = tickets;\n }\n }\n });\n\n $effect(() => {\n isCompleteOrder = false;\n isInCompleteOrder = false;\n });\n \n $effect(() => {\n if (Object.keys(quantities).length > 0 && tickets.length > 0) {\n const info = [];\n let idx = 0;\n\n for (const [ticketId, quantity] of Object.entries(quantities)) {\n const ticketMeta = tickets.find(t => String(t.ID) === ticketId);\n for (let i = 0; i < quantity; i++) {\n info.push({\n name: `Ticket ${idx + 1}`,\n sameAsPersonal: false,\n firstName: '',\n lastName: '',\n email: '',\n ticketId: ticketMeta?.ID || null,\n ticketName: ticketMeta?.name || '',\n touched: false,\n errors: {\n firstName: '',\n lastName: '',\n email: '',\n },\n });\n idx++;\n }\n }\n\n ticketsInfo = info;\n }\n });\n\n $effect(() => {\n if (firstName || lastName || email) {\n syncSameAsPersonalAttendees();\n }\n });\n \n onMount(async () => {\n updateScreenSize();\n cartId = Cookies.get('checkout-cartid');\n \n try {\n const checkoutState = loadCheckoutStateFromCookies(event?.eventID || event?.id);\n quantities = checkoutState.quantities || {};\n promocode = checkoutState.promocode || '';\n promoDiscountAmount = checkoutState.promoDiscountAmount || 0;\n tickets = checkoutState.tickets || [];\n } catch (err) {\n console.error('Error loading checkout state:', err);\n quantities = {};\n tickets = [];\n }\n \n if (tickets.length > 0) {\n if (event) event.availableTickets = tickets;\n availableTickets = tickets;\n }\n \n if (cartId && Object.keys(quantities).length > 0) {\n initializeStripePayment();\n }\n \n const interval = setInterval(() => {\n if (timerDuration > 0) {\n timerDuration -= 1;\n Timing = `${labels.timeLeft || 'Time left'} ${formatTime(timerDuration)}`;\n\n // Show extension popup when time is running low\n if (timerDuration <= SESSION_WARNING_THRESHOLD && timerDuration > 0 && !sessionExtensionOffered && !showExtendSessionPopup) {\n showExtendSessionPopup = true;\n }\n } else {\n clearInterval(interval);\n goto('/', { noScroll: false });\n }\n }, 1000);\n \n try {\n const venueData = await getVenueDetails(event?.venueID || event?.venueId);\n venueServiceCharge = {\n serviceFeeCents: venueData?.serviceFeeCents ?? 0,\n serviceFeePercentage: venueData?.serviceFeePercentage ?? 0,\n serviceFeeChargeType: venueData?.serviceFeeChargeType ?? 'both',\n maxServiceFeeCents: venueData?.maxServiceFeeCents ?? 0,\n taxPercentage: venueData?.taxPercentage ?? 0,\n };\n venueFeesReady = true;\n } catch (err) {\n console.error('Error fetching venue data:', err);\n venueServiceCharge = {\n serviceFeeCents: 0,\n serviceFeePercentage: 0,\n serviceFeeChargeType: 'both',\n maxServiceFeeCents: 0,\n taxPercentage: 0,\n };\n venueFeesReady = true;\n }\n \n // Apply initial error state for showcase/preview rendering\n if (initialError) {\n setPaymentError(\n typeof initialError === 'object'\n ? initialError\n : { code: 'card_declined', message: 'Your card was declined. Please try a different payment method.' }\n );\n }\n\n window.addEventListener('resize', updateScreenSize);\n window.addEventListener('scroll', handleScroll);\n\n stickyTop = stickyRef?.getBoundingClientRect().top || 0;\n\n return () => {\n clearInterval(interval);\n window.removeEventListener('resize', updateScreenSize);\n window.removeEventListener('scroll', handleScroll);\n };\n });\n </script>\n \n <div class=\"px-5 md:px-10 pt-12 bg-white\" bind:this={containerRef}>\n <div class=\"w-full flex md:gap-5 flex-wrap\" bind:this={stickyRef}>\n <div class=\"flex-1 pb-16 md:pb-0\">\n <div class=\"checkout-card rounded-lg md:shadow md:border\">\n <header class=\"checkout-header flex justify-between py-5 md:p-5 border-b\" role=\"banner\">\n <div class=\"gap-1\">\n <h1 class=\"checkout-title text-lg font-semibold leading-relaxed\">\n {heading}\n </h1>\n <p class=\"timer-text pt-1 text-xs font-normal leading-normal\" role=\"timer\" aria-live=\"polite\" aria-atomic=\"true\">\n {Timing}\n </p>\n </div>\n <button\n onclick={goBack}\n class=\"close-btn p-2 rounded-lg transition-colors\"\n aria-label={labels.goBackToTicketSelection || \"Go back to cart\"}\n >\n <Close size={24} class=\"close-icon\" aria-hidden=\"true\" />\n </button>\n </header>\n\n <!-- Payment Error Banner -->\n {#if paymentErrorType}\n <div class=\"error-banner p-4 md:p-5 border-b\" role=\"alert\" aria-live=\"assertive\">\n <div class=\"error-banner-content flex items-start gap-3\">\n <div class=\"error-icon-wrapper shrink-0\" aria-hidden=\"true\">\n {#if paymentErrorType === 'card_declined'}\n <ErrorFilled size={24} class=\"error-icon\" />\n {:else if paymentErrorType === 'network'}\n <WarningFilled size={24} class=\"warning-icon\" />\n {:else}\n <WarningFilled size={24} class=\"warning-icon\" />\n {/if}\n </div>\n <div class=\"error-details flex-1\">\n <h2 class=\"error-title text-sm font-semibold mb-1\">\n {paymentErrorDetails.title}\n </h2>\n <p class=\"error-message text-sm mb-2\">\n {paymentErrorDetails.message}\n </p>\n {#if paymentErrorDetails.suggestion}\n <p class=\"error-suggestion text-xs\">\n {paymentErrorDetails.suggestion}\n </p>\n {/if}\n </div>\n <button\n onclick={clearPaymentError}\n class=\"error-dismiss p-1 rounded transition-colors\"\n aria-label={labels.close || \"Dismiss payment error\"}\n >\n <Close size={18} aria-hidden=\"true\" />\n </button>\n </div>\n {#if paymentErrorDetails.retryable}\n <div class=\"error-actions mt-3 flex gap-2\">\n <button\n onclick={() => { clearPaymentError(); initializeStripePayment(); }}\n class=\"retry-btn flex items-center gap-2 px-3 py-1.5 rounded-lg text-sm font-medium transition-colors\"\n aria-label={labels.networkErrorRetry || \"Retry payment\"}\n >\n <Renew size={16} aria-hidden=\"true\" />\n {labels.networkErrorRetry || 'Try again'}\n </button>\n </div>\n {/if}\n </div>\n {/if}\n\n <PersonalDetails\n bind:firstName\n bind:lastName\n bind:email\n bind:confirmEmail\n bind:phoneNumber\n bind:keepMeUpdated\n bind:ticketsInfo\n {emailMatchError}\n {updateTicketDetails}\n ticketType={event?.eventTicketingType ?? event?.ticketType ?? 0}\n {firstNameError}\n {lastNameError}\n {emailError}\n {confirmEmailError}\n {attendeeError}\n {updateTicketField}\n bind:firstNameTouched\n bind:lastNameTouched\n bind:emailTouched\n bind:confirmEmailTouched\n />\n \n <div class=\"py-5 md:p-5\">\n <TermsAndConditions\n bind:InputValue\n {terms}\n bind:showScrollbar\n bind:scrollContainer\n {handleScroll}\n {checkScrollable}\n {termsError}\n />\n </div>\n\n <div class=\"py-5 md:p-5\">\n <GiftCardInput\n {cartId}\n onApplied={handleGiftCardApplied}\n onRemoved={handleGiftCardRemoved}\n disabled={processing}\n />\n </div>\n\n {#if !giftCardApplied || giftCardApplied.requiresStripe}\n <div class=\"py-5 md:p-5\">\n <PaymentSection\n bind:selectedPayment\n {stripe}\n {paymentIntent}\n {processing}\n {executePurchase}\n bind:elements\n error={stripeError}\n />\n </div>\n {:else}\n <!-- Zero-payment: Gift card covers full amount -->\n <div class=\"py-5 md:p-5\">\n <div class=\"gift-card-complete-section p-4 bg-green-50 dark:bg-green-900/20 rounded-lg border border-green-200 dark:border-green-800\">\n <div class=\"flex items-center gap-3 mb-3\">\n <div class=\"w-10 h-10 rounded-full bg-green-100 dark:bg-green-900/50 flex items-center justify-center\">\n <svg class=\"w-5 h-5 text-green-600 dark:text-green-400\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M5 13l4 4L19 7\"></path>\n </svg>\n </div>\n <div>\n <p class=\"text-sm font-semibold text-green-800 dark:text-green-300\">{labels.giftCardNoPaymentRequired || 'No payment required'}</p>\n <p class=\"text-xs text-green-600 dark:text-green-400\">{labels.fullyCoveredByGiftCard || 'Your gift card covers the full order'}</p>\n </div>\n </div>\n </div>\n </div>\n {/if}\n </div>\n </div>\n \n {#if isSticky}\n <!-- svelte-ignore element_invalid_self_closing_tag -->\n <div class=\"w-full sm:w-80 flex flex-col\" />\n {/if}\n\n <div\n class=\"w-full sm:w-80 sm:flex flex-col transition-all {isSticky ? 'fixed top-5' : 'static'}\"\n class:is-sticky={isSticky}\n style:left={isSticky ? `${sidebarLeft}px` : 'auto'}\n >\n {#if !venueFeesReady}\n <OrderSummarySkeleton />\n {:else}\n <OrderSummary\n btnText={giftCardApplied?.paymentType === 'gift_card_only' ? (labels.giftCardCompleteOrder || 'Complete Order') : (labels.placeOrder || 'Place order')}\n eventTickets={availableTickets}\n {quantities}\n {venueServiceCharge}\n {isAgreed}\n {feePerTicket}\n promoApplied={!!promocode}\n promoDiscount={promoDiscountAmount}\n loading={processing}\n executePurchase={giftCardApplied?.paymentType === 'gift_card_only' ? executeGiftCardOnlyPurchase : executePurchase}\n {elements}\n {giftCardApplied}\n />\n {/if}\n </div>\n </div>\n </div>\n\n <!-- Session Extension Popup -->\n {#if showExtendSessionPopup}\n <div\n class=\"session-popup-overlay\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"extend-session-title\"\n aria-describedby=\"extend-session-description\"\n data-testid=\"session-extension-popup\"\n >\n <div class=\"session-popup\">\n <div class=\"session-popup-icon\" aria-hidden=\"true\">\n <WarningFilled size={32} class=\"warning-icon-large\" />\n </div>\n <h2 id=\"extend-session-title\" class=\"session-popup-title\">\n {labels.sessionExpiringSoon || 'Session Expiring Soon'}\n </h2>\n <p id=\"extend-session-description\" class=\"session-popup-message\">\n {labels.sessionExpireMessage || 'Your session will expire in'} <span class=\"time-remaining\">{formatTime(timerDuration)}</span>.\n {labels.sessionExtendQuestion || 'Would you like to extend your time to complete your purchase?'}\n </p>\n <div class=\"session-popup-actions\" data-testid=\"session-popup-actions\">\n <Button\n variant=\"default\"\n onclick={extendSession}\n data-testid=\"extend-session-btn\"\n aria-label={labels.sessionExtendAria || \"Extend session by 5 minutes\"}\n fullWidth\n >\n {labels.sessionExtendButton || 'Extend Time (+5 min)'}\n </Button>\n <Button\n variant=\"alternative\"\n onclick={dismissExtendPopup}\n data-testid=\"dismiss-session-popup-btn\"\n aria-label={labels.sessionDismissAria || \"Dismiss and continue without extending\"}\n fullWidth\n >\n {labels.sessionNoThanks || 'No Thanks'}\n </Button>\n </div>\n </div>\n </div>\n {/if}\n\n<style>\n @reference \"../../app.css\";\n\n /* Theme-responsive checkout styles with Tailwind */\n .checkout-card {\n @apply bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-700;\n }\n\n .checkout-header {\n @apply border-gray-200 dark:border-gray-700;\n }\n\n .checkout-title {\n @apply text-gray-900 dark:text-white;\n }\n\n .timer-text {\n @apply text-red-600 dark:text-red-400;\n }\n\n .close-btn:hover {\n @apply bg-gray-100 dark:bg-gray-800;\n }\n\n .close-icon {\n @apply text-gray-600 dark:text-gray-300;\n }\n\n /* Error Banner Styles */\n .error-banner {\n @apply flex items-center gap-2 p-3 rounded-lg bg-red-50 dark:bg-red-900/20 text-red-600 dark:text-red-400 border-red-200 dark:border-red-800;\n }\n\n .error-icon-wrapper {\n @apply mt-0.5;\n }\n\n .error-icon {\n @apply text-red-600 dark:text-red-400;\n }\n\n .warning-icon {\n @apply text-amber-500 dark:text-amber-400;\n }\n\n .error-title {\n @apply text-lg font-semibold text-red-700 dark:text-red-400 mb-2;\n }\n\n .error-message {\n @apply text-sm text-red-600 dark:text-red-300 leading-relaxed;\n }\n\n .error-suggestion {\n @apply text-red-500 dark:text-red-400 italic;\n }\n\n .error-dismiss {\n @apply text-red-600 dark:text-red-400;\n }\n\n .error-dismiss:hover {\n @apply bg-red-100 dark:bg-red-800/30;\n }\n\n .retry-btn {\n @apply text-white;\n background-color: hsl(var(--Brand-Primary, 224 76% 48%));\n }\n\n .retry-btn:hover {\n filter: brightness(0.9);\n }\n\n /* Gift card complete section */\n .gift-card-complete-section {\n @apply text-center;\n }\n\n /* Network error uses amber/warning colors */\n .error-banner:has(.warning-icon) {\n @apply bg-amber-50 dark:bg-amber-900/20 border-amber-200 dark:border-amber-800;\n }\n\n .error-banner:has(.warning-icon) .error-title {\n @apply text-amber-700 dark:text-amber-400;\n }\n\n .error-banner:has(.warning-icon) .error-message {\n @apply text-amber-600 dark:text-amber-300;\n }\n\n .error-banner:has(.warning-icon) .error-suggestion {\n @apply text-amber-500 dark:text-amber-400;\n }\n\n .error-banner:has(.warning-icon) .error-dismiss {\n @apply text-amber-600 dark:text-amber-400;\n }\n\n .error-banner:has(.warning-icon) .error-dismiss:hover {\n @apply bg-amber-100 dark:bg-amber-800/30;\n }\n\n /* Session Extension Popup Styles */\n .session-popup-overlay {\n @apply fixed inset-0 bg-black/50 dark:bg-black/70 flex items-center justify-center z-50 p-4;\n animation: fadeIn 0.2s ease-out;\n }\n\n .session-popup {\n @apply bg-white dark:bg-gray-800 rounded-xl shadow-2xl p-6 max-w-sm w-full text-center;\n animation: slideUp 0.3s ease-out;\n }\n\n .session-popup-icon {\n @apply mb-4;\n }\n\n .warning-icon-large {\n @apply text-amber-500 dark:text-amber-400 mx-auto;\n }\n\n .session-popup-title {\n @apply text-lg font-semibold text-gray-900 dark:text-white mb-2;\n }\n\n .session-popup-message {\n @apply text-sm text-gray-600 dark:text-gray-300 mb-6 leading-relaxed;\n }\n\n .time-remaining {\n @apply font-semibold text-red-600 dark:text-red-400;\n }\n\n .session-popup-actions {\n @apply flex flex-col gap-3;\n }\n\n @keyframes fadeIn {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n }\n\n @keyframes slideUp {\n from {\n opacity: 0;\n transform: translateY(20px) scale(0.95);\n }\n to {\n opacity: 1;\n transform: translateY(0) scale(1);\n }\n }\n</style>\n"],"names":["firstName","lastName","email","phoneNumber","keepMeUpdated","ticketsInfo","$","$$props","ticketType","firstNameError","lastNameError","emailError","phoneError","firstNameTouched","lastNameTouched","emailTouched","phoneTouched","labels","form","root","section","div","h2","div_1","Input","node","$$value","node_1","div_2","node_2","div_3","node_3","Checkbox","node_4","span","ticket","index","$$anchor","section_1","root_3","div_4","h2_1","node_7","e","div_5","$1","node_8","node_9","div_6","node_10","$$render","consequent","InputValue","termsError","a","text_1","p","root_2","selectedPayment","error","elements","StripeElementsComp","PaymentElementComp","stripeTheme","useStripeTheme","onMount","mod","err","selectPayment","method","button","root_1","StripeElementsComp_1","PaymentElementComp_1","root_5","alternate","p_1","root_6","browser","consequent_1","alternate_1","p_2","root_7","consequent_2","slide","consequent_3","button_1","span_1","button_2","svg","path","path_1","path_2","path_3","span_2","classes","classes_1","classes_2","GOOGLE_PAY","availableTickets","value","venueId","organizationId","initialError","id","orgSlug","slug","rawEvent","event","transformEvent","venueFeesReady","quantities","promocode","promoDiscountAmount","tickets","confirmEmailTouched","confirmEmail","scrollContainer","showScrollbar","heading","timerDuration","Timing","formatTime","feePerTicket","showExtendSessionPopup","sessionExtensionOffered","SESSION_WARNING_THRESHOLD","SESSION_EXTENSION_AMOUNT","terms","isMobile","containerRef","stickyRef","isSticky","stickyTop","sidebarLeft","cartId","isScrollable","giftCardApplied","stripe","calculatedTax","calculatedServiceFee","calculatedTotal","processing","paymentIntent","isCompleteOrder","isInCompleteOrder","initializeStripePayment","filteredQuantities","_","val","paymentData","createPaymentIntent","loadStripe","ACCENT","stripeError","venueServiceCharge","handleGiftCardApplied","appliedCard","handleGiftCardRemoved","seconds","minutes","remainingSeconds","extendSession","dismissExtendPopup","checkScrollable","confirmEmailError","attendeeError","paymentErrorType","paymentErrorDetails","getPaymentErrorDetails","errorCode","errorType","errorMessage","declineCode","clearPaymentError","setPaymentError","details","validateBeforeSubmit","hasError","isAgreed","ticketErrorCount","t","errors","executePurchase","elementsParam","elementsToUse","validationError","result","paymentPayload","response","validatePaymentIntent","successData","executeGiftCardOnlyPurchase","completeGiftCardPayment","goBack","params","url","goto","updateScreenSize","handleScroll","rect","containerBounding","updateTicketField","field","i","updateTicketDetails","checked","syncSameAsPersonalAttendees","normalizedEmail","normalizedConfirmEmail","emailMatchError","info","idx","ticketId","quantity","ticketMeta","Cookies","checkoutState","loadCheckoutStateFromCookies","interval","venueData","getVenueDetails","fragment","header","h1","Close","div_7","ErrorFilled","WarningFilled","div_8","text_4","div_9","Renew","text_2","text_3","consequent_4","$0","PersonalDetails","div_10","TermsAndConditions","div_11","GiftCardInput","div_12","PaymentSection","node_11","div_13","root_8","div_14","div_15","div_16","p_3","p_4","consequent_5","div_17","root_9","consequent_6","div_18","node_12","OrderSummarySkeleton","$2","OrderSummary","alternate_2","consequent_7","div_19","root_12","div_20","div_21","p_5","text_9","div_22","Button","node_16","node_17","consequent_8","styles"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
|
-
import { f as M, P as O, b as D, c as Z } from "./VenueCalendar-
|
|
3
|
+
import { f as M, P as O, b as D, c as Z } from "./VenueCalendar-DsXtZNAR.js";
|
|
4
4
|
var R = e.from_html('<div class="hero-image-container svelte-ndk2q7"><img alt="" class="hero-image svelte-ndk2q7" aria-hidden="true"/></div>'), S = e.from_html('<div class="hero-image-container hero-image-placeholder svelte-ndk2q7"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" class="placeholder-icon svelte-ndk2q7"><rect x="2" y="2" width="20" height="20" rx="2"></rect><circle cx="8.5" cy="8.5" r="1.5"></circle><path d="m21 15-5-5L5 21"></path></svg></div>'), V = e.from_html('<span class="badge-dot svelte-ndk2q7"></span> Series', 1), j = e.from_html('<span class="badge-dot svelte-ndk2q7"></span> Collection', 1), z = e.from_html('<span class="badge-separator svelte-ndk2q7">·</span> ', 1), J = e.from_html('<p class="hero-meta svelte-ndk2q7"> <!></p>'), K = e.from_html('<div class="featured-hero svelte-ndk2q7"><!> <div class="hero-content svelte-ndk2q7"><div class="hero-badge svelte-ndk2q7"><!> <!></div> <h2 class="hero-title svelte-ndk2q7"> </h2> <!></div></div>'), Q = e.from_html('<span class="meta-separator svelte-ndk2q7">·</span> ', 1), U = e.from_html('<p class="hero-description svelte-ndk2q7"> </p>'), W = e.from_html('<div class="featured-hero featured-hero-clickable svelte-ndk2q7" tabindex="0" role="button"><div class="hero-image-container svelte-ndk2q7"><img alt="" class="hero-image svelte-ndk2q7" aria-hidden="true"/></div> <div class="hero-content svelte-ndk2q7" aria-hidden="true"><h2 class="hero-title svelte-ndk2q7"> </h2> <p class="hero-meta svelte-ndk2q7"> <!></p> <!></div></div>'), X = e.from_html('<div class="featured-empty svelte-ndk2q7"><p class="empty-text svelte-ndk2q7">No upcoming events to feature</p></div>'), Y = e.from_html('<section class="featured-view svelte-ndk2q7" aria-label="Featured event"><!></section>');
|
|
5
5
|
function te(F, h) {
|
|
6
6
|
e.push(h, !0);
|
|
@@ -125,4 +125,4 @@ e.delegate(["click", "keydown"]);
|
|
|
125
125
|
export {
|
|
126
126
|
te as default
|
|
127
127
|
};
|
|
128
|
-
//# sourceMappingURL=FeaturedView.legacy-
|
|
128
|
+
//# sourceMappingURL=FeaturedView.legacy-BNysXCtk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FeaturedView.legacy-BNysXCtk.js","sources":["../src/components/Calendar/FeaturedView.legacy.svelte"],"sourcesContent":["<script>\n import { formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n\n let {\n events = [],\n featuredItem = null,\n oneventClick,\n } = $props();\n\n // Filter to today and future, sorted chronologically\n let futureEvents = $derived(filterTodayAndFuture(events));\n\n let heroEvent = $derived(futureEvents.length > 0 ? futureEvents[0] : null);\n\n function handleClick() {\n if (heroEvent) {\n oneventClick?.(heroEvent);\n }\n }\n</script>\n\n<section class=\"featured-view\" aria-label=\"Featured event\">\n {#if featuredItem}\n <!-- Series or Collection hero -->\n <div class=\"featured-hero\">\n {#if featuredItem.image}\n <div class=\"hero-image-container\">\n <img\n src={featuredItem.image}\n alt=\"\"\n class=\"hero-image\"\n aria-hidden=\"true\"\n />\n </div>\n {:else}\n <div class=\"hero-image-container hero-image-placeholder\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" class=\"placeholder-icon\"><rect x=\"2\" y=\"2\" width=\"20\" height=\"20\" rx=\"2\"/><circle cx=\"8.5\" cy=\"8.5\" r=\"1.5\"/><path d=\"m21 15-5-5L5 21\"/></svg>\n </div>\n {/if}\n\n <div class=\"hero-content\">\n <div class=\"hero-badge\">\n {#if featuredItem.type === 'series'}\n <span class=\"badge-dot\"></span>\n Series\n {:else}\n <span class=\"badge-dot\"></span>\n Collection\n {/if}\n {#if featuredItem.subtitle}\n <span class=\"badge-separator\">·</span>\n {featuredItem.subtitle}\n {/if}\n </div>\n\n <h2 class=\"hero-title\">{featuredItem.title}</h2>\n\n {#if heroEvent}\n <p class=\"hero-meta\">\n Next: {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\n {#if heroEvent.startDateTime}\n at {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\n {/if}\n </p>\n {/if}\n </div>\n </div>\n {:else if heroEvent}\n <!-- Single event hero -->\n <div\n class=\"featured-hero featured-hero-clickable\"\n onclick={handleClick}\n onkeydown={(e) => (e.key === 'Enter' || e.key === ' ') && handleClick()}\n tabindex=\"0\"\n role=\"button\"\n aria-label=\"{heroEvent.name}, {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}. Press Enter to view details.\"\n >\n <div class=\"hero-image-container\">\n <img\n src={heroEvent.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"hero-image\"\n aria-hidden=\"true\"\n />\n </div>\n\n <div class=\"hero-content\" aria-hidden=\"true\">\n <h2 class=\"hero-title\">{heroEvent.name}</h2>\n\n <p class=\"hero-meta\">\n {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\n {#if heroEvent.startDateTime}\n <span class=\"meta-separator\">·</span>\n {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\n {/if}\n </p>\n\n {#if heroEvent.description}\n <p class=\"hero-description\">{heroEvent.description}</p>\n {/if}\n </div>\n </div>\n {:else}\n <!-- Empty state -->\n <div class=\"featured-empty\">\n <p class=\"empty-text\">No upcoming events to feature</p>\n </div>\n {/if}\n</section>\n\n<style>\n @reference \"../../app.css\";\n\n .featured-view {\n width: 100%;\n }\n\n .featured-hero {\n @apply rounded-lg border border-gray-200 dark:border-gray-700 bg-white dark:bg-gray-900 overflow-hidden;\n }\n\n .featured-hero-clickable {\n @apply cursor-pointer;\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\n }\n\n .featured-hero-clickable:hover {\n @apply border-gray-300 dark:border-gray-600;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n }\n\n .featured-hero-clickable:focus {\n @apply outline-none;\n }\n\n .featured-hero-clickable:focus-visible {\n @apply outline-2 outline-blue-700 dark:outline-blue-500 outline-offset-2;\n }\n\n .hero-image-container {\n @apply relative w-full bg-gray-100 dark:bg-gray-700 overflow-hidden;\n aspect-ratio: 16 / 9;\n }\n\n .hero-image-placeholder {\n @apply flex items-center justify-center;\n }\n\n .placeholder-icon {\n @apply w-16 h-16 text-gray-300 dark:text-gray-600;\n }\n\n .hero-image {\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .hero-content {\n @apply p-4;\n }\n\n @media (min-width: 640px) {\n .hero-content {\n @apply p-5;\n }\n }\n\n .hero-badge {\n @apply inline-flex items-center gap-1.5 text-xs font-semibold text-blue-700 dark:text-blue-400 uppercase tracking-wide mb-2;\n }\n\n .badge-dot {\n @apply w-1.5 h-1.5 rounded-full bg-blue-600 dark:bg-blue-400;\n }\n\n .badge-separator {\n @apply text-gray-400 dark:text-gray-500;\n }\n\n .hero-title {\n @apply text-xl font-bold text-gray-900 dark:text-white mb-2;\n line-height: 1.3;\n }\n\n @media (min-width: 640px) {\n .hero-title {\n @apply text-2xl;\n }\n }\n\n .hero-meta {\n @apply text-base text-gray-600 dark:text-gray-300 font-medium;\n }\n\n .meta-separator {\n @apply text-gray-400 dark:text-gray-500 mx-1;\n }\n\n .hero-description {\n @apply text-sm text-gray-600 dark:text-gray-400 mt-2;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n .featured-empty {\n @apply flex items-center justify-center py-12 rounded-lg border border-gray-200 dark:border-gray-700 bg-gray-50 dark:bg-gray-900;\n }\n\n .empty-text {\n @apply text-sm text-gray-500 dark:text-gray-400;\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .featured-hero-clickable {\n transition: none;\n }\n }\n</style>\n"],"names":["events","$","$$props","featuredItem","futureEvents","filterTodayAndFuture","heroEvent","handleClick","section","root","div","root_1","div_1","root_2","img","div_2","root_3","$$render","consequent","alternate","div_3","node_1","div_4","consequent_1","alternate_1","text","consequent_2","h2","p","root_7","formatEventTime","consequent_3","formatFullDate","consequent_4","text_1","div_5","root_9","div_6","img_1","div_7","h2_1","p_1","consequent_6","p_2","root_11","text_7","consequent_7","$0","PLACEHOLDER_IMAGE","text_4","e","div_8","root_12","consequent_8","alternate_2"],"mappings":"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"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import "svelte/internal/disclose-version";
|
|
2
|
+
import * as e from "svelte/internal/client";
|
|
3
|
+
import { a as p, i as A, P as B, d as C, b as G, c as b, S as L, e as O } from "./VenueCalendar-DsXtZNAR.js";
|
|
4
|
+
var P = e.from_html('<div class="badge-overlay svelte-18a25gb" aria-hidden="true"><span> </span></div>'), R = e.from_html('<div class="badge-overlay svelte-18a25gb" aria-hidden="true"><!></div>'), H = e.from_html("<time> </time>"), U = e.from_html('<span class="meta-separator svelte-18a25gb" aria-hidden="true">•</span> <span> </span>', 1), j = e.from_html('<a><div class="card-image-container svelte-18a25gb"><img alt="" class="card-image svelte-18a25gb" loading="lazy" aria-hidden="true"/> <!></div> <div class="card-content svelte-18a25gb" aria-hidden="true"><h3 class="card-title svelte-18a25gb"> </h3> <div class="card-meta svelte-18a25gb"><!> <!></div></div></a>');
|
|
5
|
+
function I(h, i) {
|
|
6
|
+
e.push(i, !0);
|
|
7
|
+
let v = e.prop(i, "labels", 19, () => ({})), n = e.derived(() => p(i.event)), D = e.derived(() => A(e.get(n)));
|
|
8
|
+
function T(t) {
|
|
9
|
+
const a = [t.name];
|
|
10
|
+
return t.startDateTime && a.push(`on ${G(t.startDateTime, t.timeZone)}`), t.startDateTime && a.push(`at ${b(t.startDateTime, t.timeZone)}`), e.get(n) ? a.push(e.get(n).text) : t.status && t.status !== (v().statusOnSale || "On Sale") && a.push(t.status), a.push(v().pressEnterToView || "Press Enter to view details"), a.join(", ");
|
|
11
|
+
}
|
|
12
|
+
var s = j();
|
|
13
|
+
let g;
|
|
14
|
+
var d = e.child(s), u = e.child(d), x = e.sibling(u, 2);
|
|
15
|
+
{
|
|
16
|
+
var E = (t) => {
|
|
17
|
+
var a = P(), r = e.child(a), l = e.child(r, !0);
|
|
18
|
+
e.reset(r), e.reset(a), e.template_effect(() => {
|
|
19
|
+
e.set_class(r, 1, `status-badge status-${e.get(n).type ?? ""}`, "svelte-18a25gb"), e.set_text(l, e.get(n).text);
|
|
20
|
+
}), e.append(t, a);
|
|
21
|
+
}, k = (t) => {
|
|
22
|
+
var a = R(), r = e.child(a);
|
|
23
|
+
{
|
|
24
|
+
let l = e.derived(() => i.event.ticketsRemaining ?? 0), c = e.derived(() => i.event.ticketsTotal ?? 0);
|
|
25
|
+
L(r, {
|
|
26
|
+
get remaining() {
|
|
27
|
+
return e.get(l);
|
|
28
|
+
},
|
|
29
|
+
get total() {
|
|
30
|
+
return e.get(c);
|
|
31
|
+
},
|
|
32
|
+
context: "browse",
|
|
33
|
+
get labels() {
|
|
34
|
+
return v();
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
e.reset(a), e.append(t, a);
|
|
39
|
+
};
|
|
40
|
+
e.if(x, (t) => {
|
|
41
|
+
e.get(n) ? t(E) : (i.event.ticketsTotal > 0 || i.event.ticketsRemaining === 0) && t(k, 1);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
e.reset(d);
|
|
45
|
+
var o = e.sibling(d, 2), m = e.child(o), y = e.child(m, !0);
|
|
46
|
+
e.reset(m);
|
|
47
|
+
var f = e.sibling(m, 2), _ = e.child(f);
|
|
48
|
+
{
|
|
49
|
+
var w = (t) => {
|
|
50
|
+
var a = H(), r = e.child(a, !0);
|
|
51
|
+
e.reset(a), e.template_effect(
|
|
52
|
+
(l) => {
|
|
53
|
+
e.set_attribute(a, "datetime", i.event.startDateTime), e.set_text(r, l);
|
|
54
|
+
},
|
|
55
|
+
[
|
|
56
|
+
() => O(i.event.startDateTime, i.event.timeZone)
|
|
57
|
+
]
|
|
58
|
+
), e.append(t, a);
|
|
59
|
+
};
|
|
60
|
+
e.if(_, (t) => {
|
|
61
|
+
i.event.startDateTime && t(w);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
var S = e.sibling(_, 2);
|
|
65
|
+
{
|
|
66
|
+
var Z = (t) => {
|
|
67
|
+
var a = U(), r = e.sibling(e.first_child(a), 2), l = e.child(r, !0);
|
|
68
|
+
e.reset(r), e.template_effect((c) => e.set_text(l, c), [
|
|
69
|
+
() => b(i.event.startDateTime, i.event.timeZone)
|
|
70
|
+
]), e.append(t, a);
|
|
71
|
+
};
|
|
72
|
+
e.if(S, (t) => {
|
|
73
|
+
i.event.startDateTime && t(Z);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
e.reset(f), e.reset(o), e.reset(s), e.template_effect(
|
|
77
|
+
(t, a) => {
|
|
78
|
+
e.set_attribute(s, "href", t), g = e.set_class(s, 1, "gallery-card svelte-18a25gb", null, g, { "card-unavailable": e.get(D) }), e.set_attribute(s, "aria-label", a), e.set_attribute(u, "src", i.event.image || B), e.set_text(y, i.event.name);
|
|
79
|
+
},
|
|
80
|
+
[
|
|
81
|
+
() => C(i.event),
|
|
82
|
+
() => T(i.event)
|
|
83
|
+
]
|
|
84
|
+
), e.delegated("click", s, (t) => {
|
|
85
|
+
t.preventDefault(), i.oneventClick?.(i.event);
|
|
86
|
+
}), e.append(h, s), e.pop();
|
|
87
|
+
}
|
|
88
|
+
e.delegate(["click"]);
|
|
89
|
+
export {
|
|
90
|
+
I as G
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=GalleryCard-RBMkn3Va.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GalleryCard-RBMkn3Va.js","sources":["../src/components/Calendar/GalleryCard.svelte"],"sourcesContent":["<script>\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\n import { formatBrowseDate, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { getBrowseStatus, isEventUnavailable } from \"$lib/utils/browse-status.js\";\n import { buildEventHref } from \"$lib/url-manager/params\";\n\n let { event, oneventClick, labels = {} } = $props();\n\n let browseStatus = $derived(getBrowseStatus(event));\n let isUnavailable = $derived(isEventUnavailable(browseStatus));\n\n // Build comprehensive aria-label for event card\n function getEventAriaLabel(event) {\n const parts = [event.name];\n if (event.startDateTime) {\n parts.push(`on ${formatFullDate(event.startDateTime, event.timeZone)}`);\n }\n if (event.startDateTime) {\n parts.push(`at ${formatEventTime(event.startDateTime, event.timeZone)}`);\n }\n if (browseStatus) {\n parts.push(browseStatus.text);\n } else if (event.status && event.status !== (labels.statusOnSale || 'On Sale')) {\n parts.push(event.status);\n }\n parts.push(labels.pressEnterToView || 'Press Enter to view details');\n return parts.join(', ');\n }\n</script>\n\n<a\n href={buildEventHref(event)}\n class=\"gallery-card\"\n class:card-unavailable={isUnavailable}\n onclick={(e) => { e.preventDefault(); oneventClick?.(event); }}\n aria-label={getEventAriaLabel(event)}\n>\n <!-- Fixed height image container -->\n <div class=\"card-image-container\">\n <img\n src={event.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"card-image\"\n loading=\"lazy\"\n aria-hidden=\"true\"\n />\n <!-- Status Badge overlay -->\n {#if browseStatus}\n <div class=\"badge-overlay\" aria-hidden=\"true\">\n <span class=\"status-badge status-{browseStatus.type}\">{browseStatus.text}</span>\n </div>\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\n <div class=\"badge-overlay\" aria-hidden=\"true\">\n <ScarcityBadge\n remaining={event.ticketsRemaining ?? 0}\n total={event.ticketsTotal ?? 0}\n context=\"browse\"\n {labels}\n />\n </div>\n {/if}\n </div>\n\n <!-- Event Details -->\n <div class=\"card-content\" aria-hidden=\"true\">\n <h3 class=\"card-title\">{event.name}</h3>\n <div class=\"card-meta\">\n {#if event.startDateTime}\n <time datetime={event.startDateTime}>\n {formatBrowseDate(event.startDateTime, event.timeZone)}\n </time>\n {/if}\n {#if event.startDateTime}\n <span class=\"meta-separator\" aria-hidden=\"true\">•</span>\n <span>{formatEventTime(event.startDateTime, event.timeZone)}</span>\n {/if}\n </div>\n </div>\n</a>\n\n<style>\n @reference \"../../app.css\";\n\n .gallery-card {\n @apply rounded-lg border bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-700;\n @apply overflow-hidden cursor-pointer block;\n text-decoration: none;\n color: inherit;\n transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;\n }\n\n .gallery-card:hover {\n @apply border-gray-300 dark:border-gray-600;\n transform: translateY(-2px);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);\n }\n\n .gallery-card:focus {\n @apply outline-none;\n }\n\n .gallery-card:focus-visible {\n @apply outline-2 outline-blue-700 dark:outline-blue-500 outline-offset-2;\n }\n\n .gallery-card:active {\n transform: translateY(0);\n }\n\n /* Fixed height image container */\n .card-image-container {\n @apply relative w-full bg-gray-100 dark:bg-gray-700 overflow-hidden;\n height: 200px;\n }\n\n @media (max-width: 639px) {\n .card-image-container {\n height: 220px;\n }\n }\n\n @media (min-width: 1024px) {\n .card-image-container {\n height: 180px;\n }\n }\n\n .card-image {\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .badge-overlay {\n position: absolute;\n top: 8px;\n left: 8px;\n }\n\n .card-content {\n @apply p-3;\n }\n\n @media (min-width: 640px) {\n .card-content {\n @apply p-3.5;\n }\n }\n\n .card-title {\n @apply text-base font-semibold text-gray-900 dark:text-white mb-1.5;\n line-height: 1.3;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n @media (max-width: 639px) {\n .card-title {\n @apply text-lg;\n }\n }\n\n .card-meta {\n @apply text-sm text-gray-600 dark:text-gray-300 font-medium;\n }\n\n @media (max-width: 639px) {\n .card-meta {\n @apply text-base;\n }\n }\n\n .meta-separator {\n @apply text-gray-400 dark:text-gray-500 mx-1;\n }\n\n /* Unavailable event dimming */\n .card-unavailable {\n @apply opacity-60;\n }\n\n .card-unavailable .card-image {\n filter: grayscale(0.5);\n }\n\n /* Status badges — distinct visual treatments for each status */\n .status-badge {\n @apply inline-flex items-center text-xs font-bold px-2.5 py-1 rounded;\n box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);\n letter-spacing: 0.02em;\n }\n\n .status-cancelled {\n @apply text-white;\n background: linear-gradient(135deg, rgb(127 29 29) 0%, rgb(185 28 28) 100%); /* rose-900 → red-700 */\n text-decoration: line-through;\n text-decoration-thickness: 1.5px;\n }\n\n .status-past {\n @apply text-gray-300;\n background: rgba(0, 0, 0, 0.7);\n backdrop-filter: blur(4px);\n }\n\n .status-sold_out {\n @apply text-white uppercase tracking-wider;\n background: linear-gradient(135deg, rgb(220 38 38) 0%, rgb(239 68 68) 100%); /* red-600 → red-400 */\n font-size: 0.65rem;\n }\n\n .status-sales_ended {\n @apply text-gray-200;\n background: rgba(55, 65, 81, 0.9); /* gray-700 */\n backdrop-filter: blur(4px);\n border: 1px solid rgba(156, 163, 175, 0.3);\n }\n\n .status-coming_soon {\n @apply text-white;\n background: linear-gradient(135deg, rgb(37 99 235) 0%, rgb(99 102 241) 100%); /* blue-600 → indigo-500 */\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .gallery-card {\n transition: none;\n }\n\n .gallery-card:hover {\n transform: none;\n }\n }\n</style>\n"],"names":["labels","$","$$props","browseStatus","getBrowseStatus","isUnavailable","isEventUnavailable","getEventAriaLabel","event","parts","formatFullDate","formatEventTime","a","root","div","img","div_1","root_1","span","text","div_2","root_2","$0","$1","ScarcityBadge","node_1","$$render","consequent_1","div_3","h3","div_4","time","root_3","formatBrowseDate","consequent_2","span_1","fragment","consequent_3","classes","PLACEHOLDER_IMAGE","buildEventHref","e","$$anchor"],"mappings":"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"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as k, onDestroy as C } from "svelte";
|
|
4
|
-
import { G as M } from "./GalleryCard-
|
|
5
|
-
import { f as w } from "./VenueCalendar-
|
|
4
|
+
import { G as M } from "./GalleryCard-RBMkn3Va.js";
|
|
5
|
+
import { f as w } from "./VenueCalendar-DsXtZNAR.js";
|
|
6
6
|
var x = e.from_html('<li class="gallery-card-wrapper svelte-lb0ck7"><!></li>'), E = e.from_html('<div class="load-more-trigger svelte-lb0ck7" role="status" aria-live="polite"><span class="loading-text svelte-lb0ck7">Loading more events...</span></div>'), G = e.from_html('<section class="gallery-view svelte-lb0ck7" aria-label="Events gallery"><h2 class="sr-only svelte-lb0ck7">Upcoming events</h2> <ul class="gallery-grid svelte-lb0ck7" role="list"></ul> <!></section>');
|
|
7
7
|
function F(g, i) {
|
|
8
8
|
e.push(i, !0);
|
|
@@ -49,4 +49,4 @@ function F(g, i) {
|
|
|
49
49
|
export {
|
|
50
50
|
F as default
|
|
51
51
|
};
|
|
52
|
-
//# sourceMappingURL=GalleryView.legacy-
|
|
52
|
+
//# sourceMappingURL=GalleryView.legacy-BDKpD6lT.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GalleryView.legacy-BDKpD6lT.js","sources":["../src/components/Calendar/GalleryView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount, onDestroy } from \"svelte\";\n import GalleryCard from \"./GalleryCard.svelte\";\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n\n let { events = [], initialCount = 12, loadMoreCount = 12, oneventClick } = $props();\n\n let displayedCount = initialCount;\n let loadMoreTrigger;\n let observer;\n\n // Filter to today and future, sorted chronologically\n let futureEvents = $derived(filterTodayAndFuture(events));\n let displayedEvents = $derived(futureEvents.slice(0, displayedCount));\n let hasMore = $derived(displayedCount < futureEvents.length);\n\n function loadMore() {\n displayedCount += loadMoreCount;\n }\n\n onMount(() => {\n observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting && hasMore) {\n loadMore();\n }\n },\n { rootMargin: '100px' }\n );\n\n if (loadMoreTrigger) {\n observer.observe(loadMoreTrigger);\n }\n });\n\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n }\n });\n\n // Re-observe when trigger element changes\n $effect(() => {\n if (observer && loadMoreTrigger) {\n observer.disconnect();\n observer.observe(loadMoreTrigger);\n }\n });\n</script>\n\n<section class=\"gallery-view\" aria-label=\"Events gallery\">\n <h2 class=\"sr-only\">Upcoming events</h2>\n <ul class=\"gallery-grid\" role=\"list\">\n {#each displayedEvents as event}\n <li class=\"gallery-card-wrapper\">\n <GalleryCard {event} {oneventClick} />\n </li>\n {/each}\n </ul>\n\n <!-- Infinite scroll trigger -->\n {#if hasMore}\n <div bind:this={loadMoreTrigger} class=\"load-more-trigger\" role=\"status\" aria-live=\"polite\">\n <span class=\"loading-text\">Loading more events...</span>\n </div>\n {/if}\n</section>\n\n<style>\n @reference \"../../app.css\";\n\n .gallery-view {\n width: 100%;\n }\n\n .gallery-grid {\n @apply grid grid-cols-1 gap-4 bg-gray-50 dark:bg-gray-900 p-2;\n }\n\n /* 2 columns at sm (640px) */\n @media (min-width: 640px) {\n .gallery-grid {\n @apply grid-cols-2 gap-4 p-3;\n }\n }\n\n /* 3 columns at md (768px) */\n @media (min-width: 768px) {\n .gallery-grid {\n @apply grid-cols-3 gap-5 p-4;\n }\n }\n\n /* 4 columns at lg (1024px) */\n @media (min-width: 1024px) {\n .gallery-grid {\n @apply grid-cols-4 gap-6 p-5;\n }\n }\n\n /* Load more trigger */\n .load-more-trigger {\n @apply flex items-center justify-center gap-2 py-2 p-6;\n }\n\n .loading-text {\n @apply text-sm text-gray-500 dark:text-gray-400;\n }\n\n /* Gallery card wrapper for list items */\n .gallery-card-wrapper {\n @apply list-none;\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","displayedCount","loadMoreTrigger","observer","futureEvents","filterTodayAndFuture","displayedEvents","hasMore","loadMore","onMount","entries","onDestroy","section","root","ul","$$anchor","event","li","root_1","GalleryCard","node","div","root_2","$$value","$$render","consequent"],"mappings":";;;;;;iBAAA;;MAKQA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GAAOC,iCAAe,EAAE,GAAEC,kCAAgB,EAAE,GAEpDC,IAAiBF,EAAY,GAC7BG,GACAC,GAGAC,IAAYP,EAAA,QAAA,MAAYQ,EAAqBT,EAAM,CAAA,CAAA,GACnDU,0BAA2BF,CAAY,EAAC,MAAM,GAAGH,CAAc,CAAA,GAC/DM,IAAOV,EAAA,QAAA,MAAYI,IAAcJ,EAAA,IAAGO,CAAY,EAAC,MAAM;AAElD,WAAAI,IAAW;AAClB,IAAAP,KAAkBD,EAAa;AAAA,EACjC;AAEA,EAAAS,EAAO,MAAO;AACZ,IAAAN,QAAe;AAAA,MACZ,CAAAO,MAAY;AACP,QAAAA,EAAQ,CAAC,EAAE,kBAAcb,EAAA,IAAIU,CAAO,KACtCC,EAAQ;AAAA,MAEZ;AAAA,MACE,EAAA,YAAY,QAAO;AAAA,OAGnBN,KACFC,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC,GAEDS,EAAS,MAAO;AACV,IAAAR,KACFA,EAAS,WAAU;AAAA,EAEvB,CAAC,GAGDN,EAAA,YAAO,MAAO;IACRM,KAAYD,MACdC,EAAS,WAAU,GACnBA,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC;MAGFU,IAAOC,EAAA,GAELC,sBAFFF,CAAO,GAAA,CAAA;SAELE,GAAE,IAAA,MAAAjB,EAAA,IACMS,CAAe,GAAAT,EAAA,OAAA,CAAAkB,GAAIC,MAAK;QAC5BC,IAAEC,EAAA,eAAFD,CAAE;AACA,IAAAE,EAAWC,GAAA;AAAA;qBAAEJ,CAAK;AAAA;;;;gBADpBC,CAAE,eAAFA,CAAE;AAAA,cAFNH,CAAE;oBAAFA,GAAE,CAAA;;;UAUAO,IAAGC,EAAA;kBAAHD,GAAG,CAAAE,MAAYrB,IAAeqB,GAAA,MAAfrB,CAAe,eAA9BmB,CAAG;AAAA;;YADDd,CAAO,KAAAiB,EAAAC,CAAA;AAAA;;UAXbb,CAAO,eAAPA,CAAO;AAFA;"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as ae, onDestroy as re } from "svelte";
|
|
4
|
-
import { f as se, g as ie, a as le, i as ne, P as oe, b as P, c as U, S as de } from "./VenueCalendar-
|
|
4
|
+
import { f as se, g as ie, a as le, i as ne, P as oe, b as P, c as U, S as de } from "./VenueCalendar-DsXtZNAR.js";
|
|
5
5
|
var ve = e.from_html('<div class="date-column svelte-r2wh13" aria-hidden="true"><span class="date-month svelte-r2wh13"> </span> <span class="date-day svelte-r2wh13"> </span> <span class="date-weekday svelte-r2wh13"> </span></div>'), ce = e.from_html('<p class="event-description svelte-r2wh13"> </p>'), ge = e.from_html("<span> </span>"), me = e.from_html('<li class="event-list-item svelte-r2wh13"><div tabindex="0" role="button"><div class="event-image-container svelte-r2wh13" aria-hidden="true"><img alt="" class="event-image svelte-r2wh13" loading="lazy"/></div> <div class="event-details svelte-r2wh13" aria-hidden="true"><h3 class="event-title svelte-r2wh13"> </h3> <time class="event-time svelte-r2wh13"> </time> <!></div> <div class="event-badge-container svelte-r2wh13" aria-hidden="true"><!></div></div></li>'), he = e.from_html('<div class="date-group svelte-r2wh13" role="group"><!> <ul class="events-column svelte-r2wh13"></ul></div>'), fe = e.from_html('<div class="load-more-trigger svelte-r2wh13" role="status" aria-live="polite"><span class="loading-text svelte-r2wh13">Loading more events...</span></div>'), ue = e.from_html('<section aria-label="Event listings"><h2 class="sr-only svelte-r2wh13">Event list grouped by date</h2> <!> <!></section>');
|
|
6
6
|
function be(A, d) {
|
|
7
7
|
e.push(d, !0);
|
|
@@ -145,4 +145,4 @@ e.delegate(["click", "keydown"]);
|
|
|
145
145
|
export {
|
|
146
146
|
be as default
|
|
147
147
|
};
|
|
148
|
-
//# sourceMappingURL=GroupedListView.legacy-
|
|
148
|
+
//# sourceMappingURL=GroupedListView.legacy-fL2kRm35.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GroupedListView.legacy-fL2kRm35.js","sources":["../src/components/Calendar/GroupedListView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount, onDestroy } from \"svelte\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { getDateParts, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { getBrowseStatus, isEventUnavailable, filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\n\n let {\n events = [],\n initialCount = 10,\n loadMoreCount = 10,\n showDateColumn = true,\n filterFutureOnly = true,\n oneventClick\n } = $props();\n\n let displayedCount = initialCount;\n let loadMoreTrigger;\n let observer;\n\n // Filter to today and future (if enabled), then group by date\n let filteredEvents = $derived(filterFutureOnly ? filterTodayAndFuture(events) : events);\n let groupedEvents = $derived(groupEventsByDate(filteredEvents.slice(0, displayedCount)));\n let hasMore = $derived(displayedCount < filteredEvents.length);\n\n function loadMore() {\n displayedCount += loadMoreCount;\n }\n\n onMount(() => {\n observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting && hasMore) {\n loadMore();\n }\n },\n { rootMargin: '100px' }\n );\n\n if (loadMoreTrigger) {\n observer.observe(loadMoreTrigger);\n }\n });\n\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n }\n });\n\n // Re-observe when trigger element changes\n $effect(() => {\n if (observer && loadMoreTrigger) {\n observer.disconnect();\n observer.observe(loadMoreTrigger);\n }\n });\n\n function groupEventsByDate(eventList) {\n const groups = {};\n\n for (const event of eventList) {\n const dateKey = event.date; // YYYY-MM-DD format\n if (!groups[dateKey]) {\n groups[dateKey] = [];\n }\n groups[dateKey].push(event);\n }\n\n // Convert to array sorted by date\n return Object.entries(groups)\n .sort(([a], [b]) => new Date(a) - new Date(b))\n .map(([date, events]) => ({\n date,\n events,\n formattedDate: formatGroupDate(events),\n }));\n }\n\n function formatGroupDate(events) {\n // Use the first event in the group to get timezone-aware date parts\n const firstEvent = events[0];\n if (!firstEvent?.startDateTime) return { month: '', day: '', weekday: '' };\n const parts = getDateParts(firstEvent.startDateTime, firstEvent.timeZone);\n return {\n month: parts.month.toUpperCase(),\n day: String(parts.date).padStart(2, '0'),\n weekday: parts.day.toUpperCase(),\n };\n }\n\n function handleEventClick(event) {\n oneventClick?.(event);\n }\n\n function handleKeydown(e, event) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleEventClick(event);\n }\n }\n</script>\n\n<section class=\"grouped-list\" class:no-date-column={!showDateColumn} aria-label=\"Event listings\">\n <h2 class=\"sr-only\">Event list grouped by date</h2>\n {#each groupedEvents as group}\n <div class=\"date-group\" 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=\"date-column\" aria-hidden=\"true\">\n <span class=\"date-month\">{group.formattedDate.month}</span>\n <span class=\"date-day\">{group.formattedDate.day}</span>\n <span class=\"date-weekday\">{group.formattedDate.weekday}</span>\n </div>\n {/if}\n\n <!-- Events Column -->\n <ul class=\"events-column\">\n {#each group.events as event, eventIndex}\n {@const eventStatus = getBrowseStatus(event)}\n {@const isUnavailable = isEventUnavailable(eventStatus)}\n <li class=\"event-list-item\">\n <div\n class=\"event-row\"\n class:event-row-first={eventIndex === 0}\n class:event-row-last={eventIndex === group.events.length - 1}\n class:row-unavailable={isUnavailable}\n onclick={() => handleEventClick(event)}\n onkeydown={(e) => handleKeydown(e, event)}\n tabindex=\"0\"\n role=\"button\"\n aria-label={`${event.name} on ${event.startDateTime ? formatFullDate(event.startDateTime, event.timeZone) : group.date} at ${event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}, ${eventStatus?.text || event.status || 'On Sale'}. Press Enter to view details.`}\n >\n <!-- Event Image -->\n <div class=\"event-image-container\" aria-hidden=\"true\">\n <img\n src={event.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"event-image\"\n loading=\"lazy\"\n />\n </div>\n\n <!-- Event Details (visually shown but also in aria-label, so hide from SR) -->\n <div class=\"event-details\" aria-hidden=\"true\">\n <h3 class=\"event-title\">{event.name}</h3>\n <time class=\"event-time\" datetime={event.startDateTime || group.date}>{event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}</time>\n {#if event.description}\n <p class=\"event-description\">{event.description}</p>\n {/if}\n </div>\n\n <!-- Status / Scarcity Badge -->\n <div class=\"event-badge-container\" aria-hidden=\"true\">\n {#if eventStatus}\n <span class=\"status-badge status-{eventStatus.type}\">{eventStatus.text}</span>\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\n <ScarcityBadge\n remaining={event.ticketsRemaining ?? 0}\n total={event.ticketsTotal ?? 0}\n context=\"browse\"\n />\n {/if}\n </div>\n </div>\n </li>\n {/each}\n </ul>\n </div>\n {/each}\n\n <!-- Infinite scroll trigger -->\n {#if hasMore}\n <div bind:this={loadMoreTrigger} class=\"load-more-trigger\" role=\"status\" aria-live=\"polite\">\n <span class=\"loading-text\">Loading more events...</span>\n </div>\n {/if}\n</section>\n\n<style>\n @reference \"../../app.css\";\n\n .grouped-list {\n @apply flex flex-col gap-0;\n }\n\n .date-group {\n @apply flex border-b border-gray-200 dark:border-gray-700;\n }\n\n .date-group:last-child {\n @apply border-b-0;\n }\n\n /* When no date column, remove left border styling */\n .no-date-column .date-group {\n @apply border-b-0;\n }\n\n .no-date-column .events-column {\n @apply border-l-0;\n }\n\n /* Date Column - Fixed width on left */\n .date-column {\n @apply w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-gray-50 dark:bg-gray-900 border-r border-gray-200 dark:border-gray-700;\n }\n\n .date-month {\n @apply text-xs font-semibold text-gray-600 dark:text-gray-300 uppercase tracking-tight;\n }\n\n .date-day {\n @apply text-2xl font-bold text-gray-900 dark:text-white leading-tight;\n }\n\n .date-weekday {\n @apply text-xs font-semibold text-gray-600 dark:text-gray-300 uppercase tracking-tight;\n }\n\n /* Events Column - Flexible width */\n ul.events-column {\n @apply flex-1 flex flex-col;\n }\n\n /* Individual Event Row */\n .event-row {\n @apply flex gap-4 p-5 cursor-pointer transition-colors duration-150 bg-white dark:bg-gray-800 border-b border-gray-200/50 dark:border-gray-700/50;\n }\n\n .event-row:last-child {\n @apply border-b-0;\n }\n\n .event-row:hover {\n @apply bg-gray-50 dark:bg-gray-700;\n }\n\n .event-row:focus {\n @apply outline-2 outline-blue-700 dark:outline-blue-400 -outline-offset-2;\n }\n\n .event-row:focus-visible {\n @apply outline-2 outline-blue-700 dark:outline-blue-400 -outline-offset-2;\n }\n\n /* Reset list styles */\n .events-column {\n @apply list-none p-0 m-0;\n }\n\n .event-list-item {\n @apply list-none;\n }\n\n /* Event Image */\n .event-image-container {\n @apply w-36 h-24 min-w-36 rounded-lg overflow-hidden bg-gray-50 dark:bg-gray-900 flex items-center justify-center;\n }\n\n .event-image {\n @apply w-full h-full object-contain;\n }\n\n /* Event Details */\n .event-details {\n @apply flex-1 flex flex-col gap-1.5 min-w-0;\n }\n\n .event-title {\n @apply text-lg font-semibold text-gray-900 dark:text-white m-0 leading-snug;\n }\n\n .event-time {\n @apply text-sm font-medium text-gray-600 dark:text-gray-300;\n }\n\n .event-description {\n @apply text-sm text-gray-600 dark:text-gray-300 mt-1.5 mb-0 line-clamp-2;\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n /* Badge Container */\n .event-badge-container {\n @apply flex items-start pt-0.5;\n }\n\n /* Unavailable row dimming */\n .row-unavailable {\n @apply opacity-60;\n }\n\n .row-unavailable .event-image {\n filter: grayscale(0.5);\n }\n\n /* Status badges — distinct visual treatments matching gallery cards */\n .status-badge {\n @apply inline-flex items-center text-xs font-bold px-2.5 py-1 rounded whitespace-nowrap;\n letter-spacing: 0.02em;\n }\n\n .status-cancelled {\n @apply bg-red-100 text-red-800 dark:bg-red-900/40 dark:text-red-300;\n text-decoration: line-through;\n text-decoration-thickness: 1.5px;\n }\n\n .status-past {\n @apply bg-gray-100 text-gray-500 dark:bg-gray-800 dark:text-gray-400;\n }\n\n .status-sold_out {\n @apply bg-red-100 text-red-700 dark:bg-red-900/40 dark:text-red-400 uppercase tracking-wider;\n font-size: 0.65rem;\n }\n\n .status-sales_ended {\n @apply bg-gray-100 text-gray-500 dark:bg-gray-800 dark:text-gray-400;\n border: 1px solid rgb(209 213 219); /* gray-300 */\n }\n\n :global(.dark) .status-sales_ended {\n border-color: rgb(75 85 99); /* gray-600 */\n }\n\n .status-coming_soon {\n @apply bg-indigo-100 text-indigo-700 dark:bg-indigo-900/40 dark:text-indigo-300;\n }\n\n /* Mobile Responsiveness */\n @media (max-width: 640px) {\n .date-column {\n @apply w-12 min-w-12 py-2.5 px-1.5;\n }\n\n .date-month {\n @apply text-xs;\n }\n\n .date-day {\n @apply text-lg;\n }\n\n .date-weekday {\n @apply text-xs;\n }\n\n .event-row {\n @apply p-3 gap-2.5;\n }\n\n .event-image-container {\n @apply w-20 h-16 min-w-20;\n }\n\n .event-title {\n @apply text-sm;\n }\n\n .event-time {\n @apply text-xs;\n }\n\n .event-description {\n @apply hidden;\n }\n\n .status-badge {\n @apply text-xs py-0.5 px-2;\n }\n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .event-row {\n @apply transition-none;\n }\n }\n\n /* Load more trigger */\n .load-more-trigger {\n @apply flex justify-center items-center p-6 text-gray-600 dark:text-gray-300;\n }\n\n .loading-text {\n @apply text-sm;\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root","node","group","div","root_1","div_1","root_2","span","span_1","span_2","$$render","consequent","ul","node_1","eventIndex","eventStatus","getBrowseStatus","isUnavailable","isEventUnavailable","li","root_3","div_2","div_3","img","div_4","h3","time","p","root_4","text_5","consequent_1","div_5","span_3","root_5","text_6","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_3","formatFullDate","formatEventTime","div_6","root_7","$$value","consequent_4","classes"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as ne } from "svelte";
|
|
4
|
-
import { t as ce,
|
|
4
|
+
import { t as ce, s as H, w as me, x as ge } from "./VenueCalendar-DsXtZNAR.js";
|
|
5
5
|
import { A as r } from "./colors-BZoMuXdh.js";
|
|
6
6
|
var pe = e.from_html('<div class="confetti svelte-g1e40p"></div>'), fe = e.from_html('<div class="confetti-container svelte-g1e40p" aria-hidden="true"></div>'), ue = e.from_html('<div class="detail-row svelte-g1e40p"><dt class="detail-label svelte-g1e40p">Order ID</dt> <dd class="detail-value order-id svelte-g1e40p"> </dd></div>'), _e = e.from_html('<div class="detail-row svelte-g1e40p"><dt class="detail-label svelte-g1e40p">Event</dt> <dd class="detail-value event-name svelte-g1e40p"> </dd></div>'), he = e.from_html('<div class="detail-row svelte-g1e40p"><dt class="detail-label svelte-g1e40p">When</dt> <dd class="detail-value svelte-g1e40p"><time class="svelte-g1e40p"> </time></dd></div>'), be = e.from_html('<div class="detail-row svelte-g1e40p"><dt class="detail-label svelte-g1e40p">Where</dt> <dd class="detail-value svelte-g1e40p"> </dd></div>'), ke = e.from_html('<a class="nav-link secondary svelte-g1e40p">Back to event</a>'), ye = e.from_html('<a class="nav-link primary svelte-g1e40p">Browse more events</a>'), we = e.from_html('<nav aria-label="Next steps"><!> <!></nav>'), xe = e.from_html(`<div class="success-container svelte-g1e40p" role="main" aria-labelledby="success-title"><!> <div class="content-wrapper svelte-g1e40p"><div><div class="machine-slot svelte-g1e40p"><div class="slot-inner svelte-g1e40p"></div></div> <div><div class="ticket-content svelte-g1e40p"><div class="ticket-header svelte-g1e40p"><div class="success-badge svelte-g1e40p" aria-hidden="true"><!></div> <h1 id="success-title" class="success-title svelte-g1e40p">You're all set!</h1> <p class="success-subtitle svelte-g1e40p">Your tickets have been confirmed</p></div> <div class="ticket-divider svelte-g1e40p"><div class="divider-notch left svelte-g1e40p"></div> <div class="divider-line svelte-g1e40p"></div> <div class="divider-notch right svelte-g1e40p"></div></div> <dl aria-label="Order details"><div class="detail-row svelte-g1e40p"><dt class="detail-label svelte-g1e40p">Email</dt> <dd class="detail-value svelte-g1e40p"> </dd></div> <!> <!> <!> <!></dl> <div class="ticket-footer svelte-g1e40p"><p class="footer-text svelte-g1e40p">Check your email for your tickets</p></div></div> <div class="ticket-stub svelte-g1e40p"></div></div></div> <!></div></div>`);
|
|
7
7
|
function Le(J, f) {
|
|
@@ -188,4 +188,4 @@ function Le(J, f) {
|
|
|
188
188
|
export {
|
|
189
189
|
Le as default
|
|
190
190
|
};
|
|
191
|
-
//# sourceMappingURL=Success.legacy-
|
|
191
|
+
//# sourceMappingURL=Success.legacy-D9MZwTCk.js.map
|