@getmicdrop/venue-calendar 4.0.82 → 4.0.84

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 (94) hide show
  1. package/dist/CartView-DwAGELwG.js +2365 -0
  2. package/dist/CartView-DwAGELwG.js.map +1 -0
  3. package/dist/{Checkout-B15JygVy.js → Checkout-CHo11MsU.js} +466 -470
  4. package/dist/Checkout-CHo11MsU.js.map +1 -0
  5. package/dist/Checkout-_NuoBAKt.js +789 -0
  6. package/dist/Checkout-_NuoBAKt.js.map +1 -0
  7. package/dist/{CheckoutTimer-qLOtPDt3.js → CheckoutTimer-CAGR7L-7.js} +13 -13
  8. package/dist/{CheckoutTimer-qLOtPDt3.js.map → CheckoutTimer-CAGR7L-7.js.map} +1 -1
  9. package/dist/CollectionView-Dstgu8sR.js +299 -0
  10. package/dist/CollectionView-Dstgu8sR.js.map +1 -0
  11. package/dist/{Event-DZpU-Ec1.js → Event-kfRjkMzQ.js} +1875 -1249
  12. package/dist/Event-kfRjkMzQ.js.map +1 -0
  13. package/dist/EventPage-CnhccVCI.js +529 -0
  14. package/dist/EventPage-CnhccVCI.js.map +1 -0
  15. package/dist/{Heading-5CT9Nk0b.js → Heading-Ielp7dS-.js} +2 -2
  16. package/dist/{Heading-5CT9Nk0b.js.map → Heading-Ielp7dS-.js.map} +1 -1
  17. package/dist/{ModalHeader-CGaXzdcs.js → ModalHeader-Q7levd4l.js} +2 -2
  18. package/dist/{ModalHeader-CGaXzdcs.js.map → ModalHeader-Q7levd4l.js.map} +1 -1
  19. package/dist/ScarcityBadge-CG7Mz5YN.js +90 -0
  20. package/dist/ScarcityBadge-CG7Mz5YN.js.map +1 -0
  21. package/dist/SeriesPage-C8fIvt63.js +33 -0
  22. package/dist/SeriesPage-C8fIvt63.js.map +1 -0
  23. package/dist/Success-SZNXo-Ou.js +729 -0
  24. package/dist/{Success-B4CM_cy1.js.map → Success-SZNXo-Ou.js.map} +1 -1
  25. package/dist/{Text-WY42WIKI.js → Text-DHgQP4rA.js} +16 -16
  26. package/dist/{Text-WY42WIKI.js.map → Text-DHgQP4rA.js.map} +1 -1
  27. package/dist/{VenueCalendar-DMSeDRSN.js → VenueCalendar-DTOyAhDU.js} +3820 -4111
  28. package/dist/VenueCalendar-DTOyAhDU.js.map +1 -0
  29. package/dist/{ViewTicketsEmbed-AlVzNvxE.js → ViewTicketsEmbed-DBEOjijY.js} +31 -31
  30. package/dist/{ViewTicketsEmbed-AlVzNvxE.js.map → ViewTicketsEmbed-DBEOjijY.js.map} +1 -1
  31. package/dist/api/api.cjs.map +1 -1
  32. package/dist/api/api.mjs +3 -6
  33. package/dist/api/api.mjs.map +1 -1
  34. package/dist/{data-toggle-store.svelte-CtW4s3Vw.js → data-toggle-store.svelte-E2JyoGTV.js} +2 -2
  35. package/dist/{data-toggle-store.svelte-CtW4s3Vw.js.map → data-toggle-store.svelte-E2JyoGTV.js.map} +1 -1
  36. package/dist/{labels-BB1JG19g.js → labels-nQIooadc.js} +29 -30
  37. package/dist/{labels-BB1JG19g.js.map → labels-nQIooadc.js.map} +1 -1
  38. package/dist/seo/seo.cjs +1 -1
  39. package/dist/seo/seo.cjs.map +1 -1
  40. package/dist/seo/seo.mjs +79 -58
  41. package/dist/seo/seo.mjs.map +1 -1
  42. package/dist/{transform-BlXf-shc.js → transform-C1Rmuzlt.js} +2 -4
  43. package/dist/{transform-BlXf-shc.js.map → transform-C1Rmuzlt.js.map} +1 -1
  44. package/dist/venue-calendar.css +1 -1
  45. package/dist/venue-calendar.es.js +18 -18
  46. package/dist/venue-calendar.iife.js +31 -41
  47. package/dist/venue-calendar.iife.js.map +1 -1
  48. package/dist/venue-calendar.umd.js +24 -34
  49. package/dist/venue-calendar.umd.js.map +1 -1
  50. package/package.json +170 -170
  51. package/dist/CarouselView.legacy-DAixPl6l.js +0 -65
  52. package/dist/CarouselView.legacy-DAixPl6l.js.map +0 -1
  53. package/dist/CartView-CsdqWB24.js +0 -1744
  54. package/dist/CartView-CsdqWB24.js.map +0 -1
  55. package/dist/Checkout-B15JygVy.js.map +0 -1
  56. package/dist/Checkout-CUwOrErt.js +0 -831
  57. package/dist/Checkout-CUwOrErt.js.map +0 -1
  58. package/dist/Checkout.legacy-CrFgAYYe.js +0 -1156
  59. package/dist/Checkout.legacy-CrFgAYYe.js.map +0 -1
  60. package/dist/CollectionView-D2bRelLR.js +0 -338
  61. package/dist/CollectionView-D2bRelLR.js.map +0 -1
  62. package/dist/CollectionView.legacy-DLb5fzi-.js +0 -241
  63. package/dist/CollectionView.legacy-DLb5fzi-.js.map +0 -1
  64. package/dist/Event-DZpU-Ec1.js.map +0 -1
  65. package/dist/EventPage-CL0yuKWZ.js +0 -577
  66. package/dist/EventPage-CL0yuKWZ.js.map +0 -1
  67. package/dist/EventPage.legacy-EujdNc3A.js +0 -1324
  68. package/dist/EventPage.legacy-EujdNc3A.js.map +0 -1
  69. package/dist/FeaturedView.legacy-CbLBD-tn.js +0 -128
  70. package/dist/FeaturedView.legacy-CbLBD-tn.js.map +0 -1
  71. package/dist/GalleryCard-BcIcYghD.js +0 -93
  72. package/dist/GalleryCard-BcIcYghD.js.map +0 -1
  73. package/dist/GalleryView.legacy-XpQUg-5_.js +0 -52
  74. package/dist/GalleryView.legacy-XpQUg-5_.js.map +0 -1
  75. package/dist/GroupedListView.legacy-qvwIV5Qm.js +0 -145
  76. package/dist/GroupedListView.legacy-qvwIV5Qm.js.map +0 -1
  77. package/dist/OrderSummarySkeleton-pqfhjvKT.js +0 -632
  78. package/dist/OrderSummarySkeleton-pqfhjvKT.js.map +0 -1
  79. package/dist/ScarcityBadge-BkRFHRif.js +0 -77
  80. package/dist/ScarcityBadge-BkRFHRif.js.map +0 -1
  81. package/dist/SeriesPage-NWCA_Aez.js +0 -54
  82. package/dist/SeriesPage-NWCA_Aez.js.map +0 -1
  83. package/dist/SeriesPage.legacy-BXSwM5jV.js +0 -193
  84. package/dist/SeriesPage.legacy-BXSwM5jV.js.map +0 -1
  85. package/dist/Success-B4CM_cy1.js +0 -748
  86. package/dist/Success.legacy-BWAmPmZz.js +0 -192
  87. package/dist/Success.legacy-BWAmPmZz.js.map +0 -1
  88. package/dist/VenueCalendar-DMSeDRSN.js.map +0 -1
  89. package/dist/__SKIP_NAVIGATION__-CmipjatL.js +0 -18
  90. package/dist/__SKIP_NAVIGATION__-CmipjatL.js.map +0 -1
  91. package/dist/api-ChzBkXfo.js +0 -6
  92. package/dist/api-ChzBkXfo.js.map +0 -1
  93. package/dist/colors-CmP-sSZD.js +0 -56
  94. package/dist/colors-CmP-sSZD.js.map +0 -1
