@getmicdrop/venue-calendar 4.0.83 → 4.0.84

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/dist/{CartView-DBrUqLSR.js → CartView-DwAGELwG.js} +5 -5
  2. package/dist/{CartView-DBrUqLSR.js.map → CartView-DwAGELwG.js.map} +1 -1
  3. package/dist/{Checkout-BAtOdBIM.js → Checkout-CHo11MsU.js} +7 -7
  4. package/dist/{Checkout-BAtOdBIM.js.map → Checkout-CHo11MsU.js.map} +1 -1
  5. package/dist/{Checkout-BEcmGOZm.js → Checkout-_NuoBAKt.js} +3 -3
  6. package/dist/{Checkout-BEcmGOZm.js.map → Checkout-_NuoBAKt.js.map} +1 -1
  7. package/dist/{CheckoutTimer-CayvrAa9.js → CheckoutTimer-CAGR7L-7.js} +4 -4
  8. package/dist/{CheckoutTimer-CayvrAa9.js.map → CheckoutTimer-CAGR7L-7.js.map} +1 -1
  9. package/dist/{CollectionView-kk90OMFq.js → CollectionView-Dstgu8sR.js} +5 -5
  10. package/dist/{CollectionView-kk90OMFq.js.map → CollectionView-Dstgu8sR.js.map} +1 -1
  11. package/dist/{Event-N959l6uT.js → Event-kfRjkMzQ.js} +1125 -1125
  12. package/dist/Event-kfRjkMzQ.js.map +1 -0
  13. package/dist/{EventPage-DaEMiLjY.js → EventPage-CnhccVCI.js} +7 -7
  14. package/dist/{EventPage-DaEMiLjY.js.map → EventPage-CnhccVCI.js.map} +1 -1
  15. package/dist/{Heading-A_nixT3L.js → Heading-Ielp7dS-.js} +2 -2
  16. package/dist/{Heading-A_nixT3L.js.map → Heading-Ielp7dS-.js.map} +1 -1
  17. package/dist/{ModalHeader-CxMVzApa.js → ModalHeader-Q7levd4l.js} +2 -2
  18. package/dist/{ModalHeader-CxMVzApa.js.map → ModalHeader-Q7levd4l.js.map} +1 -1
  19. package/dist/{ScarcityBadge-CiF-JsPl.js → ScarcityBadge-CG7Mz5YN.js} +2 -2
  20. package/dist/{ScarcityBadge-CiF-JsPl.js.map → ScarcityBadge-CG7Mz5YN.js.map} +1 -1
  21. package/dist/{SeriesPage-CQJHrpTH.js → SeriesPage-C8fIvt63.js} +5 -5
  22. package/dist/{SeriesPage-CQJHrpTH.js.map → SeriesPage-C8fIvt63.js.map} +1 -1
  23. package/dist/{Success-R-1NhLjx.js → Success-SZNXo-Ou.js} +7 -7
  24. package/dist/{Success-R-1NhLjx.js.map → Success-SZNXo-Ou.js.map} +1 -1
  25. package/dist/{Text-F6D2QvI6.js → Text-DHgQP4rA.js} +2 -2
  26. package/dist/{Text-F6D2QvI6.js.map → Text-DHgQP4rA.js.map} +1 -1
  27. package/dist/{VenueCalendar-DdRkxjxd.js → VenueCalendar-DTOyAhDU.js} +444 -445
  28. package/dist/VenueCalendar-DTOyAhDU.js.map +1 -0
  29. package/dist/{ViewTicketsEmbed-BwvS8VgE.js → ViewTicketsEmbed-DBEOjijY.js} +4 -4
  30. package/dist/{ViewTicketsEmbed-BwvS8VgE.js.map → ViewTicketsEmbed-DBEOjijY.js.map} +1 -1
  31. package/dist/{data-toggle-store.svelte-D9XyVwDW.js → data-toggle-store.svelte-E2JyoGTV.js} +2 -2
  32. package/dist/{data-toggle-store.svelte-D9XyVwDW.js.map → data-toggle-store.svelte-E2JyoGTV.js.map} +1 -1
  33. package/dist/{labels-DG5wh_vD.js → labels-nQIooadc.js} +3 -3
  34. package/dist/{labels-DG5wh_vD.js.map → labels-nQIooadc.js.map} +1 -1
  35. package/dist/seo/seo.cjs.map +1 -1
  36. package/dist/seo/seo.mjs.map +1 -1
  37. package/dist/{transform-C5S2acqv.js → transform-C1Rmuzlt.js} +2 -2
  38. package/dist/{transform-C5S2acqv.js.map → transform-C1Rmuzlt.js.map} +1 -1
  39. package/dist/venue-calendar.css +1 -1
  40. package/dist/venue-calendar.es.js +2 -2
  41. package/dist/venue-calendar.iife.js +11 -11
  42. package/dist/venue-calendar.iife.js.map +1 -1
  43. package/dist/venue-calendar.umd.js +10 -10
  44. package/dist/venue-calendar.umd.js.map +1 -1
  45. package/package.json +3 -4
  46. package/dist/Event-N959l6uT.js.map +0 -1
  47. package/dist/VenueCalendar-DdRkxjxd.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Success-R-1NhLjx.js","sources":["../src/lib/public-calendar-flow/SuccessTicket.svelte","../src/lib/public-calendar-flow/SuccessActions.svelte","../src/lib/public-calendar-flow/Success.svelte","../src/components/Views/Success.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n\timport { Email } from 'carbon-icons-svelte';\r\n\timport { Card, Heading, Text } from '@getmicdrop/svelte-components';\r\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport OrderSummary from './OrderSummary.svelte';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\torderTotals: OrderTotals;\r\n\t\tcustomerEmail: string;\r\n\t\tshowCheckmark: boolean;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tevent, orderId, orderTotals, customerEmail, showCheckmark, showContent, labels = {},\r\n\t}: Props = $props();\r\n\r\n\tlet ticketCount = $derived(orderTotals.lines.reduce((sum, l) => sum + l.quantity, 0));\r\n\r\n\tlet headingText = $derived(\r\n\t\tevent.isRegistrationEvent ? (labels.youreRegistered || \"You're registered!\") : (labels.youreIn || \"You're in!\")\r\n\t);\r\n\r\n</script>\r\n\r\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-primary\">\r\n\t<div class=\"p-6 md:p-8\">\r\n\t\t<!-- Spinner → Checkmark animation -->\r\n\t\t<div class=\"flex justify-center mb-6\">\r\n\t\t\t<div class=\"indicator-container\">\r\n\t\t\t\t<!-- Spinner (visible while loading) -->\r\n\t\t\t\t<div class=\"processing-spinner\" class:fade-out={showCheckmark}></div>\r\n\r\n\t\t\t\t<!-- Animated checkmark (appears after spinner) -->\r\n\t\t\t\t<svg class=\"checkmark-svg\" class:active={showCheckmark} viewBox=\"0 0 52 52\" aria-hidden=\"true\">\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-circle\" />\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-fill\" />\r\n\t\t\t\t\t<path d=\"M14 27l7 7 17-17\" class=\"checkmark-check\" />\r\n\t\t\t\t</svg>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- Content (fades in after checkmark completes) -->\r\n\t\t<div class=\"content-section\" class:visible={showContent}>\r\n\t\t\t<!-- Heading -->\r\n\t\t\t<!-- TODO: swap back to <Stack gap=\"3\"> once SC's root index.js exports Stack\r\n\t\t\t (the `export *` re-export of primitives doesn't surface it, so\r\n\t\t\t `import { Stack }` fails to resolve). flex-col gap-3 is equivalent. -->\r\n\t\t\t<div class=\"flex flex-col gap-3 text-center mb-6\">\r\n\t\t\t\t<Heading level={1} size=\"xl\" weight=\"bold\">\r\n\t\t\t\t\t{headingText}\r\n\t\t\t\t</Heading>\r\n\t\t\t\t<Text size=\"lg\" class=\"font-semibold block\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"secondary\" class=\"block\">\r\n\t\t\t\t\t{ticketCount} {ticketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} confirmed\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order summary (same format as checkout) -->\r\n\t\t\t<div class=\"mb-6\">\r\n\t\t\t\t<OrderSummary {orderTotals}\r\n\t\t\t\t{labels} />\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order info -->\r\n\t\t\t<div class=\"flex justify-between items-center py-3 border-t border-default\">\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold font-mono\">#{orderId}</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Email confirmation -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-2 p-3 rounded-lg bg-surface-secondary mt-4\">\r\n\t\t\t\t<Email size={16} class=\"shrink-0 text-color-muted\" />\r\n\t\t\t\t<Text size=\"xs\" color=\"secondary\">\r\n\t\t\t\t\t{labels.confirmationSentTo || 'Confirmation sent to'} {customerEmail}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t</div>\r\n\t</div>\r\n</Card>\r\n\r\n<style>\r\n\t/* Indicator container — holds spinner and checkmark in same space */\r\n\t.indicator-container {\r\n\t\tposition: relative;\r\n\t\twidth: 64px;\r\n\t\theight: 64px;\r\n\t}\r\n\r\n\t/* Spinner — rotating partial circle */\r\n\t.processing-spinner {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\tborder: 3px solid hsl(var(--stroke-primary) / 15%);\r\n\t\tborder-top-color: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tborder-radius: 50%;\r\n\t\tanimation: spin 0.7s linear infinite;\r\n\t\ttransition: opacity 0.2s ease;\r\n\t}\r\n\r\n\t.processing-spinner.fade-out {\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t@keyframes spin {\r\n\t\tto { transform: rotate(360deg); }\r\n\t}\r\n\r\n\t/* Checkmark SVG — scales in when active */\r\n\t.checkmark-svg {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\t\topacity: 0;\r\n\t\ttransform: scale(0.6);\r\n\t\ttransition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);\r\n\t}\r\n\r\n\t.checkmark-svg.active {\r\n\t\topacity: 1;\r\n\t\ttransform: scale(1);\r\n\t}\r\n\r\n\t/* Circle outline — draws itself */\r\n\t.checkmark-circle {\r\n\t\tstroke-dasharray: 151;\r\n\t\tstroke-dashoffset: 151;\r\n\t\tstroke-width: 2;\r\n\t\tstroke: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tfill: none;\r\n\t\ttransform-origin: center;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-circle {\r\n\t\tanimation: circle-draw 0.5s ease-out 0.1s forwards;\r\n\t}\r\n\r\n\t@keyframes circle-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Circle fill — fades in after outline completes */\r\n\t.checkmark-fill {\r\n\t\tfill: hsl(var(--accent-success, 142 71% 45%));\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-fill {\r\n\t\tanimation: fill-in 0.25s ease-out 0.5s forwards;\r\n\t}\r\n\r\n\t@keyframes fill-in {\r\n\t\tto { opacity: 1; }\r\n\t}\r\n\r\n\t/* Checkmark stroke — draws after fill */\r\n\t.checkmark-check {\r\n\t\tstroke-dasharray: 36;\r\n\t\tstroke-dashoffset: 36;\r\n\t\tstroke-width: 3;\r\n\t\tstroke: hsl(var(--bg-primary));\r\n\t\tfill: none;\r\n\t\tstroke-linecap: round;\r\n\t\tstroke-linejoin: round;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-check {\r\n\t\tanimation: check-draw 0.3s ease-out 0.6s forwards;\r\n\t}\r\n\r\n\t@keyframes check-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Content section — fades in after checkmark */\r\n\t.content-section {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.content-section.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.processing-spinner {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg .checkmark-circle,\r\n\t\t.checkmark-svg .checkmark-fill,\r\n\t\t.checkmark-svg .checkmark-check {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t\tanimation-delay: 0s;\r\n\t\t}\r\n\r\n\t\t.content-section {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>\r\n","<!-- native-element-exception: VC is an embeddable widget — native <button>s are intentional here (widget-controlled styling on calendar cells, date selectors, checkout/nav CTAs). -->\r\n<script lang=\"ts\">\r\n\timport { onMount } from 'svelte';\r\n\timport {\r\n\t\tShare,\r\n\t\tHelp,\r\n\t\tArrowLeft,\r\n\t\tApple,\r\n\t\tCalendar,\r\n\t\tChevronDown,\r\n\t\tLocationFilled,\r\n\t} from 'carbon-icons-svelte';\r\n\timport { Button, Card, Image, Text } from '@getmicdrop/svelte-components';\r\n\timport { toast } from '@getmicdrop/svelte-components/toast';\r\n\timport type { EventData } from '$lib/public-calendar-flow/types';\r\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n\timport { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\teventUrl: string;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { event, orderId, eventUrl, showContent, labels = {} }: Props = $props();\r\n\r\n\t// --- Calendar dropdown ---\r\n\tlet calendarOpen = $state(false);\r\n\r\n\tfunction toggleCalendar() {\r\n\t\tcalendarOpen = !calendarOpen;\r\n\t}\r\n\r\n\t// Close calendar dropdown when clicking outside\r\n\tonMount(() => {\r\n\t\tfunction handleClickOutside(e: MouseEvent) {\r\n\t\t\tconst target = e.target as HTMLElement;\r\n\t\t\tif (!target.closest('.calendar-dropdown')) {\r\n\t\t\t\tcalendarOpen = false;\r\n\t\t\t}\r\n\t\t}\r\n\t\tdocument.addEventListener('click', handleClickOutside);\r\n\t\treturn () => document.removeEventListener('click', handleClickOutside);\r\n\t});\r\n\r\n\t// --- Google Calendar URL ---\r\n\tlet googleCalendarUrl = $derived((() => {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForGoogle = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst params = new URLSearchParams({\r\n\t\t\taction: 'TEMPLATE',\r\n\t\t\ttext: event.title,\r\n\t\t\tdates: `${formatForGoogle(startDate)}/${formatForGoogle(endDate)}`,\r\n\t\t\tlocation: fullLocation,\r\n\t\t\tdetails: `Event: ${eventUrl}\\n\\nTicket confirmation #${orderId}`\r\n\t\t});\r\n\r\n\t\treturn `https://calendar.google.com/calendar/render?${params.toString()}`;\r\n\t})());\r\n\r\n\t// --- ICS file download (Apple Calendar) ---\r\n\tfunction downloadICS() {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForICS = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst uid = `order-${orderId}-event-${event.id}@micdrop.com`;\r\n\t\tconst now = formatForICS(new Date());\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst escapeICS = (str: string): string => {\r\n\t\t\tif (!str) return '';\r\n\t\t\treturn str.replace(/\\\\/g, '\\\\\\\\').replace(/;/g, '\\\\;').replace(/,/g, '\\\\,').replace(/\\n/g, '\\\\n');\r\n\t\t};\r\n\r\n\t\tconst icsContent = `BEGIN:VCALENDAR\r\nVERSION:2.0\r\nPRODID:-//MicDrop//Ticket Confirmation//EN\r\nCALSCALE:GREGORIAN\r\nMETHOD:PUBLISH\r\nBEGIN:VEVENT\r\nUID:${uid}\r\nDTSTAMP:${now}\r\nDTSTART:${formatForICS(startDate)}\r\nDTEND:${formatForICS(endDate)}\r\nSUMMARY:${escapeICS(event.title)}\r\nLOCATION:${escapeICS(fullLocation)}\r\nDESCRIPTION:${escapeICS(`Order #${orderId}\\n\\nView event: ${eventUrl}`)}\r\nURL:${eventUrl}\r\nSTATUS:CONFIRMED\r\nEND:VEVENT\r\nEND:VCALENDAR`;\r\n\r\n\t\tconst blob = new Blob([icsContent], { type: 'text/calendar;charset=utf-8' });\r\n\t\t// @image-handling-escape: programmatic blob-URL download (export/.ics) — SC Image canonical cannot express in-memory-blob → browser-download\r\n\t\tconst url = URL.createObjectURL(blob);\r\n\t\tconst link = document.createElement('a');\r\n\t\tlink.href = url;\r\n\t\tconst safeFilename = (event.title || 'event').replace(/[^a-zA-Z0-9\\s-]/g, '').replace(/\\s+/g, '-');\r\n\t\tlink.download = `${safeFilename}.ics`;\r\n\t\tdocument.body.appendChild(link);\r\n\t\tlink.click();\r\n\t\tdocument.body.removeChild(link);\r\n\t\tURL.revokeObjectURL(url);\r\n\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\tfunction handleGoogleCalendar() {\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\t// --- Share event ---\r\n\tasync function shareEvent() {\r\n\t\tconst shareData = { url: eventUrl };\r\n\r\n\t\tif (navigator.share) {\r\n\t\t\ttry {\r\n\t\t\t\tawait navigator.share(shareData);\r\n\t\t\t} catch (err: unknown) {\r\n\t\t\t\tif (err instanceof Error && err.name !== 'AbortError') {\r\n\t\t\t\t\tfallbackShare();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tfallbackShare();\r\n\t\t}\r\n\t}\r\n\r\n\tfunction fallbackShare() {\r\n\t\tnavigator.clipboard.writeText(eventUrl).then(() => {\r\n\t\t\ttoast.success(labels.linkCopied || 'Link copied to clipboard!');\r\n\t\t}).catch(() => {\r\n\t\t\ttoast.error(labels.copyLink || 'Could not copy link — please copy it manually: ' + eventUrl);\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Wallet handlers (mock — requires backend in production) ---\r\n\tfunction handleAppleWallet() {\r\n\t\ttoast.info('Apple Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\tfunction handleGoogleWallet() {\r\n\t\ttoast.info('Google Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Directions ---\r\n\tlet directionsUrl = $derived((() => {\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst query = encodeURIComponent(locationParts.join(', '));\r\n\t\treturn `https://www.google.com/maps/search/?api=1&query=${query}`;\r\n\t})());\r\n\r\n\t// --- Navigation ---\r\n\tfunction handleBackToEvent() {\r\n\t\twindow.location.href = eventUrl;\r\n\t}\r\n</script>\r\n\r\n<!--\r\n\tSuccessActions: Sidebar card matching BookingWidget / CheckoutSidebar pattern.\r\n\tSingle Card with event thumbnail, date summary, wallet badges, action buttons, and links.\r\n-->\r\n<div class=\"actions-wrapper\" class:visible={showContent}>\r\n\t<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\r\n\t\t<!-- Event poster (same treatment as HeroImage — object-contain, no crop) -->\r\n\t\t<div class=\"rounded-t-xl overflow-hidden bg-surface-tertiary\">\r\n\t\t\t<Image\r\n\t\t\t\tsrc={event.imageUrl}\r\n\t\t\t\talt={event.title}\r\n\t\t\t\tfallback={PLACEHOLDER_IMAGE}\r\n\t\t\t\tfit=\"contain\"\r\n\t\t\t\tclass=\"w-full max-h-60 min-h-24\"\r\n\t\t\t/>\r\n\t\t</div>\r\n\r\n\t\t<div class=\"p-5 space-y-4\">\r\n\t\t\t<!-- Event info -->\r\n\t\t\t<div>\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1.5\">\r\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\r\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\r\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{/if}\r\n\t\t\t\t\t</Text>\r\n\t\t\t\t</div>\r\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n\t\t\t\t\t{event.venue.name}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Wallet badges (official brand assets) -->\r\n\t\t\t<div class=\"flex flex-col items-center gap-3\">\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleAppleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/apple-wallet.svg\"\r\n\t\t\t\t\t\talt={labels.addToAppleWallet || 'Add to Apple Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleGoogleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-dark.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-dark\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-light.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-light\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Divider -->\r\n\t\t\t<div class=\"divider\"></div>\r\n\r\n\t\t\t<!-- Calendar dropdown (full width) -->\r\n\t\t\t<div class=\"calendar-dropdown relative\">\r\n\t\t\t\t<Button\r\n\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\tclass=\"w-full\"\r\n\t\t\t\t\tonclick={toggleCalendar}\r\n\t\t\t\t>\r\n\t\t\t\t\t<Calendar size={16} />\r\n\t\t\t\t\t{labels.addToCalendar || 'Add to Calendar'}\r\n\t\t\t\t\t<ChevronDown size={16} class=\"ml-auto transition-transform {calendarOpen ? 'rotate-180' : ''}\" />\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if calendarOpen}\r\n\t\t\t\t\t<div class=\"dropdown-menu bg-surface-primary border-default\">\r\n\t\t\t\t\t\t<a\r\n\t\t\t\t\t\t\thref={googleCalendarUrl}\r\n\t\t\t\t\t\t\trel=\"noopener noreferrer\"\r\n\t\t\t\t\t\t\tclass=\"dropdown-item text-color-primary hover:bg-surface-secondary\"\r\n\t\t\t\t\t\t\tonclick={handleGoogleCalendar}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<svg aria-hidden=\"true\" class=\"shrink-0\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n\t\t\t\t\t\t\t\t<path d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92a5.06 5.06 0 0 1-2.2 3.32v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.1z\" fill=\"#4285F4\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\" fill=\"#34A853\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18A10.96 10.96 0 0 0 1 12c0 1.77.42 3.45 1.18 4.93l3.66-2.84z\" fill=\"#FBBC05\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\" fill=\"#EA4335\"/>\r\n\t\t\t\t\t\t\t</svg>\r\n\t\t\t\t\t\t\t{labels.googleCalendar || 'Google Calendar'}\r\n\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t<button type=\"button\" class=\"dropdown-item text-color-primary hover:bg-surface-secondary\" onclick={downloadICS}>\r\n\t\t\t\t\t\t\t<Apple size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t\t{labels.appleCalendar || 'Apple Calendar (.ics)'}\r\n\t\t\t\t\t\t</button>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Share + Directions row -->\r\n\t\t\t<div class=\"flex gap-2\">\r\n\t\t\t\t<Button variant=\"default\" size=\"md\" class=\"flex-1\" onclick={shareEvent}>\r\n\t\t\t\t\t<Share size={16} />\r\n\t\t\t\t\t{labels.share || 'Share'}\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if event.venue.address}\r\n\t\t\t\t\t<Button\r\n\t\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\t\tclass=\"flex-1\"\r\n\t\t\t\t\t\thref={directionsUrl}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<LocationFilled size={16} />\r\n\t\t\t\t\t\t{labels.map || 'Map'}\r\n\t\t\t\t\t</Button>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Text links -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-4 pt-1\">\r\n\t\t\t\t<button type=\"button\" class=\"text-link text-color-muted hover:text-color-secondary\" onclick={handleBackToEvent}>\r\n\t\t\t\t\t<ArrowLeft size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t{labels.backToEvent || 'Back to event'}\r\n\t\t\t\t</button>\r\n\r\n\t\t\t\t{#if event.venue.contactEmail}\r\n\t\t\t\t\t<span class=\"text-color-muted\">·</span>\r\n\t\t\t\t\t<a\r\n\t\t\t\t\t\thref=\"mailto:{event.venue.contactEmail}?subject=Help with Order {orderId}\"\r\n\t\t\t\t\t\tclass=\"text-link text-color-muted hover:text-color-secondary\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<Help size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t{labels.needHelp || 'Need help?'}\r\n\t\t\t\t\t</a>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</Card>\r\n</div>\r\n\r\n<style>\r\n\t/* Wrapper — fades in with content */\r\n\t.actions-wrapper {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.actions-wrapper.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Sidebar poster — same object-contain treatment as HeroImage */\r\n\t/* Wallet badges — official brand assets, no modifications per guidelines */\r\n\t.wallet-badge-btn {\r\n\t\tdisplay: block;\r\n\t\ttransition-property: opacity;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t.wallet-badge-btn:hover {\r\n\t\topacity: 0.85;\r\n\t}\r\n\r\n\t.wallet-badge-btn:active {\r\n\t\topacity: 0.7;\r\n\t}\r\n\r\n\t.wallet-badge-img {\r\n\t\theight: 44px;\r\n\t\twidth: auto;\r\n\t}\r\n\r\n\t/* Google badge: show dark variant in light mode, light variant in dark mode */\r\n\t.google-light {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t/* Calendar dropdown menu */\r\n\t.dropdown-menu {\r\n\t\tposition: absolute;\r\n\t\ttop: 100%;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\tmargin-top: 0.25rem;\r\n\t\tpadding-top: 0.25rem;\r\n\t\tpadding-bottom: 0.25rem;\r\n\t\tborder-radius: 0.5rem;\r\n\t\tbox-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -4px rgb(0 0 0 / 10%);\r\n\t\tz-index: var(--z-navigation);\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t}\r\n\r\n\t.dropdown-item {\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.625rem;\r\n\t\twidth: 100%;\r\n\t\tpadding: 0.5rem 0.75rem;\r\n\t\tfont-size: 0.875rem;\r\n\t\tline-height: 1.25rem;\r\n\t\ttext-align: left;\r\n\t\ttransition-property: color, background-color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Text links */\r\n\t.text-link {\r\n\t\tdisplay: inline-flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.25rem;\r\n\t\tfont-size: 0.75rem;\r\n\t\tline-height: 1rem;\r\n\t\ttransition-property: color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.actions-wrapper {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>","<script lang=\"ts\">\r\n\timport { toTicketId } from '@getmicdrop/svelte-components';\r\n\timport { onMount } from 'svelte';\r\n\timport type { EventData, OrderTotals, OrderLine, SuccessData } from '$lib/public-calendar-flow/types';\r\n\timport {\r\n\t\tmockEvent,\r\n\t\tmockFreeEvent,\r\n\t\tmockRegistrationEvent,\r\n\t\tmockDonationEvent\r\n\t} from '$lib/public-calendar-flow/mock-data';\r\n\timport { calculateTax } from '$lib/public-calendar-flow/defaults';\r\n\r\n\timport SuccessTicket from './SuccessTicket.svelte';\r\n\timport SuccessActions from './SuccessActions.svelte';\r\n\timport { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\r\n\timport { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\r\n\r\n\t// --- DataToggle ---\r\n\ttype SuccessVariant = 'default' | 'free' | 'registration' | 'donation';\r\n\r\n\tconst successStateOptions: ToggleOption[] = [\r\n\t\t{ value: 'default', label: 'Standard', color: 'bg-accent-success' },\r\n\t\t{ value: 'free', label: 'Free', color: 'bg-sky-500' },\r\n\t\t{ value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\r\n\t\t{ value: 'donation', label: 'Donation', color: 'bg-accent-danger' }\r\n\t];\r\n\r\n\tlet dataVariant = $derived(dataToggleStore.current as SuccessVariant);\r\n\r\n\t// --- Props (dual-mode: showcase vs production) ---\r\n\tinterface Props {\r\n\t\t/** Pre-built success data for production mode. Absence = showcase. */\r\n\t\tdata?: SuccessData;\r\n\t\t/** Event page URL for production navigation and sharing. */\r\n\t\teventUrl?: string;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tdata: dataProp = undefined,\r\n\t\teventUrl: eventUrlProp = undefined,\r\n\t\tlabels = {},\r\n\t}: Props = $props();\r\n\r\n\tconst mergedLabels = $derived(mergeLabels(labels));\r\n\r\n\tlet isShowcaseMode = $derived(!dataProp);\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tdataToggleStore.options = successStateOptions;\r\n\t\tdataToggleStore.current = 'default';\r\n\t\tdataToggleStore.isActive = true;\r\n\t\treturn () => {\r\n\t\t\tdataToggleStore.isActive = false;\r\n\t\t\tdataToggleStore.options = [];\r\n\t\t};\r\n\t});\r\n\r\n\t// --- Mock data per variant ---\r\n\tconst variantData: Record<SuccessVariant, SuccessData> = {\r\n\t\tdefault: {\r\n\t\t\tevent: mockEvent,\r\n\t\t\torderId: '12847',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(101), ticketName: 'General Admission', quantity: 2, unitPrice: 25, fee: 2.5, subtotal: 50 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(102), ticketName: 'VIP Front Row', quantity: 1, unitPrice: 55, fee: 5.5, subtotal: 55 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'customer@example.com'\r\n\t\t},\r\n\t\tfree: {\r\n\t\t\tevent: mockFreeEvent,\r\n\t\t\torderId: '12848',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(201), ticketName: 'Free Entry', quantity: 2, unitPrice: 0, fee: 0, subtotal: 0 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'comedy.fan@gmail.com'\r\n\t\t},\r\n\t\tregistration: {\r\n\t\t\tevent: mockRegistrationEvent,\r\n\t\t\torderId: '12849',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(301), ticketName: 'Workshop Seat', quantity: 1, unitPrice: 75, fee: 7.5, subtotal: 75 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'learner@example.com'\r\n\t\t},\r\n\t\tdonation: {\r\n\t\t\tevent: mockDonationEvent,\r\n\t\t\torderId: '12850',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(401), ticketName: 'Donation', quantity: 1, unitPrice: 25, fee: 0, subtotal: 25 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(402), ticketName: 'Standard Admission', quantity: 1, unitPrice: 30, fee: 3, subtotal: 30 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'generous@example.com'\r\n\t\t}\r\n\t};\r\n\r\n\tlet current: SuccessData = $derived(isShowcaseMode ? variantData[dataVariant] : dataProp!);\r\n\r\n\t// Build OrderTotals — the server's persisted order is authoritative\r\n\t// (basePrice/tax/surcharge/totalPrice match what Stripe charged).\r\n\t// Fall back to a local sum-of-lines for showcase mode only.\r\n\tlet orderTotals: OrderTotals = $derived((() => {\r\n\t\tconst lines = current.lines;\r\n\t\tif (current.serverTotals) {\r\n\t\t\treturn {\r\n\t\t\t\tlines,\r\n\t\t\t\tsubtotal: current.serverTotals.subtotal,\r\n\t\t\t\tfees: current.serverTotals.fees,\r\n\t\t\t\ttaxes: current.serverTotals.taxes,\r\n\t\t\t\ttotal: current.serverTotals.total,\r\n\t\t\t\tpromoDiscount: current.serverTotals.promoDiscount,\r\n\t\t\t\tgiftCardAmount: current.serverTotals.giftCardAmount\r\n\t\t\t};\r\n\t\t}\r\n\t\tconst subtotal = lines.reduce((sum, l) => sum + l.subtotal, 0);\r\n\t\tconst fees = lines.reduce((sum, l) => sum + l.fee * l.quantity, 0);\r\n\t\tconst taxes = calculateTax(subtotal + fees, current.event.venue.taxPercentage);\r\n\t\treturn {\r\n\t\t\tlines,\r\n\t\t\tsubtotal,\r\n\t\t\tfees,\r\n\t\t\ttaxes,\r\n\t\t\ttotal: subtotal + fees + taxes,\r\n\t\t\tpromoDiscount: 0,\r\n\t\t\tgiftCardAmount: 0\r\n\t\t};\r\n\t})());\r\n\r\n\tlet eventUrl = $derived(\r\n\t\tisShowcaseMode\r\n\t\t\t? (() => {\r\n\t\t\t\tif (typeof window === 'undefined') return '#';\r\n\t\t\t\treturn `${window.location.origin}/e/${current.event.id}-${current.event.slug}`;\r\n\t\t\t})()\r\n\t\t\t: (eventUrlProp || '#')\r\n\t);\r\n\r\n\t// --- Animation ---\r\n\tlet showCheckmark = $state(false);\r\n\tlet showContent = $state(false);\r\n\tlet reducedMotion = $state(false);\r\n\r\n\tfunction runAnimations() {\r\n\t\tif (reducedMotion) {\r\n\t\t\tshowCheckmark = true;\r\n\t\t\tshowContent = true;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tshowCheckmark = false;\r\n\t\tshowContent = false;\r\n\t\tsetTimeout(() => { showCheckmark = true; }, 800);\r\n\t\tsetTimeout(() => { showContent = true; }, 1600);\r\n\t}\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tconst _v = dataVariant;\r\n\t\trunAnimations();\r\n\t});\r\n\r\n\tonMount(() => {\r\n\t\treducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;\r\n\t\trunAnimations();\r\n\t});\r\n</script>\r\n\r\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\r\n\t<div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- DESKTOP: Two-column layout (1fr 360px) -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"hidden md:grid grid-cols-booking-split gap-8 items-start\">\r\n\r\n\t\t\t<!-- LEFT COLUMN: Confirmation card -->\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<!-- RIGHT COLUMN: Sticky sidebar with event info + actions -->\r\n\t\t\t<div class=\"sticky top-6\">\r\n\t\t\t\t<SuccessActions\r\n\t\t\t\t\tevent={current.event}\r\n\t\t\t\t\torderId={current.orderId}\r\n\t\t\t\t\t{eventUrl}\r\n\t\t\t\t\t{showContent}\r\n\t\t\t\t\tlabels={mergedLabels}\r\n\t\t\t\t/>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- MOBILE: Single column -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"md:hidden space-y-6\">\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<SuccessActions\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{eventUrl}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n\r\n","<script module>\r\n import { createLogger, toTicketId } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('Success');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { onMount } from 'svelte';\r\n import {\r\n getOrder,\r\n clearCheckoutCookies,\r\n removeCookie,\r\n } from '$lib/utils/utils.js';\r\n import { getEmbedConfig } from '$lib/config.js';\r\n import { postCheckoutComplete } from '$lib/embed-bridge.js';\r\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\r\n import SuccessMain from '$lib/public-calendar-flow/Success.svelte';\r\n import type { SuccessData, OrderLine } from '$lib/public-calendar-flow/types';\r\n\r\n // --- Props ---\r\n interface Props {\r\n data?: any;\r\n browseUrl?: string;\r\n /**\r\n * Override for the canonical event URL used by the success actions\r\n * (\"view event\" / share). The full-page get-micdrop.com route lets this\r\n * default to the current origin; the embed (running on the venue's\r\n * origin) must pass the get-micdrop.com URL so those links don't 404.\r\n */\r\n eventUrl?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n data = {},\r\n browseUrl = '/',\r\n eventUrl: eventUrlProp = undefined,\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // --- State ---\r\n let successData = $state<SuccessData | null>(null);\r\n let eventUrl = $state('');\r\n let loadError = $state<string | null>(null);\r\n let loading = $state(true);\r\n\r\n onMount(async () => {\r\n const {\r\n id,\r\n slug,\r\n event: rawEvent,\r\n orderId: paramOrderId,\r\n orderUuid: paramOrderUuid,\r\n customerEmail: paramEmail,\r\n ticketCount: paramTicketCount,\r\n } = data || {};\r\n\r\n // Opt-in host notification (configureVenueCalendar({embed:{...}})).\r\n // Emitted at mount: the order is already complete when Success renders,\r\n // and a later getOrder failure must not swallow the event. Non-PII payload.\r\n {\r\n const { postMessageOnSuccess, postMessageTargetOrigin } =\r\n getEmbedConfig();\r\n if (postMessageOnSuccess) {\r\n // postCheckoutComplete validates the origin and never throws — a bad\r\n // origin logs one warning and no-ops inside the bridge, so it can't\r\n // crash this render. We deliberately ignore the boolean here.\r\n postCheckoutComplete(\r\n // orderId covers the embed successData shape; orderUuid covers the\r\n // full-page route, whose +page.js reads BOTH ?orderId= and\r\n // ?orderUuid= query params (success/+page.js:26-27) and either may\r\n // be the populated one. Success.svelte already destructures both\r\n // (paramOrderId/paramOrderUuid above). Non-PII payload (id + eventId).\r\n {\r\n orderId: String(paramOrderId || paramOrderUuid || ''),\r\n eventId: id ?? data?.eventId ?? rawEvent?.id ?? null,\r\n },\r\n postMessageTargetOrigin\r\n );\r\n }\r\n }\r\n\r\n // Build event URL — an explicit override (embed → get-micdrop.com origin)\r\n // wins; otherwise use the current origin (the full-page route).\r\n eventUrl = eventUrlProp || `${window.location.origin}/e/${id}-${slug}`;\r\n\r\n // Transform event data\r\n let eventData;\r\n try {\r\n eventData = transformApiEvent(rawEvent);\r\n } catch (e) {\r\n logger.warn('Success: transformApiEvent failed:', e);\r\n loadError = labels.failedToLoadEventData || 'Failed to load event data.';\r\n loading = false;\r\n return;\r\n }\r\n\r\n // Fetch order data\r\n let resolvedOrderId = paramOrderId || '';\r\n let resolvedEmail = paramEmail || '';\r\n let orderLines: OrderLine[] = [];\r\n let serverTotals: any = null;\r\n\r\n if (resolvedOrderId) {\r\n try {\r\n const order = await getOrder(resolvedOrderId);\r\n if (order) {\r\n // Extract email\r\n resolvedEmail = order.customerEmail || resolvedEmail;\r\n // Map purchased tickets to OrderLine[] by grouping by ticketTypeId + ticketName\r\n const tickets = ((order as any).purchasedTickets ||\r\n (order as any).tickets ||\r\n []) as any[];\r\n const grouped = new Map<string, OrderLine>();\r\n\r\n for (const ticket of tickets) {\r\n const key = `${ticket.ticketTypeId || ticket.ticketId || 0}-${ticket.ticketName || ticket.name || ''}`;\r\n const existing = grouped.get(key);\r\n if (existing) {\r\n existing.quantity += 1;\r\n existing.subtotal += ticket.purchasePrice || ticket.price || 0;\r\n } else {\r\n grouped.set(key, {\r\n ticketId: ticket.ticketTypeId || ticket.ticketId || 0,\r\n ticketName:\r\n ticket.ticketName ||\r\n ticket.name ||\r\n labels.ticketFallbackName ||\r\n 'Ticket',\r\n quantity: 1,\r\n unitPrice: ticket.purchasePrice || ticket.price || 0,\r\n fee: 0,\r\n subtotal: ticket.purchasePrice || ticket.price || 0,\r\n });\r\n }\r\n }\r\n\r\n orderLines = Array.from(grouped.values());\r\n\r\n // Capture the persisted, server-authoritative totals. These\r\n // match the actual Stripe charge (totalPrice = basePrice +\r\n // tax + surcharge) — don't let SuccessMain recompute from\r\n // lines, which would drop the tax + service fee.\r\n if (typeof order.totalPrice === 'number') {\r\n serverTotals = {\r\n subtotal: order.basePrice ?? 0,\r\n fees: order.surcharge ?? 0,\r\n taxes: order.tax ?? 0,\r\n total: order.totalPrice,\r\n promoDiscount: order.promoCodeStoredDiscountAmount ?? 0,\r\n giftCardAmount: order.giftCardPaymentAmount ?? 0,\r\n stripeAmount:\r\n Number(order.totalPrice) -\r\n Number(order.giftCardPaymentAmount ?? 0),\r\n };\r\n }\r\n }\r\n } catch (e) {\r\n logger.warn('Success: getOrder failed, using route params:', e);\r\n // Graceful degradation -- continue with whatever data we have\r\n }\r\n }\r\n\r\n // If no order lines from API, build a placeholder from route params\r\n if (orderLines.length === 0 && paramTicketCount > 0) {\r\n orderLines = [\r\n {\r\n ticketId: toTicketId(0),\r\n ticketName: labels.ticketFallbackName || 'Ticket',\r\n quantity: paramTicketCount,\r\n unitPrice: 0,\r\n fee: 0,\r\n subtotal: 0,\r\n },\r\n ];\r\n }\r\n\r\n // Build SuccessData\r\n successData = {\r\n event: eventData,\r\n orderId: String(resolvedOrderId),\r\n lines: orderLines,\r\n customerEmail: resolvedEmail,\r\n ...(serverTotals ? { serverTotals } : {}),\r\n };\r\n\r\n // Clear checkout cookies AFTER data is loaded (Pitfall 4)\r\n clearCheckoutCookies(String(id));\r\n removeCookie('checkout-cartid');\r\n\r\n loading = false;\r\n });\r\n</script>\r\n\r\n{#if loadError}\r\n <div\r\n class=\"flex flex-col items-center justify-center py-24 text-center gap-4 error-container\"\r\n >\r\n <p>{loadError}</p>\r\n </div>\r\n{:else if loading || !successData}\r\n <div\r\n class=\"flex items-center justify-center py-24 text-center loading-container\"\r\n >\r\n <p>{labels.loadingYourOrder || 'Loading your order'}</p>\r\n </div>\r\n{:else}\r\n <SuccessMain data={successData} {eventUrl} />\r\n{/if}\r\n\r\n<style>\r\n .loading-container {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .error-container p {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n</style>\r\n"],"names":["labels","$","$$props","ticketCount","sum","l","headingText","Card","$$anchor","div","root","div_1","div_2","div_3","svg","div_4","div_5","Heading","node","Text","node_1","node_2","div_6","OrderSummary","node_3","div_7","node_4","div_8","Email","node_6","classes","classes_1","classes_2","calendarOpen","toggleCalendar","onMount","handleClickOutside","e","googleCalendarUrl","startDate","endDate","formatForGoogle","date","fullLocation","downloadICS","formatForICS","uid","now","escapeICS","str","icsContent","blob","url","link","safeFilename","handleGoogleCalendar","shareEvent","shareData","err","fallbackShare","toast","handleAppleWallet","handleGoogleWallet","directionsUrl","locationParts","handleBackToEvent","root_6","fragment","Image","PLACEHOLDER_IMAGE","Calendar","formatEventTime","$$render","consequent","formatBrowseDate","text_3","button","img","button_1","img_1","img_2","Button","node_7","ChevronDown","node_9","root_2","a","button_2","Apple","consequent_1","node_12","Share","LocationFilled","consequent_2","div_9","button_3","ArrowLeft","a_1","fragment_9","Help","consequent_3","successStateOptions","dataVariant","dataToggleStore","dataProp","eventUrlProp","mergedLabels","mergeLabels","isShowcaseMode","variantData","mockEvent","toTicketId","mockFreeEvent","mockRegistrationEvent","mockDonationEvent","current","orderTotals","lines","subtotal","fees","taxes","calculateTax","eventUrl","showCheckmark","showContent","reducedMotion","runAnimations","SuccessTicket","SuccessActions","logger","createLogger","data","successData","loadError","loading","id","slug","rawEvent","paramOrderId","paramOrderUuid","paramEmail","paramTicketCount","postMessageOnSuccess","postMessageTargetOrigin","getEmbedConfig","postCheckoutComplete","eventData","transformApiEvent","resolvedOrderId","resolvedEmail","orderLines","serverTotals","order","getOrder","tickets","grouped","ticket","key","existing","clearCheckoutCookies","removeCookie","p","root_1","p_1","SuccessMain","alternate"],"mappings":"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"}
