@getmicdrop/venue-calendar 3.8.0 → 3.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (27) hide show
  1. package/dist/{CarouselView.legacy-C24vmwds.js → CarouselView.legacy-BED9P-az.js} +2 -2
  2. package/dist/{CarouselView.legacy-C24vmwds.js.map → CarouselView.legacy-BED9P-az.js.map} +1 -1
  3. package/dist/{Checkout.legacy-D2DwDhqL.js → Checkout.legacy-B1Ui4zZN.js} +7 -7
  4. package/dist/Checkout.legacy-B1Ui4zZN.js.map +1 -0
  5. package/dist/{CollectionView.legacy-BClzLXA6.js → CollectionView.legacy-CXv5mTUk.js} +2 -2
  6. package/dist/{CollectionView.legacy-BClzLXA6.js.map → CollectionView.legacy-CXv5mTUk.js.map} +1 -1
  7. package/dist/{FeaturedView.legacy-Dpzi5iwI.js → FeaturedView.legacy-C5yztREl.js} +2 -2
  8. package/dist/{FeaturedView.legacy-Dpzi5iwI.js.map → FeaturedView.legacy-C5yztREl.js.map} +1 -1
  9. package/dist/{GalleryView.legacy-CNQ3Jc0H.js → GalleryView.legacy-DoM4NcPc.js} +2 -2
  10. package/dist/{GalleryView.legacy-CNQ3Jc0H.js.map → GalleryView.legacy-DoM4NcPc.js.map} +1 -1
  11. package/dist/{GroupedListView.legacy-Bn2mO4c3.js → GroupedListView.legacy-Dmm_z1rM.js} +2 -2
  12. package/dist/{GroupedListView.legacy-Bn2mO4c3.js.map → GroupedListView.legacy-Dmm_z1rM.js.map} +1 -1
  13. package/dist/{SeriesPage.legacy-CbatHKi9.js → SeriesPage.legacy-Cgtr6qB_.js} +2 -2
  14. package/dist/{SeriesPage.legacy-CbatHKi9.js.map → SeriesPage.legacy-Cgtr6qB_.js.map} +1 -1
  15. package/dist/{Success.legacy-CcIvGfq0.js → Success.legacy-DHG9NwIq.js} +2 -2
  16. package/dist/{Success.legacy-CcIvGfq0.js.map → Success.legacy-DHG9NwIq.js.map} +1 -1
  17. package/dist/{VenueCalendar-D3wcXj5o.js → VenueCalendar-DIQ8H0q7.js} +8343 -8435
  18. package/dist/{VenueCalendar-D3wcXj5o.js.map → VenueCalendar-DIQ8H0q7.js.map} +1 -1
  19. package/dist/venue-calendar.es.js +1 -1
  20. package/dist/venue-calendar.iife.js +39 -38
  21. package/dist/venue-calendar.iife.js.map +1 -1
  22. package/dist/venue-calendar.umd.js +39 -38
  23. package/dist/venue-calendar.umd.js.map +1 -1
  24. package/package.json +1 -1
  25. package/dist/Checkout.legacy-D2DwDhqL.js.map +0 -1
  26. package/dist/index-DKIxsGNJ.js +0 -499
  27. package/dist/index-DKIxsGNJ.js.map +0 -1
@@ -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 _ } from "svelte";
4
- import { f as k, G as C } from "./VenueCalendar-D3wcXj5o.js";
4
+ import { f as k, G as C } from "./VenueCalendar-DIQ8H0q7.js";
5
5
  var S = e.from_html('<button class="carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2 svelte-1lcnwer" style="left: 8px" 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="w-5 h-5 text-text-secondary"><polyline points="15 18 9 12 15 6"></polyline></svg></button>'), j = e.from_html('<div class="carousel-item svelte-1lcnwer" role="listitem"><!></div>'), B = e.from_html('<button class="carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2 svelte-1lcnwer" style="right: 8px" 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="w-5 h-5 text-text-secondary"><polyline points="9 18 15 12 9 6"></polyline></svg></button>'), W = e.from_html('<section class="w-full" aria-label="Events carousel"><h2 class="sr-only svelte-1lcnwer">Upcoming events</h2> <div class="relative"><!> <div class="carousel-scroll flex gap-4 overflow-x-auto p-2 sm:p-3 lg:p-4 svelte-1lcnwer" role="list"></div> <!></div></section>');
