@getmicdrop/venue-calendar 3.8.4 → 4.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +700 -661
- package/dist/AirbnbSplitMain-CmX4EMJ2.js +2201 -0
- package/dist/AirbnbSplitMain-CmX4EMJ2.js.map +1 -0
- package/dist/{CarouselView.legacy-G433jD--.js → CarouselView.legacy-B4T9YnUY.js} +11 -10
- package/dist/CarouselView.legacy-B4T9YnUY.js.map +1 -0
- package/dist/CartView-C0wKcLTe.js +1667 -0
- package/dist/CartView-C0wKcLTe.js.map +1 -0
- package/dist/Checkout-DAH2LEv7.js +743 -0
- package/dist/Checkout-DAH2LEv7.js.map +1 -0
- package/dist/{Checkout.legacy-HODJd0ax.js → Checkout.legacy-CsJlr7ac.js} +374 -359
- package/dist/Checkout.legacy-CsJlr7ac.js.map +1 -0
- package/dist/CheckoutMain-CIfRFv_0.js +1403 -0
- package/dist/CheckoutMain-CIfRFv_0.js.map +1 -0
- package/dist/CheckoutTimer-DQFe_RCq.js +34 -0
- package/dist/CheckoutTimer-DQFe_RCq.js.map +1 -0
- package/dist/CollectionView-RKiSB7Gj.js +142 -0
- package/dist/CollectionView-RKiSB7Gj.js.map +1 -0
- package/dist/{CollectionView.legacy-CmNcGUzq.js → CollectionView.legacy-CHiKdISC.js} +25 -24
- package/dist/CollectionView.legacy-CHiKdISC.js.map +1 -0
- package/dist/EventDetailsView-BFXXDR_5.js +1187 -0
- package/dist/EventDetailsView-BFXXDR_5.js.map +1 -0
- package/dist/{FeaturedView.legacy-9h2qZMOt.js → FeaturedView.legacy-Bx8r9VRn.js} +15 -15
- package/dist/FeaturedView.legacy-Bx8r9VRn.js.map +1 -0
- package/dist/GalleryCard-UVhZwNEr.js +92 -0
- package/dist/GalleryCard-UVhZwNEr.js.map +1 -0
- package/dist/{GalleryView.legacy-DiA_IVST.js → GalleryView.legacy-CYYCS-Ik.js} +18 -17
- package/dist/GalleryView.legacy-CYYCS-Ik.js.map +1 -0
- package/dist/{GroupedListView.legacy-Bo-kep9X.js → GroupedListView.legacy-_lpo2UrM.js} +25 -25
- package/dist/GroupedListView.legacy-_lpo2UrM.js.map +1 -0
- package/dist/Heading-AFd3o0xt.js +44 -0
- package/dist/Heading-AFd3o0xt.js.map +1 -0
- package/dist/OrderSummarySkeleton-dDKUH741.js +16 -0
- package/dist/OrderSummarySkeleton-dDKUH741.js.map +1 -0
- package/dist/SeriesPage-CFQLBhkC.js +56 -0
- package/dist/SeriesPage-CFQLBhkC.js.map +1 -0
- package/dist/SeriesPage.legacy-C-hADRCm.js +195 -0
- package/dist/SeriesPage.legacy-C-hADRCm.js.map +1 -0
- package/dist/Success-B_q1DLLZ.js +715 -0
- package/dist/Success-B_q1DLLZ.js.map +1 -0
- package/dist/Success.legacy-DU4ReWah.js +195 -0
- package/dist/Success.legacy-DU4ReWah.js.map +1 -0
- package/dist/Text-CXR2fhx6.js +54 -0
- package/dist/Text-CXR2fhx6.js.map +1 -0
- package/dist/{VenueCalendar-DkyugLs1.js → VenueCalendar-BkiDPwSu.js} +11242 -21624
- package/dist/VenueCalendar-BkiDPwSu.js.map +1 -0
- package/dist/ViewTicketsEmbed-Lh-WqskW.js +2038 -0
- package/dist/ViewTicketsEmbed-Lh-WqskW.js.map +1 -0
- package/dist/__SKIP_NAVIGATION__-CJ96TTPE.js +7 -0
- package/dist/__SKIP_NAVIGATION__-CJ96TTPE.js.map +1 -0
- package/dist/api/api.cjs +1 -1
- package/dist/api/api.cjs.map +1 -1
- package/dist/api/api.mjs +511 -279
- package/dist/api/api.mjs.map +1 -1
- package/dist/api/client.d.ts +3 -33
- package/dist/api/cta.d.ts +38 -0
- package/dist/api/events.d.ts +3 -1
- package/dist/api/gift-cards.d.ts +88 -0
- package/dist/api/index.d.ts +6 -0
- package/dist/api/types.d.ts +353 -349
- package/dist/api/waitlist.d.ts +23 -0
- package/dist/colors-BZoMuXdh.js.map +1 -1
- package/dist/labels-BJ37eSuH.js +1351 -0
- package/dist/labels-BJ37eSuH.js.map +1 -0
- package/dist/seo/HostSeoController.d.ts +9 -1
- package/dist/seo/seo.cjs +1 -1
- package/dist/seo/seo.cjs.map +1 -1
- package/dist/seo/seo.mjs +53 -50
- package/dist/seo/seo.mjs.map +1 -1
- package/dist/seo/types.d.ts +137 -136
- package/dist/transform-C3MxXi4m.js +218 -0
- package/dist/transform-C3MxXi4m.js.map +1 -0
- package/dist/types/index.d.ts +387 -387
- package/dist/venue-calendar.css +1 -1
- package/dist/venue-calendar.es.js +36 -28
- package/dist/venue-calendar.es.js.map +1 -1
- package/dist/venue-calendar.iife.js +43 -43
- package/dist/venue-calendar.iife.js.map +1 -1
- package/dist/venue-calendar.umd.js +40 -40
- package/dist/venue-calendar.umd.js.map +1 -1
- package/package.json +44 -6
- package/src/lib/theme.js +13 -0
- package/dist/CarouselView.legacy-G433jD--.js.map +0 -1
- package/dist/Checkout.legacy-HODJd0ax.js.map +0 -1
- package/dist/CollectionView.legacy-CmNcGUzq.js.map +0 -1
- package/dist/FeaturedView.legacy-9h2qZMOt.js.map +0 -1
- package/dist/GalleryView.legacy-DiA_IVST.js.map +0 -1
- package/dist/GroupedListView.legacy-Bo-kep9X.js.map +0 -1
- package/dist/SeriesPage.legacy-BjDBPDcq.js +0 -190
- package/dist/SeriesPage.legacy-BjDBPDcq.js.map +0 -1
- package/dist/Success.legacy-D86LAPHq.js +0 -194
- package/dist/Success.legacy-D86LAPHq.js.map +0 -1
- package/dist/VenueCalendar-DkyugLs1.js.map +0 -1
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import "svelte/internal/disclose-version";
|
|
2
2
|
import * as e from "svelte/internal/client";
|
|
3
3
|
import { onMount as te, onDestroy as ae } from "svelte";
|
|
4
|
-
import {
|
|
4
|
+
import { ax as re, ay as se, az as ie, aA as le, aB as ne, a3 as A, J as B, _ as oe } from "./VenueCalendar-BkiDPwSu.js";
|
|
5
5
|
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>"), ge = 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>'), fe = 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>');
|
|
6
|
-
function he(
|
|
6
|
+
function he(F, m) {
|
|
7
7
|
e.push(m, !0);
|
|
8
|
-
let k = e.prop(m, "events", 19, () => []),
|
|
9
|
-
function
|
|
10
|
-
_ +=
|
|
8
|
+
let k = e.prop(m, "events", 19, () => []), L = e.prop(m, "initialCount", 3, 10), U = e.prop(m, "loadMoreCount", 3, 10), T = e.prop(m, "showDateColumn", 3, !0), G = e.prop(m, "filterFutureOnly", 3, !0), _ = L(), v, c, E = e.derived(() => G() ? re(k()) : k()), I = e.derived(() => R(e.get(E).slice(0, _))), C = e.derived(() => _ < e.get(E).length);
|
|
9
|
+
function P() {
|
|
10
|
+
_ += U();
|
|
11
11
|
}
|
|
12
12
|
te(() => {
|
|
13
13
|
c = new IntersectionObserver(
|
|
14
14
|
(r) => {
|
|
15
|
-
r[0].isIntersecting && e.get(C) &&
|
|
15
|
+
r[0].isIntersecting && e.get(C) && P();
|
|
16
16
|
},
|
|
17
17
|
{ rootMargin: "100px" }
|
|
18
18
|
), v && c.observe(v);
|
|
@@ -27,9 +27,9 @@ function he(P, m) {
|
|
|
27
27
|
const n = s.date;
|
|
28
28
|
a[n] || (a[n] = []), a[n].push(s);
|
|
29
29
|
}
|
|
30
|
-
return Object.entries(a).sort(([s], [n]) => new Date(s) - new Date(n)).map(([s, n]) => ({ date: s, events: n, formattedDate:
|
|
30
|
+
return Object.entries(a).sort(([s], [n]) => new Date(s) - new Date(n)).map(([s, n]) => ({ date: s, events: n, formattedDate: z(n) }));
|
|
31
31
|
}
|
|
32
|
-
function
|
|
32
|
+
function z(r) {
|
|
33
33
|
const a = r[0];
|
|
34
34
|
if (!a?.startDateTime) return { month: "", day: "", weekday: "" };
|
|
35
35
|
const s = se(a.startDateTime, a.timeZone);
|
|
@@ -42,16 +42,16 @@ function he(P, m) {
|
|
|
42
42
|
function M(r) {
|
|
43
43
|
m.oneventClick?.(r);
|
|
44
44
|
}
|
|
45
|
-
function
|
|
45
|
+
function K(r, a) {
|
|
46
46
|
(r.key === "Enter" || r.key === " ") && (r.preventDefault(), M(a));
|
|
47
47
|
}
|
|
48
48
|
var b = ue();
|
|
49
|
-
let
|
|
50
|
-
var
|
|
51
|
-
e.each(
|
|
49
|
+
let O;
|
|
50
|
+
var S = e.sibling(e.child(b), 2);
|
|
51
|
+
e.each(S, 17, () => e.get(I), e.index, (r, a) => {
|
|
52
52
|
var s = fe(), n = e.child(s);
|
|
53
53
|
{
|
|
54
|
-
var
|
|
54
|
+
var V = (g) => {
|
|
55
55
|
var t = de(), o = e.child(t), y = e.child(o, !0);
|
|
56
56
|
e.reset(o);
|
|
57
57
|
var f = e.sibling(o, 2), d = e.child(f, !0);
|
|
@@ -62,7 +62,7 @@ function he(P, m) {
|
|
|
62
62
|
}), e.append(g, t);
|
|
63
63
|
};
|
|
64
64
|
e.if(n, (g) => {
|
|
65
|
-
T() && g(
|
|
65
|
+
T() && g(V);
|
|
66
66
|
});
|
|
67
67
|
}
|
|
68
68
|
var j = e.sibling(n, 2);
|
|
@@ -70,7 +70,7 @@ function he(P, m) {
|
|
|
70
70
|
const o = e.derived(() => ie(e.get(t))), y = e.derived(() => le(e.get(o)));
|
|
71
71
|
var f = ge(), d = e.child(f);
|
|
72
72
|
let u;
|
|
73
|
-
var p = e.child(d),
|
|
73
|
+
var p = e.child(d), q = e.child(p);
|
|
74
74
|
e.reset(p);
|
|
75
75
|
var w = e.sibling(p, 2), D = e.child(w), N = e.child(D, !0);
|
|
76
76
|
e.reset(D);
|
|
@@ -114,31 +114,31 @@ function he(P, m) {
|
|
|
114
114
|
}
|
|
115
115
|
e.reset(Z), e.reset(d), e.reset(f), e.template_effect(
|
|
116
116
|
(i, l) => {
|
|
117
|
-
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(
|
|
117
|
+
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(q, "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);
|
|
118
118
|
},
|
|
119
119
|
[
|
|
120
|
-
() => `${e.get(t).name} on ${e.get(t).startDateTime ?
|
|
121
|
-
() => e.get(t).startDateTime ?
|
|
120
|
+
() => `${e.get(t).name} on ${e.get(t).startDateTime ? A(e.get(t).startDateTime, e.get(t).timeZone) : e.get(a).date} at ${e.get(t).startDateTime ? B(e.get(t).startDateTime, e.get(t).timeZone) : ""}, ${e.get(o)?.text || e.get(t).status || "On Sale"}. Press Enter to view details.`,
|
|
121
|
+
() => e.get(t).startDateTime ? B(e.get(t).startDateTime, e.get(t).timeZone) : ""
|
|
122
122
|
]
|
|
123
|
-
), e.delegated("click", d, () => M(e.get(t))), e.delegated("keydown", d, (i) =>
|
|
123
|
+
), e.delegated("click", d, () => M(e.get(t))), e.delegated("keydown", d, (i) => K(i, e.get(t))), e.append(g, f);
|
|
124
124
|
}), e.reset(j), e.reset(s), e.template_effect((g) => e.set_attribute(s, "aria-label", `Events on ${g ?? ""}`), [
|
|
125
|
-
() => e.get(a).events[0]?.startDateTime ?
|
|
125
|
+
() => e.get(a).events[0]?.startDateTime ? A(e.get(a).events[0].startDateTime, e.get(a).events[0].timeZone) : e.get(a).date
|
|
126
126
|
]), e.append(r, s);
|
|
127
127
|
});
|
|
128
|
-
var H = e.sibling(
|
|
128
|
+
var H = e.sibling(S, 2);
|
|
129
129
|
{
|
|
130
|
-
var
|
|
130
|
+
var J = (r) => {
|
|
131
131
|
var a = ve();
|
|
132
132
|
e.bind_this(a, (s) => v = s, () => v), e.append(r, a);
|
|
133
133
|
};
|
|
134
134
|
e.if(H, (r) => {
|
|
135
|
-
e.get(C) && r(
|
|
135
|
+
e.get(C) && r(J);
|
|
136
136
|
});
|
|
137
137
|
}
|
|
138
|
-
e.reset(b), e.template_effect(() =>
|
|
138
|
+
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(F, b), e.pop();
|
|
139
139
|
}
|
|
140
140
|
e.delegate(["click", "keydown"]);
|
|
141
141
|
export {
|
|
142
142
|
he as default
|
|
143
143
|
};
|
|
144
|
-
//# sourceMappingURL=GroupedListView.legacy-
|
|
144
|
+
//# sourceMappingURL=GroupedListView.legacy-_lpo2UrM.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GroupedListView.legacy-_lpo2UrM.js","sources":["../src/components/Calendar/GroupedListView.legacy.svelte"],"sourcesContent":["<script>\n import { onMount, onDestroy } from \"svelte\";\n import { PLACEHOLDER_IMAGE } from \"$lib/utils/constants.js\";\n import { getDateParts, formatFullDate, formatEventTime } from \"$lib/utils/datetime.js\";\n import { getBrowseStatus, isEventUnavailable, filterTodayAndFuture } from \"$lib/utils/browse-status.js\";\n import ScarcityBadge from \"../ScarcityBadge.svelte\";\n\n let {\n events = [],\n initialCount = 10,\n loadMoreCount = 10,\n showDateColumn = true,\n filterFutureOnly = true,\n oneventClick\n } = $props();\n\n let displayedCount = initialCount;\n let loadMoreTrigger;\n let observer;\n\n // Filter to today and future (if enabled), then group by date\n let filteredEvents = $derived(filterFutureOnly ? filterTodayAndFuture(events) : events);\n let groupedEvents = $derived(groupEventsByDate(filteredEvents.slice(0, displayedCount)));\n let hasMore = $derived(displayedCount < filteredEvents.length);\n\n function loadMore() {\n displayedCount += loadMoreCount;\n }\n\n onMount(() => {\n observer = new IntersectionObserver(\n (entries) => {\n if (entries[0].isIntersecting && hasMore) {\n loadMore();\n }\n },\n { rootMargin: '100px' }\n );\n\n if (loadMoreTrigger) {\n observer.observe(loadMoreTrigger);\n }\n });\n\n onDestroy(() => {\n if (observer) {\n observer.disconnect();\n }\n });\n\n // Re-observe when trigger element changes\n $effect(() => {\n if (observer && loadMoreTrigger) {\n observer.disconnect();\n observer.observe(loadMoreTrigger);\n }\n });\n\n function groupEventsByDate(eventList) {\n const groups = {};\n\n for (const event of eventList) {\n const dateKey = event.date; // YYYY-MM-DD format\n if (!groups[dateKey]) {\n groups[dateKey] = [];\n }\n groups[dateKey].push(event);\n }\n\n // Convert to array sorted by date\n return Object.entries(groups)\n .sort(([a], [b]) => new Date(a) - new Date(b))\n .map(([date, events]) => ({\n date,\n events,\n formattedDate: formatGroupDate(events),\n }));\n }\n\n function formatGroupDate(events) {\n // Use the first event in the group to get timezone-aware date parts\n const firstEvent = events[0];\n if (!firstEvent?.startDateTime) return { month: '', day: '', weekday: '' };\n const parts = getDateParts(firstEvent.startDateTime, firstEvent.timeZone);\n return {\n month: parts.month.toUpperCase(),\n day: String(parts.date).padStart(2, '0'),\n weekday: parts.day.toUpperCase(),\n };\n }\n\n function handleEventClick(event) {\n oneventClick?.(event);\n }\n\n function handleKeydown(e, event) {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleEventClick(event);\n }\n }\n</script>\n\n<section class=\"flex flex-col gap-0\" class:no-date-column={!showDateColumn} aria-label=\"Event listings\">\n <h2 class=\"sr-only\">Event list grouped by date</h2>\n {#each groupedEvents as group}\n <div class=\"date-group flex border-b border-border last:border-b-0\" role=\"group\" aria-label=\"Events on {group.events[0]?.startDateTime ? formatFullDate(group.events[0].startDateTime, group.events[0].timeZone) : group.date}\">\n <!-- Date Column -->\n {#if showDateColumn}\n <div class=\"w-16 min-w-16 py-4 px-2.5 flex flex-col items-center justify-start bg-bg-secondary border-r border-border max-sm:w-12 max-sm:min-w-12 max-sm:py-2.5 max-sm:px-1.5\" aria-hidden=\"true\">\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.month}</span>\n <span class=\"text-2xl max-sm:text-lg font-bold text-text-primary leading-tight\">{group.formattedDate.day}</span>\n <span class=\"text-xs font-semibold text-text-secondary uppercase tracking-tight\">{group.formattedDate.weekday}</span>\n </div>\n {/if}\n\n <!-- Events Column -->\n <ul class=\"events-column flex-1 flex flex-col list-none p-0 m-0\">\n {#each group.events as event, eventIndex}\n {@const eventStatus = getBrowseStatus(event)}\n {@const isUnavailable = isEventUnavailable(eventStatus)}\n <li class=\"list-none\">\n <div\n class=\"event-row flex gap-4 max-sm:gap-2.5 p-5 max-sm:p-3 cursor-pointer transition-colors duration-150 bg-card border-b border-border/50 last:border-b-0 hover:bg-bg-secondary focus:outline-2 focus:outline-brand-primary focus:-outline-offset-2 focus-visible:outline-2 focus-visible:outline-brand-primary:outline-brand-primary focus-visible:-outline-offset-2\"\n class:row-unavailable={isUnavailable}\n onclick={() => handleEventClick(event)}\n onkeydown={(e) => handleKeydown(e, event)}\n tabindex=\"0\"\n role=\"button\"\n aria-label={`${event.name} on ${event.startDateTime ? formatFullDate(event.startDateTime, event.timeZone) : group.date} at ${event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}, ${eventStatus?.text || event.status || 'On Sale'}. Press Enter to view details.`}\n >\n <!-- Event Image -->\n <div class=\"w-36 h-24 min-w-36 max-sm:w-20 max-sm:h-16 max-sm:min-w-20 rounded-lg overflow-hidden bg-bg-secondary flex items-center justify-center\" aria-hidden=\"true\">\n <img\n src={event.image || PLACEHOLDER_IMAGE}\n alt=\"\"\n class=\"w-full h-full object-contain\"\n loading=\"lazy\"\n />\n </div>\n\n <!-- Event Details (visually shown but also in aria-label, so hide from SR) -->\n <div class=\"flex-1 flex flex-col gap-1.5 min-w-0\" aria-hidden=\"true\">\n <h3 class=\"text-lg max-sm:text-sm font-semibold text-text-primary m-0 leading-snug\">{event.name}</h3>\n <time class=\"text-sm max-sm:text-xs font-medium text-text-secondary\" datetime={event.startDateTime || group.date}>{event.startDateTime ? formatEventTime(event.startDateTime, event.timeZone) : ''}</time>\n {#if event.description}\n <p class=\"event-description text-sm text-text-secondary mt-1.5 mb-0 line-clamp-2 max-sm:hidden\">{event.description}</p>\n {/if}\n </div>\n\n <!-- Status / Scarcity Badge -->\n <div class=\"flex items-start pt-0.5\" aria-hidden=\"true\">\n {#if eventStatus}\n <span class=\"status-badge status-{eventStatus.type}\">{eventStatus.text}</span>\n {:else if event.ticketsTotal > 0 || event.ticketsRemaining === 0}\n <ScarcityBadge\n remaining={event.ticketsRemaining ?? 0}\n total={event.ticketsTotal ?? 0}\n context=\"browse\"\n />\n {/if}\n </div>\n </div>\n </li>\n {/each}\n </ul>\n </div>\n {/each}\n\n <!-- Infinite scroll trigger -->\n {#if hasMore}\n <div bind:this={loadMoreTrigger} class=\"flex justify-center items-center p-6 text-text-secondary\" role=\"status\" aria-live=\"polite\">\n <span class=\"text-sm\">Loading more events...</span>\n </div>\n {/if}\n</section>\n\n<style>\n /* When no date column, remove left border styling */\n .no-date-column .date-group {\n border-bottom: 0;\n }\n\n .no-date-column .events-column {\n border-left: 0;\n }\n\n .event-description {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n }\n\n /* Unavailable row dimming */\n .row-unavailable {\n opacity: 0.6;\n }\n\n .row-unavailable img {\n filter: grayscale(0.5);\n }\n\n /* Status badges -- distinct visual treatments matching gallery cards */\n .status-badge {\n display: inline-flex;\n align-items: center;\n font-size: 0.75rem;\n line-height: 1rem;\n font-weight: 700;\n padding: 0.25rem 0.625rem;\n border-radius: 0.25rem;\n white-space: nowrap;\n letter-spacing: 0.02em;\n }\n\n .status-cancelled {\n background-color: hsl(var(--accent-danger) / 10%);\n color: hsl(var(--accent-danger));\n text-decoration: line-through;\n text-decoration-thickness: 1.5px;\n\n \n }\n\n .status-past {\n background-color: hsl(var(--bg-tertiary));\n color: hsl(var(--text-tertiary));\n\n \n }\n\n .status-sold_out {\n background-color: hsl(var(--accent-danger) / 10%);\n color: hsl(var(--accent-danger));\n text-transform: uppercase;\n letter-spacing: 0.05em;\n font-size: 0.65rem;\n\n \n }\n\n .status-sales_ended {\n background-color: hsl(var(--bg-tertiary));\n color: hsl(var(--text-tertiary));\n border: 1px solid hsl(var(--stroke-primary));\n\n \n }\n\n .status-coming_soon {\n background-color: hsl(var(--brand-primary) / 15%);\n color: hsl(var(--brand-primary));\n\n \n }\n\n /* Reduced motion */\n @media (prefers-reduced-motion: reduce) {\n .event-row {\n transition: none;\n }\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n</style>\n"],"names":["events","$","$$props","initialCount","loadMoreCount","showDateColumn","filterFutureOnly","displayedCount","loadMoreTrigger","observer","filteredEvents","filterTodayAndFuture","groupedEvents","groupEventsByDate","hasMore","loadMore","onMount","entries","onDestroy","eventList","groups","event","dateKey","a","b","date","formatGroupDate","firstEvent","parts","getDateParts","handleEventClick","handleKeydown","e","section","root","node","group","div","root_1","div_1","root_2","span","span_1","span_2","$$render","consequent","ul","node_1","eventStatus","getBrowseStatus","isUnavailable","isEventUnavailable","li","root_3","div_2","div_3","img","div_4","h3","time","p","root_4","text_5","consequent_1","div_5","span_3","root_5","text_6","ScarcityBadge","$$anchor","consequent_2","consequent_3","classes_1","$0","PLACEHOLDER_IMAGE","text_3","formatFullDate","formatEventTime","div_6","root_7","$$value","consequent_4","classes"],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import "svelte/internal/disclose-version";
|
|
2
|
+
import * as e from "svelte/internal/client";
|
|
3
|
+
function y(i, t) {
|
|
4
|
+
e.push(t, !0);
|
|
5
|
+
let l = e.prop(t, "level", 3, 2), o = e.prop(t, "weight", 3, "semibold"), x = e.prop(t, "color", 3, "default"), n = e.prop(t, "class", 3, "");
|
|
6
|
+
const m = { 1: "3xl", 2: "2xl", 3: "xl", 4: "lg", 5: "base", 6: "sm" }, d = {
|
|
7
|
+
xs: "text-xs",
|
|
8
|
+
sm: "text-sm",
|
|
9
|
+
base: "text-base",
|
|
10
|
+
md: "text-base",
|
|
11
|
+
lg: "text-lg",
|
|
12
|
+
xl: "text-xl",
|
|
13
|
+
"2xl": "text-2xl",
|
|
14
|
+
"3xl": "text-3xl",
|
|
15
|
+
"4xl": "text-4xl",
|
|
16
|
+
"5xl": "text-5xl"
|
|
17
|
+
}, r = {
|
|
18
|
+
normal: "font-normal",
|
|
19
|
+
medium: "font-medium",
|
|
20
|
+
semibold: "font-semibold",
|
|
21
|
+
bold: "font-bold"
|
|
22
|
+
}, c = {
|
|
23
|
+
default: "text-text-primary",
|
|
24
|
+
muted: "text-text-secondary",
|
|
25
|
+
primary: "text-primary",
|
|
26
|
+
none: ""
|
|
27
|
+
};
|
|
28
|
+
let f = e.derived(() => t.size || m[l()]), g = e.derived(() => `h${l()}`), v = e.derived(() => [
|
|
29
|
+
d[e.get(f)] || "text-lg",
|
|
30
|
+
r[o()],
|
|
31
|
+
c[x()] || "",
|
|
32
|
+
n()
|
|
33
|
+
].filter(Boolean).join(" "));
|
|
34
|
+
var s = e.comment(), b = e.first_child(s);
|
|
35
|
+
e.element(b, () => e.get(g), !1, (p, u) => {
|
|
36
|
+
e.attribute_effect(p, () => ({ id: t.id, class: e.get(v) }));
|
|
37
|
+
var a = e.comment(), h = e.first_child(a);
|
|
38
|
+
e.snippet(h, () => t.children), e.append(u, a);
|
|
39
|
+
}), e.append(i, s), e.pop();
|
|
40
|
+
}
|
|
41
|
+
export {
|
|
42
|
+
y as H
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=Heading-AFd3o0xt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Heading-AFd3o0xt.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/components/Heading.svelte"],"sourcesContent":["<script lang=\"ts\">\n import type { Snippet } from 'svelte';\n\n type Level = 1 | 2 | 3 | 4 | 5 | 6;\n type Size = 'xs' | 'sm' | 'base' | 'md' | 'lg' | 'xl' | '2xl' | '3xl' | '4xl' | '5xl';\n\n interface Props {\n level?: Level;\n size?: Size;\n weight?: 'normal' | 'medium' | 'semibold' | 'bold';\n color?: 'default' | 'muted' | 'primary' | 'none';\n class?: string;\n id?: string;\n children: Snippet;\n }\n\n let {\n level = 2,\n size,\n weight = 'semibold',\n color = 'default',\n class: className = '',\n id,\n children,\n }: Props = $props();\n\n const levelToSize: Record<Level, Size> = {\n 1: '3xl',\n 2: '2xl',\n 3: 'xl',\n 4: 'lg',\n 5: 'base',\n 6: 'sm',\n };\n\n const sizeClasses: Record<string, string> = {\n xs: 'text-xs',\n sm: 'text-sm',\n base: 'text-base',\n md: 'text-base',\n lg: 'text-lg',\n xl: 'text-xl',\n '2xl': 'text-2xl',\n '3xl': 'text-3xl',\n '4xl': 'text-4xl',\n '5xl': 'text-5xl',\n };\n\n const weightClasses: Record<string, string> = {\n normal: 'font-normal',\n medium: 'font-medium',\n semibold: 'font-semibold',\n bold: 'font-bold',\n };\n\n const colorClasses: Record<string, string> = {\n default: 'text-text-primary',\n muted: 'text-text-secondary',\n primary: 'text-primary',\n none: '',\n };\n\n let effectiveSize = $derived(size || levelToSize[level]);\n let element = $derived(`h${level}` as 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6');\n\n let classes = $derived(\n [\n sizeClasses[effectiveSize] || 'text-lg',\n weightClasses[weight],\n colorClasses[color] || '',\n className,\n ]\n .filter(Boolean)\n .join(' '),\n );\n</script>\n\n<svelte:element this={element} {id} class={classes}>{@render children()}</svelte:element>\n"],"names":["level","weight","color","className","levelToSize","sizeClasses","weightClasses","colorClasses","effectiveSize","$","$$props","element","classes","$$element","$$anchor"],"mappings":";;iBAAA;;AAiBI,MAAAA,0BAAQ,CAAC,GAETC,2BAAS,UAAU,GACnBC,0BAAQ,SAAS,GACVC,0BAAY,EAAE;QAKjBC,IAAgC,EACpC,GAAG,OACH,GAAG,OACH,GAAG,MACH,GAAG,MACH,GAAG,QACH,GAAG,KAAI,GAGHC,IAAmC;AAAA,IACvC,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,MAAM;AAAA,IACN,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,KAGHC,IAAqC;AAAA,IACzC,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,MAAM;AAAA,KAGFC,IAAoC;AAAA,IACxC,SAAS;AAAA,IACT,OAAO;AAAA,IACP,SAAS;AAAA,IACT,MAAM;AAAA;MAGJC,IAAaC,EAAA,QAAA,MAAAC,EAAA,QAAoBN,EAAYJ,EAAK,CAAA,CAAA,GAClDW,wBAAuBX,EAAK,CAAA,EAAA,GAE5BY,IAAOH,EAAA,QAAA,MAAA;AAAA,IAEPJ,EAAWI,EAAA,IAACD,CAAa,CAAA,KAAK;AAAA,IAC9BF,EAAcL,EAAM,CAAA;AAAA,IACpBM,EAAaL,EAAK,CAAA,KAAK;AAAA,IACvBC,EAAS;AAAA,EAER,EAAA,OAAO,OAAO,EACd,KAAK,GAAG,CAAA;;2BAIOQ,CAAO,GAAA,IAAA,CAAAE,GAAAC,MAAA;0DAAcF,CAAO,EAAA,EAAA;;;;AAF1C;","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import "svelte/internal/disclose-version";
|
|
2
|
+
import * as d from "svelte/internal/client";
|
|
3
|
+
var b = d.from_html('<div class="flex justify-between items-center pb-4 border-b border-border" aria-hidden="true"><div><div class="h-4 rounded w-24 mb-2 bg-bg-tertiary"></div> <div class="h-3 rounded w-16 bg-bg-tertiary"></div></div> <div class="h-4 rounded w-12 bg-bg-tertiary"></div></div>'), l = d.from_html('<div class="hidden md:block h-fit rounded-lg p-5 space-y-5 animate-pulse bg-card border border-border" role="status" aria-busy="true"><span class="sr-only svelte-19v1kvb">Loading order summary...</span> <div class="h-6 rounded w-2/3 bg-bg-tertiary" aria-hidden="true"></div> <!> <div class="space-y-3 pt-4" aria-hidden="true"><div class="flex justify-between"><div class="h-4 rounded w-20 bg-bg-tertiary"></div> <div class="h-4 rounded w-12 bg-bg-tertiary"></div></div> <div class="flex justify-between"><div class="h-4 rounded w-16 bg-bg-tertiary"></div> <div class="h-4 rounded w-12 bg-bg-tertiary"></div></div> <div class="flex justify-between"><div class="h-4 rounded w-12 bg-bg-tertiary"></div> <div class="h-4 rounded w-12 bg-bg-tertiary"></div></div></div> <div class="h-10 rounded mt-5 bg-muted" aria-hidden="true"></div></div>');
|
|
4
|
+
function u(i, r) {
|
|
5
|
+
d.push(r, !0);
|
|
6
|
+
let a = d.prop(r, "labels", 19, () => ({}));
|
|
7
|
+
var e = l(), t = d.sibling(d.child(e), 4);
|
|
8
|
+
d.each(t, 16, () => Array(2), d.index, (s, o) => {
|
|
9
|
+
var v = b();
|
|
10
|
+
d.append(s, v);
|
|
11
|
+
}), d.next(4), d.reset(e), d.template_effect(() => d.set_attribute(e, "aria-label", a().loadingOrderSummary || "Loading order summary")), d.append(i, e), d.pop();
|
|
12
|
+
}
|
|
13
|
+
export {
|
|
14
|
+
u as O
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=OrderSummarySkeleton-dDKUH741.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OrderSummarySkeleton-dDKUH741.js","sources":["../src/components/Events/Tickets/OrderSummarySkeleton.svelte"],"sourcesContent":["<script>\n let { labels = {} } = $props();\n</script>\n\n<div\n class=\"hidden md:block h-fit rounded-lg p-5 space-y-5 animate-pulse bg-card border border-border\"\n role=\"status\"\n aria-busy=\"true\"\n aria-label={labels.loadingOrderSummary || \"Loading order summary\"}\n>\n <span class=\"sr-only\">Loading order summary...</span>\n <div class=\"h-6 rounded w-2/3 bg-bg-tertiary\" aria-hidden=\"true\"></div>\n\n {#each Array(2) as _}\n <div class=\"flex justify-between items-center pb-4 border-b border-border\" aria-hidden=\"true\">\n <div>\n <div class=\"h-4 rounded w-24 mb-2 bg-bg-tertiary\"></div>\n <div class=\"h-3 rounded w-16 bg-bg-tertiary\"></div>\n </div>\n <div class=\"h-4 rounded w-12 bg-bg-tertiary\"></div>\n </div>\n {/each}\n\n <div class=\"space-y-3 pt-4\" aria-hidden=\"true\">\n <div class=\"flex justify-between\">\n <div class=\"h-4 rounded w-20 bg-bg-tertiary\"></div>\n <div class=\"h-4 rounded w-12 bg-bg-tertiary\"></div>\n </div>\n <div class=\"flex justify-between\">\n <div class=\"h-4 rounded w-16 bg-bg-tertiary\"></div>\n <div class=\"h-4 rounded w-12 bg-bg-tertiary\"></div>\n </div>\n <div class=\"flex justify-between\">\n <div class=\"h-4 rounded w-12 bg-bg-tertiary\"></div>\n <div class=\"h-4 rounded w-12 bg-bg-tertiary\"></div>\n </div>\n </div>\n\n <div class=\"h-10 rounded mt-5 bg-muted\" aria-hidden=\"true\"></div>\n</div>\n\n<style>\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n }\n</style>\n"],"names":["labels","$","$$props","div","root","$$anchor","_","div_1","root_1"],"mappings":";;;iBAAA;;MACQA,IAAMC,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA;MAGbC,IAAEC,EAAA,yBAAFD,CAAE,GAAA,CAAA;sBASM,MAAM,CAAC,GAAAF,EAAA,OAAA,CAAAI,GAAKC,MAAC;QACjBC,IAAGC,EAAA;gBAAHD,CAAG;AAAA,yBAVPJ,CAAE,GAAFF,EAAA,gBAAA,MAAAA,EAAA,cAAAE,GAAE,cAIWH,EAAM,EAAC,uBAAuB,uBAAuB,CAAA,eAJlEG,CAAE;AAFK;"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import "svelte/internal/disclose-version";
|
|
2
|
+
import * as e from "svelte/internal/client";
|
|
3
|
+
import { g as S } from "./__SKIP_NAVIGATION__-CJ96TTPE.js";
|
|
4
|
+
import { h as w } from "./VenueCalendar-BkiDPwSu.js";
|
|
5
|
+
import "svelte/internal/flags/legacy";
|
|
6
|
+
import "svelte/transition";
|
|
7
|
+
import "svelte/easing";
|
|
8
|
+
import { A as E } from "./AirbnbSplitMain-CmX4EMJ2.js";
|
|
9
|
+
import { a as C } from "./transform-C3MxXi4m.js";
|
|
10
|
+
function R(f, a) {
|
|
11
|
+
e.push(a, !0);
|
|
12
|
+
const m = w("SeriesPage");
|
|
13
|
+
let r = e.state(!1), i = e.state(null);
|
|
14
|
+
typeof window < "u" && new URLSearchParams(window.location.search).get("legacy") === "1" && e.set(r, !0), e.user_effect(() => {
|
|
15
|
+
e.get(r) && !e.get(i) && (m.warn("[VC] DEPRECATED: ?legacy=1 fallback for SeriesPage retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md."), import("./SeriesPage.legacy-C-hADRCm.js").then((t) => {
|
|
16
|
+
e.set(i, t.default, !0);
|
|
17
|
+
}).catch(() => {
|
|
18
|
+
e.set(r, !1);
|
|
19
|
+
}));
|
|
20
|
+
});
|
|
21
|
+
let o = e.prop(a, "onNavigateToOccurrence", 3, void 0), n = e.derived(() => a.series ? C(a.series) : null);
|
|
22
|
+
function l(t) {
|
|
23
|
+
o() ? o()(t.id, t.slug) : S(`/${t.id}/${t.slug}`);
|
|
24
|
+
}
|
|
25
|
+
var s = e.comment(), c = e.first_child(s);
|
|
26
|
+
{
|
|
27
|
+
var d = (t) => {
|
|
28
|
+
var g = e.comment(), p = e.first_child(g);
|
|
29
|
+
e.component(p, () => e.get(i), (v, h) => {
|
|
30
|
+
h(v, {
|
|
31
|
+
get series() {
|
|
32
|
+
return a.series;
|
|
33
|
+
},
|
|
34
|
+
get onNavigateToOccurrence() {
|
|
35
|
+
return o();
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}), e.append(t, g);
|
|
39
|
+
}, u = (t) => {
|
|
40
|
+
E(t, {
|
|
41
|
+
get event() {
|
|
42
|
+
return e.get(n);
|
|
43
|
+
},
|
|
44
|
+
onShowtimeClick: l
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
e.if(c, (t) => {
|
|
48
|
+
e.get(r) && e.get(i) ? t(d) : e.get(n) && t(u, 1);
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
e.append(f, s), e.pop();
|
|
52
|
+
}
|
|
53
|
+
export {
|
|
54
|
+
R as default
|
|
55
|
+
};
|
|
56
|
+
//# sourceMappingURL=SeriesPage-CFQLBhkC.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SeriesPage-CFQLBhkC.js","sources":["../src/components/Views/SeriesPage.svelte"],"sourcesContent":["<script lang=\"ts\">\n\timport { goto } from '$app/navigation';\n\timport { createLogger } from '@getmicdrop/svelte-components';\n\timport AirbnbSplitMain from '$lib/premium-ticket-experience/variants/v3-airbnb-split/AirbnbSplitMain.svelte';\n\timport { transformSeriesPageData } from '$lib/premium-ticket-experience/transform';\n\n\tconst logger = createLogger('SeriesPage');\n\n\t// --- Legacy fallback ---\n\t// RETIREMENT: 2026-08-13 — see docs/LEGACY_RETIREMENT.md.\n\tlet useLegacy = $state(false);\n\tlet LegacyComponent: any = $state(null);\n\n\tif (typeof window !== 'undefined') {\n\t\tconst params = new URLSearchParams(window.location.search);\n\t\tif (params.get('legacy') === '1') {\n\t\t\tuseLegacy = true;\n\t\t}\n\t}\n\n\t$effect(() => {\n\t\tif (useLegacy && !LegacyComponent) {\n\t\t\tlogger.warn(\n\t\t\t\t'[VC] DEPRECATED: ?legacy=1 fallback for SeriesPage retires on 2026-08-13. See docs/LEGACY_RETIREMENT.md.'\n\t\t\t);\n\t\t\timport('./SeriesPage.legacy.svelte').then((m) => {\n\t\t\t\tLegacyComponent = m.default;\n\t\t\t}).catch(() => {\n\t\t\t\tuseLegacy = false;\n\t\t\t});\n\t\t}\n\t});\n\n\t// --- Props (matches old SeriesPage external interface) ---\n\tinterface Props {\n\t\tseries: any;\n\t\tonNavigateToOccurrence?: (id: number, slug: string, name?: string) => void;\n\t}\n\n\tlet {\n\t\tseries,\n\t\tonNavigateToOccurrence = undefined,\n\t}: Props = $props();\n\n\t// Transform series data to EventData for AirbnbSplitMain\n\tlet eventData = $derived(series ? transformSeriesPageData(series) : null);\n\n\t// Handle occurrence click — delegate to callback or navigate directly\n\tfunction handleShowtimeClick(occurrence: { id: number; slug: string }): void {\n\t\tif (onNavigateToOccurrence) {\n\t\t\tonNavigateToOccurrence(occurrence.id, occurrence.slug);\n\t\t} else {\n\t\t\tgoto(`/${occurrence.id}/${occurrence.slug}`);\n\t\t}\n\t}\n</script>\n\n{#if useLegacy && LegacyComponent}\n\t<svelte:component this={LegacyComponent}\n\t\t{series}\n\t\t{onNavigateToOccurrence}\n\t/>\n{:else if eventData}\n\t<AirbnbSplitMain\n\t\tevent={eventData}\n\t\tonShowtimeClick={handleShowtimeClick}\n\t/>\n{/if}\n\n"],"names":["logger","createLogger","useLegacy","$","LegacyComponent","m","onNavigateToOccurrence","eventData","$$props","transformSeriesPageData","handleShowtimeClick","occurrence","goto","$$anchor","$$component","AirbnbSplitMain","$$render","consequent","consequent_1"],"mappings":";;;;;;;;;iBAAA;;QAMOA,IAASC,EAAa,YAAY;MAIpCC,IAAYC,EAAA,MAAO,EAAK,GACxBC,IAAuBD,EAAA,MAAO,IAAI;SAE3B,SAAW,WACF,gBAAgB,OAAO,SAAS,MAAM,EAC9C,IAAI,QAAQ,MAAM,OAC5BA,EAAA,IAAAD,GAAY,EAAI,GAIlBC,EAAA,YAAO,MAAO;UACTD,CAAS,KAAA,CAAAC,EAAA,IAAKC,CAAe,MAChCJ,EAAO,KACN,0GAAyG,GAEnG,OAAA,iCAA4B,EAAE,KAAI,CAAEK,MAAM;YAChDD,GAAkBC,EAAE,SAAO,EAAA;AAAA,IAC5B,CAAC,EAAE,MAAK,MAAO;AACd,MAAAF,EAAA,IAAAD,GAAY,EAAK;AAAA,IAClB,CAAC;AAAA,EAEH,CAAC;AAUA,MAAAI,2CAAyB,MAAS,GAI/BC,IAASJ,EAAA,QAAA,MAAAK,EAAA,SAAqBC,EAAuBD,EAAA,MAAA,IAAW,IAAI;WAG/DE,EAAoBC,GAAgD;AACxE,IAAAL,EAAsB,IACzBA,EAAsB,EAACK,EAAW,IAAIA,EAAW,IAAI,IAErDC,MAASD,EAAW,EAAE,IAAIA,EAAW,IAAI,EAAA;AAAA,EAE3C;;;;;iCAIwBP,CAAe,GAAA,CAAAS,GAAAC,MAAA;;;;;;mBAErCR,EAAsB;AAAA;;;;AAGvB,MAAAS,EAAcF,GAAA;AAAA;uBACPN,CAAS;AAAA;yBACCG;AAAA;;;YARdR,CAAS,KAAAC,EAAA,IAAIC,CAAe,IAAAY,EAAAC,CAAA,IAAAd,EAAA,IAKvBI,CAAS,KAAAS,EAAAE,GAAA,CAAA;AAAA;;;AAPX;"}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import "svelte/internal/disclose-version";
|
|
2
|
+
import * as e from "svelte/internal/client";
|
|
3
|
+
import { aB as ue, e as J, u as pe, aH as K, aI as be, $ as xe } from "./VenueCalendar-BkiDPwSu.js";
|
|
4
|
+
import "svelte/internal/flags/legacy";
|
|
5
|
+
import "svelte/transition";
|
|
6
|
+
import "svelte/easing";
|
|
7
|
+
var Ne = e.from_html('<span class="venue-separator svelte-4y42r2">·</span> <span class="venue-location svelte-4y42r2"> </span>', 1), qe = e.from_html('<p class="series-summary svelte-4y42r2"> </p>'), ke = e.from_html('<div class="series-description svelte-4y42r2"> </div>'), De = e.from_html('<div class="empty-dates svelte-4y42r2"><p class="empty-text svelte-4y42r2">No upcoming dates scheduled at this time.</p> <p class="empty-subtext svelte-4y42r2">Check back soon for new announcements.</p></div>'), Ie = e.from_html('<div class="occurrence-card svelte-4y42r2"><div class="occurrence-info svelte-4y42r2"><div class="occurrence-date svelte-4y42r2"> </div> <div class="occurrence-time svelte-4y42r2"> </div></div> <div class="occurrence-action svelte-4y42r2"><button> </button></div></div>'), Se = e.from_html('<div class="dates-list svelte-4y42r2"></div>'), Te = e.from_html('<img class="performer-image svelte-4y42r2"/>'), Ae = e.from_html('<div class="performer-placeholder svelte-4y42r2"><svg class="placeholder-icon svelte-4y42r2" fill="currentColor" viewBox="0 0 24 24"><path d="M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z" class="svelte-4y42r2"></path></svg></div>'), Ce = e.from_html('<div class="performer-card svelte-4y42r2"><div class="performer-avatar svelte-4y42r2"><!></div> <h3 class="performer-name svelte-4y42r2"> </h3></div>'), Le = e.from_html('<section class="section svelte-4y42r2"><h2 class="section-heading svelte-4y42r2">Performers</h2> <div class="performers-grid svelte-4y42r2"></div></section>'), we = e.from_html('<div class="faq-item svelte-4y42r2"><p class="faq-question svelte-4y42r2"> </p> <p class="faq-answer svelte-4y42r2"> </p></div>'), ze = e.from_html('<p class="svelte-4y42r2"> </p>'), Ee = e.from_html('<div class="sidebar-section svelte-4y42r2"><h3 class="sidebar-heading svelte-4y42r2">FAQ</h3> <div class="faq-content svelte-4y42r2"><!></div></div>'), Oe = e.from_html('<div class="sidebar-section svelte-4y42r2"><h3 class="sidebar-heading svelte-4y42r2">Important Info</h3> <div class="disclaimer-text svelte-4y42r2"> </div></div>'), Pe = e.from_html('<div class="sidebar-card svelte-4y42r2"><!> <!></div>'), Ze = e.from_html('<div class="series-page svelte-4y42r2"><div class="hero svelte-4y42r2"><div></div> <img class="hero-image svelte-4y42r2"/> <div class="hero-overlay svelte-4y42r2"><div class="hero-content svelte-4y42r2"><span class="series-badge svelte-4y42r2">Recurring Event</span> <h1 class="series-title svelte-4y42r2"> </h1> <div class="series-venue svelte-4y42r2"><span class="svelte-4y42r2"> </span> <!></div></div></div></div> <div class="content-grid svelte-4y42r2"><div class="main-column svelte-4y42r2"><section class="section svelte-4y42r2"><h2 class="section-heading svelte-4y42r2">About this Series</h2> <!> <!></section> <section class="section svelte-4y42r2"><div class="dates-header svelte-4y42r2"><h2 class="section-heading svelte-4y42r2">Upcoming Dates</h2> <span class="dates-count svelte-4y42r2"> </span></div> <!></section> <!></div> <div class="sidebar svelte-4y42r2"><div class="sidebar-sticky svelte-4y42r2"><!></div></div></div></div>');
|
|
8
|
+
function Re(V, t) {
|
|
9
|
+
e.push(t, !0);
|
|
10
|
+
let L = e.state(!1), W = e.derived(() => t.series?.image ? J(t.series.image) : ue), w = e.derived(() => t.series?.timeZone || pe());
|
|
11
|
+
function X(n) {
|
|
12
|
+
return be(n, { timeZone: e.get(w) });
|
|
13
|
+
}
|
|
14
|
+
function z(n) {
|
|
15
|
+
return xe(n, { timeZone: e.get(w) });
|
|
16
|
+
}
|
|
17
|
+
function Y(n) {
|
|
18
|
+
!n.ctaState?.disabled && t.onNavigateToOccurrence && t.onNavigateToOccurrence(n.id, n.slug || "", n.name || "");
|
|
19
|
+
}
|
|
20
|
+
var E = e.comment(), $ = e.first_child(E);
|
|
21
|
+
{
|
|
22
|
+
var ee = (n) => {
|
|
23
|
+
var b = Ze(), x = e.child(b), O = e.child(x);
|
|
24
|
+
let P;
|
|
25
|
+
var p = e.sibling(O, 2), Z = e.sibling(p, 2), B = e.child(Z), N = e.sibling(e.child(B), 2), te = e.child(N, !0);
|
|
26
|
+
e.reset(N);
|
|
27
|
+
var F = e.sibling(N, 2), q = e.child(F), se = e.child(q, !0);
|
|
28
|
+
e.reset(q);
|
|
29
|
+
var ae = e.sibling(q, 2);
|
|
30
|
+
{
|
|
31
|
+
var ie = (s) => {
|
|
32
|
+
var a = Ne(), r = e.sibling(e.first_child(a), 2), d = e.child(r, !0);
|
|
33
|
+
e.reset(r), e.template_effect(() => e.set_text(d, t.series.venue.googleLocationNameCache)), e.append(s, a);
|
|
34
|
+
};
|
|
35
|
+
e.if(ae, (s) => {
|
|
36
|
+
t.series.venue?.googleLocationNameCache && s(ie);
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
e.reset(F), e.reset(B), e.reset(Z), e.reset(x);
|
|
40
|
+
var G = e.sibling(x, 2), k = e.child(G), D = e.child(k), H = e.sibling(e.child(D), 2);
|
|
41
|
+
{
|
|
42
|
+
var re = (s) => {
|
|
43
|
+
var a = qe(), r = e.child(a, !0);
|
|
44
|
+
e.reset(a), e.template_effect(() => e.set_text(r, t.series.eventSummary)), e.append(s, a);
|
|
45
|
+
};
|
|
46
|
+
e.if(H, (s) => {
|
|
47
|
+
t.series.eventSummary && s(re);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
var ve = e.sibling(H, 2);
|
|
51
|
+
{
|
|
52
|
+
var le = (s) => {
|
|
53
|
+
var a = ke(), r = e.child(a, !0);
|
|
54
|
+
e.reset(a), e.template_effect(() => e.set_text(r, t.series.description)), e.append(s, a);
|
|
55
|
+
};
|
|
56
|
+
e.if(ve, (s) => {
|
|
57
|
+
t.series.description && s(le);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
e.reset(D);
|
|
61
|
+
var I = e.sibling(D, 2), S = e.child(I), M = e.sibling(e.child(S), 2), de = e.child(M);
|
|
62
|
+
e.reset(M), e.reset(S);
|
|
63
|
+
var ce = e.sibling(S, 2);
|
|
64
|
+
{
|
|
65
|
+
var ne = (s) => {
|
|
66
|
+
var a = De();
|
|
67
|
+
e.append(s, a);
|
|
68
|
+
}, oe = (s) => {
|
|
69
|
+
var a = Se();
|
|
70
|
+
e.each(a, 21, () => t.series.occurrences, e.index, (r, d) => {
|
|
71
|
+
var v = Ie(), h = e.child(v), i = e.child(h), o = e.child(i, !0);
|
|
72
|
+
e.reset(i);
|
|
73
|
+
var _ = e.sibling(i, 2), g = e.child(_);
|
|
74
|
+
e.reset(_), e.reset(h);
|
|
75
|
+
var y = e.sibling(h, 2), f = e.child(y);
|
|
76
|
+
let c;
|
|
77
|
+
var l = e.child(f, !0);
|
|
78
|
+
e.reset(f), e.reset(y), e.reset(v), e.template_effect(
|
|
79
|
+
(m, u, T) => {
|
|
80
|
+
e.set_text(o, m), e.set_text(g, `${u ?? ""} - ${T ?? ""}`), c = e.set_class(f, 1, "cta-button svelte-4y42r2", null, c, { "cta-disabled": e.get(d).ctaState?.disabled }), f.disabled = e.get(d).ctaState?.disabled, e.set_text(l, e.get(d).ctaState?.text || "Get tickets");
|
|
81
|
+
},
|
|
82
|
+
[
|
|
83
|
+
() => X(e.get(d).startDateTime),
|
|
84
|
+
() => z(e.get(d).startDateTime),
|
|
85
|
+
() => z(e.get(d).endDateTime)
|
|
86
|
+
]
|
|
87
|
+
), e.delegated("click", f, () => Y(e.get(d))), e.append(r, v);
|
|
88
|
+
}), e.reset(a), e.append(s, a);
|
|
89
|
+
};
|
|
90
|
+
e.if(ce, (s) => {
|
|
91
|
+
t.series.occurrences?.length ? s(oe, !1) : s(ne);
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
e.reset(I);
|
|
95
|
+
var _e = e.sibling(I, 2);
|
|
96
|
+
{
|
|
97
|
+
var me = (s) => {
|
|
98
|
+
var a = Le(), r = e.sibling(e.child(a), 2);
|
|
99
|
+
e.each(r, 21, () => t.series.performers, e.index, (d, v) => {
|
|
100
|
+
var h = Ce(), i = e.child(h), o = e.child(i);
|
|
101
|
+
{
|
|
102
|
+
var _ = (c) => {
|
|
103
|
+
var l = Te();
|
|
104
|
+
e.template_effect(
|
|
105
|
+
(m, u) => {
|
|
106
|
+
e.set_attribute(l, "src", m), e.set_attribute(l, "alt", u);
|
|
107
|
+
},
|
|
108
|
+
[
|
|
109
|
+
() => J(e.get(v).profileImage),
|
|
110
|
+
() => e.get(v).displayName || K(e.get(v).firstName, e.get(v).lastName)
|
|
111
|
+
]
|
|
112
|
+
), e.append(c, l);
|
|
113
|
+
}, g = (c) => {
|
|
114
|
+
var l = Ae();
|
|
115
|
+
e.append(c, l);
|
|
116
|
+
};
|
|
117
|
+
e.if(o, (c) => {
|
|
118
|
+
e.get(v).profileImage ? c(_) : c(g, !1);
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
e.reset(i);
|
|
122
|
+
var y = e.sibling(i, 2), f = e.child(y, !0);
|
|
123
|
+
e.reset(y), e.reset(h), e.template_effect((c) => e.set_text(f, c), [
|
|
124
|
+
() => e.get(v).displayName || K(e.get(v).firstName, e.get(v).lastName)
|
|
125
|
+
]), e.append(d, h);
|
|
126
|
+
}), e.reset(r), e.reset(a), e.append(s, a);
|
|
127
|
+
};
|
|
128
|
+
e.if(_e, (s) => {
|
|
129
|
+
t.series.performers?.length && s(me);
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
e.reset(k);
|
|
133
|
+
var R = e.sibling(k, 2), U = e.child(R), he = e.child(U);
|
|
134
|
+
{
|
|
135
|
+
var fe = (s) => {
|
|
136
|
+
var a = Pe(), r = e.child(a);
|
|
137
|
+
{
|
|
138
|
+
var d = (i) => {
|
|
139
|
+
var o = Ee(), _ = e.sibling(e.child(o), 2), g = e.child(_);
|
|
140
|
+
{
|
|
141
|
+
var y = (l) => {
|
|
142
|
+
var m = e.comment(), u = e.first_child(m);
|
|
143
|
+
e.each(u, 17, () => t.series.venue.faq, e.index, (T, Q) => {
|
|
144
|
+
var A = we(), C = e.child(A), ge = e.child(C, !0);
|
|
145
|
+
e.reset(C);
|
|
146
|
+
var j = e.sibling(C, 2), ye = e.child(j, !0);
|
|
147
|
+
e.reset(j), e.reset(A), e.template_effect(() => {
|
|
148
|
+
e.set_text(ge, e.get(Q).question), e.set_text(ye, e.get(Q).answer);
|
|
149
|
+
}), e.append(T, A);
|
|
150
|
+
}), e.append(l, m);
|
|
151
|
+
}, f = e.derived(() => Array.isArray(t.series.venue.faq)), c = (l) => {
|
|
152
|
+
var m = ze(), u = e.child(m, !0);
|
|
153
|
+
e.reset(m), e.template_effect(() => e.set_text(u, t.series.venue.faq)), e.append(l, m);
|
|
154
|
+
};
|
|
155
|
+
e.if(g, (l) => {
|
|
156
|
+
e.get(f) ? l(y) : l(c, !1);
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
e.reset(_), e.reset(o), e.append(i, o);
|
|
160
|
+
};
|
|
161
|
+
e.if(r, (i) => {
|
|
162
|
+
t.series.venue.faq && i(d);
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
var v = e.sibling(r, 2);
|
|
166
|
+
{
|
|
167
|
+
var h = (i) => {
|
|
168
|
+
var o = Oe(), _ = e.sibling(e.child(o), 2), g = e.child(_, !0);
|
|
169
|
+
e.reset(_), e.reset(o), e.template_effect(() => e.set_text(g, t.series.venue.disclaimer)), e.append(i, o);
|
|
170
|
+
};
|
|
171
|
+
e.if(v, (i) => {
|
|
172
|
+
t.series.venue.disclaimer && i(h);
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
e.reset(a), e.append(s, a);
|
|
176
|
+
};
|
|
177
|
+
e.if(he, (s) => {
|
|
178
|
+
(t.series.venue?.faq || t.series.venue?.disclaimer) && s(fe);
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
e.reset(U), e.reset(R), e.reset(G), e.reset(b), e.template_effect(() => {
|
|
182
|
+
P = e.set_class(O, 1, "hero-skeleton svelte-4y42r2", null, P, { hidden: e.get(L) }), e.set_attribute(p, "src", e.get(W)), e.set_attribute(p, "alt", t.series.title), e.set_text(te, t.series.title), e.set_text(se, t.series.venue?.name), e.set_text(de, `${(t.series.occurrences?.length || 0) ?? ""} events`);
|
|
183
|
+
}), e.event("load", p, () => e.set(L, !0)), e.replay_events(p), e.append(n, b);
|
|
184
|
+
};
|
|
185
|
+
e.if($, (n) => {
|
|
186
|
+
t.series && n(ee);
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
e.append(V, E), e.pop();
|
|
190
|
+
}
|
|
191
|
+
e.delegate(["click"]);
|
|
192
|
+
export {
|
|
193
|
+
Re as default
|
|
194
|
+
};
|
|
195
|
+
//# sourceMappingURL=SeriesPage.legacy-C-hADRCm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SeriesPage.legacy-C-hADRCm.js","sources":["../src/components/Views/SeriesPage.legacy.svelte"],"sourcesContent":["<script>\n import { getImageUrl } from '$lib/utils/utils.js';\n import { formatDate as scFormatDate,\n formatTime as scFormatTime, getDefaultTimezone, formatFullName } from '@getmicdrop/svelte-components';\n import { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\n\n let { series, onNavigateToOccurrence } = $props();\n\n let imageLoaded = $state(false);\n\n let seriesImage = $derived(\n series?.image ? getImageUrl(series.image) : PLACEHOLDER_IMAGE\n );\n\n let tz = $derived(series?.timeZone || getDefaultTimezone());\n\n function formatDate(iso) {\n return scFormatDate(iso, { timeZone: tz });\n }\n\n function formatTime(iso) {\n return scFormatTime(iso, { timeZone: tz });\n }\n\n function handleOccurrenceClick(occurrence) {\n if (!occurrence.ctaState?.disabled && onNavigateToOccurrence) {\n onNavigateToOccurrence(\n occurrence.id,\n occurrence.slug || '',\n occurrence.name || ''\n );\n }\n }\n</script>\n\n{#if series}\n <div class=\"series-page\">\n <!-- Hero Image -->\n <div class=\"hero\">\n <div class=\"hero-skeleton\" class:hidden={imageLoaded}></div>\n <img\n src={seriesImage}\n alt={series.title}\n class=\"hero-image\"\n onload={() => (imageLoaded = true)}\n />\n <div class=\"hero-overlay\">\n <div class=\"hero-content\">\n <span class=\"series-badge\">Recurring Event</span>\n <h1 class=\"series-title\">{series.title}</h1>\n <div class=\"series-venue\">\n <span>{series.venue?.name}</span>\n {#if series.venue?.googleLocationNameCache}\n <span class=\"venue-separator\">·</span>\n <span class=\"venue-location\"\n >{series.venue.googleLocationNameCache}</span\n >\n {/if}\n </div>\n </div>\n </div>\n </div>\n\n <!-- Content Grid -->\n <div class=\"content-grid\">\n <!-- Main Column -->\n <div class=\"main-column\">\n <!-- About Section -->\n <section class=\"section\">\n <h2 class=\"section-heading\">About this Series</h2>\n {#if series.eventSummary}\n <p class=\"series-summary\">{series.eventSummary}</p>\n {/if}\n {#if series.description}\n <div class=\"series-description\">{series.description}</div>\n {/if}\n </section>\n\n <!-- Upcoming Dates -->\n <section class=\"section\">\n <div class=\"dates-header\">\n <h2 class=\"section-heading\">Upcoming Dates</h2>\n <span class=\"dates-count\"\n >{series.occurrences?.length || 0} events</span\n >\n </div>\n\n {#if !series.occurrences?.length}\n <div class=\"empty-dates\">\n <p class=\"empty-text\">\n No upcoming dates scheduled at this time.\n </p>\n <p class=\"empty-subtext\">\n Check back soon for new announcements.\n </p>\n </div>\n {:else}\n <div class=\"dates-list\">\n {#each series.occurrences as occurrence}\n <div class=\"occurrence-card\">\n <div class=\"occurrence-info\">\n <div class=\"occurrence-date\">\n {formatDate(occurrence.startDateTime)}\n </div>\n <div class=\"occurrence-time\">\n {formatTime(occurrence.startDateTime)} - {formatTime(\n occurrence.endDateTime\n )}\n </div>\n </div>\n <div class=\"occurrence-action\">\n <button\n class=\"cta-button\"\n class:cta-disabled={occurrence.ctaState?.disabled}\n disabled={occurrence.ctaState?.disabled}\n onclick={() => handleOccurrenceClick(occurrence)}\n >\n {occurrence.ctaState?.text || 'Get tickets'}\n </button>\n </div>\n </div>\n {/each}\n </div>\n {/if}\n </section>\n\n <!-- Performers -->\n {#if series.performers?.length}\n <section class=\"section\">\n <h2 class=\"section-heading\">Performers</h2>\n <div class=\"performers-grid\">\n {#each series.performers as performer}\n <div class=\"performer-card\">\n <div class=\"performer-avatar\">\n {#if performer.profileImage}\n <img\n src={getImageUrl(performer.profileImage)}\n alt={performer.displayName ||\n formatFullName(performer.firstName, performer.lastName)}\n class=\"performer-image\"\n />\n {:else}\n <div class=\"performer-placeholder\">\n <svg\n class=\"placeholder-icon\"\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z\"\n />\n </svg>\n </div>\n {/if}\n </div>\n <h3 class=\"performer-name\">\n {performer.displayName ||\n formatFullName(performer.firstName, performer.lastName)}\n </h3>\n </div>\n {/each}\n </div>\n </section>\n {/if}\n </div>\n\n <!-- Sidebar -->\n <div class=\"sidebar\">\n <div class=\"sidebar-sticky\">\n {#if series.venue?.faq || series.venue?.disclaimer}\n <div class=\"sidebar-card\">\n {#if series.venue.faq}\n <div class=\"sidebar-section\">\n <h3 class=\"sidebar-heading\">FAQ</h3>\n <div class=\"faq-content\">\n {#if Array.isArray(series.venue.faq)}\n {#each series.venue.faq as item}\n <div class=\"faq-item\">\n <p class=\"faq-question\">{item.question}</p>\n <p class=\"faq-answer\">{item.answer}</p>\n </div>\n {/each}\n {:else}\n <p>{series.venue.faq}</p>\n {/if}\n </div>\n </div>\n {/if}\n\n {#if series.venue.disclaimer}\n <div class=\"sidebar-section\">\n <h3 class=\"sidebar-heading\">Important Info</h3>\n <div class=\"disclaimer-text\">{series.venue.disclaimer}</div>\n </div>\n {/if}\n </div>\n {/if}\n </div>\n </div>\n </div>\n </div>\n{/if}\n\n<style>\n .series-page {\n min-height: 100vh;\n padding-bottom: 5rem;\n background: hsl(var(--surface-primary, 0 0% 100%));\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n /* Hero */\n .hero {\n position: relative;\n width: 100%;\n overflow: hidden;\n height: 500px;\n }\n\n @media (width <= 768px) {\n .hero {\n height: 256px;\n }\n }\n\n .hero-skeleton {\n position: absolute;\n inset: 0;\n animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n }\n\n @keyframes pulse {\n 0%,\n 100% {\n opacity: 1;\n }\n\n 50% {\n opacity: 0.5;\n }\n }\n\n .hero-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n transition: transform 0.7s ease;\n }\n\n .hero:hover .hero-image {\n transform: scale(1.05);\n }\n\n .hero-overlay {\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n padding: 1.5rem;\n background: linear-gradient(\n to top,\n color-mix(in srgb, black 90%, transparent),\n color-mix(in srgb, black 50%, transparent),\n transparent\n );\n }\n\n @media (width >= 768px) {\n .hero-overlay {\n padding: 3rem;\n }\n }\n\n .hero-content {\n max-width: 64rem;\n margin-left: auto;\n margin-right: auto;\n width: 100%;\n }\n\n .series-badge {\n display: inline-flex;\n align-items: center;\n padding: 0.25rem 0.75rem;\n margin-bottom: 1rem;\n font-size: 0.75rem;\n line-height: 1rem;\n font-weight: 700;\n text-transform: uppercase;\n letter-spacing: 0.05em;\n border-radius: 9999px;\n box-shadow:\n 0 10px 15px -3px rgb(0 0 0 / 10%),\n 0 4px 6px -4px rgb(0 0 0 / 10%);\n background: hsl(var(--brand-primary, 224 76% 48%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n .series-title {\n font-size: 2.25rem;\n line-height: 1.1;\n font-weight: 700;\n margin-bottom: 0.75rem;\n letter-spacing: -0.025em;\n color: hsl(var(--bg-primary));\n text-shadow: 0 2px 8px color-mix(in srgb, black 30%, transparent);\n }\n\n @media (width >= 768px) {\n .series-title {\n font-size: 3.75rem;\n line-height: 1;\n }\n }\n\n .series-venue {\n font-size: 1.125rem;\n line-height: 1.75rem;\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n gap: 0.5rem;\n font-weight: 500;\n color: color-mix(in srgb, white 90%, transparent);\n }\n\n @media (width >= 768px) {\n .series-venue {\n font-size: 1.25rem;\n line-height: 1.75rem;\n }\n }\n\n .venue-separator {\n display: none;\n opacity: 0.6;\n }\n\n @media (width >= 768px) {\n .venue-separator {\n display: inline;\n }\n }\n\n .venue-location {\n opacity: 0.75;\n }\n\n /* Content Grid */\n .content-grid {\n max-width: 64rem;\n margin-left: auto;\n margin-right: auto;\n padding: 3rem 1.5rem;\n display: grid;\n grid-template-columns: 1fr;\n gap: 3rem;\n }\n\n @media (width >= 768px) {\n .content-grid {\n padding-top: 5rem;\n padding-bottom: 5rem;\n }\n }\n\n @media (width >= 1024px) {\n .content-grid {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n .main-column {\n display: flex;\n flex-direction: column;\n gap: 4rem;\n }\n\n @media (width >= 1024px) {\n .main-column {\n grid-column: span 2 / span 2;\n }\n }\n\n .section {\n display: flex;\n flex-direction: column;\n gap: 1.5rem;\n }\n\n .section-heading {\n font-size: 1.875rem;\n line-height: 2.25rem;\n font-weight: 700;\n letter-spacing: -0.025em;\n padding-bottom: 1rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n border-bottom: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n .series-summary {\n font-size: 1.25rem;\n font-weight: 500;\n line-height: 1.625;\n color: hsl(var(--text-primary, 0 0% 20%));\n }\n\n .series-description {\n max-width: none;\n white-space: pre-line;\n line-height: 1.625;\n color: hsl(var(--text-secondary, 0 0% 40%));\n }\n\n /* Upcoming Dates */\n .dates-header {\n display: flex;\n align-items: baseline;\n justify-content: space-between;\n padding-bottom: 1rem;\n border-bottom: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n .dates-count {\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .empty-dates {\n padding: 3rem;\n border-radius: 1rem;\n text-align: center;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n border: 2px dashed hsl(var(--stroke-secondary, 0 0% 85%));\n }\n\n .empty-text {\n font-size: 1.125rem;\n line-height: 1.75rem;\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .empty-subtext {\n margin-top: 0.5rem;\n color: hsl(var(--text-secondary, 0 0% 55%));\n }\n\n .dates-list {\n display: flex;\n flex-direction: column;\n gap: 1rem;\n }\n\n .occurrence-card {\n position: relative;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n padding: 1.5rem;\n border-radius: 1rem;\n transition: all 0.2s;\n background: hsl(var(--surface-primary, 0 0% 100%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n\n @media (width >= 640px) {\n .occurrence-card {\n flex-direction: row;\n align-items: center;\n }\n }\n\n .occurrence-card:hover {\n border-color: hsl(var(--brand-primary, 224 76% 48%));\n box-shadow: 0 4px 12px color-mix(in srgb, black 8%, transparent);\n }\n\n .occurrence-info {\n margin-bottom: 1rem;\n }\n\n @media (width >= 640px) {\n .occurrence-info {\n margin-bottom: 0;\n }\n }\n\n .occurrence-date {\n font-size: 1.25rem;\n line-height: 1.75rem;\n font-weight: 700;\n margin-bottom: 0.25rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .occurrence-time {\n font-weight: 500;\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .occurrence-action {\n padding-left: 0;\n }\n\n @media (width >= 640px) {\n .occurrence-action {\n padding-left: 1.5rem;\n }\n }\n\n .cta-button {\n width: 100%;\n padding: 0.75rem 1.5rem;\n border-radius: 0.5rem;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n transition: transform 0.15s;\n background: hsl(var(--brand-primary, 224 76% 48%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n @media (width >= 640px) {\n .cta-button {\n width: auto;\n }\n }\n\n .cta-button:hover:not(:disabled) {\n transform: scale(1.05);\n }\n\n .cta-disabled {\n cursor: not-allowed;\n background: hsl(var(--surface-secondary, 0 0% 90%));\n color: hsl(var(--text-secondary, 0 0% 55%));\n }\n\n /* Performers */\n .performers-grid {\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n gap: 2rem;\n }\n\n @media (width >= 640px) {\n .performers-grid {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n\n .performer-card {\n display: flex;\n flex-direction: column;\n align-items: center;\n text-align: center;\n padding: 1rem;\n border-radius: 0.75rem;\n transition: background-color 0.15s;\n }\n\n .performer-card:hover {\n background: hsl(var(--surface-secondary, 0 0% 96%));\n }\n\n .performer-avatar {\n width: 7rem;\n height: 7rem;\n margin-bottom: 1rem;\n border-radius: 9999px;\n overflow: hidden;\n box-shadow:\n 0 4px 6px -1px rgb(0 0 0 / 10%),\n 0 2px 4px -2px rgb(0 0 0 / 10%);\n background: hsl(var(--surface-secondary, 0 0% 92%));\n }\n\n .performer-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n transition: transform 0.5s ease;\n }\n\n .performer-card:hover .performer-image {\n transform: scale(1.1);\n }\n\n .performer-placeholder {\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: center;\n color: hsl(var(--text-secondary, 0 0% 60%));\n }\n\n .placeholder-icon {\n width: 3rem;\n height: 3rem;\n opacity: 0.5;\n }\n\n .performer-name {\n font-size: 1.125rem;\n line-height: 1.75rem;\n font-weight: 600;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n /* Sidebar */\n .sidebar {\n display: flex;\n flex-direction: column;\n gap: 2rem;\n }\n\n @media (width >= 1024px) {\n .sidebar {\n grid-column: span 1 / span 1;\n }\n }\n\n .sidebar-sticky {\n position: sticky;\n top: 6rem;\n display: flex;\n flex-direction: column;\n gap: 2rem;\n }\n\n .sidebar-card {\n border-radius: 1rem;\n padding: 2rem;\n background: hsl(var(--surface-secondary, 0 0% 96%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 92%));\n }\n\n .sidebar-section {\n margin-bottom: 2rem;\n }\n\n .sidebar-section:last-child {\n margin-bottom: 0;\n }\n\n .sidebar-heading {\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.1em;\n margin-bottom: 1rem;\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .faq-content {\n color: hsl(var(--text-secondary, 0 0% 40%));\n }\n\n .faq-item {\n margin-bottom: 0.75rem;\n }\n\n .faq-question {\n font-weight: 700;\n color: hsl(var(--text-primary, 0 0% 20%));\n }\n\n .faq-answer {\n font-size: 0.875rem;\n line-height: 1.25rem;\n }\n\n .disclaimer-text {\n font-size: 0.875rem;\n line-height: 1.625;\n padding: 1rem;\n border-radius: 0.5rem;\n background: hsl(var(--surface-primary, 0 0% 100%));\n color: hsl(var(--text-secondary, 0 0% 40%));\n border: 1px solid hsl(var(--stroke-secondary, 0 0% 90%));\n }\n</style>\n"],"names":["imageLoaded","$","seriesImage","getImageUrl","$$props","PLACEHOLDER_IMAGE","tz","getDefaultTimezone","formatDate","iso","scFormatDate","formatTime","scFormatTime","handleOccurrenceClick","occurrence","div","root_1","div_1","div_2","img","div_3","div_4","h1","div_5","span","span_1","fragment_1","text_2","$$render","consequent","div_6","div_7","section","p","root_3","consequent_1","div_8","root_4","consequent_2","section_1","div_9","span_2","div_10","root_5","div_11","root_6","$$anchor","div_12","root_7","div_13","div_14","div_15","div_16","button","classes_1","text_8","alternate","consequent_3","section_2","root_8","div_17","performer","div_18","root_9","div_19","img_1","root_10","$0","$1","formatFullName","div_20","root_11","consequent_4","alternate_1","h3","consequent_5","div_21","div_22","div_23","root_12","div_24","root_13","div_25","item","div_26","root_15","p_1","p_2","text_10","text_11","d","p_3","root_16","text_12","consequent_7","div_27","root_17","div_28","text_13","consequent_8","consequent_9","classes","text_1"],"mappings":"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"}
|