1
+ {"version":3,"file":"Success-SZNXo-Ou.js","sources":["../src/lib/public-calendar-flow/SuccessTicket.svelte","../src/lib/public-calendar-flow/SuccessActions.svelte","../src/lib/public-calendar-flow/Success.svelte","../src/components/Views/Success.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n\timport { Email } from 'carbon-icons-svelte';\r\n\timport { Card, Heading, Text } from '@getmicdrop/svelte-components';\r\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport OrderSummary from './OrderSummary.svelte';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\torderTotals: OrderTotals;\r\n\t\tcustomerEmail: string;\r\n\t\tshowCheckmark: boolean;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tevent, orderId, orderTotals, customerEmail, showCheckmark, showContent, labels = {},\r\n\t}: Props = $props();\r\n\r\n\tlet ticketCount = $derived(orderTotals.lines.reduce((sum, l) => sum + l.quantity, 0));\r\n\r\n\tlet headingText = $derived(\r\n\t\tevent.isRegistrationEvent ? (labels.youreRegistered || \"You're registered!\") : (labels.youreIn || \"You're in!\")\r\n\t);\r\n\r\n</script>\r\n\r\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-primary\">\r\n\t<div class=\"p-6 md:p-8\">\r\n\t\t<!-- Spinner → Checkmark animation -->\r\n\t\t<div class=\"flex justify-center mb-6\">\r\n\t\t\t<div class=\"indicator-container\">\r\n\t\t\t\t<!-- Spinner (visible while loading) -->\r\n\t\t\t\t<div class=\"processing-spinner\" class:fade-out={showCheckmark}></div>\r\n\r\n\t\t\t\t<!-- Animated checkmark (appears after spinner) -->\r\n\t\t\t\t<svg class=\"checkmark-svg\" class:active={showCheckmark} viewBox=\"0 0 52 52\" aria-hidden=\"true\">\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-circle\" />\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-fill\" />\r\n\t\t\t\t\t<path d=\"M14 27l7 7 17-17\" class=\"checkmark-check\" />\r\n\t\t\t\t</svg>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- Content (fades in after checkmark completes) -->\r\n\t\t<div class=\"content-section\" class:visible={showContent}>\r\n\t\t\t<!-- Heading -->\r\n\t\t\t<!-- TODO: swap back to <Stack gap=\"3\"> once SC's root index.js exports Stack\r\n\t\t\t (the `export *` re-export of primitives doesn't surface it, so\r\n\t\t\t `import { Stack }` fails to resolve). flex-col gap-3 is equivalent. -->\r\n\t\t\t<div class=\"flex flex-col gap-3 text-center mb-6\">\r\n\t\t\t\t<Heading level={1} size=\"xl\" weight=\"bold\">\r\n\t\t\t\t\t{headingText}\r\n\t\t\t\t</Heading>\r\n\t\t\t\t<Text size=\"lg\" class=\"font-semibold block\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"secondary\" class=\"block\">\r\n\t\t\t\t\t{ticketCount} {ticketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} confirmed\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order summary (same format as checkout) -->\r\n\t\t\t<div class=\"mb-6\">\r\n\t\t\t\t<OrderSummary {orderTotals}\r\n\t\t\t\t{labels} />\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order info -->\r\n\t\t\t<div class=\"flex justify-between items-center py-3 border-t border-default\">\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold font-mono\">#{orderId}</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Email confirmation -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-2 p-3 rounded-lg bg-surface-secondary mt-4\">\r\n\t\t\t\t<Email size={16} class=\"shrink-0 text-color-muted\" />\r\n\t\t\t\t<Text size=\"xs\" color=\"secondary\">\r\n\t\t\t\t\t{labels.confirmationSentTo || 'Confirmation sent to'} {customerEmail}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t</div>\r\n\t</div>\r\n</Card>\r\n\r\n<style>\r\n\t/* Indicator container — holds spinner and checkmark in same space */\r\n\t.indicator-container {\r\n\t\tposition: relative;\r\n\t\twidth: 64px;\r\n\t\theight: 64px;\r\n\t}\r\n\r\n\t/* Spinner — rotating partial circle */\r\n\t.processing-spinner {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\tborder: 3px solid hsl(var(--stroke-primary) / 15%);\r\n\t\tborder-top-color: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tborder-radius: 50%;\r\n\t\tanimation: spin 0.7s linear infinite;\r\n\t\ttransition: opacity 0.2s ease;\r\n\t}\r\n\r\n\t.processing-spinner.fade-out {\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t@keyframes spin {\r\n\t\tto { transform: rotate(360deg); }\r\n\t}\r\n\r\n\t/* Checkmark SVG — scales in when active */\r\n\t.checkmark-svg {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\t\topacity: 0;\r\n\t\ttransform: scale(0.6);\r\n\t\ttransition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);\r\n\t}\r\n\r\n\t.checkmark-svg.active {\r\n\t\topacity: 1;\r\n\t\ttransform: scale(1);\r\n\t}\r\n\r\n\t/* Circle outline — draws itself */\r\n\t.checkmark-circle {\r\n\t\tstroke-dasharray: 151;\r\n\t\tstroke-dashoffset: 151;\r\n\t\tstroke-width: 2;\r\n\t\tstroke: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tfill: none;\r\n\t\ttransform-origin: center;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-circle {\r\n\t\tanimation: circle-draw 0.5s ease-out 0.1s forwards;\r\n\t}\r\n\r\n\t@keyframes circle-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Circle fill — fades in after outline completes */\r\n\t.checkmark-fill {\r\n\t\tfill: hsl(var(--accent-success, 142 71% 45%));\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-fill {\r\n\t\tanimation: fill-in 0.25s ease-out 0.5s forwards;\r\n\t}\r\n\r\n\t@keyframes fill-in {\r\n\t\tto { opacity: 1; }\r\n\t}\r\n\r\n\t/* Checkmark stroke — draws after fill */\r\n\t.checkmark-check {\r\n\t\tstroke-dasharray: 36;\r\n\t\tstroke-dashoffset: 36;\r\n\t\tstroke-width: 3;\r\n\t\tstroke: hsl(var(--bg-primary));\r\n\t\tfill: none;\r\n\t\tstroke-linecap: round;\r\n\t\tstroke-linejoin: round;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-check {\r\n\t\tanimation: check-draw 0.3s ease-out 0.6s forwards;\r\n\t}\r\n\r\n\t@keyframes check-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Content section — fades in after checkmark */\r\n\t.content-section {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.content-section.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.processing-spinner {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg .checkmark-circle,\r\n\t\t.checkmark-svg .checkmark-fill,\r\n\t\t.checkmark-svg .checkmark-check {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t\tanimation-delay: 0s;\r\n\t\t}\r\n\r\n\t\t.content-section {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>\r\n","<!-- native-element-exception: VC is an embeddable widget — native <button>s are intentional here (widget-controlled styling on calendar cells, date selectors, checkout/nav CTAs). -->\r\n<script lang=\"ts\">\r\n\timport { onMount } from 'svelte';\r\n\timport {\r\n\t\tShare,\r\n\t\tHelp,\r\n\t\tArrowLeft,\r\n\t\tApple,\r\n\t\tCalendar,\r\n\t\tChevronDown,\r\n\t\tLocationFilled,\r\n\t} from 'carbon-icons-svelte';\r\n\timport { Button, Card, Image, Text } from '@getmicdrop/svelte-components';\r\n\timport { toast } from '@getmicdrop/svelte-components/toast';\r\n\timport type { EventData } from '$lib/public-calendar-flow/types';\r\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n\timport { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\teventUrl: string;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { event, orderId, eventUrl, showContent, labels = {} }: Props = $props();\r\n\r\n\t// --- Calendar dropdown ---\r\n\tlet calendarOpen = $state(false);\r\n\r\n\tfunction toggleCalendar() {\r\n\t\tcalendarOpen = !calendarOpen;\r\n\t}\r\n\r\n\t// Close calendar dropdown when clicking outside\r\n\tonMount(() => {\r\n\t\tfunction handleClickOutside(e: MouseEvent) {\r\n\t\t\tconst target = e.target as HTMLElement;\r\n\t\t\tif (!target.closest('.calendar-dropdown')) {\r\n\t\t\t\tcalendarOpen = false;\r\n\t\t\t}\r\n\t\t}\r\n\t\tdocument.addEventListener('click', handleClickOutside);\r\n\t\treturn () => document.removeEventListener('click', handleClickOutside);\r\n\t});\r\n\r\n\t// --- Google Calendar URL ---\r\n\tlet googleCalendarUrl = $derived((() => {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForGoogle = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst params = new URLSearchParams({\r\n\t\t\taction: 'TEMPLATE',\r\n\t\t\ttext: event.title,\r\n\t\t\tdates: `${formatForGoogle(startDate)}/${formatForGoogle(endDate)}`,\r\n\t\t\tlocation: fullLocation,\r\n\t\t\tdetails: `Event: ${eventUrl}\\n\\nTicket confirmation #${orderId}`\r\n\t\t});\r\n\r\n\t\treturn `https://calendar.google.com/calendar/render?${params.toString()}`;\r\n\t})());\r\n\r\n\t// --- ICS file download (Apple Calendar) ---\r\n\tfunction downloadICS() {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForICS = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst uid = `order-${orderId}-event-${event.id}@micdrop.com`;\r\n\t\tconst now = formatForICS(new Date());\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst escapeICS = (str: string): string => {\r\n\t\t\tif (!str) return '';\r\n\t\t\treturn str.replace(/\\\\/g, '\\\\\\\\').replace(/;/g, '\\\\;').replace(/,/g, '\\\\,').replace(/\\n/g, '\\\\n');\r\n\t\t};\r\n\r\n\t\tconst icsContent = `BEGIN:VCALENDAR\r\nVERSION:2.0\r\nPRODID:-//MicDrop//Ticket Confirmation//EN\r\nCALSCALE:GREGORIAN\r\nMETHOD:PUBLISH\r\nBEGIN:VEVENT\r\nUID:${uid}\r\nDTSTAMP:${now}\r\nDTSTART:${formatForICS(startDate)}\r\nDTEND:${formatForICS(endDate)}\r\nSUMMARY:${escapeICS(event.title)}\r\nLOCATION:${escapeICS(fullLocation)}\r\nDESCRIPTION:${escapeICS(`Order #${orderId}\\n\\nView event: ${eventUrl}`)}\r\nURL:${eventUrl}\r\nSTATUS:CONFIRMED\r\nEND:VEVENT\r\nEND:VCALENDAR`;\r\n\r\n\t\tconst blob = new Blob([icsContent], { type: 'text/calendar;charset=utf-8' });\r\n\t\t// @image-handling-escape: programmatic blob-URL download (export/.ics) — SC Image canonical cannot express in-memory-blob → browser-download\r\n\t\tconst url = URL.createObjectURL(blob);\r\n\t\tconst link = document.createElement('a');\r\n\t\tlink.href = url;\r\n\t\tconst safeFilename = (event.title || 'event').replace(/[^a-zA-Z0-9\\s-]/g, '').replace(/\\s+/g, '-');\r\n\t\tlink.download = `${safeFilename}.ics`;\r\n\t\tdocument.body.appendChild(link);\r\n\t\tlink.click();\r\n\t\tdocument.body.removeChild(link);\r\n\t\tURL.revokeObjectURL(url);\r\n\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\tfunction handleGoogleCalendar() {\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\t// --- Share event ---\r\n\tasync function shareEvent() {\r\n\t\tconst shareData = { url: eventUrl };\r\n\r\n\t\tif (navigator.share) {\r\n\t\t\ttry {\r\n\t\t\t\tawait navigator.share(shareData);\r\n\t\t\t} catch (err: unknown) {\r\n\t\t\t\tif (err instanceof Error && err.name !== 'AbortError') {\r\n\t\t\t\t\tfallbackShare();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tfallbackShare();\r\n\t\t}\r\n\t}\r\n\r\n\tfunction fallbackShare() {\r\n\t\tnavigator.clipboard.writeText(eventUrl).then(() => {\r\n\t\t\ttoast.success(labels.linkCopied || 'Link copied to clipboard!');\r\n\t\t}).catch(() => {\r\n\t\t\ttoast.error(labels.copyLink || 'Could not copy link — please copy it manually: ' + eventUrl);\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Wallet handlers (mock — requires backend in production) ---\r\n\tfunction handleAppleWallet() {\r\n\t\ttoast.info('Apple Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\tfunction handleGoogleWallet() {\r\n\t\ttoast.info('Google Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Directions ---\r\n\tlet directionsUrl = $derived((() => {\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst query = encodeURIComponent(locationParts.join(', '));\r\n\t\treturn `https://www.google.com/maps/search/?api=1&query=${query}`;\r\n\t})());\r\n\r\n\t// --- Navigation ---\r\n\tfunction handleBackToEvent() {\r\n\t\twindow.location.href = eventUrl;\r\n\t}\r\n</script>\r\n\r\n<!--\r\n\tSuccessActions: Sidebar card matching BookingWidget / CheckoutSidebar pattern.\r\n\tSingle Card with event thumbnail, date summary, wallet badges, action buttons, and links.\r\n-->\r\n<div class=\"actions-wrapper\" class:visible={showContent}>\r\n\t<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\r\n\t\t<!-- Event poster (same treatment as HeroImage — object-contain, no crop) -->\r\n\t\t<div class=\"rounded-t-xl overflow-hidden bg-surface-tertiary\">\r\n\t\t\t<Image\r\n\t\t\t\tsrc={event.imageUrl}\r\n\t\t\t\talt={event.title}\r\n\t\t\t\tfallback={PLACEHOLDER_IMAGE}\r\n\t\t\t\tfit=\"contain\"\r\n\t\t\t\tclass=\"w-full max-h-60 min-h-24\"\r\n\t\t\t/>\r\n\t\t</div>\r\n\r\n\t\t<div class=\"p-5 space-y-4\">\r\n\t\t\t<!-- Event info -->\r\n\t\t\t<div>\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1.5\">\r\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\r\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\r\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{/if}\r\n\t\t\t\t\t</Text>\r\n\t\t\t\t</div>\r\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n\t\t\t\t\t{event.venue.name}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Wallet badges (official brand assets) -->\r\n\t\t\t<div class=\"flex flex-col items-center gap-3\">\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleAppleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/apple-wallet.svg\"\r\n\t\t\t\t\t\talt={labels.addToAppleWallet || 'Add to Apple Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleGoogleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-dark.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-dark\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-light.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-light\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Divider -->\r\n\t\t\t<div class=\"divider\"></div>\r\n\r\n\t\t\t<!-- Calendar dropdown (full width) -->\r\n\t\t\t<div class=\"calendar-dropdown relative\">\r\n\t\t\t\t<Button\r\n\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\tclass=\"w-full\"\r\n\t\t\t\t\tonclick={toggleCalendar}\r\n\t\t\t\t>\r\n\t\t\t\t\t<Calendar size={16} />\r\n\t\t\t\t\t{labels.addToCalendar || 'Add to Calendar'}\r\n\t\t\t\t\t<ChevronDown size={16} class=\"ml-auto transition-transform {calendarOpen ? 'rotate-180' : ''}\" />\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if calendarOpen}\r\n\t\t\t\t\t<div class=\"dropdown-menu bg-surface-primary border-default\">\r\n\t\t\t\t\t\t<a\r\n\t\t\t\t\t\t\thref={googleCalendarUrl}\r\n\t\t\t\t\t\t\trel=\"noopener noreferrer\"\r\n\t\t\t\t\t\t\tclass=\"dropdown-item text-color-primary hover:bg-surface-secondary\"\r\n\t\t\t\t\t\t\tonclick={handleGoogleCalendar}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<svg aria-hidden=\"true\" class=\"shrink-0\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n\t\t\t\t\t\t\t\t<path d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92a5.06 5.06 0 0 1-2.2 3.32v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.1z\" fill=\"#4285F4\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\" fill=\"#34A853\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18A10.96 10.96 0 0 0 1 12c0 1.77.42 3.45 1.18 4.93l3.66-2.84z\" fill=\"#FBBC05\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\" fill=\"#EA4335\"/>\r\n\t\t\t\t\t\t\t</svg>\r\n\t\t\t\t\t\t\t{labels.googleCalendar || 'Google Calendar'}\r\n\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t<button type=\"button\" class=\"dropdown-item text-color-primary hover:bg-surface-secondary\" onclick={downloadICS}>\r\n\t\t\t\t\t\t\t<Apple size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t\t{labels.appleCalendar || 'Apple Calendar (.ics)'}\r\n\t\t\t\t\t\t</button>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Share + Directions row -->\r\n\t\t\t<div class=\"flex gap-2\">\r\n\t\t\t\t<Button variant=\"default\" size=\"md\" class=\"flex-1\" onclick={shareEvent}>\r\n\t\t\t\t\t<Share size={16} />\r\n\t\t\t\t\t{labels.share || 'Share'}\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if event.venue.address}\r\n\t\t\t\t\t<Button\r\n\t\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\t\tclass=\"flex-1\"\r\n\t\t\t\t\t\thref={directionsUrl}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<LocationFilled size={16} />\r\n\t\t\t\t\t\t{labels.map || 'Map'}\r\n\t\t\t\t\t</Button>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Text links -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-4 pt-1\">\r\n\t\t\t\t<button type=\"button\" class=\"text-link text-color-muted hover:text-color-secondary\" onclick={handleBackToEvent}>\r\n\t\t\t\t\t<ArrowLeft size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t{labels.backToEvent || 'Back to event'}\r\n\t\t\t\t</button>\r\n\r\n\t\t\t\t{#if event.venue.contactEmail}\r\n\t\t\t\t\t<span class=\"text-color-muted\">·</span>\r\n\t\t\t\t\t<a\r\n\t\t\t\t\t\thref=\"mailto:{event.venue.contactEmail}?subject=Help with Order {orderId}\"\r\n\t\t\t\t\t\tclass=\"text-link text-color-muted hover:text-color-secondary\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<Help size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t{labels.needHelp || 'Need help?'}\r\n\t\t\t\t\t</a>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</Card>\r\n</div>\r\n\r\n<style>\r\n\t/* Wrapper — fades in with content */\r\n\t.actions-wrapper {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.actions-wrapper.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Sidebar poster — same object-contain treatment as HeroImage */\r\n\t/* Wallet badges — official brand assets, no modifications per guidelines */\r\n\t.wallet-badge-btn {\r\n\t\tdisplay: block;\r\n\t\ttransition-property: opacity;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t.wallet-badge-btn:hover {\r\n\t\topacity: 0.85;\r\n\t}\r\n\r\n\t.wallet-badge-btn:active {\r\n\t\topacity: 0.7;\r\n\t}\r\n\r\n\t.wallet-badge-img {\r\n\t\theight: 44px;\r\n\t\twidth: auto;\r\n\t}\r\n\r\n\t/* Google badge: show dark variant in light mode, light variant in dark mode */\r\n\t.google-light {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t/* Calendar dropdown menu */\r\n\t.dropdown-menu {\r\n\t\tposition: absolute;\r\n\t\ttop: 100%;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\tmargin-top: 0.25rem;\r\n\t\tpadding-top: 0.25rem;\r\n\t\tpadding-bottom: 0.25rem;\r\n\t\tborder-radius: 0.5rem;\r\n\t\tbox-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -4px rgb(0 0 0 / 10%);\r\n\t\tz-index: var(--z-navigation);\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t}\r\n\r\n\t.dropdown-item {\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.625rem;\r\n\t\twidth: 100%;\r\n\t\tpadding: 0.5rem 0.75rem;\r\n\t\tfont-size: 0.875rem;\r\n\t\tline-height: 1.25rem;\r\n\t\ttext-align: left;\r\n\t\ttransition-property: color, background-color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Text links */\r\n\t.text-link {\r\n\t\tdisplay: inline-flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.25rem;\r\n\t\tfont-size: 0.75rem;\r\n\t\tline-height: 1rem;\r\n\t\ttransition-property: color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.actions-wrapper {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>","<script lang=\"ts\">\r\n\timport { toTicketId } from '@getmicdrop/svelte-components';\r\n\timport { onMount } from 'svelte';\r\n\timport type { EventData, OrderTotals, OrderLine, SuccessData } from '$lib/public-calendar-flow/types';\r\n\timport {\r\n\t\tmockEvent,\r\n\t\tmockFreeEvent,\r\n\t\tmockRegistrationEvent,\r\n\t\tmockDonationEvent\r\n\t} from '$lib/public-calendar-flow/mock-data';\r\n\timport { calculateTax } from '$lib/public-calendar-flow/defaults';\r\n\r\n\timport SuccessTicket from './SuccessTicket.svelte';\r\n\timport SuccessActions from './SuccessActions.svelte';\r\n\timport { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\r\n\timport { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\r\n\r\n\t// --- DataToggle ---\r\n\ttype SuccessVariant = 'default' | 'free' | 'registration' | 'donation';\r\n\r\n\tconst successStateOptions: ToggleOption[] = [\r\n\t\t{ value: 'default', label: 'Standard', color: 'bg-accent-success' },\r\n\t\t{ value: 'free', label: 'Free', color: 'bg-sky-500' },\r\n\t\t{ value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\r\n\t\t{ value: 'donation', label: 'Donation', color: 'bg-accent-danger' }\r\n\t];\r\n\r\n\tlet dataVariant = $derived(dataToggleStore.current as SuccessVariant);\r\n\r\n\t// --- Props (dual-mode: showcase vs production) ---\r\n\tinterface Props {\r\n\t\t/** Pre-built success data for production mode. Absence = showcase. */\r\n\t\tdata?: SuccessData;\r\n\t\t/** Event page URL for production navigation and sharing. */\r\n\t\teventUrl?: string;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tdata: dataProp = undefined,\r\n\t\teventUrl: eventUrlProp = undefined,\r\n\t\tlabels = {},\r\n\t}: Props = $props();\r\n\r\n\tconst mergedLabels = $derived(mergeLabels(labels));\r\n\r\n\tlet isShowcaseMode = $derived(!dataProp);\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tdataToggleStore.options = successStateOptions;\r\n\t\tdataToggleStore.current = 'default';\r\n\t\tdataToggleStore.isActive = true;\r\n\t\treturn () => {\r\n\t\t\tdataToggleStore.isActive = false;\r\n\t\t\tdataToggleStore.options = [];\r\n\t\t};\r\n\t});\r\n\r\n\t// --- Mock data per variant ---\r\n\tconst variantData: Record<SuccessVariant, SuccessData> = {\r\n\t\tdefault: {\r\n\t\t\tevent: mockEvent,\r\n\t\t\torderId: '12847',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(101), ticketName: 'General Admission', quantity: 2, unitPrice: 25, fee: 2.5, subtotal: 50 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(102), ticketName: 'VIP Front Row', quantity: 1, unitPrice: 55, fee: 5.5, subtotal: 55 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'customer@example.com'\r\n\t\t},\r\n\t\tfree: {\r\n\t\t\tevent: mockFreeEvent,\r\n\t\t\torderId: '12848',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(201), ticketName: 'Free Entry', quantity: 2, unitPrice: 0, fee: 0, subtotal: 0 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'comedy.fan@gmail.com'\r\n\t\t},\r\n\t\tregistration: {\r\n\t\t\tevent: mockRegistrationEvent,\r\n\t\t\torderId: '12849',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(301), ticketName: 'Workshop Seat', quantity: 1, unitPrice: 75, fee: 7.5, subtotal: 75 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'learner@example.com'\r\n\t\t},\r\n\t\tdonation: {\r\n\t\t\tevent: mockDonationEvent,\r\n\t\t\torderId: '12850',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(401), ticketName: 'Donation', quantity: 1, unitPrice: 25, fee: 0, subtotal: 25 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(402), ticketName: 'Standard Admission', quantity: 1, unitPrice: 30, fee: 3, subtotal: 30 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'generous@example.com'\r\n\t\t}\r\n\t};\r\n\r\n\tlet current: SuccessData = $derived(isShowcaseMode ? variantData[dataVariant] : dataProp!);\r\n\r\n\t// Build OrderTotals — the server's persisted order is authoritative\r\n\t// (basePrice/tax/surcharge/totalPrice match what Stripe charged).\r\n\t// Fall back to a local sum-of-lines for showcase mode only.\r\n\tlet orderTotals: OrderTotals = $derived((() => {\r\n\t\tconst lines = current.lines;\r\n\t\tif (current.serverTotals) {\r\n\t\t\treturn {\r\n\t\t\t\tlines,\r\n\t\t\t\tsubtotal: current.serverTotals.subtotal,\r\n\t\t\t\tfees: current.serverTotals.fees,\r\n\t\t\t\ttaxes: current.serverTotals.taxes,\r\n\t\t\t\ttotal: current.serverTotals.total,\r\n\t\t\t\tpromoDiscount: current.serverTotals.promoDiscount,\r\n\t\t\t\tgiftCardAmount: current.serverTotals.giftCardAmount\r\n\t\t\t};\r\n\t\t}\r\n\t\tconst subtotal = lines.reduce((sum, l) => sum + l.subtotal, 0);\r\n\t\tconst fees = lines.reduce((sum, l) => sum + l.fee * l.quantity, 0);\r\n\t\tconst taxes = calculateTax(subtotal + fees, current.event.venue.taxPercentage);\r\n\t\treturn {\r\n\t\t\tlines,\r\n\t\t\tsubtotal,\r\n\t\t\tfees,\r\n\t\t\ttaxes,\r\n\t\t\ttotal: subtotal + fees + taxes,\r\n\t\t\tpromoDiscount: 0,\r\n\t\t\tgiftCardAmount: 0\r\n\t\t};\r\n\t})());\r\n\r\n\tlet eventUrl = $derived(\r\n\t\tisShowcaseMode\r\n\t\t\t? (() => {\r\n\t\t\t\tif (typeof window === 'undefined') return '#';\r\n\t\t\t\treturn `${window.location.origin}/e/${current.event.id}-${current.event.slug}`;\r\n\t\t\t})()\r\n\t\t\t: (eventUrlProp || '#')\r\n\t);\r\n\r\n\t// --- Animation ---\r\n\tlet showCheckmark = $state(false);\r\n\tlet showContent = $state(false);\r\n\tlet reducedMotion = $state(false);\r\n\r\n\tfunction runAnimations() {\r\n\t\tif (reducedMotion) {\r\n\t\t\tshowCheckmark = true;\r\n\t\t\tshowContent = true;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tshowCheckmark = false;\r\n\t\tshowContent = false;\r\n\t\tsetTimeout(() => { showCheckmark = true; }, 800);\r\n\t\tsetTimeout(() => { showContent = true; }, 1600);\r\n\t}\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tconst _v = dataVariant;\r\n\t\trunAnimations();\r\n\t});\r\n\r\n\tonMount(() => {\r\n\t\treducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;\r\n\t\trunAnimations();\r\n\t});\r\n</script>\r\n\r\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\r\n\t<div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- DESKTOP: Two-column layout (1fr 360px) -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"hidden md:grid grid-cols-booking-split gap-8 items-start\">\r\n\r\n\t\t\t<!-- LEFT COLUMN: Confirmation card -->\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<!-- RIGHT COLUMN: Sticky sidebar with event info + actions -->\r\n\t\t\t<div class=\"sticky top-6\">\r\n\t\t\t\t<SuccessActions\r\n\t\t\t\t\tevent={current.event}\r\n\t\t\t\t\torderId={current.orderId}\r\n\t\t\t\t\t{eventUrl}\r\n\t\t\t\t\t{showContent}\r\n\t\t\t\t\tlabels={mergedLabels}\r\n\t\t\t\t/>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- MOBILE: Single column -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"md:hidden space-y-6\">\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<SuccessActions\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{eventUrl}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n\r\n","<script module>\r\n import { createLogger, toTicketId } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('Success');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { onMount } from 'svelte';\r\n import {\r\n getOrder,\r\n clearCheckoutCookies,\r\n removeCookie,\r\n } from '$lib/utils/utils.js';\r\n import { getEmbedConfig } from '$lib/config.js';\r\n import { postCheckoutComplete } from '$lib/embed-bridge.js';\r\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\r\n import SuccessMain from '$lib/public-calendar-flow/Success.svelte';\r\n import type { SuccessData, OrderLine } from '$lib/public-calendar-flow/types';\r\n\r\n // --- Props ---\r\n interface Props {\r\n data?: any;\r\n browseUrl?: string;\r\n /**\r\n * Override for the canonical event URL used by the success actions\r\n * (\"view event\" / share). The full-page get-micdrop.com route lets this\r\n * default to the current origin; the embed (running on the venue's\r\n * origin) must pass the get-micdrop.com URL so those links don't 404.\r\n */\r\n eventUrl?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n data = {},\r\n browseUrl = '/',\r\n eventUrl: eventUrlProp = undefined,\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // --- State ---\r\n let successData = $state<SuccessData | null>(null);\r\n let eventUrl = $state('');\r\n let loadError = $state<string | null>(null);\r\n let loading = $state(true);\r\n\r\n onMount(async () => {\r\n const {\r\n id,\r\n slug,\r\n event: rawEvent,\r\n orderId: paramOrderId,\r\n orderUuid: paramOrderUuid,\r\n customerEmail: paramEmail,\r\n ticketCount: paramTicketCount,\r\n } = data || {};\r\n\r\n // Opt-in host notification (configureVenueCalendar({embed:{...}})).\r\n // Emitted at mount: the order is already complete when Success renders,\r\n // and a later getOrder failure must not swallow the event. Non-PII payload.\r\n {\r\n const { postMessageOnSuccess, postMessageTargetOrigin } =\r\n getEmbedConfig();\r\n if (postMessageOnSuccess) {\r\n // postCheckoutComplete validates the origin and never throws — a bad\r\n // origin logs one warning and no-ops inside the bridge, so it can't\r\n // crash this render. We deliberately ignore the boolean here.\r\n postCheckoutComplete(\r\n // orderId covers the embed successData shape; orderUuid covers the\r\n // full-page route, whose +page.js reads BOTH ?orderId= and\r\n // ?orderUuid= query params (success/+page.js:26-27) and either may\r\n // be the populated one. Success.svelte already destructures both\r\n // (paramOrderId/paramOrderUuid above). Non-PII payload (id + eventId).\r\n {\r\n orderId: String(paramOrderId || paramOrderUuid || ''),\r\n eventId: id ?? data?.eventId ?? rawEvent?.id ?? null,\r\n },\r\n postMessageTargetOrigin\r\n );\r\n }\r\n }\r\n\r\n // Build event URL — an explicit override (embed → get-micdrop.com origin)\r\n // wins; otherwise use the current origin (the full-page route).\r\n eventUrl = eventUrlProp || `${window.location.origin}/e/${id}-${slug}`;\r\n\r\n // Transform event data\r\n let eventData;\r\n try {\r\n eventData = transformApiEvent(rawEvent);\r\n } catch (e) {\r\n logger.warn('Success: transformApiEvent failed:', e);\r\n loadError = labels.failedToLoadEventData || 'Failed to load event data.';\r\n loading = false;\r\n return;\r\n }\r\n\r\n // Fetch order data\r\n let resolvedOrderId = paramOrderId || '';\r\n let resolvedEmail = paramEmail || '';\r\n let orderLines: OrderLine[] = [];\r\n let serverTotals: any = null;\r\n\r\n if (resolvedOrderId) {\r\n try {\r\n const order = await getOrder(resolvedOrderId);\r\n if (order) {\r\n // Extract email\r\n resolvedEmail = order.customerEmail || resolvedEmail;\r\n // Map purchased tickets to OrderLine[] by grouping by ticketTypeId + ticketName\r\n const tickets = ((order as any).purchasedTickets ||\r\n (order as any).tickets ||\r\n []) as any[];\r\n const grouped = new Map<string, OrderLine>();\r\n\r\n for (const ticket of tickets) {\r\n const key = `${ticket.ticketTypeId || ticket.ticketId || 0}-${ticket.ticketName || ticket.name || ''}`;\r\n const existing = grouped.get(key);\r\n if (existing) {\r\n existing.quantity += 1;\r\n existing.subtotal += ticket.purchasePrice || ticket.price || 0;\r\n } else {\r\n grouped.set(key, {\r\n ticketId: ticket.ticketTypeId || ticket.ticketId || 0,\r\n ticketName:\r\n ticket.ticketName ||\r\n ticket.name ||\r\n labels.ticketFallbackName ||\r\n 'Ticket',\r\n quantity: 1,\r\n unitPrice: ticket.purchasePrice || ticket.price || 0,\r\n fee: 0,\r\n subtotal: ticket.purchasePrice || ticket.price || 0,\r\n });\r\n }\r\n }\r\n\r\n orderLines = Array.from(grouped.values());\r\n\r\n // Capture the persisted, server-authoritative totals. These\r\n // match the actual Stripe charge (totalPrice = basePrice +\r\n // tax + surcharge) — don't let SuccessMain recompute from\r\n // lines, which would drop the tax + service fee.\r\n if (typeof order.totalPrice === 'number') {\r\n serverTotals = {\r\n subtotal: order.basePrice ?? 0,\r\n fees: order.surcharge ?? 0,\r\n taxes: order.tax ?? 0,\r\n total: order.totalPrice,\r\n promoDiscount: order.promoCodeStoredDiscountAmount ?? 0,\r\n giftCardAmount: order.giftCardPaymentAmount ?? 0,\r\n stripeAmount:\r\n Number(order.totalPrice) -\r\n Number(order.giftCardPaymentAmount ?? 0),\r\n };\r\n }\r\n }\r\n } catch (e) {\r\n logger.warn('Success: getOrder failed, using route params:', e);\r\n // Graceful degradation -- continue with whatever data we have\r\n }\r\n }\r\n\r\n // If no order lines from API, build a placeholder from route params\r\n if (orderLines.length === 0 && paramTicketCount > 0) {\r\n orderLines = [\r\n {\r\n ticketId: toTicketId(0),\r\n ticketName: labels.ticketFallbackName || 'Ticket',\r\n quantity: paramTicketCount,\r\n unitPrice: 0,\r\n fee: 0,\r\n subtotal: 0,\r\n },\r\n ];\r\n }\r\n\r\n // Build SuccessData\r\n successData = {\r\n event: eventData,\r\n orderId: String(resolvedOrderId),\r\n lines: orderLines,\r\n customerEmail: resolvedEmail,\r\n ...(serverTotals ? { serverTotals } : {}),\r\n };\r\n\r\n // Clear checkout cookies AFTER data is loaded (Pitfall 4)\r\n clearCheckoutCookies(String(id));\r\n removeCookie('checkout-cartid');\r\n\r\n loading = false;\r\n });\r\n</script>\r\n\r\n{#if loadError}\r\n <div\r\n class=\"flex flex-col items-center justify-center py-24 text-center gap-4 error-container\"\r\n >\r\n <p>{loadError}</p>\r\n </div>\r\n{:else if loading || !successData}\r\n <div\r\n class=\"flex items-center justify-center py-24 text-center loading-container\"\r\n >\r\n <p>{labels.loadingYourOrder || 'Loading your order'}</p>\r\n </div>\r\n{:else}\r\n <SuccessMain data={successData} {eventUrl} />\r\n{/if}\r\n\r\n<style>\r\n .loading-container {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .error-container p {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n</style>\r\n"],"names":["labels","$","$$props","ticketCount","sum","l","headingText","Card","$$anchor","div","root","div_1","div_2","div_3","svg","div_4","div_5","Heading","node","Text","node_1","node_2","div_6","OrderSummary","node_3","div_7","node_4","div_8","Email","node_6","classes","classes_1","classes_2","calendarOpen","toggleCalendar","onMount","handleClickOutside","e","googleCalendarUrl","startDate","endDate","formatForGoogle","date","fullLocation","downloadICS","formatForICS","uid","now","escapeICS","str","icsContent","blob","url","link","safeFilename","handleGoogleCalendar","shareEvent","shareData","err","fallbackShare","toast","handleAppleWallet","handleGoogleWallet","directionsUrl","locationParts","handleBackToEvent","root_6","fragment","Image","PLACEHOLDER_IMAGE","Calendar","formatEventTime","$$render","consequent","formatBrowseDate","text_3","button","img","button_1","img_1","img_2","Button","node_7","ChevronDown","node_9","root_2","a","button_2","Apple","consequent_1","node_12","Share","LocationFilled","consequent_2","div_9","button_3","ArrowLeft","a_1","fragment_9","Help","consequent_3","successStateOptions","dataVariant","dataToggleStore","dataProp","eventUrlProp","mergedLabels","mergeLabels","isShowcaseMode","variantData","mockEvent","toTicketId","mockFreeEvent","mockRegistrationEvent","mockDonationEvent","current","orderTotals","lines","subtotal","fees","taxes","calculateTax","eventUrl","showCheckmark","showContent","reducedMotion","runAnimations","SuccessTicket","SuccessActions","logger","createLogger","data","successData","loadError","loading","id","slug","rawEvent","paramOrderId","paramOrderUuid","paramEmail","paramTicketCount","postMessageOnSuccess","postMessageTargetOrigin","getEmbedConfig","postCheckoutComplete","eventData","transformApiEvent","resolvedOrderId","resolvedEmail","orderLines","serverTotals","order","getOrder","tickets","grouped","ticket","key","existing","clearCheckoutCookies","removeCookie","p","root_1","p_1","SuccessMain","alternate"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import "svelte/internal/disclose-version";
2
2
  import * as e from "svelte/internal/client";
3
- import { j as A, ax as S } from "./VenueCalendar-DdRkxjxd.js";
3
+ import { j as A, ax as S } from "./VenueCalendar-DTOyAhDU.js";
4
4
  var D = e.from_html('<div><img alt="" class="sc-image__blur svelte-12gell2" aria-hidden="true" decoding="async"/> <img decoding="async"/></div>'), O = e.from_html('<img decoding="async"/>'), V = e.from_html('<div role="img"></div>'), X = e.from_html('<div aria-hidden="true"></div>');
5
5
  function H(T, t) {
6
6
  e.push(t, !0), A("Image"), typeof process < "u" && process.env?.VITEST;
@@ -155,4 +155,4 @@ export {
155
155
  H as I,
156
156
  J as T
157
157
  };
158
- //# sourceMappingURL=Text-F6D2QvI6.js.map
158
+ //# sourceMappingURL=Text-DHgQP4rA.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Text-F6D2QvI6.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Image/Image.svelte","../node_modules/@getmicdrop/svelte-components/dist/components/Text.svelte"],"sourcesContent":["<!--\r\n Image.svelte\r\n\r\n The canonical image primitive for Micdrop. Variable-aspect, user-uploaded\r\n sources (event posters, performer headshots, venue photos) where we do NOT\r\n control the aspect ratio. This component is now the single home for the\r\n whole image family — `Avatar` composes it, and `BlurBackdropImage` is a\r\n thin `@deprecated` shim.\r\n\r\n Premium contract (Atlas brief 04 — perf 5 / completeness 5):\r\n\r\n 1. ZERO CLS — pass `width`/`height` (intrinsic px) or `aspectRatio`\r\n (e.g. `'2/3'`, `'16/9'`, `'1'`). The component reserves that space\r\n BEFORE the image loads so the page never reflows when it arrives.\r\n Dev-only `console.warn` if you provide neither dimensions nor a\r\n sizing class (we can't reserve space and CLS can creep back in).\r\n\r\n 2. BLUR-UP LOADING — the main image starts slightly blurred and SHARPENS\r\n (blur → 0) once the real bitmap has decoded (`img.decode()` +\r\n `decoding=\"async\"`). In blur-backdrop framing a blurred copy of the\r\n SAME already-fetched bitmap fills the letterbox gaps — no second\r\n network fetch, no LQIP asset to ship. Fade timing reads the motion\r\n tokens, so `prefers-reduced-motion` collapses it automatically.\r\n\r\n 3. BLUR-BACKDROP IS THE DEFAULT FRAMING — `fit` defaults to\r\n `'blur-backdrop'`: the image is `object-fit: contain` (never cropped)\r\n and a blurred copy of itself fills the letterbox gaps. This handles\r\n BOTH tall posters and wide photos with no cropping and no flat-gray\r\n bars. `'cover'` / `'contain'` / `'fill'` / `'scale-down'` / `'none'`\r\n remain as escape hatches and render the plain single-`<img>` path\r\n (identical DOM to the pre-premium component).\r\n\r\n 4. BRANDED FALLBACK — when `src` (and `fallback`) are missing or both\r\n error, we render a branded placeholder (the Micdrop mark on a tint)\r\n instead of a flat gray div. Override the asset with `fallback`, or\r\n suppress the mark with `branded={false}`.\r\n\r\n Passthrough props for raw-<img> parity (so consumers can migrate\r\n existing `<img>` sites to `<Image>`):\r\n - `draggable` — forwarded to the underlying `<img draggable>`.\r\n - `onload` — forwarded to the `<img>` load event.\r\n - `fetchpriority` — forwarded to `<img fetchpriority>` (resource hint).\r\n - `onError` — fires ONCE, only after the internal fallback chain is\r\n exhausted (i.e. the branded placeholder takes over). It does NOT fire\r\n on the first error while a distinct `fallback` is still going to be\r\n tried. The raw `onerror` handler stays owned internally to drive the\r\n src→fallback→placeholder degradation; `onError` composes with it\r\n rather than replacing it.\r\n Deliberately NOT exposed: `srcset`/`sizes` — zero consumer demand.\r\n\r\n Example:\r\n <Image src={event.posterUrl} alt={event.name} aspectRatio=\"2/3\" class=\"w-full rounded-xl\" />\r\n <Image src={user.avatarUrl} alt={user.name} width={80} height={80} fit=\"cover\" class=\"rounded-full\" />\r\n <Image src={banner.url} alt=\"\" aspectRatio=\"16/9\" class=\"w-full\" loading=\"eager\" fetchpriority=\"high\" />\r\n-->\r\n<script lang=\"ts\">\r\n import { DEV } from 'esm-env';\r\n import { cn } from '../../utils/classNames.js';\r\n import { createLogger } from '../../utils/logger.js';\r\n\r\n const log = createLogger('Image');\r\n\r\n // Silence the dev CLS nudge under the test runner (the suite intentionally\r\n // renders without dimensions to exercise other behaviour). Reads the Node\r\n // env var Vitest sets — bundler-agnostic.\r\n const IS_TEST =\r\n typeof process !== 'undefined' && !!process.env?.VITEST;\r\n\r\n interface Props {\r\n /** Image source URL. When empty/missing, falls back to `fallback`. */\r\n src?: string;\r\n /** Alt text. Empty string marks decorative images per WCAG. */\r\n alt?: string;\r\n /** Additional CSS classes (sizing, shape, rounded corners). Wins last. */\r\n class?: string;\r\n /** Fallback URL used when src is empty or errors (before the branded mark). */\r\n fallback?: string;\r\n /** Loading strategy. Default 'lazy'; pass 'eager' for above-fold. */\r\n loading?: 'eager' | 'lazy';\r\n /**\r\n * Framing mode. Default `'blur-backdrop'` — `object-fit: contain` over a\r\n * blurred copy of the same image so tall AND wide sources are never\r\n * cropped and never letterboxed with flat gray. The remaining values are\r\n * escape hatches that render a plain single `<img object-fit:…>`.\r\n */\r\n fit?: 'blur-backdrop' | 'contain' | 'cover' | 'fill' | 'none' | 'scale-down';\r\n /**\r\n * Intrinsic width in CSS px — reserves space before load (zero CLS) and\r\n * sets the `<img width>` attribute. Pair with `height` for a fixed box.\r\n */\r\n width?: number;\r\n /**\r\n * Intrinsic height in CSS px — reserves space before load (zero CLS) and\r\n * sets the `<img height>` attribute. Pair with `width` for a fixed box.\r\n */\r\n height?: number;\r\n /**\r\n * CSS `aspect-ratio` string (e.g. `'2/3'` posters, `'16/9'` banners,\r\n * `'1'` square). Reserves space before load when you size by one axis\r\n * (`w-full`) — the zero-CLS path for fluid layouts.\r\n */\r\n aspectRatio?: string;\r\n /**\r\n * Blur-up loading: render blurred, then sharpen once the real bitmap\r\n * decodes. Default true. Set false to skip the effect (e.g. tiny icons\r\n * where the blur is imperceptible but the extra work isn't worth it).\r\n */\r\n blurUp?: boolean;\r\n /**\r\n * When the fallback chain is exhausted, show the branded Micdrop mark on\r\n * a tint. Default true. Set false for a plain tinted placeholder.\r\n */\r\n branded?: boolean;\r\n /** Forwarded to `<img draggable>`. Omitted when undefined. */\r\n draggable?: boolean;\r\n /** Forwarded to the `<img>` load event. */\r\n // eslint-disable-next-line no-unused-vars -- intentionally retained (prop/slot/forward-compat or Svelte-5 reactive binding eslint cannot see)\r\n onload?: (e: Event) => void;\r\n /** Forwarded to `<img fetchpriority>` (fetch-priority resource hint). */\r\n fetchpriority?: 'high' | 'low' | 'auto';\r\n /**\r\n * Fires once when the fallback chain is exhausted and the branded\r\n * placeholder takes over — NOT on the first error if a distinct\r\n * `fallback` is still going to be tried. Composes with the internal\r\n * `onerror` machine.\r\n */\r\n onError?: () => void;\r\n }\r\n\r\n let {\r\n src = '',\r\n alt = '',\r\n class: className = '',\r\n fallback = '',\r\n loading = 'lazy',\r\n fit = 'blur-backdrop',\r\n width,\r\n height,\r\n aspectRatio,\r\n blurUp = true,\r\n branded = true,\r\n draggable,\r\n onload,\r\n fetchpriority,\r\n onError,\r\n }: Props = $props();\r\n\r\n // Track loading attempts: which URL we're showing right now.\r\n // When the current URL errors, drop to 'failed' and render the placeholder.\r\n // Distinct from src/fallback inputs because we need to remember which\r\n // candidate we already tried. Reset whenever inputs change.\r\n let attempt: 'src' | 'fallback' | 'failed' = $state(\r\n // eslint-disable-next-line svelte/valid-compile -- known Svelte compiler note, accepted for this primitive\r\n src ? 'src' : fallback ? 'fallback' : 'failed'\r\n );\r\n\r\n // Guard so `onError` fires at most once per input set, even if a stale\r\n // <img> re-emits a duplicate final `error`. Reset when inputs change so a\r\n // fresh src/fallback can legitimately fail-and-notify again.\r\n let notifiedError = $state(false);\r\n\r\n // Blur-up: starts blurred, sharpens once the real bitmap decodes. Reset on\r\n // every new candidate URL so each swap re-runs the blur-up reveal.\r\n let decoded = $state(false);\r\n\r\n $effect(() => {\r\n // Re-derive when inputs change. (Read both to register dependencies.)\r\n const _s = src;\r\n const _f = fallback;\r\n attempt = _s ? 'src' : _f ? 'fallback' : 'failed';\r\n notifiedError = false;\r\n decoded = false;\r\n });\r\n\r\n let activeSrc = $derived(\r\n attempt === 'src' ? src : attempt === 'fallback' ? fallback : ''\r\n );\r\n let showImg = $derived(attempt !== 'failed' && !!activeSrc);\r\n\r\n // blur-backdrop is the only framing mode that wraps; everything else is a\r\n // plain single <img object-fit:…> (identical DOM to the legacy component).\r\n let backdrop = $derived(fit === 'blur-backdrop');\r\n let objectFit = $derived(backdrop ? 'contain' : fit);\r\n\r\n // Does the consumer reserve a DEFINITE box — one that fixes the rendered\r\n // HEIGHT before the bitmap's intrinsic dimensions are known? Only these\r\n // prevent vertical CLS:\r\n // - aspectRatio (height derives from width via the ratio), OR\r\n // - both width AND height (a fully fixed box), OR\r\n // - a `size-*` utility (sets width AND height together), OR\r\n // - a definite height / aspect-ratio class (`h-*`, `aspect-*`).\r\n // Deliberately NOT counted: width alone, `w-full`, `max-h-*`, `h-auto`,\r\n // AND `min-h-*` — min-h only reserves a FLOOR, so a taller bitmap still\r\n // grows the box and shifts the page. None of these reserve the actual\r\n // vertical extent before metadata, so CLS can still creep in.\r\n const DEFINITE_BOX_CLASS = /(?:^|\\s)(?:aspect-|size-|h-(?!auto\\b))/;\r\n let hasReservedBox = $derived(\r\n !!aspectRatio ||\r\n (width != null && height != null) ||\r\n DEFINITE_BOX_CLASS.test(className)\r\n );\r\n\r\n // Dev-only nudge: without a definite box we cannot reserve VERTICAL space,\r\n // so CLS can creep back in. Warn, never throw.\r\n $effect(() => {\r\n // Dev-only (tree-shaken from prod via esm-env DEV) and never under test.\r\n if (DEV && !IS_TEST && !hasReservedBox) {\r\n log.warn(\r\n 'No aspectRatio, no width+height pair, and no definite height/aspect ' +\r\n 'sizing class — vertical layout space cannot be reserved and the ' +\r\n 'page may shift when the image loads (CLS). Pass aspectRatio=\"2/3\", ' +\r\n 'both width and height, or an h-*/aspect-* class. (width alone or ' +\r\n 'w-full does not reserve vertical space.)'\r\n );\r\n }\r\n });\r\n\r\n // Reserve intrinsic space on the box that owns layout. For blur-backdrop\r\n // that's the wrapper; for the plain path it's the <img> itself.\r\n let reserveStyle = $derived(\r\n [\r\n width != null ? `width:${width}px` : '',\r\n height != null ? `height:${height}px` : '',\r\n aspectRatio ? `aspect-ratio:${aspectRatio}` : '',\r\n ]\r\n .filter(Boolean)\r\n .join(';')\r\n );\r\n\r\n // mark the real bitmap as decoded → triggers the blur→sharp fade.\r\n async function handleLoad(e: Event) {\r\n const img = e.currentTarget as HTMLImageElement;\r\n // Capture which URL this load is FOR. If `src` swaps mid-decode (the\r\n // active candidate changes), this stale resolution must NOT sharpen — or\r\n // fire onload for — the new image. Compare against the live activeSrc\r\n // after the await and bail if it moved on.\r\n const loadedSrc = activeSrc;\r\n try {\r\n // decode() resolves once the bitmap is paint-ready; avoids revealing a\r\n // half-painted image. Falls through if unsupported / aborted.\r\n await img.decode?.();\r\n } catch {\r\n // decode can reject on detached/aborted images — reveal anyway.\r\n }\r\n // Src swapped while we awaited decode() → this is a stale load. Drop it;\r\n // the new candidate's own load event will drive the reveal.\r\n if (activeSrc !== loadedSrc) return;\r\n decoded = true;\r\n onload?.(e);\r\n }\r\n\r\n function handleError() {\r\n // If we were on src and have a distinct fallback to try, advance.\r\n if (attempt === 'src' && fallback && fallback !== src) {\r\n attempt = 'fallback';\r\n return;\r\n }\r\n // Either fallback already attempted, or no distinct fallback exists.\r\n // The chain is exhausted — the branded placeholder takes over. Notify the\r\n // consumer exactly here (final failure only), never on the transient\r\n // src→fallback hop, and at most once per input set.\r\n attempt = 'failed';\r\n if (!notifiedError) {\r\n notifiedError = true;\r\n onError?.();\r\n }\r\n }\r\n</script>\r\n\r\n{#if showImg && backdrop}\r\n <!-- blur-backdrop framing (default): contain + same-image blurred fill.\r\n The wrapper owns layout + reserves space; the blur layer is a second\r\n cheap reuse of the already-fetched bitmap (no extra network fetch). -->\r\n <div\r\n class={cn('sc-image sc-image--backdrop', className)}\r\n class:sc-image--backdrop-reserved={hasReservedBox}\r\n style={reserveStyle || undefined}\r\n >\r\n <img\r\n src={activeSrc}\r\n alt=\"\"\r\n class=\"sc-image__blur\"\r\n aria-hidden=\"true\"\r\n decoding=\"async\"\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n />\r\n <img\r\n src={activeSrc}\r\n {alt}\r\n class=\"sc-image__main\"\r\n class:sc-image__main--reserved={hasReservedBox}\r\n class:sc-image__main--loading={blurUp && !decoded}\r\n style:object-fit={objectFit}\r\n {width}\r\n {height}\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n decoding=\"async\"\r\n onerror={handleError}\r\n onload={handleLoad}\r\n />\r\n </div>\r\n{:else if showImg}\r\n <!-- escape-hatch framing (cover/contain/fill/none/scale-down): plain single\r\n <img>, identical DOM to the legacy component, plus blur-up + dims. -->\r\n <img\r\n src={activeSrc}\r\n {alt}\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n {width}\r\n {height}\r\n class={cn(\r\n 'sc-image image',\r\n blurUp && !decoded && 'sc-image--loading',\r\n className\r\n )}\r\n style:object-fit={objectFit}\r\n style:aspect-ratio={aspectRatio || undefined}\r\n decoding=\"async\"\r\n onerror={handleError}\r\n onload={handleLoad}\r\n />\r\n{:else}\r\n <!-- No usable src — branded placeholder (Micdrop mark on a tint), or a plain\r\n tinted box when branded={false}. Empty alt marks decorative images (per\r\n WCAG); hide from assistive tech via aria-hidden + no role. -->\r\n {#if alt}\r\n <div\r\n class={cn(\r\n 'sc-image image sc-image-placeholder image-placeholder',\r\n branded && 'sc-image-placeholder--branded',\r\n className\r\n )}\r\n style={reserveStyle || undefined}\r\n role=\"img\"\r\n aria-label={alt}\r\n ></div>\r\n {:else}\r\n <div\r\n class={cn(\r\n 'sc-image image sc-image-placeholder image-placeholder',\r\n branded && 'sc-image-placeholder--branded',\r\n className\r\n )}\r\n style={reserveStyle || undefined}\r\n aria-hidden=\"true\"\r\n ></div>\r\n {/if}\r\n{/if}\r\n\r\n<style>\r\n /* `.image` is a legacy back-compat alias of `.sc-image` on the plain\r\n escape-hatch <img> + placeholder (consumer CSS / tests may target it). */\r\n .sc-image,\r\n .image {\r\n display: block;\r\n max-width: 100%;\r\n }\r\n\r\n /* --- blur-backdrop framing --- */\r\n .sc-image--backdrop {\r\n position: relative;\r\n overflow: hidden;\r\n container-type: inline-size;\r\n background: hsl(var(--bg-quaternary));\r\n }\r\n\r\n .sc-image__blur {\r\n position: absolute;\r\n inset: 0;\r\n width: 100%;\r\n height: 100%;\r\n max-width: none;\r\n object-fit: cover;\r\n transform: scale(1.15);\r\n filter: blur(16px) saturate(1.2);\r\n /* purely decorative fill; the absolutely-positioned blur paints first and\r\n the in-flow main layer (position:relative) stacks above it by source\r\n order — no explicit z-index needed. */\r\n }\r\n\r\n /* Small containers (<=80px): blur() applies before scale() in the render\r\n pipeline, so the blur halo gets scaled too. Need enough scale that the\r\n opaque image extends past the container edge even after the halo grows. */\r\n @container (max-width: 5rem) {\r\n .sc-image__blur {\r\n transform: scale(2);\r\n filter: blur(6px) saturate(1.2);\r\n }\r\n }\r\n\r\n .sc-image__main {\r\n position: relative;\r\n display: block;\r\n width: 100%;\r\n /* No reserved box (legacy / no-fit default): the in-flow main image\r\n DRIVES the wrapper height and sizes ITSELF to the consumer's sizing\r\n classes — which land on the wrapper. `max-height: inherit` /\r\n `max-width: inherit` pull the wrapper's `max-h-*` / `max-w-*` onto the\r\n image so object-fit:contain shrinks it to fit (image height == wrapper\r\n height). The image therefore NEVER exceeds the wrapper, so the wrapper's\r\n overflow:hidden (which clips the decorative blur fill) cannot clip the\r\n MAIN image — it renders exactly as the pre-premium single <img> did,\r\n constrained by max-h-* / h-auto, no reflow. Only force the image to fill\r\n a fixed box when the consumer reserved a DEFINITE one (explicit height /\r\n aspectRatio / size-* / h-* / aspect-*) — there the wrapper owns layout\r\n and the image fills it (true zero-CLS letterbox). */\r\n height: auto;\r\n max-width: inherit;\r\n max-height: inherit;\r\n object-fit: contain;\r\n }\r\n\r\n .sc-image--backdrop-reserved .sc-image__main--reserved {\r\n height: 100%;\r\n max-width: none;\r\n max-height: none;\r\n }\r\n\r\n /* --- blur-up reveal (CSS-only; reduced-motion gated via motion tokens) ---\r\n The main image / plain image starts slightly blurred + scaled and\r\n sharpens on decode. Durations read from --motion-* so\r\n prefers-reduced-motion collapses them. */\r\n .sc-image--loading,\r\n .sc-image__main {\r\n transition:\r\n filter var(--motion-normal, 300ms) var(--ease-out, ease),\r\n transform var(--motion-normal, 300ms) var(--ease-out, ease);\r\n }\r\n\r\n .sc-image--loading,\r\n .sc-image__main--loading {\r\n filter: blur(12px);\r\n transform: scale(1.02);\r\n }\r\n\r\n /* --- placeholder --- */\r\n .sc-image-placeholder {\r\n background: hsl(var(--bg-quaternary));\r\n }\r\n\r\n .sc-image-placeholder--branded {\r\n background-color: hsl(var(--bg-tertiary));\r\n background-image: url('../../assets/images/micdrop-logo.png');\r\n background-repeat: no-repeat;\r\n background-position: center;\r\n /* keep the mark a small, calm watermark — never edge-to-edge */\r\n background-size: min(48%, 96px) auto;\r\n opacity: 0.92;\r\n }\r\n</style>\r\n","<script lang=\"ts\">\r\n import type { Snippet } from 'svelte';\r\n\r\n interface Props {\r\n as?: 'span' | 'p' | 'label' | 'div';\r\n size?: 'xs' | 'sm' | 'base' | 'md' | 'lg' | 'xl' | '2xl';\r\n leading?: 'none' | 'tight' | 'snug' | 'normal' | 'relaxed' | 'loose';\r\n color?: 'default' | 'muted' | 'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'none';\r\n weight?: 'normal' | 'medium' | 'semibold' | 'bold';\r\n truncate?: boolean;\r\n class?: string;\r\n children: Snippet;\r\n }\r\n\r\n let {\r\n as = 'span',\r\n size = 'md',\r\n leading,\r\n color = 'default',\r\n weight = 'normal',\r\n truncate = false,\r\n class: className = '',\r\n children,\r\n }: Props = $props();\r\n\r\n const sizeClasses: Record<string, string> = {\r\n xs: 'text-xs',\r\n sm: 'text-sm',\r\n base: 'text-base',\r\n md: 'text-base',\r\n lg: 'text-lg',\r\n xl: 'text-xl',\r\n '2xl': 'text-2xl',\r\n };\r\n\r\n const colorClasses: Record<string, string> = {\r\n default: 'text-text-primary',\r\n muted: 'text-muted-foreground',\r\n primary: 'text-primary-600',\r\n secondary: 'text-text-secondary',\r\n success: 'text-accent-success',\r\n warning: 'text-accent-warning',\r\n error: 'text-accent-danger',\r\n none: '',\r\n };\r\n\r\n const leadingClasses: Record<string, string> = {\r\n none: 'leading-none',\r\n tight: 'leading-tight',\r\n snug: 'leading-snug',\r\n normal: 'leading-normal',\r\n relaxed: 'leading-relaxed',\r\n loose: 'leading-loose',\r\n };\r\n\r\n const weightClasses: Record<string, string> = {\r\n normal: 'font-normal',\r\n medium: 'font-medium',\r\n semibold: 'font-semibold',\r\n bold: 'font-bold',\r\n };\r\n\r\n let classes = $derived(\r\n [\r\n sizeClasses[size] || 'text-base',\r\n leading ? leadingClasses[leading] : '',\r\n colorClasses[color] || '',\r\n weightClasses[weight],\r\n truncate ? 'truncate' : '',\r\n className,\r\n ]\r\n .filter(Boolean)\r\n .join(' '),\r\n );\r\n</script>\r\n\r\n<svelte:element this={as} class={classes}>{@render children()}</svelte:element>\r\n"],"names":["createLogger","src","$","$$props","alt","className","fallback","loading","fit","blurUp","branded","attempt","notifiedError","decoded","_s","_f","activeSrc","showImg","backdrop","objectFit","DEFINITE_BOX_CLASS","hasReservedBox","reserveStyle","handleLoad","e","img","loadedSrc","handleError","div","root","img_1","img_2","classes","classes_1","styles","cn","img_3","root_1","$0","styles_1","div_1","root_2","div_2","root_3","$$render","consequent_2","alternate","consequent","consequent_1","alternate_1","as","size","color","weight","truncate","sizeClasses","colorClasses","leadingClasses","weightClasses","$$element","$$anchor"],"mappings":"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","x_google_ignoreList":[0,1]}
1
+ {"version":3,"file":"Text-DHgQP4rA.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Image/Image.svelte","../node_modules/@getmicdrop/svelte-components/dist/components/Text.svelte"],"sourcesContent":["<!--\r\n Image.svelte\r\n\r\n The canonical image primitive for Micdrop. Variable-aspect, user-uploaded\r\n sources (event posters, performer headshots, venue photos) where we do NOT\r\n control the aspect ratio. This component is now the single home for the\r\n whole image family — `Avatar` composes it, and `BlurBackdropImage` is a\r\n thin `@deprecated` shim.\r\n\r\n Premium contract (Atlas brief 04 — perf 5 / completeness 5):\r\n\r\n 1. ZERO CLS — pass `width`/`height` (intrinsic px) or `aspectRatio`\r\n (e.g. `'2/3'`, `'16/9'`, `'1'`). The component reserves that space\r\n BEFORE the image loads so the page never reflows when it arrives.\r\n Dev-only `console.warn` if you provide neither dimensions nor a\r\n sizing class (we can't reserve space and CLS can creep back in).\r\n\r\n 2. BLUR-UP LOADING — the main image starts slightly blurred and SHARPENS\r\n (blur → 0) once the real bitmap has decoded (`img.decode()` +\r\n `decoding=\"async\"`). In blur-backdrop framing a blurred copy of the\r\n SAME already-fetched bitmap fills the letterbox gaps — no second\r\n network fetch, no LQIP asset to ship. Fade timing reads the motion\r\n tokens, so `prefers-reduced-motion` collapses it automatically.\r\n\r\n 3. BLUR-BACKDROP IS THE DEFAULT FRAMING — `fit` defaults to\r\n `'blur-backdrop'`: the image is `object-fit: contain` (never cropped)\r\n and a blurred copy of itself fills the letterbox gaps. This handles\r\n BOTH tall posters and wide photos with no cropping and no flat-gray\r\n bars. `'cover'` / `'contain'` / `'fill'` / `'scale-down'` / `'none'`\r\n remain as escape hatches and render the plain single-`<img>` path\r\n (identical DOM to the pre-premium component).\r\n\r\n 4. BRANDED FALLBACK — when `src` (and `fallback`) are missing or both\r\n error, we render a branded placeholder (the Micdrop mark on a tint)\r\n instead of a flat gray div. Override the asset with `fallback`, or\r\n suppress the mark with `branded={false}`.\r\n\r\n Passthrough props for raw-<img> parity (so consumers can migrate\r\n existing `<img>` sites to `<Image>`):\r\n - `draggable` — forwarded to the underlying `<img draggable>`.\r\n - `onload` — forwarded to the `<img>` load event.\r\n - `fetchpriority` — forwarded to `<img fetchpriority>` (resource hint).\r\n - `onError` — fires ONCE, only after the internal fallback chain is\r\n exhausted (i.e. the branded placeholder takes over). It does NOT fire\r\n on the first error while a distinct `fallback` is still going to be\r\n tried. The raw `onerror` handler stays owned internally to drive the\r\n src→fallback→placeholder degradation; `onError` composes with it\r\n rather than replacing it.\r\n Deliberately NOT exposed: `srcset`/`sizes` — zero consumer demand.\r\n\r\n Example:\r\n <Image src={event.posterUrl} alt={event.name} aspectRatio=\"2/3\" class=\"w-full rounded-xl\" />\r\n <Image src={user.avatarUrl} alt={user.name} width={80} height={80} fit=\"cover\" class=\"rounded-full\" />\r\n <Image src={banner.url} alt=\"\" aspectRatio=\"16/9\" class=\"w-full\" loading=\"eager\" fetchpriority=\"high\" />\r\n-->\r\n<script lang=\"ts\">\r\n import { DEV } from 'esm-env';\r\n import { cn } from '../../utils/classNames.js';\r\n import { createLogger } from '../../utils/logger.js';\r\n\r\n const log = createLogger('Image');\r\n\r\n // Silence the dev CLS nudge under the test runner (the suite intentionally\r\n // renders without dimensions to exercise other behaviour). Reads the Node\r\n // env var Vitest sets — bundler-agnostic.\r\n const IS_TEST =\r\n typeof process !== 'undefined' && !!process.env?.VITEST;\r\n\r\n interface Props {\r\n /** Image source URL. When empty/missing, falls back to `fallback`. */\r\n src?: string;\r\n /** Alt text. Empty string marks decorative images per WCAG. */\r\n alt?: string;\r\n /** Additional CSS classes (sizing, shape, rounded corners). Wins last. */\r\n class?: string;\r\n /** Fallback URL used when src is empty or errors (before the branded mark). */\r\n fallback?: string;\r\n /** Loading strategy. Default 'lazy'; pass 'eager' for above-fold. */\r\n loading?: 'eager' | 'lazy';\r\n /**\r\n * Framing mode. Default `'blur-backdrop'` — `object-fit: contain` over a\r\n * blurred copy of the same image so tall AND wide sources are never\r\n * cropped and never letterboxed with flat gray. The remaining values are\r\n * escape hatches that render a plain single `<img object-fit:…>`.\r\n */\r\n fit?: 'blur-backdrop' | 'contain' | 'cover' | 'fill' | 'none' | 'scale-down';\r\n /**\r\n * Intrinsic width in CSS px — reserves space before load (zero CLS) and\r\n * sets the `<img width>` attribute. Pair with `height` for a fixed box.\r\n */\r\n width?: number;\r\n /**\r\n * Intrinsic height in CSS px — reserves space before load (zero CLS) and\r\n * sets the `<img height>` attribute. Pair with `width` for a fixed box.\r\n */\r\n height?: number;\r\n /**\r\n * CSS `aspect-ratio` string (e.g. `'2/3'` posters, `'16/9'` banners,\r\n * `'1'` square). Reserves space before load when you size by one axis\r\n * (`w-full`) — the zero-CLS path for fluid layouts.\r\n */\r\n aspectRatio?: string;\r\n /**\r\n * Blur-up loading: render blurred, then sharpen once the real bitmap\r\n * decodes. Default true. Set false to skip the effect (e.g. tiny icons\r\n * where the blur is imperceptible but the extra work isn't worth it).\r\n */\r\n blurUp?: boolean;\r\n /**\r\n * When the fallback chain is exhausted, show the branded Micdrop mark on\r\n * a tint. Default true. Set false for a plain tinted placeholder.\r\n */\r\n branded?: boolean;\r\n /** Forwarded to `<img draggable>`. Omitted when undefined. */\r\n draggable?: boolean;\r\n /** Forwarded to the `<img>` load event. */\r\n // eslint-disable-next-line no-unused-vars -- intentionally retained (prop/slot/forward-compat or Svelte-5 reactive binding eslint cannot see)\r\n onload?: (e: Event) => void;\r\n /** Forwarded to `<img fetchpriority>` (fetch-priority resource hint). */\r\n fetchpriority?: 'high' | 'low' | 'auto';\r\n /**\r\n * Fires once when the fallback chain is exhausted and the branded\r\n * placeholder takes over — NOT on the first error if a distinct\r\n * `fallback` is still going to be tried. Composes with the internal\r\n * `onerror` machine.\r\n */\r\n onError?: () => void;\r\n }\r\n\r\n let {\r\n src = '',\r\n alt = '',\r\n class: className = '',\r\n fallback = '',\r\n loading = 'lazy',\r\n fit = 'blur-backdrop',\r\n width,\r\n height,\r\n aspectRatio,\r\n blurUp = true,\r\n branded = true,\r\n draggable,\r\n onload,\r\n fetchpriority,\r\n onError,\r\n }: Props = $props();\r\n\r\n // Track loading attempts: which URL we're showing right now.\r\n // When the current URL errors, drop to 'failed' and render the placeholder.\r\n // Distinct from src/fallback inputs because we need to remember which\r\n // candidate we already tried. Reset whenever inputs change.\r\n let attempt: 'src' | 'fallback' | 'failed' = $state(\r\n // eslint-disable-next-line svelte/valid-compile -- known Svelte compiler note, accepted for this primitive\r\n src ? 'src' : fallback ? 'fallback' : 'failed'\r\n );\r\n\r\n // Guard so `onError` fires at most once per input set, even if a stale\r\n // <img> re-emits a duplicate final `error`. Reset when inputs change so a\r\n // fresh src/fallback can legitimately fail-and-notify again.\r\n let notifiedError = $state(false);\r\n\r\n // Blur-up: starts blurred, sharpens once the real bitmap decodes. Reset on\r\n // every new candidate URL so each swap re-runs the blur-up reveal.\r\n let decoded = $state(false);\r\n\r\n $effect(() => {\r\n // Re-derive when inputs change. (Read both to register dependencies.)\r\n const _s = src;\r\n const _f = fallback;\r\n attempt = _s ? 'src' : _f ? 'fallback' : 'failed';\r\n notifiedError = false;\r\n decoded = false;\r\n });\r\n\r\n let activeSrc = $derived(\r\n attempt === 'src' ? src : attempt === 'fallback' ? fallback : ''\r\n );\r\n let showImg = $derived(attempt !== 'failed' && !!activeSrc);\r\n\r\n // blur-backdrop is the only framing mode that wraps; everything else is a\r\n // plain single <img object-fit:…> (identical DOM to the legacy component).\r\n let backdrop = $derived(fit === 'blur-backdrop');\r\n let objectFit = $derived(backdrop ? 'contain' : fit);\r\n\r\n // Does the consumer reserve a DEFINITE box — one that fixes the rendered\r\n // HEIGHT before the bitmap's intrinsic dimensions are known? Only these\r\n // prevent vertical CLS:\r\n // - aspectRatio (height derives from width via the ratio), OR\r\n // - both width AND height (a fully fixed box), OR\r\n // - a `size-*` utility (sets width AND height together), OR\r\n // - a definite height / aspect-ratio class (`h-*`, `aspect-*`).\r\n // Deliberately NOT counted: width alone, `w-full`, `max-h-*`, `h-auto`,\r\n // AND `min-h-*` — min-h only reserves a FLOOR, so a taller bitmap still\r\n // grows the box and shifts the page. None of these reserve the actual\r\n // vertical extent before metadata, so CLS can still creep in.\r\n const DEFINITE_BOX_CLASS = /(?:^|\\s)(?:aspect-|size-|h-(?!auto\\b))/;\r\n let hasReservedBox = $derived(\r\n !!aspectRatio ||\r\n (width != null && height != null) ||\r\n DEFINITE_BOX_CLASS.test(className)\r\n );\r\n\r\n // Dev-only nudge: without a definite box we cannot reserve VERTICAL space,\r\n // so CLS can creep back in. Warn, never throw.\r\n $effect(() => {\r\n // Dev-only (tree-shaken from prod via esm-env DEV) and never under test.\r\n if (DEV && !IS_TEST && !hasReservedBox) {\r\n log.warn(\r\n 'No aspectRatio, no width+height pair, and no definite height/aspect ' +\r\n 'sizing class — vertical layout space cannot be reserved and the ' +\r\n 'page may shift when the image loads (CLS). Pass aspectRatio=\"2/3\", ' +\r\n 'both width and height, or an h-*/aspect-* class. (width alone or ' +\r\n 'w-full does not reserve vertical space.)'\r\n );\r\n }\r\n });\r\n\r\n // Reserve intrinsic space on the box that owns layout. For blur-backdrop\r\n // that's the wrapper; for the plain path it's the <img> itself.\r\n let reserveStyle = $derived(\r\n [\r\n width != null ? `width:${width}px` : '',\r\n height != null ? `height:${height}px` : '',\r\n aspectRatio ? `aspect-ratio:${aspectRatio}` : '',\r\n ]\r\n .filter(Boolean)\r\n .join(';')\r\n );\r\n\r\n // mark the real bitmap as decoded → triggers the blur→sharp fade.\r\n async function handleLoad(e: Event) {\r\n const img = e.currentTarget as HTMLImageElement;\r\n // Capture which URL this load is FOR. If `src` swaps mid-decode (the\r\n // active candidate changes), this stale resolution must NOT sharpen — or\r\n // fire onload for — the new image. Compare against the live activeSrc\r\n // after the await and bail if it moved on.\r\n const loadedSrc = activeSrc;\r\n try {\r\n // decode() resolves once the bitmap is paint-ready; avoids revealing a\r\n // half-painted image. Falls through if unsupported / aborted.\r\n await img.decode?.();\r\n } catch {\r\n // decode can reject on detached/aborted images — reveal anyway.\r\n }\r\n // Src swapped while we awaited decode() → this is a stale load. Drop it;\r\n // the new candidate's own load event will drive the reveal.\r\n if (activeSrc !== loadedSrc) return;\r\n decoded = true;\r\n onload?.(e);\r\n }\r\n\r\n function handleError() {\r\n // If we were on src and have a distinct fallback to try, advance.\r\n if (attempt === 'src' && fallback && fallback !== src) {\r\n attempt = 'fallback';\r\n return;\r\n }\r\n // Either fallback already attempted, or no distinct fallback exists.\r\n // The chain is exhausted — the branded placeholder takes over. Notify the\r\n // consumer exactly here (final failure only), never on the transient\r\n // src→fallback hop, and at most once per input set.\r\n attempt = 'failed';\r\n if (!notifiedError) {\r\n notifiedError = true;\r\n onError?.();\r\n }\r\n }\r\n</script>\r\n\r\n{#if showImg && backdrop}\r\n <!-- blur-backdrop framing (default): contain + same-image blurred fill.\r\n The wrapper owns layout + reserves space; the blur layer is a second\r\n cheap reuse of the already-fetched bitmap (no extra network fetch). -->\r\n <div\r\n class={cn('sc-image sc-image--backdrop', className)}\r\n class:sc-image--backdrop-reserved={hasReservedBox}\r\n style={reserveStyle || undefined}\r\n >\r\n <img\r\n src={activeSrc}\r\n alt=\"\"\r\n class=\"sc-image__blur\"\r\n aria-hidden=\"true\"\r\n decoding=\"async\"\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n />\r\n <img\r\n src={activeSrc}\r\n {alt}\r\n class=\"sc-image__main\"\r\n class:sc-image__main--reserved={hasReservedBox}\r\n class:sc-image__main--loading={blurUp && !decoded}\r\n style:object-fit={objectFit}\r\n {width}\r\n {height}\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n decoding=\"async\"\r\n onerror={handleError}\r\n onload={handleLoad}\r\n />\r\n </div>\r\n{:else if showImg}\r\n <!-- escape-hatch framing (cover/contain/fill/none/scale-down): plain single\r\n <img>, identical DOM to the legacy component, plus blur-up + dims. -->\r\n <img\r\n src={activeSrc}\r\n {alt}\r\n {loading}\r\n {draggable}\r\n {fetchpriority}\r\n {width}\r\n {height}\r\n class={cn(\r\n 'sc-image image',\r\n blurUp && !decoded && 'sc-image--loading',\r\n className\r\n )}\r\n style:object-fit={objectFit}\r\n style:aspect-ratio={aspectRatio || undefined}\r\n decoding=\"async\"\r\n onerror={handleError}\r\n onload={handleLoad}\r\n />\r\n{:else}\r\n <!-- No usable src — branded placeholder (Micdrop mark on a tint), or a plain\r\n tinted box when branded={false}. Empty alt marks decorative images (per\r\n WCAG); hide from assistive tech via aria-hidden + no role. -->\r\n {#if alt}\r\n <div\r\n class={cn(\r\n 'sc-image image sc-image-placeholder image-placeholder',\r\n branded && 'sc-image-placeholder--branded',\r\n className\r\n )}\r\n style={reserveStyle || undefined}\r\n role=\"img\"\r\n aria-label={alt}\r\n ></div>\r\n {:else}\r\n <div\r\n class={cn(\r\n 'sc-image image sc-image-placeholder image-placeholder',\r\n branded && 'sc-image-placeholder--branded',\r\n className\r\n )}\r\n style={reserveStyle || undefined}\r\n aria-hidden=\"true\"\r\n ></div>\r\n {/if}\r\n{/if}\r\n\r\n<style>\r\n /* `.image` is a legacy back-compat alias of `.sc-image` on the plain\r\n escape-hatch <img> + placeholder (consumer CSS / tests may target it). */\r\n .sc-image,\r\n .image {\r\n display: block;\r\n max-width: 100%;\r\n }\r\n\r\n /* --- blur-backdrop framing --- */\r\n .sc-image--backdrop {\r\n position: relative;\r\n overflow: hidden;\r\n container-type: inline-size;\r\n background: hsl(var(--bg-quaternary));\r\n }\r\n\r\n .sc-image__blur {\r\n position: absolute;\r\n inset: 0;\r\n width: 100%;\r\n height: 100%;\r\n max-width: none;\r\n object-fit: cover;\r\n transform: scale(1.15);\r\n filter: blur(16px) saturate(1.2);\r\n /* purely decorative fill; the absolutely-positioned blur paints first and\r\n the in-flow main layer (position:relative) stacks above it by source\r\n order — no explicit z-index needed. */\r\n }\r\n\r\n /* Small containers (<=80px): blur() applies before scale() in the render\r\n pipeline, so the blur halo gets scaled too. Need enough scale that the\r\n opaque image extends past the container edge even after the halo grows. */\r\n @container (max-width: 5rem) {\r\n .sc-image__blur {\r\n transform: scale(2);\r\n filter: blur(6px) saturate(1.2);\r\n }\r\n }\r\n\r\n .sc-image__main {\r\n position: relative;\r\n display: block;\r\n width: 100%;\r\n /* No reserved box (legacy / no-fit default): the in-flow main image\r\n DRIVES the wrapper height and sizes ITSELF to the consumer's sizing\r\n classes — which land on the wrapper. `max-height: inherit` /\r\n `max-width: inherit` pull the wrapper's `max-h-*` / `max-w-*` onto the\r\n image so object-fit:contain shrinks it to fit (image height == wrapper\r\n height). The image therefore NEVER exceeds the wrapper, so the wrapper's\r\n overflow:hidden (which clips the decorative blur fill) cannot clip the\r\n MAIN image — it renders exactly as the pre-premium single <img> did,\r\n constrained by max-h-* / h-auto, no reflow. Only force the image to fill\r\n a fixed box when the consumer reserved a DEFINITE one (explicit height /\r\n aspectRatio / size-* / h-* / aspect-*) — there the wrapper owns layout\r\n and the image fills it (true zero-CLS letterbox). */\r\n height: auto;\r\n max-width: inherit;\r\n max-height: inherit;\r\n object-fit: contain;\r\n }\r\n\r\n .sc-image--backdrop-reserved .sc-image__main--reserved {\r\n height: 100%;\r\n max-width: none;\r\n max-height: none;\r\n }\r\n\r\n /* --- blur-up reveal (CSS-only; reduced-motion gated via motion tokens) ---\r\n The main image / plain image starts slightly blurred + scaled and\r\n sharpens on decode. Durations read from --motion-* so\r\n prefers-reduced-motion collapses them. */\r\n .sc-image--loading,\r\n .sc-image__main {\r\n transition:\r\n filter var(--motion-normal, 300ms) var(--ease-out, ease),\r\n transform var(--motion-normal, 300ms) var(--ease-out, ease);\r\n }\r\n\r\n .sc-image--loading,\r\n .sc-image__main--loading {\r\n filter: blur(12px);\r\n transform: scale(1.02);\r\n }\r\n\r\n /* --- placeholder --- */\r\n .sc-image-placeholder {\r\n background: hsl(var(--bg-quaternary));\r\n }\r\n\r\n .sc-image-placeholder--branded {\r\n background-color: hsl(var(--bg-tertiary));\r\n background-image: url('../../assets/images/micdrop-logo.png');\r\n background-repeat: no-repeat;\r\n background-position: center;\r\n /* keep the mark a small, calm watermark — never edge-to-edge */\r\n background-size: min(48%, 96px) auto;\r\n opacity: 0.92;\r\n }\r\n</style>\r\n","<script lang=\"ts\">\r\n import type { Snippet } from 'svelte';\r\n\r\n interface Props {\r\n as?: 'span' | 'p' | 'label' | 'div';\r\n size?: 'xs' | 'sm' | 'base' | 'md' | 'lg' | 'xl' | '2xl';\r\n leading?: 'none' | 'tight' | 'snug' | 'normal' | 'relaxed' | 'loose';\r\n color?: 'default' | 'muted' | 'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'none';\r\n weight?: 'normal' | 'medium' | 'semibold' | 'bold';\r\n truncate?: boolean;\r\n class?: string;\r\n children: Snippet;\r\n }\r\n\r\n let {\r\n as = 'span',\r\n size = 'md',\r\n leading,\r\n color = 'default',\r\n weight = 'normal',\r\n truncate = false,\r\n class: className = '',\r\n children,\r\n }: Props = $props();\r\n\r\n const sizeClasses: Record<string, string> = {\r\n xs: 'text-xs',\r\n sm: 'text-sm',\r\n base: 'text-base',\r\n md: 'text-base',\r\n lg: 'text-lg',\r\n xl: 'text-xl',\r\n '2xl': 'text-2xl',\r\n };\r\n\r\n const colorClasses: Record<string, string> = {\r\n default: 'text-text-primary',\r\n muted: 'text-muted-foreground',\r\n primary: 'text-primary-600',\r\n secondary: 'text-text-secondary',\r\n success: 'text-accent-success',\r\n warning: 'text-accent-warning',\r\n error: 'text-accent-danger',\r\n none: '',\r\n };\r\n\r\n const leadingClasses: Record<string, string> = {\r\n none: 'leading-none',\r\n tight: 'leading-tight',\r\n snug: 'leading-snug',\r\n normal: 'leading-normal',\r\n relaxed: 'leading-relaxed',\r\n loose: 'leading-loose',\r\n };\r\n\r\n const weightClasses: Record<string, string> = {\r\n normal: 'font-normal',\r\n medium: 'font-medium',\r\n semibold: 'font-semibold',\r\n bold: 'font-bold',\r\n };\r\n\r\n let classes = $derived(\r\n [\r\n sizeClasses[size] || 'text-base',\r\n leading ? leadingClasses[leading] : '',\r\n colorClasses[color] || '',\r\n weightClasses[weight],\r\n truncate ? 'truncate' : '',\r\n className,\r\n ]\r\n .filter(Boolean)\r\n .join(' '),\r\n );\r\n</script>\r\n\r\n<svelte:element this={as} class={classes}>{@render children()}</svelte:element>\r\n"],"names":["createLogger","src","$","$$props","alt","className","fallback","loading","fit","blurUp","branded","attempt","notifiedError","decoded","_s","_f","activeSrc","showImg","backdrop","objectFit","DEFINITE_BOX_CLASS","hasReservedBox","reserveStyle","handleLoad","e","img","loadedSrc","handleError","div","root","img_1","img_2","classes","classes_1","styles","cn","img_3","root_1","$0","styles_1","div_1","root_2","div_2","root_3","$$render","consequent_2","alternate","consequent","consequent_1","alternate_1","as","size","color","weight","truncate","sizeClasses","colorClasses","leadingClasses","weightClasses","$$element","$$anchor"],"mappings":"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","x_google_ignoreList":[0,1]}