6
6
  function G(b, i) {
7
7
  e.push(i, !0);
@@ -61,4 +61,4 @@ e.delegate(["click"]);
61
61
  export {
62
62
  G as default
63
63
  };
64
- //# sourceMappingURL=CarouselView.legacy-C24vmwds.js.map
64
+ //# sourceMappingURL=CarouselView.legacy-BED9P-az.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CarouselView.legacy-C24vmwds.js","sources":["../src/components/Calendar/CarouselView.legacy.svelte"],"sourcesContent":["<script>\r\n import { onMount } from \"svelte\";\r\n import GalleryCard from \"./GalleryCard.svelte\";\r\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n\r\n let { events = [], oneventClick } = $props();\r\n\r\n let scrollContainer;\r\n let canScrollLeft = $state(false);\r\n let canScrollRight = $state(false);\r\n let showArrows = $state(false);\r\n\r\n // Filter to today and future, sorted chronologically\r\n let futureEvents = $derived(filterTodayAndFuture(events));\r\n\r\n function updateScrollState() {\r\n if (!scrollContainer) return;\r\n const { scrollLeft, scrollWidth, clientWidth } = scrollContainer;\r\n canScrollLeft = scrollLeft > 1;\r\n canScrollRight = scrollLeft + clientWidth < scrollWidth - 1;\r\n showArrows = scrollWidth > clientWidth + 1;\r\n }\r\n\r\n function scrollByCard(direction) {\r\n if (!scrollContainer) return;\r\n // Get the width of the first card item\r\n const firstCard = scrollContainer.querySelector('.carousel-item');\r\n if (!firstCard) return;\r\n const cardWidth = firstCard.offsetWidth + 16; // card width + gap\r\n scrollContainer.scrollBy({ left: direction * cardWidth, behavior: 'smooth' });\r\n }\r\n\r\n onMount(() => {\r\n updateScrollState();\r\n // Use ResizeObserver to update on container resize\r\n const observer = new ResizeObserver(() => updateScrollState());\r\n if (scrollContainer) {\r\n observer.observe(scrollContainer);\r\n }\r\n return () => observer.disconnect();\r\n });\r\n</script>\r\n\r\n<section class=\"w-full\" aria-label=\"Events carousel\">\r\n <h2 class=\"sr-only\">Upcoming events</h2>\r\n\r\n <div class=\"relative\">\r\n <!-- Left arrow -->\r\n {#if showArrows && canScrollLeft}\r\n <button\r\n class=\"carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n style=\"left: 8px\"\r\n onclick={() => scrollByCard(-1)}\r\n aria-label=\"Scroll left\"\r\n >\r\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=\"w-5 h-5 text-text-secondary\"><polyline points=\"15 18 9 12 15 6\"></polyline></svg>\r\n </button>\r\n {/if}\r\n\r\n <!-- Scroll container -->\r\n <div\r\n class=\"carousel-scroll flex gap-4 overflow-x-auto p-2 sm:p-3 lg:p-4\"\r\n bind:this={scrollContainer}\r\n onscroll={updateScrollState}\r\n role=\"list\"\r\n >\r\n {#each futureEvents as event}\r\n <div class=\"carousel-item\" role=\"listitem\">\r\n <GalleryCard {event} {oneventClick} />\r\n </div>\r\n {/each}\r\n </div>\r\n\r\n <!-- Right arrow -->\r\n {#if showArrows && canScrollRight}\r\n <button\r\n class=\"carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n style=\"right: 8px\"\r\n onclick={() => scrollByCard(1)}\r\n aria-label=\"Scroll right\"\r\n >\r\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=\"w-5 h-5 text-text-secondary\"><polyline points=\"9 18 15 12 9 6\"></polyline></svg>\r\n </button>\r\n {/if}\r\n </div>\r\n</section>\r\n\r\n<style>\r\n .carousel-scroll {\r\n scroll-snap-type: x mandatory;\r\n -webkit-overflow-scrolling: touch;\r\n scrollbar-width: none;\r\n }\r\n\r\n .carousel-scroll::-webkit-scrollbar {\r\n display: none;\r\n }\r\n\r\n .carousel-item {\r\n scroll-snap-align: start;\r\n flex: 0 0 85%;\r\n }\r\n\r\n /* Tablet: 2 visible cards with peek */\r\n @media (min-width: 640px) {\r\n .carousel-item {\r\n flex: 0 0 calc(50% - 8px);\r\n }\r\n }\r\n\r\n /* Desktop: 3 visible cards with peek */\r\n @media (min-width: 1024px) {\r\n .carousel-item {\r\n flex: 0 0 calc(33.333% - 11px);\r\n }\r\n }\r\n\r\n /* Hide arrows on mobile -- touch scrolling is natural */\r\n @media (max-width: 639px) {\r\n .carousel-arrow {\r\n display: none;\r\n }\r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .carousel-scroll {\r\n scroll-behavior: auto;\r\n }\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border-width: 0;\r\n }\r\n</style>\r\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,QAAc;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,IAAMC,EAAA;2BAAND,GAAM,MAGUT,EAAY,EAAG,CAAA,eAH/BS,CAAM;AAAA;;AADJ,MAAArB,EAAA,IAAAK,CAAU,WAAIF,CAAa,KAAAoB,EAAAC,CAAA;AAAA;;MAY/BC,IAAGzB,EAAA,QAAA0B,GAAA,CAAA;SAAHD,GAAG,IAAA,MAAAzB,EAAA,IAMKM,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,CAAG,eAAHA,GAAG,CAAAQ,MAES/B,IAAe+B,GAAA,MAAf/B,CAAe;oBAF3BuB,GAAG,CAAA;;;UAeDS,IAAMC,EAAA;2BAAND,GAAM,MAGUtB,EAAa,CAAC,CAAA,eAH9BsB,CAAM;AAAA;;AADJ,MAAAlC,EAAA,IAAAK,CAAU,WAAID,CAAc,KAAAmB,EAAAa,CAAA;AAAA;;UA5BlChB,CAAG,WAHLF,CAAO,GAiBHlB,EAAA,MAAA,UAAAyB,GAGWjB,CAAiB,eApBhCU,CAAO;AAFA;;"}
1
+ {"version":3,"file":"CarouselView.legacy-BED9P-az.js","sources":["../src/components/Calendar/CarouselView.legacy.svelte"],"sourcesContent":["<script>\r\n import { onMount } from \"svelte\";\r\n import GalleryCard from \"./GalleryCard.svelte\";\r\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n\r\n let { events = [], oneventClick } = $props();\r\n\r\n let scrollContainer;\r\n let canScrollLeft = $state(false);\r\n let canScrollRight = $state(false);\r\n let showArrows = $state(false);\r\n\r\n // Filter to today and future, sorted chronologically\r\n let futureEvents = $derived(filterTodayAndFuture(events));\r\n\r\n function updateScrollState() {\r\n if (!scrollContainer) return;\r\n const { scrollLeft, scrollWidth, clientWidth } = scrollContainer;\r\n canScrollLeft = scrollLeft > 1;\r\n canScrollRight = scrollLeft + clientWidth < scrollWidth - 1;\r\n showArrows = scrollWidth > clientWidth + 1;\r\n }\r\n\r\n function scrollByCard(direction) {\r\n if (!scrollContainer) return;\r\n // Get the width of the first card item\r\n const firstCard = scrollContainer.querySelector('.carousel-item');\r\n if (!firstCard) return;\r\n const cardWidth = firstCard.offsetWidth + 16; // card width + gap\r\n scrollContainer.scrollBy({ left: direction * cardWidth, behavior: 'smooth' });\r\n }\r\n\r\n onMount(() => {\r\n updateScrollState();\r\n // Use ResizeObserver to update on container resize\r\n const observer = new ResizeObserver(() => updateScrollState());\r\n if (scrollContainer) {\r\n observer.observe(scrollContainer);\r\n }\r\n return () => observer.disconnect();\r\n });\r\n</script>\r\n\r\n<section class=\"w-full\" aria-label=\"Events carousel\">\r\n <h2 class=\"sr-only\">Upcoming events</h2>\r\n\r\n <div class=\"relative\">\r\n <!-- Left arrow -->\r\n {#if showArrows && canScrollLeft}\r\n <button\r\n class=\"carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n style=\"left: 8px\"\r\n onclick={() => scrollByCard(-1)}\r\n aria-label=\"Scroll left\"\r\n >\r\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=\"w-5 h-5 text-text-secondary\"><polyline points=\"15 18 9 12 15 6\"></polyline></svg>\r\n </button>\r\n {/if}\r\n\r\n <!-- Scroll container -->\r\n <div\r\n class=\"carousel-scroll flex gap-4 overflow-x-auto p-2 sm:p-3 lg:p-4\"\r\n bind:this={scrollContainer}\r\n onscroll={updateScrollState}\r\n role=\"list\"\r\n >\r\n {#each futureEvents as event}\r\n <div class=\"carousel-item\" role=\"listitem\">\r\n <GalleryCard {event} {oneventClick} />\r\n </div>\r\n {/each}\r\n </div>\r\n\r\n <!-- Right arrow -->\r\n {#if showArrows && canScrollRight}\r\n <button\r\n class=\"carousel-arrow absolute top-1/2 -translate-y-1/2 z-10 w-10 h-10 rounded-full flex items-center justify-center bg-card/90 border border-border shadow-lg cursor-pointer transition-opacity duration-200 hover:bg-card hover: focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n style=\"right: 8px\"\r\n onclick={() => scrollByCard(1)}\r\n aria-label=\"Scroll right\"\r\n >\r\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=\"w-5 h-5 text-text-secondary\"><polyline points=\"9 18 15 12 9 6\"></polyline></svg>\r\n </button>\r\n {/if}\r\n </div>\r\n</section>\r\n\r\n<style>\r\n .carousel-scroll {\r\n scroll-snap-type: x mandatory;\r\n -webkit-overflow-scrolling: touch;\r\n scrollbar-width: none;\r\n }\r\n\r\n .carousel-scroll::-webkit-scrollbar {\r\n display: none;\r\n }\r\n\r\n .carousel-item {\r\n scroll-snap-align: start;\r\n flex: 0 0 85%;\r\n }\r\n\r\n /* Tablet: 2 visible cards with peek */\r\n @media (min-width: 640px) {\r\n .carousel-item {\r\n flex: 0 0 calc(50% - 8px);\r\n }\r\n }\r\n\r\n /* Desktop: 3 visible cards with peek */\r\n @media (min-width: 1024px) {\r\n .carousel-item {\r\n flex: 0 0 calc(33.333% - 11px);\r\n }\r\n }\r\n\r\n /* Hide arrows on mobile -- touch scrolling is natural */\r\n @media (max-width: 639px) {\r\n .carousel-arrow {\r\n display: none;\r\n }\r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .carousel-scroll {\r\n scroll-behavior: auto;\r\n }\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border-width: 0;\r\n }\r\n</style>\r\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,QAAc;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,IAAMC,EAAA;2BAAND,GAAM,MAGUT,EAAY,EAAG,CAAA,eAH/BS,CAAM;AAAA;;AADJ,MAAArB,EAAA,IAAAK,CAAU,WAAIF,CAAa,KAAAoB,EAAAC,CAAA;AAAA;;MAY/BC,IAAGzB,EAAA,QAAA0B,GAAA,CAAA;SAAHD,GAAG,IAAA,MAAAzB,EAAA,IAMKM,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,CAAG,eAAHA,GAAG,CAAAQ,MAES/B,IAAe+B,GAAA,MAAf/B,CAAe;oBAF3BuB,GAAG,CAAA;;;UAeDS,IAAMC,EAAA;2BAAND,GAAM,MAGUtB,EAAa,CAAC,CAAA,eAH9BsB,CAAM;AAAA;;AADJ,MAAAlC,EAAA,IAAAK,CAAU,WAAID,CAAc,KAAAmB,EAAAa,CAAA;AAAA;;UA5BlChB,CAAG,WAHLF,CAAO,GAiBHlB,EAAA,MAAA,UAAAyB,GAGWjB,CAAiB,eApBhCU,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 fe, C as rt, d as et, e as Jt, t as Zt, h as $t, l as er, j as ft, k as tr, m as ht, n as rr, o as ar, p as sr, O as ir, q as lr, W as tt, B as yt, v as nr, r as or, E as dr, R as cr } from "./VenueCalendar-D3wcXj5o.js";
3
+ import { I as fe, C as rt, d as et, e as Jt, t as Zt, h as $t, l as er, j as ft, k as tr, m as ht, n as rr, o as ar, p as sr, O as ir, q as lr, W as tt, B as yt, v as nr, r as or, E as dr, R as cr } from "./VenueCalendar-DIQ8H0q7.js";
4
4
  import { onDestroy as ur, onMount as gr } from "svelte";
5
5
  import "svelte/internal/flags/legacy";
6
6
  import { slide as mr } from "svelte/transition";
@@ -317,17 +317,17 @@ function wr(oe, a) {
317
317
  });
318
318
  let B = e.prop(a, "elements", 15), m = e.prop(a, "labels", 19, () => ({}));
319
319
  const G = et ? Jt() : "stripe";
320
- let n = e.state(null), I = null, Y = !1;
320
+ let n = e.state(null), I = null, Y = e.state(!1);
321
321
  function de() {
322
- !et || !a.stripe || !a.paymentIntent || !e.get(n) || Y || (B(a.stripe.elements({
322
+ !et || !a.stripe || !a.paymentIntent || !e.get(n) || e.get(Y) || (B(a.stripe.elements({
323
323
  clientSecret: a.paymentIntent,
324
324
  appearance: { theme: G }
325
- })), I = B().create("payment"), I.mount(e.get(n)), Y = !0);
325
+ })), I = B().create("payment"), I.mount(e.get(n)), e.set(Y, !0));
326
326
  }
327
327
  e.user_effect(() => {
328
- a.stripe && a.paymentIntent && e.get(n) && p() === "card" && (Y || de());
328
+ a.stripe && a.paymentIntent && e.get(n) && p() === "card" && (e.get(Y) || de());
329
329
  }), ur(() => {
330
- I && (I.destroy(), I = null), Y = !1;
330
+ I && (I.destroy(), I = null), e.set(Y, !1);
331
331
  });
332
332
  function T(c) {
333
333
  p(c);
@@ -1178,4 +1178,4 @@ e.delegate(["click"]);
1178
1178
  export {
1179
1179
  jr as default
1180
1180
  };
1181
- //# sourceMappingURL=Checkout.legacy-D2DwDhqL.js.map
1181
+ //# sourceMappingURL=Checkout.legacy-B1Ui4zZN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Checkout.legacy-B1Ui4zZN.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>\r\n import { Input, Checkbox } from '@getmicdrop/svelte-components';\r\n\r\n let {\r\n firstName = $bindable(''),\r\n lastName = $bindable(''),\r\n email = $bindable(''),\r\n phoneNumber = $bindable(''),\r\n keepMeUpdated = $bindable(false),\r\n termsAgreed = $bindable(false),\r\n ticketsInfo = [],\r\n ticketType = 0,\r\n updateTicketDetails,\r\n updateTicketField,\r\n firstNameError = $bindable(''),\r\n lastNameError = $bindable(''),\r\n emailError = $bindable(''),\r\n phoneError = $bindable(''),\r\n termsError = $bindable(''),\r\n firstNameTouched = $bindable(false),\r\n lastNameTouched = $bindable(false),\r\n emailTouched = $bindable(false),\r\n phoneTouched = $bindable(false),\r\n labels = {},\r\n } = $props();\r\n</script>\r\n\r\n<form aria-label={labels.checkoutFormLabel || \"Checkout form\"}>\r\n <section class=\"p-4 md:p-5\" aria-labelledby=\"billing-section-title\">\r\n <div class=\"space-y-4\">\r\n <h2 id=\"billing-section-title\" class=\"section-title text-lg font-semibold text-text-primary mb-4\">\r\n {labels.billingInformation || 'Billing information'}\r\n </h2>\r\n <div class=\"grid grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.firstName || \"First name\"}\r\n size=\"full\"\r\n type=\"text\"\r\n required\r\n autocomplete=\"given-name\"\r\n bind:value={firstName}\r\n bind:displayErrorText={firstNameError}\r\n bind:touched={firstNameTouched}\r\n />\r\n <Input\r\n label={labels.lastName || \"Last name\"}\r\n size=\"full\"\r\n type=\"text\"\r\n required\r\n autocomplete=\"family-name\"\r\n bind:value={lastName}\r\n bind:displayErrorText={lastNameError}\r\n bind:touched={lastNameTouched}\r\n />\r\n <div class=\"col-span-2\">\r\n <Input\r\n label={labels.emailAddress || \"Email address\"}\r\n size=\"full\"\r\n type=\"email\"\r\n required\r\n autocomplete=\"email\"\r\n bind:value={email}\r\n bind:displayErrorText={emailError}\r\n bind:touched={emailTouched}\r\n />\r\n </div>\r\n <div class=\"col-span-2\">\r\n <Input\r\n label={labels.phoneNumber || \"Phone number\"}\r\n size=\"full\"\r\n type=\"phoneNumber\"\r\n autocomplete=\"tel\"\r\n bind:value={phoneNumber}\r\n bind:displayErrorText={phoneError}\r\n bind:touched={phoneTouched}\r\n />\r\n </div>\r\n </div>\r\n <Checkbox bind:checked={keepMeUpdated} class=\"mailing-list-checkbox\" aria-describedby=\"mailing-list-description\">\r\n {labels.keepMeUpdated || 'Keep me updated on more events and news'}\r\n </Checkbox>\r\n <span id=\"mailing-list-description\" class=\"sr-only\">{labels.subscribeToUpdates || 'Subscribe to event updates and news'}</span>\r\n </div>\r\n </section>\r\n\r\n <!-- Ticket-wise Attendee Details (Only if ticketType === 1) -->\r\n {#if ticketType === 1}\r\n {#each ticketsInfo as ticket, index (ticket.ticketId + '-' + index)}\r\n <section class=\"p-4 md:p-5\" aria-labelledby=\"ticket-section-{index}\">\r\n <div class=\"grid grid-row-3 gap-3\">\r\n <h2 id=\"ticket-section-{index}\" class=\"text-base font-medium leading-6 text-text-primary mb-4\">\r\n {(labels.ticketN || 'Ticket {index} - {name}').replace('{index}', String(index + 1)).replace('{name}', ticket.ticketName)}\r\n </h2>\r\n <Checkbox\r\n checked={ticket.sameAsPersonal}\r\n onchange={e => updateTicketDetails(index, e.detail.checked)}\r\n class=\"same-as-personal-checkbox\"\r\n >\r\n {labels.sameAsPersonalDetails || 'Same as personal details'}\r\n </Checkbox>\r\n <div class=\"grid grid-cols-2 gap-4\">\r\n <Input\r\n label={labels.firstName || \"First name\"}\r\n size=\"full\"\r\n type=\"text\"\r\n value={ticket.firstName}\r\n oninput={e => updateTicketField(index, 'firstName', e.target.value)}\r\n displayErrorText={ticket.touched && ticket.errors.firstName ? ticket.errors.firstName : ''}\r\n touched={ticket.touched}\r\n />\r\n <Input\r\n label={labels.lastName || \"Last name\"}\r\n size=\"full\"\r\n type=\"text\"\r\n value={ticket.lastName}\r\n oninput={e => updateTicketField(index, 'lastName', e.target.value)}\r\n displayErrorText={ticket.touched && ticket.errors.lastName ? ticket.errors.lastName : ''}\r\n touched={ticket.touched}\r\n />\r\n <div class=\"col-span-2\">\r\n <Input\r\n label={labels.emailAddress || \"Email address\"}\r\n size=\"full\"\r\n type=\"email\"\r\n value={ticket.email}\r\n oninput={e => updateTicketField(index, 'email', e.target.value)}\r\n displayErrorText={ticket.touched && ticket.errors.email ? ticket.errors.email : ''}\r\n touched={ticket.touched}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n {/each}\r\n {/if}\r\n</form>\r\n\r\n<style>\r\n /* Checkbox label styling for shared component */\r\n :global(.mailing-list-checkbox .checkbox__label),\r\n :global(.same-as-personal-checkbox .checkbox__label) {\r\n color: hsl(var(--text-tertiary)); /* gray-500 */\r\n font-weight: 400; /* normal */\r\n font-size: 0.875rem; /* text-sm */\r\n line-height: 1.25rem;\r\n }\r\n :global(.dark .mailing-list-checkbox .checkbox__label),\r\n :global(.dark .same-as-personal-checkbox .checkbox__label) {\r\n color: hsl(var(--text-head)); /* gray-400 */\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border: 0;\r\n }\r\n</style>\r\n","<script>\r\n import { Checkbox } from '@getmicdrop/svelte-components';\r\n\r\n let {\r\n InputValue = $bindable(false),\r\n terms = [],\r\n showScrollbar = false,\r\n scrollContainer,\r\n handleScroll = () => {},\r\n checkScrollable = () => {},\r\n termsError = '',\r\n labels = {},\r\n } = $props();\r\n</script>\r\n\r\n<section class=\"space-y-4\" aria-labelledby=\"terms-section-title\">\r\n <h2 id=\"terms-section-title\" class=\"heading-md text-color-primary\">\r\n {labels.termsAndConditions || 'Terms and conditions'}\r\n </h2>\r\n\r\n <Checkbox\r\n bind:checked={InputValue}\r\n class=\"terms-checkbox\"\r\n aria-required=\"true\"\r\n aria-describedby={termsError ? 'terms-error' : undefined}\r\n >\r\n {labels.agreeToTerms || 'I agree to the'} <a href=\"https://get-micdrop.com/tos\" target=\"_blank\" rel=\"noopener noreferrer\" class=\"text-brand-primary underline hover:opacity-80\">{labels.termsAndConditionsLink || 'terms and conditions'}<span class=\"sr-only\"> (opens in new tab)</span></a>\r\n </Checkbox>\r\n\r\n {#if termsError}\r\n <p id=\"terms-error\" class=\"body-sm mt-1 text-error\" role=\"alert\" aria-live=\"assertive\">{termsError}</p>\r\n {/if}\r\n</section>\r\n\r\n<style>\r\n :global(.terms-checkbox .checkbox__label) {\r\n color: hsl(var(--text-secondary)); /* gray-600 */\r\n }\r\n :global(.dark .terms-checkbox .checkbox__label) {\r\n color: hsl(var(--text-head)); /* gray-300 */\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border: 0;\r\n }\r\n</style>\r\n","<script>\n import { onMount, onDestroy } from 'svelte';\n import { slide } from 'svelte/transition';\n import { browser } from '$app/environment';\n import { getInitialStripeTheme } 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 const stripeTheme = browser ? getInitialStripeTheme() : 'stripe';\n\n // Mount Stripe Payment Element directly via Stripe.js API instead of\n // svelte-stripe, which has a Svelte 5 compatibility bug: its Elements\n // component compiles onMount as a user_effect that re-runs on any prop\n // change (e.g. parent re-renders from timer), calling stripe.elements()\n // repeatedly and causing \"Can only create one Element of type payment\".\n let paymentMountDiv = $state(null);\n let paymentElement = null;\n let mounted = $state(false);\n\n function mountPaymentElement() {\n if (!browser || !stripe || !paymentIntent || !paymentMountDiv || mounted)\n return;\n\n // Create elements group and payment element\n elements = stripe.elements({\n clientSecret: paymentIntent,\n appearance: { theme: stripeTheme },\n });\n\n paymentElement = elements.create('payment');\n paymentElement.mount(paymentMountDiv);\n mounted = true;\n }\n\n // Watch for when all conditions are met to mount\n $effect(() => {\n if (\n stripe &&\n paymentIntent &&\n paymentMountDiv &&\n selectedPayment === 'card'\n ) {\n // Use untrack-like pattern: only run once\n if (!mounted) {\n mountPaymentElement();\n }\n }\n });\n\n onDestroy(() => {\n if (paymentElement) {\n paymentElement.destroy();\n paymentElement = null;\n }\n mounted = false;\n });\n\n function selectPayment(method) {\n selectedPayment = method;\n }\n</script>\n\n<section class=\"pay-with-section pt-2\" aria-labelledby=\"payment-section-title\">\n <h2\n id=\"payment-section-title\"\n class=\"section-title text-lg font-semibold text-text-primary mb-4\"\n >\n {labels.payWith || 'Pay with'}\n </h2>\n\n <div\n class=\"payment-options flex flex-col gap-3\"\n role=\"radiogroup\"\n aria-label={labels.paymentMethodSelection || 'Payment method selection'}\n >\n <!-- Credit or Debit Card -->\n <div class=\"payment-option-wrapper flex flex-col\">\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=\"flex items-center gap-3\">\n <svg\n class=\"payment-icon w-6 h-6 shrink-0 text-text-primary\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n aria-hidden=\"true\"\n >\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\"\n >{labels.creditOrDebitCard || 'Credit or debit card'}</span\n >\n <img\n src=\"/stripe-logo.png\"\n alt=\"\"\n class=\"stripe-logo h-9 w-auto ml-auto opacity-60\"\n aria-hidden=\"true\"\n />\n </div>\n </button>\n\n {#if selectedPayment === 'card'}\n <div\n class=\"card-form\"\n transition:slide={{ duration: 200 }}\n role=\"region\"\n aria-label={labels.cardPaymentForm || 'Card payment form'}\n >\n {#if browser && stripe && paymentIntent}\n <div bind:this={paymentMountDiv}></div>\n {:else}\n <p\n class=\"text-sm text-muted-foreground py-2\"\n role=\"status\"\n aria-live=\"polite\"\n >\n Loading secure payment form...\n </p>\n {/if}\n\n {#if error}\n <p\n class=\"error-text text-sm text-accent-danger mt-2\"\n role=\"alert\"\n aria-live=\"assertive\"\n >\n {error}\n </p>\n {/if}\n </div>\n {/if}\n </div>\n\n <!-- Apple Pay -->\n <button\n type=\"button\"\n class=\"payment-option standalone rounded-lg\"\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=\"flex items-center gap-3\">\n <svg\n class=\"apple-icon w-6 h-6 shrink-0 text-text-primary\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n 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 />\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 rounded-lg\"\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=\"flex items-center gap-3\">\n <svg\n class=\"google-icon w-6 h-6 shrink-0\"\n viewBox=\"0 0 24 24\"\n aria-hidden=\"true\"\n >\n <path\n fill={GOOGLE_PAY.blue}\n 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 />\n <path\n fill={GOOGLE_PAY.green}\n 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 />\n <path\n fill={GOOGLE_PAY.yellow}\n 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 />\n <path\n fill={GOOGLE_PAY.red}\n 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 />\n </svg>\n <span class=\"payment-label\">{labels.googlePay || 'Google Pay'}</span>\n </div>\n </button>\n </div>\n</section>\n\n<style>\n .payment-option {\n display: flex;\n flex-direction: column;\n width: 100%;\n padding: 1rem;\n border-radius: 0.5rem;\n cursor: pointer;\n text-align: left;\n background-color: hsl(var(--bg-primary));\n border: 1px solid hsl(var(--border));\n transition: all 0.15s ease;\n }\n\n .payment-option.selected {\n z-index: 10;\n position: relative;\n border-color: hsl(var(--brand-primary, 224 76% 48%));\n border-radius: 8px 8px 0 0;\n\n &:where(.dark, .dark *) {\n background-color: hsl(var(--bg-primary));\n }\n }\n\n .payment-option:not(.selected):hover {\n background-color: hsl(var(--bg-secondary));\n\n &:where(.dark, .dark *) {\n background-color: hsl(var(--bg-primary));\n }\n }\n\n .payment-label {\n font-size: 1rem;\n line-height: 1.5rem;\n font-weight: 400;\n color: hsl(var(--text-primary));\n font-family:\n 'Inter',\n -apple-system,\n BlinkMacSystemFont,\n sans-serif;\n }\n\n /* Card form styling */\n .card-form {\n padding: 1rem;\n background-color: hsl(var(--bg-primary));\n border: 1px solid hsl(var(--brand-primary, 224 76% 48%));\n border-top: 0;\n border-radius: 0 0 8px 8px;\n }\n</style>\n","<script>\r\n import Cookies from 'js-cookie';\r\n import { onMount } from 'svelte';\r\n import { goto } from '$app/navigation';\r\n import { Close, WarningFilled, ErrorFilled, Renew } from 'carbon-icons-svelte';\r\n import { transformEvent, loadCheckoutStateFromCookies, getVenueDetails, createPaymentIntent, validatePaymentIntent } from '$lib/utils/utils.js';\r\n import { completeGiftCardPayment } from '$lib/utils/api.js';\r\n import OrderSummarySkeleton from \"../Events/Tickets/OrderSummarySkeleton.svelte\";\r\n import PersonalDetails from \"../Events/Checkout/PersonalDetails.svelte\";\r\n import TermsAndConditions from \"../Events/Checkout/TermsAndConditions.svelte\";\r\n import PaymentSection from \"../Events/Checkout/PaymentSection.svelte\";\r\n import GiftCardInput from \"../Events/Checkout/GiftCardInput.svelte\";\r\n import { OrderSummary, Button } from '@getmicdrop/svelte-components';\r\n import { loadStripe } from '@stripe/stripe-js';\r\n import { ACCENT } from '$lib/constants/colors.ts';\r\n\r\n let {\r\n data,\r\n availableTickets = [],\r\n value = '',\r\n venueId = '',\r\n organizationId = '',\r\n onNavigateToSuccess,\r\n initialError = undefined,\r\n labels = {},\r\n } = $props();\r\n\r\n const { id, orgSlug, slug, event: rawEvent } = data || {};\r\n let event = $derived(\r\n rawEvent\r\n ? transformEvent(rawEvent)\r\n : data && (data.id || id)\r\n ? {\r\n id: data.id || id,\r\n eventID: data.id || id,\r\n venueID: data.venueID ?? data.venueId ?? null,\r\n venueId: data.venueId ?? data.venueID ?? null,\r\n eventTicketingType: 0,\r\n ticketType: 0,\r\n availableTickets: [],\r\n }\r\n : null\r\n );\r\n \r\n let venueFeesReady = $state(false);\r\n\r\n let quantities = $state({});\r\n let promocode = $state('');\r\n let promoDiscountAmount = $state(0);\r\n let tickets = $state([]);\r\n\r\n let ticketsInfo = $state([]);\r\n\r\n let firstNameTouched = $state(false);\r\n let lastNameTouched = $state(false);\r\n let emailTouched = $state(false);\r\n let confirmEmailTouched = $state(false);\r\n\r\n let InputValue = $state(false);\r\n let selectedPayment = $state('card');\r\n let firstName = $state('');\r\n let lastName = $state('');\r\n let email = $state('');\r\n let confirmEmail = $state('');\r\n let phoneNumber = $state('');\r\n let keepMeUpdated = $state(false);\r\n let scrollContainer = $state();\r\n let showScrollbar = $state(false);\r\n let heading = $derived(' ' + (labels.checkout || 'Checkout'));\r\n let timerDuration = $state(15 * 60);\r\n let Timing = $state(`${labels.timeLeft || 'Time left'} ${formatTime(15 * 60)}`);\r\n let feePerTicket = 4.48;\r\n\r\n // Session extension popup state\r\n let showExtendSessionPopup = $state(false);\r\n let sessionExtensionOffered = false;\r\n const SESSION_WARNING_THRESHOLD = 2 * 60; // 2 minutes\r\n const SESSION_EXTENSION_AMOUNT = 5 * 60; // 5 minutes extension\r\n \r\n let inputValue = value;\r\n \r\n const terms = [\r\n 'All ticket sales are final and non-refundable unless the event is canceled or rescheduled by the organizer.',\r\n 'Tickets are valid only for the event, date, time, and venue specified. Unauthorized resale of tickets is prohibited.',\r\n 'The event organizer reserves the right to refuse entry or remove any individual from the venue without refund.',\r\n 'Attendees must comply with all venue rules and regulations, including any age restrictions or dress codes.',\r\n 'Photography and recording policies may vary; please check the event details for specific guidelines.',\r\n ];\r\n \r\n let error = $state(null);\r\n\r\n let isMobile = $state(false);\r\n let containerRef = $state();\r\n let stickyRef = $state();\r\n let isSticky = $state(false);\r\n let stickyTop = $state(0);\r\n let sidebarLeft = $state(0);\r\n let cartId = $state('');\r\n let isScrollable = $state(false);\r\n\r\n // Gift card state\r\n let giftCardApplied = $state(null); // { code, giftCardAmount, giftCardBalance, paymentType, stripeAmount, requiresStripe }\r\n \r\n let elements = $state();\r\n\r\n let stripe = $state(null);\r\n let calculatedTax = $state(0);\r\n let calculatedServiceFee = $state(0);\r\n let calculatedTotal = $state(0);\r\n let processing = $state(false);\r\n let paymentIntent = $state('');\r\n let isCompleteOrder = $state(false);\r\n let isInCompleteOrder = $state(false);\r\n\r\n async function initializeStripePayment() {\r\n if (!cartId) {\r\n console.error('Missing cartId!');\r\n return;\r\n }\r\n\r\n const filteredQuantities = Object.fromEntries(\r\n Object.entries(quantities).filter(([_, val]) => val > 0)\r\n );\r\n\r\n try {\r\n const paymentData = await createPaymentIntent(cartId, filteredQuantities);\r\n\r\n if (paymentData && paymentData.client_secret) {\r\n stripe = await loadStripe(\r\n 'pk_test_51RJLygPlXDynGkUGKI0vaVT0DXCDdf2wLp3BVNGtdulddY8jG5qBlDUuQuArbTW1dPh19wfZngGeABvH35XIjjMz00NwnD7ydB'\r\n );\r\n \r\n if (stripe) {\r\n paymentIntent = paymentData.client_secret;\r\n \r\n elements = stripe.elements({\r\n appearance: {\r\n theme: 'stripe',\r\n variables: {\r\n colorDanger: ACCENT.red[600],\r\n fontSizeBase: '16px',\r\n },\r\n },\r\n clientSecret: paymentData.client_secret,\r\n });\r\n\r\n calculatedTax = (paymentData.tax_amount_exclusive || 0) / 100;\r\n calculatedServiceFee = (paymentData.service_fee || 0) / 100;\r\n calculatedTotal = (paymentData.amount_total || 0) / 100;\r\n }\r\n } else {\r\n stripeError = labels.failedToCreatePaymentIntent || 'Failed to create payment intent. Please try again.';\r\n }\r\n } catch (err) {\r\n console.error('Failed to initialize Stripe payment:', err);\r\n stripeError = err.message || labels.failedToInitPayment || 'Failed to initialize payment. Please check your connection and try again.';\r\n }\r\n }\r\n\r\n let venueServiceCharge = $state({\r\n serviceFeeCents: 0,\r\n serviceFeePercentage: 0,\r\n serviceFeeChargeType: 'both',\r\n maxServiceFeeCents: 0,\r\n taxPercentage: 0,\r\n });\r\n\r\n // Gift card event handlers\r\n function handleGiftCardApplied(appliedCard) {\r\n giftCardApplied = appliedCard;\r\n // If gift card covers full amount, no need for Stripe\r\n if (!appliedCard.requiresStripe) {\r\n // Clear Stripe elements if they exist\r\n elements = null;\r\n stripe = null;\r\n }\r\n }\r\n\r\n function handleGiftCardRemoved() {\r\n giftCardApplied = null;\r\n // Re-initialize Stripe payment if needed\r\n if (cartId && Object.keys(quantities).length > 0) {\r\n initializeStripePayment();\r\n }\r\n }\r\n\r\n function formatTime(seconds) {\r\n const minutes = Math.floor(seconds / 60);\r\n const remainingSeconds = seconds % 60;\r\n return `${String(minutes).padStart(2, '0')}:${String(remainingSeconds).padStart(2, '0')}`;\r\n }\r\n\r\n function extendSession() {\r\n timerDuration += SESSION_EXTENSION_AMOUNT;\r\n Timing = `${labels.timeLeft || 'Time left'} ${formatTime(timerDuration)}`;\r\n showExtendSessionPopup = false;\r\n // Allow extending again if time runs low again\r\n sessionExtensionOffered = false;\r\n }\r\n\r\n function dismissExtendPopup() {\r\n showExtendSessionPopup = false;\r\n // Don't offer again for this session\r\n sessionExtensionOffered = true;\r\n }\r\n\r\n function checkScrollable() {\r\n if (scrollContainer) {\r\n isScrollable =\r\n scrollContainer.scrollHeight > scrollContainer.clientHeight;\r\n showScrollbar = isScrollable;\r\n }\r\n }\r\n \r\n let firstNameError = $state('');\r\n let lastNameError = $state('');\r\n let emailError = $state('');\r\n let confirmEmailError = $state('');\r\n let termsError = $state('');\r\n let attendeeError = $state('');\r\n let stripeError = $state('');\r\n\r\n // Enhanced error state for better UX\r\n let paymentErrorType = $state(''); // 'card_declined', 'network', 'validation', 'general'\r\n let paymentErrorDetails = $state({\r\n title: '',\r\n message: '',\r\n suggestion: '',\r\n retryable: true\r\n });\r\n\r\n // Map Stripe error codes to user-friendly messages\r\n function getPaymentErrorDetails(error) {\r\n const errorCode = error?.code || error?.decline_code || '';\r\n const errorType = error?.type || '';\r\n const errorMessage = error?.message || '';\r\n\r\n // Card declined errors\r\n if (errorCode === 'card_declined' || errorType === 'card_error') {\r\n const declineCode = error?.decline_code || '';\r\n\r\n if (declineCode === 'insufficient_funds') {\r\n return {\r\n type: 'card_declined',\r\n title: 'Insufficient funds',\r\n message: 'Your card has insufficient funds to complete this purchase.',\r\n suggestion: 'Please try a different payment method or contact your bank.',\r\n retryable: true\r\n };\r\n }\r\n\r\n if (declineCode === 'lost_card' || declineCode === 'stolen_card') {\r\n return {\r\n type: 'card_declined',\r\n title: 'Card cannot be used',\r\n message: 'This card cannot be used for this transaction.',\r\n suggestion: 'Please use a different payment method.',\r\n retryable: true\r\n };\r\n }\r\n\r\n if (declineCode === 'expired_card') {\r\n return {\r\n type: 'card_declined',\r\n title: 'Card expired',\r\n message: 'Your card has expired.',\r\n suggestion: 'Please use a different card or update your card details.',\r\n retryable: true\r\n };\r\n }\r\n\r\n return {\r\n type: 'card_declined',\r\n title: 'Card declined',\r\n message: 'Your card was declined by your bank.',\r\n suggestion: 'Please try a different card or contact your bank for more information.',\r\n retryable: true\r\n };\r\n }\r\n\r\n // Network/connection errors\r\n if (errorType === 'api_connection_error' || errorMessage.includes('network') || errorMessage.includes('connection')) {\r\n return {\r\n type: 'network',\r\n title: 'Connection error',\r\n message: 'We couldn\\'t connect to the payment server.',\r\n suggestion: 'Please check your internet connection and try again.',\r\n retryable: true\r\n };\r\n }\r\n\r\n // Rate limiting\r\n if (errorCode === 'rate_limit') {\r\n return {\r\n type: 'rate_limit',\r\n title: 'Too many attempts',\r\n message: 'Too many payment attempts. Please wait a moment.',\r\n suggestion: 'Wait 30 seconds before trying again.',\r\n retryable: true\r\n };\r\n }\r\n\r\n // Invalid card details\r\n if (errorCode === 'incorrect_number' || errorCode === 'invalid_number') {\r\n return {\r\n type: 'validation',\r\n title: 'Invalid card number',\r\n message: 'The card number you entered is invalid.',\r\n suggestion: 'Please check your card number and try again.',\r\n retryable: true\r\n };\r\n }\r\n\r\n if (errorCode === 'incorrect_cvc' || errorCode === 'invalid_cvc') {\r\n return {\r\n type: 'validation',\r\n title: 'Invalid security code',\r\n message: 'The security code (CVC) is incorrect.',\r\n suggestion: 'Please check the 3-digit code on the back of your card.',\r\n retryable: true\r\n };\r\n }\r\n\r\n if (errorCode === 'invalid_expiry_month' || errorCode === 'invalid_expiry_year') {\r\n return {\r\n type: 'validation',\r\n title: 'Invalid expiration date',\r\n message: 'The expiration date is invalid.',\r\n suggestion: 'Please check your card\\'s expiration date.',\r\n retryable: true\r\n };\r\n }\r\n\r\n // Default error\r\n return {\r\n type: 'general',\r\n title: 'Payment failed',\r\n message: errorMessage || 'Something went wrong with your payment.',\r\n suggestion: 'Please try again or use a different payment method.',\r\n retryable: true\r\n };\r\n }\r\n\r\n function clearPaymentError() {\r\n stripeError = '';\r\n paymentErrorType = '';\r\n paymentErrorDetails = {\r\n title: '',\r\n message: '',\r\n suggestion: '',\r\n retryable: true\r\n };\r\n }\r\n\r\n function setPaymentError(error) {\r\n const details = getPaymentErrorDetails(error);\r\n paymentErrorType = details.type;\r\n paymentErrorDetails = details;\r\n stripeError = details.message;\r\n }\r\n \r\n function validateBeforeSubmit() {\r\n let hasError = false;\r\n \r\n firstNameTouched =\r\n lastNameTouched =\r\n emailTouched =\r\n confirmEmailTouched =\r\n true;\r\n firstNameError =\r\n lastNameError =\r\n emailError =\r\n confirmEmailError =\r\n termsError =\r\n attendeeError =\r\n '';\r\n \r\n if (!firstName.trim()) {\r\n firstNameError = 'First name is required.';\r\n hasError = true;\r\n }\r\n \r\n if (!lastName.trim()) {\r\n lastNameError = 'Last name is required.';\r\n hasError = true;\r\n }\r\n \r\n if (!email.trim()) {\r\n emailError = 'Email is required.';\r\n hasError = true;\r\n }\r\n \r\n if (!confirmEmail.trim()) {\r\n confirmEmailError = 'Confirm email is required.';\r\n hasError = true;\r\n } else if (\r\n email.trim() &&\r\n confirmEmail.trim() &&\r\n email.trim() !== confirmEmail.trim()\r\n ) {\r\n confirmEmailError = 'Email addresses do not match.';\r\n hasError = true;\r\n }\r\n \r\n if (!isAgreed) {\r\n termsError = 'You must agree to the terms and conditions above.';\r\n hasError = true;\r\n }\r\n \r\n if (event.ticketType === 1) {\r\n let ticketErrorCount = 0;\r\n \r\n ticketsInfo = ticketsInfo.map((t, index) => {\r\n const errors = {\r\n firstName: '',\r\n lastName: '',\r\n email: '',\r\n };\r\n \r\n if (!t.sameAsPersonal) {\r\n if (!t.firstName.trim()) {\r\n errors.firstName = 'First name is required.';\r\n ticketErrorCount++;\r\n }\r\n if (!t.lastName.trim()) {\r\n errors.lastName = 'Last name is required.';\r\n ticketErrorCount++;\r\n }\r\n if (!t.email.trim()) {\r\n errors.email = 'Email is required.';\r\n ticketErrorCount++;\r\n }\r\n }\r\n \r\n return {\r\n ...t,\r\n errors,\r\n qtouched: true,\r\n };\r\n });\r\n \r\n if (ticketErrorCount > 0) {\r\n attendeeError = 'Please fill in all attendee details.';\r\n hasError = true;\r\n }\r\n }\r\n \r\n return !hasError;\r\n }\r\n \r\n async function executePurchase(elementsParam) {\r\n if (processing) return;\r\n\r\n // Clear any previous errors before attempting\r\n clearPaymentError();\r\n\r\n const elementsToUse = elementsParam || elements;\r\n\r\n if (!elementsToUse) {\r\n setPaymentError({\r\n type: 'validation',\r\n message: labels.paymentFormNotReady || 'Payment form is not ready. Please wait a moment and try again.'\r\n });\r\n return;\r\n }\r\n\r\n if (!stripe) {\r\n setPaymentError({\r\n type: 'general',\r\n message: labels.paymentSystemNotInitialized || 'Payment system is not initialized. Please refresh the page.'\r\n });\r\n return;\r\n }\r\n\r\n processing = true;\r\n\r\n const isValid = validateBeforeSubmit();\r\n\r\n if (!isValid) {\r\n processing = false;\r\n return;\r\n }\r\n\r\n try {\r\n const { error: validationError } = await elementsToUse.submit();\r\n if (validationError) {\r\n setPaymentError(validationError);\r\n processing = false;\r\n return;\r\n }\r\n\r\n const result = await stripe.confirmPayment({\r\n elements: elementsToUse,\r\n redirect: 'if_required',\r\n });\r\n\r\n if (result.error) {\r\n setPaymentError(result.error);\r\n processing = false;\r\n return;\r\n }\r\n\r\n const paymentPayload = {\r\n id: cartId,\r\n paymentIntentId: result.paymentIntent.id,\r\n tickets: quantities,\r\n firstName,\r\n lastName,\r\n email: confirmEmail,\r\n phoneNumber: phoneNumber || null,\r\n paymentMethod: 'credit-card',\r\n mailingList: keepMeUpdated,\r\n saleType: 'online',\r\n };\r\n\r\n const response = await validatePaymentIntent(cartId, paymentPayload);\r\n\r\n if (response?.status === 'Payment succeeded') {\r\n isCompleteOrder = true;\r\n\r\n try {\r\n const successData = {\r\n orderId: cartId,\r\n eventId: event?.id || event?.eventID || null,\r\n event: event || null,\r\n venueId: venueId || event?.venueId || null,\r\n organizationId: organizationId || event?.organizationId || null\r\n };\r\n dispatch('success', successData);\r\n\r\n if (onNavigateToSuccess) {\r\n onNavigateToSuccess(successData);\r\n }\r\n } catch(e) {\r\n console.warn('Failed to dispatch success event', e);\r\n }\r\n } else if (\r\n response?.status === 'Payment amount does not match the total price'\r\n ) {\r\n isInCompleteOrder = true;\r\n setPaymentError({\r\n type: 'general',\r\n message: labels.paymentAmountMismatch || 'Payment amount mismatch. Please refresh and try again.'\r\n });\r\n }\r\n } catch (err) {\r\n console.error('Payment execution error:', err);\r\n setPaymentError(err);\r\n } finally {\r\n processing = false;\r\n }\r\n }\r\n\r\n async function executeGiftCardOnlyPurchase() {\r\n if (processing) return;\r\n\r\n processing = true;\r\n clearPaymentError();\r\n\r\n const isValid = validateBeforeSubmit();\r\n if (!isValid) {\r\n processing = false;\r\n return;\r\n }\r\n\r\n try {\r\n const result = await completeGiftCardPayment(cartId, {\r\n firstName,\r\n lastName,\r\n email: confirmEmail,\r\n phoneNumber: phoneNumber || null,\r\n mailingList: keepMeUpdated,\r\n });\r\n\r\n if (result?.success) {\r\n isCompleteOrder = true;\r\n\r\n const successData = {\r\n orderId: result.orderId || cartId,\r\n eventId: event?.id || event?.eventID || null,\r\n event: event || null,\r\n venueId: venueId || event?.venueId || null,\r\n organizationId: organizationId || event?.organizationId || null,\r\n paymentType: 'gift_card_only',\r\n };\r\n\r\n if (onNavigateToSuccess) {\r\n onNavigateToSuccess(successData);\r\n }\r\n } else {\r\n setPaymentError({\r\n type: 'general',\r\n message: result?.error || labels.failedToCompleteOrder || 'Failed to complete order. Please try again.',\r\n });\r\n }\r\n } catch (err) {\r\n console.error('Gift card payment error:', err);\r\n setPaymentError(err);\r\n } finally {\r\n processing = false;\r\n }\r\n }\r\n\r\n function goBack() {\r\n const params = new URLSearchParams(window.location.search);\r\n params.set(\"subroute\", \"cart\");\r\n const url = `/?${params.toString()}`;\r\n goto(url, { noScroll: false });\r\n }\r\n \r\n function updateScreenSize() {\r\n isMobile = window.innerWidth < 640;\r\n }\r\n \r\n function handleScroll() {\r\n if (isMobile) {\r\n isSticky = false;\r\n return;\r\n }\r\n \r\n const rect = stickyRef?.getBoundingClientRect();\r\n if (!rect) return;\r\n \r\n isSticky = rect.top <= 20;\r\n \r\n if (isSticky && containerRef) {\r\n const containerBounding = containerRef.getBoundingClientRect();\r\n sidebarLeft =\r\n containerBounding.left + containerRef.clientWidth - 340 - 40;\r\n }\r\n }\r\n \r\n function updateTicketField(index, field, value) {\r\n ticketsInfo = ticketsInfo.map((ticket, i) => {\r\n if (i === index) {\r\n if (field === 'touched') {\r\n return { ...ticket, touched: true };\r\n }\r\n const updatedTicket = {\r\n ...ticket,\r\n [field]: value,\r\n sameAsPersonal: false,\r\n errors: {\r\n ...ticket.errors,\r\n [field]: value.trim()\r\n ? ''\r\n : `${field[0].toUpperCase() + field.slice(1)} is required.`,\r\n },\r\n };\r\n \r\n return updatedTicket;\r\n }\r\n return ticket;\r\n });\r\n }\r\n \r\n function updateTicketDetails(index, checked) {\r\n ticketsInfo = ticketsInfo.map((ticket, i) => {\r\n if (i === index) {\r\n return {\r\n ...ticket,\r\n sameAsPersonal: checked,\r\n firstName: checked ? firstName : ticket.firstName,\r\n lastName: checked ? lastName : ticket.lastName,\r\n email: checked ? email : ticket.email,\r\n };\r\n }\r\n return ticket;\r\n });\r\n }\r\n \r\n function syncSameAsPersonalAttendees() {\r\n ticketsInfo = ticketsInfo.map(t =>\r\n t.sameAsPersonal ? { ...t, firstName, lastName, email } : t\r\n );\r\n }\r\n\r\n let normalizedEmail = $derived(email?.trim().toLowerCase());\r\n let normalizedConfirmEmail = $derived(confirmEmail?.trim().toLowerCase());\r\n\r\n let emailMatchError = $derived(\r\n normalizedEmail !== normalizedConfirmEmail && confirmEmail !== ''\r\n );\r\n\r\n let isAgreed = $derived(InputValue);\r\n\r\n $effect(() => {\r\n email = email?.trim();\r\n confirmEmail = confirmEmail?.trim();\r\n });\r\n\r\n $effect(() => {\r\n inputValue = value;\r\n });\r\n\r\n $effect(() => {\r\n processing = false;\r\n });\r\n\r\n $effect(() => {\r\n paymentIntent = '';\r\n });\r\n\r\n $effect(() => {\r\n if (tickets?.length > 0) {\r\n if (event) {\r\n event.availableTickets = tickets;\r\n }\r\n }\r\n });\r\n\r\n $effect(() => {\r\n isCompleteOrder = false;\r\n isInCompleteOrder = false;\r\n });\r\n \r\n $effect(() => {\r\n if (Object.keys(quantities).length > 0 && tickets.length > 0) {\r\n const info = [];\r\n let idx = 0;\r\n\r\n for (const [ticketId, quantity] of Object.entries(quantities)) {\r\n const ticketMeta = tickets.find(t => String(t.ID) === ticketId);\r\n for (let i = 0; i < quantity; i++) {\r\n info.push({\r\n name: `Ticket ${idx + 1}`,\r\n sameAsPersonal: false,\r\n firstName: '',\r\n lastName: '',\r\n email: '',\r\n ticketId: ticketMeta?.ID || null,\r\n ticketName: ticketMeta?.name || '',\r\n touched: false,\r\n errors: {\r\n firstName: '',\r\n lastName: '',\r\n email: '',\r\n },\r\n });\r\n idx++;\r\n }\r\n }\r\n\r\n ticketsInfo = info;\r\n }\r\n });\r\n\r\n $effect(() => {\r\n if (firstName || lastName || email) {\r\n syncSameAsPersonalAttendees();\r\n }\r\n });\r\n \r\n onMount(async () => {\r\n updateScreenSize();\r\n cartId = Cookies.get('checkout-cartid');\r\n \r\n try {\r\n const checkoutState = loadCheckoutStateFromCookies(event?.eventID || event?.id);\r\n quantities = checkoutState.quantities || {};\r\n promocode = checkoutState.promocode || '';\r\n promoDiscountAmount = checkoutState.promoDiscountAmount || 0;\r\n tickets = checkoutState.tickets || [];\r\n } catch (err) {\r\n console.error('Error loading checkout state:', err);\r\n quantities = {};\r\n tickets = [];\r\n }\r\n \r\n if (tickets.length > 0) {\r\n if (event) event.availableTickets = tickets;\r\n availableTickets = tickets;\r\n }\r\n \r\n if (cartId && Object.keys(quantities).length > 0) {\r\n initializeStripePayment();\r\n }\r\n \r\n const interval = setInterval(() => {\r\n if (timerDuration > 0) {\r\n timerDuration -= 1;\r\n Timing = `${labels.timeLeft || 'Time left'} ${formatTime(timerDuration)}`;\r\n\r\n // Show extension popup when time is running low\r\n if (timerDuration <= SESSION_WARNING_THRESHOLD && timerDuration > 0 && !sessionExtensionOffered && !showExtendSessionPopup) {\r\n showExtendSessionPopup = true;\r\n }\r\n } else {\r\n clearInterval(interval);\r\n goto('/', { noScroll: false });\r\n }\r\n }, 1000);\r\n \r\n try {\r\n const venueData = await getVenueDetails(event?.venueID || event?.venueId);\r\n venueServiceCharge = {\r\n serviceFeeCents: venueData?.serviceFeeCents ?? 0,\r\n serviceFeePercentage: venueData?.serviceFeePercentage ?? 0,\r\n serviceFeeChargeType: venueData?.serviceFeeChargeType ?? 'both',\r\n maxServiceFeeCents: venueData?.maxServiceFeeCents ?? 0,\r\n taxPercentage: venueData?.taxPercentage ?? 0,\r\n };\r\n venueFeesReady = true;\r\n } catch (err) {\r\n console.error('Error fetching venue data:', err);\r\n venueServiceCharge = {\r\n serviceFeeCents: 0,\r\n serviceFeePercentage: 0,\r\n serviceFeeChargeType: 'both',\r\n maxServiceFeeCents: 0,\r\n taxPercentage: 0,\r\n };\r\n venueFeesReady = true;\r\n }\r\n \r\n // Apply initial error state for showcase/preview rendering\r\n if (initialError) {\r\n setPaymentError(\r\n typeof initialError === 'object'\r\n ? initialError\r\n : { code: 'card_declined', message: 'Your card was declined. Please try a different payment method.' }\r\n );\r\n }\r\n\r\n window.addEventListener('resize', updateScreenSize);\r\n window.addEventListener('scroll', handleScroll);\r\n\r\n stickyTop = stickyRef?.getBoundingClientRect().top || 0;\r\n\r\n return () => {\r\n clearInterval(interval);\r\n window.removeEventListener('resize', updateScreenSize);\r\n window.removeEventListener('scroll', handleScroll);\r\n };\r\n });\r\n </script>\r\n \r\n <div class=\"px-5 md:px-10 pt-12 bg-card\" bind:this={containerRef}>\r\n <div class=\"w-full flex md:gap-5 flex-wrap\" bind:this={stickyRef}>\r\n <div class=\"flex-1 pb-16 md:pb-0\">\r\n <div class=\"checkout-card rounded-lg md:shadow md:border\">\r\n <header class=\"checkout-header flex justify-between py-5 md:p-5 border-b\" role=\"banner\">\r\n <div class=\"gap-1\">\r\n <h1 class=\"checkout-title text-lg font-semibold leading-relaxed\">\r\n {heading}\r\n </h1>\r\n <p class=\"timer-text pt-1 text-xs font-normal leading-normal\" role=\"timer\" aria-live=\"polite\" aria-atomic=\"true\">\r\n {Timing}\r\n </p>\r\n </div>\r\n <button\r\n onclick={goBack}\r\n class=\"close-btn p-2 rounded-lg transition-colors\"\r\n aria-label={labels.goBackToTicketSelection || \"Go back to cart\"}\r\n >\r\n <Close size={24} class=\"close-icon\" aria-hidden=\"true\" />\r\n </button>\r\n </header>\r\n\r\n <!-- Payment Error Banner -->\r\n {#if paymentErrorType}\r\n <div class=\"error-banner p-4 md:p-5 border-b\" role=\"alert\" aria-live=\"assertive\">\r\n <div class=\"error-banner-content flex items-start gap-3\">\r\n <div class=\"error-icon-wrapper shrink-0\" aria-hidden=\"true\">\r\n {#if paymentErrorType === 'card_declined'}\r\n <ErrorFilled size={24} class=\"error-icon\" />\r\n {:else if paymentErrorType === 'network'}\r\n <WarningFilled size={24} class=\"warning-icon\" />\r\n {:else}\r\n <WarningFilled size={24} class=\"warning-icon\" />\r\n {/if}\r\n </div>\r\n <div class=\"error-details flex-1\">\r\n <h2 class=\"error-title text-sm font-semibold mb-1\">\r\n {paymentErrorDetails.title}\r\n </h2>\r\n <p class=\"error-message text-sm mb-2\">\r\n {paymentErrorDetails.message}\r\n </p>\r\n {#if paymentErrorDetails.suggestion}\r\n <p class=\"error-suggestion text-xs\">\r\n {paymentErrorDetails.suggestion}\r\n </p>\r\n {/if}\r\n </div>\r\n <button\r\n onclick={clearPaymentError}\r\n class=\"error-dismiss p-1 rounded transition-colors\"\r\n aria-label={labels.close || \"Dismiss payment error\"}\r\n >\r\n <Close size={18} aria-hidden=\"true\" />\r\n </button>\r\n </div>\r\n {#if paymentErrorDetails.retryable}\r\n <div class=\"error-actions mt-3 flex gap-2\">\r\n <button\r\n onclick={() => { clearPaymentError(); initializeStripePayment(); }}\r\n class=\"retry-btn flex items-center gap-2 px-3 py-1.5 rounded-lg text-sm font-medium transition-colors\"\r\n aria-label={labels.networkErrorRetry || \"Retry payment\"}\r\n >\r\n <Renew size={16} aria-hidden=\"true\" />\r\n {labels.networkErrorRetry || 'Try again'}\r\n </button>\r\n </div>\r\n {/if}\r\n </div>\r\n {/if}\r\n\r\n <PersonalDetails\r\n bind:firstName\r\n bind:lastName\r\n bind:email\r\n bind:confirmEmail\r\n bind:phoneNumber\r\n bind:keepMeUpdated\r\n bind:ticketsInfo\r\n {emailMatchError}\r\n {updateTicketDetails}\r\n ticketType={event?.eventTicketingType ?? event?.ticketType ?? 0}\r\n {firstNameError}\r\n {lastNameError}\r\n {emailError}\r\n {confirmEmailError}\r\n {attendeeError}\r\n {updateTicketField}\r\n bind:firstNameTouched\r\n bind:lastNameTouched\r\n bind:emailTouched\r\n bind:confirmEmailTouched\r\n />\r\n \r\n <div class=\"py-5 md:p-5\">\r\n <TermsAndConditions\r\n bind:InputValue\r\n {terms}\r\n bind:showScrollbar\r\n bind:scrollContainer\r\n {handleScroll}\r\n {checkScrollable}\r\n {termsError}\r\n />\r\n </div>\r\n\r\n <div class=\"py-5 md:p-5\">\r\n <GiftCardInput\r\n {cartId}\r\n onApplied={handleGiftCardApplied}\r\n onRemoved={handleGiftCardRemoved}\r\n disabled={processing}\r\n />\r\n </div>\r\n\r\n {#if !giftCardApplied || giftCardApplied.requiresStripe}\r\n <div class=\"py-5 md:p-5\">\r\n <PaymentSection\r\n bind:selectedPayment\r\n {stripe}\r\n {paymentIntent}\r\n {processing}\r\n {executePurchase}\r\n bind:elements\r\n error={stripeError}\r\n />\r\n </div>\r\n {:else}\r\n <!-- Zero-payment: Gift card covers full amount -->\r\n <div class=\"py-5 md:p-5\">\r\n <div class=\"gift-card-complete-section p-4 bg-status-success-bg rounded-lg border border-status-success-border\">\r\n <div class=\"flex items-center gap-3 mb-3\">\r\n <div class=\"w-10 h-10 rounded-full bg-status-success-bg flex items-center justify-center\">\r\n <svg class=\"w-5 h-5 text-accent-success\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\r\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M5 13l4 4L19 7\"></path>\r\n </svg>\r\n </div>\r\n <div>\r\n <p class=\"text-sm font-semibold text-status-success-text\">{labels.giftCardNoPaymentRequired || 'No payment required'}</p>\r\n <p class=\"text-xs text-accent-success\">{labels.fullyCoveredByGiftCard || 'Your gift card covers the full order'}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n {/if}\r\n </div>\r\n </div>\r\n \r\n {#if isSticky}\r\n <!-- svelte-ignore element_invalid_self_closing_tag -->\r\n <div class=\"w-full sm:w-80 flex flex-col\" />\r\n {/if}\r\n\r\n <div\r\n class=\"w-full sm:w-80 sm:flex flex-col transition-all {isSticky ? 'fixed top-5' : 'static'}\"\r\n class:is-sticky={isSticky}\r\n style:left={isSticky ? `${sidebarLeft}px` : 'auto'}\r\n >\r\n {#if !venueFeesReady}\r\n <OrderSummarySkeleton />\r\n {:else}\r\n <OrderSummary\r\n btnText={giftCardApplied?.paymentType === 'gift_card_only' ? (labels.giftCardCompleteOrder || 'Complete Order') : (labels.placeOrder || 'Place order')}\r\n eventTickets={availableTickets}\r\n {quantities}\r\n {venueServiceCharge}\r\n {isAgreed}\r\n {feePerTicket}\r\n promoApplied={!!promocode}\r\n promoDiscount={promoDiscountAmount}\r\n loading={processing}\r\n executePurchase={giftCardApplied?.paymentType === 'gift_card_only' ? executeGiftCardOnlyPurchase : executePurchase}\r\n {elements}\r\n {giftCardApplied}\r\n />\r\n {/if}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Session Extension Popup -->\r\n {#if showExtendSessionPopup}\r\n <div\r\n class=\"session-popup-overlay\"\r\n role=\"dialog\"\r\n aria-modal=\"true\"\r\n aria-labelledby=\"extend-session-title\"\r\n aria-describedby=\"extend-session-description\"\r\n data-testid=\"session-extension-popup\"\r\n >\r\n <div class=\"session-popup\">\r\n <div class=\"session-popup-icon\" aria-hidden=\"true\">\r\n <WarningFilled size={32} class=\"warning-icon-large\" />\r\n </div>\r\n <h2 id=\"extend-session-title\" class=\"session-popup-title\">\r\n {labels.sessionExpiringSoon || 'Session Expiring Soon'}\r\n </h2>\r\n <p id=\"extend-session-description\" class=\"session-popup-message\">\r\n {labels.sessionExpireMessage || 'Your session will expire in'} <span class=\"time-remaining\">{formatTime(timerDuration)}</span>.\r\n {labels.sessionExtendQuestion || 'Would you like to extend your time to complete your purchase?'}\r\n </p>\r\n <div class=\"session-popup-actions\" data-testid=\"session-popup-actions\">\r\n <Button\r\n variant=\"default\"\r\n onclick={extendSession}\r\n data-testid=\"extend-session-btn\"\r\n aria-label={labels.sessionExtendAria || \"Extend session by 5 minutes\"}\r\n fullWidth\r\n >\r\n {labels.sessionExtendButton || 'Extend Time (+5 min)'}\r\n </Button>\r\n <Button\r\n variant=\"alternative\"\r\n onclick={dismissExtendPopup}\r\n data-testid=\"dismiss-session-popup-btn\"\r\n aria-label={labels.sessionDismissAria || \"Dismiss and continue without extending\"}\r\n fullWidth\r\n >\r\n {labels.sessionNoThanks || 'No Thanks'}\r\n </Button>\r\n </div>\r\n </div>\r\n </div>\r\n {/if}\r\n\r\n<style>\r\n /* Theme-responsive checkout styles */\r\n .checkout-card {\r\n background-color: hsl(var(--bg-primary));\r\n border-color: hsl(var(--border));\r\n }\r\n\r\n .checkout-header {\r\n border-color: hsl(var(--border));\r\n }\r\n\r\n .checkout-title {\r\n color: hsl(var(--text-primary));\r\n }\r\n\r\n .timer-text {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .close-btn:hover {\r\n background-color: hsl(var(--bg-tertiary));\r\n }\r\n\r\n .close-icon {\r\n color: hsl(var(--text-secondary));\r\n }\r\n\r\n /* Error Banner Styles */\r\n .error-banner {\r\n display: flex;\r\n align-items: center;\r\n gap: 0.5rem;\r\n padding: 0.75rem;\r\n border-radius: 0.5rem;\r\n background-color: hsl(var(--accent-danger) / 0.05);\r\n color: hsl(var(--accent-danger));\r\n border-color: hsl(var(--accent-danger) / 0.2);\r\n }\r\n\r\n .error-icon-wrapper {\r\n margin-top: 0.125rem;\r\n }\r\n\r\n .error-icon {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .warning-icon {\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .error-title {\r\n font-size: 1.125rem;\r\n line-height: 1.75rem;\r\n font-weight: 600;\r\n color: hsl(var(--accent-danger));\r\n margin-bottom: 0.5rem;\r\n }\r\n\r\n .error-message {\r\n font-size: 0.875rem;\r\n line-height: 1.625;\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .error-suggestion {\r\n color: hsl(var(--accent-danger));\r\n font-style: italic;\r\n }\r\n\r\n .error-dismiss {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .error-dismiss:hover {\r\n background-color: hsl(var(--accent-danger) / 0.1);\r\n }\r\n\r\n .retry-btn {\r\n color: hsl(var(--bg-primary));\r\n background-color: hsl(var(--brand-primary, 224 76% 48%));\r\n }\r\n\r\n .retry-btn:hover {\r\n filter: brightness(0.9);\r\n }\r\n\r\n /* Gift card complete section */\r\n .gift-card-complete-section {\r\n text-align: center;\r\n }\r\n\r\n /* Network error uses amber/warning colors */\r\n .error-banner:has(.warning-icon) {\r\n background-color: hsl(var(--accent-warning) / 0.08);\r\n border-color: hsl(var(--accent-warning) / 0.3);\r\n }\r\n\r\n .error-banner:has(.warning-icon) .error-title {\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .error-banner:has(.warning-icon) .error-message {\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .error-banner:has(.warning-icon) .error-suggestion {\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .error-banner:has(.warning-icon) .error-dismiss {\r\n color: hsl(var(--accent-warning));\r\n }\r\n\r\n .error-banner:has(.warning-icon) .error-dismiss:hover {\r\n background-color: hsl(var(--accent-warning) / 0.15);\r\n }\r\n\r\n /* Session Extension Popup Styles */\r\n .session-popup-overlay {\r\n position: fixed;\r\n inset: 0;\r\n background-color: rgb(0 0 0 / 0.5);\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n z-index: 50;\r\n padding: 1rem;\r\n animation: fadeIn 0.2s ease-out;\r\n \r\n &:where(.dark, .dark *) {\r\n background-color: rgb(0 0 0 / 0.7);\r\n }\r\n }\r\n\r\n .session-popup {\r\n background-color: hsl(var(--bg-primary));\r\n border-radius: 0.75rem;\r\n box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);\r\n padding: 1.5rem;\r\n max-width: 24rem;\r\n width: 100%;\r\n text-align: center;\r\n animation: slideUp 0.3s ease-out;\r\n }\r\n\r\n .session-popup-icon {\r\n margin-bottom: 1rem;\r\n }\r\n\r\n .warning-icon-large {\r\n color: hsl(var(--accent-warning));\r\n margin-left: auto;\r\n margin-right: auto;\r\n }\r\n\r\n .session-popup-title {\r\n font-size: 1.125rem;\r\n line-height: 1.75rem;\r\n font-weight: 600;\r\n color: hsl(var(--text-primary));\r\n margin-bottom: 0.5rem;\r\n }\r\n\r\n .session-popup-message {\r\n font-size: 0.875rem;\r\n line-height: 1.625;\r\n color: hsl(var(--text-secondary));\r\n margin-bottom: 1.5rem;\r\n }\r\n\r\n .time-remaining {\r\n font-weight: 600;\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .session-popup-actions {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.75rem;\r\n }\r\n\r\n @keyframes fadeIn {\r\n from {\r\n opacity: 0;\r\n }\r\n to {\r\n opacity: 1;\r\n }\r\n }\r\n\r\n @keyframes slideUp {\r\n from {\r\n opacity: 0;\r\n transform: translateY(20px) scale(0.95);\r\n }\r\n to {\r\n opacity: 1;\r\n transform: translateY(0) scale(1);\r\n }\r\n }\r\n</style>\r\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","stripeTheme","browser","getInitialStripeTheme","paymentMountDiv","paymentElement","mounted","mountPaymentElement","onDestroy","selectPayment","method","button","root_1","alternate","p_1","root_4","text_2","consequent_1","slide","consequent_2","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","err","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","onMount","Cookies","checkoutState","loadCheckoutStateFromCookies","interval","venueData","getVenueDetails","fragment","header","h1","Close","div_7","ErrorFilled","WarningFilled","div_8","p_2","root_5","text_4","div_9","root_6","Renew","consequent_3","text_3","consequent_4","$0","PersonalDetails","div_10","TermsAndConditions","div_11","GiftCardInput","div_12","root_7","PaymentSection","node_11","div_13","root_8","div_14","div_15","div_16","p_3","p_4","consequent_5","alternate_1","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,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, onDestroy as de } from "svelte";
4
- import { f as ce, g as ve, a as ge, i as me, P as ue, b as le, c as oe, S as fe, x as ie, A as pe, D as _e, F as he, G as xe } from "./VenueCalendar-D3wcXj5o.js";
4
+ import { f as ce, g as ve, a as ge, i as me, P as ue, b as le, c as oe, S as fe, x as ie, A as pe, D as _e, F as he, G as xe } from "./VenueCalendar-DIQ8H0q7.js";
5
5
  import "svelte/internal/flags/legacy";
6
6
  import "svelte/transition";
7
7
  import "svelte/easing";
@@ -372,4 +372,4 @@ e.delegate(["click"]);
372
372
  export {
373
373
  Ne as default
374
374
  };
375
- //# sourceMappingURL=CollectionView.legacy-BClzLXA6.js.map
375
+ //# sourceMappingURL=CollectionView.legacy-CXv5mTUk.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CollectionView.legacy-BClzLXA6.js","sources":["../src/components/Calendar/GroupedListView.svelte","../src/components/Views/CollectionView.legacy.svelte"],"sourcesContent":["<script>\r\n import { onMount, onDestroy } from \"svelte\";\r\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\r\n import { getDateParts, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\r\n import { getBrowseStatus, isEventUnavailable, filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\r\n\r\n let {\r\n events = [],\r\n initialCount = 10,\r\n loadMoreCount = 10,\r\n showDateColumn = true,\r\n filterFutureOnly = true,\r\n oneventClick,\r\n labels = {},\r\n } = $props();\r\n\r\n let displayedCount = $state(initialCount);\r\n let loadMoreTrigger = $state();\r\n let observer;\r\n\r\n // Filter to today and future (if enabled), then group by date\r\n let filteredEvents = $derived(filterFutureOnly ? filterTodayAndFuture(events) : events);\r\n let groupedEvents = $derived(groupEventsByDate(filteredEvents.slice(0, displayedCount)));\r\n let hasMore = $derived(displayedCount < filteredEvents.length);\r\n\r\n function loadMore() {\r\n displayedCount += loadMoreCount;\r\n }\r\n\r\n onMount(() => {\r\n observer = new IntersectionObserver(\r\n (entries) => {\r\n if (entries[0].isIntersecting && hasMore) {\r\n loadMore();\r\n }\r\n },\r\n { rootMargin: '100px' }\r\n );\r\n\r\n if (loadMoreTrigger) {\r\n observer.observe(loadMoreTrigger);\r\n }\r\n });\r\n\r\n onDestroy(() => {\r\n if (observer) {\r\n observer.disconnect();\r\n }\r\n });\r\n\r\n // Re-observe when trigger element changes\r\n $effect(() => {\r\n if (observer && loadMoreTrigger) {\r\n observer.disconnect();\r\n observer.observe(loadMoreTrigger);\r\n }\r\n });\r\n\r\n function groupEventsByDate(eventList) {\r\n const groups = {};\r\n\r\n for (const event of eventList) {\r\n const dateKey = event.date; // YYYY-MM-DD format\r\n if (!groups[dateKey]) {\r\n groups[dateKey] = [];\r\n }\r\n groups[dateKey].push(event);\r\n }\r\n\r\n // Convert to array sorted by date\r\n return Object.entries(groups)\r\n .sort(([a], [b]) => new Date(a) - new Date(b))\r\n .map(([date, events]) => ({\r\n date,\r\n events,\r\n formattedDate: formatGroupDate(events),\r\n }));\r\n }\r\n\r\n function formatGroupDate(events) {\r\n // Use the first event in the group to get timezone-aware date parts\r\n const firstEvent = events[0];\r\n if (!firstEvent?.startDateTime) return { month: '', day: '', weekday: '' };\r\n const parts = getDateParts(firstEvent.startDateTime, firstEvent.timeZone);\r\n return {\r\n month: parts.month.toUpperCase(),\r\n day: String(parts.date).padStart(2, '0'),\r\n weekday: parts.day.toUpperCase(),\r\n };\r\n }\r\n\r\n function handleEventClick(event) {\r\n oneventClick?.(event);\r\n }\r\n\r\n function handleKeydown(e, event) {\r\n if (e.key === 'Enter' || e.key === ' ') {\r\n e.preventDefault();\r\n handleEventClick(event);\r\n }\r\n }\r\n</script>\r\n\r\n<section class=\"flex flex-col gap-0\" class:no-date-column={!showDateColumn} aria-label={labels.eventListings || 'Event listings'}>\r\n <h2 class=\"sr-only\">{labels.eventListGroupedByDate || 'Event list grouped by date'}</h2>\r\n {#each groupedEvents as group}\r\n <div class=\"date-group flex border-b border-border last:border-b-0\" role=\"group\" aria-label=\"Events on {group.events[0]?.startDateTime ? formatFullDate(group.events[0].startDateTime, group.events[0].timeZone) : group.date}\">\r\n <!-- Date Column -->\r\n {#if showDateColumn}\r\n <div class=\"w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-bg-secondary border-r border-border max-sm:w-12 max-sm:min-w-12 max-sm:py-2.5 max-sm:px-1.5\" aria-hidden=\"true\">\r\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.month}</span>\r\n <span class=\"text-2xl max-sm:text-lg font-bold text-text-primary leading-tight\">{group.formattedDate.day}</span>\r\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.weekday}</span>\r\n </div>\r\n {/if}\r\n\r\n <!-- Events Column -->\r\n <ul class=\"events-column flex-1 flex flex-col list-none p-0 m-0\">\r\n {#each group.events as event, eventIndex}\r\n {@const eventStatus = getBrowseStatus(event)}\r\n {@const isUnavailable = isEventUnavailable(eventStatus)}\r\n <li class=\"list-none\">\r\n <div\r\n class=\"event-row flex gap-4 max-sm:gap-2.5 p-5 max-sm:p-3 cursor-pointer transition-colors duration-150 bg-card border-b border-border/50 last:border-b-0 hover:bg-bg-secondary focus:outline-2 focus:outline-brand-primary focus:-outline-offset-2 focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:-outline-offset-2\"\r\n class:row-unavailable={isUnavailable}\r\n onclick={() => handleEventClick(event)}\r\n onkeydown={(e) => handleKeydown(e, event)}\r\n tabindex=\"0\"\r\n role=\"button\"\r\n aria-label={`${event.name} on ${event.startDateTime ? formatFullDate(event.startDateTime, event.timeZone) : group.date} at ${event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}, ${eventStatus?.text || event.status || labels.statusOnSale || 'On Sale'}. ${labels.pressEnterToView || 'Press Enter to view details'}`}\r\n >\r\n <!-- Event Image -->\r\n <div class=\"w-36 h-24 min-w-36 max-sm:w-20 max-sm:h-16 max-sm:min-w-20 rounded-lg overflow-hidden bg-bg-secondary flex items-center justify-center\" aria-hidden=\"true\">\r\n <img\r\n src={event.image || PLACEHOLDER_IMAGE}\r\n alt=\"\"\r\n class=\"w-full h-full object-contain\"\r\n loading=\"lazy\"\r\n />\r\n </div>\r\n\r\n <!-- Event Details (visually shown but also in aria-label, so hide from SR) -->\r\n <div class=\"flex-1 flex flex-col gap-1.5 min-w-0\" aria-hidden=\"true\">\r\n <h3 class=\"text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug\">{event.name}</h3>\r\n <time class=\"text-sm max-sm:text-xs font-medium text-text-secondary\" datetime={event.startDateTime || group.date}>{event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}</time>\r\n {#if event.description}\r\n <p class=\"event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden\">{event.description}</p>\r\n {/if}\r\n </div>\r\n\r\n <!-- Status / Scarcity Badge -->\r\n <div class=\"flex items-start pt-0.5\" aria-hidden=\"true\">\r\n {#if eventStatus}\r\n <span class=\"status-badge status-{eventStatus.type}\">{eventStatus.text}</span>\r\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\r\n <ScarcityBadge\r\n remaining={event.ticketsRemaining ?? 0}\r\n total={event.ticketsTotal ?? 0}\r\n context=\"browse\"\r\n {labels}\r\n />\r\n {/if}\r\n </div>\r\n </div>\r\n </li>\r\n {/each}\r\n </ul>\r\n </div>\r\n {/each}\r\n\r\n <!-- Infinite scroll trigger -->\r\n {#if hasMore}\r\n <div bind:this={loadMoreTrigger} class=\"flex justify-center items-center p-6 text-text-secondary\" role=\"status\" aria-live=\"polite\">\r\n <span class=\"text-sm\">{labels.loadingMoreEvents || 'Loading more events...'}</span>\r\n </div>\r\n {/if}\r\n</section>\r\n\r\n<style>\r\n /* When no date column, remove left border styling */\r\n .no-date-column .date-group {\r\n border-bottom: 0;\r\n }\r\n\r\n .no-date-column .events-column {\r\n border-left: 0;\r\n }\r\n\r\n .event-description {\r\n display: -webkit-box;\r\n -webkit-box-orient: vertical;\r\n overflow: hidden;\r\n }\r\n\r\n /* Unavailable row dimming */\r\n .row-unavailable {\r\n opacity: 0.6;\r\n }\r\n\r\n .row-unavailable img {\r\n filter: grayscale(0.5);\r\n }\r\n\r\n /* Status badges -- distinct visual treatments matching gallery cards */\r\n .status-badge {\r\n display: inline-flex;\r\n align-items: center;\r\n font-size: 0.75rem;\r\n line-height: 1rem;\r\n font-weight: 700;\r\n padding: 0.25rem 0.625rem;\r\n border-radius: 0.25rem;\r\n white-space: nowrap;\r\n letter-spacing: 0.02em;\r\n }\r\n\r\n .status-cancelled {\r\n background-color: hsl(var(--accent-danger) / 0.1);\r\n color: hsl(var(--accent-danger));\r\n text-decoration: line-through;\r\n text-decoration-thickness: 1.5px;\r\n\r\n \r\n }\r\n\r\n .status-past {\r\n background-color: hsl(var(--bg-tertiary));\r\n color: hsl(var(--text-tertiary));\r\n\r\n \r\n }\r\n\r\n .status-sold_out {\r\n background-color: hsl(var(--accent-danger) / 0.1);\r\n color: hsl(var(--accent-danger));\r\n text-transform: uppercase;\r\n letter-spacing: 0.05em;\r\n font-size: 0.65rem;\r\n\r\n \r\n }\r\n\r\n .status-sales_ended {\r\n background-color: hsl(var(--bg-tertiary));\r\n color: hsl(var(--text-tertiary));\r\n border: 1px solid hsl(var(--stroke-primary));\r\n\r\n \r\n }\r\n\r\n .status-coming_soon {\r\n background-color: hsl(var(--brand-primary) / 0.15);\r\n color: hsl(var(--brand-primary));\r\n\r\n \r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .event-row {\r\n transition: none;\r\n }\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border-width: 0;\r\n }\r\n</style>\r\n","<script>\r\n import { onMount, onDestroy } from 'svelte';\r\n import { fetchPublicCollection } from '../../lib/api/events.ts';\r\n import { getImageUrl } from '$lib/utils/utils.js';\r\n import { EmptyState } from '@getmicdrop/svelte-components';\r\n import GalleryCard from '../Calendar/GalleryCard.svelte';\r\n import GroupedListView from '../Calendar/GroupedListView.svelte';\r\n import SkeletonLoader from '../SkeletonLoader/SkeletonLoader.svelte';\r\n\r\n let {\r\n collectionId,\r\n organizationId = '',\r\n onNavigateToEvent,\r\n password: initialPassword = undefined,\r\n displayMode: initialDisplayMode = 'gallery',\r\n showViewSwitcher = true,\r\n labels = {},\r\n } = $props();\r\n\r\n let collection = $state(null);\r\n let isLoading = $state(true);\r\n let error = $state(null);\r\n let isMounted = $state(false);\r\n let passwordRequired = $state(false);\r\n let passwordInput = $state('');\r\n let passwordError = $state(false);\r\n let activeDisplayMode = $state(initialDisplayMode);\r\n\r\n // Transform collection events into the shape GalleryCard expects\r\n function toGalleryEvent(event) {\r\n return {\r\n id: event.id,\r\n name: event.title || event.name || '',\r\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\r\n image: event.image ? getImageUrl(event.image) : '',\r\n timeline: event.startDateTime ? formatTimeline(event.startDateTime) : '',\r\n status: event.status || 'on_sale',\r\n slug: event.slug || '',\r\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\r\n ticketsTotal: event.ticketsTotal ?? event.capacity,\r\n };\r\n }\r\n\r\n // Transform collection events into the shape GroupedListView expects\r\n function toListEvent(event) {\r\n return {\r\n id: event.id,\r\n name: event.title || event.name || '',\r\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\r\n startDateTime: event.startDateTime || '',\r\n image: event.image ? getImageUrl(event.image) : '',\r\n status: event.status || 'on_sale',\r\n slug: event.slug || '',\r\n description: event.description || '',\r\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\r\n ticketsTotal: event.ticketsTotal ?? event.capacity,\r\n };\r\n }\r\n\r\n function formatTimeline(iso) {\r\n if (!iso) return '';\r\n const date = new Date(iso);\r\n return date.toLocaleTimeString('en-US', {\r\n hour: 'numeric',\r\n minute: '2-digit',\r\n hour12: true,\r\n });\r\n }\r\n\r\n let displayEvents = $derived(\r\n collection ? sortByStartTime(collection.events || []) : []\r\n );\r\n\r\n let galleryEvents = $derived(displayEvents.map(toGalleryEvent));\r\n let listEvents = $derived(displayEvents.map(toListEvent));\r\n\r\n // Only show view switcher when there are 2+ events\r\n let canShowSwitcher = $derived(showViewSwitcher && displayEvents.length >= 2);\r\n\r\n function sortByStartTime(events) {\r\n return [...events].sort((a, b) => {\r\n if (!a.startDateTime && !b.startDateTime) return 0;\r\n if (!a.startDateTime) return 1;\r\n if (!b.startDateTime) return -1;\r\n return new Date(a.startDateTime).getTime() - new Date(b.startDateTime).getTime();\r\n });\r\n }\r\n\r\n function handleEventClick(galleryEvent) {\r\n if (onNavigateToEvent) {\r\n const eventData = galleryEvent.detail || galleryEvent;\r\n onNavigateToEvent(eventData.id, eventData.slug || '');\r\n }\r\n }\r\n\r\n async function loadCollection(pwd) {\r\n if (!isMounted) return;\r\n if (!collectionId) {\r\n error = labels.noCollectionIdProvided || 'No collection ID provided';\r\n isLoading = false;\r\n return;\r\n }\r\n\r\n isLoading = true;\r\n error = null;\r\n passwordError = false;\r\n\r\n try {\r\n const data = await fetchPublicCollection(collectionId, pwd);\r\n if (!isMounted) return;\r\n\r\n if (data) {\r\n // Check if the response indicates password is required\r\n if (data.passwordRequired || data.error?.code === 'PASSWORD_REQUIRED') {\r\n passwordRequired = true;\r\n isLoading = false;\r\n return;\r\n }\r\n collection = data;\r\n passwordRequired = false;\r\n } else {\r\n // A null response after providing a password likely means wrong password\r\n if (pwd) {\r\n passwordRequired = true;\r\n passwordError = true;\r\n isLoading = false;\r\n return;\r\n }\r\n error = labels.failedToLoadCollection || 'Failed to load collection';\r\n }\r\n } catch (err) {\r\n if (isMounted) {\r\n // Check for password-related error responses\r\n const msg = err.message || '';\r\n if (msg.includes('401') || msg.includes('403') || msg.includes('password')) {\r\n passwordRequired = true;\r\n } else {\r\n error = msg || 'Failed to load collection';\r\n }\r\n }\r\n } finally {\r\n if (isMounted) {\r\n isLoading = false;\r\n }\r\n }\r\n }\r\n\r\n function handlePasswordSubmit(e) {\r\n e.preventDefault();\r\n if (!passwordInput.trim()) return;\r\n loadCollection(passwordInput);\r\n }\r\n\r\n onMount(async () => {\r\n isMounted = true;\r\n await loadCollection(initialPassword);\r\n });\r\n\r\n onDestroy(() => {\r\n isMounted = false;\r\n });\r\n</script>\r\n\r\n<div class=\"collection-view\">\r\n {#if isLoading}\r\n <SkeletonLoader type=\"gallery\" />\r\n {:else if passwordRequired}\r\n <div class=\"password-container\">\r\n <div class=\"password-card\">\r\n <h2 class=\"password-title\">{labels.collectionPrivateTitle || 'This collection is private'}</h2>\r\n <p class=\"password-description\">{labels.collectionPrivateDescription || 'Please enter the password to view this collection.'}</p>\r\n <form onsubmit={handlePasswordSubmit} class=\"password-form\">\r\n <input\r\n type=\"password\"\r\n bind:value={passwordInput}\r\n placeholder={labels.enterPassword || \"Enter password\"}\r\n class=\"password-input\"\r\n class:password-input-error={passwordError}\r\n />\r\n {#if passwordError}\r\n <p class=\"password-error-text\">{labels.incorrectPassword || 'Incorrect password. Please try again.'}</p>\r\n {/if}\r\n <button type=\"submit\" class=\"password-submit\">{labels.viewCollection || 'View Collection'}</button>\r\n </form>\r\n </div>\r\n </div>\r\n {:else if error}\r\n <div class=\"error-container\">\r\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\r\n </div>\r\n {:else if collection}\r\n <!-- Cover Image with Blur -->\r\n {#if collection.coverImage}\r\n {@const imageUrl = getImageUrl(collection.coverImage)}\r\n <div class=\"cover-image\">\r\n <div class=\"cover-blur\" style=\"background-image: url({imageUrl})\"></div>\r\n <img src={imageUrl} alt={collection.collectionTitle} />\r\n </div>\r\n {/if}\r\n\r\n <!-- Collection Header -->\r\n <div class=\"collection-header\">\r\n <h1 class=\"collection-title\">{collection.collectionTitle}</h1>\r\n {#if collection.summary}\r\n <p class=\"collection-summary\">{collection.summary}</p>\r\n {/if}\r\n {#if collection.description}\r\n <div class=\"collection-description\">{collection.description}</div>\r\n {/if}\r\n </div>\r\n\r\n <!-- Events Section -->\r\n <div class=\"events-section\">\r\n <div class=\"events-section-header\">\r\n <h2 class=\"events-heading\">Events ({displayEvents.length})</h2>\r\n\r\n {#if canShowSwitcher}\r\n <div class=\"view-switcher\" role=\"group\" aria-label={labels.viewOptions || \"Display mode\"}>\r\n <button\r\n type=\"button\"\r\n class=\"view-switcher-btn\"\r\n class:view-switcher-btn-active={activeDisplayMode === 'gallery'}\r\n onclick={() => activeDisplayMode = 'gallery'}\r\n aria-label={labels.galleryView || \"Gallery view\"}\r\n aria-pressed={activeDisplayMode === 'gallery'}\r\n >\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <rect x=\"3\" y=\"3\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"14\" y=\"3\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"3\" y=\"14\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"14\" y=\"14\" width=\"7\" height=\"7\"></rect>\r\n </svg>\r\n </button>\r\n <button\r\n type=\"button\"\r\n class=\"view-switcher-btn\"\r\n class:view-switcher-btn-active={activeDisplayMode === 'list'}\r\n onclick={() => activeDisplayMode = 'list'}\r\n aria-label={labels.listView || \"List view\"}\r\n aria-pressed={activeDisplayMode === 'list'}\r\n >\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <line x1=\"8\" y1=\"6\" x2=\"21\" y2=\"6\"></line>\r\n <line x1=\"8\" y1=\"12\" x2=\"21\" y2=\"12\"></line>\r\n <line x1=\"8\" y1=\"18\" x2=\"21\" y2=\"18\"></line>\r\n <line x1=\"3\" y1=\"6\" x2=\"3.01\" y2=\"6\"></line>\r\n <line x1=\"3\" y1=\"12\" x2=\"3.01\" y2=\"12\"></line>\r\n <line x1=\"3\" y1=\"18\" x2=\"3.01\" y2=\"18\"></line>\r\n </svg>\r\n </button>\r\n </div>\r\n {/if}\r\n </div>\r\n\r\n {#if displayEvents.length === 0}\r\n <EmptyState\r\n message={labels.noUpcomingEvents || \"No upcoming events\"}\r\n subtext={labels.noUpcomingEventsSubtext || \"There are no events in this collection right now. Check back soon!\"}\r\n />\r\n {:else if activeDisplayMode === 'list'}\r\n <GroupedListView\r\n events={listEvents}\r\n filterFutureOnly={false}\r\n oneventClick={handleEventClick}\r\n />\r\n {:else}\r\n <div class=\"events-grid\">\r\n {#each galleryEvents as event (event.id)}\r\n <GalleryCard {event} oneventClick={handleEventClick} />\r\n {/each}\r\n </div>\r\n {/if}\r\n </div>\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n .collection-view {\r\n width: 100%;\r\n max-width: 64rem;\r\n margin-left: auto;\r\n margin-right: auto;\r\n padding-left: 1rem;\r\n padding-right: 1rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .error-container,\r\n .password-container {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n min-height: 50vh;\r\n text-align: center;\r\n }\r\n\r\n .error-text {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n /* Password gate */\r\n .password-card {\r\n border-radius: 0.5rem;\r\n padding: 2rem;\r\n max-width: 24rem;\r\n width: 100%;\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n box-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\r\n }\r\n\r\n .password-title {\r\n font-size: 1.25rem;\r\n line-height: 1.75rem;\r\n font-weight: 700;\r\n margin-bottom: 0.5rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .password-description {\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n margin-bottom: 1.5rem;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .password-form {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.75rem;\r\n }\r\n\r\n .password-input {\r\n width: 100%;\r\n padding: 0.5rem 0.75rem;\r\n border-radius: 0.5rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 85%));\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n }\r\n\r\n .password-input:focus {\r\n outline: none;\r\n border-color: hsl(var(--brand-primary, 220 90% 56%));\r\n box-shadow: 0 0 0 2px hsl(var(--brand-primary, 220 90% 56%) / 0.2);\r\n }\r\n\r\n .password-input-error {\r\n border-color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .password-error-text {\r\n font-size: 0.75rem;\r\n line-height: 1rem;\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .password-submit {\r\n padding: 0.5rem 1rem;\r\n border-radius: 0.5rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n font-weight: 600;\r\n background: hsl(var(--brand-primary, 220 90% 56%));\r\n color: hsl(var(--text-on-primary, 0 0% 100%));\r\n }\r\n\r\n .password-submit:hover {\r\n filter: brightness(0.95);\r\n }\r\n\r\n /* Cover Image with blur background */\r\n .cover-image {\r\n position: relative;\r\n width: 100%;\r\n overflow: hidden;\r\n border-radius: 0.5rem;\r\n margin-bottom: 2rem;\r\n height: 350px;\r\n }\r\n\r\n .cover-blur {\r\n position: absolute;\r\n inset: 0;\r\n background-size: cover;\r\n background-position: center;\r\n filter: blur(24px) saturate(1.2);\r\n transform: scale(1.15);\r\n }\r\n\r\n .cover-image img {\r\n position: relative;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: contain;\r\n }\r\n\r\n /* Header */\r\n .collection-header {\r\n margin-bottom: 2rem;\r\n }\r\n\r\n .collection-title {\r\n font-size: 1.875rem;\r\n line-height: 2.25rem;\r\n font-weight: 700;\r\n margin-bottom: 0.5rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .collection-summary {\r\n font-size: 1.125rem;\r\n line-height: 1.75rem;\r\n margin-bottom: 1rem;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .collection-description {\r\n line-height: 1.625;\r\n color: hsl(var(--text-secondary, 0 0% 35%));\r\n }\r\n\r\n /* Events Section */\r\n .events-section {\r\n margin-bottom: 2rem;\r\n }\r\n\r\n .events-section-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n margin-bottom: 1rem;\r\n }\r\n\r\n .events-heading {\r\n font-size: 1.5rem;\r\n line-height: 2rem;\r\n font-weight: 700;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n /* View Switcher */\r\n .view-switcher {\r\n display: flex;\r\n gap: 0.25rem;\r\n padding: 0.25rem;\r\n border-radius: 0.5rem;\r\n background: hsl(var(--surface-secondary, 0 0% 96%));\r\n }\r\n\r\n .view-switcher-btn {\r\n padding: 0.375rem;\r\n border-radius: 0.375rem;\r\n transition: color 0.15s;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .view-switcher-btn:hover {\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .view-switcher-btn-active {\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n box-shadow: 0 1px 2px color-mix(in srgb, black 8%, transparent);\r\n }\r\n\r\n .events-grid {\r\n display: grid;\r\n gap: 1.5rem;\r\n grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));\r\n }\r\n\r\n /* Responsive */\r\n @media (max-width: 640px) {\r\n .cover-image {\r\n height: 250px;\r\n }\r\n\r\n .collection-title {\r\n font-size: 1.5rem;\r\n line-height: 2rem;\r\n }\r\n\r\n .events-grid {\r\n grid-template-columns: repeat(2, 1fr);\r\n }\r\n }\r\n\r\n @media (max-width: 400px) {\r\n .events-grid {\r\n grid-template-columns: 1fr;\r\n }\r\n }\r\n</style>\r\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","labels","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root","h2","node","group","div","root_1","div_1","root_2","span","span_1","span_2","$$render","consequent","ul","node_1","eventStatus","getBrowseStatus","isUnavailable","isEventUnavailable","li","root_3","div_2","div_3","img","div_4","h3","time","p","root_4","text_6","consequent_1","div_5","span_3","root_5","text_7","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_4","formatFullDate","formatEventTime","div_6","root_7","span_4","$$value","consequent_4","classes","initialPassword","initialDisplayMode","showViewSwitcher","collection","isLoading","error","isMounted","passwordRequired","passwordInput","passwordError","activeDisplayMode","toGalleryEvent","getImageUrl","formatTimeline","toListEvent","iso","displayEvents","sortByStartTime","galleryEvents","listEvents","canShowSwitcher","galleryEvent","eventData","loadCollection","pwd","data","fetchPublicCollection","err","msg","handlePasswordSubmit","SkeletonLoader","form","input","p_1","button","p_2","imageUrl","root_6","node_2","h1","p_3","consequent_5","div_7","root_8","consequent_6","div_8","div_9","h2_1","div_10","root_9","button_1","button_2","classes_2","consequent_7","EmptyState","GroupedListView","div_11","root_12","GalleryCard","consequent_8","consequent_9","alternate","text_5","text_8","consequent_10"],"mappings":"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"}
1
+ {"version":3,"file":"CollectionView.legacy-CXv5mTUk.js","sources":["../src/components/Calendar/GroupedListView.svelte","../src/components/Views/CollectionView.legacy.svelte"],"sourcesContent":["<script>\r\n import { onMount, onDestroy } from \"svelte\";\r\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\r\n import { getDateParts, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\r\n import { getBrowseStatus, isEventUnavailable, filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\r\n\r\n let {\r\n events = [],\r\n initialCount = 10,\r\n loadMoreCount = 10,\r\n showDateColumn = true,\r\n filterFutureOnly = true,\r\n oneventClick,\r\n labels = {},\r\n } = $props();\r\n\r\n let displayedCount = $state(initialCount);\r\n let loadMoreTrigger = $state();\r\n let observer;\r\n\r\n // Filter to today and future (if enabled), then group by date\r\n let filteredEvents = $derived(filterFutureOnly ? filterTodayAndFuture(events) : events);\r\n let groupedEvents = $derived(groupEventsByDate(filteredEvents.slice(0, displayedCount)));\r\n let hasMore = $derived(displayedCount < filteredEvents.length);\r\n\r\n function loadMore() {\r\n displayedCount += loadMoreCount;\r\n }\r\n\r\n onMount(() => {\r\n observer = new IntersectionObserver(\r\n (entries) => {\r\n if (entries[0].isIntersecting && hasMore) {\r\n loadMore();\r\n }\r\n },\r\n { rootMargin: '100px' }\r\n );\r\n\r\n if (loadMoreTrigger) {\r\n observer.observe(loadMoreTrigger);\r\n }\r\n });\r\n\r\n onDestroy(() => {\r\n if (observer) {\r\n observer.disconnect();\r\n }\r\n });\r\n\r\n // Re-observe when trigger element changes\r\n $effect(() => {\r\n if (observer && loadMoreTrigger) {\r\n observer.disconnect();\r\n observer.observe(loadMoreTrigger);\r\n }\r\n });\r\n\r\n function groupEventsByDate(eventList) {\r\n const groups = {};\r\n\r\n for (const event of eventList) {\r\n const dateKey = event.date; // YYYY-MM-DD format\r\n if (!groups[dateKey]) {\r\n groups[dateKey] = [];\r\n }\r\n groups[dateKey].push(event);\r\n }\r\n\r\n // Convert to array sorted by date\r\n return Object.entries(groups)\r\n .sort(([a], [b]) => new Date(a) - new Date(b))\r\n .map(([date, events]) => ({\r\n date,\r\n events,\r\n formattedDate: formatGroupDate(events),\r\n }));\r\n }\r\n\r\n function formatGroupDate(events) {\r\n // Use the first event in the group to get timezone-aware date parts\r\n const firstEvent = events[0];\r\n if (!firstEvent?.startDateTime) return { month: '', day: '', weekday: '' };\r\n const parts = getDateParts(firstEvent.startDateTime, firstEvent.timeZone);\r\n return {\r\n month: parts.month.toUpperCase(),\r\n day: String(parts.date).padStart(2, '0'),\r\n weekday: parts.day.toUpperCase(),\r\n };\r\n }\r\n\r\n function handleEventClick(event) {\r\n oneventClick?.(event);\r\n }\r\n\r\n function handleKeydown(e, event) {\r\n if (e.key === 'Enter' || e.key === ' ') {\r\n e.preventDefault();\r\n handleEventClick(event);\r\n }\r\n }\r\n</script>\r\n\r\n<section class=\"flex flex-col gap-0\" class:no-date-column={!showDateColumn} aria-label={labels.eventListings || 'Event listings'}>\r\n <h2 class=\"sr-only\">{labels.eventListGroupedByDate || 'Event list grouped by date'}</h2>\r\n {#each groupedEvents as group}\r\n <div class=\"date-group flex border-b border-border last:border-b-0\" role=\"group\" aria-label=\"Events on {group.events[0]?.startDateTime ? formatFullDate(group.events[0].startDateTime, group.events[0].timeZone) : group.date}\">\r\n <!-- Date Column -->\r\n {#if showDateColumn}\r\n <div class=\"w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-bg-secondary border-r border-border max-sm:w-12 max-sm:min-w-12 max-sm:py-2.5 max-sm:px-1.5\" aria-hidden=\"true\">\r\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.month}</span>\r\n <span class=\"text-2xl max-sm:text-lg font-bold text-text-primary leading-tight\">{group.formattedDate.day}</span>\r\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.weekday}</span>\r\n </div>\r\n {/if}\r\n\r\n <!-- Events Column -->\r\n <ul class=\"events-column flex-1 flex flex-col list-none p-0 m-0\">\r\n {#each group.events as event, eventIndex}\r\n {@const eventStatus = getBrowseStatus(event)}\r\n {@const isUnavailable = isEventUnavailable(eventStatus)}\r\n <li class=\"list-none\">\r\n <div\r\n class=\"event-row flex gap-4 max-sm:gap-2.5 p-5 max-sm:p-3 cursor-pointer transition-colors duration-150 bg-card border-b border-border/50 last:border-b-0 hover:bg-bg-secondary focus:outline-2 focus:outline-brand-primary focus:-outline-offset-2 focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:-outline-offset-2\"\r\n class:row-unavailable={isUnavailable}\r\n onclick={() => handleEventClick(event)}\r\n onkeydown={(e) => handleKeydown(e, event)}\r\n tabindex=\"0\"\r\n role=\"button\"\r\n aria-label={`${event.name} on ${event.startDateTime ? formatFullDate(event.startDateTime, event.timeZone) : group.date} at ${event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}, ${eventStatus?.text || event.status || labels.statusOnSale || 'On Sale'}. ${labels.pressEnterToView || 'Press Enter to view details'}`}\r\n >\r\n <!-- Event Image -->\r\n <div class=\"w-36 h-24 min-w-36 max-sm:w-20 max-sm:h-16 max-sm:min-w-20 rounded-lg overflow-hidden bg-bg-secondary flex items-center justify-center\" aria-hidden=\"true\">\r\n <img\r\n src={event.image || PLACEHOLDER_IMAGE}\r\n alt=\"\"\r\n class=\"w-full h-full object-contain\"\r\n loading=\"lazy\"\r\n />\r\n </div>\r\n\r\n <!-- Event Details (visually shown but also in aria-label, so hide from SR) -->\r\n <div class=\"flex-1 flex flex-col gap-1.5 min-w-0\" aria-hidden=\"true\">\r\n <h3 class=\"text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug\">{event.name}</h3>\r\n <time class=\"text-sm max-sm:text-xs font-medium text-text-secondary\" datetime={event.startDateTime || group.date}>{event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}</time>\r\n {#if event.description}\r\n <p class=\"event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden\">{event.description}</p>\r\n {/if}\r\n </div>\r\n\r\n <!-- Status / Scarcity Badge -->\r\n <div class=\"flex items-start pt-0.5\" aria-hidden=\"true\">\r\n {#if eventStatus}\r\n <span class=\"status-badge status-{eventStatus.type}\">{eventStatus.text}</span>\r\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\r\n <ScarcityBadge\r\n remaining={event.ticketsRemaining ?? 0}\r\n total={event.ticketsTotal ?? 0}\r\n context=\"browse\"\r\n {labels}\r\n />\r\n {/if}\r\n </div>\r\n </div>\r\n </li>\r\n {/each}\r\n </ul>\r\n </div>\r\n {/each}\r\n\r\n <!-- Infinite scroll trigger -->\r\n {#if hasMore}\r\n <div bind:this={loadMoreTrigger} class=\"flex justify-center items-center p-6 text-text-secondary\" role=\"status\" aria-live=\"polite\">\r\n <span class=\"text-sm\">{labels.loadingMoreEvents || 'Loading more events...'}</span>\r\n </div>\r\n {/if}\r\n</section>\r\n\r\n<style>\r\n /* When no date column, remove left border styling */\r\n .no-date-column .date-group {\r\n border-bottom: 0;\r\n }\r\n\r\n .no-date-column .events-column {\r\n border-left: 0;\r\n }\r\n\r\n .event-description {\r\n display: -webkit-box;\r\n -webkit-box-orient: vertical;\r\n overflow: hidden;\r\n }\r\n\r\n /* Unavailable row dimming */\r\n .row-unavailable {\r\n opacity: 0.6;\r\n }\r\n\r\n .row-unavailable img {\r\n filter: grayscale(0.5);\r\n }\r\n\r\n /* Status badges -- distinct visual treatments matching gallery cards */\r\n .status-badge {\r\n display: inline-flex;\r\n align-items: center;\r\n font-size: 0.75rem;\r\n line-height: 1rem;\r\n font-weight: 700;\r\n padding: 0.25rem 0.625rem;\r\n border-radius: 0.25rem;\r\n white-space: nowrap;\r\n letter-spacing: 0.02em;\r\n }\r\n\r\n .status-cancelled {\r\n background-color: hsl(var(--accent-danger) / 0.1);\r\n color: hsl(var(--accent-danger));\r\n text-decoration: line-through;\r\n text-decoration-thickness: 1.5px;\r\n\r\n \r\n }\r\n\r\n .status-past {\r\n background-color: hsl(var(--bg-tertiary));\r\n color: hsl(var(--text-tertiary));\r\n\r\n \r\n }\r\n\r\n .status-sold_out {\r\n background-color: hsl(var(--accent-danger) / 0.1);\r\n color: hsl(var(--accent-danger));\r\n text-transform: uppercase;\r\n letter-spacing: 0.05em;\r\n font-size: 0.65rem;\r\n\r\n \r\n }\r\n\r\n .status-sales_ended {\r\n background-color: hsl(var(--bg-tertiary));\r\n color: hsl(var(--text-tertiary));\r\n border: 1px solid hsl(var(--stroke-primary));\r\n\r\n \r\n }\r\n\r\n .status-coming_soon {\r\n background-color: hsl(var(--brand-primary) / 0.15);\r\n color: hsl(var(--brand-primary));\r\n\r\n \r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .event-row {\r\n transition: none;\r\n }\r\n }\r\n\r\n /* Screen reader only text */\r\n .sr-only {\r\n position: absolute;\r\n width: 1px;\r\n height: 1px;\r\n padding: 0;\r\n margin: -1px;\r\n overflow: hidden;\r\n clip: rect(0, 0, 0, 0);\r\n white-space: nowrap;\r\n border-width: 0;\r\n }\r\n</style>\r\n","<script>\r\n import { onMount, onDestroy } from 'svelte';\r\n import { fetchPublicCollection } from '../../lib/api/events.ts';\r\n import { getImageUrl } from '$lib/utils/utils.js';\r\n import { EmptyState } from '@getmicdrop/svelte-components';\r\n import GalleryCard from '../Calendar/GalleryCard.svelte';\r\n import GroupedListView from '../Calendar/GroupedListView.svelte';\r\n import SkeletonLoader from '../SkeletonLoader/SkeletonLoader.svelte';\r\n\r\n let {\r\n collectionId,\r\n organizationId = '',\r\n onNavigateToEvent,\r\n password: initialPassword = undefined,\r\n displayMode: initialDisplayMode = 'gallery',\r\n showViewSwitcher = true,\r\n labels = {},\r\n } = $props();\r\n\r\n let collection = $state(null);\r\n let isLoading = $state(true);\r\n let error = $state(null);\r\n let isMounted = $state(false);\r\n let passwordRequired = $state(false);\r\n let passwordInput = $state('');\r\n let passwordError = $state(false);\r\n let activeDisplayMode = $state(initialDisplayMode);\r\n\r\n // Transform collection events into the shape GalleryCard expects\r\n function toGalleryEvent(event) {\r\n return {\r\n id: event.id,\r\n name: event.title || event.name || '',\r\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\r\n image: event.image ? getImageUrl(event.image) : '',\r\n timeline: event.startDateTime ? formatTimeline(event.startDateTime) : '',\r\n status: event.status || 'on_sale',\r\n slug: event.slug || '',\r\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\r\n ticketsTotal: event.ticketsTotal ?? event.capacity,\r\n };\r\n }\r\n\r\n // Transform collection events into the shape GroupedListView expects\r\n function toListEvent(event) {\r\n return {\r\n id: event.id,\r\n name: event.title || event.name || '',\r\n date: event.startDateTime ? event.startDateTime.split('T')[0] : '',\r\n startDateTime: event.startDateTime || '',\r\n image: event.image ? getImageUrl(event.image) : '',\r\n status: event.status || 'on_sale',\r\n slug: event.slug || '',\r\n description: event.description || '',\r\n ticketsRemaining: event.ticketsRemaining ?? event.ticketsAvailable,\r\n ticketsTotal: event.ticketsTotal ?? event.capacity,\r\n };\r\n }\r\n\r\n function formatTimeline(iso) {\r\n if (!iso) return '';\r\n const date = new Date(iso);\r\n return date.toLocaleTimeString('en-US', {\r\n hour: 'numeric',\r\n minute: '2-digit',\r\n hour12: true,\r\n });\r\n }\r\n\r\n let displayEvents = $derived(\r\n collection ? sortByStartTime(collection.events || []) : []\r\n );\r\n\r\n let galleryEvents = $derived(displayEvents.map(toGalleryEvent));\r\n let listEvents = $derived(displayEvents.map(toListEvent));\r\n\r\n // Only show view switcher when there are 2+ events\r\n let canShowSwitcher = $derived(showViewSwitcher && displayEvents.length >= 2);\r\n\r\n function sortByStartTime(events) {\r\n return [...events].sort((a, b) => {\r\n if (!a.startDateTime && !b.startDateTime) return 0;\r\n if (!a.startDateTime) return 1;\r\n if (!b.startDateTime) return -1;\r\n return new Date(a.startDateTime).getTime() - new Date(b.startDateTime).getTime();\r\n });\r\n }\r\n\r\n function handleEventClick(galleryEvent) {\r\n if (onNavigateToEvent) {\r\n const eventData = galleryEvent.detail || galleryEvent;\r\n onNavigateToEvent(eventData.id, eventData.slug || '');\r\n }\r\n }\r\n\r\n async function loadCollection(pwd) {\r\n if (!isMounted) return;\r\n if (!collectionId) {\r\n error = labels.noCollectionIdProvided || 'No collection ID provided';\r\n isLoading = false;\r\n return;\r\n }\r\n\r\n isLoading = true;\r\n error = null;\r\n passwordError = false;\r\n\r\n try {\r\n const data = await fetchPublicCollection(collectionId, pwd);\r\n if (!isMounted) return;\r\n\r\n if (data) {\r\n // Check if the response indicates password is required\r\n if (data.passwordRequired || data.error?.code === 'PASSWORD_REQUIRED') {\r\n passwordRequired = true;\r\n isLoading = false;\r\n return;\r\n }\r\n collection = data;\r\n passwordRequired = false;\r\n } else {\r\n // A null response after providing a password likely means wrong password\r\n if (pwd) {\r\n passwordRequired = true;\r\n passwordError = true;\r\n isLoading = false;\r\n return;\r\n }\r\n error = labels.failedToLoadCollection || 'Failed to load collection';\r\n }\r\n } catch (err) {\r\n if (isMounted) {\r\n // Check for password-related error responses\r\n const msg = err.message || '';\r\n if (msg.includes('401') || msg.includes('403') || msg.includes('password')) {\r\n passwordRequired = true;\r\n } else {\r\n error = msg || 'Failed to load collection';\r\n }\r\n }\r\n } finally {\r\n if (isMounted) {\r\n isLoading = false;\r\n }\r\n }\r\n }\r\n\r\n function handlePasswordSubmit(e) {\r\n e.preventDefault();\r\n if (!passwordInput.trim()) return;\r\n loadCollection(passwordInput);\r\n }\r\n\r\n onMount(async () => {\r\n isMounted = true;\r\n await loadCollection(initialPassword);\r\n });\r\n\r\n onDestroy(() => {\r\n isMounted = false;\r\n });\r\n</script>\r\n\r\n<div class=\"collection-view\">\r\n {#if isLoading}\r\n <SkeletonLoader type=\"gallery\" />\r\n {:else if passwordRequired}\r\n <div class=\"password-container\">\r\n <div class=\"password-card\">\r\n <h2 class=\"password-title\">{labels.collectionPrivateTitle || 'This collection is private'}</h2>\r\n <p class=\"password-description\">{labels.collectionPrivateDescription || 'Please enter the password to view this collection.'}</p>\r\n <form onsubmit={handlePasswordSubmit} class=\"password-form\">\r\n <input\r\n type=\"password\"\r\n bind:value={passwordInput}\r\n placeholder={labels.enterPassword || \"Enter password\"}\r\n class=\"password-input\"\r\n class:password-input-error={passwordError}\r\n />\r\n {#if passwordError}\r\n <p class=\"password-error-text\">{labels.incorrectPassword || 'Incorrect password. Please try again.'}</p>\r\n {/if}\r\n <button type=\"submit\" class=\"password-submit\">{labels.viewCollection || 'View Collection'}</button>\r\n </form>\r\n </div>\r\n </div>\r\n {:else if error}\r\n <div class=\"error-container\">\r\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\r\n </div>\r\n {:else if collection}\r\n <!-- Cover Image with Blur -->\r\n {#if collection.coverImage}\r\n {@const imageUrl = getImageUrl(collection.coverImage)}\r\n <div class=\"cover-image\">\r\n <div class=\"cover-blur\" style=\"background-image: url({imageUrl})\"></div>\r\n <img src={imageUrl} alt={collection.collectionTitle} />\r\n </div>\r\n {/if}\r\n\r\n <!-- Collection Header -->\r\n <div class=\"collection-header\">\r\n <h1 class=\"collection-title\">{collection.collectionTitle}</h1>\r\n {#if collection.summary}\r\n <p class=\"collection-summary\">{collection.summary}</p>\r\n {/if}\r\n {#if collection.description}\r\n <div class=\"collection-description\">{collection.description}</div>\r\n {/if}\r\n </div>\r\n\r\n <!-- Events Section -->\r\n <div class=\"events-section\">\r\n <div class=\"events-section-header\">\r\n <h2 class=\"events-heading\">Events ({displayEvents.length})</h2>\r\n\r\n {#if canShowSwitcher}\r\n <div class=\"view-switcher\" role=\"group\" aria-label={labels.viewOptions || \"Display mode\"}>\r\n <button\r\n type=\"button\"\r\n class=\"view-switcher-btn\"\r\n class:view-switcher-btn-active={activeDisplayMode === 'gallery'}\r\n onclick={() => activeDisplayMode = 'gallery'}\r\n aria-label={labels.galleryView || \"Gallery view\"}\r\n aria-pressed={activeDisplayMode === 'gallery'}\r\n >\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <rect x=\"3\" y=\"3\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"14\" y=\"3\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"3\" y=\"14\" width=\"7\" height=\"7\"></rect>\r\n <rect x=\"14\" y=\"14\" width=\"7\" height=\"7\"></rect>\r\n </svg>\r\n </button>\r\n <button\r\n type=\"button\"\r\n class=\"view-switcher-btn\"\r\n class:view-switcher-btn-active={activeDisplayMode === 'list'}\r\n onclick={() => activeDisplayMode = 'list'}\r\n aria-label={labels.listView || \"List view\"}\r\n aria-pressed={activeDisplayMode === 'list'}\r\n >\r\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <line x1=\"8\" y1=\"6\" x2=\"21\" y2=\"6\"></line>\r\n <line x1=\"8\" y1=\"12\" x2=\"21\" y2=\"12\"></line>\r\n <line x1=\"8\" y1=\"18\" x2=\"21\" y2=\"18\"></line>\r\n <line x1=\"3\" y1=\"6\" x2=\"3.01\" y2=\"6\"></line>\r\n <line x1=\"3\" y1=\"12\" x2=\"3.01\" y2=\"12\"></line>\r\n <line x1=\"3\" y1=\"18\" x2=\"3.01\" y2=\"18\"></line>\r\n </svg>\r\n </button>\r\n </div>\r\n {/if}\r\n </div>\r\n\r\n {#if displayEvents.length === 0}\r\n <EmptyState\r\n message={labels.noUpcomingEvents || \"No upcoming events\"}\r\n subtext={labels.noUpcomingEventsSubtext || \"There are no events in this collection right now. Check back soon!\"}\r\n />\r\n {:else if activeDisplayMode === 'list'}\r\n <GroupedListView\r\n events={listEvents}\r\n filterFutureOnly={false}\r\n oneventClick={handleEventClick}\r\n />\r\n {:else}\r\n <div class=\"events-grid\">\r\n {#each galleryEvents as event (event.id)}\r\n <GalleryCard {event} oneventClick={handleEventClick} />\r\n {/each}\r\n </div>\r\n {/if}\r\n </div>\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n .collection-view {\r\n width: 100%;\r\n max-width: 64rem;\r\n margin-left: auto;\r\n margin-right: auto;\r\n padding-left: 1rem;\r\n padding-right: 1rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .error-container,\r\n .password-container {\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n justify-content: center;\r\n min-height: 50vh;\r\n text-align: center;\r\n }\r\n\r\n .error-text {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n /* Password gate */\r\n .password-card {\r\n border-radius: 0.5rem;\r\n padding: 2rem;\r\n max-width: 24rem;\r\n width: 100%;\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n box-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\r\n }\r\n\r\n .password-title {\r\n font-size: 1.25rem;\r\n line-height: 1.75rem;\r\n font-weight: 700;\r\n margin-bottom: 0.5rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .password-description {\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n margin-bottom: 1.5rem;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .password-form {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 0.75rem;\r\n }\r\n\r\n .password-input {\r\n width: 100%;\r\n padding: 0.5rem 0.75rem;\r\n border-radius: 0.5rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 85%));\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n }\r\n\r\n .password-input:focus {\r\n outline: none;\r\n border-color: hsl(var(--brand-primary, 220 90% 56%));\r\n box-shadow: 0 0 0 2px hsl(var(--brand-primary, 220 90% 56%) / 0.2);\r\n }\r\n\r\n .password-input-error {\r\n border-color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .password-error-text {\r\n font-size: 0.75rem;\r\n line-height: 1rem;\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .password-submit {\r\n padding: 0.5rem 1rem;\r\n border-radius: 0.5rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n font-weight: 600;\r\n background: hsl(var(--brand-primary, 220 90% 56%));\r\n color: hsl(var(--text-on-primary, 0 0% 100%));\r\n }\r\n\r\n .password-submit:hover {\r\n filter: brightness(0.95);\r\n }\r\n\r\n /* Cover Image with blur background */\r\n .cover-image {\r\n position: relative;\r\n width: 100%;\r\n overflow: hidden;\r\n border-radius: 0.5rem;\r\n margin-bottom: 2rem;\r\n height: 350px;\r\n }\r\n\r\n .cover-blur {\r\n position: absolute;\r\n inset: 0;\r\n background-size: cover;\r\n background-position: center;\r\n filter: blur(24px) saturate(1.2);\r\n transform: scale(1.15);\r\n }\r\n\r\n .cover-image img {\r\n position: relative;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: contain;\r\n }\r\n\r\n /* Header */\r\n .collection-header {\r\n margin-bottom: 2rem;\r\n }\r\n\r\n .collection-title {\r\n font-size: 1.875rem;\r\n line-height: 2.25rem;\r\n font-weight: 700;\r\n margin-bottom: 0.5rem;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .collection-summary {\r\n font-size: 1.125rem;\r\n line-height: 1.75rem;\r\n margin-bottom: 1rem;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .collection-description {\r\n line-height: 1.625;\r\n color: hsl(var(--text-secondary, 0 0% 35%));\r\n }\r\n\r\n /* Events Section */\r\n .events-section {\r\n margin-bottom: 2rem;\r\n }\r\n\r\n .events-section-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n margin-bottom: 1rem;\r\n }\r\n\r\n .events-heading {\r\n font-size: 1.5rem;\r\n line-height: 2rem;\r\n font-weight: 700;\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n /* View Switcher */\r\n .view-switcher {\r\n display: flex;\r\n gap: 0.25rem;\r\n padding: 0.25rem;\r\n border-radius: 0.5rem;\r\n background: hsl(var(--surface-secondary, 0 0% 96%));\r\n }\r\n\r\n .view-switcher-btn {\r\n padding: 0.375rem;\r\n border-radius: 0.375rem;\r\n transition: color 0.15s;\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .view-switcher-btn:hover {\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .view-switcher-btn-active {\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n box-shadow: 0 1px 2px color-mix(in srgb, black 8%, transparent);\r\n }\r\n\r\n .events-grid {\r\n display: grid;\r\n gap: 1.5rem;\r\n grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));\r\n }\r\n\r\n /* Responsive */\r\n @media (max-width: 640px) {\r\n .cover-image {\r\n height: 250px;\r\n }\r\n\r\n .collection-title {\r\n font-size: 1.5rem;\r\n line-height: 2rem;\r\n }\r\n\r\n .events-grid {\r\n grid-template-columns: repeat(2, 1fr);\r\n }\r\n }\r\n\r\n @media (max-width: 400px) {\r\n .events-grid {\r\n grid-template-columns: 1fr;\r\n }\r\n }\r\n</style>\r\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","labels","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root","h2","node","group","div","root_1","div_1","root_2","span","span_1","span_2","$$render","consequent","ul","node_1","eventStatus","getBrowseStatus","isUnavailable","isEventUnavailable","li","root_3","div_2","div_3","img","div_4","h3","time","p","root_4","text_6","consequent_1","div_5","span_3","root_5","text_7","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_4","formatFullDate","formatEventTime","div_6","root_7","span_4","$$value","consequent_4","classes","initialPassword","initialDisplayMode","showViewSwitcher","collection","isLoading","error","isMounted","passwordRequired","passwordInput","passwordError","activeDisplayMode","toGalleryEvent","getImageUrl","formatTimeline","toListEvent","iso","displayEvents","sortByStartTime","galleryEvents","listEvents","canShowSwitcher","galleryEvent","eventData","loadCollection","pwd","data","fetchPublicCollection","err","msg","handlePasswordSubmit","SkeletonLoader","form","input","p_1","button","p_2","imageUrl","root_6","node_2","h1","p_3","consequent_5","div_7","root_8","consequent_6","div_8","div_9","h2_1","div_10","root_9","button_1","button_2","classes_2","consequent_7","EmptyState","GroupedListView","div_11","root_12","GalleryCard","consequent_8","consequent_9","alternate","text_5","text_8","consequent_10"],"mappings":"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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 H, P as M, b as D, c as Z } from "./VenueCalendar-D3wcXj5o.js";
3
+ import { f as H, P as M, b as D, c as Z } from "./VenueCalendar-DIQ8H0q7.js";
4
4
  var O = e.from_html('<div class="hero-image-container relative w-full bg-muted overflow-hidden svelte-ndk2q7"><img alt="" class="hero-image svelte-ndk2q7" aria-hidden="true"/></div>'), R = e.from_html('<div class="hero-image-container relative w-full bg-muted overflow-hidden flex items-center justify-center svelte-ndk2q7"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" class="w-16 h-16 text-muted-foreground"><rect x="2" y="2" width="20" height="20" rx="2"></rect><circle cx="8.5" cy="8.5" r="1.5"></circle><path d="m21 15-5-5L5 21"></path></svg></div>'), S = e.from_html('<span class="w-1.5 h-1.5 rounded-full bg-brand-primary"></span> Series', 1), V = e.from_html('<span class="w-1.5 h-1.5 rounded-full bg-brand-primary"></span> Collection', 1), z = e.from_html('<span class="text-muted-foreground">·</span> ', 1), J = e.from_html('<p class="text-base text-text-secondary font-medium"> <!></p>'), K = e.from_html('<div class="featured-hero rounded-lg border border-border bg-card overflow-hidden"><!> <div class="p-4 sm:p-5"><div class="inline-flex items-center gap-1.5 text-xs font-semibold text-brand-primary uppercase tracking-wide mb-2"><!> <!></div> <h2 class="hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2 svelte-ndk2q7"> </h2> <!></div></div>'), Q = e.from_html('<span class="text-muted-foreground mx-1">·</span> ', 1), U = e.from_html('<p class="hero-description text-sm text-text-secondary mt-2 svelte-ndk2q7"> </p>'), W = e.from_html('<div class="featured-hero featured-hero-clickable rounded-lg border border-border bg-card overflow-hidden cursor-pointer hover:border-stroke-primary focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2 svelte-ndk2q7" tabindex="0" role="button"><div class="hero-image-container relative w-full bg-muted overflow-hidden svelte-ndk2q7"><img alt="" class="hero-image svelte-ndk2q7" aria-hidden="true"/></div> <div class="p-4 sm:p-5" aria-hidden="true"><h2 class="hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2 svelte-ndk2q7"> </h2> <p class="text-base text-text-secondary font-medium"> <!></p> <!></div></div>'), X = e.from_html('<div class="flex items-center justify-center py-12 rounded-lg border border-border bg-bg-secondary"><p class="text-sm text-muted-foreground">No upcoming events to feature</p></div>'), Y = e.from_html('<section class="w-full" aria-label="Featured event"><!></section>');
5
5
  function te(F, u) {
6
6
  e.push(u, !0);
@@ -125,4 +125,4 @@ e.delegate(["click", "keydown"]);
125
125
  export {
126
126
  te as default
127
127
  };
128
- //# sourceMappingURL=FeaturedView.legacy-Dpzi5iwI.js.map
128
+ //# sourceMappingURL=FeaturedView.legacy-C5yztREl.js.map