@getmicdrop/venue-calendar 4.0.86 → 4.0.87

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 (69) hide show
  1. package/README.md +740 -740
  2. package/dist/{CartView-e2hG7cOV.js → CartView-DrfUvXHU.js} +370 -370
  3. package/dist/CartView-DrfUvXHU.js.map +1 -0
  4. package/dist/{Checkout-DmnOMwhl.js → Checkout-BIT0aula.js} +3 -3
  5. package/dist/Checkout-BIT0aula.js.map +1 -0
  6. package/dist/{Checkout-BpTUMyLk.js → Checkout-DNwBnmE3.js} +51 -51
  7. package/dist/Checkout-DNwBnmE3.js.map +1 -0
  8. package/dist/{CheckoutTimer-Dv0c-X6O.js → CheckoutTimer-C50Ahi93.js} +4 -4
  9. package/dist/CheckoutTimer-C50Ahi93.js.map +1 -0
  10. package/dist/{CollectionView-CyxK6aI9.js → CollectionView-W4Atllhp.js} +5 -5
  11. package/dist/CollectionView-W4Atllhp.js.map +1 -0
  12. package/dist/{Event-Cw7b9UEd.js → Event-t3hhfFuJ.js} +10 -7
  13. package/dist/{Event-Cw7b9UEd.js.map → Event-t3hhfFuJ.js.map} +1 -1
  14. package/dist/{EventPage-BKtFiZL1.js → EventPage-CEWppTrK.js} +7 -7
  15. package/dist/EventPage-CEWppTrK.js.map +1 -0
  16. package/dist/Heading-DUg5tgzm.js +91 -0
  17. package/dist/Heading-DUg5tgzm.js.map +1 -0
  18. package/dist/{ModalHeader-V5AlK1dt.js → ModalHeader-DEuHuPK2.js} +2 -2
  19. package/dist/{ModalHeader-V5AlK1dt.js.map → ModalHeader-DEuHuPK2.js.map} +1 -1
  20. package/dist/{ScarcityBadge-Co7gZXuW.js → ScarcityBadge-BVM_XAXR.js} +2 -2
  21. package/dist/ScarcityBadge-BVM_XAXR.js.map +1 -0
  22. package/dist/{SeriesPage-USYe3APQ.js → SeriesPage-Bg4oZ2fA.js} +5 -5
  23. package/dist/SeriesPage-Bg4oZ2fA.js.map +1 -0
  24. package/dist/{Success-C387RvIY.js → Success-DwpMMfeZ.js} +19 -19
  25. package/dist/Success-DwpMMfeZ.js.map +1 -0
  26. package/dist/Text-D4lbf8Z6.js +167 -0
  27. package/dist/{Text-ZUPglf_o.js.map → Text-D4lbf8Z6.js.map} +1 -1
  28. package/dist/{VenueCalendar-tmWZSmhT.js → VenueCalendar-DYnha5wZ.js} +97 -100
  29. package/dist/VenueCalendar-DYnha5wZ.js.map +1 -0
  30. package/dist/{ViewTicketsEmbed--091XJJn.js → ViewTicketsEmbed-mrawQhqD.js} +382 -382
  31. package/dist/ViewTicketsEmbed-mrawQhqD.js.map +1 -0
  32. package/dist/api/api.cjs.map +1 -1
  33. package/dist/api/api.mjs +21 -21
  34. package/dist/api/api.mjs.map +1 -1
  35. package/dist/api/transformers/venue.d.ts +17 -7
  36. package/dist/{data-toggle-store.svelte-Bn0h8FT_.js → data-toggle-store.svelte-CgH3EfQF.js} +2 -2
  37. package/dist/data-toggle-store.svelte-CgH3EfQF.js.map +1 -0
  38. package/dist/{labels-C7Znep_T.js → labels-CV4Mq9xD.js} +3 -3
  39. package/dist/labels-CV4Mq9xD.js.map +1 -0
  40. package/dist/seo/seo.cjs.map +1 -1
  41. package/dist/seo/seo.mjs.map +1 -1
  42. package/dist/{transform-BxgTZDAD.js → transform-DrAudcCa.js} +2 -2
  43. package/dist/transform-DrAudcCa.js.map +1 -0
  44. package/dist/types/index.d.ts +442 -442
  45. package/dist/venue-calendar.css +1 -1
  46. package/dist/venue-calendar.es.js +2 -2
  47. package/dist/venue-calendar.iife.js +21 -21
  48. package/dist/venue-calendar.iife.js.map +1 -1
  49. package/dist/venue-calendar.umd.js +11 -11
  50. package/dist/venue-calendar.umd.js.map +1 -1
  51. package/package.json +2 -2
  52. package/src/lib/theme.js +222 -222
  53. package/dist/CartView-e2hG7cOV.js.map +0 -1
  54. package/dist/Checkout-BpTUMyLk.js.map +0 -1
  55. package/dist/Checkout-DmnOMwhl.js.map +0 -1
  56. package/dist/CheckoutTimer-Dv0c-X6O.js.map +0 -1
  57. package/dist/CollectionView-CyxK6aI9.js.map +0 -1
  58. package/dist/EventPage-BKtFiZL1.js.map +0 -1
  59. package/dist/Heading-D0grC8vd.js +0 -81
  60. package/dist/Heading-D0grC8vd.js.map +0 -1
  61. package/dist/ScarcityBadge-Co7gZXuW.js.map +0 -1
  62. package/dist/SeriesPage-USYe3APQ.js.map +0 -1
  63. package/dist/Success-C387RvIY.js.map +0 -1
  64. package/dist/Text-ZUPglf_o.js +0 -158
  65. package/dist/VenueCalendar-tmWZSmhT.js.map +0 -1
  66. package/dist/ViewTicketsEmbed--091XJJn.js.map +0 -1
  67. package/dist/data-toggle-store.svelte-Bn0h8FT_.js.map +0 -1
  68. package/dist/labels-C7Znep_T.js.map +0 -1
  69. package/dist/transform-BxgTZDAD.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"CollectionView-CyxK6aI9.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/recipes/inputs/PasswordStrengthIndicator/PasswordStrengthIndicator.svelte","../node_modules/@getmicdrop/svelte-components/dist/recipes/inputs/PasswordInput.svelte","../src/components/Views/CollectionView.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n import type { Snippet } from 'svelte';\r\n import { safeSlide } from \"../../../utils/transitions.js\";\r\n import { lazyOnce } from \"../../../utils/lazyOnce.js\";\r\n import { cubicOut } from \"svelte/easing\";\r\n import { untrack } from \"svelte\";\r\n\r\n const defaultLabels = {\r\n tooWeak: 'Too weak',\r\n weak: 'Weak',\r\n good: 'Good',\r\n strong: 'Strong',\r\n };\r\n\r\n interface Props {\r\n password?: string;\r\n strengthText?: string;\r\n score?: number;\r\n textColor?: string;\r\n children?: Snippet;\r\n labels?: Partial<typeof defaultLabels>;\r\n }\r\n\r\n let {\r\n password = \"\",\r\n strengthText = $bindable(\"\"),\r\n score = $bindable(-1),\r\n textColor = $bindable(\"\"),\r\n children,\r\n labels: userLabels = {},\r\n }: Props = $props();\r\n\r\n let labels = $derived({ ...defaultLabels, ...userLabels });\r\n\r\n let debouncedPassword = $state(\"\");\r\n // Use a plain variable for timer to avoid reactive dependency\r\n let timer: ReturnType<typeof setTimeout> | undefined;\r\n\r\n // Lazily load the (~10 KB) strength library only once a password exists.\r\n // Until it resolves, `strengthFn` is null and the indicator shows its\r\n // neutral (no-result) state — the debounce window absorbs the load latency.\r\n //\r\n // lazyOnce memoizes the import on success but RESETS on rejection: a\r\n // transient chunk-load failure must not be cached, or the indicator would\r\n // stay bricked until a page reload. On failure the next keystroke retries.\r\n let strengthFn: typeof import('check-password-strength').passwordStrength | null = $state(null);\r\n const loadStrengthModule = lazyOnce(() => import('check-password-strength'));\r\n function ensureStrengthFn() {\r\n void loadStrengthModule()\r\n .then((m) => {\r\n strengthFn = m.passwordStrength;\r\n })\r\n .catch(() => {\r\n // Swallow — strengthFn stays null (neutral state) and lazyOnce\r\n // has already dropped its memo, so a later keystroke retries.\r\n });\r\n }\r\n\r\n // Kick off the load on the first keystroke, before the debounce fires.\r\n // Retries naturally on subsequent keystrokes after a transient failure\r\n // because lazyOnce does not cache the rejection.\r\n $effect(() => {\r\n if (password && !strengthFn) ensureStrengthFn();\r\n });\r\n\r\n let customOptions = $derived([\r\n {\r\n id: 0,\r\n value: labels.tooWeak,\r\n minDiversity: 0,\r\n minLength: 0,\r\n },\r\n {\r\n id: 1,\r\n value: labels.weak,\r\n minDiversity: 1,\r\n minLength: 6,\r\n },\r\n {\r\n id: 2,\r\n value: labels.good,\r\n minDiversity: 2,\r\n minLength: 8,\r\n },\r\n {\r\n id: 3,\r\n value: labels.strong,\r\n minDiversity: 3,\r\n minLength: 10,\r\n },\r\n ] as const);\r\n\r\n // Debounce password updates - timer is not reactive to avoid dependency cycle\r\n $effect(() => {\r\n clearTimeout(timer);\r\n if (password.length === 0) {\r\n debouncedPassword = \"\";\r\n } else {\r\n timer = setTimeout(() => {\r\n debouncedPassword = password;\r\n }, 400); // 400ms delay as requested\r\n }\r\n return () => clearTimeout(timer);\r\n });\r\n\r\n let strength = $derived(debouncedPassword && strengthFn\r\n ? strengthFn(debouncedPassword, customOptions as any)\r\n : null);\r\n\r\n // Derive score based on password length and strength\r\n let computedScore = $derived(debouncedPassword.length > 12 ? 3 : (strength?.id ?? -1));\r\n\r\n // Sync computed values to bindable props using effects with untrack\r\n $effect(() => {\r\n const newScore = computedScore;\r\n if (untrack(() => score) !== newScore) {\r\n score = newScore;\r\n }\r\n });\r\n\r\n // Derive text and color from computedScore (not from bindable score)\r\n let computedStrengthText = $derived(\r\n computedScore === 0 ? labels.tooWeak :\r\n computedScore === 1 ? labels.weak :\r\n computedScore === 2 ? labels.good :\r\n computedScore === 3 ? labels.strong : \"\"\r\n );\r\n\r\n // No color until a real strength result exists. computedScore is -1 while\r\n // the lazily-loaded strength library is still in flight (and during the\r\n // debounce window), so emitting danger here would flash a red \"Password\r\n // strength\" line with empty text in consumers (e.g. PasswordInput).\r\n let computedTextColor = $derived(\r\n computedScore < 0 ? \"\" :\r\n computedScore <= 1 ? \"text-accent-danger\" : \"text-accent-success\"\r\n );\r\n\r\n $effect(() => {\r\n const newText = computedStrengthText;\r\n if (untrack(() => strengthText) !== newText) {\r\n strengthText = newText;\r\n }\r\n });\r\n\r\n let strengthColor = $derived(computedScore <= 1 ? \"bg-accent-danger\" : \"bg-accent-success\");\r\n\r\n $effect(() => {\r\n const newColor = computedTextColor;\r\n if (untrack(() => textColor) !== newColor) {\r\n textColor = newColor;\r\n }\r\n });\r\n\r\n // Calculate how many bars to fill (1-3)\r\n let filledBars = $derived(computedScore === 0 ? 1 : computedScore === 1 ? 2 : computedScore >= 2 ? 3 : 0);\r\n</script>\r\n\r\n{#if debouncedPassword.length > 0}\r\n <div\r\n transition:safeSlide={{ duration: 600, easing: cubicOut }}\r\n class=\"pt-2 space-y-2\"\r\n >\r\n <!-- 3 segment bars -->\r\n <div class=\"flex gap-1.5\">\r\n <!-- eslint-disable-next-line svelte/require-each-key -- keyed-each migration deferred -->\r\n {#each [0, 1, 2] as barIndex}\r\n <div\r\n class=\"h-1 flex-1 rounded-full transition-colors duration-300 {barIndex <\r\n filledBars\r\n ? strengthColor\r\n : 'bg-bg-tertiary'}\"\r\n ></div>\r\n {/each}\r\n </div>\r\n {@render children?.()}\r\n </div>\r\n{/if}\r\n","<script lang=\"ts\">\r\n /**\r\n * PasswordInput - Password field with show/hide toggle and strength indicator\r\n *\r\n * Combines Input (password type) with PasswordStrengthIndicator for\r\n * a complete password entry experience.\r\n *\r\n * @example\r\n * <PasswordInput\r\n * label=\"New Password\"\r\n * bind:value={password}\r\n * showStrength\r\n * error={$errors.password}\r\n * required\r\n * />\r\n *\r\n * @example Consumer-owned validation (e.g. Zod): opt out of the built-in\r\n * `required` constraint so the consuming form is the single source of truth.\r\n * <PasswordInput\r\n * label=\"Password\"\r\n * bind:value={password}\r\n * required\r\n * disableBuiltInValidation\r\n * error={$errors.password}\r\n * />\r\n */\r\n import Input from '../../primitives/Input/Input.svelte';\r\n import PasswordStrengthIndicator from './PasswordStrengthIndicator/PasswordStrengthIndicator.svelte';\r\n\r\n const defaultLabels = {\r\n passwordStrength: 'Password strength:',\r\n };\r\n\r\n interface Props {\r\n /** Password value */\r\n value?: string;\r\n /** Label text */\r\n label?: string;\r\n /** Placeholder text */\r\n placeholder?: string;\r\n /** Input name attribute */\r\n name?: string;\r\n /** Input id attribute */\r\n id?: string;\r\n /** Whether the field is required */\r\n required?: boolean;\r\n /**\r\n * Opt out of the component's built-in `required` validation so the\r\n * consumer owns validation entirely (e.g. a Zod schema on the form).\r\n * When `true`, the `required` constraint is NOT forwarded to the\r\n * underlying field (no `aria-required`, no required asterisk). The\r\n * visual error/hint still render via `error`/`hint`. Defaults to\r\n * `false`, preserving the existing built-in behavior exactly.\r\n */\r\n disableBuiltInValidation?: boolean;\r\n /** Whether the field is disabled */\r\n disabled?: boolean;\r\n /** Error message to display */\r\n error?: string;\r\n /** Hint text shown below input */\r\n hint?: string;\r\n /** Show password strength indicator */\r\n showStrength?: boolean;\r\n /** Size variant */\r\n size?: 'sm' | 'md' | 'lg';\r\n /** Minimum password length */\r\n minlength?: number | null;\r\n /** Maximum password length */\r\n maxlength?: number | null;\r\n /** Autocomplete attribute */\r\n autocomplete?: string;\r\n /** Whether to show the password toggle button */\r\n showPasswordToggle?: boolean;\r\n /** Additional class for the wrapper div */\r\n class?: string;\r\n // Optional callbacks (matching Input component signatures)\r\n // eslint-disable-next-line no-unused-vars -- intentionally retained (prop/slot/forward-compat or Svelte-5 reactive binding eslint cannot see)\n oninput?: (value: string) => void;\r\n onblur?: () => void;\r\n onfocus?: () => void;\r\n /** Override user-visible strings */\r\n labels?: Partial<typeof defaultLabels>;\r\n }\r\n\r\n let {\r\n value = $bindable(''),\r\n label = '',\r\n placeholder = '',\r\n name = '',\r\n id = '',\r\n required = false,\r\n disableBuiltInValidation = false,\r\n disabled = false,\r\n error = '',\r\n hint = '',\r\n showStrength = false,\r\n size = 'md',\r\n minlength = null,\r\n maxlength = null,\r\n autocomplete = 'new-password',\r\n showPasswordToggle = true,\r\n class: className = '',\r\n oninput,\r\n onblur,\r\n onfocus,\r\n labels: userLabels = {},\r\n }: Props = $props();\r\n\r\n let labels = $derived({ ...defaultLabels, ...userLabels });\r\n\r\n // When the consumer opts out of built-in validation, do NOT forward the\r\n // `required` constraint to the underlying field — the consuming form owns\r\n // validation entirely. Default (false) forwards `required` as-is, exactly\r\n // preserving existing behavior.\r\n let effectiveRequired = $derived(disableBuiltInValidation ? false : required);\r\n\r\n // Password strength tracking\r\n let strengthScore = $state(-1);\r\n let strengthText = $state('');\r\n let strengthColor = $state('');\r\n</script>\r\n\r\n<div class={className}>\r\n <Input\r\n type=\"password\"\r\n {id}\r\n {name}\r\n {placeholder}\r\n {label}\r\n required={effectiveRequired}\r\n {disabled}\r\n {size}\r\n {minlength}\r\n {maxlength}\r\n {autocomplete}\r\n {showPasswordToggle}\r\n errorText={error}\r\n hintText={hint}\r\n bind:value\r\n oninputchange={oninput}\r\n {onblur}\r\n {onfocus}\r\n />\r\n\r\n {#if showStrength && value}\r\n <PasswordStrengthIndicator\r\n password={value}\r\n bind:score={strengthScore}\r\n bind:strengthText\r\n bind:textColor={strengthColor}\r\n >\r\n <p class=\"text-xs {strengthColor}\">\r\n {labels.passwordStrength} {strengthText}\r\n </p>\r\n </PasswordStrengthIndicator>\r\n {/if}\r\n</div>\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). -->\n<!-- @route-escape: widget-intentional. -->\n<script lang=\"ts\">\n import { onMount, onDestroy } from 'svelte';\n import { goto } from '$app/navigation';\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\n import { transformCollectionData } from '$lib/public-calendar-flow/transform';\n import { fetchPublicCollection } from '$lib/api/events';\n import type { PublicCollectionData } from '$lib/api/types';\n import { createLogger, PasswordInput } from '@getmicdrop/svelte-components';\n\n const logger = createLogger('CollectionView');\n\n // --- Props (matches old CollectionView external interface) ---\n interface Props {\n collectionId: string | number;\n organizationId?: string;\n onNavigateToEvent?: (id: number, slug: string) => void;\n password?: string;\n displayMode?: string;\n showViewSwitcher?: boolean;\n labels?: Record<string, string>;\n }\n\n let {\n collectionId,\n organizationId = '',\n onNavigateToEvent = undefined,\n password = undefined,\n displayMode = 'gallery',\n showViewSwitcher = true,\n labels = {},\n }: Props = $props();\n\n // --- State ---\n let collection = $state<PublicCollectionData | null>(null);\n let isLoading = $state(true);\n let error = $state<string | null>(null);\n let isMounted = $state(false);\n let passwordRequired = $state(false);\n let passwordInput = $state('');\n let passwordError = $state(false);\n\n // --- Derived ---\n let eventData = $derived(\n collection ? transformCollectionData(collection) : null\n );\n\n // --- Load collection data ---\n async function loadCollection(pwd?: string): Promise<void> {\n if (!isMounted) return;\n if (!collectionId) {\n error = labels.noCollectionIdProvided || 'No collection ID provided';\n isLoading = false;\n return;\n }\n\n isLoading = true;\n error = null;\n passwordError = false;\n\n try {\n const data = await fetchPublicCollection(collectionId, pwd);\n if (!isMounted) return;\n\n if (data) {\n if (\n (data as any).passwordRequired ||\n (data as any).error?.code === 'PASSWORD_REQUIRED'\n ) {\n passwordRequired = true;\n isLoading = false;\n return;\n }\n collection = data;\n passwordRequired = false;\n } else {\n if (pwd) {\n passwordRequired = true;\n passwordError = true;\n isLoading = false;\n return;\n }\n error = labels.failedToLoadCollection || 'Failed to load collection';\n }\n } catch (err: any) {\n if (isMounted) {\n const msg = err.message || '';\n if (\n msg.includes('401') ||\n msg.includes('403') ||\n msg.includes('password')\n ) {\n passwordRequired = true;\n } else {\n error =\n msg || labels.failedToLoadCollection || 'Failed to load collection';\n }\n }\n } finally {\n if (isMounted) {\n isLoading = false;\n }\n }\n }\n\n function handlePasswordSubmit(e: Event): void {\n e.preventDefault();\n if (!passwordInput.trim()) return;\n loadCollection(passwordInput);\n }\n\n function handleCollectionEventClick(galleryEvent: {\n id?: number | string;\n slug: string;\n }): void {\n if (onNavigateToEvent && galleryEvent.id) {\n onNavigateToEvent(Number(galleryEvent.id), galleryEvent.slug);\n } else {\n // @url-builder-escape: widget-internal route; SC's url-builders cover /a admin paths, not embedded calendar navigation.\n goto(`/${galleryEvent.id}/${galleryEvent.slug}`);\n }\n }\n\n // --- Lifecycle ---\n onMount(() => {\n isMounted = true;\n loadCollection(password);\n });\n\n onDestroy(() => {\n isMounted = false;\n });\n</script>\n\n{#if isLoading}\n <div\n class=\"flex items-center justify-center py-12 text-center loading-container\"\n >\n <p>{labels.loadingCollection || 'Loading collection...'}</p>\n </div>\n{:else if passwordRequired}\n <div\n class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\"\n >\n <div class=\"password-card rounded-lg p-8 max-w-sm w-full\">\n <h2 class=\"password-title text-xl font-bold mb-2\">\n {labels.collectionPrivateTitle || 'This collection is private'}\n </h2>\n <p class=\"password-description text-sm mb-6\">\n {labels.collectionPrivateDescription ||\n 'Please enter the password to view this collection.'}\n </p>\n <form onsubmit={handlePasswordSubmit} class=\"flex flex-col gap-3\">\n <PasswordInput\n bind:value={passwordInput}\n placeholder={labels.enterPassword || 'Enter password'}\n error={passwordError\n ? labels.incorrectPassword ||\n 'Incorrect password. Please try again.'\n : ''}\n />\n <button\n type=\"submit\"\n class=\"password-submit px-4 py-2 rounded-lg text-sm font-semibold\"\n >{labels.viewCollection || 'View Collection'}</button\n >\n </form>\n </div>\n </div>\n{:else if error}\n <div\n class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\"\n >\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\n </div>\n{:else if eventData}\n <EventExperience\n event={eventData}\n onCollectionEventClick={handleCollectionEventClick}\n />\n{/if}\n\n<style>\n .loading-container {\n color: hsl(var(--text-secondary, 215 16% 47%));\n }\n\n .error-text {\n color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n\n .password-card {\n background: hsl(var(--surface-primary, 0 0% 100%));\n box-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\n }\n\n .password-title {\n color: hsl(var(--text-primary, 0 0% 10%));\n }\n\n .password-description {\n color: hsl(var(--text-secondary, 0 0% 45%));\n }\n\n .password-submit {\n background: hsl(var(--brand-primary, 220 90% 56%));\n color: hsl(var(--text-on-primary, 0 0% 100%));\n }\n\n .password-submit:hover {\n filter: brightness(0.95);\n }\n</style>\n"],"names":["defaultLabels","password","$","$$props","strengthText","score","textColor","userLabels","labels","debouncedPassword","timer","strengthFn","loadStrengthModule","lazyOnce","ensureStrengthFn","m","customOptions","strength","computedScore","newScore","untrack","computedStrengthText","computedTextColor","newText","strengthColor","newColor","filledBars","div","root_1","div_1","barIndex","div_2","root","cubicOut","$$render","consequent","value","label","placeholder","name","id","required","disableBuiltInValidation","disabled","error","hint","showStrength","size","minlength","maxlength","autocomplete","showPasswordToggle","className","effectiveRequired","strengthScore","Input","node","$$value","PasswordStrengthIndicator","$$anchor","p","createLogger","onNavigateToEvent","collection","isLoading","isMounted","passwordRequired","passwordInput","passwordError","eventData","transformCollectionData","loadCollection","pwd","data","fetchPublicCollection","err","msg","handlePasswordSubmit","e","handleCollectionEventClick","galleryEvent","goto","onMount","onDestroy","h2","p_1","form","PasswordInput","node_1","button","div_3","root_2","p_2","text_4","EventExperience","consequent_1","consequent_3"],"mappings":";;;;;;;;;iBAAA;;AAOI,QAAMA,IAAa;AAAA,IACjB,SAAS;AAAA,IACT,MAAM;AAAA,IACN,MAAM;AAAA,IACN,QAAQ;AAAA;AAYV,MACEC,IAAQC,EAAA,KAAAC,GAAA,YAAA,GAAG,EAAE,GACbC,kCAAyB,EAAE,GAC3BC,mCAAoB,GACpBC,+BAAsB,EAAE,GAEhBC,IAAUL,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA,GAGhBK,IAAMN,EAAA,QAAA,OAAA,EAAA,GAAiBF,GAAa,GAAKO,EAAU,EAAA,EAAA,GAEnDE,IAAoBP,EAAA,MAAO,EAAE,GAE7BQ,GASAC,IAA+ET,EAAA,MAAO,IAAI;AAC9F,QAAMU,IAAqBC,EAAQ,MAAO,OAAO,qBAAyB,CAAA;AAC1E,WAASC,IAAmB;AACnB,IAAAF,EAAkB,EAClB,KAAI,CAAEG,MAAM;YACTJ,GAAaI,EAAE,kBAAgB,EAAA;AAAA,IACnC,CAAC,EACA,MAAK,MAAO;AAAA,IAGb,CAAC;AAAA,EACT;AAKA,EAAAb,EAAA,kBAAc;AACV,IAAID,EAAQ,KAAA,CAAAC,EAAA,IAAKS,CAAU,KAAEG,EAAgB;AAAA,EACjD,CAAC;AAED,MAAIE,IAAad,EAAA,QAAA,MAAA;AAAA;MAET,IAAI;AAAA,MACJ,OAAKA,EAAA,IAAEM,CAAM,EAAC;AAAA,MACd,cAAc;AAAA,MACd,WAAW;AAAA;;MAGX,IAAI;AAAA,MACJ,OAAKN,EAAA,IAAEM,CAAM,EAAC;AAAA,MACd,cAAc;AAAA,MACd,WAAW;AAAA;;MAGX,IAAI;AAAA,MACJ,OAAKN,EAAA,IAAEM,CAAM,EAAC;AAAA,MACd,cAAc;AAAA,MACd,WAAW;AAAA;;MAGX,IAAI;AAAA,MACJ,OAAKN,EAAA,IAAEM,CAAM,EAAC;AAAA,MACd,cAAc;AAAA,MACd,WAAW;AAAA;;AAKnB,EAAAN,EAAA,mBACI,aAAaQ,CAAK,GACdT,EAAQ,EAAC,WAAW,IACpBC,EAAA,IAAAO,GAAoB,EAAE,IAEtBC,IAAQ;AAAA,UAAiB;AACrB,MAAAR,EAAA,IAAAO,GAAoBR,GAAQ;AAAA,IAChC;AAAA,IAAG;AAAA,KAED,MAAO,aAAaS,CAAK,EAClC;AAED,MAAIO,IAAQf,EAAA,QAAA,MAAAA,EAAA,IAAYO,CAAiB,KAAAP,EAAA,IAAIS,CAAU,UACjDA,CAAU,EAAAT,EAAA,IAACO,CAAiB,GAAAP,EAAA,IAAEc,CAAa,CAAA,IAC3C,IAAI,GAGNE,IAAahB,EAAA,QAAA,MAAAA,EAAA,IAAYO,CAAiB,EAAC,SAAS,KAAK,IAACP,EAAA,IAAIe,CAAQ,GAAE,QAAQ;AAGpF,EAAAf,EAAA,kBAAc;AACV,UAAMiB,UAAWD,CAAa;AAC9B,IAAIE,EAAO,MAAOf,EAAK,CAAA,MAAMc,KACzBd,EAAQc,CAAQ;AAAA,EAExB,CAAC;AAGD,MAAIE,IAAoBnB,EAAA,QAAA,MAAAA,EAAA,IACpBgB,CAAa,MAAK,IAAIhB,EAAA,IAAAM,CAAM,EAAC,UAC7BN,EAAA,IAAAgB,CAAa,MAAK,IAAIhB,EAAA,IAAAM,CAAM,EAAC,OAC7BN,EAAA,IAAAgB,CAAa,MAAK,IAAIhB,EAAA,IAAAM,CAAM,EAAC,OAC7BN,EAAA,IAAAgB,CAAa,MAAK,IAAChB,EAAA,IAAGM,CAAM,EAAC,SAAS,EAAE,GAOxCc,IAAiBpB,EAAA,QAAA,MAAAA,EAAA,IACjBgB,CAAa,IAAG,IAAI,KACpBhB,EAAA,IAAAgB,CAAa,KAAI,IAAI,uBAAuB,qBAAqB;AAGrE,EAAAhB,EAAA,kBAAc;AACV,UAAMqB,UAAUF,CAAoB;AACpC,IAAID,EAAO,MAAOhB,EAAY,CAAA,MAAMmB,KAChCnB,EAAemB,CAAO;AAAA,EAE9B,CAAC;AAED,MAAIC,0BAAyBN,CAAa,KAAI,IAAI,qBAAqB,mBAAmB;AAE1F,EAAAhB,EAAA,kBAAc;AACV,UAAMuB,UAAWH,CAAiB;AAClC,IAAIF,EAAO,MAAOd,EAAS,CAAA,MAAMmB,KAC7BnB,EAAYmB,CAAQ;AAAA,EAE5B,CAAC;AAGD,MAAIC,IAAUxB,EAAA,QAAA,MAAAA,EAAA,IAAYgB,CAAa,MAAK,IAAI,UAAIA,CAAa,MAAK,IAAI,IAAChB,EAAA,IAAGgB,CAAa,KAAI,IAAI,IAAI,CAAC;;;;UAIvGS,IAAGC,EAAA,GAKCC,YALJF,CAAG;AAKC,MAAAzB,EAAA,KAAA2B,cAEW,GAAG,GAAG,CAAC,gBAAKC,MAAQ;YACvBC,IAAGC,EAAA;AAAH,QAAA9B,EAAA,gBAAA,MAAAA,EAAA,UAAA6B,iEACkED,IAAQ5B,EAAA,IACvEwB,CAAU,IAAAxB,EAAA,IACJsB,CAAa,IACb,qBAAgB,EAAA,EAAA,CAAA,eAJzBO,CAAG;AAAA,kBAHXF,CAAG;wBAAHA,GAAG,CAAA;wDALPF,CAAG,GAAHzB,EAAA,WAAA,GAAAyB,qBAC2B,UAAU,KAAK,QAAQM,EAAQ,EAAA,eAD1DN,CAAG;AAAA;;YADHlB,CAAiB,EAAC,SAAS,KAACyB,EAAAC,CAAA;AAAA;;;AAFzB;;kBC3JR;;AA6BE,QAAMnC,IAAa,EACjB,kBAAkB,qBAAoB;AAsDxC,MACEoC,IAAKlC,EAAA,KAAAC,GAAA,SAAA,IAAa,EAAE,GACpBkC,0BAAQ,EAAE,GACVC,gCAAc,EAAE,GAChBC,yBAAO,EAAE,GACTC,uBAAK,EAAE,GACPC,6BAAW,EAAK,GAChBC,6CAA2B,EAAK,GAChCC,6BAAW,EAAK,GAChBC,0BAAQ,EAAE,GACVC,yBAAO,EAAE,GACTC,iCAAe,EAAK,GACpBC,yBAAO,IAAI,GACXC,8BAAY,IAAI,GAChBC,8BAAY,IAAI,GAChBC,iCAAe,cAAc,GAC7BC,uCAAqB,EAAI,GAClBC,0BAAY,EAAE,GAIb7C,IAAUL,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA,GAGhBK,IAAMN,EAAA,QAAA,OAAA,EAAA,GAAiBF,GAAa,GAAKO,EAAU,EAAA,EAAA,GAMnD8C,IAAiBnD,EAAA,QAAA,MAAYwC,MAA2B,KAAQD,GAAQ,GAGxEa,IAAgBpD,EAAA,MAAM,EAAG,GACzBE,IAAeF,EAAA,MAAO,EAAE,GACxBsB,IAAgBtB,EAAA,MAAO,EAAE;MAG9ByB,IAAGC,EAAA,eAAHD,CAAG;AACD,EAAA4B,EAAKC,GAAA;AAAA;;aAEHhB,EAAE;AAAA;;aACFD,EAAI;AAAA;;aACJD,EAAW;AAAA;;aACXD,EAAK;AAAA;;mBACIgB,CAAiB;AAAA;;aAC1BV,EAAQ;AAAA;;aACRI,EAAI;AAAA;;aACJC,EAAS;AAAA;;aACTC,EAAS;AAAA;;aACTC,EAAY;AAAA;;aACZC,EAAkB;AAAA;;aACRP,EAAK;AAAA;;aACNC,EAAI;AAAA;;;;;;;;;;QACd,QAAU;;;QAAV,MAAUY,GAAA;;;;;;;AAOT,MAAAC,EAAyBC,GAAA;AAAA;iBACdvB,EAAK;AAAA;YACf,QAAU;uBAAEkB,CAAa;AAAA;YAAzB,MAAUG,GAAA;gBAAEH,GAAaG,GAAA,EAAA;AAAA;YACzB,eAAiB;;;YAAjB,aAAiBA,GAAA;;;YACjB,YAAc;uBAAEjC,CAAa;AAAA;YAA7B,UAAciC,GAAA;gBAAEjC,GAAaiC,GAAA,EAAA;AAAA;;cAE5BG,IAAC5B,EAAA,eAAD4B,CAAC;kBAADA,CAAC;AAAD,YAAA1D,EAAA,UAAA0D,uBAAkBpC,CAAa,KAAA,EAAA,EAAA,0BAC7BhB,CAAM,EAAC,oBAAgB,EAAA,IAAAN,EAAA,IAAGE,CAAY,KAAA,EAAA,EAAA;AAAA,0BADxCwD,CAAC;AAAA;;;;;AAPD,MAAAd,EAAY,KAAIV,OAAKF,EAAAC,CAAA;AAAA;;UAtB3BR,CAAG,GAAHzB,EAAA,gBAAA,MAAAA,EAAA,UAAAyB,aAAWyB,EAAS,CAAA,CAAA,CAAA,eAApBzB,CAAG;AAFI;;kBCtHR;iBASiBkC,EAAa,gBAAgB,GAe5B3D,EAAA,KAAAC,GAAA,kBAAA,GAAG,EAAE;AACnB,MAAA2D,sCAAoB,MAAS,GAC7B7D,6BAAW,MAAS;8BACN,SAAS,oCACJ,EAAI;MACvBO,IAAMN,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,GAAA,GAIJ4D,IAAa7D,EAAA,MAAoC,IAAI,GACrD8D,IAAY9D,EAAA,MAAO,EAAI,GACvB0C,IAAQ1C,EAAA,MAAsB,IAAI,GAClC+D,IAAY/D,EAAA,MAAO,EAAK,GACxBgE,IAAmBhE,EAAA,MAAO,EAAK,GAC/BiE,IAAgBjE,EAAA,MAAO,EAAE,GACzBkE,IAAgBlE,EAAA,MAAO,EAAK,GAG5BmE,0BACFN,CAAU,IAAGO,EAAuBpE,EAAA,IAAC6D,CAAU,KAAI,IAAG;AAIxD,iBAAeQ,EAAeC,GAA6B;AACzD,QAAEtE,EAAA,IAAG+D,CAAS,GACd;AAAA,UAAE,CAAA9D,EAAA,cAAiB;AACjB,QAAAD,EAAA,IAAA0C,GAAQpC,EAAM,EAAC,0BAA0B,6BAA2B,EAAA,GACpEN,EAAA,IAAA8D,GAAY,EAAK;AACjB;AAAA,MACF;AAEA,MAAA9D,EAAA,IAAA8D,GAAY,EAAI,GAChB9D,EAAA,IAAA0C,GAAQ,IAAI,GACZ1C,EAAA,IAAAkE,GAAgB,EAAK;AAErB,UAAI;AACF,cAAMK,IAAO,MAAMC,kBAAoCF,CAAG;AAC1D,YAAE,CAAAtE,EAAA,IAAG+D,CAAS,EAAE;AAEhB,YAAIQ,GAAM;AACR,cACGA,EAAa,oBACbA,EAAa,OAAO,SAAS,qBAC9B;AACA,YAAAvE,EAAA,IAAAgE,GAAmB,EAAI,GACvBhE,EAAA,IAAA8D,GAAY,EAAK;AACjB;AAAA,UACF;AACA,UAAA9D,EAAA,IAAA6D,GAAaU,GAAI,EAAA,GACjBvE,EAAA,IAAAgE,GAAmB,EAAK;AAAA,QAC1B,OAAO;AACL,cAAIM,GAAK;AACP,YAAAtE,EAAA,IAAAgE,GAAmB,EAAI,GACvBhE,EAAA,IAAAkE,GAAgB,EAAI,GACpBlE,EAAA,IAAA8D,GAAY,EAAK;AACjB;AAAA,UACF;AACA,UAAA9D,EAAA,IAAA0C,GAAQpC,EAAM,EAAC,0BAA0B,6BAA2B,EAAA;AAAA,QACtE;AAAA,MACF,SAASmE,GAAU;AACjB,YAAEzE,EAAA,IAAE+D,CAAS,GAAE;AACb,gBAAMW,IAAMD,EAAI,WAAW;AAC3B,UACEC,EAAI,SAAS,KAAK,KAClBA,EAAI,SAAS,KAAK,KAClBA,EAAI,SAAS,UAAU,IAEvB1E,EAAA,IAAAgE,GAAmB,EAAI,IAEvBhE,EAAA,IAAA0C,GACEgC,KAAOpE,EAAM,EAAC,0BAA0B,6BAA2B,EAAA;AAAA,QAEzE;AAAA,MACF,UAAC;AACC,QAAEN,EAAA,IAAE+D,CAAS,KACX/D,EAAA,IAAA8D,GAAY,EAAK;AAAA,MAErB;AAAA;AAAA,EACF;AAEA,WAASa,EAAqBC,GAAgB;AAE5C,IADAA,EAAE,eAAc,GACd5E,EAAA,IAAGiE,CAAa,EAAC,KAAI,KACvBI,QAAeJ,CAAa,CAAA;AAAA,EAC9B;AAEA,WAASY,EAA2BC,GAG3B;AACP,IAAIlB,EAAiB,KAAIkB,EAAa,KACpClB,EAAiB,EAAC,OAAOkB,EAAa,EAAE,GAAGA,EAAa,IAAI,IAG5DC,MAASD,EAAa,EAAE,IAAIA,EAAa,IAAI,EAAA;AAAA,EAEjD;AAGA,EAAAE,EAAO,MAAO;AACZ,IAAAhF,EAAA,IAAA+D,GAAY,EAAI,GAChBM,EAAetE,EAAQ,CAAA;AAAA,EACzB,CAAC,GAEDkF,EAAS,MAAO;AACd,IAAAjF,EAAA,IAAA+D,GAAY,EAAK;AAAA,EACnB,CAAC;;;;UAIAtC,IAAEK,GAAA,GAGA4B,YAHFjC,CAAE,eAGAiC,GAAC,EAAA;cAADA,CAAC,WAHHjC,CAAE,yCAGGnB,EAAM,EAAC,qBAAqB,uBAAuB,CAAA,eAHxDmB,CAAE;AAAA;UAMFE,IAAED,GAAA,GAGAG,YAHFF,CAAE,GAIEuD,YADFrD,CAAG,eACDqD,GAAE,EAAA;cAAFA,CAAE;AAGF,UAAAC,cAHAD,GAAE,CAAA,eAGFC,GAAC,EAAA;cAADA,CAAC;AAID,UAAAC,cAJAD,GAAC,CAAA,eAIDC,CAAI;;gCAGY9E,EAAM,EAAC,iBAAiB,gBAAgB,6BAC9C4D,CAAY,IACf5D,EAAM,EAAC,qBACP,0CACA,EAAE;AANP,QAAA+E,GAAYC,GAAA;AAAA;;;;;;cACX,QAAU;yBAAErB,CAAa;AAAA;cAAzB,MAAUV,GAAA;kBAAEU,GAAaV,GAAA,EAAA;AAAA;;;UAO1BgC,IAAKvF,EAAA,QAAAsF,GAAA,CAAA,eAALC,GAAK,EAAA;cAALA,CAAK,WATPH,CAAI,WARNvD,CAAG,WAHLF,CAAE;sBAKIrB,EAAM,EAAC,0BAA0B,4BAA4B,iBAG7DA,EAAM,EAAC,gCACN,oDAAoD,iBAclDA,EAAM,EAAC,kBAAkB,iBAAiB;AAAA,UAZ/CN,EAAA,MAAA,UAAAoF,GAAeT,CAAoB,eAXvChD,CAAE;AAAA;UA6BF6D,IAAEC,GAAA,GAGAC,YAHFF,CAAE,eAGAE,CAAC;cAADA,CAAC,WAHHF,CAAE,GAGsBxF,EAAA,gBAAA,MAAAA,EAAA,SAAA2F,GAAA,IAAArF,IAAO,eAAe,yBAAWoC,CAAK,KAAA,EAAA,EAAA,CAAA,eAH9D8C,CAAE;AAAA;AAMFI,MAAAA,EAAcnC,GAAA;AAAA;uBACNU,CAAS;AAAA;gCACQU;AAAA;;;AA5CvB,MAAA7E,EAAA,IAAA8D,CAAS,IAAA9B,EAAAC,CAAA,IAAAjC,EAAA,IAMJgE,CAAgB,IAAAhC,EAAA6D,GAAA,CAAA,IAAA7F,EAAA,IA6BhB0C,CAAK,oBAMLyB,CAAS,KAAAnC,EAAA8D,GAAA,CAAA;AAAA;;;AA3CX;","x_google_ignoreList":[0,1]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventPage-BKtFiZL1.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Icons/ExclamationTriangleOutline.svelte","../node_modules/@getmicdrop/svelte-components/dist/assets/svg/cancel.svg","../node_modules/@getmicdrop/svelte-components/dist/recipes/modals/InputModal.svelte","../src/lib/navigation.ts","../src/components/Views/EventPage.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n interface Props {\r\n size?: string;\r\n color?: string;\r\n class?: string;\r\n }\r\n let { size = \"24\", color = \"currentColor\", class: className = \"\" }: Props = $props();\r\n</script>\r\n\r\n<svg\r\n class={className}\r\n aria-hidden=\"true\"\r\n width={size}\r\n height={size}\r\n fill=\"none\"\r\n stroke={color}\r\n stroke-width=\"1.5\"\r\n viewBox=\"0 0 24 24\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n>\r\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z\" />\r\n</svg>\r\n","export default \"data:image/svg+xml,%3csvg%20width='14'%20height='14'%20viewBox='0%200%2014%2014'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20id='cancel'%3e%3cpath%20id='Vector'%20d='M11.0846%202.91797L2.91797%2011.0846M2.91797%202.91797L11.0846%2011.0846'%20stroke='%23FF6666'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/g%3e%3c/svg%3e\"","<script lang=\"ts\">\r\n import type { Component, ComponentProps } from 'svelte';\r\n import { ExclamationTriangleOutline } from \"../../primitives/Icons\";\r\n import Button from \"../../primitives/Button/Button.svelte\";\r\n import Cancel from \"../../assets/svg/cancel.svg\";\r\n import { ModalRoot, ModalOverlay, ModalPanel, ModalHeader, ModalBody, ModalFooter } from '../../primitives/Modal/index.js';\r\n import { typography } from '../../tokens/typography';\r\n import { isEmailAddress } from \"../../types/brands.js\";\r\n\r\n interface Props {\r\n open?: boolean;\r\n size?: 'sm' | 'md' | 'lg' | 'xl';\r\n title?: string;\r\n description?: string;\r\n closeBtn?: boolean;\r\n persistent?: boolean;\r\n inputLabel?: string;\r\n inputPlaceholder?: string;\r\n inputType?: 'text' | 'email' | 'password' | 'textarea';\r\n inputValue?: string;\r\n inputRequired?: boolean;\r\n inputRows?: number;\r\n inputIcon?: Component | null;\r\n helpText?: string;\r\n errorMessage?: string;\r\n showError?: boolean;\r\n validateEmail?: boolean;\r\n primaryButtonText?: string;\r\n secondaryButtonText?: string;\r\n primaryButtonVariant?: ComponentProps<typeof Button>['variant'];\r\n disabled?: boolean;\r\n loading?: boolean;\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 onconfirm?: (data: { value: string }) => void;\r\n oncancel?: () => void;\r\n onclose?: () => void;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n const defaultLabels = {\r\n confirm: 'Confirm',\r\n cancel: 'Cancel',\r\n close: 'Close',\r\n invalidEmail: 'Please enter a valid email address',\r\n };\r\n\r\n let {\r\n open = $bindable(false),\r\n size = \"md\",\r\n title = \"\",\r\n description = \"\",\r\n closeBtn = false,\r\n persistent = false,\r\n\r\n // Input configuration\r\n inputLabel = \"\",\r\n inputPlaceholder = \"\",\r\n inputType = \"text\",\r\n inputValue = $bindable(\"\"),\r\n inputRequired = false,\r\n inputRows = 4,\r\n inputIcon = null,\r\n helpText = \"\",\r\n\r\n // Validation\r\n errorMessage = \"\",\r\n showError = false,\r\n validateEmail = false,\r\n\r\n // Buttons\r\n primaryButtonText = undefined,\r\n secondaryButtonText = undefined,\r\n primaryButtonVariant = \"default\",\r\n\r\n // State\r\n disabled = false,\r\n loading = false,\r\n\r\n // Callbacks\r\n onconfirm,\r\n oncancel,\r\n onclose,\r\n labels: userLabels = {},\r\n }: Props = $props();\r\n\r\n let labels = $derived({ ...defaultLabels, ...userLabels });\r\n let effectivePrimaryText = $derived(primaryButtonText ?? labels.confirm);\r\n let effectiveSecondaryText = $derived(secondaryButtonText ?? labels.cancel);\r\n\r\n // Email validation\r\n const isValidEmail = (email: string): boolean => isEmailAddress(email);\r\n\r\n let emailError = $derived(!!(validateEmail && inputValue && !isValidEmail(inputValue)));\r\n let isEmpty = $derived(!!(inputRequired && (!inputValue || inputValue.trim() === \"\")));\r\n let hasError = $derived(showError || emailError);\r\n let isDisabled = $derived(disabled || loading || isEmpty || emailError);\r\n\r\n const handlePrimaryAction = () => {\r\n if (!isDisabled) {\r\n onconfirm?.({ value: inputValue });\r\n }\r\n };\r\n\r\n const handleSecondaryAction = () => {\r\n if (!disabled && !loading) {\r\n oncancel?.();\r\n closeModal();\r\n }\r\n };\r\n\r\n const closeModal = () => {\r\n open = false;\r\n onclose?.();\r\n };\r\n\r\n const handleClose = () => {\r\n if (disabled || loading) return;\r\n closeModal();\r\n };\r\n</script>\r\n\r\n<ModalRoot bind:open {size} {persistent}>\r\n <ModalOverlay />\r\n <ModalPanel>\r\n <ModalHeader>\r\n <div class=\"text-left\">\r\n {#if closeBtn}\r\n <div class=\"flex justify-end -mt-2 -mr-2 mb-2\">\r\n <Button variant=\"icon\" size=\"xs\" onclick={handleClose} {disabled}>\r\n <img src={Cancel} alt={labels.close} class=\"w-5 h-5\" />\r\n </Button>\r\n </div>\r\n {/if}\r\n {#if title}\r\n <h3 class={typography.h2}>{title}</h3>\r\n {/if}\r\n </div>\r\n </ModalHeader>\r\n\r\n <ModalBody>\r\n <div class=\"text-left mt-4\">\r\n {#if description}\r\n <p class={`${typography.smMuted} leading-relaxed mb-4`}>\r\n {description}\r\n </p>\r\n {/if}\r\n\r\n <div>\r\n {#if inputLabel}\r\n <label\r\n for=\"modal-input\"\r\n class={`${typography.label} block mb-2`}\r\n >\r\n {inputLabel}\r\n </label>\r\n {/if}\r\n\r\n {#if inputType === \"textarea\"}\r\n <textarea\r\n id=\"modal-input\"\r\n name=\"value\"\r\n bind:value={inputValue}\r\n placeholder={inputPlaceholder}\r\n rows={inputRows}\r\n class=\"w-full px-3 py-2 border {hasError ? 'border-status-error-border' : 'border-stroke-primary'} bg-bg-secondary {typography.body} rounded-lg focus:outline-hidden focus:ring-2 focus:ring-focus-ring focus:border-transparent resize-none\"\r\n disabled={disabled || loading}\r\n ></textarea>\r\n {:else}\r\n <div class=\"relative\">\r\n {#if inputIcon}\r\n {@const InputIconComponent = inputIcon}\r\n <div class=\"absolute inset-y-0 left-0 flex items-center pl-3 pointer-events-none\">\r\n <InputIconComponent class={`w-5 h-5 ${typography.iconMuted}`} />\r\n </div>\r\n {/if}\r\n <input\r\n id=\"modal-input\"\r\n type={inputType}\r\n name=\"value\"\r\n bind:value={inputValue}\r\n placeholder={inputPlaceholder}\r\n required={inputRequired}\r\n disabled={disabled || loading}\r\n class=\"w-full {inputIcon ? 'pl-10' : 'px-3'} py-2 border {hasError ? 'border-status-error-border' : 'border-stroke-primary'} rounded-lg {typography.body} bg-card focus:ring-2 focus:ring-focus-ring focus:border-transparent disabled:opacity-50 disabled:cursor-not-allowed\"\r\n />\r\n </div>\r\n {/if}\r\n\r\n {#if hasError && (errorMessage || emailError)}\r\n <p class={`${typography.label} text-accent-danger mt-2 flex items-center gap-1`}>\r\n <ExclamationTriangleOutline class=\"w-4 h-4\" />\r\n {emailError ? labels.invalidEmail : errorMessage}\r\n </p>\r\n {:else if helpText && !hasError}\r\n <p class={`${typography.xsMuted} pt-2`}>\r\n {helpText}\r\n </p>\r\n {/if}\r\n </div>\r\n </div>\r\n </ModalBody>\r\n\r\n <ModalFooter>\r\n <div class=\"flex gap-3\">\r\n {#if effectiveSecondaryText}\r\n <Button\r\n size=\"full\"\r\n variant=\"alternative\"\r\n onclick={handleSecondaryAction}\r\n disabled={disabled || loading}\r\n >\r\n {effectiveSecondaryText}\r\n </Button>\r\n {/if}\r\n\r\n <Button\r\n size=\"full\"\r\n variant={primaryButtonVariant}\r\n onclick={handlePrimaryAction}\r\n disabled={isDisabled}\r\n {loading}\r\n >\r\n {effectivePrimaryText}\r\n </Button>\r\n </div>\r\n </ModalFooter>\r\n </ModalPanel>\r\n</ModalRoot>\r\n","/**\n * Public-calendar URL builders. Centralizes the route shapes so call sites\n * stop hand-rolling `goto(`/${id}/${slug}`)` template literals\n * (Atlas utility-url-builders convergence). One place per route.\n */\n\n/** Event (or occurrence) page: `/<id>/<slug>`. */\nexport function buildEventUrl(id: number | string, slug: string): string {\n return `/${id}/${slug}`;\n}\n\n/** Event page by slug only: `/<slug>`. */\nexport function buildEventBySlugUrl(slug: string): string {\n return `/${slug}`;\n}\n\n/** Checkout for an event: `/<id>/<slug>/checkout`. */\nexport function buildCheckoutUrl(id: number | string, slug: string): string {\n return `/${id}/${slug}/checkout`;\n}\n\n/** Checkout success page: `/<id>/<slug>/checkout/success`. */\nexport function buildCheckoutSuccessUrl(\n id: number | string,\n slug: string\n): string {\n return `${buildCheckoutUrl(id, slug)}/success`;\n}\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). -->\n<script module>\n import { createLogger } from '@getmicdrop/svelte-components';\n const logger = createLogger('EventPage');\n</script>\n\n<script lang=\"ts\">\n import { onMount } from 'svelte';\n import { goto } from '$app/navigation';\n import { Locked } from 'carbon-icons-svelte';\n import { InputModal, parseEventId } from '@getmicdrop/svelte-components';\n import type { EventId } from '@getmicdrop/svelte-components';\n import { toast } from '@getmicdrop/svelte-components/toast';\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\n import { validatePromoCode } from '$lib/api/promo';\n import {\n buildEventUrl,\n buildEventBySlugUrl,\n buildCheckoutUrl,\n } from '$lib/navigation';\n import {\n persistCheckoutState,\n initiateOrder,\n trackUTMSource,\n } from '$lib/utils/utils.js';\n import {\n fetchSeriesOccurrences,\n fetchEventDetails,\n checkEventPassword,\n } from '$lib/api';\n import type {\n EventData,\n PromoCodeState,\n OrderTotals,\n SeriesOccurrence,\n } from '$lib/public-calendar-flow/types';\n\n // --- Props (matches old EventPage external interface) ---\n interface Props {\n rawEvent?: any;\n eventId?: string | number;\n slug?: string;\n currentEventId?: number | null;\n onNavigateBack?: () => void;\n onBuyTickets?: (eventId: EventId, slug: string) => void;\n /**\n * Optional checkout hand-off. The standalone get-micdrop.com route lets\n * this default to navigating to /{id}/{slug}/checkout; the embed passes a\n * callback that renders Checkout in-place instead (the cart is already\n * created when this fires). Receives (id, slug, rawEvent).\n */\n onNavigateToCart?: (\n id: string | number,\n slug: string,\n rawEvent: any\n ) => void;\n organizationId?: string;\n labels?: Record<string, string>;\n }\n\n let {\n rawEvent: rawEventProp = undefined,\n eventId: eventIdProp = undefined,\n slug: slugProp = '',\n currentEventId: currentEventIdProp = undefined,\n onNavigateBack = undefined,\n onBuyTickets = undefined,\n onNavigateToCart = undefined,\n organizationId = '',\n labels = {},\n }: Props = $props();\n\n // --- Data state ---\n /* svelte-ignore state_referenced_locally */\n let rawEvent = $state<any>(rawEventProp ?? null);\n /* svelte-ignore state_referenced_locally */\n let dataLoading = $state(!rawEventProp && !!eventIdProp);\n\n // Keep rawEvent in sync if rawEventProp changes reactively\n $effect(() => {\n if (rawEventProp) rawEvent = rawEventProp;\n });\n let dataError = $state<string | null>(null);\n\n // Transform raw API data to EventData\n let baseEventData = $derived(rawEvent ? transformApiEvent(rawEvent) : null);\n let id = $derived(eventIdProp || baseEventData?.id || '');\n let slug = $derived(slugProp || baseEventData?.slug || '');\n\n // Series occurrences (async enrichment)\n let seriesOccurrences = $state<SeriesOccurrence[]>([]);\n let eventData = $derived<EventData | null>(\n baseEventData\n ? {\n ...baseEventData,\n seriesOccurrences:\n seriesOccurrences.length > 0\n ? seriesOccurrences\n : baseEventData.seriesOccurrences || [],\n }\n : null\n );\n\n // --- Password protection state ---\n let showPasswordModal = $state(false);\n let isPasswordVerified = $state(false);\n let passwordValue = $state('');\n let passwordError = $state('');\n let passwordLoading = $state(false);\n\n // The public API strips the real password (auth models/Event.go json:\"-\") and\n // exposes only a boolean `hasPassword`. Gate on the transform-derived\n // `isPasswordProtected` (which reads hasPassword, with an admin-shaped\n // `password` fallback) — NOT the stripped `rawEvent.password`, which is always\n // undefined on the public payload and left every protected event unlocked.\n let requiresPassword = $derived(\n baseEventData?.isPasswordProtected === true ||\n rawEvent?.hasPassword === true\n );\n // Stay locked whenever we only hold the server's stripped teaser\n // (rawEvent.passwordRequired === true), even if this session previously\n // authenticated — the unlocked payload only arrives via a ?password= re-fetch,\n // so a sessionStorage flag alone must not reveal an (empty) teaser.\n let isLocked = $derived(\n requiresPassword &&\n !isPasswordVerified &&\n (rawEvent?.passwordRequired === true || !isEventAuthenticated(id))\n );\n\n function isEventAuthenticated(evtId: string | number): boolean {\n if (typeof window === 'undefined') return false;\n const authedEvents = JSON.parse(\n sessionStorage.getItem('authedEvents') || '[]'\n ); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\n return authedEvents.includes(String(evtId));\n }\n\n function setEventAuthenticated(evtId: string | number): void {\n if (typeof window === 'undefined') return;\n const authedEvents = JSON.parse(\n sessionStorage.getItem('authedEvents') || '[]'\n ); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\n const evtIdStr = String(evtId);\n if (!authedEvents.includes(evtIdStr)) {\n authedEvents.push(evtIdStr);\n sessionStorage.setItem('authedEvents', JSON.stringify(authedEvents)); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\n }\n }\n\n async function handlePasswordSubmit(e: any): Promise<void> {\n const password = e.detail?.value || passwordValue;\n if (!password || !id) return;\n passwordLoading = true;\n passwordError = '';\n try {\n const result = await checkEventPassword(String(id), password);\n if (result.valid) {\n // The server withholds the event's sensitive fields until the correct\n // password is supplied, so re-fetch the now-unlocked full payload and\n // swap it in (the initial load / SSR only had the stripped teaser).\n try {\n const unlocked = await fetchEventDetails(id, fetch, password);\n if (unlocked) rawEvent = unlocked;\n } catch {\n // Keep the teaser; still mark verified so the gate clears for UX.\n }\n setEventAuthenticated(id);\n isPasswordVerified = true;\n showPasswordModal = false;\n passwordValue = '';\n } else {\n passwordError =\n labels.incorrectPassword || 'Incorrect password. Please try again.';\n }\n } catch {\n passwordError =\n labels.unableToVerifyPassword ||\n 'Unable to verify password. Please try again.';\n } finally {\n passwordLoading = false;\n }\n }\n\n function handlePasswordCancel(): void {\n showPasswordModal = false;\n if (onNavigateBack) onNavigateBack();\n }\n\n // --- Promo state tracking for checkout persistence ---\n let lastPromoCode = $state('');\n let lastPromoDiscount = $state(0);\n\n async function handlePromoApply(code: string): Promise<PromoCodeState> {\n const result = await validatePromoCode(String(id), code);\n if (!result.valid) {\n return {\n code,\n isApplied: false,\n isValidating: false,\n error: result.error || 'Invalid promo code',\n hint: '',\n discountAmount: 0,\n discountType: '',\n discountTicketIds: [],\n revealHiddenTickets: false,\n revealTicketIds: [],\n };\n }\n lastPromoCode = result.code || code;\n lastPromoDiscount = result.amount || 0;\n return {\n code: result.code || code,\n isApplied: true,\n isValidating: false,\n error: '',\n hint: `${(result.code || code).toUpperCase()} applied`,\n discountAmount: result.amount || 0,\n discountType:\n result.discountType === 'percentage'\n ? '%'\n : result.discountType === 'fixed'\n ? '$'\n : '',\n discountTicketIds: [],\n revealHiddenTickets: result.revealHiddenTickets || false,\n revealTicketIds: result.revealTicketIds || [],\n };\n }\n\n function handlePromoRemove(): void {\n lastPromoCode = '';\n lastPromoDiscount = 0;\n }\n\n // --- Checkout callback ---\n async function handleCheckout(orderTotals: OrderTotals): Promise<void> {\n if (!eventData) return;\n\n // Reconstruct quantities and donation amounts from OrderTotals lines\n const quantities: Record<number, number> = {};\n const donationAmounts: Record<number, number> = {};\n\n for (const line of orderTotals.lines) {\n quantities[line.ticketId] = line.quantity;\n const ticket = eventData.tickets.find(t => t.id === line.ticketId);\n if (ticket?.isDonation) {\n donationAmounts[line.ticketId] = line.unitPrice;\n }\n }\n\n // Persist checkout state for downstream checkout page\n persistCheckoutState({\n eventID: String(id),\n quantities,\n donationAmounts,\n promocode: lastPromoCode,\n promoDiscountAmount: lastPromoDiscount,\n tickets: eventData.tickets.map(t => ({\n ID: t.id,\n name: t.name,\n price: t.price,\n type: String(t.ticketType || 0),\n visibility: String(t.isHidden ? 1 : 0),\n salesChannel: '0',\n })),\n });\n\n // Create cart (sets checkout-cartid cookie automatically)\n const result = await initiateOrder({\n eventID: id,\n quantities,\n promoCode: lastPromoCode || undefined,\n });\n if (!result?.success) {\n toast.error(\n result?.error ||\n labels.failedToCompleteOrder ||\n 'Failed to complete order. Please try again.'\n );\n return;\n }\n\n // Embed: render Checkout in-place. Standalone route: navigate to the\n // checkout page. The cart cookie is set either way by initiateOrder().\n if (onNavigateToCart) {\n onNavigateToCart(id, slug, rawEvent);\n } else {\n goto(buildCheckoutUrl(id, slug));\n }\n }\n\n // --- Navigation callbacks ---\n function handleCollectionEventClick(event: {\n id?: number | string;\n slug: string;\n }): void {\n if (event.id) {\n goto(buildEventUrl(event.id, event.slug));\n } else {\n logger.warn('Collection event missing id, navigating by slug only');\n goto(buildEventBySlugUrl(event.slug));\n }\n }\n\n function handleShowtimeClick(occurrence: { id: number; slug: string }): void {\n if (onBuyTickets) {\n onBuyTickets(parseEventId(occurrence.id), occurrence.slug);\n } else {\n goto(buildEventUrl(occurrence.id, occurrence.slug));\n }\n }\n\n // --- Lifecycle ---\n onMount(async () => {\n // Self-fetch mode (widget builder / color preview)\n if (!rawEvent && eventIdProp) {\n try {\n const fetched = await fetchEventDetails(eventIdProp);\n rawEvent = fetched;\n } catch (err: any) {\n dataError =\n err.message || labels.failedToLoadEvent || 'Failed to load event';\n dataLoading = false;\n return;\n }\n dataLoading = false;\n }\n\n if (!rawEvent) return;\n\n // UTM tracking — use event ID, not venue ID\n const evtId = rawEvent.ID || rawEvent.id;\n if (evtId) {\n trackUTMSource(evtId);\n }\n\n // Fetch series occurrences\n const seriesId = rawEvent.eventSeriesId || 0;\n const vId = rawEvent.venueID || rawEvent.venueId || 0;\n\n if (seriesId > 0 && vId > 0) {\n try {\n const occurrences = await fetchSeriesOccurrences(seriesId, vId);\n if (Array.isArray(occurrences) && occurrences.length > 0) {\n seriesOccurrences = occurrences.map((occ: any) => ({\n id: occ.id,\n slug: occ.slug || '',\n startDateTime: occ.startDateTime,\n endDateTime: occ.endDateTime || '',\n status: (occ.ctaState?.reason === 'sold_out'\n ? 'sold_out'\n : 'on_sale') as import('$lib/public-calendar-flow/types').EventStatus,\n ctaText: occ.ctaState?.text || 'Get tickets',\n ctaDisabled: occ.ctaState?.disabled || false,\n }));\n }\n } catch {\n // Non-fatal: event page works without series data\n }\n }\n\n // Password protection check\n if (requiresPassword && !isEventAuthenticated(id)) {\n showPasswordModal = true;\n }\n });\n</script>\n\n{#if dataLoading}\n <div\n class=\"flex items-center justify-center py-12 text-center loading-container\"\n >\n <p>{labels.loadingEvent || 'Loading event...'}</p>\n </div>\n{:else if dataError}\n <div\n class=\"flex flex-col items-center justify-center py-12 text-center gap-4\"\n >\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {dataError}</p>\n {#if onNavigateBack}\n <button\n class=\"go-back-btn px-4 py-2 rounded-lg text-white\"\n onclick={onNavigateBack}>{labels.goBack || 'Go back'}</button\n >\n {/if}\n </div>\n{:else if eventData}\n {#if isLocked}\n <div class=\"locked-wrapper\">\n <div\n class=\"locked-overlay absolute inset-0 z-20 flex flex-col items-center justify-center min-h-96\"\n >\n <div class=\"text-center p-8\">\n <div\n class=\"locked-icon-wrapper w-20 h-20 mx-auto mb-4 rounded-full flex items-center justify-center\"\n >\n <Locked size={32} />\n </div>\n <h2 class=\"locked-title text-xl font-semibold mb-2\">\n {labels.passwordProtectedTitle ||\n 'This event is password protected'}\n </h2>\n <p\n class=\"locked-description text-sm max-w-xs mx-auto mb-6 leading-relaxed\"\n >\n {labels.passwordProtectedDescription ||\n 'Enter the event password to view details and purchase tickets.'}\n </p>\n <button\n class=\"unlock-btn py-3 px-6 text-white rounded-lg text-sm font-semibold cursor-pointer\"\n onclick={() => (showPasswordModal = true)}\n >\n {labels.enterPassword || 'Enter password'}\n </button>\n </div>\n </div>\n <div class=\"blur-content\">\n <EventExperience\n event={eventData}\n onCheckout={handleCheckout}\n onPromoApply={handlePromoApply}\n onPromoRemove={handlePromoRemove}\n onCollectionEventClick={handleCollectionEventClick}\n onShowtimeClick={handleShowtimeClick}\n />\n </div>\n </div>\n {:else}\n <EventExperience\n event={eventData}\n onCheckout={handleCheckout}\n onPromoApply={handlePromoApply}\n onPromoRemove={handlePromoRemove}\n onCollectionEventClick={handleCollectionEventClick}\n onShowtimeClick={handleShowtimeClick}\n />\n {/if}\n{/if}\n\n<InputModal\n bind:open={showPasswordModal}\n size=\"md\"\n title={labels.enterEventPassword || 'Enter event password'}\n description={labels.passwordModalDescription ||\n 'This event requires a password to view. Please enter the password provided by the event organizer.'}\n inputLabel={labels.passwordLabel || 'Password'}\n inputType=\"password\"\n bind:inputValue={passwordValue}\n inputRequired={true}\n errorMessage={passwordError}\n showError={!!passwordError}\n primaryButtonText={labels.unlockEvent || 'Unlock event'}\n secondaryButtonText={labels.goBack || 'Go back'}\n loading={passwordLoading}\n onconfirm={handlePasswordSubmit}\n oncancel={handlePasswordCancel}\n onclose={handlePasswordCancel}\n/>\n\n<style>\n .loading-container {\n color: hsl(var(--text-secondary, 215 16% 47%));\n }\n\n .error-text {\n color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n\n .go-back-btn {\n background-color: hsl(var(--brand-primary, 224 76% 48%));\n }\n\n .locked-wrapper {\n position: relative;\n }\n\n .blur-content {\n filter: blur(8px);\n pointer-events: none;\n user-select: none;\n }\n\n .locked-overlay {\n background-color: hsl(var(--bg-primary, 0 0% 100%) / 95%);\n }\n\n .locked-icon-wrapper {\n background-color: hsl(var(--bg-secondary, 210 20% 98%));\n color: hsl(var(--text-tertiary, 220 9% 46%));\n }\n\n .locked-title {\n color: hsl(var(--text-primary, 222 47% 11%));\n }\n\n .locked-description {\n color: hsl(var(--text-secondary, 215 16% 47%));\n }\n\n .unlock-btn {\n background-color: hsl(var(--brand-primary, 224 76% 48%));\n border: none;\n transition: background-color 0.2s ease;\n }\n\n .unlock-btn:hover {\n opacity: 0.9;\n }\n</style>\n"],"names":["size","$","$$props","color","className","svg","root","Cancel","defaultLabels","open","title","description","closeBtn","persistent","inputLabel","inputPlaceholder","inputType","inputValue","inputRequired","inputRows","inputIcon","helpText","errorMessage","showError","validateEmail","primaryButtonText","secondaryButtonText","primaryButtonVariant","disabled","loading","userLabels","labels","effectivePrimaryText","effectiveSecondaryText","isValidEmail","email","isEmailAddress","emailError","isEmpty","hasError","isDisabled","handlePrimaryAction","handleSecondaryAction","closeModal","handleClose","ModalRoot","$$anchor","$$value","ModalOverlay","node","ModalPanel","node_1","ModalHeader","node_2","div","root_3","div_1","root_1","Button","node_4","img","$$render","consequent","h3","root_2","typography","consequent_1","ModalBody","node_6","div_2","root_10","p","root_4","consequent_2","div_3","node_7","label","root_5","consequent_3","textarea","root_6","div_4","root_8","InputIconComponent","div_5","root_7","$0","InputIconComponent_1","consequent_5","input","node_10","consequent_4","alternate","p_1","root_9","ExclamationTriangleOutline","node_13","text_3","p_2","consequent_6","consequent_7","ModalFooter","node_14","div_6","root_11","consequent_8","node_16","buildEventUrl","id","slug","buildEventBySlugUrl","buildCheckoutUrl","logger","createLogger","rawEventProp","eventIdProp","slugProp","onNavigateBack","onBuyTickets","onNavigateToCart","rawEvent","dataLoading","dataError","baseEventData","transformApiEvent","seriesOccurrences","eventData","showPasswordModal","isPasswordVerified","passwordValue","passwordError","passwordLoading","requiresPassword","isLocked","isEventAuthenticated","evtId","setEventAuthenticated","authedEvents","evtIdStr","handlePasswordSubmit","e","password","checkEventPassword","unlocked","fetchEventDetails","handlePasswordCancel","lastPromoCode","lastPromoDiscount","handlePromoApply","code","result","validatePromoCode","handlePromoRemove","handleCheckout","orderTotals","quantities","donationAmounts","line","t","persistCheckoutState","initiateOrder","toast","goto","handleCollectionEventClick","event","handleShowtimeClick","occurrence","parseEventId","onMount","fetched","err","trackUTMSource","seriesId","vId","occurrences","fetchSeriesOccurrences","occ","button","$$args","text_1","Locked","h2","text_4","button_1","EventExperience","InputModal","node_5"],"mappings":"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","x_google_ignoreList":[0,1,2]}
