@getmicdrop/venue-calendar 4.0.46 → 4.0.47

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 (53) hide show
  1. package/dist/{CarouselView.legacy-D-zALoga.js → CarouselView.legacy-BhQhihsJ.js} +3 -3
  2. package/dist/{CarouselView.legacy-D-zALoga.js.map → CarouselView.legacy-BhQhihsJ.js.map} +1 -1
  3. package/dist/{CartView-DkxrA2Fd.js → CartView-D7dkTShT.js} +38 -40
  4. package/dist/{CartView-DkxrA2Fd.js.map → CartView-D7dkTShT.js.map} +1 -1
  5. package/dist/{Checkout-DhFLKly_.js → Checkout-C6RRUmtO.js} +4 -4
  6. package/dist/{Checkout-DhFLKly_.js.map → Checkout-C6RRUmtO.js.map} +1 -1
  7. package/dist/{Checkout-DBaJEzYJ.js → Checkout-DMuiqS05.js} +5 -5
  8. package/dist/{Checkout-DBaJEzYJ.js.map → Checkout-DMuiqS05.js.map} +1 -1
  9. package/dist/{Checkout.legacy-BC2N73uU.js → Checkout.legacy-6dBBM4RC.js} +4 -4
  10. package/dist/{Checkout.legacy-BC2N73uU.js.map → Checkout.legacy-6dBBM4RC.js.map} +1 -1
  11. package/dist/{CheckoutTimer-B03Dz0RS.js → CheckoutTimer-BspCv_uj.js} +2 -2
  12. package/dist/{CheckoutTimer-B03Dz0RS.js.map → CheckoutTimer-BspCv_uj.js.map} +1 -1
  13. package/dist/{CollectionView-Csi0WCC7.js → CollectionView-7v9vlibR.js} +5 -5
  14. package/dist/{CollectionView-Csi0WCC7.js.map → CollectionView-7v9vlibR.js.map} +1 -1
  15. package/dist/{CollectionView.legacy-B2aQ7pUX.js → CollectionView.legacy-BnpWHstC.js} +3 -3
  16. package/dist/{CollectionView.legacy-B2aQ7pUX.js.map → CollectionView.legacy-BnpWHstC.js.map} +1 -1
  17. package/dist/{Event-0Eq2doPK.js → Event-bhTqHV_2.js} +3 -3
  18. package/dist/{Event-0Eq2doPK.js.map → Event-bhTqHV_2.js.map} +1 -1
  19. package/dist/{EventDetailsView-B3NjmCKj.js → EventDetailsView-0oKsmxfN.js} +41 -44
  20. package/dist/EventDetailsView-0oKsmxfN.js.map +1 -0
  21. package/dist/{FeaturedView.legacy-eHHU2dOf.js → FeaturedView.legacy-CHfs0YPT.js} +2 -2
  22. package/dist/{FeaturedView.legacy-eHHU2dOf.js.map → FeaturedView.legacy-CHfs0YPT.js.map} +1 -1
  23. package/dist/{GalleryCard-DGZXM8kt.js → GalleryCard-CqgjvH5a.js} +2 -2
  24. package/dist/{GalleryCard-DGZXM8kt.js.map → GalleryCard-CqgjvH5a.js.map} +1 -1
  25. package/dist/{GalleryView.legacy-G_52n5RT.js → GalleryView.legacy-BtxbUVJ9.js} +3 -3
  26. package/dist/{GalleryView.legacy-G_52n5RT.js.map → GalleryView.legacy-BtxbUVJ9.js.map} +1 -1
  27. package/dist/{GroupedListView.legacy-BP9vJEZD.js → GroupedListView.legacy-CDPTkF0L.js} +2 -2
  28. package/dist/{GroupedListView.legacy-BP9vJEZD.js.map → GroupedListView.legacy-CDPTkF0L.js.map} +1 -1
  29. package/dist/{SeriesPage-BrUvWjWu.js → SeriesPage-DVh54STJ.js} +5 -5
  30. package/dist/{SeriesPage-BrUvWjWu.js.map → SeriesPage-DVh54STJ.js.map} +1 -1
  31. package/dist/{SeriesPage.legacy-Co104sE7.js → SeriesPage.legacy-BCr3x7-A.js} +2 -2
  32. package/dist/{SeriesPage.legacy-Co104sE7.js.map → SeriesPage.legacy-BCr3x7-A.js.map} +1 -1
  33. package/dist/{Success-DlB6kX9c.js → Success-CLLPGGuR.js} +6 -6
  34. package/dist/{Success-DlB6kX9c.js.map → Success-CLLPGGuR.js.map} +1 -1
  35. package/dist/{Success.legacy-zRXio4EE.js → Success.legacy-D_lBTHkg.js} +2 -2
  36. package/dist/{Success.legacy-zRXio4EE.js.map → Success.legacy-D_lBTHkg.js.map} +1 -1
  37. package/dist/{VenueCalendar-BkRqSb_t.js → VenueCalendar-DFfEZMyW.js} +14 -14
  38. package/dist/{VenueCalendar-BkRqSb_t.js.map → VenueCalendar-DFfEZMyW.js.map} +1 -1
  39. package/dist/{ViewTicketsEmbed-BvGGkM9j.js → ViewTicketsEmbed-B0uv-JHs.js} +2 -2
  40. package/dist/{ViewTicketsEmbed-BvGGkM9j.js.map → ViewTicketsEmbed-B0uv-JHs.js.map} +1 -1
  41. package/dist/{data-toggle-store.svelte-CitSx2Ty.js → data-toggle-store.svelte-WHLIXMim.js} +2 -2
  42. package/dist/{data-toggle-store.svelte-CitSx2Ty.js.map → data-toggle-store.svelte-WHLIXMim.js.map} +1 -1
  43. package/dist/{labels-8o7WS2MO.js → labels-D85LcGba.js} +2 -2
  44. package/dist/{labels-8o7WS2MO.js.map → labels-D85LcGba.js.map} +1 -1
  45. package/dist/{transform-CVW2Zmpy.js → transform-II0DR2_f.js} +2 -2
  46. package/dist/{transform-CVW2Zmpy.js.map → transform-II0DR2_f.js.map} +1 -1
  47. package/dist/venue-calendar.es.js +1 -1
  48. package/dist/venue-calendar.iife.js +16 -16
  49. package/dist/venue-calendar.iife.js.map +1 -1
  50. package/dist/venue-calendar.umd.js +16 -16
  51. package/dist/venue-calendar.umd.js.map +1 -1
  52. package/package.json +1 -1
  53. package/dist/EventDetailsView-B3NjmCKj.js.map +0 -1
@@ -1,11 +1,11 @@
1
1
  import "svelte/internal/disclose-version";
2
- import { f as pe, B as K, L as Ke, T as Re, S as ut, i as gt, M as ft, C as pt, I as Ne, j as mt, g as ht, a as bt, c as _t, t as Ge, b as xt, d as wt, A as yt, e as Ue, h as kt, k as Et, l as Qe, W as Tt, F as Pt } from "./VenueCalendar-BkRqSb_t.js";
2
+ import { f as pe, B as K, L as Ye, T as Re, S as ut, i as gt, M as ft, C as pt, I as qe, j as mt, g as ht, a as bt, c as _t, t as Ne, b as xt, d as wt, A as yt, e as Ge, h as kt, k as Et, l as Ue, W as Tt, F as Pt } from "./VenueCalendar-DFfEZMyW.js";
3
3
  import * as e from "svelte/internal/client";
4
4
  import "svelte/internal/flags/legacy";
5
5
  import "svelte/transition";
6
6
  import "svelte/easing";
7
- import { onMount as Ze, onDestroy as We } from "svelte";
8
- import { g as He } from "./__SKIP_NAVIGATION__-CJ96TTPE.js";
7
+ import { onMount as Ke, onDestroy as Ze } from "svelte";
8
+ import { g as Qe } from "./__SKIP_NAVIGATION__-CJ96TTPE.js";
9
9
  var St = e.from_html('<span class="text-lg font-semibold text-text-primary"> </span>'), Ct = e.from_html('<span class="text-lg font-semibold text-text-primary"> </span>'), It = e.from_html('<span class="text-xs text-muted-foreground" aria-hidden="true"> </span>'), Dt = e.from_html('<div class="flex flex-col items-end gap-0.5"><!> <!></div>');
10
10
  function At(V, t) {
11
11
  e.push(t, !0);
@@ -51,7 +51,7 @@ function Lt(V) {
51
51
  e.append(V, t);
52
52
  }
53
53
  var zt = e.from_html('<div class="flex items-baseline gap-1.5"><span class="text-xl font-semibold text-text-primary"> </span> <span class="text-xs text-muted-foreground" aria-hidden="true"> </span></div>'), Rt = e.from_html('<div class="h-6 w-20 skeleton rounded" role="status" aria-busy="true"></div>'), Wt = e.from_html("<!> ", 1), jt = e.from_html('<div class="mobile-drawer flex items-center justify-between gap-4 px-4 py-3 safe-area-bottom svelte-yxa700" role="region"><div class="flex flex-col min-w-0"><span class="text-xs text-muted-foreground"> </span> <!></div> <div class="shrink-0"><!></div></div>'), Bt = e.from_html("<!> ", 1), Mt = e.from_html('<!> <div class="flex items-center justify-center gap-1.5 mt-3 text-color-tertiary" aria-hidden="true"><span class="caption"> </span></div>', 1), Ot = e.from_html('<!> <div class="flex items-center justify-center gap-1.5 mt-3 text-muted-foreground" aria-hidden="true"><!> <span class="text-xs"> </span></div>', 1), Vt = e.from_html('<div class="card p-5 mt-5" role="region"><div class="flex flex-col gap-3"><div class="flex items-center justify-between"><span class="text-sm text-muted-foreground"> </span> <!></div> <div><!></div></div></div>');
54
- function Ye(V, t) {
54
+ function He(V, t) {
55
55
  e.push(t, !0);
56
56
  let p = e.prop(t, "dataReady", 3, !1), S = e.prop(t, "availableTickets", 19, () => []), v = e.prop(t, "isMobileDrawer", 3, !1), r = e.prop(t, "isCancelled", 3, !1), s = e.prop(t, "purchasedTickets", 19, () => t.event.purchasedTickets || 0), u = e.prop(t, "waitlistEnabled", 3, !1), c = e.prop(t, "gated", 3, !1), n = e.prop(t, "onJoinWaitlist", 3, () => {
57
57
  }), a = e.prop(t, "labels", 19, () => ({}));
@@ -326,7 +326,7 @@ function Ye(V, t) {
326
326
  });
327
327
  }
328
328
  var b = e.sibling(T, 2), _ = e.child(b);
329
- Ke(_, { size: 16, "aria-hidden": "true" });
329
+ Ye(_, { size: 16, "aria-hidden": "true" });
330
330
  var F = e.sibling(_, 2), L = e.child(F, !0);
331
331
  e.reset(F), e.reset(b), e.template_effect(() => e.set_text(L, a().secureCheckout || "Secure checkout")), e.append(o, h);
332
332
  };
@@ -363,7 +363,7 @@ function qt(V, t) {
363
363
  }
364
364
  });
365
365
  var I = e.sibling(R, 2);
