@getmicdrop/venue-calendar 4.0.71 → 4.0.73
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/dist/{CarouselView.legacy-ClHr7g2d.js → CarouselView.legacy-D8292Vwd.js} +3 -3
- package/dist/{CarouselView.legacy-ClHr7g2d.js.map → CarouselView.legacy-D8292Vwd.js.map} +1 -1
- package/dist/{CartView-BncT-vVW.js → CartView-CLi2VVd0.js} +139 -139
- package/dist/{CartView-BncT-vVW.js.map → CartView-CLi2VVd0.js.map} +1 -1
- package/dist/{Checkout-DUwzAkMN.js → Checkout-ByCnBt-G.js} +317 -316
- package/dist/{Checkout-DUwzAkMN.js.map → Checkout-ByCnBt-G.js.map} +1 -1
- package/dist/Checkout-DvbhqCsh.js +830 -0
- package/dist/Checkout-DvbhqCsh.js.map +1 -0
- package/dist/{Checkout.legacy-D9nNe_AZ.js → Checkout.legacy-C95H23qA.js} +60 -60
- package/dist/{Checkout.legacy-D9nNe_AZ.js.map → Checkout.legacy-C95H23qA.js.map} +1 -1
- package/dist/{CheckoutTimer-Vgrjjbvg.js → CheckoutTimer-CzRcyBzu.js} +2 -2
- package/dist/{CheckoutTimer-Vgrjjbvg.js.map → CheckoutTimer-CzRcyBzu.js.map} +1 -1
- package/dist/{CollectionView-DLcoMjuw.js → CollectionView-CtMBS-m8.js} +5 -5
- package/dist/{CollectionView-DLcoMjuw.js.map → CollectionView-CtMBS-m8.js.map} +1 -1
- package/dist/{CollectionView.legacy-B_8a2U1u.js → CollectionView.legacy-C4ba5bLU.js} +32 -32
- package/dist/{CollectionView.legacy-B_8a2U1u.js.map → CollectionView.legacy-C4ba5bLU.js.map} +1 -1
- package/dist/Event-Bm1bpwyl.js +2188 -0
- package/dist/Event-Bm1bpwyl.js.map +1 -0
- package/dist/{EventPage-CtJ9YZcS.js → EventPage-BT2m0JQi.js} +5 -5
- package/dist/{EventPage-CtJ9YZcS.js.map → EventPage-BT2m0JQi.js.map} +1 -1
- package/dist/EventPage.legacy-Deu8PGw6.js +1300 -0
- package/dist/EventPage.legacy-Deu8PGw6.js.map +1 -0
- package/dist/{FeaturedView.legacy-aKrVnwkw.js → FeaturedView.legacy-Cbxg3oCb.js} +22 -22
- package/dist/{FeaturedView.legacy-aKrVnwkw.js.map → FeaturedView.legacy-Cbxg3oCb.js.map} +1 -1
- package/dist/{GalleryCard-Da9zFkLr.js → GalleryCard-K-h-w_A6.js} +13 -13
- package/dist/{GalleryCard-Da9zFkLr.js.map → GalleryCard-K-h-w_A6.js.map} +1 -1
- package/dist/{GalleryView.legacy-D3A9pCKp.js → GalleryView.legacy-BYiC8PVZ.js} +3 -3
- package/dist/{GalleryView.legacy-D3A9pCKp.js.map → GalleryView.legacy-BYiC8PVZ.js.map} +1 -1
- package/dist/{GroupedListView.legacy-BaoTHCTN.js → GroupedListView.legacy-BZq2qDjS.js} +27 -27
- package/dist/{GroupedListView.legacy-BaoTHCTN.js.map → GroupedListView.legacy-BZq2qDjS.js.map} +1 -1
- package/dist/{SeriesPage-Cp9hhvIY.js → SeriesPage-BbGXRoCV.js} +5 -5
- package/dist/{SeriesPage-Cp9hhvIY.js.map → SeriesPage-BbGXRoCV.js.map} +1 -1
- package/dist/{SeriesPage.legacy-Jk6vH4SQ.js → SeriesPage.legacy-eMr3yDRa.js} +33 -33
- package/dist/{SeriesPage.legacy-Jk6vH4SQ.js.map → SeriesPage.legacy-eMr3yDRa.js.map} +1 -1
- package/dist/{Success-C7SFYk8j.js → Success-CeNSlAZj.js} +130 -131
- package/dist/{Success-C7SFYk8j.js.map → Success-CeNSlAZj.js.map} +1 -1
- package/dist/{Success.legacy-VgQ_-sfp.js → Success.legacy-DpYGRNGA.js} +25 -25
- package/dist/{Success.legacy-VgQ_-sfp.js.map → Success.legacy-DpYGRNGA.js.map} +1 -1
- package/dist/{VenueCalendar-BYs68ta2.js → VenueCalendar-CGKy4kQ8.js} +6897 -7487
- package/dist/VenueCalendar-CGKy4kQ8.js.map +1 -0
- package/dist/{ViewTicketsEmbed-DLjGYNC1.js → ViewTicketsEmbed-CxQZM79q.js} +20 -20
- package/dist/{ViewTicketsEmbed-DLjGYNC1.js.map → ViewTicketsEmbed-CxQZM79q.js.map} +1 -1
- package/dist/{api-COTZNjyj.js → api-toYmKtOR.js} +2 -2
- package/dist/{api-COTZNjyj.js.map → api-toYmKtOR.js.map} +1 -1
- package/dist/{data-toggle-store.svelte-C65MzzYZ.js → data-toggle-store.svelte-DWzk0MLS.js} +2 -2
- package/dist/{data-toggle-store.svelte-C65MzzYZ.js.map → data-toggle-store.svelte-DWzk0MLS.js.map} +1 -1
- package/dist/labels-BpBCM7Zc.js +657 -0
- package/dist/labels-BpBCM7Zc.js.map +1 -0
- package/dist/{transform-TJz04LxL.js → transform-DeiNOLZ8.js} +2 -2
- package/dist/{transform-TJz04LxL.js.map → transform-DeiNOLZ8.js.map} +1 -1
- package/dist/types/index.d.ts +20 -17
- package/dist/venue-calendar.css +1 -1
- package/dist/venue-calendar.es.js +23 -24
- package/dist/venue-calendar.iife.js +71 -62
- package/dist/venue-calendar.iife.js.map +1 -1
- package/dist/venue-calendar.umd.js +68 -71
- package/dist/venue-calendar.umd.js.map +1 -1
- package/package.json +4 -1
- package/dist/Checkout-7rhwtJSX.js +0 -803
- package/dist/Checkout-7rhwtJSX.js.map +0 -1
- package/dist/Event-BBIEvf3e.js +0 -1789
- package/dist/Event-BBIEvf3e.js.map +0 -1
- package/dist/EventDetailsView-BHxDjZCb.js +0 -1366
- package/dist/EventDetailsView-BHxDjZCb.js.map +0 -1
- package/dist/EventPage.legacy-CQ1MAI_B.js +0 -1044
- package/dist/EventPage.legacy-CQ1MAI_B.js.map +0 -1
- package/dist/OrderSummary-DaBRHOX_.js +0 -497
- package/dist/OrderSummary-DaBRHOX_.js.map +0 -1
- package/dist/PromoCodeInput-C_RKyiKy.js +0 -415
- package/dist/PromoCodeInput-C_RKyiKy.js.map +0 -1
- package/dist/VenueCalendar-BYs68ta2.js.map +0 -1
- package/dist/WaitlistModal-BRRzVbhX.js +0 -266
- package/dist/WaitlistModal-BRRzVbhX.js.map +0 -1
- package/dist/labels-CWMBE5R1.js +0 -163
- package/dist/labels-CWMBE5R1.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels-BpBCM7Zc.js","sources":["../src/lib/api/cta.ts","../src/lib/public-calendar-flow/defaults.ts","../src/lib/public-calendar-flow/OrderSummary.svelte","../src/lib/public-calendar-flow/i18n/labels.js"],"sourcesContent":["/**\r\n * CTA state computation.\r\n *\r\n * Pure function (no I/O) — derives the buy-button state from an event and\r\n * its ticket list. Lives in `api/` because it is the canonical, single\r\n * source of truth that replaces the duplicate implementations previously\r\n * scattered across utils/api.js, core/api-client.js, and a few components.\r\n */\r\n\r\n// Import from the specific subpath (not the bare entry) so the api/\r\n// bundle doesn't pull in the entire SC component graph (Accordion etc.)\r\n// and break `npm run build:api`.\r\nimport {\r\n formatDateRaw,\r\n formatTime,\r\n} from '@getmicdrop/svelte-components/utils/formatters';\r\n\r\nexport interface CtaStateOptions {\r\n cancelled?: boolean;\r\n isRegistration?: boolean;\r\n waitlistEnabled?: boolean;\r\n}\r\n\r\nexport interface CtaState {\r\n text: string;\r\n disabled: boolean;\r\n reason:\r\n | 'cancelled'\r\n | 'event_past'\r\n | 'no_tickets'\r\n | 'available'\r\n | 'coming_soon'\r\n | 'sold_out_waitlist'\r\n | 'sold_out'\r\n | 'sales_ended'\r\n | 'hidden_only';\r\n}\r\n\r\ninterface CtaEvent {\r\n startDateTime?: string | null;\r\n endDateTime?: string | null;\r\n hasPurchasableHiddenTickets?: boolean;\r\n}\r\n\r\ninterface CtaTicket {\r\n salesChannel?: number;\r\n salesBegin?: string | null;\r\n salesStart?: string | null;\r\n saleBegin?: string | null;\r\n onSaleStart?: string | null;\r\n salesEnd?: string | null;\r\n saleEnd?: string | null;\r\n onSaleEnd?: string | null;\r\n remainingCapacity?: number | null;\r\n quantityRemaining?: number | null;\r\n quantity?: number | null;\r\n soldOut?: boolean;\r\n isHidden?: boolean;\r\n visibility?: number;\r\n}\r\n\r\n// A hidden ticket (visibility>=2 or isHidden) that's still on sale drives the\r\n// \"Sales ended\" / \"Sold out\" / \"No tickets\" → \"Get tickets\" override. The user\r\n// just needs the promo code to see it.\r\nexport function isHiddenTicketPurchasable(ticket: CtaTicket): boolean {\r\n if (!ticket) return false;\r\n const isHidden =\r\n ticket.isHidden === true ||\r\n (typeof ticket.visibility === 'number' && ticket.visibility >= 2);\r\n if (!isHidden) return false;\r\n if (ticket.salesChannel === 2) return false;\r\n\r\n const now = new Date();\r\n const salesBegin =\r\n ticket.salesBegin ||\r\n ticket.salesStart ||\r\n ticket.saleBegin ||\r\n ticket.onSaleStart;\r\n const salesEnd = ticket.salesEnd || ticket.saleEnd || ticket.onSaleEnd;\r\n if (salesBegin && new Date(salesBegin) > now) return false;\r\n if (salesEnd && new Date(salesEnd) < now) return false;\r\n\r\n const remaining =\r\n ticket.remainingCapacity ?? ticket.quantityRemaining ?? ticket.quantity;\r\n const isSoldOut =\r\n ticket.soldOut ||\r\n (remaining !== null && remaining !== undefined && remaining <= 0);\r\n if (isSoldOut) return false;\r\n\r\n return true;\r\n}\r\n\r\nexport function computeCtaState(\r\n event: CtaEvent,\r\n tickets: CtaTicket[] | undefined,\r\n options: CtaStateOptions = {}\r\n): CtaState {\r\n const {\r\n cancelled = false,\r\n isRegistration = false,\r\n waitlistEnabled = false,\r\n } = options;\r\n const now = new Date();\r\n\r\n if (cancelled)\r\n return { text: 'Cancelled', disabled: true, reason: 'cancelled' };\r\n\r\n const eventEnd = event.endDateTime || event.startDateTime;\r\n if (eventEnd && new Date(eventEnd) < now) {\r\n return { text: 'Sales ended', disabled: true, reason: 'event_past' };\r\n }\r\n\r\n const hiddenAvailable =\r\n event?.hasPurchasableHiddenTickets === true ||\r\n (Array.isArray(tickets) && tickets.some(isHiddenTicketPurchasable));\r\n\r\n const publicTickets = (tickets || []).filter(\r\n t =>\r\n t.salesChannel !== 2 &&\r\n !t.isHidden &&\r\n !(typeof t.visibility === 'number' && t.visibility >= 2)\r\n );\r\n if (publicTickets.length === 0) {\r\n if (hiddenAvailable) {\r\n return {\r\n text: isRegistration ? 'Reserve a spot' : 'Get tickets',\r\n disabled: false,\r\n reason: 'hidden_only',\r\n };\r\n }\r\n return {\r\n text: 'No tickets available',\r\n disabled: true,\r\n reason: 'no_tickets',\r\n };\r\n }\r\n\r\n let hasPurchasable = false;\r\n let allSoldOut = true;\r\n let allComingSoon = true;\r\n let earliestSalesStart: Date | null = null;\r\n\r\n for (const ticket of publicTickets) {\r\n const salesBegin =\r\n ticket.salesBegin ||\r\n ticket.salesStart ||\r\n ticket.saleBegin ||\r\n ticket.onSaleStart;\r\n const salesEnd = ticket.salesEnd || ticket.saleEnd || ticket.onSaleEnd;\r\n const remaining =\r\n ticket.remainingCapacity ?? ticket.quantityRemaining ?? ticket.quantity;\r\n const isSoldOut =\r\n ticket.soldOut ||\r\n (remaining !== null && remaining !== undefined && remaining <= 0);\r\n\r\n const isScheduled = salesBegin ? new Date(salesBegin) > now : false;\r\n const hasSalesEnded = salesEnd ? new Date(salesEnd) < now : false;\r\n const isPurchasable = !isSoldOut && !isScheduled && !hasSalesEnded;\r\n\r\n if (isPurchasable) hasPurchasable = true;\r\n if (!isSoldOut) allSoldOut = false;\r\n if (!isScheduled) allComingSoon = false;\r\n\r\n if (isScheduled && salesBegin && !isSoldOut && !hasSalesEnded) {\r\n const startDate = new Date(salesBegin);\r\n if (!earliestSalesStart || startDate < earliestSalesStart) {\r\n earliestSalesStart = startDate;\r\n }\r\n }\r\n }\r\n\r\n if (hasPurchasable) {\r\n return {\r\n text: isRegistration ? 'Reserve a spot' : 'Get tickets',\r\n disabled: false,\r\n reason: 'available',\r\n };\r\n }\r\n\r\n if (allComingSoon && earliestSalesStart) {\r\n if (hiddenAvailable) {\r\n return {\r\n text: isRegistration ? 'Reserve a spot' : 'Get tickets',\r\n disabled: false,\r\n reason: 'hidden_only',\r\n };\r\n }\r\n const diffMs = earliestSalesStart.getTime() - now.getTime();\r\n const diffHours = diffMs / (1000 * 60 * 60);\r\n const diffDays = diffMs / (1000 * 60 * 60 * 24);\r\n let dateText: string;\r\n if (diffHours < 24) {\r\n dateText = formatTime(earliestSalesStart, { hour12: true }, 'en-US');\r\n } else if (diffDays <= 7) {\r\n dateText = formatDateRaw(\r\n earliestSalesStart,\r\n { weekday: 'short', hour: 'numeric', minute: '2-digit', hour12: true },\r\n 'en-US'\r\n );\r\n } else {\r\n const d = formatDateRaw(\r\n earliestSalesStart,\r\n { month: 'short', day: 'numeric' },\r\n 'en-US'\r\n );\r\n const t = formatTime(earliestSalesStart, { hour12: true }, 'en-US');\r\n dateText = `${d} ${t}`;\r\n }\r\n return {\r\n text: `On sale ${dateText}`,\r\n disabled: true,\r\n reason: 'coming_soon',\r\n };\r\n }\r\n\r\n if (allSoldOut) {\r\n if (hiddenAvailable) {\r\n return {\r\n text: isRegistration ? 'Reserve a spot' : 'Get tickets',\r\n disabled: false,\r\n reason: 'hidden_only',\r\n };\r\n }\r\n if (waitlistEnabled) {\r\n return {\r\n text: 'Join Waitlist',\r\n disabled: false,\r\n reason: 'sold_out_waitlist',\r\n };\r\n }\r\n return { text: 'Sold out', disabled: true, reason: 'sold_out' };\r\n }\r\n\r\n if (hiddenAvailable) {\r\n return {\r\n text: isRegistration ? 'Reserve a spot' : 'Get tickets',\r\n disabled: false,\r\n reason: 'hidden_only',\r\n };\r\n }\r\n\r\n return { text: 'Sales ended', disabled: true, reason: 'sales_ended' };\r\n}\r\n","// @currency-escape: feeCents / 100 in calculateServiceFee is arithmetic,\r\n// not display. Produces a dollar-magnitude number used in the fee formula\r\n// `price * (feePercentage / 100) + feeCents / 100`. Per Atlas\r\n// utility-currency convergence record; the no-handrolled-currency\r\n// ESLint rule's divideByHundred detector treats variable-name `Cents`\r\n// as drift but here it's real math.\r\n\r\n// Premium Ticket Experience — Constants & Defaults\r\n// Used by all design variants. DO NOT MODIFY per-variant.\r\n\r\n// @raw-intl-datetimeformat-escape: formatSmartSalesDate is a date-formatter\r\n// implementation (smart relative-date thresholds → \"on Friday at 8 PM\" / \"on Mar 15\").\r\n// The weekday-long (\"Friday\") and month-short+day (\"Mar 15\") fragments are interpolated\r\n// into smart-threshold strings; SC formatDate/DATE_FORMATS has no preset that emits a\r\n// bare weekday or a bare month+day, so it cannot reproduce these byte-identical fragments.\r\n// This file is the canonical formatter module for public-calendar-flow (it wraps + re-exports\r\n// scFormatDate/scFormatTime), not a call site.\r\n\r\nimport type {\r\n EventData,\r\n TicketTypeData,\r\n ScarcityLevel,\r\n CtaConfig,\r\n PromoCodeState,\r\n} from './types';\r\nimport { computeCtaState } from '$lib/api';\r\nimport type { Cents } from '@getmicdrop/svelte-components';\r\nimport {\r\n formatDate as scFormatDate,\r\n formatTime as scFormatTime,\r\n roundCurrency,\r\n} from '@getmicdrop/svelte-components';\r\nimport {\r\n formatFullDate,\r\n formatFullDateCompact,\r\n formatEventTime,\r\n formatTimeRange,\r\n formatDoorsTime,\r\n formatSalesDate,\r\n formatBrowseDate,\r\n formatEventDate,\r\n formatCleanTimeRange,\r\n getDateParts,\r\n} from '$lib/utils/datetime.js';\r\n\r\n// --- Re-export production date/time formatters (timezone-aware) ---\r\nexport {\r\n formatFullDate,\r\n formatFullDateCompact,\r\n formatEventTime,\r\n formatTimeRange,\r\n formatDoorsTime,\r\n formatSalesDate,\r\n formatBrowseDate,\r\n formatEventDate,\r\n formatCleanTimeRange,\r\n getDateParts,\r\n};\r\n\r\n// --- Scarcity Badge Rules ---\r\nexport const SCARCITY_THRESHOLDS = {\r\n SOLD_OUT: 0,\r\n URGENT: 0.1, // ≤10% remaining → urgent (\"Only X left\")\r\n LOW: 0.2, // ≤20% remaining (80%+ sold) → \"Selling fast\"\r\n MAX_EXACT_COUNT: 20, // Don't show exact count above 20\r\n} as const;\r\n\r\nexport function getScarcityLevel(\r\n remaining: number,\r\n total: number\r\n): ScarcityLevel {\r\n if (total === 0) return 'none';\r\n if (remaining <= 0) return 'sold_out';\r\n const pct = remaining / total;\r\n if (pct <= SCARCITY_THRESHOLDS.URGENT) return 'urgent';\r\n if (pct <= SCARCITY_THRESHOLDS.LOW) return 'low';\r\n return 'none';\r\n}\r\n\r\nexport function getScarcityText(\r\n level: ScarcityLevel,\r\n remaining: number,\r\n context: 'browse' | 'event' | 'ticket',\r\n options?: { isFree?: boolean }\r\n): string | null {\r\n if (level === 'none') return null;\r\n if (level === 'sold_out') return 'Sold out';\r\n // No scarcity badges on free events/tickets — nothing to lose = no urgency\r\n if (options?.isFree) return null;\r\n if (\r\n level === 'urgent' &&\r\n context !== 'browse' &&\r\n remaining <= SCARCITY_THRESHOLDS.MAX_EXACT_COUNT\r\n ) {\r\n return `Only ${remaining} left`;\r\n }\r\n if (level === 'low' || level === 'urgent') return 'Selling fast';\r\n return null;\r\n}\r\n\r\n// --- CTA Rules ---\r\n// Delegates to production computeCtaState() but adapts our EventData shape.\r\n// Components keep calling getCtaConfig(event) — internal logic is production-aligned.\r\nexport function getCtaConfig(event: EventData): CtaConfig {\r\n // Map our EventData tickets to the shape computeCtaState expects.\r\n // `isHidden` flows through so computeCtaState can apply the hidden-only\r\n // \"Sales ended\" → \"Get tickets\" override (MIC-1039).\r\n const apiTickets = event.tickets.map(t => ({\r\n salesBegin: t.salesStartDate,\r\n salesEnd: t.salesEndDate,\r\n remainingCapacity: t.quantityAvailable,\r\n totalCapacity: t.quantityTotal,\r\n soldOut: t.status === 'sold_out',\r\n salesChannel: 1, // All our tickets are online (not \"at the door only\")\r\n isHidden: t.isHidden,\r\n }));\r\n\r\n // Handle statuses that computeCtaState doesn't compute from tickets\r\n if (event.status === 'cancelled') {\r\n return {\r\n text: 'Cancelled',\r\n disabled: true,\r\n reason: 'This event has been cancelled',\r\n };\r\n }\r\n if (event.status === 'past') {\r\n return {\r\n text: 'Event ended',\r\n disabled: true,\r\n reason: 'This event has ended',\r\n };\r\n }\r\n\r\n const result = computeCtaState(\r\n { startDateTime: event.startDateTime, endDateTime: event.endDateTime },\r\n apiTickets,\r\n {\r\n cancelled: false,\r\n isRegistration: event.isRegistrationEvent,\r\n waitlistEnabled: false,\r\n }\r\n );\r\n\r\n return {\r\n text: result.text,\r\n disabled: result.disabled,\r\n reason: result.disabled ? toFriendlyReason(result.reason) : undefined,\r\n };\r\n}\r\n\r\n/**\r\n * computeCtaState() returns machine-enum reasons ('event_past', 'sold_out',\r\n * 'coming_soon', etc) intended for branching, not display. The BookingWidget\r\n * and MobileCta render `reason` directly as supplementary copy below the\r\n * button text — which leaks raw enum strings to users.\r\n *\r\n * Map each enum to a friendly sentence, OR return undefined when the button\r\n * `text` already says everything (\"Sales ended\" / \"Sold out\" — no need for\r\n * a second line repeating it).\r\n */\r\nfunction toFriendlyReason(reason: string | undefined): string | undefined {\r\n if (!reason) return undefined;\r\n switch (reason) {\r\n case 'cancelled':\r\n return 'This event has been cancelled.';\r\n case 'event_past':\r\n return 'This event has already happened.';\r\n case 'no_tickets':\r\n return 'There are no tickets configured for this event.';\r\n case 'coming_soon':\r\n return undefined; // text already shows \"On sale <date>\"\r\n case 'sold_out':\r\n return undefined; // text already shows \"Sold out\"\r\n case 'sold_out_waitlist':\r\n return 'All tickets are claimed. Join the waitlist to be notified.';\r\n case 'sales_ended':\r\n return undefined; // text already shows \"Sales ended\"\r\n default:\r\n return undefined; // unknown enum — never leak it\r\n }\r\n}\r\n\r\n// --- Price Display Rules (from DECISIONS.md #1) ---\r\nexport function getPriceDisplay(event: EventData): string | null {\r\n const visibleTickets = event.tickets.filter(\r\n t => t.status === 'on_sale' && !t.isHidden\r\n );\r\n if (visibleTickets.length === 0) return null;\r\n\r\n const hasDonation = visibleTickets.some(\r\n t => t.isDonation || t.ticketType === 2\r\n );\r\n const paidTickets = visibleTickets.filter(\r\n t => !t.isDonation && t.ticketType !== 2\r\n );\r\n const hasFree = paidTickets.some(t => t.price === 0);\r\n const pricedTickets = paidTickets.filter(t => t.price > 0);\r\n\r\n // Only donation tickets → \"Donation\"\r\n if (pricedTickets.length === 0 && !hasFree && hasDonation) return 'Donation';\r\n\r\n // Only free tickets (no paid, no donation) → null (BookingWidget shows \"Free\" via isFreeEvent)\r\n if (pricedTickets.length === 0 && hasFree) return null;\r\n\r\n const minPrice = Math.min(...pricedTickets.map(t => t.price));\r\n\r\n // Free + paid → \"Free\" (free dominates the display)\r\n if (hasFree) return null;\r\n\r\n // Donation + paid → \"From $X\" (donation is an alternative option)\r\n if (hasDonation) return `From $${minPrice}`;\r\n\r\n // Single paid ticket type → \"$X\"\r\n if (pricedTickets.length === 1) return `$${minPrice}`;\r\n\r\n // Multiple paid ticket types → \"From $X\"\r\n return `From $${minPrice}`;\r\n}\r\n\r\n// --- Fee Calculation ---\r\nexport function calculateFee(\r\n price: number,\r\n feePercentage: number,\r\n feeCents: Cents\r\n): number {\r\n return roundCurrency(price * (feePercentage / 100) + feeCents / 100);\r\n}\r\n\r\nexport function calculateTax(amount: number, taxPercentage: number): number {\r\n return roundCurrency(amount * (taxPercentage / 100));\r\n}\r\n\r\n// --- Date Formatting ---\r\n// PREFERRED: Use the timezone-aware production formatters re-exported above:\r\n// formatBrowseDate(iso, tz) → \"Fri, Feb 20\"\r\n// formatFullDateCompact(iso, tz) → \"Friday, February 20\"\r\n// formatEventTime(iso, tz) → \"8:00 PM\"\r\n// formatTimeRange(start, end, tz) → \"8:00 PM - 10:00 PM\"\r\n// formatDoorsTime(doors, tz) → \"7:00 PM\"\r\n//\r\n// DEPRECATED: The functions below are backward-compatible wrappers for variants\r\n// not yet migrated to timezone-aware formatters. They use browser-local timezone.\r\n// Migrate to the production formatters above when updating each variant.\r\n\r\n/** @deprecated Use formatBrowseDate(dateStr, timezone) instead */\r\nexport function formatDate(dateStr: string): string {\r\n return scFormatDate(dateStr, { weekday: 'short', year: undefined });\r\n}\r\n\r\n/** @deprecated Use formatEventTime(dateStr, timezone) instead */\r\nexport function formatTime(dateStr: string): string {\r\n return scFormatTime(dateStr);\r\n}\r\n\r\n/** @deprecated Use formatBrowseDate + formatTimeRange instead */\r\nexport function formatDateRange(start: string, end: string): string {\r\n const tz = Intl.DateTimeFormat().resolvedOptions().timeZone;\r\n return `${formatBrowseDate(start, tz)} · ${formatTimeRange(start, end, tz)}`;\r\n}\r\n\r\n// --- Animation Durations ---\r\nexport const DURATION = {\r\n instant: 100,\r\n micro: 150,\r\n fast: 200,\r\n normal: 300,\r\n slow: 400,\r\n elaborate: 600,\r\n} as const;\r\n\r\n// --- Smart Sales Date Formatting ---\r\n// Ported from production TicketBlock.svelte — smart thresholds for human-readable dates\r\nexport function formatSmartSalesDate(dateStr: string): string {\r\n if (!dateStr) return '';\r\n const date = new Date(dateStr);\r\n const now = new Date();\r\n const diffMs = date.getTime() - now.getTime();\r\n const diffMinutes = Math.round(diffMs / (1000 * 60));\r\n const diffHours = diffMs / (1000 * 60 * 60);\r\n\r\n // < 1 hour: \"in X minutes\"\r\n if (diffMinutes > 0 && diffMinutes < 60) {\r\n const mins = Math.max(1, diffMinutes);\r\n return `in ${mins} minute${mins !== 1 ? 's' : ''}`;\r\n }\r\n\r\n // 1-24 hours: \"in X hours\"\r\n if (diffHours > 0 && diffHours < 24) {\r\n const hours = Math.max(1, Math.round(diffHours));\r\n return `in ${hours} hour${hours !== 1 ? 's' : ''}`;\r\n }\r\n\r\n // Tomorrow: \"tomorrow at X PM\"\r\n const tomorrow = new Date(now);\r\n tomorrow.setDate(tomorrow.getDate() + 1);\r\n if (date.toDateString() === tomorrow.toDateString()) {\r\n const timeStr = scFormatTime(\r\n date,\r\n { hour: 'numeric', minute: '2-digit' },\r\n 'en-US'\r\n );\r\n return `tomorrow at ${timeStr}`;\r\n }\r\n\r\n // 2-7 days: \"on Friday at X PM\"\r\n const diffDays = diffMs / (1000 * 60 * 60 * 24);\r\n if (diffDays > 0 && diffDays <= 7) {\r\n const dayName = new Intl.DateTimeFormat('en-US', {\r\n weekday: 'long',\r\n }).format(date);\r\n const timeStr = scFormatTime(\r\n date,\r\n { hour: 'numeric', minute: '2-digit' },\r\n 'en-US'\r\n );\r\n return `on ${dayName} at ${timeStr}`;\r\n }\r\n\r\n // > 7 days: \"on Mar 15\"\r\n const dateFormatted = new Intl.DateTimeFormat('en-US', {\r\n month: 'short',\r\n day: 'numeric',\r\n }).format(date);\r\n return `on ${dateFormatted}`;\r\n}\r\n\r\n// --- Promo Code State Factory ---\r\nexport function createDefaultPromoState(): PromoCodeState {\r\n return {\r\n code: '',\r\n isApplied: false,\r\n isValidating: false,\r\n error: '',\r\n hint: '',\r\n discountAmount: 0,\r\n discountType: '',\r\n discountTicketIds: [],\r\n revealHiddenTickets: false,\r\n revealTicketIds: [],\r\n };\r\n}\r\n\r\n// --- Ticket helpers ---\r\nexport function getAvailableTickets(\r\n tickets: TicketTypeData[]\r\n): TicketTypeData[] {\r\n return tickets.filter(t => !t.isHidden && t.status === 'on_sale');\r\n}\r\n","<script lang=\"ts\">\r\n\timport type { USD } from '@getmicdrop/svelte-components';\r\n\timport { Text, formatCurrency } from '@getmicdrop/svelte-components';\r\n\timport type { OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport { DURATION } from '$lib/public-calendar-flow/defaults';\r\n\r\n\tinterface Props {\r\n\t\torderTotals: OrderTotals;\r\n\t\tlabels?: Record<string, string>;\r\n\t\t/**\r\n\t\t * Which section to render.\r\n\t\t * - `full` (default): ticket lines + totals stacked together.\r\n\t\t * - `lines` : ticket-line items only. Use when the parent scrolls\r\n\t\t * this section in a flex column.\r\n\t\t * - `totals` : subtotal/fees/taxes/promo/total only. Use in a fixed\r\n\t\t * footer alongside the action button.\r\n\t\t *\r\n\t\t * Splitting via `lines` / `totals` lets the sticky sidebars scroll\r\n\t\t * just the variable-length ticket list while keeping the summary\r\n\t\t * block and CTA always visible.\r\n\t\t */\r\n\t\tmode?: 'full' | 'lines' | 'totals';\r\n\t}\r\n\r\n\tlet { orderTotals, labels = {}, mode = 'full' }: Props = $props();\r\n</script>\r\n\r\n<div\r\n\tclass=\"space-y-2\"\r\n\tstyle=\"transition-duration: {DURATION.normal}ms;\"\r\n>\r\n\t{#if mode !== 'totals'}\r\n\t\t<!-- Line items -->\r\n\t\t{#each orderTotals.lines as line (line.ticketId)}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\">{line.quantity}x {line.ticketName}</Text>\r\n\t\t\t\t<Text size=\"sm\">{formatCurrency(line.subtotal as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/each}\r\n\t{/if}\r\n\r\n\t{#if mode !== 'lines'}\r\n\t\t<!-- Subtotal. In `totals` mode the parent supplies the separator above\r\n\t\t this block (BookingWidget wraps the totals block in border-t); a\r\n\t\t second internal border would render as a double line. Only show\r\n\t\t the internal border-t in `full` mode where lines + totals stack\r\n\t\t in one container with no external separator. -->\r\n\t\t{#if mode === 'full' && orderTotals.lines.length > 1}\r\n\t\t\t<div class=\"flex justify-between pt-1 border-t border-default\">\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{labels.subtotal || 'Subtotal'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{formatCurrency(orderTotals.subtotal as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{:else if orderTotals.lines.length > 1}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{labels.subtotal || 'Subtotal'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{formatCurrency(orderTotals.subtotal as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/if}\r\n\r\n\t\t<!-- Fees -->\r\n\t\t{#if orderTotals.fees > 0}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{labels.serviceFees || 'Service fees'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{formatCurrency(orderTotals.fees as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/if}\r\n\r\n\t\t<!-- Taxes -->\r\n\t\t{#if orderTotals.taxes > 0}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{labels.taxes || 'Taxes'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"muted\">{formatCurrency(orderTotals.taxes as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/if}\r\n\r\n\t\t<!-- Promo discount -->\r\n\t\t{#if orderTotals.promoDiscount > 0}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\" color=\"success\">{labels.promoDiscount || 'Promo discount'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"success\">-{formatCurrency(orderTotals.promoDiscount as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/if}\r\n\r\n\t\t<!-- Gift card — deduction from the amount due; `total` already reflects it -->\r\n\t\t{#if orderTotals.giftCardAmount > 0}\r\n\t\t\t<div class=\"flex justify-between\">\r\n\t\t\t\t<Text size=\"sm\" color=\"success\">{labels.giftCard || 'Gift card'}</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"success\">-{formatCurrency(orderTotals.giftCardAmount as USD)}</Text>\r\n\t\t\t</div>\r\n\t\t{/if}\r\n\r\n\t\t<!-- Total -->\r\n\t\t<div class=\"flex justify-between pt-2 border-t border-default\">\r\n\t\t\t<Text size=\"base\" class=\"font-semibold\">{labels.total || 'Total'}</Text>\r\n\t\t\t<Text size=\"base\" class=\"font-semibold\">{formatCurrency(orderTotals.total as USD)}</Text>\r\n\t\t</div>\r\n\t{/if}\r\n</div>\r\n","/**\r\n * Default English labels for public-calendar-flow components.\r\n * Consumers override via the `labels` prop on any *Main component.\r\n *\r\n * Label keys use flat camelCase. For composed strings (e.g. aria-labels),\r\n * components build them from atomic label parts.\r\n */\r\nexport const defaultLabels = {\r\n // ── Ticket quantity controls ──────────────────────────────────────\r\n decrease: 'Decrease',\r\n increase: 'Increase',\r\n quantity: 'quantity',\r\n\r\n // ── Ticket states ─────────────────────────────────────────────────\r\n soldOut: 'Sold out',\r\n free: 'Free',\r\n unavailable: 'Unavailable',\r\n eventSoldOut: 'This event is sold out',\r\n\r\n // ── Price display ─────────────────────────────────────────────────\r\n includesFees: 'Includes',\r\n fees: 'fees',\r\n fee: 'fee',\r\n\r\n // ── Checkout CTAs ─────────────────────────────────────────────────\r\n checkout: 'Checkout',\r\n getTickets: 'Get tickets',\r\n selectTickets: 'Select tickets',\r\n selectTicketsBelow: 'Select tickets below',\r\n selectTicketsToContinue: 'Select tickets to continue',\r\n reserveASpot: 'Reserve a spot',\r\n\r\n // ── Password modal / gate ─────────────────────────────────────────\r\n enterPassword: 'Enter Password',\r\n enterEventPassword: 'Enter event password',\r\n passwordRequired: 'Password Required',\r\n passwordRequiredShort: 'Password required',\r\n eventRequiresPassword: 'This event requires a password to purchase tickets.',\r\n eventRequiresPasswordAccess: 'This event requires a password to access tickets.',\r\n enterEventPasswordToView: 'Enter the event password to view tickets.',\r\n enterEventPasswordToViewAvailable: 'Enter the event password to view available tickets.',\r\n eventPassword: 'Event password',\r\n password: 'Password',\r\n pleaseEnterPassword: 'Please enter the event password',\r\n pleaseEnterAPassword: 'Please enter a password',\r\n eventRequiresPasswordShort: 'This event requires a password',\r\n unlockTickets: 'Unlock tickets',\r\n cancel: 'Cancel',\r\n continue: 'Continue',\r\n submit: 'Submit',\r\n\r\n // ── Order summary ─────────────────────────────────────────────────\r\n subtotal: 'Subtotal',\r\n serviceFees: 'Service fees',\r\n taxes: 'Taxes',\r\n tax: 'Tax',\r\n promoDiscount: 'Promo discount',\r\n giftCard: 'Gift card',\r\n total: 'Total',\r\n orderSummary: 'Order summary',\r\n yourOrder: 'Your Order',\r\n\r\n // ── Ticket counts (used in CTA buttons) ───────────────────────────\r\n ticket: 'ticket',\r\n tickets: 'tickets',\r\n\r\n // ── Checkout form (public-calendar-flow) ───────────────────────────────\r\n yourDetails: 'Your details',\r\n attendeeDetails: 'Attendee details',\r\n attendee: 'Attendee',\r\n sameAsPurchaser: 'Same as purchaser',\r\n payment: 'Payment',\r\n noPaymentRequired: 'No payment required',\r\n freeEventMessage: 'This is a free event. Complete the form above to reserve your spot.',\r\n firstName: 'First name',\r\n lastName: 'Last name',\r\n emailAddress: 'Email address',\r\n email: 'Email',\r\n emailPlaceholder: 'you@example.com',\r\n attendeeEmailPlaceholder: 'attendee@example.com',\r\n cardNumber: 'Card number',\r\n cardPlaceholder: '4242 4242 4242 4242',\r\n expiryDate: 'Expiry date',\r\n expiryPlaceholder: 'MM / YY',\r\n cvc: 'CVC',\r\n cvcPlaceholder: '123',\r\n keepMeUpdated: 'Keep me updated about this event and similar events',\r\n agreeToTerms: 'I agree to the terms and conditions',\r\n goBack: 'Go back',\r\n loadingPaymentForm: 'Loading secure payment form...',\r\n\r\n // ── Checkout form validation ──────────────────────────────────────\r\n firstNameRequired: 'First name is required',\r\n lastNameRequired: 'Last name is required',\r\n emailRequired: 'Email is required',\r\n emailInvalid: 'Enter a valid email address',\r\n emailInvalidShort: 'Enter a valid email',\r\n cardNumberRequired: 'Card number is required',\r\n expiryRequired: 'Expiry date is required',\r\n cvcRequired: 'CVC is required',\r\n mustAgreeTerms: 'You must agree to the terms',\r\n\r\n // ── Place order CTAs ──────────────────────────────────────────────\r\n placeOrder: 'Place order',\r\n completeOrder: 'Complete order',\r\n placingOrder: 'Placing order...',\r\n\r\n // ── Promo code ────────────────────────────────────────────────────\r\n havePromoCode: 'Have a promo code?',\r\n promoCode: 'Promo code',\r\n enterCode: 'Enter code',\r\n apply: 'Apply',\r\n remove: 'Remove',\r\n removePromoCode: 'Remove promo code',\r\n applyPromoCode: 'Apply promo code',\r\n checkingPromoCode: 'Checking promo code',\r\n checking: 'Checking...',\r\n promoApplied: 'Promo applied',\r\n\r\n // ── Navigation tabs (app-segments) ────────────────────────────────\r\n about: 'About',\r\n ticketsTab: 'Tickets',\r\n eventSections: 'Event sections',\r\n\r\n // ── Event details ─────────────────────────────────────────────────\r\n eventDetails: 'Event details',\r\n performers: 'Performers',\r\n faq: 'FAQ',\r\n frequentlyAskedQuestions: 'Frequently asked questions',\r\n doors: 'Doors',\r\n doorsOpenAt: 'Doors open at',\r\n\r\n // ── Series occurrences ────────────────────────────────────────────\r\n upcomingDates: 'Upcoming Dates',\r\n\r\n // ── Close / dismiss ───────────────────────────────────────────────\r\n closeTicketSelection: 'Close ticket selection',\r\n closeTicketSelector: 'Close ticket selector',\r\n\r\n // ── Accessibility ─────────────────────────────────────────────────\r\n ticketSelection: 'ticket selection',\r\n ticketsSelected: 'tickets selected',\r\n view: 'View',\r\n\r\n // ── Success page (public-calendar-flow) ────────────────────────────────\r\n youreIn: \"You're in!\",\r\n youreRegistered: \"You're registered!\",\r\n confirmed: 'confirmed',\r\n viewTickets: 'View tickets',\r\n order: 'Order',\r\n confirmationSentTo: 'Confirmation sent to',\r\n addToCalendar: 'Add to Calendar',\r\n googleCalendar: 'Google Calendar',\r\n appleCalendar: 'Apple Calendar (.ics)',\r\n share: 'Share',\r\n map: 'Map',\r\n backToEvent: 'Back to event',\r\n needHelp: 'Need help?',\r\n linkCopied: 'Link copied to clipboard!',\r\n copyLink: 'Copy this link:',\r\n addToAppleWallet: 'Add to Apple Wallet',\r\n saveToGoogleWallet: 'Save to Google Wallet',\r\n\r\n // ── Session timer / expiration modals ─────────────────────────────\r\n sessionExpiringSoon: 'Session expiring soon',\r\n sessionExpiringSoonMessage: 'Your checkout session will expire in {time}. Your selected tickets will be released back to inventory.',\r\n extensionsRemaining: '{count} extension{plural} remaining',\r\n continueCheckout: 'Continue checkout',\r\n okIllHurry: \"OK, I'll hurry\",\r\n maxExtensionsReached: 'Maximum extensions reached',\r\n wantToKeepTickets: 'Want to keep your tickets?',\r\n sessionExpiredMessage: 'Your checkout session has expired and your selected tickets have been released.',\r\n sessionExpired: 'Session expired',\r\n reservationTimedOut: 'Your reservation has timed out. Please select your tickets again to continue.',\r\n keepMyTickets: 'Keep my tickets',\r\n selectTicketsAgain: 'Select tickets again',\r\n extendingSession: 'Extending...',\r\n\r\n // ── MobileCta ─────────────────────────────────────────────────────\r\n selectTicketsLabel: 'Select Tickets',\r\n};\r\n\r\n/**\r\n * Merge user-provided label overrides with the defaults.\r\n * Shallow merge — any key provided by the consumer wins.\r\n *\r\n * @param {Record<string, string>} [userLabels] - Partial label overrides\r\n * @returns {Record<string, string>} Merged labels object\r\n */\r\nexport function mergeLabels(userLabels = {}) {\r\n return { ...defaultLabels, ...userLabels };\r\n}\r\n"],"names":["isHiddenTicketPurchasable","ticket","now","salesBegin","salesEnd","remaining","computeCtaState","event","tickets","options","cancelled","isRegistration","waitlistEnabled","eventEnd","hiddenAvailable","publicTickets","t","hasPurchasable","allSoldOut","allComingSoon","earliestSalesStart","isSoldOut","isScheduled","hasSalesEnded","startDate","diffMs","diffHours","diffDays","dateText","formatTime","formatDateRaw","d","SCARCITY_THRESHOLDS","getScarcityLevel","total","pct","getScarcityText","level","context","getCtaConfig","apiTickets","result","toFriendlyReason","reason","getPriceDisplay","visibleTickets","hasDonation","paidTickets","hasFree","pricedTickets","minPrice","calculateTax","amount","taxPercentage","roundCurrency","DURATION","formatSmartSalesDate","dateStr","date","diffMinutes","mins","hours","tomorrow","scFormatTime","dayName","timeStr","createDefaultPromoState","labels","$","$$props","mode","div","root","node_1","line","div_1","root_2","Text","node_2","text","node_3","formatCurrency","$$render","consequent","div_2","root_6","node_6","node_7","$0","text_3","div_3","root_9","node_8","node_9","text_5","consequent_1","consequent_2","div_4","root_12","node_11","node_12","text_7","consequent_3","div_5","root_15","node_14","node_15","text_9","consequent_4","div_6","root_18","node_17","node_18","text_11","consequent_5","div_7","root_21","node_20","node_21","text_13","consequent_6","div_8","node_19","node_22","node_23","text_15","consequent_7","defaultLabels","mergeLabels","userLabels"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { aL as y, aM as g, ag as D } from "./VenueCalendar-CGKy4kQ8.js";
|
|
2
2
|
import "svelte/internal/disclose-version";
|
|
3
3
|
import "svelte/internal/client";
|
|
4
4
|
import "svelte/transition";
|
|
@@ -253,4 +253,4 @@ export {
|
|
|
253
253
|
b,
|
|
254
254
|
k as t
|
|
255
255
|
};
|
|
256
|
-
//# sourceMappingURL=transform-
|
|
256
|
+
//# sourceMappingURL=transform-DeiNOLZ8.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transform-TJz04LxL.js","sources":["../src/lib/public-calendar-flow/transform.ts"],"sourcesContent":["import { formatDateRaw } from '@getmicdrop/svelte-components';\n// Premium Ticket Experience — API → EventData Transformer\n// Maps raw API event responses to our clean EventData interface.\n// Used when plugging in real API data. The showcase continues using mock-data.ts directly.\n\nimport { getImageUrl } from '$lib/utils/utils.js';\nimport { getIANATimezone } from '$lib/utils/datetime.js';\nimport type {\n EventData,\n EventStatus,\n TicketTypeData,\n TicketStatus,\n VenueData,\n PerformerData,\n FAQItem,\n SeriesOccurrence,\n CollectionEvent,\n} from './types';\nimport type { SeriesPageData, PublicCollectionData } from '$lib/api/types';\n\n/**\n * Parse a single-line address string into display lines.\n * E.g. \"123 Main St, Los Angeles, CA 90012\" → [\"123 Main St\", \"Los Angeles, CA 90012\"]\n */\nfunction parseAddress(addressStr: string): string[] {\n if (!addressStr) return [];\n const parts = addressStr.split(',').map(p => p.trim());\n if (parts.length < 2) return [addressStr];\n const lastPart = parts[parts.length - 1];\n const stateZipMatch = lastPart.match(/^([A-Z]{2})\\s+(\\d{5}(-\\d{4})?)$/);\n if (stateZipMatch && parts.length >= 3) {\n const state = stateZipMatch[1];\n const zip = stateZipMatch[2];\n const city = parts[parts.length - 2];\n const lines = parts.slice(0, -2);\n lines.push(`${city}, ${state} ${zip}`);\n return lines;\n }\n return [parts[0], parts.slice(1).join(', ')];\n}\n\n/**\n * Build a Google Maps search URL from an address string.\n */\nfunction buildGoogleMapsUrl(address: string): string {\n if (!address) return '';\n return `https://www.google.com/maps/search/?api=1&query=${encodeURIComponent(address)}`;\n}\n\n/**\n * Map a raw API ticket status/state to our TicketStatus union.\n */\nfunction mapTicketStatus(ticket: any): TicketStatus {\n const now = new Date();\n const remaining =\n ticket.remainingCapacity ??\n ticket.quantityRemaining ??\n ticket.quantity ??\n 0;\n const salesBegin =\n ticket.salesBegin ||\n ticket.salesStart ||\n ticket.saleBegin ||\n ticket.onSaleStart;\n const salesEnd = ticket.salesEnd || ticket.saleEnd || ticket.onSaleEnd;\n\n if (remaining <= 0) return 'sold_out';\n if (salesEnd && new Date(salesEnd) < now) return 'sales_ended';\n if (salesBegin && new Date(salesBegin) > now) return 'coming_soon';\n return 'on_sale';\n}\n\n/**\n * Map a raw API event status string to our EventStatus union.\n */\nfunction mapEventStatus(\n rawStatus: string,\n tickets: TicketTypeData[]\n): EventStatus {\n const s = (rawStatus || '').toLowerCase().replace(/\\s+/g, '_');\n\n if (s === 'cancelled' || s === 'canceled') return 'cancelled';\n\n // Check if event is past based on end time (handled by caller if needed)\n if (s === 'past' || s === 'ended') return 'past';\n\n // MIC-1039: if any hidden ticket is still on sale, the event is \"on_sale\"\n // regardless of visible-ticket states — the user just needs a promo code.\n const hasPurchasableHiddenTickets = tickets.some(\n t => t.isHidden && t.status === 'on_sale'\n );\n if (hasPurchasableHiddenTickets) return 'on_sale';\n\n // Derive from ticket states\n const publicTickets = tickets.filter(t => !t.isHidden);\n if (publicTickets.length > 0) {\n if (publicTickets.every(t => t.status === 'sold_out')) return 'sold_out';\n if (publicTickets.every(t => t.status === 'coming_soon'))\n return 'coming_soon';\n if (\n publicTickets.every(\n t => t.status === 'sales_ended' || t.status === 'sold_out'\n )\n )\n return 'sales_ended';\n }\n\n if (s === 'sold_out' || s === 'soldout') return 'sold_out';\n if (s === 'coming_soon' || s === 'comingsoon') return 'coming_soon';\n if (s === 'sales_ended' || s === 'salesended') return 'sales_ended';\n\n return 'on_sale';\n}\n\n/**\n * Transform a raw API event response into our clean EventData interface.\n * This is the bridge between the API and our premium ticket experience components.\n */\nexport function transformApiEvent(rawEvent: any): EventData {\n const rawVenue = rawEvent.venue || {};\n // Event-level timeZone is an OPTIONAL per-event override; when absent/blank it\n // must inherit the venue timezone. Falling straight to 'UTC' here rendered\n // venue-local times (e.g. a Fri 10pm Central show) in UTC (\"Sat 3:00 AM\"),\n // which made already-ended events look like future ones.\n const timezone = getIANATimezone(\n rawEvent.timeZone ||\n rawEvent.timezone ||\n rawVenue.timeZone ||\n rawVenue.timezone ||\n 'UTC'\n );\n\n // Transform tickets\n const rawTickets = rawEvent.availableTickets || [];\n const tickets: TicketTypeData[] = rawTickets.map((t: any) => ({\n id: t.id || t.ID,\n name: t.name || t.title || '',\n description: t.description || undefined,\n price: t.price ?? 0,\n fee: t.fee ?? 0,\n quantityAvailable:\n t.remainingCapacity ?? t.quantityRemaining ?? t.quantity ?? 0,\n quantityTotal: t.totalCapacity ?? t.quantity ?? 0,\n minPerOrder: t.minPerOrder ?? t.minQuantity ?? 1,\n maxPerOrder: t.maxPerOrder ?? t.maxQuantity ?? 10,\n status: mapTicketStatus(t),\n salesStartDate:\n t.salesBegin || t.salesStart || t.saleBegin || t.onSaleStart || undefined,\n salesEndDate: t.salesEnd || t.saleEnd || t.onSaleEnd || undefined,\n isDonation: t.type === 2 || t.ticketType === 2 || t.isDonation === true,\n isHidden: t.visibility === 2 || t.isHidden === true,\n ticketType: t.type || t.ticketType || undefined,\n sectionName: t.sectionName || t.section || undefined,\n }));\n\n // Calculate totals from public tickets\n const publicTickets = tickets.filter(t => !t.isHidden && !t.isDonation);\n const totalRemaining = publicTickets.reduce(\n (sum, t) => sum + t.quantityAvailable,\n 0\n );\n const totalCapacity = publicTickets.reduce(\n (sum, t) => sum + t.quantityTotal,\n 0\n );\n\n // Determine event status\n const status = mapEventStatus(rawEvent.status, tickets);\n\n // Build image URL\n const rawImage =\n rawEvent.image || rawEvent.imageUrl || rawEvent.image_url || '';\n const imageUrl = rawImage.startsWith('http')\n ? rawImage\n : getImageUrl(rawImage);\n\n // Venue\n const venue: VenueData = {\n id: rawVenue.id || rawVenue.ID || 0,\n name: rawVenue.name || rawVenue.googleLocationNameCache || '',\n address: rawVenue.address || rawVenue.googleLocationNameCache || '',\n timezone,\n serviceFeePercentage: rawVenue.serviceFeePercentage ?? rawVenue.fee ?? 0,\n serviceFeeCents: rawVenue.serviceFeeCents ?? 0,\n taxPercentage: rawVenue.taxPercentage ?? rawVenue.tax ?? 0,\n contactEmail: rawVenue.contactEmail || rawVenue.email || undefined,\n };\n\n // Performers\n const rawPerformers = rawEvent.performers || [];\n const performers: PerformerData[] = rawPerformers.map((p: any) => ({\n id: p.id || p.ID,\n displayName: p.displayName || p.name || '',\n profileImage: p.avatar || p.profileImage || undefined,\n role: p.role || undefined,\n }));\n\n // FAQs (may not be in API response)\n const faqs: FAQItem[] = (rawEvent.faqs || []).map((f: any) => ({\n question: f.question || '',\n answer: f.answer || '',\n }));\n\n // Date in venue timezone\n let date = '';\n if (rawEvent.startDateTime) {\n const dt = new Date(rawEvent.startDateTime);\n date = formatDateRaw(\n dt,\n { timeZone: timezone, year: 'numeric', month: '2-digit', day: '2-digit' },\n 'en-CA'\n );\n }\n\n return {\n id: rawEvent.id || rawEvent.ID,\n title: rawEvent.title || rawEvent.name || '',\n slug: rawEvent.slug || '',\n description: rawEvent.description || rawEvent.eventSummary || '',\n date,\n startDateTime: rawEvent.startDateTime || '',\n endDateTime: rawEvent.endDateTime || '',\n doorsOpenTime: rawEvent.doorsOpenTime || '',\n timezone,\n imageUrl,\n venue,\n performers,\n tickets,\n faqs,\n disclaimer: rawEvent.disclaimer || undefined,\n status,\n eventSeriesId: rawEvent.eventSeriesId || undefined,\n // Public API hides the actual password (json:\"-\") and exposes a boolean\n // `hasPassword` flag instead; fall back to a populated `password` for\n // admin-shaped payloads.\n isPasswordProtected: rawEvent.hasPassword === true || !!rawEvent.password,\n isRegistrationEvent:\n rawEvent.ticketType === 1 || rawEvent.eventTicketingType === 1,\n totalTicketsRemaining: totalRemaining,\n totalTicketsCapacity: totalCapacity,\n stageName: rawEvent.stage?.name || rawEvent.stageName || undefined,\n ageRestriction: rawEvent.ageRestriction || undefined,\n displayAgeRestriction: rawEvent.displayAgeRestriction ?? false,\n displayStartTime: rawEvent.displayStartTime ?? true,\n displayEndTime: rawEvent.displayEndTime ?? true,\n displayDoorsTime: rawEvent.displayDoorsTime ?? true,\n collectionId: rawEvent.collectionId || rawEvent.collection_id || undefined,\n venueAddressLines: parseAddress(\n rawVenue.address || rawVenue.googleLocationNameCache || ''\n ),\n googleMapsUrl: buildGoogleMapsUrl(\n rawVenue.address || rawVenue.googleLocationNameCache || ''\n ),\n };\n}\n\n/**\n * Transform SeriesPageData (from the series API) into our clean EventData interface.\n * Sets eventSeriesId so AirbnbSplitMain renders in full-width series mode.\n */\nexport function transformSeriesPageData(series: SeriesPageData): EventData {\n const timezone = getIANATimezone(series.timeZone || 'UTC');\n\n // Build image URL\n const rawImage = series.image || '';\n const imageUrl = rawImage.startsWith('http')\n ? rawImage\n : rawImage\n ? getImageUrl(rawImage)\n : '';\n\n // Map occurrences to SeriesOccurrence[]\n const seriesOccurrences: SeriesOccurrence[] = (series.occurrences || []).map(\n occ => ({\n id: occ.id,\n slug: occ.slug || '',\n startDateTime: occ.startDateTime,\n endDateTime: occ.endDateTime || '',\n status: (occ.ctaState?.reason === 'sold_out'\n ? 'sold_out'\n : 'on_sale') as EventStatus,\n ctaText: occ.ctaState?.text || 'Get Tickets',\n ctaDisabled: occ.ctaState?.disabled || false,\n })\n );\n\n // Use first occurrence for date fields\n const firstOcc = series.occurrences?.[0];\n let date = '';\n if (firstOcc?.startDateTime) {\n const dt = new Date(firstOcc.startDateTime);\n date = formatDateRaw(\n dt,\n { timeZone: timezone, year: 'numeric', month: '2-digit', day: '2-digit' },\n 'en-CA'\n );\n }\n\n // Map FAQs\n const rawFaq = series.venue?.faq;\n let faqs: FAQItem[] = [];\n if (Array.isArray(rawFaq)) {\n faqs = rawFaq.map(f => ({\n question: f.question || '',\n answer: f.answer || '',\n }));\n } else if (typeof rawFaq === 'string' && rawFaq) {\n faqs = [{ question: 'FAQ', answer: rawFaq }];\n }\n\n // Map performers\n const performers: PerformerData[] = (series.performers || []).map(\n (p, index) => ({\n id: index + 1,\n displayName:\n p.displayName || [p.firstName, p.lastName].filter(Boolean).join(' '),\n profileImage: p.profileImage || undefined,\n })\n );\n\n // Venue address\n const venueAddress =\n series.venue?.location || series.venue?.googleLocationNameCache || '';\n\n return {\n id: series.id,\n title: series.title || '',\n slug: '',\n description: series.description || series.eventSummary || '',\n date,\n startDateTime: firstOcc?.startDateTime || '',\n endDateTime: firstOcc?.endDateTime || '',\n doorsOpenTime: '',\n timezone,\n imageUrl,\n venue: {\n id: series.venue?.id || 0,\n name: series.venue?.name || '',\n address: venueAddress,\n timezone,\n serviceFeePercentage: 0,\n serviceFeeCents: 0,\n taxPercentage: 0,\n },\n performers,\n tickets: [],\n faqs,\n disclaimer: series.venue?.disclaimer || undefined,\n status: 'on_sale',\n eventSeriesId: series.id,\n seriesOccurrences,\n isPasswordProtected: false,\n isRegistrationEvent: false,\n totalTicketsRemaining: 0,\n totalTicketsCapacity: 0,\n venueAddressLines: parseAddress(venueAddress),\n googleMapsUrl: buildGoogleMapsUrl(venueAddress),\n };\n}\n\n/**\n * Transform PublicCollectionData (from the collection API) into our clean EventData interface.\n * Sets collectionId so AirbnbSplitMain renders in full-width collection mode.\n */\nexport function transformCollectionData(\n collection: PublicCollectionData\n): EventData {\n // Map collection events to CollectionEvent[]\n const collectionEvents: CollectionEvent[] = (collection.events || []).map(\n ev => {\n const rawImg = ev.image || '';\n return {\n id: ev.id,\n name: ev.title || '',\n slug: ev.slug || '',\n image: rawImg.startsWith('http')\n ? rawImg\n : rawImg\n ? getImageUrl(rawImg)\n : '',\n startDateTime: ev.startDateTime || '',\n status: (ev.status || 'on_sale') as EventStatus,\n };\n }\n );\n\n // Cover image\n const rawCover = collection.coverImage || '';\n const imageUrl = rawCover.startsWith('http')\n ? rawCover\n : rawCover\n ? getImageUrl(rawCover)\n : '';\n\n return {\n id: collection.id,\n title: collection.collectionTitle || '',\n slug: '',\n description: collection.description || collection.summary || '',\n date: '',\n startDateTime: '',\n endDateTime: '',\n doorsOpenTime: '',\n timezone: 'UTC',\n imageUrl,\n venue: {\n id: 0,\n name: '',\n address: '',\n timezone: 'UTC',\n serviceFeePercentage: 0,\n serviceFeeCents: 0,\n taxPercentage: 0,\n },\n performers: [],\n tickets: [],\n faqs: [],\n status: 'on_sale',\n collectionId: collection.id,\n collectionEvents,\n isPasswordProtected: false,\n isRegistrationEvent: false,\n totalTicketsRemaining: 0,\n totalTicketsCapacity: 0,\n };\n}\n"],"names":["parseAddress","addressStr","parts","p","stateZipMatch","state","zip","city","lines","buildGoogleMapsUrl","address","mapTicketStatus","ticket","now","remaining","salesBegin","salesEnd","mapEventStatus","rawStatus","tickets","s","t","publicTickets","transformApiEvent","rawEvent","rawVenue","timezone","getIANATimezone","totalRemaining","sum","totalCapacity","status","rawImage","imageUrl","getImageUrl","venue","performers","faqs","f","date","dt","formatDateRaw","transformSeriesPageData","series","seriesOccurrences","occ","firstOcc","rawFaq","index","venueAddress","transformCollectionData","collection","collectionEvents","ev","rawImg","rawCover"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"transform-DeiNOLZ8.js","sources":["../src/lib/public-calendar-flow/transform.ts"],"sourcesContent":["import { formatDateRaw } from '@getmicdrop/svelte-components';\n// Premium Ticket Experience — API → EventData Transformer\n// Maps raw API event responses to our clean EventData interface.\n// Used when plugging in real API data. The showcase continues using mock-data.ts directly.\n\nimport { getImageUrl } from '$lib/utils/utils.js';\nimport { getIANATimezone } from '$lib/utils/datetime.js';\nimport type {\n EventData,\n EventStatus,\n TicketTypeData,\n TicketStatus,\n VenueData,\n PerformerData,\n FAQItem,\n SeriesOccurrence,\n CollectionEvent,\n} from './types';\nimport type { SeriesPageData, PublicCollectionData } from '$lib/api/types';\n\n/**\n * Parse a single-line address string into display lines.\n * E.g. \"123 Main St, Los Angeles, CA 90012\" → [\"123 Main St\", \"Los Angeles, CA 90012\"]\n */\nfunction parseAddress(addressStr: string): string[] {\n if (!addressStr) return [];\n const parts = addressStr.split(',').map(p => p.trim());\n if (parts.length < 2) return [addressStr];\n const lastPart = parts[parts.length - 1];\n const stateZipMatch = lastPart.match(/^([A-Z]{2})\\s+(\\d{5}(-\\d{4})?)$/);\n if (stateZipMatch && parts.length >= 3) {\n const state = stateZipMatch[1];\n const zip = stateZipMatch[2];\n const city = parts[parts.length - 2];\n const lines = parts.slice(0, -2);\n lines.push(`${city}, ${state} ${zip}`);\n return lines;\n }\n return [parts[0], parts.slice(1).join(', ')];\n}\n\n/**\n * Build a Google Maps search URL from an address string.\n */\nfunction buildGoogleMapsUrl(address: string): string {\n if (!address) return '';\n return `https://www.google.com/maps/search/?api=1&query=${encodeURIComponent(address)}`;\n}\n\n/**\n * Map a raw API ticket status/state to our TicketStatus union.\n */\nfunction mapTicketStatus(ticket: any): TicketStatus {\n const now = new Date();\n const remaining =\n ticket.remainingCapacity ??\n ticket.quantityRemaining ??\n ticket.quantity ??\n 0;\n const salesBegin =\n ticket.salesBegin ||\n ticket.salesStart ||\n ticket.saleBegin ||\n ticket.onSaleStart;\n const salesEnd = ticket.salesEnd || ticket.saleEnd || ticket.onSaleEnd;\n\n if (remaining <= 0) return 'sold_out';\n if (salesEnd && new Date(salesEnd) < now) return 'sales_ended';\n if (salesBegin && new Date(salesBegin) > now) return 'coming_soon';\n return 'on_sale';\n}\n\n/**\n * Map a raw API event status string to our EventStatus union.\n */\nfunction mapEventStatus(\n rawStatus: string,\n tickets: TicketTypeData[]\n): EventStatus {\n const s = (rawStatus || '').toLowerCase().replace(/\\s+/g, '_');\n\n if (s === 'cancelled' || s === 'canceled') return 'cancelled';\n\n // Check if event is past based on end time (handled by caller if needed)\n if (s === 'past' || s === 'ended') return 'past';\n\n // MIC-1039: if any hidden ticket is still on sale, the event is \"on_sale\"\n // regardless of visible-ticket states — the user just needs a promo code.\n const hasPurchasableHiddenTickets = tickets.some(\n t => t.isHidden && t.status === 'on_sale'\n );\n if (hasPurchasableHiddenTickets) return 'on_sale';\n\n // Derive from ticket states\n const publicTickets = tickets.filter(t => !t.isHidden);\n if (publicTickets.length > 0) {\n if (publicTickets.every(t => t.status === 'sold_out')) return 'sold_out';\n if (publicTickets.every(t => t.status === 'coming_soon'))\n return 'coming_soon';\n if (\n publicTickets.every(\n t => t.status === 'sales_ended' || t.status === 'sold_out'\n )\n )\n return 'sales_ended';\n }\n\n if (s === 'sold_out' || s === 'soldout') return 'sold_out';\n if (s === 'coming_soon' || s === 'comingsoon') return 'coming_soon';\n if (s === 'sales_ended' || s === 'salesended') return 'sales_ended';\n\n return 'on_sale';\n}\n\n/**\n * Transform a raw API event response into our clean EventData interface.\n * This is the bridge between the API and our premium ticket experience components.\n */\nexport function transformApiEvent(rawEvent: any): EventData {\n const rawVenue = rawEvent.venue || {};\n // Event-level timeZone is an OPTIONAL per-event override; when absent/blank it\n // must inherit the venue timezone. Falling straight to 'UTC' here rendered\n // venue-local times (e.g. a Fri 10pm Central show) in UTC (\"Sat 3:00 AM\"),\n // which made already-ended events look like future ones.\n const timezone = getIANATimezone(\n rawEvent.timeZone ||\n rawEvent.timezone ||\n rawVenue.timeZone ||\n rawVenue.timezone ||\n 'UTC'\n );\n\n // Transform tickets\n const rawTickets = rawEvent.availableTickets || [];\n const tickets: TicketTypeData[] = rawTickets.map((t: any) => ({\n id: t.id || t.ID,\n name: t.name || t.title || '',\n description: t.description || undefined,\n price: t.price ?? 0,\n fee: t.fee ?? 0,\n quantityAvailable:\n t.remainingCapacity ?? t.quantityRemaining ?? t.quantity ?? 0,\n quantityTotal: t.totalCapacity ?? t.quantity ?? 0,\n minPerOrder: t.minPerOrder ?? t.minQuantity ?? 1,\n maxPerOrder: t.maxPerOrder ?? t.maxQuantity ?? 10,\n status: mapTicketStatus(t),\n salesStartDate:\n t.salesBegin || t.salesStart || t.saleBegin || t.onSaleStart || undefined,\n salesEndDate: t.salesEnd || t.saleEnd || t.onSaleEnd || undefined,\n isDonation: t.type === 2 || t.ticketType === 2 || t.isDonation === true,\n isHidden: t.visibility === 2 || t.isHidden === true,\n ticketType: t.type || t.ticketType || undefined,\n sectionName: t.sectionName || t.section || undefined,\n }));\n\n // Calculate totals from public tickets\n const publicTickets = tickets.filter(t => !t.isHidden && !t.isDonation);\n const totalRemaining = publicTickets.reduce(\n (sum, t) => sum + t.quantityAvailable,\n 0\n );\n const totalCapacity = publicTickets.reduce(\n (sum, t) => sum + t.quantityTotal,\n 0\n );\n\n // Determine event status\n const status = mapEventStatus(rawEvent.status, tickets);\n\n // Build image URL\n const rawImage =\n rawEvent.image || rawEvent.imageUrl || rawEvent.image_url || '';\n const imageUrl = rawImage.startsWith('http')\n ? rawImage\n : getImageUrl(rawImage);\n\n // Venue\n const venue: VenueData = {\n id: rawVenue.id || rawVenue.ID || 0,\n name: rawVenue.name || rawVenue.googleLocationNameCache || '',\n address: rawVenue.address || rawVenue.googleLocationNameCache || '',\n timezone,\n serviceFeePercentage: rawVenue.serviceFeePercentage ?? rawVenue.fee ?? 0,\n serviceFeeCents: rawVenue.serviceFeeCents ?? 0,\n taxPercentage: rawVenue.taxPercentage ?? rawVenue.tax ?? 0,\n contactEmail: rawVenue.contactEmail || rawVenue.email || undefined,\n };\n\n // Performers\n const rawPerformers = rawEvent.performers || [];\n const performers: PerformerData[] = rawPerformers.map((p: any) => ({\n id: p.id || p.ID,\n displayName: p.displayName || p.name || '',\n profileImage: p.avatar || p.profileImage || undefined,\n role: p.role || undefined,\n }));\n\n // FAQs (may not be in API response)\n const faqs: FAQItem[] = (rawEvent.faqs || []).map((f: any) => ({\n question: f.question || '',\n answer: f.answer || '',\n }));\n\n // Date in venue timezone\n let date = '';\n if (rawEvent.startDateTime) {\n const dt = new Date(rawEvent.startDateTime);\n date = formatDateRaw(\n dt,\n { timeZone: timezone, year: 'numeric', month: '2-digit', day: '2-digit' },\n 'en-CA'\n );\n }\n\n return {\n id: rawEvent.id || rawEvent.ID,\n title: rawEvent.title || rawEvent.name || '',\n slug: rawEvent.slug || '',\n description: rawEvent.description || rawEvent.eventSummary || '',\n date,\n startDateTime: rawEvent.startDateTime || '',\n endDateTime: rawEvent.endDateTime || '',\n doorsOpenTime: rawEvent.doorsOpenTime || '',\n timezone,\n imageUrl,\n venue,\n performers,\n tickets,\n faqs,\n disclaimer: rawEvent.disclaimer || undefined,\n status,\n eventSeriesId: rawEvent.eventSeriesId || undefined,\n // Public API hides the actual password (json:\"-\") and exposes a boolean\n // `hasPassword` flag instead; fall back to a populated `password` for\n // admin-shaped payloads.\n isPasswordProtected: rawEvent.hasPassword === true || !!rawEvent.password,\n isRegistrationEvent:\n rawEvent.ticketType === 1 || rawEvent.eventTicketingType === 1,\n totalTicketsRemaining: totalRemaining,\n totalTicketsCapacity: totalCapacity,\n stageName: rawEvent.stage?.name || rawEvent.stageName || undefined,\n ageRestriction: rawEvent.ageRestriction || undefined,\n displayAgeRestriction: rawEvent.displayAgeRestriction ?? false,\n displayStartTime: rawEvent.displayStartTime ?? true,\n displayEndTime: rawEvent.displayEndTime ?? true,\n displayDoorsTime: rawEvent.displayDoorsTime ?? true,\n collectionId: rawEvent.collectionId || rawEvent.collection_id || undefined,\n venueAddressLines: parseAddress(\n rawVenue.address || rawVenue.googleLocationNameCache || ''\n ),\n googleMapsUrl: buildGoogleMapsUrl(\n rawVenue.address || rawVenue.googleLocationNameCache || ''\n ),\n };\n}\n\n/**\n * Transform SeriesPageData (from the series API) into our clean EventData interface.\n * Sets eventSeriesId so AirbnbSplitMain renders in full-width series mode.\n */\nexport function transformSeriesPageData(series: SeriesPageData): EventData {\n const timezone = getIANATimezone(series.timeZone || 'UTC');\n\n // Build image URL\n const rawImage = series.image || '';\n const imageUrl = rawImage.startsWith('http')\n ? rawImage\n : rawImage\n ? getImageUrl(rawImage)\n : '';\n\n // Map occurrences to SeriesOccurrence[]\n const seriesOccurrences: SeriesOccurrence[] = (series.occurrences || []).map(\n occ => ({\n id: occ.id,\n slug: occ.slug || '',\n startDateTime: occ.startDateTime,\n endDateTime: occ.endDateTime || '',\n status: (occ.ctaState?.reason === 'sold_out'\n ? 'sold_out'\n : 'on_sale') as EventStatus,\n ctaText: occ.ctaState?.text || 'Get Tickets',\n ctaDisabled: occ.ctaState?.disabled || false,\n })\n );\n\n // Use first occurrence for date fields\n const firstOcc = series.occurrences?.[0];\n let date = '';\n if (firstOcc?.startDateTime) {\n const dt = new Date(firstOcc.startDateTime);\n date = formatDateRaw(\n dt,\n { timeZone: timezone, year: 'numeric', month: '2-digit', day: '2-digit' },\n 'en-CA'\n );\n }\n\n // Map FAQs\n const rawFaq = series.venue?.faq;\n let faqs: FAQItem[] = [];\n if (Array.isArray(rawFaq)) {\n faqs = rawFaq.map(f => ({\n question: f.question || '',\n answer: f.answer || '',\n }));\n } else if (typeof rawFaq === 'string' && rawFaq) {\n faqs = [{ question: 'FAQ', answer: rawFaq }];\n }\n\n // Map performers\n const performers: PerformerData[] = (series.performers || []).map(\n (p, index) => ({\n id: index + 1,\n displayName:\n p.displayName || [p.firstName, p.lastName].filter(Boolean).join(' '),\n profileImage: p.profileImage || undefined,\n })\n );\n\n // Venue address\n const venueAddress =\n series.venue?.location || series.venue?.googleLocationNameCache || '';\n\n return {\n id: series.id,\n title: series.title || '',\n slug: '',\n description: series.description || series.eventSummary || '',\n date,\n startDateTime: firstOcc?.startDateTime || '',\n endDateTime: firstOcc?.endDateTime || '',\n doorsOpenTime: '',\n timezone,\n imageUrl,\n venue: {\n id: series.venue?.id || 0,\n name: series.venue?.name || '',\n address: venueAddress,\n timezone,\n serviceFeePercentage: 0,\n serviceFeeCents: 0,\n taxPercentage: 0,\n },\n performers,\n tickets: [],\n faqs,\n disclaimer: series.venue?.disclaimer || undefined,\n status: 'on_sale',\n eventSeriesId: series.id,\n seriesOccurrences,\n isPasswordProtected: false,\n isRegistrationEvent: false,\n totalTicketsRemaining: 0,\n totalTicketsCapacity: 0,\n venueAddressLines: parseAddress(venueAddress),\n googleMapsUrl: buildGoogleMapsUrl(venueAddress),\n };\n}\n\n/**\n * Transform PublicCollectionData (from the collection API) into our clean EventData interface.\n * Sets collectionId so AirbnbSplitMain renders in full-width collection mode.\n */\nexport function transformCollectionData(\n collection: PublicCollectionData\n): EventData {\n // Map collection events to CollectionEvent[]\n const collectionEvents: CollectionEvent[] = (collection.events || []).map(\n ev => {\n const rawImg = ev.image || '';\n return {\n id: ev.id,\n name: ev.title || '',\n slug: ev.slug || '',\n image: rawImg.startsWith('http')\n ? rawImg\n : rawImg\n ? getImageUrl(rawImg)\n : '',\n startDateTime: ev.startDateTime || '',\n status: (ev.status || 'on_sale') as EventStatus,\n };\n }\n );\n\n // Cover image\n const rawCover = collection.coverImage || '';\n const imageUrl = rawCover.startsWith('http')\n ? rawCover\n : rawCover\n ? getImageUrl(rawCover)\n : '';\n\n return {\n id: collection.id,\n title: collection.collectionTitle || '',\n slug: '',\n description: collection.description || collection.summary || '',\n date: '',\n startDateTime: '',\n endDateTime: '',\n doorsOpenTime: '',\n timezone: 'UTC',\n imageUrl,\n venue: {\n id: 0,\n name: '',\n address: '',\n timezone: 'UTC',\n serviceFeePercentage: 0,\n serviceFeeCents: 0,\n taxPercentage: 0,\n },\n performers: [],\n tickets: [],\n faqs: [],\n status: 'on_sale',\n collectionId: collection.id,\n collectionEvents,\n isPasswordProtected: false,\n isRegistrationEvent: false,\n totalTicketsRemaining: 0,\n totalTicketsCapacity: 0,\n };\n}\n"],"names":["parseAddress","addressStr","parts","p","stateZipMatch","state","zip","city","lines","buildGoogleMapsUrl","address","mapTicketStatus","ticket","now","remaining","salesBegin","salesEnd","mapEventStatus","rawStatus","tickets","s","t","publicTickets","transformApiEvent","rawEvent","rawVenue","timezone","getIANATimezone","totalRemaining","sum","totalCapacity","status","rawImage","imageUrl","getImageUrl","venue","performers","faqs","f","date","dt","formatDateRaw","transformSeriesPageData","series","seriesOccurrences","occ","firstOcc","rawFaq","index","venueAddress","transformCollectionData","collection","collectionEvents","ev","rawImg","rawCover"],"mappings":"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"}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -159,15 +159,23 @@ export interface CalendarProps extends BaseInitOptions {
|
|
|
159
159
|
}
|
|
160
160
|
|
|
161
161
|
/**
|
|
162
|
-
* Options for initializing the Event
|
|
163
|
-
*/
|
|
164
|
-
export interface
|
|
165
|
-
/** The event ID to display */
|
|
166
|
-
eventId
|
|
167
|
-
/**
|
|
162
|
+
* Options for initializing the (inline) Event Page.
|
|
163
|
+
*/
|
|
164
|
+
export interface EventPageOptions extends BaseInitOptions {
|
|
165
|
+
/** The event ID to display (the page self-fetches), or pass rawEvent. */
|
|
166
|
+
eventId?: string | number;
|
|
167
|
+
/** Pre-fetched raw event payload (skips the self-fetch). */
|
|
168
|
+
rawEvent?: any;
|
|
169
|
+
/** Event slug (cosmetic). */
|
|
170
|
+
slug?: string;
|
|
171
|
+
/** Callback when the back control is clicked. */
|
|
168
172
|
onNavigateBack?: () => void;
|
|
169
|
-
/** Callback when
|
|
170
|
-
onNavigateToCart?: (
|
|
173
|
+
/** Callback when proceeding to checkout (cart already created). */
|
|
174
|
+
onNavigateToCart?: (id: string | number, slug: string, rawEvent: any) => void;
|
|
175
|
+
/** Callback when a series occurrence is clicked. */
|
|
176
|
+
onBuyTickets?: (eventId: string | number, slug: string) => void;
|
|
177
|
+
/** i18n label overrides. */
|
|
178
|
+
labels?: Record<string, string>;
|
|
171
179
|
}
|
|
172
180
|
|
|
173
181
|
/**
|
|
@@ -238,11 +246,11 @@ export interface SvelteComponentInstance {
|
|
|
238
246
|
export function initVenueCalendar(options: CalendarProps): SvelteComponentInstance | null;
|
|
239
247
|
|
|
240
248
|
/**
|
|
241
|
-
* Initialize the Event
|
|
249
|
+
* Initialize the (inline) Event Page.
|
|
242
250
|
* @param options - Configuration options
|
|
243
|
-
* @returns The Svelte component instance, or null if target not found
|
|
251
|
+
* @returns The Svelte component instance, or null if target not found / no event
|
|
244
252
|
*/
|
|
245
|
-
export function
|
|
253
|
+
export function initEventPage(options: EventPageOptions): SvelteComponentInstance | null;
|
|
246
254
|
|
|
247
255
|
/**
|
|
248
256
|
* Initialize the Checkout View
|
|
@@ -320,10 +328,6 @@ export function generateThemeCSS(theme: Partial<ThemeColors>): string;
|
|
|
320
328
|
*/
|
|
321
329
|
export const VenueCalendar: any;
|
|
322
330
|
|
|
323
|
-
/**
|
|
324
|
-
* EventDetailsView Svelte component
|
|
325
|
-
*/
|
|
326
|
-
export const EventDetailsView: any;
|
|
327
331
|
|
|
328
332
|
/**
|
|
329
333
|
* Checkout Svelte component
|
|
@@ -366,7 +370,7 @@ export const CollectionView: any;
|
|
|
366
370
|
|
|
367
371
|
declare const _default: {
|
|
368
372
|
initVenueCalendar: typeof initVenueCalendar;
|
|
369
|
-
|
|
373
|
+
initEventPage: typeof initEventPage;
|
|
370
374
|
initCheckoutView: typeof initCheckoutView;
|
|
371
375
|
initCheckout: typeof initCheckoutView;
|
|
372
376
|
initSuccessView: typeof initSuccessView;
|
|
@@ -379,7 +383,6 @@ declare const _default: {
|
|
|
379
383
|
highContrastTheme: ThemeColors;
|
|
380
384
|
applyTheme: typeof applyTheme;
|
|
381
385
|
generateThemeCSS: typeof generateThemeCSS;
|
|
382
|
-
EventDetailsView: any;
|
|
383
386
|
Checkout: any;
|
|
384
387
|
CheckoutView: any;
|
|
385
388
|
Success: any;
|