@@ -1,81 +0,0 @@
1
- import "svelte/internal/disclose-version";
2
- import * as e from "svelte/internal/client";
3
- import { createContext as C } from "svelte";
4
- import { ax as _ } from "./VenueCalendar-tmWZSmhT.js";
5
- const [P, z] = C();
6
- var H = e.from_html("<div><!></div>");
7
- function S(s, t) {
8
- e.push(t, !0);
9
- let a = e.prop(t, "padding", 3, !0), o = e.prop(t, "border", 3, !1), n = e.prop(t, "horizontal", 3, !1), i = e.prop(t, "minH", 3, "none"), m = e.prop(t, "class", 3, "");
10
- const c = {
11
- none: "",
12
- sm: "min-h-64",
13
- md: "min-h-80",
14
- lg: "min-h-96",
15
- xl: "min-h-screen"
16
- };
17
- let x = e.derived(() => c[i()] ?? i());
18
- t.className;
19
- const f = {
20
- padding: a(),
21
- border: o(),
22
- horizontal: n()
23
- };
24
- z(f);
25
- var r = H(), g = e.child(r);
26
- {
27
- var h = (l) => {
28
- var d = e.comment(), v = e.first_child(d);
29
- e.snippet(v, () => t.children), e.append(l, d);
30
- };
31
- e.if(g, (l) => {
32
- t.children && l(h);
33
- });
34
- }
35
- e.reset(r), e.template_effect((l) => e.set_class(r, 1, l), [
36
- () => e.clsx(_("bg-card rounded-lg shadow-md", o() && "border border-border", a() && "p-6", n() && "flex flex-row", e.get(x), m(), t.className))
37
- ]), e.append(s, r), e.pop();
38
- }
39
- function j(s, t) {
40
- e.push(t, !0);
41
- let a = e.prop(t, "level", 3, 2), o = e.prop(t, "weight", 3, "semibold"), n = e.prop(t, "color", 3, "default"), i = e.prop(t, "class", 3, "");
42
- const m = { 1: "3xl", 2: "2xl", 3: "xl", 4: "lg", 5: "base", 6: "sm" }, c = {
43
- xs: "text-xs",
44
- sm: "text-sm",
45
- base: "text-base",
46
- md: "text-base",
47
- lg: "text-lg",
48
- xl: "text-xl",
49
- "2xl": "text-2xl",
50
- "3xl": "text-3xl",
51
- "4xl": "text-4xl",
52
- "5xl": "text-5xl"
53
- }, x = {
54
- normal: "font-normal",
55
- medium: "font-medium",
56
- semibold: "font-semibold",
57
- bold: "font-bold"
58
- }, f = {
59
- default: "text-text-primary",
60
- muted: "text-text-secondary",
61
- primary: "text-primary",
62
- none: ""
63
- };
64
- let r = e.derived(() => t.size || m[a()]), g = e.derived(() => `h${a()}`), h = e.derived(() => [
65
- c[e.get(r)] || "text-lg",
66
- x[o()],
67
- f[n()] || "",
68
- i()
69
- ].filter(Boolean).join(" "));
70
- var l = e.comment(), d = e.first_child(l);
71
- e.element(d, () => e.get(g), !1, (v, b) => {
72
- e.attribute_effect(v, () => ({ id: t.id, class: e.get(h) }));
73
- var p = e.comment(), u = e.first_child(p);
74
- e.snippet(u, () => t.children), e.append(b, p);
75
- }), e.append(s, l), e.pop();
76
- }
77
- export {
78
- S as C,
79
- j as H
80
- };
81
- //# sourceMappingURL=Heading-D0grC8vd.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Heading-D0grC8vd.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Card/context.js","../node_modules/@getmicdrop/svelte-components/dist/primitives/Card/CardRoot.svelte","../node_modules/@getmicdrop/svelte-components/dist/components/Heading.svelte"],"sourcesContent":["/**\n * Card compound component context.\n *\n * Convention: Every compound component gets a context.ts file using\n * Svelte 5's createContext(). The returned [get, set] tuple provides\n * type-safe context that auto-throws if a sub-component is used\n * outside its Root.\n *\n * Card context is static (no $state flags) because Card has no\n * child-to-parent signaling like Alert does.\n */\nimport { createContext } from 'svelte';\nexport const [getCardContext, setCardContext] = createContext();\n","<script lang=\"ts\">\r\n import type { Snippet } from 'svelte';\r\n import { setCardContext, type CardContext } from './context.js';\r\n import { cn } from '../../utils/classNames.js';\r\n import { deprecation } from '../../utils/deprecation.js';\r\n\r\n /**\r\n * Reserve a minimum height so the card doesn't collapse on empty/loading\r\n * states. Prevents Cumulative Layout Shift when content swaps in.\r\n * 'sm' = 24rem | 'md' = 32rem | 'lg' = 44rem | 'xl' = 56rem\r\n * Or pass a Tailwind class string (e.g. 'min-h-screen') for custom values.\r\n */\r\n type MinHeight = 'none' | 'sm' | 'md' | 'lg' | 'xl' | string;\r\n\r\n interface Props {\r\n padding?: boolean;\r\n border?: boolean;\r\n horizontal?: boolean;\r\n minH?: MinHeight;\r\n class?: string;\r\n className?: string;\r\n children?: Snippet;\r\n }\r\n\r\n let {\r\n padding = true,\r\n border = false,\r\n horizontal = false,\r\n minH = 'none',\r\n class: classFromProp = '',\r\n className,\r\n children,\r\n }: Props = $props();\r\n\r\n // Mapped to Tailwind's standard min-h scale (no arbitrary values).\r\n // sm = 16rem (256px) | md = 20rem (320px) | lg = 24rem (384px) | xl = full screen\r\n const minHPresets: Record<string, string> = {\r\n none: '',\r\n sm: 'min-h-64',\r\n md: 'min-h-80',\r\n lg: 'min-h-96',\r\n xl: 'min-h-screen',\r\n };\r\n let minHClass = $derived(minHPresets[minH] ?? minH);\r\n\r\n // eslint-disable-next-line svelte/valid-compile -- known Svelte compiler note, accepted for this primitive\n if (className) {\r\n deprecation(\r\n `Card prop 'className' is deprecated. Use 'class' instead.\\n` +\r\n ` Before: <Card className=\"my-class\" />\\n` +\r\n ` After: <Card class=\"my-class\" />`\r\n );\r\n }\r\n\r\n // eslint-disable-next-line svelte/valid-compile -- known Svelte compiler note, accepted for this primitive\n const ctx: CardContext = { padding, border, horizontal };\r\n setCardContext(ctx);\r\n</script>\r\n\r\n<div\r\n class={cn(\r\n 'bg-card rounded-lg shadow-md',\r\n border && 'border border-border',\r\n padding && 'p-6',\r\n horizontal && 'flex flex-row',\r\n minHClass,\r\n classFromProp,\r\n className,\r\n )}\r\n>\r\n {#if children}{@render children()}{/if}\r\n</div>\r\n","<script lang=\"ts\">\r\n import type { Snippet } from 'svelte';\r\n\r\n type Level = 1 | 2 | 3 | 4 | 5 | 6;\r\n type Size = 'xs' | 'sm' | 'base' | 'md' | 'lg' | 'xl' | '2xl' | '3xl' | '4xl' | '5xl';\r\n\r\n interface Props {\r\n level?: Level;\r\n size?: Size;\r\n weight?: 'normal' | 'medium' | 'semibold' | 'bold';\r\n color?: 'default' | 'muted' | 'primary' | 'none';\r\n class?: string;\r\n id?: string;\r\n children: Snippet;\r\n }\r\n\r\n let {\r\n level = 2,\r\n size,\r\n weight = 'semibold',\r\n color = 'default',\r\n class: className = '',\r\n id,\r\n children,\r\n }: Props = $props();\r\n\r\n const levelToSize: Record<Level, Size> = {\r\n 1: '3xl',\r\n 2: '2xl',\r\n 3: 'xl',\r\n 4: 'lg',\r\n 5: 'base',\r\n 6: 'sm',\r\n };\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 '3xl': 'text-3xl',\r\n '4xl': 'text-4xl',\r\n '5xl': 'text-5xl',\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 const colorClasses: Record<string, string> = {\r\n default: 'text-text-primary',\r\n muted: 'text-text-secondary',\r\n primary: 'text-primary',\r\n none: '',\r\n };\r\n\r\n let effectiveSize = $derived(size || levelToSize[level]);\r\n let element = $derived(`h${level}` as 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6');\r\n\r\n let classes = $derived(\r\n [\r\n sizeClasses[effectiveSize] || 'text-lg',\r\n weightClasses[weight],\r\n colorClasses[color] || '',\r\n className,\r\n ]\r\n .filter(Boolean)\r\n .join(' '),\r\n );\r\n</script>\r\n\r\n<svelte:element this={element} {id} class={classes}>{@render children()}</svelte:element>\r\n"],"names":["getCardContext","setCardContext","createContext","padding","$","$$props","border","horizontal","minH","classFromProp","minHPresets","minHClass","ctx","div","root","$0","cn","level","weight","color","className","levelToSize","sizeClasses","weightClasses","colorClasses","effectiveSize","element","classes","$$element","$$anchor"],"mappings":";;;;AAYO,MAAM,CAACA,GAAgBC,CAAc,IAAIC,EAAa;;iBCZ7D;;AAwBE,MACEC,IAAOC,EAAA,KAAAC,GAAA,WAAA,GAAG,EAAI,GACdC,2BAAS,EAAK,GACdC,+BAAa,EAAK,GAClBC,yBAAO,MAAM,GACNC,0BAAgB,EAAE;AAO3B,QAAMC,IAAmC;AAAA,IACvC,MAAM;AAAA,IACN,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA;AAEN,MAAIC,IAASP,EAAA,QAAA,MAAYM,EAAYF,EAAI,MAAKA,GAAI;AAGlD;AASA,QAAMI,IAAgB;AAAA,IAAK,SAAAT,EAAO;AAAA,IAAE,QAAAG,EAAM;AAAA,IAAE,YAAAC,EAAU;AAAA;AACtD,EAAAN,EAAeW,CAAG;MAGnBC,IAAGC,EAAA,eAAHD,CAAG;;;;;;;;;;UAAHA,CAAG,wCAAHA,GAAG,GAAAE,CAAA,GAAA;AAAA,IACK,MAAAX,EAAA,KAAAY,EACL,gCACAV,OAAU,wBACVH,OAAW,OACXI,OAAc,iBAAeH,EAAA,IAC7BO,CAAS,GACTF,EAAa,GAAAJ,EAAA,SAAA,CAAA;AAAA,kBAPhBQ,CAAG;AAFI;iBCzDR;;AAgBE,MACEI,IAAKb,EAAA,KAAAC,GAAA,SAAA,GAAG,CAAC,GAETa,2BAAS,UAAU,GACnBC,0BAAQ,SAAS,GACVC,0BAAY,EAAE;AAKvB,QAAMC,IAAgC,EACpC,GAAG,OACH,GAAG,OACH,GAAG,MACH,GAAG,MACH,GAAG,QACH,GAAG,KAAI,GAGHC,IAAmC;AAAA,IACvC,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,MAAM;AAAA,IACN,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,KAGHC,IAAqC;AAAA,IACzC,QAAQ;AAAA,IACR,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,MAAM;AAAA,KAGFC,IAAoC;AAAA,IACxC,SAAS;AAAA,IACT,OAAO;AAAA,IACP,SAAS;AAAA,IACT,MAAM;AAAA;AAGR,MAAIC,IAAarB,EAAA,QAAA,MAAAC,EAAA,QAAoBgB,EAAYJ,EAAK,CAAA,CAAA,GAClDS,wBAAuBT,EAAK,CAAA,EAAA,GAE5BU,IAAOvB,EAAA,QAAA,MAAA;AAAA,IAEPkB,EAAWlB,EAAA,IAACqB,CAAa,CAAA,KAAK;AAAA,IAC9BF,EAAcL,EAAM,CAAA;AAAA,IACpBM,EAAaL,EAAK,CAAA,KAAK;AAAA,IACvBC,EAAS;AAAA,EAER,EAAA,OAAO,OAAO,EACd,KAAK,GAAG,CAAA;;2BAIOM,CAAO,GAAA,IAAA,CAAAE,GAAAC,MAAA;0DAAcF,CAAO,EAAA,EAAA;;;;AAF1C;","x_google_ignoreList":[0,1,2]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ScarcityBadge-Co7gZXuW.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Icons/ChevronDownOutline.svelte","../__SKIP_NAVIGATION__","../src/components/ScarcityBadge.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n interface Props {\r\n size?: string;\r\n color?: string;\r\n class?: string;\r\n }\r\n let { size = \"24\", color = \"currentColor\", class: className = \"\" }: Props = $props();\r\n</script>\r\n\r\n<svg\r\n class={className}\r\n aria-hidden=\"true\"\r\n width={size}\r\n height={size}\r\n fill=\"none\"\r\n stroke={color}\r\n stroke-width=\"2\"\r\n viewBox=\"0 0 24 24\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n>\r\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\" />\r\n</svg>\r\n","\n export function goto(url, opts) {\n if (typeof window !== 'undefined' && window.location) {\n if (opts?.replaceState) {\n window.history.replaceState({}, '', url);\n } else {\n window.location.href = url;\n }\n }\n }\n export function beforeNavigate(callback) {\n // No-op for library builds\n }\n export function afterNavigate(callback) {\n // No-op for library builds\n }\n export function disable() {\n // No-op for library builds\n }\n export function enable() {\n // No-op for library builds\n }\n ","<script>\n import { Badge } from '@getmicdrop/svelte-components';\n import { Fire } from 'carbon-icons-svelte';\n import { computeScarcityLevel } from '$lib/constants/scarcity';\n\n /**\n * ScarcityBadge - Shows urgency indicators based on ticket availability.\n *\n * Wraps SC <Badge> with venue-calendar's threshold logic. Renders to\n * the same primitive every other status badge uses (List, Gallery,\n * Calendar embed) so a \"Selling fast\" / \"Sold out\" pill is visually\n * identical wherever it appears.\n *\n * Thresholds are canonicalized in $lib/constants/scarcity:\n * URGENT_PCT=10, LOW_PCT=25, MAX_EXACT_COUNT=20.\n * TicketBlock.svelte uses the same source so the badge tier matches the\n * urgency copy on the ticket selection page.\n *\n * - 0 remaining: \"Sold out\" (red, no flame)\n * - <=10% remaining: \"Only X left\" with exact count (warning + flame)\n * - <=20% remaining (80%+ sold): \"Selling fast\" (warning + flame)\n * - >20% remaining: No badge\n *\n * @prop {\"browse\"|\"event\"|\"ticket\"} context - browse=vague only; event/ticket=exact at urgent\n * @prop {\"default\"|\"minimal\"} variant - default=SC Badge pill; minimal=transparent text+icon\n * @prop {boolean} isFree - Suppress scarcity badges for free events/tickets\n */\n let {\n remaining,\n total,\n context = 'browse',\n variant = 'default',\n isFree = false,\n labels = {},\n } = $props();\n\n const MAX_EXACT_COUNT = 20;\n const URGENT_PCT = 10;\n const LOW_PCT = 20;\n\n let percent = $derived(total > 0 ? (remaining / total) * 100 : 100);\n\n let badgeInfo = $derived.by(() => {\n const soldOutText = labels.statusSoldOut || 'Sold out';\n const sellingFastText = labels.statusSellingFast || 'Selling fast';\n const onlyNLeftTemplate =\n labels.scarcityOnlyNLeft || 'Only {remaining} left';\n\n if (remaining <= 0) {\n return { type: 'sold-out', text: soldOutText, showFlame: false };\n }\n if (isFree) return null;\n\n if (context === 'browse') {\n if (percent <= LOW_PCT) {\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\n }\n return null;\n }\n\n if (percent <= URGENT_PCT && remaining <= MAX_EXACT_COUNT) {\n return { type: 'scarcity', text: onlyNLeftTemplate.replace('{remaining}', String(remaining)), showFlame: true };\n }\n if (percent <= LOW_PCT) {\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\n }\n\n // Event page / Ticket page: vague at low.\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\n });\n\n let scVariant = $derived(\n /** @type {'error' | 'warning'} */ (badgeInfo?.type === 'sold-out' ? 'error' : 'warning')\n );\n let ariaLabel = $derived(\n badgeInfo?.type === 'sold-out'\n ? (labels.statusSoldOut || 'Sold out')\n : `${labels.scarcityLowAvailability || 'Low availability'}: ${badgeInfo?.text}`\n );\n</script>\n\n{#if badgeInfo}\n {#if variant === 'minimal'}\n <span\n class=\"inline-flex items-center gap-1 text-xs leading-none {badgeInfo.type === 'sold-out' ? 'text-status-error-text' : 'text-accent-warning'}\"\n role=\"status\"\n aria-live=\"polite\"\n aria-label={ariaLabel}\n >\n {#if badgeInfo.showFlame}\n <Fire size={16} aria-hidden=\"true\" />\n {/if}\n {badgeInfo.text}\n </span>\n {:else}\n <Badge variant={scVariant} size=\"sm\">\n {#snippet leftIcon()}\n {#if badgeInfo.showFlame}\n <Fire size={16} aria-hidden=\"true\" />\n {/if}\n {/snippet}\n {badgeInfo.text}\n </Badge>\n {/if}\n{/if}\n"],"names":["size","$","$$props","color","className","svg","root","goto","url","opts","context","variant","isFree","labels","MAX_EXACT_COUNT","URGENT_PCT","LOW_PCT","percent","badgeInfo","soldOutText","sellingFastText","onlyNLeftTemplate","scVariant","ariaLabel","span","Fire","$$render","consequent","text","Badge","$$anchor","consequent_2","text_1","consequent_1","alternate","consequent_3"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"SeriesPage-USYe3APQ.js","sources":["../src/components/Views/SeriesPage.svelte"],"sourcesContent":["<!-- @route-escape: widget-intentional. -->\n<script lang=\"ts\">\n import { goto } from '$app/navigation';\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\n import { createLogger } from '@getmicdrop/svelte-components';\n import { transformSeriesPageData } from '$lib/public-calendar-flow/transform';\n\n const logger = createLogger('SeriesPage');\n\n // --- Props (matches old SeriesPage external interface) ---\n interface Props {\n series: any;\n onNavigateToOccurrence?: (id: number, slug: string, name?: string) => void;\n }\n\n let { series, onNavigateToOccurrence = undefined }: Props = $props();\n\n // Transform series data to EventData for EventExperience\n let eventData = $derived(series ? transformSeriesPageData(series) : null);\n\n // Handle occurrence click — delegate to callback or navigate directly\n function handleShowtimeClick(occurrence: { id: number; slug: string }): void {\n if (onNavigateToOccurrence) {\n onNavigateToOccurrence(occurrence.id, occurrence.slug);\n } else {\n // @url-builder-escape: widget-internal route; SC's url-builders cover /a admin paths, not embedded calendar navigation.\n goto(`/${occurrence.id}/${occurrence.slug}`);\n }\n }\n</script>\n\n{#if eventData}\n <EventExperience\n event={eventData}\n isSeriesMaster\n onShowtimeClick={handleShowtimeClick}\n />\n{/if}\n"],"names":["createLogger","onNavigateToOccurrence","$","$$props","eventData","transformSeriesPageData","handleShowtimeClick","occurrence","goto","EventExperience","$$anchor","$$render","consequent"],"mappings":";;;;;;iBACA;iBAMiBA,EAAa,YAAY;AAQxC,MAAcC,IAAsBC,EAAA,KAAAC,GAAA,0BAAA,GAAG,MAAS,GAG5CC,IAASF,EAAA,QAAA,MAAAC,EAAA,SAAqBE,EAAuBF,EAAA,MAAA,IAAW,IAAI;AAGxE,WAASG,EAAoBC,GAAgD;AAC3E,IAAIN,EAAsB,IACxBA,EAAsB,EAACM,EAAW,IAAIA,EAAW,IAAI,IAGrDC,MAASD,EAAW,EAAE,IAAIA,EAAW,IAAI,EAAA;AAAA,EAE7C;;;;AAICE,MAAAA,EAAcC,GAAA;AAAA;uBACNN,CAAS;AAAA;;yBAECE;AAAA;;;YAJhBF,CAAS,KAAAO,EAAAC,CAAA;AAAA;;;AAFN;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Success-C387RvIY.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\">\n\timport { Email } from 'carbon-icons-svelte';\n\timport { Card, Heading, Text } from '@getmicdrop/svelte-components';\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\n\timport OrderSummary from './OrderSummary.svelte';\n\n\tinterface Props {\n\t\tevent: EventData;\n\t\torderId: string;\n\t\torderTotals: OrderTotals;\n\t\tcustomerEmail: string;\n\t\tshowCheckmark: boolean;\n\t\tshowContent: boolean;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tevent, orderId, orderTotals, customerEmail, showCheckmark, showContent, labels = {},\n\t}: Props = $props();\n\n\tlet ticketCount = $derived(orderTotals.lines.reduce((sum, l) => sum + l.quantity, 0));\n\n\tlet headingText = $derived(\n\t\tevent.isRegistrationEvent ? (labels.youreRegistered || \"You're registered!\") : (labels.youreIn || \"You're in!\")\n\t);\n\n</script>\n\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-primary\">\n\t<div class=\"p-6 md:p-8\">\n\t\t<!-- Spinner → Checkmark animation -->\n\t\t<div class=\"flex justify-center mb-6\">\n\t\t\t<div class=\"indicator-container\">\n\t\t\t\t<!-- Spinner (visible while loading) -->\n\t\t\t\t<div class=\"processing-spinner\" class:fade-out={showCheckmark}></div>\n\n\t\t\t\t<!-- Animated checkmark (appears after spinner) -->\n\t\t\t\t<svg class=\"checkmark-svg\" class:active={showCheckmark} viewBox=\"0 0 52 52\" aria-hidden=\"true\">\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-circle\" />\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-fill\" />\n\t\t\t\t\t<path d=\"M14 27l7 7 17-17\" class=\"checkmark-check\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<!-- Content (fades in after checkmark completes) -->\n\t\t<div class=\"content-section\" class:visible={showContent}>\n\t\t\t<!-- Heading -->\n\t\t\t<!-- TODO: swap back to <Stack gap=\"3\"> once SC's root index.js exports Stack\n\t\t\t (the `export *` re-export of primitives doesn't surface it, so\n\t\t\t `import { Stack }` fails to resolve). flex-col gap-3 is equivalent. -->\n\t\t\t<div class=\"flex flex-col gap-3 text-center mb-6\">\n\t\t\t\t<Heading level={1} size=\"xl\" weight=\"bold\">\n\t\t\t\t\t{headingText}\n\t\t\t\t</Heading>\n\t\t\t\t<Text size=\"lg\" class=\"font-semibold block\">\n\t\t\t\t\t{event.title}\n\t\t\t\t</Text>\n\t\t\t\t<Text size=\"sm\" color=\"secondary\" class=\"block\">\n\t\t\t\t\t{ticketCount} {ticketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} confirmed\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Order summary (same format as checkout) -->\n\t\t\t<div class=\"mb-6\">\n\t\t\t\t<OrderSummary {orderTotals}\n\t\t\t\t{labels} />\n\t\t\t</div>\n\n\t\t\t<!-- Order info -->\n\t\t\t<div class=\"flex justify-between items-center py-3 border-t border-default\">\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold font-mono\">#{orderId}</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Email confirmation -->\n\t\t\t<div class=\"flex items-center justify-center gap-2 p-3 rounded-lg bg-surface-secondary mt-4\">\n\t\t\t\t<Email size={16} class=\"shrink-0 text-color-muted\" />\n\t\t\t\t<Text size=\"xs\" color=\"secondary\">\n\t\t\t\t\t{labels.confirmationSentTo || 'Confirmation sent to'} {customerEmail}\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t</div>\n\t</div>\n</Card>\n\n<style>\n\t/* Indicator container — holds spinner and checkmark in same space */\n\t.indicator-container {\n\t\tposition: relative;\n\t\twidth: 64px;\n\t\theight: 64px;\n\t}\n\n\t/* Spinner — rotating partial circle */\n\t.processing-spinner {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder: 3px solid hsl(var(--stroke-primary) / 15%);\n\t\tborder-top-color: hsl(var(--accent-success, 142 71% 45%));\n\t\tborder-radius: 50%;\n\t\tanimation: spin 0.7s linear infinite;\n\t\ttransition: opacity 0.2s ease;\n\t}\n\n\t.processing-spinner.fade-out {\n\t\topacity: 0;\n\t}\n\n\t@keyframes spin {\n\t\tto { transform: rotate(360deg); }\n\t}\n\n\t/* Checkmark SVG — scales in when active */\n\t.checkmark-svg {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\topacity: 0;\n\t\ttransform: scale(0.6);\n\t\ttransition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);\n\t}\n\n\t.checkmark-svg.active {\n\t\topacity: 1;\n\t\ttransform: scale(1);\n\t}\n\n\t/* Circle outline — draws itself */\n\t.checkmark-circle {\n\t\tstroke-dasharray: 151;\n\t\tstroke-dashoffset: 151;\n\t\tstroke-width: 2;\n\t\tstroke: hsl(var(--accent-success, 142 71% 45%));\n\t\tfill: none;\n\t\ttransform-origin: center;\n\t}\n\n\t.checkmark-svg.active .checkmark-circle {\n\t\tanimation: circle-draw 0.5s ease-out 0.1s forwards;\n\t}\n\n\t@keyframes circle-draw {\n\t\tto { stroke-dashoffset: 0; }\n\t}\n\n\t/* Circle fill — fades in after outline completes */\n\t.checkmark-fill {\n\t\tfill: hsl(var(--accent-success, 142 71% 45%));\n\t\topacity: 0;\n\t}\n\n\t.checkmark-svg.active .checkmark-fill {\n\t\tanimation: fill-in 0.25s ease-out 0.5s forwards;\n\t}\n\n\t@keyframes fill-in {\n\t\tto { opacity: 1; }\n\t}\n\n\t/* Checkmark stroke — draws after fill */\n\t.checkmark-check {\n\t\tstroke-dasharray: 36;\n\t\tstroke-dashoffset: 36;\n\t\tstroke-width: 3;\n\t\tstroke: hsl(var(--bg-primary));\n\t\tfill: none;\n\t\tstroke-linecap: round;\n\t\tstroke-linejoin: round;\n\t}\n\n\t.checkmark-svg.active .checkmark-check {\n\t\tanimation: check-draw 0.3s ease-out 0.6s forwards;\n\t}\n\n\t@keyframes check-draw {\n\t\tto { stroke-dashoffset: 0; }\n\t}\n\n\t/* Content section — fades in after checkmark */\n\t.content-section {\n\t\topacity: 0;\n\t\ttransform: translateY(8px);\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\n\t}\n\n\t.content-section.visible {\n\t\topacity: 1;\n\t\ttransform: translateY(0);\n\t}\n\n\t/* Reduced motion */\n\t@media (prefers-reduced-motion: reduce) {\n\t\t.processing-spinner {\n\t\t\tanimation-duration: 0s;\n\t\t}\n\n\t\t.checkmark-svg {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\n\t\t.checkmark-svg .checkmark-circle,\n\t\t.checkmark-svg .checkmark-fill,\n\t\t.checkmark-svg .checkmark-check {\n\t\t\tanimation-duration: 0s;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\n\t\t.content-section {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\t}\n</style>\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). -->\n<script lang=\"ts\">\n\timport { onMount } from 'svelte';\n\timport {\n\t\tShare,\n\t\tHelp,\n\t\tArrowLeft,\n\t\tApple,\n\t\tCalendar,\n\t\tChevronDown,\n\t\tLocationFilled,\n\t} from 'carbon-icons-svelte';\n\timport { Button, Card, Image, Text } from '@getmicdrop/svelte-components';\n\timport { toast } from '@getmicdrop/svelte-components/toast';\n\timport type { EventData } from '$lib/public-calendar-flow/types';\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\n\timport { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\n\n\tinterface Props {\n\t\tevent: EventData;\n\t\torderId: string;\n\t\teventUrl: string;\n\t\tshowContent: boolean;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet { event, orderId, eventUrl, showContent, labels = {} }: Props = $props();\n\n\t// --- Calendar dropdown ---\n\tlet calendarOpen = $state(false);\n\n\tfunction toggleCalendar() {\n\t\tcalendarOpen = !calendarOpen;\n\t}\n\n\t// Close calendar dropdown when clicking outside\n\tonMount(() => {\n\t\tfunction handleClickOutside(e: MouseEvent) {\n\t\t\tconst target = e.target as HTMLElement;\n\t\t\tif (!target.closest('.calendar-dropdown')) {\n\t\t\t\tcalendarOpen = false;\n\t\t\t}\n\t\t}\n\t\tdocument.addEventListener('click', handleClickOutside);\n\t\treturn () => document.removeEventListener('click', handleClickOutside);\n\t});\n\n\t// --- Google Calendar URL ---\n\tlet googleCalendarUrl = $derived((() => {\n\t\tconst startDate = new Date(event.startDateTime);\n\t\tconst endDate = event.endDateTime\n\t\t\t? new Date(event.endDateTime)\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\n\n\t\tconst formatForGoogle = (date: Date): string => {\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\n\t\t};\n\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst fullLocation = locationParts.join(', ');\n\n\t\tconst params = new URLSearchParams({\n\t\t\taction: 'TEMPLATE',\n\t\t\ttext: event.title,\n\t\t\tdates: `${formatForGoogle(startDate)}/${formatForGoogle(endDate)}`,\n\t\t\tlocation: fullLocation,\n\t\t\tdetails: `Event: ${eventUrl}\\n\\nTicket confirmation #${orderId}`\n\t\t});\n\n\t\treturn `https://calendar.google.com/calendar/render?${params.toString()}`;\n\t})());\n\n\t// --- ICS file download (Apple Calendar) ---\n\tfunction downloadICS() {\n\t\tconst startDate = new Date(event.startDateTime);\n\t\tconst endDate = event.endDateTime\n\t\t\t? new Date(event.endDateTime)\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\n\n\t\tconst formatForICS = (date: Date): string => {\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\n\t\t};\n\n\t\tconst uid = `order-${orderId}-event-${event.id}@micdrop.com`;\n\t\tconst now = formatForICS(new Date());\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst fullLocation = locationParts.join(', ');\n\n\t\tconst escapeICS = (str: string): string => {\n\t\t\tif (!str) return '';\n\t\t\treturn str.replace(/\\\\/g, '\\\\\\\\').replace(/;/g, '\\\\;').replace(/,/g, '\\\\,').replace(/\\n/g, '\\\\n');\n\t\t};\n\n\t\tconst icsContent = `BEGIN:VCALENDAR\nVERSION:2.0\nPRODID:-//MicDrop//Ticket Confirmation//EN\nCALSCALE:GREGORIAN\nMETHOD:PUBLISH\nBEGIN:VEVENT\nUID:${uid}\nDTSTAMP:${now}\nDTSTART:${formatForICS(startDate)}\nDTEND:${formatForICS(endDate)}\nSUMMARY:${escapeICS(event.title)}\nLOCATION:${escapeICS(fullLocation)}\nDESCRIPTION:${escapeICS(`Order #${orderId}\\n\\nView event: ${eventUrl}`)}\nURL:${eventUrl}\nSTATUS:CONFIRMED\nEND:VEVENT\nEND:VCALENDAR`;\n\n\t\tconst blob = new Blob([icsContent], { type: 'text/calendar;charset=utf-8' });\n\t\t// @image-handling-escape: programmatic blob-URL download (export/.ics) — SC Image canonical cannot express in-memory-blob → browser-download\n\t\tconst url = URL.createObjectURL(blob);\n\t\tconst link = document.createElement('a');\n\t\tlink.href = url;\n\t\tconst safeFilename = (event.title || 'event').replace(/[^a-zA-Z0-9\\s-]/g, '').replace(/\\s+/g, '-');\n\t\tlink.download = `${safeFilename}.ics`;\n\t\tdocument.body.appendChild(link);\n\t\tlink.click();\n\t\tdocument.body.removeChild(link);\n\t\tURL.revokeObjectURL(url);\n\n\t\tcalendarOpen = false;\n\t}\n\n\tfunction handleGoogleCalendar() {\n\t\tcalendarOpen = false;\n\t}\n\n\t// --- Share event ---\n\tasync function shareEvent() {\n\t\tconst shareData = { url: eventUrl };\n\n\t\tif (navigator.share) {\n\t\t\ttry {\n\t\t\t\tawait navigator.share(shareData);\n\t\t\t} catch (err: unknown) {\n\t\t\t\tif (err instanceof Error && err.name !== 'AbortError') {\n\t\t\t\t\tfallbackShare();\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfallbackShare();\n\t\t}\n\t}\n\n\tfunction fallbackShare() {\n\t\tnavigator.clipboard.writeText(eventUrl).then(() => {\n\t\t\ttoast.success(labels.linkCopied || 'Link copied to clipboard!');\n\t\t}).catch(() => {\n\t\t\ttoast.error(labels.copyLink || 'Could not copy link — please copy it manually: ' + eventUrl);\n\t\t});\n\t}\n\n\t// --- Wallet handlers (mock — requires backend in production) ---\n\tfunction handleAppleWallet() {\n\t\ttoast.info('Apple Wallet coming soon', {\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\n\t\t});\n\t}\n\n\tfunction handleGoogleWallet() {\n\t\ttoast.info('Google Wallet coming soon', {\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\n\t\t});\n\t}\n\n\t// --- Directions ---\n\tlet directionsUrl = $derived((() => {\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\n\t\tconst query = encodeURIComponent(locationParts.join(', '));\n\t\treturn `https://www.google.com/maps/search/?api=1&query=${query}`;\n\t})());\n\n\t// --- Navigation ---\n\tfunction handleBackToEvent() {\n\t\twindow.location.href = eventUrl;\n\t}\n</script>\n\n<!--\n\tSuccessActions: Sidebar card matching BookingWidget / CheckoutSidebar pattern.\n\tSingle Card with event thumbnail, date summary, wallet badges, action buttons, and links.\n-->\n<div class=\"actions-wrapper\" class:visible={showContent}>\n\t<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\n\t\t<!-- Event poster (same treatment as HeroImage — object-contain, no crop) -->\n\t\t<div class=\"rounded-t-xl overflow-hidden bg-surface-tertiary\">\n\t\t\t<Image\n\t\t\t\tsrc={event.imageUrl}\n\t\t\t\talt={event.title}\n\t\t\t\tfallback={PLACEHOLDER_IMAGE}\n\t\t\t\tfit=\"contain\"\n\t\t\t\tclass=\"w-full max-h-60 min-h-24\"\n\t\t\t/>\n\t\t</div>\n\n\t\t<div class=\"p-5 space-y-4\">\n\t\t\t<!-- Event info -->\n\t\t\t<div>\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight\">\n\t\t\t\t\t{event.title}\n\t\t\t\t</Text>\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1.5\">\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\n\t\t\t\t\t\t{/if}\n\t\t\t\t\t</Text>\n\t\t\t\t</div>\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\n\t\t\t\t\t{event.venue.name}\n\t\t\t\t</Text>\n\t\t\t</div>\n\n\t\t\t<!-- Wallet badges (official brand assets) -->\n\t\t\t<div class=\"flex flex-col items-center gap-3\">\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleAppleWallet}>\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/apple-wallet.svg\"\n\t\t\t\t\t\talt={labels.addToAppleWallet || 'Add to Apple Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img\"\n\t\t\t\t\t/>\n\t\t\t\t</button>\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleGoogleWallet}>\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-dark.svg\"\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img google-dark\"\n\t\t\t\t\t/>\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-light.svg\"\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\n\t\t\t\t\t\tclass=\"wallet-badge-img google-light\"\n\t\t\t\t\t/>\n\t\t\t\t</button>\n\t\t\t</div>\n\n\t\t\t<!-- Divider -->\n\t\t\t<div class=\"divider\"></div>\n\n\t\t\t<!-- Calendar dropdown (full width) -->\n\t\t\t<div class=\"calendar-dropdown relative\">\n\t\t\t\t<Button\n\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\tsize=\"md\"\n\t\t\t\t\tclass=\"w-full\"\n\t\t\t\t\tonclick={toggleCalendar}\n\t\t\t\t>\n\t\t\t\t\t<Calendar size={16} />\n\t\t\t\t\t{labels.addToCalendar || 'Add to Calendar'}\n\t\t\t\t\t<ChevronDown size={16} class=\"ml-auto transition-transform {calendarOpen ? 'rotate-180' : ''}\" />\n\t\t\t\t</Button>\n\n\t\t\t\t{#if calendarOpen}\n\t\t\t\t\t<div class=\"dropdown-menu bg-surface-primary border-default\">\n\t\t\t\t\t\t<a\n\t\t\t\t\t\t\thref={googleCalendarUrl}\n\t\t\t\t\t\t\trel=\"noopener noreferrer\"\n\t\t\t\t\t\t\tclass=\"dropdown-item text-color-primary hover:bg-surface-secondary\"\n\t\t\t\t\t\t\tonclick={handleGoogleCalendar}\n\t\t\t\t\t\t>\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\">\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\"/>\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\"/>\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\"/>\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\"/>\n\t\t\t\t\t\t\t</svg>\n\t\t\t\t\t\t\t{labels.googleCalendar || 'Google Calendar'}\n\t\t\t\t\t\t</a>\n\t\t\t\t\t\t<button type=\"button\" class=\"dropdown-item text-color-primary hover:bg-surface-secondary\" onclick={downloadICS}>\n\t\t\t\t\t\t\t<Apple size={16} class=\"shrink-0\" />\n\t\t\t\t\t\t\t{labels.appleCalendar || 'Apple Calendar (.ics)'}\n\t\t\t\t\t\t</button>\n\t\t\t\t\t</div>\n\t\t\t\t{/if}\n\t\t\t</div>\n\n\t\t\t<!-- Share + Directions row -->\n\t\t\t<div class=\"flex gap-2\">\n\t\t\t\t<Button variant=\"default\" size=\"md\" class=\"flex-1\" onclick={shareEvent}>\n\t\t\t\t\t<Share size={16} />\n\t\t\t\t\t{labels.share || 'Share'}\n\t\t\t\t</Button>\n\n\t\t\t\t{#if event.venue.address}\n\t\t\t\t\t<Button\n\t\t\t\t\t\tvariant=\"default\"\n\t\t\t\t\t\tsize=\"md\"\n\t\t\t\t\t\tclass=\"flex-1\"\n\t\t\t\t\t\thref={directionsUrl}\n\t\t\t\t\t>\n\t\t\t\t\t\t<LocationFilled size={16} />\n\t\t\t\t\t\t{labels.map || 'Map'}\n\t\t\t\t\t</Button>\n\t\t\t\t{/if}\n\t\t\t</div>\n\n\t\t\t<!-- Text links -->\n\t\t\t<div class=\"flex items-center justify-center gap-4 pt-1\">\n\t\t\t\t<button type=\"button\" class=\"text-link text-color-muted hover:text-color-secondary\" onclick={handleBackToEvent}>\n\t\t\t\t\t<ArrowLeft size={16} class=\"shrink-0\" />\n\t\t\t\t\t{labels.backToEvent || 'Back to event'}\n\t\t\t\t</button>\n\n\t\t\t\t{#if event.venue.contactEmail}\n\t\t\t\t\t<span class=\"text-color-muted\">·</span>\n\t\t\t\t\t<a\n\t\t\t\t\t\thref=\"mailto:{event.venue.contactEmail}?subject=Help with Order {orderId}\"\n\t\t\t\t\t\tclass=\"text-link text-color-muted hover:text-color-secondary\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<Help size={16} class=\"shrink-0\" />\n\t\t\t\t\t\t{labels.needHelp || 'Need help?'}\n\t\t\t\t\t</a>\n\t\t\t\t{/if}\n\t\t\t</div>\n\t\t</div>\n\t</Card>\n</div>\n\n<style>\n\t/* Wrapper — fades in with content */\n\t.actions-wrapper {\n\t\topacity: 0;\n\t\ttransform: translateY(8px);\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\n\t}\n\n\t.actions-wrapper.visible {\n\t\topacity: 1;\n\t\ttransform: translateY(0);\n\t}\n\n\t/* Sidebar poster — same object-contain treatment as HeroImage */\n\t/* Wallet badges — official brand assets, no modifications per guidelines */\n\t.wallet-badge-btn {\n\t\tdisplay: block;\n\t\ttransition-property: opacity;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t.wallet-badge-btn:hover {\n\t\topacity: 0.85;\n\t}\n\n\t.wallet-badge-btn:active {\n\t\topacity: 0.7;\n\t}\n\n\t.wallet-badge-img {\n\t\theight: 44px;\n\t\twidth: auto;\n\t}\n\n\t/* Google badge: show dark variant in light mode, light variant in dark mode */\n\t.google-light {\n\t\tdisplay: none;\n\t}\n\n\t/* Calendar dropdown menu */\n\t.dropdown-menu {\n\t\tposition: absolute;\n\t\ttop: 100%;\n\t\tleft: 0;\n\t\tright: 0;\n\t\tmargin-top: 0.25rem;\n\t\tpadding-top: 0.25rem;\n\t\tpadding-bottom: 0.25rem;\n\t\tborder-radius: 0.5rem;\n\t\tbox-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -4px rgb(0 0 0 / 10%);\n\t\tz-index: var(--z-navigation);\n\t\tborder-width: 1px;\n\t\tborder-style: solid;\n\t}\n\n\t.dropdown-item {\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tgap: 0.625rem;\n\t\twidth: 100%;\n\t\tpadding: 0.5rem 0.75rem;\n\t\tfont-size: 0.875rem;\n\t\tline-height: 1.25rem;\n\t\ttext-align: left;\n\t\ttransition-property: color, background-color;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t/* Text links */\n\t.text-link {\n\t\tdisplay: inline-flex;\n\t\talign-items: center;\n\t\tgap: 0.25rem;\n\t\tfont-size: 0.75rem;\n\t\tline-height: 1rem;\n\t\ttransition-property: color;\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n\t\ttransition-duration: 150ms;\n\t}\n\n\t/* Reduced motion */\n\t@media (prefers-reduced-motion: reduce) {\n\t\t.actions-wrapper {\n\t\t\ttransition-duration: 0s;\n\t\t}\n\t}\n</style>","<script lang=\"ts\">\n\timport { toTicketId } from '@getmicdrop/svelte-components';\n\timport { onMount } from 'svelte';\n\timport type { EventData, OrderTotals, OrderLine, SuccessData } from '$lib/public-calendar-flow/types';\n\timport {\n\t\tmockEvent,\n\t\tmockFreeEvent,\n\t\tmockRegistrationEvent,\n\t\tmockDonationEvent\n\t} from '$lib/public-calendar-flow/mock-data';\n\timport { calculateTax } from '$lib/public-calendar-flow/defaults';\n\n\timport SuccessTicket from './SuccessTicket.svelte';\n\timport SuccessActions from './SuccessActions.svelte';\n\timport { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\n\timport { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\n\n\t// --- DataToggle ---\n\ttype SuccessVariant = 'default' | 'free' | 'registration' | 'donation';\n\n\tconst successStateOptions: ToggleOption[] = [\n\t\t{ value: 'default', label: 'Standard', color: 'bg-accent-success' },\n\t\t{ value: 'free', label: 'Free', color: 'bg-sky-500' },\n\t\t{ value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\n\t\t{ value: 'donation', label: 'Donation', color: 'bg-accent-danger' }\n\t];\n\n\tlet dataVariant = $derived(dataToggleStore.current as SuccessVariant);\n\n\t// --- Props (dual-mode: showcase vs production) ---\n\tinterface Props {\n\t\t/** Pre-built success data for production mode. Absence = showcase. */\n\t\tdata?: SuccessData;\n\t\t/** Event page URL for production navigation and sharing. */\n\t\teventUrl?: string;\n\t\tlabels?: Record<string, string>;\n\t}\n\n\tlet {\n\t\tdata: dataProp = undefined,\n\t\teventUrl: eventUrlProp = undefined,\n\t\tlabels = {},\n\t}: Props = $props();\n\n\tconst mergedLabels = $derived(mergeLabels(labels));\n\n\tlet isShowcaseMode = $derived(!dataProp);\n\n\t$effect(() => {\n\t\tif (!isShowcaseMode) return;\n\t\tdataToggleStore.options = successStateOptions;\n\t\tdataToggleStore.current = 'default';\n\t\tdataToggleStore.isActive = true;\n\t\treturn () => {\n\t\t\tdataToggleStore.isActive = false;\n\t\t\tdataToggleStore.options = [];\n\t\t};\n\t});\n\n\t// --- Mock data per variant ---\n\tconst variantData: Record<SuccessVariant, SuccessData> = {\n\t\tdefault: {\n\t\t\tevent: mockEvent,\n\t\t\torderId: '12847',\n\t\t\tlines: [\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(101), ticketName: 'General Admission', quantity: 2, unitPrice: 25, fee: 2.5, subtotal: 50 },\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(102), ticketName: 'VIP Front Row', quantity: 1, unitPrice: 55, fee: 5.5, subtotal: 55 }\n\t\t\t],\n\t\t\tcustomerEmail: 'customer@example.com'\n\t\t},\n\t\tfree: {\n\t\t\tevent: mockFreeEvent,\n\t\t\torderId: '12848',\n\t\t\tlines: [\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(201), ticketName: 'Free Entry', quantity: 2, unitPrice: 0, fee: 0, subtotal: 0 }\n\t\t\t],\n\t\t\tcustomerEmail: 'comedy.fan@gmail.com'\n\t\t},\n\t\tregistration: {\n\t\t\tevent: mockRegistrationEvent,\n\t\t\torderId: '12849',\n\t\t\tlines: [\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(301), ticketName: 'Workshop Seat', quantity: 1, unitPrice: 75, fee: 7.5, subtotal: 75 }\n\t\t\t],\n\t\t\tcustomerEmail: 'learner@example.com'\n\t\t},\n\t\tdonation: {\n\t\t\tevent: mockDonationEvent,\n\t\t\torderId: '12850',\n\t\t\tlines: [\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(401), ticketName: 'Donation', quantity: 1, unitPrice: 25, fee: 0, subtotal: 25 },\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\n\t\t\t\t{ ticketId: toTicketId(402), ticketName: 'Standard Admission', quantity: 1, unitPrice: 30, fee: 3, subtotal: 30 }\n\t\t\t],\n\t\t\tcustomerEmail: 'generous@example.com'\n\t\t}\n\t};\n\n\tlet current: SuccessData = $derived(isShowcaseMode ? variantData[dataVariant] : dataProp!);\n\n\t// Build OrderTotals — the server's persisted order is authoritative\n\t// (basePrice/tax/surcharge/totalPrice match what Stripe charged).\n\t// Fall back to a local sum-of-lines for showcase mode only.\n\tlet orderTotals: OrderTotals = $derived((() => {\n\t\tconst lines = current.lines;\n\t\tif (current.serverTotals) {\n\t\t\treturn {\n\t\t\t\tlines,\n\t\t\t\tsubtotal: current.serverTotals.subtotal,\n\t\t\t\tfees: current.serverTotals.fees,\n\t\t\t\ttaxes: current.serverTotals.taxes,\n\t\t\t\ttotal: current.serverTotals.total,\n\t\t\t\tpromoDiscount: current.serverTotals.promoDiscount,\n\t\t\t\tgiftCardAmount: current.serverTotals.giftCardAmount\n\t\t\t};\n\t\t}\n\t\tconst subtotal = lines.reduce((sum, l) => sum + l.subtotal, 0);\n\t\tconst fees = lines.reduce((sum, l) => sum + l.fee * l.quantity, 0);\n\t\tconst taxes = calculateTax(subtotal + fees, current.event.venue.taxPercentage);\n\t\treturn {\n\t\t\tlines,\n\t\t\tsubtotal,\n\t\t\tfees,\n\t\t\ttaxes,\n\t\t\ttotal: subtotal + fees + taxes,\n\t\t\tpromoDiscount: 0,\n\t\t\tgiftCardAmount: 0\n\t\t};\n\t})());\n\n\tlet eventUrl = $derived(\n\t\tisShowcaseMode\n\t\t\t? (() => {\n\t\t\t\tif (typeof window === 'undefined') return '#';\n\t\t\t\treturn `${window.location.origin}/e/${current.event.id}-${current.event.slug}`;\n\t\t\t})()\n\t\t\t: (eventUrlProp || '#')\n\t);\n\n\t// --- Animation ---\n\tlet showCheckmark = $state(false);\n\tlet showContent = $state(false);\n\tlet reducedMotion = $state(false);\n\n\tfunction runAnimations() {\n\t\tif (reducedMotion) {\n\t\t\tshowCheckmark = true;\n\t\t\tshowContent = true;\n\t\t\treturn;\n\t\t}\n\t\tshowCheckmark = false;\n\t\tshowContent = false;\n\t\tsetTimeout(() => { showCheckmark = true; }, 800);\n\t\tsetTimeout(() => { showContent = true; }, 1600);\n\t}\n\n\t$effect(() => {\n\t\tif (!isShowcaseMode) return;\n\t\tconst _v = dataVariant;\n\t\trunAnimations();\n\t});\n\n\tonMount(() => {\n\t\treducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;\n\t\trunAnimations();\n\t});\n</script>\n\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\n\t<div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\n\n\t\t<!-- ============================================== -->\n\t\t<!-- DESKTOP: Two-column layout (1fr 360px) -->\n\t\t<!-- ============================================== -->\n\t\t<div class=\"hidden md:grid grid-cols-booking-split gap-8 items-start\">\n\n\t\t\t<!-- LEFT COLUMN: Confirmation card -->\n\t\t\t<SuccessTicket\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{orderTotals}\n\t\t\t\tcustomerEmail={current.customerEmail}\n\t\t\t\t{showCheckmark}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\n\t\t\t<!-- RIGHT COLUMN: Sticky sidebar with event info + actions -->\n\t\t\t<div class=\"sticky top-6\">\n\t\t\t\t<SuccessActions\n\t\t\t\t\tevent={current.event}\n\t\t\t\t\torderId={current.orderId}\n\t\t\t\t\t{eventUrl}\n\t\t\t\t\t{showContent}\n\t\t\t\t\tlabels={mergedLabels}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t</div>\n\n\t\t<!-- ============================================== -->\n\t\t<!-- MOBILE: Single column -->\n\t\t<!-- ============================================== -->\n\t\t<div class=\"md:hidden space-y-6\">\n\t\t\t<SuccessTicket\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{orderTotals}\n\t\t\t\tcustomerEmail={current.customerEmail}\n\t\t\t\t{showCheckmark}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\n\t\t\t<SuccessActions\n\t\t\t\tevent={current.event}\n\t\t\t\torderId={current.orderId}\n\t\t\t\t{eventUrl}\n\t\t\t\t{showContent}\n\t\t\t\tlabels={mergedLabels}\n\t\t\t/>\n\t\t</div>\n\t</div>\n</div>\n\n","<script module>\n import { createLogger, toTicketId } from '@getmicdrop/svelte-components';\n const logger = createLogger('Success');\n</script>\n\n<script lang=\"ts\">\n import { onMount } from 'svelte';\n import {\n getOrder,\n clearCheckoutCookies,\n removeCookie,\n } from '$lib/utils/utils.js';\n import { getEmbedConfig } from '$lib/config.js';\n import { postCheckoutComplete } from '$lib/embed-bridge.js';\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\n import SuccessMain from '$lib/public-calendar-flow/Success.svelte';\n import type { SuccessData, OrderLine } from '$lib/public-calendar-flow/types';\n\n // --- Props ---\n interface Props {\n data?: any;\n browseUrl?: string;\n /**\n * Override for the canonical event URL used by the success actions\n * (\"view event\" / share). The full-page get-micdrop.com route lets this\n * default to the current origin; the embed (running on the venue's\n * origin) must pass the get-micdrop.com URL so those links don't 404.\n */\n eventUrl?: string;\n labels?: Record<string, string>;\n }\n\n let {\n data = {},\n browseUrl = '/',\n eventUrl: eventUrlProp = undefined,\n labels = {},\n }: Props = $props();\n\n // --- State ---\n let successData = $state<SuccessData | null>(null);\n let eventUrl = $state('');\n let loadError = $state<string | null>(null);\n let loading = $state(true);\n\n onMount(async () => {\n const {\n id,\n slug,\n event: rawEvent,\n orderId: paramOrderId,\n orderUuid: paramOrderUuid,\n customerEmail: paramEmail,\n ticketCount: paramTicketCount,\n } = data || {};\n\n // Opt-in host notification (configureVenueCalendar({embed:{...}})).\n // Emitted at mount: the order is already complete when Success renders,\n // and a later getOrder failure must not swallow the event. Non-PII payload.\n {\n const { postMessageOnSuccess, postMessageTargetOrigin } =\n getEmbedConfig();\n if (postMessageOnSuccess) {\n // postCheckoutComplete validates the origin and never throws — a bad\n // origin logs one warning and no-ops inside the bridge, so it can't\n // crash this render. We deliberately ignore the boolean here.\n postCheckoutComplete(\n // orderId covers the embed successData shape; orderUuid covers the\n // full-page route, whose +page.js reads BOTH ?orderId= and\n // ?orderUuid= query params (success/+page.js:26-27) and either may\n // be the populated one. Success.svelte already destructures both\n // (paramOrderId/paramOrderUuid above). Non-PII payload (id + eventId).\n {\n orderId: String(paramOrderId || paramOrderUuid || ''),\n eventId: id ?? data?.eventId ?? rawEvent?.id ?? null,\n },\n postMessageTargetOrigin\n );\n }\n }\n\n // Build event URL — an explicit override (embed → get-micdrop.com origin)\n // wins; otherwise use the current origin (the full-page route).\n eventUrl = eventUrlProp || `${window.location.origin}/e/${id}-${slug}`;\n\n // Transform event data\n let eventData;\n try {\n eventData = transformApiEvent(rawEvent);\n } catch (e) {\n logger.warn('Success: transformApiEvent failed:', e);\n loadError = labels.failedToLoadEventData || 'Failed to load event data.';\n loading = false;\n return;\n }\n\n // Fetch order data\n let resolvedOrderId = paramOrderId || '';\n let resolvedEmail = paramEmail || '';\n let orderLines: OrderLine[] = [];\n let serverTotals: any = null;\n\n if (resolvedOrderId) {\n try {\n const order = await getOrder(resolvedOrderId);\n if (order) {\n // Extract email\n resolvedEmail = order.customerEmail || resolvedEmail;\n // Map purchased tickets to OrderLine[] by grouping by ticketTypeId + ticketName\n const tickets = ((order as any).purchasedTickets ||\n (order as any).tickets ||\n []) as any[];\n const grouped = new Map<string, OrderLine>();\n\n for (const ticket of tickets) {\n const key = `${ticket.ticketTypeId || ticket.ticketId || 0}-${ticket.ticketName || ticket.name || ''}`;\n const existing = grouped.get(key);\n if (existing) {\n existing.quantity += 1;\n existing.subtotal += ticket.purchasePrice || ticket.price || 0;\n } else {\n grouped.set(key, {\n ticketId: ticket.ticketTypeId || ticket.ticketId || 0,\n ticketName:\n ticket.ticketName ||\n ticket.name ||\n labels.ticketFallbackName ||\n 'Ticket',\n quantity: 1,\n unitPrice: ticket.purchasePrice || ticket.price || 0,\n fee: 0,\n subtotal: ticket.purchasePrice || ticket.price || 0,\n });\n }\n }\n\n orderLines = Array.from(grouped.values());\n\n // Capture the persisted, server-authoritative totals. These\n // match the actual Stripe charge (totalPrice = basePrice +\n // tax + surcharge) — don't let SuccessMain recompute from\n // lines, which would drop the tax + service fee.\n if (typeof order.totalPrice === 'number') {\n serverTotals = {\n subtotal: order.basePrice ?? 0,\n fees: order.surcharge ?? 0,\n taxes: order.tax ?? 0,\n total: order.totalPrice,\n promoDiscount: order.promoCodeStoredDiscountAmount ?? 0,\n giftCardAmount: order.giftCardPaymentAmount ?? 0,\n stripeAmount:\n Number(order.totalPrice) -\n Number(order.giftCardPaymentAmount ?? 0),\n };\n }\n }\n } catch (e) {\n logger.warn('Success: getOrder failed, using route params:', e);\n // Graceful degradation -- continue with whatever data we have\n }\n }\n\n // If no order lines from API, build a placeholder from route params\n if (orderLines.length === 0 && paramTicketCount > 0) {\n orderLines = [\n {\n ticketId: toTicketId(0),\n ticketName: labels.ticketFallbackName || 'Ticket',\n quantity: paramTicketCount,\n unitPrice: 0,\n fee: 0,\n subtotal: 0,\n },\n ];\n }\n\n // Build SuccessData\n successData = {\n event: eventData,\n orderId: String(resolvedOrderId),\n lines: orderLines,\n customerEmail: resolvedEmail,\n ...(serverTotals ? { serverTotals } : {}),\n };\n\n // Clear checkout cookies AFTER data is loaded (Pitfall 4)\n clearCheckoutCookies(String(id));\n removeCookie('checkout-cartid');\n\n loading = false;\n });\n</script>\n\n{#if loadError}\n <div\n class=\"flex flex-col items-center justify-center py-24 text-center gap-4 error-container\"\n >\n <p>{loadError}</p>\n </div>\n{:else if loading || !successData}\n <div\n class=\"flex items-center justify-center py-24 text-center loading-container\"\n >\n <p>{labels.loadingYourOrder || 'Loading your order'}</p>\n </div>\n{:else}\n <SuccessMain data={successData} {eventUrl} />\n{/if}\n\n<style>\n .loading-container {\n color: hsl(var(--text-secondary, 215 16% 47%));\n }\n\n .error-container p {\n color: hsl(var(--status-sold-out, 0 72% 51%));\n }\n</style>\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","text_5","button_2","Apple","consequent_1","node_12","Share","LocationFilled","consequent_2","div_9","button_3","ArrowLeft","a_1","fragment_9","node_18","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,158 +0,0 @@
1
- import "svelte/internal/disclose-version";
2
- import * as e from "svelte/internal/client";
3
- import { j as A, ax as S } from "./VenueCalendar-tmWZSmhT.js";
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
- function H(T, t) {
6
- e.push(t, !0), A("Image"), typeof process < "u" && process.env?.VITEST;
7
- let f = e.prop(t, "src", 3, ""), _ = e.prop(t, "alt", 3, ""), o = e.prop(t, "class", 3, ""), m = e.prop(t, "fallback", 3, ""), h = e.prop(t, "loading", 3, "lazy"), x = e.prop(t, "fit", 3, "blur-backdrop"), y = e.prop(t, "blurUp", 3, !0), p = e.prop(t, "branded", 3, !0), s = e.state(e.proxy(
8
- // eslint-disable-next-line svelte/valid-compile -- known Svelte compiler note, accepted for this primitive
9
- f() ? "src" : m() ? "fallback" : "failed"
10
- )), b = e.state(!1), u = e.state(!1);
11
- e.user_effect(() => {
12
- const l = f(), a = m();
13
- e.set(s, l ? "src" : a ? "fallback" : "failed", !0), e.set(b, !1), e.set(u, !1);
14
- });
15
- let d = e.derived(() => e.get(s) === "src" ? f() : e.get(s) === "fallback" ? m() : ""), w = e.derived(() => e.get(s) !== "failed" && !!e.get(d)), k = e.derived(() => x() === "blur-backdrop"), I = e.derived(() => e.get(k) ? "contain" : x());
16
- const j = /(?:^|\s)(?:aspect-|size-|h-(?!auto\b))/;
17
- let E = e.derived(() => !!t.aspectRatio || t.width != null && t.height != null || j.test(o()));
18
- e.user_effect(() => {
19
- });
20
- let z = e.derived(() => [
21
- t.width != null ? `width:${t.width}px` : "",
22
- t.height != null ? `height:${t.height}px` : "",
23
- t.aspectRatio ? `aspect-ratio:${t.aspectRatio}` : ""
24
- ].filter(Boolean).join(";"));
25
- async function C(l) {
26
- const a = l.currentTarget, c = e.get(d);
27
- try {
28
- await a.decode?.();
29
- } catch {
30
- }
31
- e.get(d) === c && (e.set(u, !0), t.onload?.(l));
32
- }
33
- function R() {
34
- if (e.get(s) === "src" && m() && m() !== f()) {
35
- e.set(s, "fallback");
36
- return;
37
- }
38
- e.set(s, "failed"), e.get(b) || (e.set(b, !0), t.onError?.());
39
- }
40
- var B = e.comment(), L = e.first_child(B);
41
- {
42
- var N = (l) => {
43
- var a = D();
44
- let c;
45
- var n = e.child(a), i = e.sibling(n, 2);
46
- let g, r;
47
- e.reset(a), e.template_effect(
48
- (v) => {
49
- c = e.set_class(a, 1, v, "svelte-12gell2", c, { "sc-image--backdrop-reserved": e.get(E) }), e.set_style(a, e.get(z) || void 0), e.set_attribute(n, "src", e.get(d)), e.set_attribute(n, "loading", h()), e.set_attribute(n, "draggable", t.draggable), e.set_attribute(n, "fetchpriority", t.fetchpriority), e.set_attribute(i, "src", e.get(d)), e.set_attribute(i, "alt", _()), g = e.set_class(i, 1, "sc-image__main svelte-12gell2", null, g, {
50
- "sc-image__main--reserved": e.get(E),
51
- "sc-image__main--loading": y() && !e.get(u)
52
- }), e.set_attribute(i, "width", t.width), e.set_attribute(i, "height", t.height), e.set_attribute(i, "loading", h()), e.set_attribute(i, "draggable", t.draggable), e.set_attribute(i, "fetchpriority", t.fetchpriority), r = e.set_style(i, "", r, { "object-fit": e.get(I) });
53
- },
54
- [() => e.clsx(S("sc-image sc-image--backdrop", o()))]
55
- ), e.event("error", i, R), e.event("load", i, C), e.replay_events(i), e.append(l, a);
56
- }, F = (l) => {
57
- var a = O();
58
- let c;
59
- e.template_effect(
60
- (n) => {
61
- e.set_attribute(a, "src", e.get(d)), e.set_attribute(a, "alt", _()), e.set_attribute(a, "loading", h()), e.set_attribute(a, "draggable", t.draggable), e.set_attribute(a, "fetchpriority", t.fetchpriority), e.set_attribute(a, "width", t.width), e.set_attribute(a, "height", t.height), e.set_class(a, 1, n, "svelte-12gell2"), c = e.set_style(a, "", c, {
62
- "object-fit": e.get(I),
63
- "aspect-ratio": t.aspectRatio || void 0
64
- });
65
- },
66
- [
67
- () => e.clsx(S("sc-image image", y() && !e.get(u) && "sc-image--loading", o()))
68
- ]
69
- ), e.event("error", a, R), e.event("load", a, C), e.replay_events(a), e.append(l, a);
70
- }, U = (l) => {
71
- var a = e.comment(), c = e.first_child(a);
72
- {
73
- var n = (g) => {
74
- var r = V();
75
- e.template_effect(
76
- (v) => {
77
- e.set_class(r, 1, v, "svelte-12gell2"), e.set_style(r, e.get(z) || void 0), e.set_attribute(r, "aria-label", _());
78
- },
79
- [
80
- () => e.clsx(S("sc-image image sc-image-placeholder image-placeholder", p() && "sc-image-placeholder--branded", o()))
81
- ]
82
- ), e.append(g, r);
83
- }, i = (g) => {
84
- var r = X();
85
- e.template_effect(
86
- (v) => {
87
- e.set_class(r, 1, v, "svelte-12gell2"), e.set_style(r, e.get(z) || void 0);
88
- },
89
- [
90
- () => e.clsx(S("sc-image image sc-image-placeholder image-placeholder", p() && "sc-image-placeholder--branded", o()))
91
- ]
92
- ), e.append(g, r);
93
- };
94
- e.if(c, (g) => {
95
- _() ? g(n) : g(i, -1);
96
- });
97
- }
98
- e.append(l, a);
99
- };
100
- e.if(L, (l) => {
101
- e.get(w) && e.get(k) ? l(N) : e.get(w) ? l(F, 1) : l(U, -1);
102
- });
103
- }
104
- e.append(T, B), e.pop();
105
- }
106
- function J(T, t) {
107
- e.push(t, !0);
108
- let f = e.prop(t, "as", 3, "span"), _ = e.prop(t, "size", 3, "md"), o = e.prop(t, "color", 3, "default"), m = e.prop(t, "weight", 3, "normal"), h = e.prop(t, "truncate", 3, !1), x = e.prop(t, "class", 3, "");
109
- const y = {
110
- xs: "text-xs",
111
- sm: "text-sm",
112
- base: "text-base",
113
- md: "text-base",
114
- lg: "text-lg",
115
- xl: "text-xl",
116
- "2xl": "text-2xl"
117
- }, p = {
118
- default: "text-text-primary",
119
- muted: "text-muted-foreground",
120
- primary: "text-primary-600",
121
- secondary: "text-text-secondary",
122
- success: "text-accent-success",
123
- warning: "text-accent-warning",
124
- error: "text-accent-danger",
125
- none: ""
126
- }, s = {
127
- none: "leading-none",
128
- tight: "leading-tight",
129
- snug: "leading-snug",
130
- normal: "leading-normal",
131
- relaxed: "leading-relaxed",
132
- loose: "leading-loose"
133
- }, b = {
134
- normal: "font-normal",
135
- medium: "font-medium",
136
- semibold: "font-semibold",
137
- bold: "font-bold"
138
- };
139
- let u = e.derived(() => [
140
- y[_()] || "text-base",
141
- t.leading ? s[t.leading] : "",
142
- p[o()] || "",
143
- b[m()],
144
- h() ? "truncate" : "",
145
- x()
146
- ].filter(Boolean).join(" "));
147
- var d = e.comment(), w = e.first_child(d);
148
- e.element(w, f, !1, (k, I) => {
149
- e.attribute_effect(k, () => ({ class: e.get(u) }));
150
- var j = e.comment(), E = e.first_child(j);
151
- e.snippet(E, () => t.children), e.append(I, j);
152
- }), e.append(T, d), e.pop();
153
- }
154
- export {
155
- H as I,
156
- J as T
157
- };
158
- //# sourceMappingURL=Text-ZUPglf_o.js.map