@@ -1,52 +0,0 @@
1
- import "svelte/internal/disclose-version";
2
- import * as e from "svelte/internal/client";
3
- import { onMount as C, onDestroy as M } from "svelte";
4
- import { G as x } from "./GalleryCard-BcIcYghD.js";
5
- import { aI as k } from "./VenueCalendar-DMSeDRSN.js";
6
- var w = e.from_html('<li class="list-none"><!></li>'), E = e.from_html('<div class="flex items-center justify-center gap-2 py-2 p-6" role="status" aria-live="polite"><span class="text-sm text-muted-foreground">Loading more events...</span></div>'), G = e.from_html('<section class="w-full" aria-label="Events gallery"><h2 class="sr-only svelte-lb0ck7">Upcoming events</h2> <ul class="grid grid-cols-1 gap-4 bg-bg-secondary p-2 sm:grid-cols-2 sm:gap-4 sm:p-3 md:grid-cols-3 md:gap-5 md:p-4 lg:grid-cols-4 lg:gap-6 lg:p-5" role="list"></ul> <!></section>');
7
- function D(v, i) {
8
- e.push(i, !0);
9
- let p = e.prop(i, "events", 19, () => []), m = e.prop(i, "initialCount", 3, 12), u = e.prop(i, "loadMoreCount", 3, 12), s = m(), o, t, g = e.derived(() => k(p())), f = e.derived(() => e.get(g).slice(0, s)), c = e.derived(() => s < e.get(g).length);
10
- function h() {
11
- s += u();
12
- }
13
- C(() => {
14
- t = new IntersectionObserver(
15
- (r) => {
16
- r[0].isIntersecting && e.get(c) && h();
17
- },
18
- { rootMargin: "100px" }
19
- ), o && t.observe(o);
20
- }), M(() => {
21
- t && t.disconnect();
22
- }), e.user_effect(() => {
23
- t && o && (t.disconnect(), t.observe(o));
24
- });
25
- var a = G(), d = e.sibling(e.child(a), 2);
26
- e.each(d, 21, () => e.get(f), e.index, (r, n) => {
27
- var l = w(), _ = e.child(l);
28
- x(_, {
29
- get event() {
30
- return e.get(n);
31
- },
32
- get oneventClick() {
33
- return i.oneventClick;
34
- }
35
- }), e.reset(l), e.append(r, l);
36
- }), e.reset(d);
37
- var y = e.sibling(d, 2);
38
- {
39
- var b = (r) => {
40
- var n = E();
41
- e.bind_this(n, (l) => o = l, () => o), e.append(r, n);
42
- };
43
- e.if(y, (r) => {
44
- e.get(c) && r(b);
45
- });
46
- }
47
- e.reset(a), e.append(v, a), e.pop();
48
- }
49
- export {
50
- D as default
51
- };
52
- //# sourceMappingURL=GalleryView.legacy-XpQUg-5_.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"GalleryView.legacy-XpQUg-5_.js","sources":["../src/components/Calendar/GalleryView.legacy.svelte"],"sourcesContent":["<script>\r\n // @ts-nocheck legacy fallback (legacy=1 path), slated for deletion after VC finalization — not type-maintained\r\n import { onMount, onDestroy } 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 = [], initialCount = 12, loadMoreCount = 12, oneventClick } = $props();\r\n\r\n let displayedCount = initialCount;\r\n let loadMoreTrigger;\r\n let observer;\r\n\r\n // Filter to today and future, sorted chronologically\r\n let futureEvents = $derived(filterTodayAndFuture(events));\r\n let displayedEvents = $derived(futureEvents.slice(0, displayedCount));\r\n let hasMore = $derived(displayedCount < futureEvents.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</script>\r\n\r\n<section class=\"w-full\" aria-label=\"Events gallery\">\r\n <h2 class=\"sr-only\">Upcoming events</h2>\r\n <ul class=\"grid grid-cols-1 gap-4 bg-bg-secondary p-2 sm:grid-cols-2 sm:gap-4 sm:p-3 md:grid-cols-3 md:gap-5 md:p-4 lg:grid-cols-4 lg:gap-6 lg:p-5\" role=\"list\">\r\n {#each displayedEvents as event}\r\n <li class=\"list-none\">\r\n <GalleryCard {event} {oneventClick} />\r\n </li>\r\n {/each}\r\n </ul>\r\n\r\n <!-- Infinite scroll trigger -->\r\n {#if hasMore}\r\n <div bind:this={loadMoreTrigger} class=\"flex items-center justify-center gap-2 py-2 p-6\" role=\"status\" aria-live=\"polite\">\r\n <span class=\"text-sm text-muted-foreground\">Loading more events...</span>\r\n </div>\r\n {/if}\r\n</section>\r\n\r\n<style>\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","initialCount","loadMoreCount","displayedCount","loadMoreTrigger","observer","futureEvents","filterTodayAndFuture","displayedEvents","hasMore","loadMore","onMount","entries","onDestroy","section","root_2","ul","$$anchor","event","li","root","GalleryCard","node","div","root_1","$$value","$$render","consequent"],"mappings":";;;;;;iBAAA;;AAME,MAAIA,IAAQC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GAAOC,iCAAe,EAAE,GAAEC,kCAAgB,EAAE,GAEpDC,IAAiBF,EAAY,GAC7BG,GACAC,GAGAC,IAAYP,EAAA,QAAA,MAAYQ,EAAqBT,EAAM,CAAA,CAAA,GACnDU,0BAA2BF,CAAY,EAAC,MAAM,GAAGH,CAAc,CAAA,GAC/DM,IAAOV,EAAA,QAAA,MAAYI,IAAcJ,EAAA,IAAGO,CAAY,EAAC,MAAM;AAE3D,WAASI,IAAW;AAClB,IAAAP,KAAkBD,EAAa;AAAA,EACjC;AAEA,EAAAS,QAAc;AACZ,IAAAN,IAAW,IAAI;AAAA,MACZ,CAAAO,MAAY;AACX,QAAIA,EAAQ,CAAC,EAAE,kBAAcb,EAAA,IAAIU,CAAO,KACtCC,EAAQ;AAAA,MAEZ;AAAA,MACE,EAAA,YAAY,QAAO;AAAA,OAGnBN,KACFC,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC,GAEDS,QAAgB;AACd,IAAIR,KACFA,EAAS,WAAU;AAAA,EAEvB,CAAC,GAGDN,EAAA,kBAAc;AACZ,IAAIM,KAAYD,MACdC,EAAS,WAAU,GACnBA,EAAS,QAAQD,CAAe;AAAA,EAEpC,CAAC;MAGFU,IAAOC,EAAA,GAELC,sBAFFF,CAAO,GAAA,CAAA;SAELE,GAAE,IAAA,MAAAjB,EAAA,IACMS,CAAe,GAAAT,EAAA,OAAA,CAAAkB,GAAIC,MAAK;QAC5BC,IAAEC,EAAA,eAAFD,CAAE;AACA,IAAAE,EAAWC,GAAA;AAAA;qBAAEJ,CAAK;AAAA;;;;gBADpBC,CAAE,eAAFA,CAAE;AAAA,cAFNH,CAAE;oBAAFA,GAAE,CAAA;;;UAUAO,IAAGC,EAAA;kBAAHD,GAAG,CAAAE,MAAYrB,IAAeqB,GAAA,MAAfrB,CAAe,eAA9BmB,CAAG;AAAA;;YADDd,CAAO,KAAAiB,EAAAC,CAAA;AAAA;;UAXbb,CAAO,eAAPA,CAAO;AAFA;"}
@@ -1,145 +0,0 @@
1
- import "svelte/internal/disclose-version";
2
- import * as e from "svelte/internal/client";
3
- import { onMount as te, onDestroy as ae } from "svelte";
4
- import { aI as re, b0 as se, b1 as ie, b2 as le, P as ne, a9 as F, O as I } from "./VenueCalendar-DMSeDRSN.js";
5
- import { S as oe } from "./ScarcityBadge-BkRFHRif.js";
6
- var de = e.from_html('<div class="w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-bg-secondary border-r border-border max-sm:w-12 max-sm:min-w-12 max-sm:py-2.5 max-sm:px-1.5" aria-hidden="true"><span class="text-xs font-semibold text-text-secondary uppercase tracking-tight"> </span> <span class="text-2xl max-sm:text-lg font-bold text-text-primary leading-tight"> </span> <span class="text-xs font-semibold text-text-secondary uppercase tracking-tight"> </span></div>'), me = e.from_html('<p class="event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden svelte-r2wh13"> </p>'), ce = e.from_html("<span> </span>"), fe = e.from_html('<li class="list-none"><div tabindex="0" role="button"><div class="w-36 h-24 min-w-36 max-sm:w-20 max-sm:h-16 max-sm:min-w-20 rounded-lg overflow-hidden bg-bg-secondary flex items-center justify-center" aria-hidden="true"><img alt="" class="w-full h-full object-contain svelte-r2wh13" loading="lazy"/></div> <div class="flex-1 flex flex-col gap-1.5 min-w-0" aria-hidden="true"><h3 class="text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug"> </h3> <time class="text-sm max-sm:text-xs font-medium text-text-secondary"> </time> <!></div> <div class="flex items-start pt-0.5" aria-hidden="true"><!></div></div></li>'), ge = e.from_html('<div class="date-group flex border-b border-border last:border-b-0 svelte-r2wh13" role="group"><!> <ul class="events-column flex-1 flex flex-col list-none p-0 m-0 svelte-r2wh13"></ul></div>'), ve = e.from_html('<div class="flex justify-center items-center p-6 text-text-secondary" role="status" aria-live="polite"><span class="text-sm">Loading more events...</span></div>'), ue = e.from_html('<section aria-label="Event listings"><h2 class="sr-only svelte-r2wh13">Event list grouped by date</h2> <!> <!></section>');
7
- function _e(L, m) {
8
- e.push(m, !0);
9
- let k = e.prop(m, "events", 19, () => []), P = e.prop(m, "initialCount", 3, 10), U = e.prop(m, "loadMoreCount", 3, 10), T = e.prop(m, "showDateColumn", 3, !0), A = e.prop(m, "filterFutureOnly", 3, !0), _ = P(), v, c, E = e.derived(() => A() ? re(k()) : k()), B = e.derived(() => R(e.get(E).slice(0, _))), C = e.derived(() => _ < e.get(E).length);
10
- function G() {
11
- _ += U();
12
- }
13
- te(() => {
14
- c = new IntersectionObserver(
15
- (r) => {
16
- r[0].isIntersecting && e.get(C) && G();
17
- },
18
- { rootMargin: "100px" }
19
- ), v && c.observe(v);
20
- }), ae(() => {
21
- c && c.disconnect();
22
- }), e.user_effect(() => {
23
- c && v && (c.disconnect(), c.observe(v));
24
- });
25
- function R(r) {
26
- const a = {};
27
- for (const s of r) {
28
- const n = s.date;
29
- a[n] || (a[n] = []), a[n].push(s);
30
- }
31
- return Object.entries(a).sort(([s], [n]) => new Date(s) - new Date(n)).map(([s, n]) => ({ date: s, events: n, formattedDate: K(n) }));
32
- }
33
- function K(r) {
34
- const a = r[0];
35
- if (!a?.startDateTime) return { month: "", day: "", weekday: "" };
36
- const s = se(a.startDateTime, a.timeZone);
37
- return {
38
- month: s.month.toUpperCase(),
39
- day: String(s.date).padStart(2, "0"),
40
- weekday: s.day.toUpperCase()
41
- };
42
- }
43
- function M(r) {
44
- m.oneventClick?.(r);
45
- }
46
- function z(r, a) {
47
- (r.key === "Enter" || r.key === " ") && (r.preventDefault(), M(a));
48
- }
49
- var b = ue();
50
- let O;
51
- var S = e.sibling(e.child(b), 2);
52
- e.each(S, 17, () => e.get(B), e.index, (r, a) => {
53
- var s = ge(), n = e.child(s);
54
- {
55
- var q = (f) => {
56
- var t = de(), o = e.child(t), y = e.child(o, !0);
57
- e.reset(o);
58
- var g = e.sibling(o, 2), d = e.child(g, !0);
59
- e.reset(g);
60
- var u = e.sibling(g, 2), p = e.child(u, !0);
61
- e.reset(u), e.reset(t), e.template_effect(() => {
62
- e.set_text(y, e.get(a).formattedDate.month), e.set_text(d, e.get(a).formattedDate.day), e.set_text(p, e.get(a).formattedDate.weekday);
63
- }), e.append(f, t);
64
- };
65
- e.if(n, (f) => {
66
- T() && f(q);
67
- });
68
- }
69
- var j = e.sibling(n, 2);
70
- e.each(j, 21, () => e.get(a).events, e.index, (f, t) => {
71
- const o = e.derived(() => ie(e.get(t))), y = e.derived(() => le(e.get(o)));
72
- var g = fe(), d = e.child(g);
73
- let u;
74
- var p = e.child(d), J = e.child(p);
75
- e.reset(p);
76
- var w = e.sibling(p, 2), D = e.child(w), N = e.child(D, !0);
77
- e.reset(D);
78
- var h = e.sibling(D, 2), Q = e.child(h, !0);
79
- e.reset(h);
80
- var W = e.sibling(h, 2);
81
- {
82
- var X = (i) => {
83
- var l = me(), x = e.child(l, !0);
84
- e.reset(l), e.template_effect(() => e.set_text(x, e.get(t).description)), e.append(i, l);
85
- };
86
- e.if(W, (i) => {
87
- e.get(t).description && i(X);
88
- });
89
- }
90
- e.reset(w);
91
- var Z = e.sibling(w, 2), Y = e.child(Z);
92
- {
93
- var $ = (i) => {
94
- var l = ce(), x = e.child(l, !0);
95
- e.reset(l), e.template_effect(() => {
96
- e.set_class(l, 1, `status-badge status-${e.get(o).type ?? ""}`, "svelte-r2wh13"), e.set_text(x, e.get(o).text);
97
- }), e.append(i, l);
98
- }, ee = (i) => {
99
- {
100
- let l = e.derived(() => e.get(t).ticketsRemaining ?? 0), x = e.derived(() => e.get(t).ticketsTotal ?? 0);
101
- oe(i, {
102
- get remaining() {
103
- return e.get(l);
104
- },
105
- get total() {
106
- return e.get(x);
107
- },
108
- context: "browse"
109
- });
110
- }
111
- };
112
- e.if(Y, (i) => {
113
- e.get(o) ? i($) : (e.get(t).ticketsTotal > 0 || e.get(t).ticketsRemaining === 0) && i(ee, 1);
114
- });
115
- }
116
- e.reset(Z), e.reset(d), e.reset(g), e.template_effect(
117
- (i, l) => {
118
- u = e.set_class(d, 1, "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 svelte-r2wh13", null, u, { "row-unavailable": e.get(y) }), e.set_attribute(d, "aria-label", i), e.set_attribute(J, "src", e.get(t).image || ne), e.set_text(N, e.get(t).name), e.set_attribute(h, "datetime", e.get(t).startDateTime || e.get(a).date), e.set_text(Q, l);
119
- },
120
- [
121
- () => `${e.get(t).name} on ${e.get(t).startDateTime ? F(e.get(t).startDateTime, e.get(t).timeZone) : e.get(a).date} at ${e.get(t).startDateTime ? I(e.get(t).startDateTime, e.get(t).timeZone) : ""}, ${e.get(o)?.text || e.get(t).status || "On Sale"}. Press Enter to view details.`,
122
- () => e.get(t).startDateTime ? I(e.get(t).startDateTime, e.get(t).timeZone) : ""
123
- ]
124
- ), e.delegated("click", d, () => M(e.get(t))), e.delegated("keydown", d, (i) => z(i, e.get(t))), e.append(f, g);
125
- }), e.reset(j), e.reset(s), e.template_effect((f) => e.set_attribute(s, "aria-label", `Events on ${f ?? ""}`), [
126
- () => e.get(a).events[0]?.startDateTime ? F(e.get(a).events[0].startDateTime, e.get(a).events[0].timeZone) : e.get(a).date
127
- ]), e.append(r, s);
128
- });
129
- var H = e.sibling(S, 2);
130
- {
131
- var V = (r) => {
132
- var a = ve();
133
- e.bind_this(a, (s) => v = s, () => v), e.append(r, a);
134
- };
135
- e.if(H, (r) => {
136
- e.get(C) && r(V);
137
- });
138
- }
139
- e.reset(b), e.template_effect(() => O = e.set_class(b, 1, "flex flex-col gap-0 svelte-r2wh13", null, O, { "no-date-column": !T() })), e.append(L, b), e.pop();
140
- }
141
- e.delegate(["click", "keydown"]);
142
- export {
143
- _e as default
144
- };
145
- //# sourceMappingURL=GroupedListView.legacy-qvwIV5Qm.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"GroupedListView.legacy-qvwIV5Qm.js","sources":["../src/components/Calendar/GroupedListView.legacy.svelte"],"sourcesContent":["<script>\r\n // @ts-nocheck legacy fallback (legacy=1 path), slated for deletion after VC finalization — not type-maintained\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 } = $props();\r\n\r\n let displayedCount = initialCount;\r\n let loadMoreTrigger;\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=\"Event listings\">\r\n <h2 class=\"sr-only\">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 || 'On Sale'}. 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 />\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\">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) / 10%);\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) / 10%);\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) / 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"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root_6","node","group","div","root_4","div_1","root","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_1","text_5","consequent_1","div_5","span_3","root_2","text_6","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_3","formatFullDate","formatEventTime","div_6","root_5","$$value","consequent_4","classes"],"mappings":"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"}