366
- Ye(I, {
366
+ He(I, {
367
367
  get event() {
368
368
  return t.event;
369
369
  },
@@ -396,7 +396,7 @@ function qt(V, t) {
396
396
  }
397
397
  }), e.reset(g);
398
398
  var E = e.sibling(g, 2), re = e.child(E);
399
- Ye(re, {
399
+ He(re, {
400
400
  get event() {
401
401
  return t.event;
402
402
  },
@@ -505,7 +505,7 @@ function $t(V, t) {
505
505
  var T = e.sibling(o, 2), b = e.child(T);
506
506
  {
507
507
  let y = e.derived(() => v().waitlistEmailPlaceholder || "you@example.com"), j = e.derived(() => e.get(d) ? "border-status-error-border" : "");
508
- Ne(b, {
508
+ qe(b, {
509
509
  id: "waitlist-email",
510
510
  type: "email",
511
511
  get placeholder() {
@@ -548,7 +548,7 @@ function $t(V, t) {
548
548
  var j = Ht(), $ = e.child(j);
549
549
  {
550
550
  let ce = e.derived(() => v().waitlistPhonePlaceholder || "(555) 123-4567"), ve = e.derived(() => e.get(C) ? "border-status-error-border" : "");
551
- Ne($, {
551
+ qe($, {
552
552
  id: "waitlist-phone",
553
553
  type: "tel",
554
554
  get placeholder() {
@@ -707,7 +707,7 @@ function sa(V, t) {
707
707
  const d = p()[a].id;
708
708
  r(d), document.getElementById(`tab-${d}`)?.focus();
709
709
  }
710
- Ze(() => {
710
+ Ke(() => {
711
711
  v = new IntersectionObserver(
712
712
  (c) => {
713
713
  c.forEach((n) => {
@@ -719,7 +719,7 @@ function sa(V, t) {
719
719
  const n = document.getElementById(c.id);
720
720
  n && v.observe(n);
721
721
  });
722
- }), We(() => {
722
+ }), Ze(() => {
723
723
  v && v.disconnect();
724
724
  });
725
725
  var u = ia();
@@ -805,17 +805,17 @@ function ka(V, t) {
805
805
  const i = new URLSearchParams(window.location.search);
806
806
  i.set("subroute", "calendar"), i.delete("event_id"), i.delete("slug");
807
807
  const l = `/?${i.toString()}`;
808
- He(l, {});
808
+ Qe(l, {});
809
809
  }
810
810
  }
811
811
  function me() {
812
812
  if (t.onNavigateToCart)
813
- t.onNavigateToCart(t.eventId, Qe(e.get(s)?.name || "event"));
813
+ t.onNavigateToCart(t.eventId, Ue(e.get(s)?.name || "event"));
814
814
  else {
815
815
  const i = new URLSearchParams(window.location.search);
816
- i.set("event_id", t.eventId), i.set("subroute", "cart"), i.set("slug", Qe(e.get(s)?.name || "event"));
816
+ i.set("event_id", t.eventId), i.set("subroute", "cart"), i.set("slug", Ue(e.get(s)?.name || "event"));
817
817
  const l = `/?${i.toString()}`;
818
- He(l, {});
818
+ Qe(l, {});
819
819
  }
820
820
  }
821
821
  function ge() {
@@ -848,11 +848,11 @@ function ka(V, t) {
848
848
  try {
849
849
  if (v()) {
850
850
  if (e.set(u, v()), !e.get(g)) return;
851
- e.set(s, Ge(e.get(u)), !0), e.set(d, h(e.get(u)?.showtimes || []), !0);
851
+ e.set(s, Ne(e.get(u)), !0), e.set(d, h(e.get(u)?.showtimes || []), !0);
852
852
  } else
853
853
  try {
854
854
  if (e.set(u, await xt(t.eventId), !0), !e.get(g)) return;
855
- e.set(s, Ge(e.get(u)), !0), e.set(d, h(e.get(u)?.showtimes || []), !0);
855
+ e.set(s, Ne(e.get(u)), !0), e.set(d, h(e.get(u)?.showtimes || []), !0);
856
856
  } catch (l) {
857
857
  ze.error("Event fetch failed:", l), e.set(n, r().failedToLoadEvent || "Failed to load event", !0), e.set(c, !1);
858
858
  return;
@@ -888,7 +888,7 @@ function ka(V, t) {
888
888
  function oe() {
889
889
  e.set(k, !1), de();
890
890
  }
891
- Ze(async () => {
891
+ Ke(async () => {
892
892
  if (e.set(g, !0), ge(), window.addEventListener("resize", ge), window.addEventListener("scroll", y), await $(), t.eventId) {
893
893
  const i = await ht(t.eventId);
894
894
  e.get(g) && e.set(f, i.gated, !0);
@@ -898,11 +898,8 @@ function ka(V, t) {
898
898
  const i = e.get(I).querySelector("img");
899
899
  i && e.set(x, i.offsetHeight, !0);
900
900
  }
901
- We(() => {
902
- window.removeEventListener("resize", ge), window.removeEventListener("scroll", y);
903
- });
904
- }), We(() => {
905
- e.set(g, !1);
901
+ }), Ze(() => {
902
+ e.set(g, !1), window.removeEventListener("resize", ge), window.removeEventListener("scroll", y);
906
903
  });
907
904
  var Te = pa(), le = e.first_child(Te), he = e.child(le), ce = e.child(he, !0);
908
905
  e.reset(he);
@@ -923,7 +920,7 @@ function ka(V, t) {
923
920
  {
924
921
  var ue = (m) => {
925
922
  var P = da(), Y = e.child(P), ee = e.child(Y), xe = e.child(ee);
926
- Ke(xe, { class: "w-12 h-12 text-muted-foreground" }), e.reset(ee);
923
+ Ye(xe, { class: "w-12 h-12 text-muted-foreground" }), e.reset(ee);
927
924
  var fe = e.sibling(ee, 2), we = e.child(fe, !0);
928
925
  e.reset(fe);
929
926
  var ye = e.sibling(fe, 2), ke = e.child(ye, !0);
@@ -958,23 +955,23 @@ function ka(V, t) {
958
955
  });
959
956
  }
960
957
  var ne = e.sibling(ie, 2);
961
- let Be;
958
+ let je;
962
959
  var Pe = e.child(ne), Ie = e.child(Pe), Se = e.sibling(Ie, 2), tt = e.child(Se);
963
960
  yt(tt, {
964
961
  class: "size-3.5 sm:size-5 text-white",
965
962
  "aria-hidden": "true"
966
963
  }), e.reset(Se), e.reset(Pe), e.bind_this(Pe, (m) => e.set(I, m), () => e.get(I));
967
- var Me = e.sibling(Pe, 2);
964
+ var Be = e.sibling(Pe, 2);
968
965
  {
969
966
  var at = (m) => {
970
967
  var P = ca();
971
968
  e.append(m, P);
972
969
  };
973
- e.if(Me, (m) => {
970
+ e.if(Be, (m) => {
974
971
  e.get(E) && m(at);
975
972
  });
976
973
  }
977
- var rt = e.sibling(Me, 2);
974
+ var rt = e.sibling(Be, 2);
978
975
  qt(rt, {
979
976
  get event() {
980
977
  return e.get(s);
@@ -1013,8 +1010,8 @@ function ka(V, t) {
1013
1010
  }
1014
1011
  }), e.reset(ne);
1015
1012
  var De = e.sibling(ne, 2);
1016
- let Oe;
1017
- var Ve = e.child(De), Ae = e.child(Ve), it = e.child(Ae);
1013
+ let Me;
1014
+ var Oe = e.child(De), Ae = e.child(Oe), it = e.child(Ae);
1018
1015
  sa(it, {
1019
1016
  get items() {
1020
1017
  return e.get(z);
@@ -1023,7 +1020,7 @@ function ka(V, t) {
1023
1020
  var Fe = e.sibling(Ae, 2), st = e.child(Fe);
1024
1021
  {
1025
1022
  let m = e.derived(() => r().tabAboutTheShow || "About the show");
1026
- Ue(st, {
1023
+ Ge(st, {
1027
1024
  ShowImage: "",
1028
1025
  get description() {
1029
1026
  return e.get(s).description;
@@ -1036,13 +1033,13 @@ function ka(V, t) {
1036
1033
  });
1037
1034
  }
1038
1035
  e.reset(Fe);
1039
- var Je = e.sibling(Fe, 2);
1036
+ var Ve = e.sibling(Fe, 2);
1040
1037
  {
1041
1038
  var lt = (m) => {
1042
1039
  var P = va(), Y = e.child(P), ee = e.child(Y, !0);
1043
1040
  e.reset(Y);
1044
1041
  var xe = e.sibling(Y, 2);
1045
- Ue(xe, {
1042
+ Ge(xe, {
1046
1043
  ShowImage: "",
1047
1044
  description: "",
1048
1045
  get performers() {
@@ -1051,11 +1048,11 @@ function ka(V, t) {
1051
1048
  showTitle: !1
1052
1049
  }), e.reset(P), e.template_effect(() => e.set_text(ee, r().tabFeaturing || "Featuring")), e.append(m, P);
1053
1050
  };
1054
- e.if(Je, (m) => {
1051
+ e.if(Ve, (m) => {
1055
1052
  e.get(G) && m(lt);
1056
1053
  });
1057
1054
  }
1058
- var qe = e.sibling(Je, 2);
1055
+ var Je = e.sibling(Ve, 2);
1059
1056
  {
1060
1057
  var nt = (m) => {
1061
1058
  var P = ua(), Y = e.child(P);
@@ -1065,11 +1062,11 @@ function ka(V, t) {
1065
1062
  }
1066
1063
  }), e.reset(P), e.append(m, P);
1067
1064
  };
1068
- e.if(qe, (m) => {
1065
+ e.if(Je, (m) => {
1069
1066
  e.get(_).length && m(nt);
1070
1067
  });
1071
1068
  }
1072
- var dt = e.sibling(qe, 2);
1069
+ var dt = e.sibling(Je, 2);
1073
1070
  {
1074
1071
  var ot = (m) => {
1075
1072
  var P = ga(), Y = e.child(P);
@@ -1087,12 +1084,12 @@ function ka(V, t) {
1087
1084
  e.get(L).length && m(ot);
1088
1085
  });
1089
1086
  }
1090
- e.reset(Ve), e.next(2), e.reset(De), e.reset(l), e.template_effect(
1087
+ e.reset(Oe), e.next(2), e.reset(De), e.reset(l), e.template_effect(
1091
1088
  (m) => {
1092
- Be = e.set_class(ne, 1, "flex-1 flex flex-col lg:flex-row w-full gap-7 relative svelte-abxi04", null, Be, {
1089
+ je = e.set_class(ne, 1, "flex-1 flex flex-col lg:flex-row w-full gap-7 relative svelte-abxi04", null, je, {
1093
1090
  "blur-content": e.get(O),
1094
1091
  "cancelled-content": e.get(Z)
1095
- }), e.set_attribute(Ie, "src", m), e.set_attribute(Ie, "alt", e.get(s).name ? (r().eventPoster || "Event poster") + " — " + e.get(s).name : r().eventPoster || "Event poster"), e.set_attribute(Se, "aria-label", r().goBackToCalendar || "Go back to calendar"), Oe = e.set_class(De, 1, "flex-1 flex flex-col lg:flex-row w-full gap-7 svelte-abxi04", null, Oe, {
1092
+ }), e.set_attribute(Ie, "src", m), e.set_attribute(Ie, "alt", e.get(s).name ? (r().eventPoster || "Event poster") + " — " + e.get(s).name : r().eventPoster || "Event poster"), e.set_attribute(Se, "aria-label", r().goBackToCalendar || "Go back to calendar"), Me = e.set_class(De, 1, "flex-1 flex flex-col lg:flex-row w-full gap-7 svelte-abxi04", null, Me, {
1096
1093
  "blur-content": e.get(O),
1097
1094
  "cancelled-content": e.get(Z)
1098
1095
  });
@@ -1107,10 +1104,10 @@ function ka(V, t) {
1107
1104
  });
1108
1105
  }
1109
1106
  e.reset(le), e.bind_this(le, (i) => e.set(R, i), () => e.get(R));
1110
- var je = e.sibling(le, 2);
1107
+ var We = e.sibling(le, 2);
1111
1108
  {
1112
1109
  let i = e.derived(() => r().enterEventPassword || "Enter event password"), l = e.derived(() => r().passwordModalDescription || "This event requires a password to view. Please enter the password provided by the event organizer."), H = e.derived(() => r().passwordLabel || "Password"), ue = e.derived(() => !!e.get(W)), ie = e.derived(() => r().unlockEvent || "Unlock event"), _e = e.derived(() => r().goBack || "Go back");
1113
- bt(je, {
1110
+ bt(We, {
1114
1111
  size: "md",
1115
1112
  get title() {
1116
1113
  return e.get(i);
@@ -1155,7 +1152,7 @@ function ka(V, t) {
1155
1152
  }
1156
1153
  });
1157
1154
  }
1158
- var et = e.sibling(je, 2);
1155
+ var et = e.sibling(We, 2);
1159
1156
  {
1160
1157
  let i = e.derived(() => e.get(s)?.name || "this event");
1161
1158
  $t(et, {
@@ -1185,4 +1182,4 @@ e.delegate(["click"]);
1185
1182
  export {
1186
1183
  ka as default
1187
1184
  };
1188
- //# sourceMappingURL=EventDetailsView-B3NjmCKj.js.map
1185
+ //# sourceMappingURL=EventDetailsView-0oKsmxfN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EventDetailsView-0oKsmxfN.js","sources":["../src/components/Events/Details/PriceTag.svelte","../src/components/Events/Details/PriceTagSkeleton.svelte","../src/components/Events/Details/TicketActions.svelte","../src/components/Events/Details/StickySidebar.svelte","../src/components/Modals/WaitlistModal.svelte","../src/components/Events/Details/Disclaimer.svelte","../src/components/Tab/+page.svelte","../src/components/Views/EventDetailsView.svelte"],"sourcesContent":["<script>\r\n import { formatCurrency } from '@getmicdrop/svelte-components';\r\nlet {\r\n price,\r\n fee,\r\n tickets,\r\n labels = {},\r\n } = $props();\r\n\r\n const onlyOneFreeTicket = $derived(\r\n tickets.length === 1 && parseFloat(tickets[0].price) === 0\r\n );\r\n</script>\r\n\r\n<div class=\"flex flex-col items-end gap-0.5\" aria-label=\"Ticket price: {price === 0 ? (onlyOneFreeTicket ? (labels.free || 'Free') : '$0.00') : `${formatCurrency(price /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}`}{fee > 0 ? `, ${(labels.includingFee || 'including {fee} service fee').replace('{fee}', formatCurrency(fee /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */))}` : ''}\">\r\n {#if price === 0}\r\n <span class=\"text-lg font-semibold text-text-primary\">\r\n {onlyOneFreeTicket ? (labels.free || 'Free') : '$0.00'}\r\n </span>\r\n {:else}\r\n <span class=\"text-lg font-semibold text-text-primary\">\r\n {formatCurrency(price /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\r\n </span>\r\n {/if}\r\n\r\n {#if fee > 0}\r\n <span class=\"text-xs text-muted-foreground\" aria-hidden=\"true\">\r\n {(labels.inclFee || 'incl. {fee} fee').replace('{fee}', formatCurrency(fee /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */))}\r\n </span>\r\n {/if}\r\n</div>\r\n","<div class=\"flex items-center gap-2 animate-pulse\" role=\"status\" aria-busy=\"true\" aria-label=\"Loading price\">\r\n <span class=\"sr-only\">Loading price...</span>\r\n <div class=\"h-5 w-16 rounded-md bg-bg-tertiary\" aria-hidden=\"true\"></div>\r\n <div class=\"h-3 w-12 rounded-md bg-muted\" aria-hidden=\"true\"></div>\r\n</div>\r\n\r\n<style>\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 PriceTag from './PriceTag.svelte';\r\n import PriceTagSkeleton from './PriceTagSkeleton.svelte';\r\n import { Button, formatCurrency } from '@getmicdrop/svelte-components';\r\n import { Locked, Time } from 'carbon-icons-svelte';\r\n\r\n /** @type {{\r\n * dataReady?: boolean;\r\n * event: any;\r\n * ticketType: number;\r\n * availableTickets?: any[];\r\n * goToCheckout: (e: MouseEvent) => void;\r\n * isMobileDrawer?: boolean;\r\n * isCancelled?: boolean;\r\n * purchasedTickets?: number;\r\n * waitlistEnabled?: boolean;\r\n * gated?: boolean;\r\n * onJoinWaitlist?: (e: MouseEvent) => void;\r\n * labels?: Record<string, string>;\r\n * }} */\r\n let {\r\n dataReady = false,\r\n event,\r\n ticketType,\r\n availableTickets = [],\r\n goToCheckout,\r\n isMobileDrawer = false,\r\n isCancelled = false,\r\n purchasedTickets = event.purchasedTickets || 0,\r\n waitlistEnabled = false,\r\n gated = false,\r\n onJoinWaitlist = () => {},\r\n labels = {},\r\n } = $props();\r\n\r\n const visibleTickets = $derived(availableTickets.filter(\r\n t => t.visibility === 0\r\n ));\r\n\r\n const totalRemainingCapacity = $derived(visibleTickets.reduce(\r\n (acc, t) => acc + t.remainingCapacity,\r\n 0\r\n ));\r\n // Waitlist-only gating (decision #3): when the event is gated, present as\r\n // sold-out to non-members even if tickets are technically available, so freed\r\n // inventory routes to notified waitlisters via their tokenized links.\r\n const isSoldOut = $derived(gated || purchasedTickets >= totalRemainingCapacity);\r\n const hasNoTickets = $derived(visibleTickets.length === 0);\r\n\r\n const basePrice = $derived(\r\n visibleTickets.length > 0\r\n ? Math.min(...visibleTickets.map(t => t.price))\r\n : 0\r\n );\r\n</script>\r\n\r\n{#if isMobileDrawer}\r\n <!-- Mobile drawer: compact horizontal layout -->\r\n <div class=\"mobile-drawer flex items-center justify-between gap-4 px-4 py-3 safe-area-bottom\" role=\"region\" aria-label={labels.ticketPurchase || \"Ticket purchase\"}>\r\n <div class=\"flex flex-col min-w-0\">\r\n <span class=\"text-xs text-muted-foreground\">{labels.from || 'From'}</span>\r\n {#if dataReady}\r\n <div class=\"flex items-baseline gap-1.5\" aria-label=\"Price: from {formatCurrency(basePrice /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\">\r\n <span class=\"text-xl font-semibold text-text-primary\">\r\n {formatCurrency(basePrice /* FIXME(canonical-cleanup:toFixed): heuristic guess — verify this is USD (not cents); when migrating to TS, add `as USD` brand cast at the API-response-transform layer. */)}\r\n </span>\r\n <span class=\"text-xs text-muted-foreground\" aria-hidden=\"true\">+ {labels.fees || 'fees'}</span>\r\n </div>\r\n {:else}\r\n <div class=\"h-6 w-20 skeleton rounded\" role=\"status\" aria-busy=\"true\" aria-label={labels.loadingPrice || \"Loading price\"}></div>\r\n {/if}\r\n </div>\r\n\r\n <div class=\"shrink-0\">\r\n {#if isCancelled}\r\n <Button variant=\"red-outline\" disabled aria-label={labels.eventCancelled || \"Event Cancelled\"}>{labels.eventCancelled || 'Event Cancelled'}</Button>\r\n {:else if hasNoTickets}\r\n <Button variant=\"red-outline\" disabled aria-label={labels.salesEnded || \"Sales Ended\"}>{labels.salesEnded || 'Sales Ended'}</Button>\r\n {:else if isSoldOut}\r\n {#if waitlistEnabled}\r\n <Button onclick={onJoinWaitlist} class=\"px-6 py-3 text-base font-semibold\" aria-label={labels.joinWaitlist || \"Join waitlist for this sold out event\"}>\r\n <Time size={16} class=\"mr-1.5\" aria-hidden=\"true\" />\r\n {labels.joinWaitlist || 'Join Waitlist'}\r\n </Button>\r\n {:else}\r\n <Button variant=\"alternative\" disabled aria-label={labels.soldOut || \"Sold Out\"}>{labels.soldOut || 'Sold Out'}</Button>\r\n {/if}\r\n {:else}\r\n <Button onclick={goToCheckout} class=\"px-6 py-3 text-base font-semibold\" aria-label={ticketType === 1 ? (labels.reserve || 'Reserve a spot for this event') : (labels.getTickets || 'Get tickets for this event')}>\r\n {ticketType === 1 ? (labels.reserve || 'Reserve') : (labels.getTickets || 'Get tickets')}\r\n </Button>\r\n {/if}\r\n </div>\r\n </div>\r\n{:else}\r\n <!-- Desktop: full layout with trust signals -->\r\n <div class=\"card p-5 mt-5\" role=\"region\" aria-label={labels.ticketPurchaseOptions || \"Ticket purchase options\"}>\r\n <div class=\"flex flex-col gap-3\">\r\n <div class=\"flex items-center justify-between\">\r\n <span class=\"text-sm text-muted-foreground\">{labels.startsFrom || 'Starts from'}</span>\r\n\r\n {#if dataReady}\r\n <PriceTag\r\n price={basePrice}\r\n fee={0}\r\n tickets={availableTickets}\r\n />\r\n {:else}\r\n <PriceTagSkeleton />\r\n {/if}\r\n </div>\r\n\r\n <div>\r\n {#if isCancelled}\r\n <Button size=\"lg\" variant=\"red-outline\" disabled aria-label={labels.eventCancelled || \"Event Cancelled\"}>{labels.eventCancelled || 'Event Cancelled'}</Button>\r\n {:else if hasNoTickets}\r\n <Button size=\"lg\" variant=\"red-outline\" disabled aria-label={labels.salesEnded || \"Sales Ended\"}>{labels.salesEnded || 'Sales Ended'}</Button>\r\n {:else if isSoldOut}\r\n {#if waitlistEnabled}\r\n <Button size=\"lg\" onclick={onJoinWaitlist} aria-label={labels.joinWaitlist || \"Join waitlist for this sold out event\"}>\r\n <Time size={16} class=\"mr-1.5\" aria-hidden=\"true\" />\r\n {labels.joinWaitlist || 'Join Waitlist'}\r\n </Button>\r\n <!-- Waitlist info -->\r\n <div class=\"flex items-center justify-center gap-1.5 mt-3 text-color-tertiary\" aria-hidden=\"true\">\r\n <span class=\"caption\">{labels.getNotifiedWhenAvailable || 'Get notified when tickets are available'}</span>\r\n </div>\r\n {:else}\r\n <Button size=\"lg\" variant=\"alternative\" disabled aria-label={labels.soldOut || \"Sold Out\"}>{labels.soldOut || 'Sold Out'}</Button>\r\n {/if}\r\n {:else}\r\n <Button size=\"lg\" onclick={goToCheckout} aria-label={ticketType === 1 ? (labels.reserveASpot || 'Reserve a spot for this event') : (labels.getTickets || 'Get tickets for this event')}>\r\n {ticketType === 1 ? (labels.reserveASpot || 'Reserve a spot') : (labels.getTickets || 'Get tickets')}\r\n </Button>\r\n <!-- Trust signal -->\r\n <div class=\"flex items-center justify-center gap-1.5 mt-3 text-muted-foreground\" aria-hidden=\"true\">\r\n <Locked size={16} aria-hidden=\"true\" />\r\n <span class=\"text-xs\">{labels.secureCheckout || 'Secure checkout'}</span>\r\n </div>\r\n {/if}\r\n </div>\r\n </div>\r\n </div>\r\n{/if}\r\n\r\n<style>\r\n .safe-area-bottom {\r\n padding-bottom: max(0.75rem, env(safe-area-inset-bottom));\r\n }\r\n</style>\r\n","<script>\r\n import { ShowCard } from '@getmicdrop/svelte-components';\r\n import TicketActions from './TicketActions.svelte';\r\n\r\n /** @type {{\r\n * dataReady?: boolean;\r\n * event: any;\r\n * showtimes?: any[];\r\n * ticketType: number;\r\n * availableTickets?: any[];\r\n * isSticky?: boolean;\r\n * sidebarLeft?: number;\r\n * goToCheckout: (e: MouseEvent) => void;\r\n * isCancelled?: boolean;\r\n * waitlistEnabled?: boolean;\r\n * gated?: boolean;\r\n * onJoinWaitlist?: (e: MouseEvent) => void;\r\n * labels?: Record<string, string>;\r\n * }} */\r\n let {\r\n dataReady = false,\r\n event,\r\n showtimes = [],\r\n ticketType,\r\n availableTickets = [],\r\n isSticky = false,\r\n sidebarLeft = 0,\r\n goToCheckout,\r\n isCancelled = false,\r\n waitlistEnabled = false,\r\n gated = false,\r\n onJoinWaitlist = () => {},\r\n labels = {},\r\n } = $props();\r\n</script>\r\n\r\n<!-- Desktop sidebar - hidden on mobile -->\r\n<aside\r\n class=\"hidden lg:flex w-80 flex-col transition-all duration-200 {isSticky ? 'fixed top-5 max-h-[calc(100vh-40px)] overflow-y-auto' : 'relative max-h-none overflow-visible'}\"\r\n style:left={isSticky ? `${sidebarLeft}px` : 'auto'}\r\n aria-label={labels.ariaEventBooking || \"Event booking\"}\r\n>\r\n <ShowCard {event} {showtimes} onShowtimeSelect={() => {}} />\r\n\r\n <TicketActions\r\n {event}\r\n {ticketType}\r\n {availableTickets}\r\n {goToCheckout}\r\n\r\n {dataReady}\r\n {isCancelled}\r\n {waitlistEnabled}\r\n {gated}\r\n {onJoinWaitlist}\r\n {labels}\r\n />\r\n</aside>\r\n\r\n<!-- Mobile sticky bottom CTA - only shows on mobile -->\r\n<div class=\"lg:hidden fixed bottom-0 left-0 right-0 z-50 bg-card border-t border-border shadow-xl\" role=\"region\" aria-label={labels.ariaGetTickets || \"Get tickets\"}>\r\n <TicketActions\r\n {event}\r\n {ticketType}\r\n {availableTickets}\r\n {goToCheckout}\r\n\r\n {dataReady}\r\n {isCancelled}\r\n {waitlistEnabled}\r\n {gated}\r\n {onJoinWaitlist}\r\n isMobileDrawer={true}\r\n {labels}\r\n />\r\n</div>\r\n","<script>\r\n import { Modal, Button, Input, isEmailAddress } from '@getmicdrop/svelte-components';\r\n import { Time, Email, Phone, CheckmarkFilled } from 'carbon-icons-svelte';\r\n import { joinWaitlist } from '$lib/api';\r\n\r\n let {\r\n show = $bindable(false),\r\n eventId,\r\n eventName = 'this event',\r\n onClose = () => {},\r\n labels = {},\r\n } = $props();\r\n\r\n // Form state\r\n let email = $state('');\r\n let phone = $state('');\r\n let smsOptIn = $state(false);\r\n let loading = $state(false);\r\n let error = $state('');\r\n let success = $state(false);\r\n\r\n // Validation\r\n let emailError = $derived(email && !isValidEmail(email) ? (labels.pleaseEnterValidEmail || 'Please enter a valid email') : '');\r\n let phoneError = $derived(phone && smsOptIn && !isValidPhone(phone) ? (labels.pleaseEnterValidPhone || 'Please enter a valid phone number') : '');\r\n\r\n function isValidEmail(email) {\r\n return isEmailAddress(email);\r\n }\r\n\r\n function isValidPhone(phone) {\r\n // Allow various phone formats\r\n const cleaned = phone.replace(/\\D/g, '');\r\n return cleaned.length >= 10 && cleaned.length <= 15;\r\n }\r\n\r\n async function handleSubmit() {\r\n error = '';\r\n\r\n if (!email || !isValidEmail(email)) {\r\n error = labels.pleaseEnterValidEmailAddress || 'Please enter a valid email address';\r\n return;\r\n }\r\n\r\n if (smsOptIn && phone && !isValidPhone(phone)) {\r\n error = labels.pleaseEnterValidPhone || 'Please enter a valid phone number';\r\n return;\r\n }\r\n\r\n loading = true;\r\n\r\n const result = await joinWaitlist(\r\n eventId,\r\n email,\r\n smsOptIn ? phone : null,\r\n smsOptIn\r\n );\r\n\r\n loading = false;\r\n\r\n if (result.success) {\r\n success = true;\r\n } else {\r\n error = result.error;\r\n }\r\n }\r\n\r\n function handleClose() {\r\n // Reset state when closing\r\n email = '';\r\n phone = '';\r\n smsOptIn = false;\r\n error = '';\r\n success = false;\r\n show = false;\r\n onClose();\r\n }\r\n</script>\r\n\r\n<Modal\r\n bind:open={show}\r\n size=\"sm\"\r\n>\r\n {#snippet body()}\r\n {#if success}\r\n <!-- Success State -->\r\n <div class=\"flex flex-col items-center text-center pt-6 px-4 pb-4\">\r\n <div class=\"w-16 h-16 rounded-full flex items-center justify-center mb-4 bg-accent-success/10 text-accent-success\" aria-hidden=\"true\">\r\n <CheckmarkFilled size={32} aria-hidden=\"true\" />\r\n </div>\r\n <h3 id=\"waitlist-title\" class=\"text-xl font-semibold text-text-primary mb-2\">\r\n {labels.youreOnTheList || \"You're on the waitlist\"}\r\n </h3>\r\n <p id=\"waitlist-description\" class=\"text-sm text-text-secondary leading-relaxed max-w-72\">\r\n {labels.waitlistNotifyByEmail || \"We'll let you know if tickets become available.\"}\r\n </p>\r\n {#if smsOptIn && phone}\r\n <p class=\"text-xs text-muted-foreground mt-2\">\r\n {labels.waitlistSmsAlerts || \"You'll also receive SMS alerts.\"}\r\n </p>\r\n {/if}\r\n </div>\r\n {:else}\r\n <!-- Form State -->\r\n <div class=\"flex flex-col pt-6 px-4 pb-4\">\r\n <div class=\"flex items-center justify-center mb-4\">\r\n <div class=\"w-12 h-12 rounded-full flex items-center justify-center bg-brand-primary/10 text-brand-primary\" aria-hidden=\"true\">\r\n <Time size={24} aria-hidden=\"true\" />\r\n </div>\r\n </div>\r\n <h3 id=\"waitlist-title\" class=\"text-xl font-semibold text-text-primary mb-2 text-center\">\r\n {labels.waitlistTitle || 'This show is sold out.'}\r\n </h3>\r\n <p id=\"waitlist-description\" class=\"text-sm text-text-secondary leading-relaxed text-center mb-6\">\r\n {labels.waitlistDescription || 'Want to be notified if tickets become available?'}\r\n </p>\r\n\r\n <form onsubmit={(e) => { e.preventDefault(); handleSubmit(); }} class=\"space-y-4\">\r\n <!-- Email Input -->\r\n <div>\r\n <label for=\"waitlist-email\" class=\"block text-sm font-medium text-text-secondary mb-1\">\r\n {labels.waitlistEmailLabel || 'Email address'}\r\n </label>\r\n <div class=\"relative\">\r\n <Input\r\n id=\"waitlist-email\"\r\n type=\"email\"\r\n bind:value={email}\r\n placeholder={labels.waitlistEmailPlaceholder || \"you@example.com\"}\r\n required\r\n disabled={loading}\r\n class={emailError ? 'border-status-error-border' : ''}\r\n />\r\n </div>\r\n {#if emailError}\r\n <p class=\"text-xs text-accent-danger mt-1\">{emailError}</p>\r\n {/if}\r\n </div>\r\n\r\n <!-- SMS Opt-in -->\r\n <div class=\"space-y-2\">\r\n <label class=\"flex items-start gap-3 cursor-pointer\">\r\n <input\r\n type=\"checkbox\"\r\n bind:checked={smsOptIn}\r\n disabled={loading}\r\n class=\"mt-0.5 w-4 h-4 text-brand-primary border-stroke-primary rounded focus:ring-focus-ring\"\r\n />\r\n <span class=\"text-sm text-text-secondary\">\r\n {labels.smsOptIn || 'Text me when tickets are available'}\r\n </span>\r\n </label>\r\n\r\n {#if smsOptIn}\r\n <div class=\"ml-7\">\r\n <Input\r\n id=\"waitlist-phone\"\r\n type=\"tel\"\r\n bind:value={phone}\r\n placeholder={labels.waitlistPhonePlaceholder || \"(555) 123-4567\"}\r\n disabled={loading}\r\n class={phoneError ? 'border-status-error-border' : ''}\r\n />\r\n {#if phoneError}\r\n <p class=\"text-xs text-accent-danger mt-1\">{phoneError}</p>\r\n {/if}\r\n <p class=\"text-xs text-muted-foreground mt-1\">\r\n {labels.smsDisclaimer || 'Message & data rates may apply. Reply STOP to unsubscribe.'}\r\n </p>\r\n </div>\r\n {/if}\r\n </div>\r\n\r\n {#if error}\r\n <div class=\"p-3 bg-status-error-bg border border-status-error-border rounded-lg\">\r\n <p class=\"text-sm text-accent-danger\">{error}</p>\r\n </div>\r\n {/if}\r\n </form>\r\n </div>\r\n {/if}\r\n {/snippet}\r\n {#snippet footer()}\r\n <div class=\"flex gap-3 w-full\" role=\"group\" aria-label={labels.dialogActions || \"Dialog actions\"}>\r\n {#if success}\r\n <Button size=\"full\" variant=\"default\" onclick={handleClose}>\r\n {labels.done || 'Done'}\r\n </Button>\r\n {:else}\r\n <Button size=\"full\" variant=\"alternative\" onclick={handleClose} disabled={loading}>\r\n {labels.cancel || 'Cancel'}\r\n </Button>\r\n <Button\r\n size=\"full\"\r\n variant=\"default\"\r\n onclick={handleSubmit}\r\n {loading}\r\n disabled={!email || !!emailError || (smsOptIn && phone && !!phoneError)}\r\n >\r\n {loading ? (labels.joining || 'Joining...') : (labels.notifyMe || 'Notify Me')}\r\n </Button>\r\n {/if}\r\n </div>\r\n {/snippet}\r\n</Modal>\r\n","<script>\r\n let {\r\n disclaimer = [],\r\n labels = {},\r\n } = $props();\r\n\r\n const fullText = $derived(Array.isArray(disclaimer) ? disclaimer.join(' ') : disclaimer);\r\n</script>\r\n\r\n<section class=\"flex flex-col gap-3\" aria-labelledby=\"disclaimer-title\">\r\n <h2 id=\"disclaimer-title\" class=\"heading-lg text-color-primary\">{labels.disclaimer || 'Disclaimer'}</h2>\r\n\r\n <p class=\"body-sm text-color-secondary\">\r\n {fullText}\r\n </p>\r\n</section>\r\n","<script>\r\n import { onMount, onDestroy } from 'svelte';\r\n\r\n let {\r\n items = [],\r\n } = $props();\r\n\r\n /* svelte-ignore state_referenced_locally */\r\n let activeTab = $state(items[0]?.id || '');\r\n let observer;\r\n\r\n function scrollToSection(tabId) {\r\n activeTab = tabId;\r\n const section = document.getElementById(tabId);\r\n if (section) {\r\n section.scrollIntoView({ behavior: 'smooth' });\r\n }\r\n }\r\n\r\n function handleTabKeydown(e, currentIndex) {\r\n let newIndex = currentIndex;\r\n\r\n if (e.key === 'ArrowRight') {\r\n e.preventDefault();\r\n newIndex = (currentIndex + 1) % items.length;\r\n } else if (e.key === 'ArrowLeft') {\r\n e.preventDefault();\r\n newIndex = (currentIndex - 1 + items.length) % items.length;\r\n } else if (e.key === 'Home') {\r\n e.preventDefault();\r\n newIndex = 0;\r\n } else if (e.key === 'End') {\r\n e.preventDefault();\r\n newIndex = items.length - 1;\r\n } else {\r\n return; // Don't handle other keys\r\n }\r\n\r\n // Focus the new tab and activate it\r\n const newTabId = items[newIndex].id;\r\n scrollToSection(newTabId);\r\n document.getElementById(`tab-${newTabId}`)?.focus();\r\n }\r\n\r\n onMount(() => {\r\n // Observe sections to update active tab on scroll\r\n observer = new IntersectionObserver(\r\n (entries) => {\r\n entries.forEach((entry) => {\r\n if (entry.isIntersecting) {\r\n activeTab = entry.target.id;\r\n }\r\n });\r\n },\r\n { rootMargin: '-20% 0px -70% 0px' }\r\n );\r\n\r\n items.forEach((item) => {\r\n const section = document.getElementById(item.id);\r\n if (section) observer.observe(section);\r\n });\r\n });\r\n\r\n onDestroy(() => {\r\n if (observer) observer.disconnect();\r\n });\r\n </script>\r\n\r\n <div class=\"tab-container flex justify-start gap-1 sm:gap-2 border-b border-border\" role=\"tablist\" aria-label=\"Page sections\">\r\n {#each items as item, index}\r\n <button\r\n type=\"button\"\r\n onclick={() => scrollToSection(item.id)}\r\n onkeydown={(e) => handleTabKeydown(e, index)}\r\n class=\"tab-button py-3 px-3 sm:px-4 text-sm sm:text-base font-medium transition-colors relative text-muted-foreground:outline-brand-primary\"\r\n class:active={activeTab === item.id}\r\n role=\"tab\"\r\n aria-selected={activeTab === item.id}\r\n aria-controls={item.id}\r\n tabindex={activeTab === item.id ? 0 : -1}\r\n id=\"tab-{item.id}\"\r\n >\r\n {item.label}\r\n {#if activeTab === item.id}\r\n <span class=\"tab-indicator absolute bottom-0 left-0 right-0 h-0.5 bg-bg-primary\" aria-hidden=\"true\"></span>\r\n {/if}\r\n </button>\r\n {/each}\r\n </div>\r\n\r\n<style>\r\n /* Theme-responsive tab styles */\r\n .tab-button:hover {\r\n color: hsl(var(--text-primary)); /* gray-900 */\r\n }\r\n\r\n .tab-button.active {\r\n color: hsl(var(--text-primary)); /* gray-900 */\r\n }\r\n\r\n .tab-button:focus-visible {\r\n outline: hsl(var(--brand-primary)) solid 2px; /* blue-700 */\r\n outline-offset: 2px;\r\n }\r\n</style>\r\n ","<script module>\r\n\timport { createLogger } from '@getmicdrop/svelte-components';\r\n\tconst logger = createLogger('EventDetailsView');\r\n</script>\r\n\r\n<script>\r\n import { onMount, onDestroy } from 'svelte';\r\n import { goto } from '$app/navigation';\r\n import {\r\n transformEvent,\r\n getImageUrl,\r\n getVenueDetails,\r\n generateSlug,\r\n } from '$lib/utils/utils.js';\r\n import {\r\n fetchEventDetails,\r\n checkEventPassword,\r\n getWaitlistStatus,\r\n } from '$lib/api';\r\n import StickySidebar from '../Events/Details/StickySidebar.svelte';\r\n import WaitlistModal from '../Modals/WaitlistModal.svelte';\r\n import { ArrowLeft, Locked, WarningAltFilled } from 'carbon-icons-svelte';\r\n import { AboutShow, FAQs, InputModal } from '@getmicdrop/svelte-components';\r\n import Disclaimer from '../Events/Details/Disclaimer.svelte';\r\n import Tab from '../Tab/+page.svelte';\r\n\r\n let {\r\n eventId,\r\n organizationId = '',\r\n venueId = '',\r\n initialEventData = null,\r\n onNavigateToCart,\r\n onNavigateBack,\r\n labels = {},\r\n } = $props();\r\n\r\n let event = $state(null);\r\n let rawEvent = $state(null);\r\n let isLoading = $state(true);\r\n let error = $state(null);\r\n let dataReady = $state(false);\r\n let showtimes = $state([]);\r\n let venueServiceCharge = $state({});\r\n let isMounted = $state(false);\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 imageHeight = $state(0);\r\n\r\n // Password protection state\r\n let showPasswordModal = $state(false);\r\n let passwordValue = $state('');\r\n let passwordError = $state('');\r\n let passwordLoading = $state(false);\r\n let isPasswordVerified = $state(false);\r\n\r\n // Waitlist state\r\n let showWaitlistModal = $state(false);\r\n\r\n // Check if event is already authenticated in sessionStorage\r\n function isEventAuthenticated(evtId) {\r\n if (typeof window === 'undefined') return false;\r\n const authedEvents = JSON.parse(\r\n sessionStorage.getItem('authedEvents') || '[]' // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n );\r\n return authedEvents.includes(evtId);\r\n }\r\n\r\n // Store event authentication in sessionStorage\r\n function setEventAuthenticated(evtId) {\r\n if (typeof window === 'undefined') return;\r\n const authedEvents = JSON.parse(\r\n sessionStorage.getItem('authedEvents') || '[]' // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n );\r\n if (!authedEvents.includes(evtId)) {\r\n authedEvents.push(evtId);\r\n sessionStorage.setItem('authedEvents', JSON.stringify(authedEvents)); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n }\r\n }\r\n\r\n // Handle password submission\r\n async function handlePasswordSubmit(e) {\r\n const password = e.detail?.value || passwordValue;\r\n if (!password || !eventId) return;\r\n\r\n passwordLoading = true;\r\n passwordError = '';\r\n\r\n try {\r\n const result = await checkEventPassword(eventId, password);\r\n if (result.valid) {\r\n setEventAuthenticated(eventId);\r\n isPasswordVerified = true;\r\n showPasswordModal = false;\r\n passwordValue = '';\r\n } else {\r\n passwordError =\r\n labels.incorrectPassword || 'Incorrect password. Please try again.';\r\n }\r\n } catch (err) {\r\n passwordError =\r\n labels.unableToVerifyPassword ||\r\n 'Unable to verify password. Please try again.';\r\n } finally {\r\n passwordLoading = false;\r\n }\r\n }\r\n\r\n // Check if password protection is required\r\n let requiresPassword = $derived(\r\n event?.password && event.password.trim() !== ''\r\n );\r\n let isLocked = $derived(\r\n requiresPassword && !isPasswordVerified && !isEventAuthenticated(eventId)\r\n );\r\n\r\n // Check if event is cancelled\r\n let isCancelled = $derived(\r\n event?.status?.toLowerCase() === 'cancelled' ||\r\n event?.status?.toLowerCase() === 'canceled'\r\n );\r\n\r\n // Check if waitlist is enabled for this event\r\n let waitlistEnabled = $derived(rawEvent?.waitlistEnabled === true);\r\n\r\n // Waitlist-only gating (decision #3): resolved from the backend so the page\r\n // can present \"Sold Out — join the waitlist\" to non-members even when tickets\r\n // are technically available. Defaults to false (normal behavior).\r\n let gated = $state(false);\r\n\r\n // Handler for joining waitlist\r\n function handleJoinWaitlist() {\r\n showWaitlistModal = true;\r\n }\r\n\r\n // Filter out unpublished series events from showtimes\r\n // Each showtime in a series may have its own published status\r\n function filterPublishedShowtimes(rawShowtimes) {\r\n if (!Array.isArray(rawShowtimes)) return [];\r\n return rawShowtimes.filter(showtime => {\r\n // Include if no published field exists (backwards compatible)\r\n if (\r\n showtime.published === undefined &&\r\n showtime.isPublished === undefined\r\n ) {\r\n return true;\r\n }\r\n // Check both possible field names for published status\r\n return showtime.published === true || showtime.isPublished === true;\r\n });\r\n }\r\n\r\n const toFaqArray = src => {\r\n if (!src) return [];\r\n if (Array.isArray(src)) {\r\n return src.map(item =>\r\n typeof item === 'string' ? { question: '', answer: item.trim() } : item\r\n );\r\n }\r\n return [{ question: '', answer: String(src).trim() }];\r\n };\r\n\r\n let venue = $derived(rawEvent?.venue || {});\r\n let venueFAQs = $derived(toFaqArray(venue.faq));\r\n let venueDisclaimer = $derived(venue.disclaimer || '');\r\n let parsedVenueDisclaimer = $derived(\r\n venueDisclaimer\r\n ? venueDisclaimer\r\n .split(/(?<=[.?!])\\s+(?=[A-Z])/g)\r\n .map(s => s.trim())\r\n .filter(Boolean)\r\n : []\r\n );\r\n\r\n let hasPerformers = $derived(\r\n event?.performers && event.performers.length > 0\r\n );\r\n\r\n let tabsData = $derived([\r\n { id: 'about', label: labels.tabAboutTheShow || 'About the show' },\r\n ...(hasPerformers\r\n ? [{ id: 'featuring', label: labels.tabFeaturing || 'Featuring' }]\r\n : []),\r\n ...(venueFAQs.length\r\n ? [{ id: 'faqs', label: labels.tabFAQs || 'FAQs' }]\r\n : []),\r\n ...(parsedVenueDisclaimer.length\r\n ? [{ id: 'disclaimers', label: labels.tabDisclaimers || 'Disclaimers' }]\r\n : []),\r\n ]);\r\n\r\n let ticketType = $derived(\r\n event?.eventTicketingType ?? event?.ticketType ?? 0\r\n );\r\n let availableTickets = $derived(event?.availableTickets || []);\r\n\r\n function goBack() {\r\n if (onNavigateBack) {\r\n onNavigateBack();\r\n } else {\r\n const params = new URLSearchParams(window.location.search);\r\n params.set('subroute', 'calendar');\r\n params.delete('event_id');\r\n params.delete('slug');\r\n const url = `/?${params.toString()}`;\r\n goto(url, { noScroll: false });\r\n }\r\n }\r\n\r\n function goToCheckout() {\r\n if (onNavigateToCart) {\r\n onNavigateToCart(eventId, generateSlug(event?.name || 'event'));\r\n } else {\r\n const params = new URLSearchParams(window.location.search);\r\n params.set('event_id', eventId);\r\n params.set('subroute', 'cart');\r\n params.set('slug', generateSlug(event?.name || 'event'));\r\n const url = `/?${params.toString()}`;\r\n goto(url, { noScroll: false });\r\n }\r\n }\r\n\r\n function updateScreenSize() {\r\n isMobile = window.innerWidth < 640;\r\n }\r\n\r\n let ticking = false;\r\n\r\n function handleScroll() {\r\n if (!ticking) {\r\n window.requestAnimationFrame(() => {\r\n updateStickyState();\r\n ticking = false;\r\n });\r\n ticking = true;\r\n }\r\n }\r\n\r\n function updateStickyState() {\r\n if (isMobile) {\r\n isSticky = false;\r\n return;\r\n }\r\n const rect = stickyRef?.getBoundingClientRect();\r\n if (!rect) return;\r\n\r\n isSticky = rect.top + imageHeight <= 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 getTestEventData(eventId) {\r\n if (!eventId) return null;\r\n\r\n const today = new Date();\r\n const testDate = new Date(today);\r\n testDate.setDate(today.getDate() + 7);\r\n\r\n return {\r\n id: String(eventId),\r\n ID: String(eventId),\r\n title: 'Test Comedy Show',\r\n name: 'Test Comedy Show',\r\n description:\r\n 'This is a test event for development and testing purposes. Join us for an amazing comedy show featuring top comedians!',\r\n coverImage:\r\n 'https://images.unsplash.com/photo-1492684223066-81342ee5ff30?w=1200&h=800&fit=crop',\r\n startDateTime: testDate.toISOString(), // @datetime-escape: test fixture — populates API-shaped state field consumed by transformEvent()\r\n endDateTime: new Date(\r\n testDate.getTime() + 2 * 60 * 60 * 1000\r\n ).toISOString(), // @datetime-escape: test fixture — populates API-shaped state field consumed by transformEvent()\r\n venueID: 'test-venue-1',\r\n venue: {\r\n name: 'Test Comedy Club',\r\n address: '123 Test Street, Test City',\r\n faq: [\r\n {\r\n question: 'What time does the show start?',\r\n answer: 'The show starts at 8:00 PM.',\r\n },\r\n {\r\n question: 'Is there parking available?',\r\n answer: 'Yes, free parking is available.',\r\n },\r\n ],\r\n disclaimer:\r\n 'All ticket sales are final. No refunds unless event is cancelled.',\r\n },\r\n eventTicketingType: 0,\r\n ticketType: 0,\r\n status: 'On Sale',\r\n availableTickets: [\r\n {\r\n ID: 'ticket-1',\r\n name: 'General Admission',\r\n price: 25,\r\n remainingCapacity: 50,\r\n visibility: 0,\r\n },\r\n {\r\n ID: 'ticket-2',\r\n name: 'VIP',\r\n price: 50,\r\n remainingCapacity: 10,\r\n visibility: 0,\r\n },\r\n ],\r\n showtimes: [\r\n {\r\n startTime: testDate.toISOString(), // @datetime-escape: test fixture — populates API-shaped showtime field consumed by filterPublishedShowtimes()\r\n endTime: new Date(\r\n testDate.getTime() + 2 * 60 * 60 * 1000\r\n ).toISOString(), // @datetime-escape: test fixture — populates API-shaped showtime field consumed by filterPublishedShowtimes()\r\n },\r\n ],\r\n performers: [],\r\n };\r\n }\r\n\r\n async function loadEventData() {\r\n if (!isMounted) {\r\n return;\r\n }\r\n if (!eventId) {\r\n error = labels.noEventIdProvided || 'No event ID provided';\r\n isLoading = false;\r\n return;\r\n }\r\n\r\n isLoading = true;\r\n error = null;\r\n\r\n try {\r\n if (initialEventData) {\r\n // Use server-provided data — skip client-side fetch\r\n rawEvent = initialEventData;\r\n if (!isMounted) return;\r\n event = transformEvent(rawEvent);\r\n showtimes = filterPublishedShowtimes(rawEvent?.showtimes || []);\r\n } else {\r\n try {\r\n rawEvent = await fetchEventDetails(eventId);\r\n if (!isMounted) return;\r\n event = transformEvent(rawEvent);\r\n showtimes = filterPublishedShowtimes(rawEvent?.showtimes || []);\r\n } catch (apiErr) {\r\n logger.error('Event fetch failed:', apiErr);\r\n error = labels.failedToLoadEvent || 'Failed to load event';\r\n isLoading = false;\r\n return;\r\n }\r\n }\r\n\r\n const effectiveVenueId = event?.venueID || venueId || null;\r\n if (effectiveVenueId) {\r\n try {\r\n const venueData = await getVenueDetails(effectiveVenueId);\r\n if (!isMounted) return;\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 } catch (err) {\r\n if (!isMounted) return;\r\n logger.error('Error fetching venue data:', err);\r\n }\r\n }\r\n if (isMounted) {\r\n dataReady = true;\r\n\r\n // Check if password protection is needed after data is ready\r\n if (event?.password && event.password.trim() !== '') {\r\n // Check if already authenticated in this session\r\n if (!isEventAuthenticated(eventId)) {\r\n showPasswordModal = true;\r\n } else {\r\n isPasswordVerified = true;\r\n }\r\n }\r\n }\r\n } catch (err) {\r\n if (isMounted) {\r\n logger.error('Error loading event:', err);\r\n error =\r\n err.message || labels.failedToLoadEvent || 'Failed to load event';\r\n }\r\n } finally {\r\n if (isMounted) {\r\n isLoading = false;\r\n }\r\n }\r\n }\r\n\r\n // Handle cancel - go back if password modal is cancelled\r\n function handlePasswordCancel() {\r\n showPasswordModal = false;\r\n goBack();\r\n }\r\n\r\n onMount(async () => {\r\n isMounted = true;\r\n updateScreenSize();\r\n window.addEventListener('resize', updateScreenSize);\r\n window.addEventListener('scroll', handleScroll);\r\n\r\n await loadEventData();\r\n\r\n // Resolve waitlist gating status (decision #3). Best-effort: failures leave\r\n // gated=false so the page falls back to normal sold-out behavior.\r\n if (eventId) {\r\n const status = await getWaitlistStatus(eventId);\r\n if (isMounted) gated = status.gated;\r\n }\r\n\r\n if (stickyRef && isMounted) {\r\n stickyTop = stickyRef.getBoundingClientRect().top || 0;\r\n const imageElement = stickyRef.querySelector('img');\r\n if (imageElement) {\r\n imageHeight = imageElement.offsetHeight;\r\n }\r\n }\r\n });\r\n\r\n // NOTE: onDestroy must be registered synchronously during component init,\r\n // NOT inside the async onMount above (after an await the init context is\r\n // gone and Svelte 5 throws lifecycle_outside_component). Clean up the\r\n // resize/scroll listeners here instead.\r\n onDestroy(() => {\r\n isMounted = false;\r\n window.removeEventListener('resize', updateScreenSize);\r\n window.removeEventListener('scroll', handleScroll);\r\n });\r\n</script>\r\n\r\n<div\r\n class=\"px-5 sm:px-10 py-12 bg-card\"\r\n bind:this={containerRef}\r\n data-org-id={organizationId}\r\n>\r\n <!-- Visually hidden h1 for accessibility - event name announced as page title -->\r\n <h1 class=\"sr-only\">\r\n {event?.name || labels.eventDetails || 'Event Details'}\r\n </h1>\r\n\r\n {#if isLoading}\r\n <div\r\n class=\"flex items-center justify-center py-12\"\r\n role=\"status\"\r\n aria-live=\"polite\"\r\n >\r\n <p class=\"loading-text\">{labels.loadingEvent || 'Loading event...'}</p>\r\n </div>\r\n {:else if error}\r\n <div class=\"text-center py-8\" role=\"alert\">\r\n <p class=\"error-text mb-2\">{labels.errorPrefix || 'Error:'} {error}</p>\r\n <button\r\n class=\"go-back-btn mt-4 px-4 py-2 rounded-lg\"\r\n onclick={goBack}\r\n aria-label={labels.goBackToCalendar || 'Go back to calendar'}\r\n >\r\n {labels.goBack || 'Go back'}\r\n </button>\r\n </div>\r\n {:else if event}\r\n <div class=\"flex flex-col w-full relative\">\r\n {#if isLocked}\r\n <!-- Locked overlay when password is required but not verified -->\r\n <div\r\n class=\"locked-overlay absolute inset-0 z-20 flex flex-col items-center justify-center bg-card/95 rounded-lg\"\r\n >\r\n <div class=\"locked-content text-center p-8\">\r\n <div class=\"locked-icon-wrapper mx-auto mb-4\">\r\n <Locked class=\"w-12 h-12 text-muted-foreground\" />\r\n </div>\r\n <h2 class=\"locked-title text-xl font-semibold mb-2\">\r\n {labels.passwordProtectedTitle ||\r\n 'This event is password protected'}\r\n </h2>\r\n <p class=\"locked-description text-sm mb-6\">\r\n {labels.passwordProtectedDescription ||\r\n 'Enter the event password to view details and purchase tickets.'}\r\n </p>\r\n <button\r\n class=\"unlock-btn px-6 py-3 rounded-lg font-medium\"\r\n onclick={() => (showPasswordModal = true)}\r\n >\r\n {labels.enterPassword || 'Enter password'}\r\n </button>\r\n </div>\r\n </div>\r\n {/if}\r\n\r\n {#if isCancelled}\r\n <!-- Cancelled event banner -->\r\n <div\r\n class=\"cancelled-banner mb-6 p-4 rounded-lg\"\r\n role=\"alert\"\r\n aria-live=\"assertive\"\r\n >\r\n <div class=\"flex items-start gap-3\">\r\n <div\r\n class=\"cancelled-icon-wrapper shrink-0 mt-0.5\"\r\n aria-hidden=\"true\"\r\n >\r\n <WarningAltFilled size={24} class=\"cancelled-icon\" />\r\n </div>\r\n <div class=\"cancelled-content\">\r\n <h3 class=\"cancelled-title text-base font-semibold mb-1\">\r\n {labels.eventCancelledTitle || 'This event has been cancelled'}\r\n </h3>\r\n <p class=\"cancelled-message text-sm mb-2\">\r\n {labels.eventCancelledMessage ||\r\n \"We're sorry, but this event is no longer taking place.\"}\r\n </p>\r\n <p class=\"cancelled-refund text-sm\">\r\n <strong\r\n >{labels.eventCancelledRefund ||\r\n 'Refund information:'}</strong\r\n >\r\n {labels.eventCancelledRefundDetails ||\r\n 'If you purchased tickets, a full refund will be processed automatically to your original payment method within 5-10 business days. Check your email for confirmation.'}\r\n </p>\r\n </div>\r\n </div>\r\n </div>\r\n {/if}\r\n\r\n <div\r\n class=\"flex-1 flex flex-col lg:flex-row w-full gap-7 relative\"\r\n class:blur-content={isLocked}\r\n class:cancelled-content={isCancelled}\r\n >\r\n <div class=\"flex-1 relative\" bind:this={stickyRef}>\r\n <!-- @component-image-escape: scoped-CSS selector targets this img via .cancelled-content img -->\r\n <img\r\n src={event.coverImage\r\n ? getImageUrl(event.coverImage)\r\n : 'https://images.unsplash.com/photo-1558618666-fcd25c85cd64?w=1200&h=800&fit=crop'}\r\n alt={event.name\r\n ? (labels.eventPoster || 'Event poster') + ' — ' + event.name\r\n : labels.eventPoster || 'Event poster'}\r\n class=\"w-full rounded-lg object-contain bg-bg-secondary\"\r\n />\r\n <button\r\n class=\"bg-bg-secondary rounded-full size-8 sm:size-10 flex items-center justify-center absolute top-3 left-3 z-10\"\r\n onclick={goBack}\r\n aria-label={labels.goBackToCalendar || 'Go back to calendar'}\r\n >\r\n <ArrowLeft\r\n class=\"size-3.5 sm:size-5 text-white\"\r\n aria-hidden=\"true\"\r\n />\r\n </button>\r\n </div>\r\n\r\n {#if isSticky}\r\n <!-- Spacer to maintain layout when sidebar becomes fixed -->\r\n <div class=\"hidden lg:block w-80 shrink-0\" aria-hidden=\"true\"></div>\r\n {/if}\r\n\r\n <StickySidebar\r\n {event}\r\n {showtimes}\r\n {ticketType}\r\n {availableTickets}\r\n {isSticky}\r\n {sidebarLeft}\r\n {goToCheckout}\r\n {dataReady}\r\n {isCancelled}\r\n {waitlistEnabled}\r\n {gated}\r\n onJoinWaitlist={handleJoinWaitlist}\r\n {labels}\r\n />\r\n </div>\r\n\r\n <div\r\n class=\"flex-1 flex flex-col lg:flex-row w-full gap-7\"\r\n class:blur-content={isLocked}\r\n class:cancelled-content={isCancelled}\r\n >\r\n <div class=\"flex-1\">\r\n <div class=\"my-3 px-0 sm:my-5 sm:px-4\">\r\n <Tab items={tabsData} />\r\n </div>\r\n\r\n <div id=\"about\" class=\"my-8\">\r\n <AboutShow\r\n ShowImage=\"\"\r\n description={event.description}\r\n performers={[]}\r\n title={labels.tabAboutTheShow || 'About the show'}\r\n showTitle={true}\r\n />\r\n </div>\r\n\r\n {#if hasPerformers}\r\n <section\r\n id=\"featuring\"\r\n class=\"my-8\"\r\n aria-labelledby=\"featuring-title\"\r\n >\r\n <h2\r\n id=\"featuring-title\"\r\n class=\"section-title font-medium text-2xl mb-4\"\r\n >\r\n {labels.tabFeaturing || 'Featuring'}\r\n </h2>\r\n <AboutShow\r\n ShowImage=\"\"\r\n description=\"\"\r\n performers={event.performers}\r\n showTitle={false}\r\n />\r\n </section>\r\n {/if}\r\n\r\n {#if venueFAQs.length}\r\n <section\r\n id=\"faqs\"\r\n class=\"my-8\"\r\n aria-label=\"Frequently asked questions\"\r\n >\r\n <FAQs faqs={venueFAQs} />\r\n </section>\r\n {/if}\r\n\r\n {#if parsedVenueDisclaimer.length}\r\n <section id=\"disclaimers\" class=\"my-8\" aria-label=\"Disclaimers\">\r\n <Disclaimer disclaimer={parsedVenueDisclaimer.join(' ')} />\r\n </section>\r\n {/if}\r\n </div>\r\n\r\n <!-- svelte-ignore element_invalid_self_closing_tag -->\r\n <div class=\"w-full sm:w-80 flex flex-col\" />\r\n </div>\r\n </div>\r\n {/if}\r\n</div>\r\n\r\n<!-- Password Protection Modal -->\r\n<InputModal\r\n bind:open={showPasswordModal}\r\n size=\"md\"\r\n title={labels.enterEventPassword || 'Enter event password'}\r\n description={labels.passwordModalDescription ||\r\n 'This event requires a password to view. Please enter the password provided by the event organizer.'}\r\n inputLabel={labels.passwordLabel || 'Password'}\r\n inputType=\"password\"\r\n bind:inputValue={passwordValue}\r\n inputRequired={true}\r\n errorMessage={passwordError}\r\n showError={!!passwordError}\r\n primaryButtonText={labels.unlockEvent || 'Unlock event'}\r\n secondaryButtonText={labels.goBack || 'Go back'}\r\n loading={passwordLoading}\r\n onconfirm={handlePasswordSubmit}\r\n oncancel={handlePasswordCancel}\r\n onclose={handlePasswordCancel}\r\n/>\r\n\r\n<!-- Waitlist Modal -->\r\n<WaitlistModal\r\n bind:show={showWaitlistModal}\r\n {eventId}\r\n eventName={event?.name || 'this event'}\r\n onClose={() => (showWaitlistModal = false)}\r\n {labels}\r\n/>\r\n\r\n<style>\r\n /* Theme-responsive colors */\r\n .loading-text {\r\n color: hsl(var(--text-secondary));\r\n }\r\n\r\n .error-text {\r\n color: hsl(var(--status-sold-out));\r\n }\r\n\r\n .go-back-btn {\r\n background-color: hsl(var(--brand-primary));\r\n color: hsl(var(--bg-primary));\r\n }\r\n\r\n .go-back-btn:hover {\r\n background-color: hsl(var(--brand-primary) / 90%);\r\n }\r\n\r\n .section-title {\r\n color: hsl(var(--text-primary));\r\n }\r\n\r\n /* Password protection styles */\r\n .blur-content {\r\n filter: blur(8px);\r\n pointer-events: none;\r\n user-select: none;\r\n }\r\n\r\n .locked-overlay {\r\n min-height: 400px;\r\n background-color: hsl(var(--bg-primary) / 95%);\r\n }\r\n\r\n .locked-title {\r\n color: hsl(var(--text-primary));\r\n }\r\n\r\n .locked-description {\r\n color: hsl(var(--text-secondary));\r\n max-width: 300px;\r\n margin-left: auto;\r\n margin-right: auto;\r\n }\r\n\r\n .locked-icon-wrapper {\r\n width: 80px;\r\n height: 80px;\r\n border-radius: 50%;\r\n background-color: hsl(var(--bg-secondary, var(--bg-primary)));\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n }\r\n\r\n .unlock-btn {\r\n background-color: hsl(var(--brand-primary));\r\n color: hsl(var(--bg-primary));\r\n transition: background-color 0.2s ease;\r\n }\r\n\r\n .unlock-btn:hover {\r\n background-color: hsl(var(--brand-primary) / 90%);\r\n }\r\n\r\n /* Cancelled event styles */\r\n .cancelled-banner {\r\n background-color: hsl(var(--accent-danger) / 5%);\r\n border: 1px solid hsl(var(--accent-danger) / 20%);\r\n }\r\n\r\n :global(.cancelled-icon) {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .cancelled-title {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .cancelled-message {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .cancelled-refund {\r\n color: hsl(var(--accent-danger));\r\n line-height: 1.5;\r\n }\r\n\r\n .cancelled-refund strong {\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .cancelled-content {\r\n filter: grayscale(60%);\r\n opacity: 0.85;\r\n }\r\n\r\n .cancelled-content img {\r\n filter: grayscale(70%);\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":["labels","$","$$props","onlyOneFreeTicket","div","root","span","root_1","text","span_1","root_2","formatCurrency","$$render","consequent","alternate","span_2","root_3","consequent_1","$0","$1","dataReady","availableTickets","isMobileDrawer","isCancelled","purchasedTickets","waitlistEnabled","gated","onJoinWaitlist","visibleTickets","t","totalRemainingCapacity","acc","isSoldOut","hasNoTickets","basePrice","div_1","div_2","div_3","div_4","Button","$$anchor","Time","consequent_3","alternate_1","consequent_2","consequent_4","alternate_2","div_5","root_15","div_6","div_7","span_3","PriceTag","PriceTagSkeleton","consequent_6","alternate_3","div_8","node_8","div_9","span_4","consequent_9","alternate_4","node_10","div_10","Locked","span_5","node_11","consequent_7","consequent_8","consequent_10","alternate_5","consequent_5","alternate_6","showtimes","isSticky","sidebarLeft","aside","fragment","ShowCard","node","TicketActions","node_1","node_2","styles","show","onClose","email","phone","smsOptIn","loading","error","success","emailError","isValidEmail","phoneError","isValidPhone","isEmailAddress","cleaned","handleSubmit","result","joinWaitlist","handleClose","Modal","$$value","CheckmarkFilled","h3","p","p_1","root_4","h3_1","p_2","form","label","Input","node_4","p_3","root_5","label_1","input","root_6","node_7","p_4","root_7","p_5","root_8","p_6","e","root_9","node_12","disclaimer","fullText","section","h2","items","activeTab","observer","scrollToSection","tabId","handleTabKeydown","currentIndex","newIndex","newTabId","onMount","entries","entry","item","onDestroy","index","button","classes","logger","createLogger","organizationId","venueId","initialEventData","event","rawEvent","isLoading","venueServiceCharge","isMounted","isMobile","containerRef","stickyRef","stickyTop","imageHeight","showPasswordModal","passwordValue","passwordError","passwordLoading","isPasswordVerified","showWaitlistModal","isEventAuthenticated","evtId","setEventAuthenticated","authedEvents","handlePasswordSubmit","password","checkEventPassword","requiresPassword","isLocked","handleJoinWaitlist","filterPublishedShowtimes","rawShowtimes","showtime","toFaqArray","src","venue","venueFAQs","venueDisclaimer","parsedVenueDisclaimer","s","hasPerformers","tabsData","ticketType","goBack","params","url","goto","goToCheckout","generateSlug","updateScreenSize","ticking","handleScroll","updateStickyState","rect","containerBounding","loadEventData","transformEvent","fetchEventDetails","apiErr","effectiveVenueId","venueData","getVenueDetails","err","handlePasswordCancel","status","getWaitlistStatus","imageElement","h1","text_2","button_1","WarningAltFilled","strong","div_11","node_3","div_12","img","button_2","ArrowLeft","node_5","div_13","StickySidebar","div_14","div_15","div_16","Tab","div_17","AboutShow","node_9","h2_1","section_1","FAQs","node_13","section_2","Disclaimer","node_15","classes_1","getImageUrl","InputModal","node_16","WaitlistModal","node_17"],"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 { aQ as B, aM as G, aa as D, Q as Z } from "./VenueCalendar-BkRqSb_t.js";
3
+ import { aQ as B, aM as G, aa as D, Q as Z } from "./VenueCalendar-DFfEZMyW.js";
4
4
  var H = 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>'), O = 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>'), R = e.from_html('<span class="w-1.5 h-1.5 rounded-full bg-brand-primary"></span> Series', 1), S = e.from_html('<span class="w-1.5 h-1.5 rounded-full bg-brand-primary"></span> Collection', 1), V = e.from_html('<span class="text-muted-foreground">·</span> ', 1), z = e.from_html('<p class="text-base text-text-secondary font-medium"> <!></p>'), J = 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>'), K = 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-eHHU2dOf.js.map
128
+ //# sourceMappingURL=FeaturedView.legacy-CHfs0YPT.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FeaturedView.legacy-eHHU2dOf.js","sources":["../src/components/Calendar/FeaturedView.legacy.svelte"],"sourcesContent":["<script>\r\n import { formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\r\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\r\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n\r\n let {\r\n events = [],\r\n featuredItem = null,\r\n oneventClick,\r\n } = $props();\r\n\r\n // Filter to today and future, sorted chronologically\r\n let futureEvents = $derived(filterTodayAndFuture(events));\r\n\r\n let heroEvent = $derived(futureEvents.length > 0 ? futureEvents[0] : null);\r\n\r\n function handleClick() {\r\n if (heroEvent) {\r\n oneventClick?.(heroEvent);\r\n }\r\n }\r\n</script>\r\n\r\n<section class=\"w-full\" aria-label=\"Featured event\">\r\n {#if featuredItem}\r\n <!-- Series or Collection hero -->\r\n <div class=\"featured-hero rounded-lg border border-border bg-card overflow-hidden\">\r\n {#if featuredItem.image}\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\r\n <img\r\n src={featuredItem.image}\r\n alt=\"\"\r\n class=\"hero-image\"\r\n aria-hidden=\"true\"\r\n />\r\n </div>\r\n {:else}\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden flex items-center justify-center\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" class=\"w-16 h-16 text-muted-foreground\"><rect x=\"2\" y=\"2\" width=\"20\" height=\"20\" rx=\"2\"/><circle cx=\"8.5\" cy=\"8.5\" r=\"1.5\"/><path d=\"m21 15-5-5L5 21\"/></svg>\r\n </div>\r\n {/if}\r\n\r\n <div class=\"p-4 sm:p-5\">\r\n <div class=\"inline-flex items-center gap-1.5 text-xs font-semibold text-brand-primary uppercase tracking-wide mb-2\">\r\n {#if featuredItem.type === 'series'}\r\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\r\n Series\r\n {:else}\r\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\r\n Collection\r\n {/if}\r\n {#if featuredItem.subtitle}\r\n <span class=\"text-muted-foreground\">·</span>\r\n {featuredItem.subtitle}\r\n {/if}\r\n </div>\r\n\r\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{featuredItem.title}</h2>\r\n\r\n {#if heroEvent}\r\n <p class=\"text-base text-text-secondary font-medium\">\r\n Next: {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {#if heroEvent.startDateTime}\r\n at {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {/if}\r\n </p>\r\n {/if}\r\n </div>\r\n </div>\r\n {:else if heroEvent}\r\n <!-- Single event hero -->\r\n <div\r\n class=\"featured-hero featured-hero-clickable rounded-lg border border-border bg-card overflow-hidden cursor-pointer hover:border-stroke-primary focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n onclick={handleClick}\r\n onkeydown={(e) => (e.key === 'Enter' || e.key === ' ') && handleClick()}\r\n tabindex=\"0\"\r\n role=\"button\"\r\n aria-label=\"{heroEvent.name}, {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}. Press Enter to view details.\"\r\n >\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\r\n <img\r\n src={heroEvent.image || PLACEHOLDER_IMAGE}\r\n alt=\"\"\r\n class=\"hero-image\"\r\n aria-hidden=\"true\"\r\n />\r\n </div>\r\n\r\n <div class=\"p-4 sm:p-5\" aria-hidden=\"true\">\r\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{heroEvent.name}</h2>\r\n\r\n <p class=\"text-base text-text-secondary font-medium\">\r\n {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {#if heroEvent.startDateTime}\r\n <span class=\"text-muted-foreground mx-1\">·</span>\r\n {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {/if}\r\n </p>\r\n\r\n {#if heroEvent.description}\r\n <p class=\"hero-description text-sm text-text-secondary mt-2\">{heroEvent.description}</p>\r\n {/if}\r\n </div>\r\n </div>\r\n {:else}\r\n <!-- Empty state -->\r\n <div class=\"flex items-center justify-center py-12 rounded-lg border border-border bg-bg-secondary\">\r\n <p class=\"text-sm text-muted-foreground\">No upcoming events to feature</p>\r\n </div>\r\n {/if}\r\n</section>\r\n\r\n<style>\r\n .hero-image-container {\r\n aspect-ratio: 16 / 9;\r\n }\r\n\r\n .hero-image {\r\n width: 100%;\r\n height: 100%;\r\n object-fit: contain;\r\n }\r\n\r\n .hero-title {\r\n line-height: 1.3;\r\n }\r\n\r\n .featured-hero-clickable {\r\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\r\n }\r\n\r\n .featured-hero-clickable:hover {\r\n box-shadow: 0 4px 12px color-mix(in srgb, black 10%, transparent);\r\n }\r\n\r\n .featured-hero-clickable:focus {\r\n outline: none;\r\n }\r\n\r\n .hero-description {\r\n display: -webkit-box;\r\n -webkit-line-clamp: 2;\r\n line-clamp: 2;\r\n -webkit-box-orient: vertical;\r\n overflow: hidden;\r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .featured-hero-clickable {\r\n transition: none;\r\n }\r\n }\r\n</style>\r\n"],"names":["events","$","$$props","featuredItem","futureEvents","filterTodayAndFuture","heroEvent","handleClick","section","root","div","root_1","div_1","root_2","img","div_2","root_3","$$render","consequent","alternate","div_3","node_1","div_4","consequent_1","alternate_1","text","consequent_2","h2","p","root_7","formatEventTime","consequent_3","formatFullDate","consequent_4","text_1","div_5","root_9","div_6","img_1","div_7","h2_1","p_1","consequent_6","p_2","root_11","text_7","consequent_7","$0","PLACEHOLDER_IMAGE","text_4","e","div_8","root_12","consequent_8","alternate_2"],"mappings":";;;;kBAAA;;MAMIA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,MAAA,EAAA,GACNC,iCAAe,IAAI,GAKjBC,IAAYH,EAAA,QAAA,MAAYI,EAAqBL,EAAM,CAAA,CAAA,GAEnDM,IAASL,EAAA,QAAA,MAAAA,EAAA,IAAYG,CAAY,EAAC,SAAS,IAACH,EAAA,IAAGG,CAAY,EAAC,CAAC,IAAI,IAAI;AAEhE,WAAAG,IAAc;AACjB,IAAAN,EAAA,IAAAK,CAAS,4BACIA,CAAS,CAAA;AAAA,EAE5B;MAGDE,IAAOC,EAAA,eAAPD,CAAO;;;UAGHE,IAAGC,EAAA,eAAHD,CAAG;;;cAECE,IAAGC,EAAA,GACDC,YADFF,CAAG;kBAAHA,CAAG,2CACDE,GAAG,OACGX,IAAa,KAAK,CAAA,eAF1BS,CAAG;AAAA;cASHG,IAAGC,EAAA;sBAAHD,CAAG;AAAA;;AAVD,UAAAZ,EAAY,EAAC,QAAKc,EAAAC,CAAA,IAAAD,EAAAE,GAAA,EAAA;AAAA;;UAetBC,IAAGnB,EAAA,QAAAoB,GAAA,CAAA,GACDC,YADFF,CAAG,eACDE,CAAG;;;;;;;;;;UACGnB,EAAY,EAAC,SAAS,WAAQc,EAAAM,CAAA,IAAAN,EAAAO,GAAA,EAAA;AAAA;;;;;;AAShC,UAAAvB,EAAA,gBAAA,MAAAA,EAAA,SAAAwB,GAAA,IAAAtB,EAAY,EAAC,YAAQ,EAAA,EAAA,CAAA;;;AAFnB,UAAAA,EAAY,EAAC,YAAQc,EAAAS,CAAA;AAAA;;cAR3BJ,CAAG;AAcH,UAAAK,cAdAL,GAAG,CAAA,eAcHK,GAAE,EAAA;cAAFA,CAAE;wBAAFA,GAAE,CAAA;;;cAGAC,IAACC,EAAA,eAADD,CAAC;;;;;gBAGM,MAAAE,QAAgBxB,CAAS,EAAC,eAAaL,EAAA,IAAEK,CAAS,EAAC,QAAQ;AAAA;;;AAD5D,cAAAL,EAAA,IAAAK,CAAS,EAAC,iBAAaW,EAAAc,CAAA;AAAA;;kBAF7BH,CAAC;YACO,MAAAI,QAAe1B,CAAS,EAAC,eAAaL,EAAA,IAAEK,CAAS,EAAC,QAAQ;AAAA,0BADlEsB,CAAC;AAAA;;gBADCtB,CAAS,KAAAW,EAAAgB,CAAA;AAAA;;cAjBfb,CAAG,WAhBLV,CAAG,GA+B6ET,EAAA,gBAAA,MAAAA,EAAA,SAAAiC,GAAA/B,EAAY,EAAC,KAAK,CAAA,eA/BlGO,CAAG;AAAA;UA6CHyB,IAAGC,EAAA,GAQDC,YARFF,CAAG,GASCG,YADFD,CAAG;cAAHA,CAAG;AASH,UAAAE,cATAF,GAAG,CAAA,GAUDG,YADFD,CAAG,eACDC,GAAE,EAAA;cAAFA,CAAE;AAEF,UAAAC,cAFAD,GAAE,CAAA,eAEFC,CAAC;;;;;YAIG,MAAAX,QAAgBxB,CAAS,EAAC,eAAaL,EAAA,IAAEK,CAAS,EAAC,QAAQ;AAAA;;;AAFzD,UAAAL,EAAA,IAAAK,CAAS,EAAC,iBAAaW,EAAAyB,CAAA;AAAA;;cAF7BD,CAAC;wBAADA,GAAC,CAAA;;;cASCE,IAACC,EAAA,eAADD,GAAC,EAAA;kBAADA,CAAC,GAA4D1C,EAAA,gBAAA,MAAAA,EAAA,SAAA4C,GAAA5C,EAAA,IAAAK,CAAS,EAAC,WAAW,CAAA,eAAlFqC,CAAC;AAAA;;AADC,UAAA1C,EAAA,IAAAK,CAAS,EAAC,eAAWW,EAAA6B,CAAA;AAAA;;cAX3BP,CAAG,WAjBLJ,CAAG;;0BAAHA,GAAG,cAAA,GAAAlC,EAAA,IAMWK,CAAS,EAAC,QAAI,EAAA,KAAAyC,KAAA,EAAA,gCAAA,GAGxB9C,EAAA,cAAAqC,GAAG,OAAArC,EAAA,IACGK,CAAS,EAAC,SAAS0C,CAAiB,GAQkC/C,EAAA,SAAAgD,GAAAhD,EAAA,IAAAK,CAAS,EAAC,IAAI;;;UAZ9D,MAAA0B,QAAe1B,CAAS,EAAC,eAAaL,EAAA,IAAEK,CAAS,EAAC,QAAQ;AAAA,UAepF,MAAA0B,QAAe1B,CAAS,EAAC,eAAaL,EAAA,IAAEK,CAAS,EAAC,QAAQ;AAAA;SArBhEL,EAAA,UAAA,SAAAkC,GAEU5B,CAAW,GAFrBN,EAAA,UAAA,WAAAkC,GAAG,CAGUe,OAAOA,EAAE,QAAQ,WAAWA,EAAE,QAAQ,QAAQ3C,EAAW,CAAA,eAHtE4B,CAAG;AAAA;UAmCHgB,IAAGC,EAAA;kBAAHD,CAAG;AAAA;;AAlFD,MAAAhD,EAAY,iBA6CPG,CAAS,IAAAW,EAAAoC,GAAA,CAAA,IAAApC,EAAAqC,GAAA,EAAA;AAAA;;UA9CpB9C,CAAO,eAAPA,CAAO;AAFA;;"}
1
+ {"version":3,"file":"FeaturedView.legacy-CHfs0YPT.js","sources":["../src/components/Calendar/FeaturedView.legacy.svelte"],"sourcesContent":["<script>\r\n import { formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\r\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\r\n import { filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\r\n\r\n let {\r\n events = [],\r\n featuredItem = null,\r\n oneventClick,\r\n } = $props();\r\n\r\n // Filter to today and future, sorted chronologically\r\n let futureEvents = $derived(filterTodayAndFuture(events));\r\n\r\n let heroEvent = $derived(futureEvents.length > 0 ? futureEvents[0] : null);\r\n\r\n function handleClick() {\r\n if (heroEvent) {\r\n oneventClick?.(heroEvent);\r\n }\r\n }\r\n</script>\r\n\r\n<section class=\"w-full\" aria-label=\"Featured event\">\r\n {#if featuredItem}\r\n <!-- Series or Collection hero -->\r\n <div class=\"featured-hero rounded-lg border border-border bg-card overflow-hidden\">\r\n {#if featuredItem.image}\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\r\n <img\r\n src={featuredItem.image}\r\n alt=\"\"\r\n class=\"hero-image\"\r\n aria-hidden=\"true\"\r\n />\r\n </div>\r\n {:else}\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden flex items-center justify-center\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" class=\"w-16 h-16 text-muted-foreground\"><rect x=\"2\" y=\"2\" width=\"20\" height=\"20\" rx=\"2\"/><circle cx=\"8.5\" cy=\"8.5\" r=\"1.5\"/><path d=\"m21 15-5-5L5 21\"/></svg>\r\n </div>\r\n {/if}\r\n\r\n <div class=\"p-4 sm:p-5\">\r\n <div class=\"inline-flex items-center gap-1.5 text-xs font-semibold text-brand-primary uppercase tracking-wide mb-2\">\r\n {#if featuredItem.type === 'series'}\r\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\r\n Series\r\n {:else}\r\n <span class=\"w-1.5 h-1.5 rounded-full bg-brand-primary\"></span>\r\n Collection\r\n {/if}\r\n {#if featuredItem.subtitle}\r\n <span class=\"text-muted-foreground\">·</span>\r\n {featuredItem.subtitle}\r\n {/if}\r\n </div>\r\n\r\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{featuredItem.title}</h2>\r\n\r\n {#if heroEvent}\r\n <p class=\"text-base text-text-secondary font-medium\">\r\n Next: {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {#if heroEvent.startDateTime}\r\n at {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {/if}\r\n </p>\r\n {/if}\r\n </div>\r\n </div>\r\n {:else if heroEvent}\r\n <!-- Single event hero -->\r\n <div\r\n class=\"featured-hero featured-hero-clickable rounded-lg border border-border bg-card overflow-hidden cursor-pointer hover:border-stroke-primary focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:outline-offset-2\"\r\n onclick={handleClick}\r\n onkeydown={(e) => (e.key === 'Enter' || e.key === ' ') && handleClick()}\r\n tabindex=\"0\"\r\n role=\"button\"\r\n aria-label=\"{heroEvent.name}, {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}. Press Enter to view details.\"\r\n >\r\n <div class=\"hero-image-container relative w-full bg-muted overflow-hidden\">\r\n <img\r\n src={heroEvent.image || PLACEHOLDER_IMAGE}\r\n alt=\"\"\r\n class=\"hero-image\"\r\n aria-hidden=\"true\"\r\n />\r\n </div>\r\n\r\n <div class=\"p-4 sm:p-5\" aria-hidden=\"true\">\r\n <h2 class=\"hero-title text-xl sm:text-2xl font-bold text-text-primary mb-2\">{heroEvent.name}</h2>\r\n\r\n <p class=\"text-base text-text-secondary font-medium\">\r\n {formatFullDate(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {#if heroEvent.startDateTime}\r\n <span class=\"text-muted-foreground mx-1\">·</span>\r\n {formatEventTime(heroEvent.startDateTime, heroEvent.timeZone)}\r\n {/if}\r\n </p>\r\n\r\n {#if heroEvent.description}\r\n <p class=\"hero-description text-sm text-text-secondary mt-2\">{heroEvent.description}</p>\r\n {/if}\r\n </div>\r\n </div>\r\n {:else}\r\n <!-- Empty state -->\r\n <div class=\"flex items-center justify-center py-12 rounded-lg border border-border bg-bg-secondary\">\r\n <p class=\"text-sm text-muted-foreground\">No upcoming events to feature</p>\r\n </div>\r\n {/if}\r\n</section>\r\n\r\n<style>\r\n .hero-image-container {\r\n aspect-ratio: 16 / 9;\r\n }\r\n\r\n .hero-image {\r\n width: 100%;\r\n height: 100%;\r\n object-fit: contain;\r\n }\r\n\r\n .hero-title {\r\n line-height: 1.3;\r\n }\r\n\r\n .featured-hero-clickable {\r\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\r\n }\r\n\r\n .featured-hero-clickable:hover {\r\n box-shadow: 0 4px 12px color-mix(in srgb, black 10%, transparent);\r\n }\r\n\r\n .featured-hero-clickable:focus {\r\n outline: none;\r\n }\r\n\r\n .hero-description {\r\n display: -webkit-box;\r\n -webkit-line-clamp: 2;\r\n line-clamp: 2;\r\n -webkit-box-orient: vertical;\r\n overflow: hidden;\r\n }\r\n\r\n /* Reduced motion */\r\n @media (prefers-reduced-motion: reduce) {\r\n .featured-hero-clickable {\r\n transition: none;\r\n }\r\n }\r\n</style>\r\n"],"names":["events","$","$$props","featuredItem","futureEvents","filterTodayAndFuture","heroEvent","handleClick","section","root","div","root_1","div_1","root_2","img","div_2","root_3","$$render","consequent","alternate","div_3","node_1","div_4","consequent_1","alternate_1","text","consequent_2","h2","p","root_7","formatEventTime","consequent_3","formatFullDate","consequent_4","text_1","div_5","root_9","div_6","img_1","div_7","h2_1","p_1","consequent_6","p_2","root_11","text_7","consequent_7","$0","PLACEHOLDER_IMAGE","text_4","e","div_8","root_12","consequent_8","alternate_2"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import "svelte/internal/disclose-version";
2
2
  import * as e from "svelte/internal/client";
3
- import { aI as p, aJ as A, aM as B, aK as C, aa as G, Q as b, a5 as L, P as O } from "./VenueCalendar-BkRqSb_t.js";
3
+ import { aI as p, aJ as A, aM as B, aK as C, aa as G, Q as b, a5 as L, P as O } from "./VenueCalendar-DFfEZMyW.js";
4
4
  var P = e.from_html('<div class="badge-overlay svelte-18a25gb" aria-hidden="true"><span> </span></div>'), R = e.from_html('<div class="badge-overlay svelte-18a25gb" aria-hidden="true"><!></div>'), H = e.from_html("<time> </time>"), I = e.from_html('<span class="meta-separator svelte-18a25gb" aria-hidden="true">•</span> <span> </span>', 1), M = e.from_html('<a><div class="card-image-container svelte-18a25gb"><img alt="" class="card-image svelte-18a25gb" loading="lazy" aria-hidden="true"/> <!></div> <div class="card-content svelte-18a25gb" aria-hidden="true"><h3 class="card-title svelte-18a25gb"> </h3> <div class="card-meta svelte-18a25gb"><!> <!></div></div></a>');
5
5
  function z(h, i) {
6
6
  e.push(i, !0);
@@ -89,4 +89,4 @@ e.delegate(["click"]);
89
89
  export {
90
90
  z as G
91
91
  };
92
- //# sourceMappingURL=GalleryCard-DGZXM8kt.js.map
92
+ //# sourceMappingURL=GalleryCard-CqgjvH5a.js.map