@getmicdrop/venue-calendar 4.0.84 → 4.0.86

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 (68) hide show
  1. package/README.md +740 -740
  2. package/dist/{CartView-DwAGELwG.js → CartView-e2hG7cOV.js} +5 -5
  3. package/dist/CartView-e2hG7cOV.js.map +1 -0
  4. package/dist/{Checkout-CHo11MsU.js → Checkout-BpTUMyLk.js} +7 -7
  5. package/dist/Checkout-BpTUMyLk.js.map +1 -0
  6. package/dist/Checkout-DmnOMwhl.js +809 -0
  7. package/dist/Checkout-DmnOMwhl.js.map +1 -0
  8. package/dist/{CheckoutTimer-CAGR7L-7.js → CheckoutTimer-Dv0c-X6O.js} +4 -4
  9. package/dist/CheckoutTimer-Dv0c-X6O.js.map +1 -0
  10. package/dist/{CollectionView-Dstgu8sR.js → CollectionView-CyxK6aI9.js} +5 -5
  11. package/dist/CollectionView-CyxK6aI9.js.map +1 -0
  12. package/dist/{Event-kfRjkMzQ.js → Event-Cw7b9UEd.js} +6 -6
  13. package/dist/{Event-kfRjkMzQ.js.map → Event-Cw7b9UEd.js.map} +1 -1
  14. package/dist/{EventPage-CnhccVCI.js → EventPage-BKtFiZL1.js} +7 -7
  15. package/dist/EventPage-BKtFiZL1.js.map +1 -0
  16. package/dist/{Heading-Ielp7dS-.js → Heading-D0grC8vd.js} +2 -2
  17. package/dist/{Heading-Ielp7dS-.js.map → Heading-D0grC8vd.js.map} +1 -1
  18. package/dist/{ModalHeader-Q7levd4l.js → ModalHeader-V5AlK1dt.js} +2 -2
  19. package/dist/{ModalHeader-Q7levd4l.js.map → ModalHeader-V5AlK1dt.js.map} +1 -1
  20. package/dist/{ScarcityBadge-CG7Mz5YN.js → ScarcityBadge-Co7gZXuW.js} +2 -2
  21. package/dist/ScarcityBadge-Co7gZXuW.js.map +1 -0
  22. package/dist/{SeriesPage-C8fIvt63.js → SeriesPage-USYe3APQ.js} +5 -5
  23. package/dist/SeriesPage-USYe3APQ.js.map +1 -0
  24. package/dist/{Success-SZNXo-Ou.js → Success-C387RvIY.js} +7 -7
  25. package/dist/Success-C387RvIY.js.map +1 -0
  26. package/dist/{Text-DHgQP4rA.js → Text-ZUPglf_o.js} +2 -2
  27. package/dist/{Text-DHgQP4rA.js.map → Text-ZUPglf_o.js.map} +1 -1
  28. package/dist/{VenueCalendar-DTOyAhDU.js → VenueCalendar-tmWZSmhT.js} +21 -18
  29. package/dist/VenueCalendar-tmWZSmhT.js.map +1 -0
  30. package/dist/{ViewTicketsEmbed-DBEOjijY.js → ViewTicketsEmbed--091XJJn.js} +4 -4
  31. package/dist/ViewTicketsEmbed--091XJJn.js.map +1 -0
  32. package/dist/api/api.cjs +1 -1
  33. package/dist/api/api.cjs.map +1 -1
  34. package/dist/api/api.mjs +18 -15
  35. package/dist/api/api.mjs.map +1 -1
  36. package/dist/api/gift-cards.d.ts +3 -2
  37. package/dist/{data-toggle-store.svelte-E2JyoGTV.js → data-toggle-store.svelte-Bn0h8FT_.js} +2 -2
  38. package/dist/data-toggle-store.svelte-Bn0h8FT_.js.map +1 -0
  39. package/dist/{labels-nQIooadc.js → labels-C7Znep_T.js} +3 -3
  40. package/dist/labels-C7Znep_T.js.map +1 -0
  41. package/dist/seo/seo.cjs.map +1 -1
  42. package/dist/seo/seo.mjs.map +1 -1
  43. package/dist/{transform-C1Rmuzlt.js → transform-BxgTZDAD.js} +2 -2
  44. package/dist/transform-BxgTZDAD.js.map +1 -0
  45. package/dist/types/index.d.ts +442 -442
  46. package/dist/venue-calendar.css +1 -1
  47. package/dist/venue-calendar.es.js +2 -2
  48. package/dist/venue-calendar.iife.js +20 -20
  49. package/dist/venue-calendar.iife.js.map +1 -1
  50. package/dist/venue-calendar.umd.js +19 -19
  51. package/dist/venue-calendar.umd.js.map +1 -1
  52. package/package.json +170 -170
  53. package/src/lib/theme.js +222 -222
  54. package/dist/CartView-DwAGELwG.js.map +0 -1
  55. package/dist/Checkout-CHo11MsU.js.map +0 -1
  56. package/dist/Checkout-_NuoBAKt.js +0 -789
  57. package/dist/Checkout-_NuoBAKt.js.map +0 -1
  58. package/dist/CheckoutTimer-CAGR7L-7.js.map +0 -1
  59. package/dist/CollectionView-Dstgu8sR.js.map +0 -1
  60. package/dist/EventPage-CnhccVCI.js.map +0 -1
  61. package/dist/ScarcityBadge-CG7Mz5YN.js.map +0 -1
  62. package/dist/SeriesPage-C8fIvt63.js.map +0 -1
  63. package/dist/Success-SZNXo-Ou.js.map +0 -1
  64. package/dist/VenueCalendar-DTOyAhDU.js.map +0 -1
  65. package/dist/ViewTicketsEmbed-DBEOjijY.js.map +0 -1
  66. package/dist/data-toggle-store.svelte-E2JyoGTV.js.map +0 -1
  67. package/dist/labels-nQIooadc.js.map +0 -1
  68. package/dist/transform-C1Rmuzlt.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"Checkout-_NuoBAKt.js","sources":["../node_modules/@stripe/stripe-js/dist/index.mjs","../src/lib/utils/stripe-errors.ts","../src/components/Events/Checkout/GiftCardInput.svelte","../src/components/Views/Checkout.svelte"],"sourcesContent":["function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nvar RELEASE_TRAIN = 'clover';\n\nvar runtimeVersionToUrlVersion = function runtimeVersionToUrlVersion(version) {\n return version === 3 ? 'v3' : version;\n};\n\nvar ORIGIN = 'https://js.stripe.com';\nvar STRIPE_JS_URL = \"\".concat(ORIGIN, \"/\").concat(RELEASE_TRAIN, \"/stripe.js\");\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\nvar STRIPE_JS_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/(v3|[a-z]+)\\/stripe\\.js(\\?.*)?$/;\nvar EXISTING_SCRIPT_MESSAGE = 'loadStripe.setLoadParameters was called but an existing Stripe.js script already exists in the document; existing script parameters will be used';\n\nvar isStripeJSURL = function isStripeJSURL(url) {\n return V3_URL_REGEX.test(url) || STRIPE_JS_URL_REGEX.test(url);\n};\n\nvar findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(ORIGIN, \"\\\"]\"));\n\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n\n if (!isStripeJSURL(script.src)) {\n continue;\n }\n\n return script;\n }\n\n return null;\n};\n\nvar injectScript = function injectScript(params) {\n var queryString = params && !params.advancedFraudSignals ? '?advancedFraudSignals=false' : '';\n var script = document.createElement('script');\n script.src = \"\".concat(STRIPE_JS_URL).concat(queryString);\n var headOrBody = document.head || document.body;\n\n if (!headOrBody) {\n throw new Error('Expected document.body not to be null. Stripe.js requires a <body> element.');\n }\n\n headOrBody.appendChild(script);\n return script;\n};\n\nvar registerWrapper = function registerWrapper(stripe, startTime) {\n if (!stripe || !stripe._registerWrapper) {\n return;\n }\n\n stripe._registerWrapper({\n name: 'stripe-js',\n version: \"8.8.0\",\n startTime: startTime\n });\n};\n\nvar stripePromise$1 = null;\nvar onErrorListener = null;\nvar onLoadListener = null;\n\nvar onError = function onError(reject) {\n return function (cause) {\n reject(new Error('Failed to load Stripe.js', {\n cause: cause\n }));\n };\n};\n\nvar onLoad = function onLoad(resolve, reject) {\n return function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n };\n};\n\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise$1 !== null) {\n return stripePromise$1;\n }\n\n stripePromise$1 = new Promise(function (resolve, reject) {\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n // Resolve to null when imported server side. This makes the module\n // safe to import in an isomorphic code base.\n resolve(null);\n return;\n }\n\n if (window.Stripe && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n }\n\n if (window.Stripe) {\n resolve(window.Stripe);\n return;\n }\n\n try {\n var script = findScript();\n\n if (script && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n } else if (!script) {\n script = injectScript(params);\n } else if (script && onLoadListener !== null && onErrorListener !== null) {\n var _script$parentNode;\n\n // remove event listeners\n script.removeEventListener('load', onLoadListener);\n script.removeEventListener('error', onErrorListener); // if script exists, but we are reloading due to an error,\n // reload script to trigger 'load' event\n\n (_script$parentNode = script.parentNode) === null || _script$parentNode === void 0 ? void 0 : _script$parentNode.removeChild(script);\n script = injectScript(params);\n }\n\n onLoadListener = onLoad(resolve, reject);\n onErrorListener = onError(reject);\n script.addEventListener('load', onLoadListener);\n script.addEventListener('error', onErrorListener);\n } catch (error) {\n reject(error);\n return;\n }\n }); // Resets stripePromise on error\n\n return stripePromise$1[\"catch\"](function (error) {\n stripePromise$1 = null;\n return Promise.reject(error);\n });\n};\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\n }\n\n var pk = args[0];\n\n if (typeof pk !== 'string') {\n throw new Error(\"Expected publishable key to be of type string, got type \".concat(_typeof(pk), \" instead.\"));\n }\n\n var isTestKey = pk.match(/^pk_test/); // @ts-expect-error this is not publicly typed\n\n var version = runtimeVersionToUrlVersion(maybeStripe.version);\n var expectedVersion = RELEASE_TRAIN;\n\n if (isTestKey && version !== expectedVersion) {\n console.warn(\"Stripe.js@\".concat(version, \" was loaded on the page, but @stripe/stripe-js@\").concat(\"8.8.0\", \" expected Stripe.js@\").concat(expectedVersion, \". This may result in unexpected behavior. For more information, see https://docs.stripe.com/sdks/stripejs-versioning\"));\n }\n\n var stripe = maybeStripe.apply(undefined, args);\n registerWrapper(stripe, startTime);\n return stripe;\n}; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\nvar stripePromise;\nvar loadCalled = false;\n\nvar getStripePromise = function getStripePromise() {\n if (stripePromise) {\n return stripePromise;\n }\n\n stripePromise = loadScript(null)[\"catch\"](function (error) {\n // clear cache on error\n stripePromise = null;\n return Promise.reject(error);\n });\n return stripePromise;\n}; // Execute our own script injection after a tick to give users time to do their\n// own script injection.\n\n\nPromise.resolve().then(function () {\n return getStripePromise();\n})[\"catch\"](function (error) {\n if (!loadCalled) {\n console.warn(error);\n }\n});\nvar loadStripe = function loadStripe() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n loadCalled = true;\n var startTime = Date.now(); // if previous attempts are unsuccessful, will re-load script\n\n return getStripePromise().then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\n\nexport { loadStripe };\n","// Stripe error code to user-friendly message mapping.\r\n// Extracted from Views/Checkout.svelte for reuse across checkout implementations.\r\n\r\nexport interface PaymentErrorDetails {\r\n\ttype: string; // 'card_declined', 'network', 'validation', 'general', 'rate_limit'\r\n\ttitle: string;\r\n\tmessage: string;\r\n\tsuggestion: string;\r\n\tretryable: boolean;\r\n}\r\n\r\n/**\r\n * Maps a Stripe error object to user-friendly error details.\r\n * Handles card_declined (insufficient_funds, lost_card, stolen_card, expired_card),\r\n * api_connection_error/network, rate_limit, incorrect_number/invalid_cvc/invalid_expiry,\r\n * and a default fallback.\r\n */\r\nexport function getPaymentErrorDetails(error: any): PaymentErrorDetails {\r\n\tconst errorCode = error?.code || error?.decline_code || '';\r\n\tconst errorType = error?.type || '';\r\n\tconst errorMessage = error?.message || '';\r\n\r\n\t// Card declined errors\r\n\tif (errorCode === 'card_declined' || errorType === 'card_error') {\r\n\t\tconst declineCode = error?.decline_code || '';\r\n\r\n\t\tif (declineCode === 'insufficient_funds') {\r\n\t\t\treturn {\r\n\t\t\t\ttype: 'card_declined',\r\n\t\t\t\ttitle: 'Insufficient funds',\r\n\t\t\t\tmessage: 'Your card has insufficient funds to complete this purchase.',\r\n\t\t\t\tsuggestion: 'Please try a different payment method or contact your bank.',\r\n\t\t\t\tretryable: true,\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\tif (declineCode === 'lost_card' || declineCode === 'stolen_card') {\r\n\t\t\treturn {\r\n\t\t\t\ttype: 'card_declined',\r\n\t\t\t\ttitle: 'Card cannot be used',\r\n\t\t\t\tmessage: 'This card cannot be used for this transaction.',\r\n\t\t\t\tsuggestion: 'Please use a different payment method.',\r\n\t\t\t\tretryable: true,\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\tif (declineCode === 'expired_card') {\r\n\t\t\treturn {\r\n\t\t\t\ttype: 'card_declined',\r\n\t\t\t\ttitle: 'Card expired',\r\n\t\t\t\tmessage: 'Your card has expired.',\r\n\t\t\t\tsuggestion: 'Please use a different card or update your card details.',\r\n\t\t\t\tretryable: true,\r\n\t\t\t};\r\n\t\t}\r\n\r\n\t\treturn {\r\n\t\t\ttype: 'card_declined',\r\n\t\t\ttitle: 'Card declined',\r\n\t\t\tmessage: 'Your card was declined by your bank.',\r\n\t\t\tsuggestion: 'Please try a different card or contact your bank for more information.',\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\t// Network/connection errors\r\n\tif (\r\n\t\terrorType === 'api_connection_error' ||\r\n\t\terrorMessage.includes('network') ||\r\n\t\terrorMessage.includes('connection')\r\n\t) {\r\n\t\treturn {\r\n\t\t\ttype: 'network',\r\n\t\t\ttitle: 'Connection error',\r\n\t\t\tmessage: \"We couldn't connect to the payment server.\",\r\n\t\t\tsuggestion: 'Please check your internet connection and try again.',\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\t// Rate limiting\r\n\tif (errorCode === 'rate_limit') {\r\n\t\treturn {\r\n\t\t\ttype: 'rate_limit',\r\n\t\t\ttitle: 'Too many attempts',\r\n\t\t\tmessage: 'Too many payment attempts. Please wait a moment.',\r\n\t\t\tsuggestion: 'Wait 30 seconds before trying again.',\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\t// Invalid card details\r\n\tif (errorCode === 'incorrect_number' || errorCode === 'invalid_number') {\r\n\t\treturn {\r\n\t\t\ttype: 'validation',\r\n\t\t\ttitle: 'Invalid card number',\r\n\t\t\tmessage: 'The card number you entered is invalid.',\r\n\t\t\tsuggestion: 'Please check your card number and try again.',\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\tif (errorCode === 'incorrect_cvc' || errorCode === 'invalid_cvc') {\r\n\t\treturn {\r\n\t\t\ttype: 'validation',\r\n\t\t\ttitle: 'Invalid security code',\r\n\t\t\tmessage: 'The security code (CVC) is incorrect.',\r\n\t\t\tsuggestion: 'Please check the 3-digit code on the back of your card.',\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\tif (errorCode === 'invalid_expiry_month' || errorCode === 'invalid_expiry_year') {\r\n\t\treturn {\r\n\t\t\ttype: 'validation',\r\n\t\t\ttitle: 'Invalid expiration date',\r\n\t\t\tmessage: 'The expiration date is invalid.',\r\n\t\t\tsuggestion: \"Please check your card's expiration date.\",\r\n\t\t\tretryable: true,\r\n\t\t};\r\n\t}\r\n\r\n\t// Default error\r\n\treturn {\r\n\t\ttype: 'general',\r\n\t\ttitle: 'Payment failed',\r\n\t\tmessage: errorMessage || 'Something went wrong with your payment.',\r\n\t\tsuggestion: 'Please try again or use a different payment method.',\r\n\t\tretryable: true,\r\n\t};\r\n}\r\n","<!-- native-element-exception: VC is an embeddable widget — native <button>s are intentional here (widget-controlled styling on calendar cells, date selectors, checkout/nav CTAs). -->\r\n<script module>\r\n import { createLogger } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('GiftCardInput');\r\n</script>\r\n\r\n<script>\r\n import { Gift, Close, Checkmark, Warning } from 'carbon-icons-svelte';\r\n import {\r\n DURATION,\r\n formatCurrency,\r\n safeSlide,\r\n } from '@getmicdrop/svelte-components';\r\n import { applyGiftCard, removeGiftCard } from '$lib/api';\r\n\r\n let {\r\n cartId,\r\n onApplied = () => {},\r\n onRemoved = () => {},\r\n disabled = false,\r\n labels = {},\r\n } = $props();\r\n\r\n let code = $state('');\r\n let loading = $state(false);\r\n let error = $state('');\r\n let appliedCard = $state(null);\r\n let showInput = $state(false);\r\n\r\n async function handleApply() {\r\n if (!code.trim() || loading || !cartId) return;\r\n\r\n loading = true;\r\n error = '';\r\n\r\n try {\r\n const result = await applyGiftCard(cartId, code.trim().toUpperCase());\r\n\r\n if (result.valid) {\r\n appliedCard = {\r\n code: result.giftCardCode || code.trim().toUpperCase(),\r\n giftCardAmount: result.giftCardAmount,\r\n giftCardBalance: result.giftCardBalance,\r\n paymentType: result.paymentType,\r\n stripeAmount: result.stripeAmount,\r\n orderTotal: result.orderTotal,\r\n requiresStripe: result.requiresStripe,\r\n };\r\n code = '';\r\n showInput = false;\r\n onApplied(appliedCard);\r\n } else {\r\n error =\r\n result.error ||\r\n labels.invalidGiftCardCode ||\r\n 'Invalid gift card code';\r\n }\r\n } catch (err) {\r\n logger.error('Error applying gift card:', err);\r\n error =\r\n labels.failedToApplyGiftCard ||\r\n 'Failed to apply gift card. Please try again.';\r\n }\r\n\r\n loading = false;\r\n }\r\n\r\n async function handleRemove() {\r\n if (loading || !cartId) return;\r\n\r\n loading = true;\r\n error = '';\r\n\r\n try {\r\n const result = await removeGiftCard(cartId);\r\n\r\n if (!result.error) {\r\n const previousCard = appliedCard;\r\n appliedCard = null;\r\n showInput = false;\r\n onRemoved(previousCard);\r\n } else {\r\n error = result.error;\r\n }\r\n } catch (err) {\r\n logger.error('Error removing gift card:', err);\r\n error =\r\n labels.failedToRemoveGiftCard ||\r\n 'Failed to remove gift card. Please try again.';\r\n }\r\n\r\n loading = false;\r\n }\r\n\r\n function handleKeydown(e) {\r\n if (e.key === 'Enter' && !loading) {\r\n handleApply();\r\n }\r\n }\r\n\r\n function toggleInput() {\r\n if (!appliedCard) {\r\n showInput = !showInput;\r\n if (!showInput) {\r\n code = '';\r\n error = '';\r\n }\r\n }\r\n }\r\n</script>\r\n\r\n<div class=\"mb-4\">\r\n {#if appliedCard}\r\n <!-- Applied gift card display -->\r\n <div\r\n class=\"applied-card\"\r\n transition:safeSlide={{ duration: DURATION.fast }}\r\n >\r\n <div class=\"flex items-center gap-3\">\r\n <div class=\"applied-icon\">\r\n <Checkmark size={16} />\r\n </div>\r\n <div class=\"flex flex-col flex-1\">\r\n <span class=\"text-xs text-status-success-text font-medium\"\r\n >{labels.giftCardApplied || 'Gift card applied'}</span\r\n >\r\n <span class=\"text-sm font-mono text-text-primary\"\r\n >{appliedCard.code}</span\r\n >\r\n </div>\r\n <button\r\n class=\"remove-btn\"\r\n onclick={handleRemove}\r\n disabled={loading || disabled}\r\n aria-label={labels.removeGiftCard || 'Remove gift card'}\r\n >\r\n {#if loading}\r\n <span class=\"gc-spinner gc-spinner-sm\"></span>\r\n {:else}\r\n <Close size={16} />\r\n {/if}\r\n </button>\r\n </div>\r\n <div class=\"applied-details\">\r\n <div class=\"flex justify-between items-center text-sm\">\r\n <span class=\"text-text-secondary\"\r\n >{labels.appliedToOrder || 'Applied to order'}</span\r\n >\r\n <span class=\"font-medium text-accent-success\"\r\n >-{formatCurrency(appliedCard.giftCardAmount)}</span\r\n >\r\n </div>\r\n {#if appliedCard.paymentType === 'gift_card_only'}\r\n <div class=\"full-coverage-badge\">\r\n <Checkmark size={16} />\r\n <span\r\n >{labels.fullyCoveredByGiftCard ||\r\n 'Fully covered by gift card'}</span\r\n >\r\n </div>\r\n {:else if appliedCard.paymentType === 'split'}\r\n <div class=\"flex justify-between items-center text-sm mt-1.5\">\r\n <span class=\"text-text-secondary\"\r\n >{labels.remainingToPay || 'Remaining to pay'}</span\r\n >\r\n <span class=\"font-medium text-text-primary\"\r\n >{formatCurrency(appliedCard.stripeAmount)}</span\r\n >\r\n </div>\r\n {/if}\r\n </div>\r\n </div>\r\n {:else}\r\n <!-- Gift card input toggle -->\r\n <button\r\n class=\"gift-card-toggle\"\r\n onclick={toggleInput}\r\n {disabled}\r\n aria-expanded={showInput}\r\n >\r\n <Gift size={20} class=\"gift-icon\" />\r\n <span>{labels.haveAGiftCard || 'Have a gift card?'}</span>\r\n <span class=\"toggle-indicator\">{showInput ? '-' : '+'}</span>\r\n </button>\r\n\r\n {#if showInput}\r\n <div\r\n class=\"input-section\"\r\n transition:safeSlide={{ duration: DURATION.fast }}\r\n >\r\n <div class=\"flex gap-2\">\r\n <input\r\n type=\"text\"\r\n name=\"giftCardCode\"\r\n aria-label={labels.enterGiftCardCode || 'Enter gift card code'}\r\n bind:value={code}\r\n onkeydown={handleKeydown}\r\n placeholder={labels.enterGiftCardCode || 'Enter gift card code'}\r\n disabled={loading || disabled}\r\n class=\"gift-input\"\r\n class:has-error={!!error}\r\n autocomplete=\"off\"\r\n autocapitalize=\"characters\"\r\n />\r\n <button\r\n class=\"apply-btn\"\r\n onclick={handleApply}\r\n disabled={!code.trim() || loading || disabled}\r\n >\r\n {#if loading}\r\n <span class=\"gc-spinner\"></span>\r\n {:else}\r\n {labels.apply || 'Apply'}\r\n {/if}\r\n </button>\r\n </div>\r\n {#if error}\r\n <div\r\n class=\"flex items-center gap-1.5 mt-2 text-sm text-accent-danger\"\r\n transition:safeSlide={{ duration: DURATION.micro }}\r\n >\r\n <Warning size={16} />\r\n <span>{error}</span>\r\n </div>\r\n {/if}\r\n </div>\r\n {/if}\r\n {/if}\r\n</div>\r\n\r\n<style>\r\n .gift-card-toggle {\r\n display: flex;\r\n align-items: center;\r\n gap: 0.5rem;\r\n width: 100%;\r\n padding: 0.75rem 1rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n font-weight: 500;\r\n background-color: hsl(var(--bg-secondary));\r\n border-radius: 0.5rem;\r\n border: 1px solid hsl(var(--border));\r\n color: hsl(var(--text-secondary));\r\n cursor: pointer;\r\n transition-property: background-color, color;\r\n transition-duration: 150ms;\r\n }\r\n\r\n .gift-card-toggle:hover:not(:disabled) {\r\n background-color: hsl(var(--bg-tertiary));\r\n\r\n &:is([data-theme='dark'], [data-theme='dark'] *) {\r\n background-color: hsl(var(--muted));\r\n }\r\n }\r\n\r\n .gift-card-toggle:disabled {\r\n opacity: 0.5;\r\n cursor: not-allowed;\r\n }\r\n\r\n .gift-card-toggle :global(.gift-icon) {\r\n color: hsl(var(--text-tertiary));\r\n\r\n &:is([data-theme='dark'], [data-theme='dark'] *) {\r\n color: hsl(var(--text-head));\r\n }\r\n }\r\n\r\n .toggle-indicator {\r\n margin-left: auto;\r\n color: hsl(var(--text-head));\r\n font-size: 1.125rem;\r\n font-weight: 300;\r\n }\r\n\r\n .input-section {\r\n margin-top: 0.75rem;\r\n padding: 1rem;\r\n background-color: hsl(var(--bg-secondary));\r\n border-radius: 0.5rem;\r\n border: 1px solid hsl(var(--border));\r\n }\r\n\r\n .gift-input {\r\n width: 100%;\r\n padding: 0.5rem 0.75rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n border-radius: 0.5rem;\r\n border: 1px solid hsl(var(--stroke-primary));\r\n background-color: hsl(var(--bg-primary));\r\n color: hsl(var(--text-primary));\r\n flex: 1;\r\n text-transform: uppercase;\r\n transition-property: border-color;\r\n transition-duration: 150ms;\r\n }\r\n\r\n .gift-input::placeholder {\r\n color: hsl(var(--text-head));\r\n\r\n &:is([data-theme='dark'], [data-theme='dark'] *) {\r\n color: hsl(var(--text-tertiary));\r\n }\r\n }\r\n\r\n .gift-input:focus {\r\n outline: none;\r\n box-shadow: 0 0 0 2px hsl(var(--brand-primary));\r\n border-color: transparent;\r\n }\r\n\r\n .gift-input.has-error {\r\n border-color: hsl(var(--accent-danger));\r\n }\r\n\r\n .gift-input:disabled {\r\n opacity: 0.5;\r\n cursor: not-allowed;\r\n }\r\n\r\n .apply-btn {\r\n padding: 0.5rem 1rem;\r\n font-size: 0.875rem;\r\n line-height: 1.25rem;\r\n font-weight: 500;\r\n border-radius: 0.5rem;\r\n color: hsl(var(--bg-primary));\r\n border: none;\r\n transition-property: background-color;\r\n transition-duration: 150ms;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n min-width: 4rem;\r\n cursor: pointer;\r\n background-color: hsl(var(--brand-primary, 224 76% 48%));\r\n }\r\n\r\n .apply-btn:hover:not(:disabled) {\r\n filter: brightness(0.9);\r\n }\r\n\r\n .apply-btn:disabled {\r\n opacity: 0.5;\r\n cursor: not-allowed;\r\n }\r\n\r\n /* Applied card styles */\r\n .applied-card {\r\n padding: 1rem;\r\n background-color: hsl(var(--accent-success) / 8%);\r\n border-radius: 0.5rem;\r\n border: 1px solid hsl(var(--accent-success) / 30%);\r\n }\r\n\r\n .applied-icon {\r\n width: 2rem;\r\n height: 2rem;\r\n border-radius: 9999px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n background-color: hsl(var(--accent-success) / 15%);\r\n color: hsl(var(--accent-success));\r\n }\r\n\r\n .remove-btn {\r\n padding: 0.5rem;\r\n border-radius: 9999px;\r\n border: none;\r\n background: none;\r\n transition-property: background-color, color;\r\n transition-duration: 150ms;\r\n color: hsl(var(--text-tertiary));\r\n cursor: pointer;\r\n }\r\n\r\n .remove-btn:hover {\r\n background-color: hsl(var(--accent-danger) / 10%);\r\n color: hsl(var(--accent-danger));\r\n }\r\n\r\n .remove-btn:disabled {\r\n opacity: 0.5;\r\n cursor: not-allowed;\r\n }\r\n\r\n .applied-details {\r\n margin-top: 0.75rem;\r\n padding-top: 0.75rem;\r\n border-top: 1px solid hsl(var(--accent-success) / 30%);\r\n }\r\n\r\n .full-coverage-badge {\r\n display: flex;\r\n align-items: center;\r\n gap: 0.375rem;\r\n margin-top: 0.5rem;\r\n padding: 0.375rem 0.625rem;\r\n border-radius: 0.375rem;\r\n background-color: hsl(var(--accent-success) / 15%);\r\n color: hsl(var(--accent-success));\r\n font-size: 0.75rem;\r\n line-height: 1rem;\r\n font-weight: 500;\r\n }\r\n\r\n /* Loading spinner */\r\n .gc-spinner {\r\n width: 1.5rem;\r\n height: 1.5rem;\r\n border: 2px solid hsl(var(--border));\r\n border-radius: 9999px;\r\n border-top-color: hsl(var(--brand-primary));\r\n animation: spin 0.8s linear infinite;\r\n }\r\n\r\n .gc-spinner-sm {\r\n width: 1rem;\r\n height: 1rem;\r\n }\r\n\r\n @keyframes spin {\r\n from {\r\n transform: rotate(0deg);\r\n }\r\n to {\r\n transform: rotate(360deg);\r\n }\r\n }\r\n</style>","<!--\r\n @currency-escape: cents/100 in this file is fee-math arithmetic, not\r\n display. `serviceFeeCents / 100` produces a dollar-magnitude `number`\r\n used in the running fee total + `Math.min(fee, maxServiceFeeCents / 100)`\r\n cap calculation. Real math, not formatter bypass. Per Atlas\r\n utility-currency convergence record.\r\n\r\n @form-handling-escape: `processing` is a Stripe payment-confirmation\r\n reentrancy guard (`if (processing) return; processing = true` around\r\n confirmPayment), NOT form-submission/validation state. createFormStore\r\n cannot express a payment-intent confirmation flow, and forcing it here\r\n would risk double-charge regressions for zero user-visible benefit.\r\n Same call as PP#193. Per Atlas behavior-form-handling convergence record.\r\n-->\r\n<script module>\r\n import { createLogger } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('Checkout');\r\n</script>\r\n\r\n<script>\r\n import {\r\n roundCurrency,\r\n getCookie,\r\n COOKIE_NAMES,\r\n } from '@getmicdrop/svelte-components';\r\n import { getDefaultTimezone } from '@getmicdrop/svelte-components/utils/timezones';\r\n import { onMount } from 'svelte';\r\n import { loadStripe } from '@stripe/stripe-js';\r\n import {\r\n loadCheckoutStateFromCookies,\r\n getVenueDetails,\r\n } from '$lib/utils/utils.js';\r\n // DETAIL-mode view shaper under an unambiguous alias — `$lib/api` exports\r\n // a DIFFERENT `transformEvent` (the canonical domain parseEvent); the name\r\n // collision previously made this import ambiguous to readers.\r\n import { transformEvent as transformEventDetail } from '$lib/utils/event-transform.js';\r\n import {\r\n createPaymentIntent,\r\n completeGiftCardPayment,\r\n extendCheckoutSession,\r\n getSessionStatus,\r\n applyPromoCode,\r\n // validatePaymentIntent MUST come from the same orders-v2 service as\r\n // createPaymentIntent. Previously it was imported from utils.js (the legacy\r\n // /api/v2/public/orders/{id}/validate-payment endpoint), so after a\r\n // successful charge the cart created via the orders-v2 PI could fail to\r\n // finalize / report \"validation failed\" — money taken, order not confirmed.\r\n validatePaymentIntent,\r\n } from '$lib/api';\r\n import { getPaymentErrorDetails } from '$lib/utils/stripe-errors';\r\n import CheckoutMain from '$lib/public-calendar-flow/Checkout.svelte';\r\n import GiftCardInput from '../Events/Checkout/GiftCardInput.svelte';\r\n\r\n let {\r\n data,\r\n availableTickets = [],\r\n value = '',\r\n venueId = '',\r\n organizationId = '',\r\n onNavigateToSuccess,\r\n // Optional back handler. Defaults to history.back() for the full-page\r\n // get-micdrop.com checkout route; the in-widget embed passes a callback\r\n // that returns to the in-place show detail (there is no history entry to\r\n // pop in that context).\r\n onNavigateBack = undefined,\r\n initialError = undefined,\r\n labels = {},\r\n } = $props();\r\n\r\n // --- Derive event from data prop ---\r\n let id = $derived((data || {}).id);\r\n let orgSlug = $derived((data || {}).orgSlug);\r\n let slug = $derived((data || {}).slug);\r\n let rawEvent = $derived((data || {}).event);\r\n let event = $derived(\r\n rawEvent\r\n ? transformEventDetail(rawEvent)\r\n : data && (data.id || id)\r\n ? {\r\n id: data.id || id,\r\n eventID: data.id || id,\r\n venueID: data.venueID ?? data.venueId ?? null,\r\n venueId: data.venueId ?? data.venueID ?? null,\r\n eventTicketingType: 0,\r\n ticketType: 0,\r\n availableTickets: [],\r\n }\r\n : null\r\n );\r\n\r\n // --- Core state ---\r\n let cartId = $state('');\r\n let quantities = $state({});\r\n let donationAmounts = $state({});\r\n let tickets = $state([]);\r\n let promocode = $state('');\r\n let promoDiscountAmount = $state(0);\r\n let processing = $state(false);\r\n\r\n // Stripe state\r\n let stripe = $state(null);\r\n let paymentIntent = $state('');\r\n let elements = $state(undefined);\r\n\r\n // Error state\r\n let paymentErrorMessage = $state('');\r\n let showError = $state(false);\r\n let errorMessage = $state('');\r\n\r\n // Gift card state\r\n let giftCardApplied = $state(null);\r\n\r\n // CheckoutConfig for CheckoutMain\r\n let checkoutConfig = $state(null);\r\n\r\n // Captured from /payment-intent response — the server's totals are\r\n // the source of truth for what Stripe charges. Set inside\r\n // initializeStripePayment (which runs before checkoutConfig is\r\n // built) and applied at checkoutConfig assembly time.\r\n let serverTotalsFromPaymentIntent = null;\r\n\r\n // --- Initialize on mount ---\r\n onMount(async () => {\r\n cartId = getCookie(COOKIE_NAMES.CHECKOUT_CARTID);\r\n\r\n if (!cartId) {\r\n showError = true;\r\n errorMessage =\r\n labels.noCheckoutSession ||\r\n 'No checkout session found. Please select tickets first.';\r\n return;\r\n }\r\n\r\n // Load checkout state from cookies/localStorage\r\n try {\r\n const checkoutState = loadCheckoutStateFromCookies(\r\n event?.eventID || event?.id || id\r\n );\r\n quantities = checkoutState.quantities || {};\r\n donationAmounts = checkoutState.donationAmounts || {};\r\n promocode = checkoutState.promocode || '';\r\n promoDiscountAmount = checkoutState.promoDiscountAmount || 0;\r\n tickets = checkoutState.tickets || [];\r\n } catch (err) {\r\n logger.error('Error loading checkout state:', err);\r\n quantities = {};\r\n tickets = [];\r\n }\r\n\r\n if (tickets.length > 0 && event) {\r\n event.availableTickets = tickets;\r\n availableTickets = tickets;\r\n }\r\n\r\n // Fetch venue details for fee calculations\r\n let venueServiceCharge = {\r\n serviceFeeCents: 0,\r\n serviceFeePercentage: 0,\r\n serviceFeeChargeType: 'both',\r\n maxServiceFeeCents: 0,\r\n taxPercentage: 0,\r\n };\r\n\r\n try {\r\n const venueData = /** @type {any} */ (\r\n await getVenueDetails(event?.venueID || event?.venueId || venueId)\r\n );\r\n venueServiceCharge = {\r\n serviceFeeCents: Number(venueData?.serviceFeeCents ?? 0),\r\n serviceFeePercentage: Number(venueData?.serviceFeePercentage ?? 0),\r\n serviceFeeChargeType: String(venueData?.serviceFeeChargeType ?? 'both'),\r\n maxServiceFeeCents: Number(venueData?.maxServiceFeeCents ?? 0),\r\n taxPercentage: Number(venueData?.taxPercentage ?? 0),\r\n };\r\n } catch (err) {\r\n logger.error('Error fetching venue data:', err);\r\n }\r\n\r\n // Build OrderLine[] from quantities + tickets + venue fees\r\n const lines = buildOrderLines(quantities, tickets, venueServiceCharge);\r\n\r\n // Initialize the payment intent for any cart that has line items.\r\n //\r\n // For PAID carts this creates a Stripe PaymentIntent up front so the\r\n // card form has a PI to mount against on the common pay-by-card path.\r\n // Gift-card application happens AFTER mount; if the user later applies a\r\n // gift card that covers the whole amount, handleGiftCardApplied clears\r\n // the elements. The unused PaymentIntent is benign on Stripe's side\r\n // (auto-expires).\r\n //\r\n // For genuinely FREE carts ($0 total, no donation) we STILL call the\r\n // payment-intent endpoint: the backend's CreatePaymentIntentFromCart\r\n // finalizes a $0 order in-band (generates tickets, marks the cart\r\n // completed, sends the confirmation email, sets payment_status\r\n // \"succeeded\") and returns { requires_stripe: false, payment_type:\r\n // 'free', order_uuid }. initializeStripePayment then sets the\r\n // `paymentIntent = 'free'` sentinel, which handlePlaceOrder reads to\r\n // skip Stripe and navigate straight to the Confirmation page. Skipping\r\n // this call is what dead-ended free orders at \"Payment form is not\r\n // ready\" (checkout-free-order-deadend).\r\n // Donation (\"pay what you want\") carts have unitPrice-0 lines but a real\r\n // amount in donationAmounts, so they are paid carts and take the Stripe\r\n // path via the same call below.\r\n if (Object.keys(quantities).length > 0) {\r\n await initializeStripePayment();\r\n }\r\n\r\n // Resolve timer from: 1) server session, 2) localStorage, 3) default 15 min\r\n let timerStart = 15 * 60;\r\n if (cartId) {\r\n // Always check localStorage first (set by tickets page timer)\r\n const storedExpiry =\r\n typeof localStorage !== 'undefined'\r\n ? localStorage.getItem(`checkout-expiry-${cartId}`) // @storage-escape: checkout-timer state (intentional raw localStorage)\r\n : null;\r\n if (storedExpiry) {\r\n const remaining = Math.max(\r\n 0,\r\n Math.floor((parseInt(storedExpiry, 10) - Date.now()) / 1000)\r\n );\r\n if (remaining > 0) timerStart = remaining;\r\n }\r\n\r\n // Then try server (overrides localStorage if available)\r\n try {\r\n const status = await getSessionStatus(cartId);\r\n if (!status.error && status.expiresAt) {\r\n const remaining = Math.max(\r\n 0,\r\n Math.floor(\r\n (new Date(status.expiresAt).getTime() - Date.now()) / 1000\r\n )\r\n );\r\n timerStart = remaining;\r\n localStorage.setItem(\r\n // @storage-escape: checkout-timer state (intentional raw localStorage)\r\n `checkout-expiry-${cartId}`,\r\n String(new Date(status.expiresAt).getTime())\r\n );\r\n }\r\n // If status.error (404), timerStart keeps the localStorage value\r\n } catch {\r\n // Network error — timerStart keeps the localStorage value\r\n }\r\n }\r\n\r\n // Build CheckoutConfig for CheckoutMain. If initializeStripePayment\r\n // already captured server totals (paid carts), include them so the\r\n // first render uses authoritative numbers.\r\n checkoutConfig = {\r\n event: buildEventData(event, venueServiceCharge),\r\n lines,\r\n timerStart,\r\n promoApplied: !!promocode,\r\n promoDiscount: promoDiscountAmount,\r\n forceExpired: false,\r\n ...(serverTotalsFromPaymentIntent\r\n ? { serverTotals: serverTotalsFromPaymentIntent }\r\n : {}),\r\n };\r\n\r\n // Apply initial error if provided (for showcase/preview)\r\n if (initialError) {\r\n const details = getPaymentErrorDetails(\r\n typeof initialError === 'object'\r\n ? initialError\r\n : {\r\n code: 'card_declined',\r\n message:\r\n 'Your card was declined. Please try a different payment method.',\r\n }\r\n );\r\n paymentErrorMessage = details.message;\r\n }\r\n });\r\n\r\n // --- Stripe initialization (uses API-provided key, NO hardcoded key) ---\r\n async function initializeStripePayment() {\r\n if (!cartId) {\r\n logger.error('Missing cartId!');\r\n return;\r\n }\r\n\r\n const filteredQuantities = Object.fromEntries(\r\n Object.entries(quantities).filter(([_, val]) => val > 0)\r\n );\r\n\r\n try {\r\n // Convert donationAmounts to numeric keys/values for the API\r\n const numericDonationAmounts = Object.fromEntries(\r\n Object.entries(donationAmounts)\r\n .filter(([, v]) => parseFloat(String(v)) > 0)\r\n .map(([k, v]) => [parseInt(k, 10), parseFloat(String(v))])\r\n );\r\n // Persist the promo code onto the cart BEFORE creating the PaymentIntent.\r\n // The PI is built from the cart's DiscountAmount, which is only set by the\r\n // apply-promo endpoint — validation on the event-detail step is display-only.\r\n // Without this, the buyer saw a discount but was charged full price.\r\n if (promocode) {\r\n const promoResult = await applyPromoCode(cartId, promocode);\r\n if (!promoResult.success) {\r\n logger.error(\r\n 'Failed to apply promo code to cart:',\r\n promoResult.error\r\n );\r\n }\r\n }\r\n\r\n const paymentData = await createPaymentIntent(\r\n cartId,\r\n filteredQuantities,\r\n Object.keys(numericDonationAmounts).length > 0\r\n ? numericDonationAmounts\r\n : undefined\r\n );\r\n\r\n if (!paymentData) {\r\n paymentErrorMessage =\r\n labels.failedToCreatePaymentIntent ||\r\n 'Failed to create payment intent. Please try again.';\r\n return;\r\n }\r\n\r\n // Capture the server's authoritative totals — from here on,\r\n // OrderSummary / Place-order render from these numbers, not\r\n // from a local subtotal × tax-rate guess, so the displayed\r\n // total always matches what Stripe will charge. Server returns\r\n // int cents for all monetary fields.\r\n const paymentDataAny = /** @type {any} */ (paymentData);\r\n serverTotalsFromPaymentIntent = {\r\n subtotal: (paymentDataAny.subtotal ?? 0) / 100,\r\n fees: (paymentDataAny.service_fee ?? 0) / 100,\r\n taxes: (paymentDataAny.tax_amount_exclusive ?? 0) / 100,\r\n total: (paymentDataAny.amount_total ?? 0) / 100,\r\n promoDiscount: (paymentDataAny.discount ?? 0) / 100,\r\n giftCardAmount: (paymentDataAny.gift_card_amount ?? 0) / 100,\r\n stripeAmount: (paymentDataAny.stripe_amount ?? 0) / 100,\r\n };\r\n // If checkoutConfig was already built (e.g. a later re-init for\r\n // promo/gift-card flows), apply immediately. Otherwise the\r\n // assembly step below picks it up.\r\n if (checkoutConfig) {\r\n checkoutConfig = {\r\n ...checkoutConfig,\r\n serverTotals: serverTotalsFromPaymentIntent,\r\n };\r\n }\r\n\r\n // §8.2 Free-order branch — server returned payment_type=free /\r\n // requires_stripe=false. Order has already been finalized in-band; do\r\n // NOT mount Stripe Element. Set a sentinel paymentIntent so downstream\r\n // place-order code knows to skip Stripe confirm and just navigate to\r\n // the success page using the order_uuid the server returned.\r\n if (\r\n paymentDataAny.requires_stripe === false ||\r\n paymentDataAny.payment_type === 'free'\r\n ) {\r\n paymentIntent = 'free';\r\n return;\r\n }\r\n\r\n // Use the Stripe publishable key from the API response -- NEVER hardcoded\r\n const stripeKey = paymentData.stripe_publishable_key;\r\n if (!stripeKey) {\r\n logger.error('No Stripe publishable key in payment intent response');\r\n paymentErrorMessage =\r\n labels.paymentConfigError ||\r\n 'Payment configuration error. Please try again.';\r\n return;\r\n }\r\n\r\n stripe = await loadStripe(stripeKey);\r\n\r\n if (paymentData.client_secret) {\r\n paymentIntent = paymentData.client_secret;\r\n } else {\r\n paymentErrorMessage =\r\n labels.failedToInitPayment ||\r\n 'Failed to initialize payment. Please try again.';\r\n }\r\n } catch (err) {\r\n logger.error('Failed to initialize Stripe payment:', err);\r\n paymentErrorMessage =\r\n err.message ||\r\n labels.failedToInitPayment ||\r\n 'Failed to initialize payment. Please try again.';\r\n }\r\n }\r\n\r\n // --- Build EventData shape for CheckoutMain ---\r\n function buildEventData(evt, venueCharge) {\r\n if (!evt) return null;\r\n return {\r\n id: evt.id || evt.eventID,\r\n title: evt.name || evt.title || '',\r\n slug: evt.slug || slug || '',\r\n description: evt.description || '',\r\n date: evt.date || '',\r\n startDateTime: evt.startDateTime || '',\r\n endDateTime: evt.endDateTime || '',\r\n doorsOpenTime: evt.doorsOpenTime || '',\r\n timezone: evt.timeZone || evt.timezone || getDefaultTimezone(),\r\n imageUrl: evt.imageUrl || evt.image || '',\r\n venue: {\r\n id: evt.venueID || evt.venueId || 0,\r\n name: evt.venueName || '',\r\n address: evt.venueAddress || '',\r\n timezone: evt.timeZone || evt.timezone || getDefaultTimezone(),\r\n serviceFeePercentage: venueCharge.serviceFeePercentage,\r\n serviceFeeCents: venueCharge.serviceFeeCents,\r\n taxPercentage: venueCharge.taxPercentage,\r\n serviceFeeChargeType: venueCharge.serviceFeeChargeType,\r\n maxServiceFeeCents: venueCharge.maxServiceFeeCents,\r\n },\r\n performers: evt.performers || [],\r\n tickets: (evt.availableTickets || []).map(t => ({\r\n id: t.ID || t.id,\r\n name: t.name || '',\r\n description: t.description || '',\r\n price: (t.price || 0) / 100,\r\n fee: 0,\r\n quantityAvailable: t.quantityAvailable || 0,\r\n quantityTotal: t.quantityTotal || 0,\r\n minPerOrder: t.minPerOrder || 1,\r\n maxPerOrder: t.maxPerOrder || 10,\r\n status: 'on_sale',\r\n isDonation: t.type === 2,\r\n isHidden: false,\r\n })),\r\n faqs: evt.faqs || [],\r\n status: 'on_sale',\r\n isPasswordProtected: false,\r\n isRegistrationEvent: evt.eventTicketingType === 1 || evt.ticketType === 1,\r\n totalTicketsRemaining: 100,\r\n totalTicketsCapacity: 100,\r\n };\r\n }\r\n\r\n // --- Build OrderLine[] from cookie data + venue fees ---\r\n function buildOrderLines(qtys, ticketList, venueCharge) {\r\n const lines = [];\r\n for (const [ticketId, quantity] of Object.entries(qtys)) {\r\n if (quantity <= 0) continue;\r\n const ticket = ticketList.find(\r\n t => String(t.ID) === ticketId || String(t.id) === ticketId\r\n );\r\n if (!ticket) continue;\r\n\r\n const unitPrice = ticket.price || 0;\r\n const fee = calculateTicketFee(unitPrice, venueCharge);\r\n\r\n lines.push({\r\n ticketId: parseInt(ticketId),\r\n ticketName: ticket.name || '',\r\n quantity,\r\n unitPrice,\r\n fee,\r\n subtotal: roundCurrency(unitPrice * quantity),\r\n });\r\n }\r\n return lines;\r\n }\r\n\r\n // --- Calculate fee per ticket based on venue charge settings ---\r\n function calculateTicketFee(unitPrice, venueCharge) {\r\n if (unitPrice === 0) return 0;\r\n\r\n const {\r\n serviceFeePercentage = 0,\r\n serviceFeeCents = 0,\r\n serviceFeeChargeType = 'both',\r\n maxServiceFeeCents = 0,\r\n } = venueCharge;\r\n\r\n let fee = 0;\r\n if (\r\n serviceFeeChargeType === 'percentage' ||\r\n serviceFeeChargeType === 'both'\r\n ) {\r\n fee += unitPrice * (serviceFeePercentage / 100);\r\n }\r\n // Canonical charge type is 'fixed' (normalizeChargeType maps legacy\r\n // 'flat'/'cents' -> 'fixed'); accept all so a 'fixed'-configured venue's\r\n // flat fee isn't silently dropped from the estimate.\r\n if (\r\n serviceFeeChargeType === 'fixed' ||\r\n serviceFeeChargeType === 'flat' ||\r\n serviceFeeChargeType === 'cents' ||\r\n serviceFeeChargeType === 'both'\r\n ) {\r\n fee += serviceFeeCents / 100;\r\n }\r\n\r\n if (maxServiceFeeCents > 0) {\r\n fee = Math.min(fee, maxServiceFeeCents / 100);\r\n }\r\n\r\n return roundCurrency(fee);\r\n }\r\n\r\n // --- Compute whether order is free (for hiding gift card section) ---\r\n // A donation (\"pay what you want\") cart has unitPrice-0 lines but a real\r\n // amount in donationAmounts, so it is NOT free — otherwise the payment UI is\r\n // hidden and the donation can't be paid.\r\n let hasDonations = $derived(\r\n Object.values(donationAmounts).some(v => (Number(v) || 0) > 0)\r\n );\r\n let isFreeOrder = $derived(\r\n !hasDonations &&\r\n (checkoutConfig\r\n ? checkoutConfig.lines.every(l => l.unitPrice === 0)\r\n : true)\r\n );\r\n\r\n // --- Place order handler: 3-step Stripe flow ---\r\n async function handlePlaceOrder(formData) {\r\n if (processing) return;\r\n processing = true;\r\n paymentErrorMessage = '';\r\n\r\n try {\r\n // Gift-card-only purchase: skip Stripe entirely\r\n if (giftCardApplied && !giftCardApplied.requiresStripe) {\r\n await executeGiftCardOnlyPurchase(formData);\r\n return;\r\n }\r\n\r\n // Free ($0) order: skip Stripe entirely. The backend's payment-intent\r\n // endpoint finalizes a $0 order in-band (issues tickets, completes the\r\n // cart, sends the confirmation email) and returns requires_stripe:false\r\n // / payment_type:'free'; initializeStripePayment records that as the\r\n // `paymentIntent === 'free'` sentinel. If the sentinel isn't set yet\r\n // (init skipped or raced), executeFreeOrder calls the endpoint itself so\r\n // the order is finalized before we navigate.\r\n if (isFreeOrder) {\r\n await executeFreeOrder(formData);\r\n return;\r\n }\r\n\r\n // Step 1: Validate card via Stripe elements\r\n if (!elements) {\r\n paymentErrorMessage =\r\n labels.paymentFormNotReady ||\r\n 'Payment form is not ready. Please wait a moment and try again.';\r\n processing = false;\r\n return;\r\n }\r\n\r\n if (!stripe) {\r\n paymentErrorMessage =\r\n labels.paymentSystemNotInitialized ||\r\n 'Payment system is not initialized. Please refresh the page.';\r\n processing = false;\r\n return;\r\n }\r\n\r\n const { error: submitError } = await elements.submit();\r\n if (submitError) {\r\n const details = getPaymentErrorDetails(submitError);\r\n paymentErrorMessage = details.message;\r\n processing = false;\r\n return;\r\n }\r\n\r\n // Step 2: Confirm payment with Stripe\r\n const result = await stripe.confirmPayment({\r\n elements,\r\n redirect: 'if_required',\r\n });\r\n\r\n if (result.error) {\r\n const details = getPaymentErrorDetails(result.error);\r\n paymentErrorMessage = details.message;\r\n processing = false;\r\n return;\r\n }\r\n\r\n // Step 3: Validate payment on backend\r\n const paymentPayload = {\r\n id: cartId,\r\n paymentIntentId: result.paymentIntent.id,\r\n tickets: quantities,\r\n firstName: formData.firstName,\r\n lastName: formData.lastName,\r\n email: formData.email,\r\n paymentMethod: 'credit-card',\r\n mailingList: formData.keepMeUpdated,\r\n saleType: 'online',\r\n };\r\n\r\n const response = await validatePaymentIntent(cartId, paymentPayload);\r\n\r\n if (response?.status === 'Payment succeeded') {\r\n const successData = {\r\n orderId: cartId,\r\n eventId: event?.id || event?.eventID || null,\r\n event: event || null,\r\n venueId: venueId || event?.venueId || null,\r\n organizationId: organizationId || event?.organizationId || null,\r\n };\r\n\r\n if (onNavigateToSuccess) {\r\n onNavigateToSuccess(successData);\r\n }\r\n } else if (\r\n response?.status === 'Payment amount does not match the total price'\r\n ) {\r\n paymentErrorMessage =\r\n labels.paymentAmountMismatch ||\r\n 'Payment amount mismatch. Please refresh and try again.';\r\n } else {\r\n paymentErrorMessage =\r\n labels.paymentValidationFailed ||\r\n 'Payment validation failed. Please try again.';\r\n }\r\n } catch (err) {\r\n logger.error('Payment execution error:', err);\r\n const details = getPaymentErrorDetails(err);\r\n paymentErrorMessage = details.message;\r\n } finally {\r\n processing = false;\r\n }\r\n }\r\n\r\n // --- Gift card only purchase ---\r\n async function executeGiftCardOnlyPurchase(formData) {\r\n try {\r\n const result = await completeGiftCardPayment(cartId, {\r\n firstName: formData.firstName,\r\n lastName: formData.lastName,\r\n email: formData.email,\r\n phoneNumber: null,\r\n mailingList: formData.keepMeUpdated,\r\n });\r\n\r\n if (result?.success) {\r\n const successData = {\r\n orderId: result.orderId || cartId,\r\n eventId: event?.id || event?.eventID || null,\r\n event: event || null,\r\n venueId: venueId || event?.venueId || null,\r\n organizationId: organizationId || event?.organizationId || null,\r\n paymentType: 'gift_card_only',\r\n };\r\n\r\n if (onNavigateToSuccess) {\r\n onNavigateToSuccess(successData);\r\n }\r\n } else {\r\n paymentErrorMessage =\r\n result?.error ||\r\n labels.failedToCompleteOrder ||\r\n 'Failed to complete order. Please try again.';\r\n }\r\n } catch (err) {\r\n logger.error('Gift card payment error:', err);\r\n const details = getPaymentErrorDetails(err);\r\n paymentErrorMessage = details.message;\r\n } finally {\r\n processing = false;\r\n }\r\n }\r\n\r\n // --- Free ($0) order: complete without Stripe ---\r\n // The orders-service finalizes a $0 order in-band when the payment-intent\r\n // endpoint is called: it issues tickets, marks the cart completed and sets\r\n // payment_status \"succeeded\" (CreatePaymentIntentFromCart, stripeAmount==0\r\n // branch). initializeStripePayment records that result as paymentIntent ===\r\n // 'free'. If init was skipped or hasn't completed yet we call it now so the\r\n // order is finalized server-side before navigating to the Confirmation page.\r\n // NOTE: the public payment-intent endpoint does not accept customer details,\r\n // so name/email are not persisted on a purely-free order today — see the\r\n // checkout-free-order-deadend finding for the backend follow-up.\r\n async function executeFreeOrder(_formData) {\r\n try {\r\n if (paymentIntent !== 'free') {\r\n await initializeStripePayment();\r\n }\r\n\r\n if (paymentIntent !== 'free') {\r\n // Backend did not treat the order as free (e.g. it now carries a\r\n // chargeable amount). Surface a recoverable error rather than a\r\n // silent dead-end.\r\n paymentErrorMessage =\r\n labels.failedToCompleteOrder ||\r\n 'Could not complete the order. Please try again.';\r\n return;\r\n }\r\n\r\n const successData = {\r\n orderId: cartId,\r\n eventId: event?.id || event?.eventID || null,\r\n event: event || null,\r\n venueId: venueId || event?.venueId || null,\r\n organizationId: organizationId || event?.organizationId || null,\r\n paymentType: 'free',\r\n };\r\n\r\n if (onNavigateToSuccess) {\r\n onNavigateToSuccess(successData);\r\n }\r\n } catch (err) {\r\n logger.error('Free order completion error:', err);\r\n const details = getPaymentErrorDetails(err);\r\n paymentErrorMessage = details.message;\r\n } finally {\r\n processing = false;\r\n }\r\n }\r\n\r\n // --- Gift card handlers ---\r\n function handleGiftCardApplied(appliedCard) {\r\n giftCardApplied = appliedCard;\r\n\r\n // Fold the gift card into the authoritative totals so the OrderSummary\r\n // line items AND the \"Place order · $X\" button show the final amount due\r\n // — not the pre-gift-card total. The gift-card panel still shows the full\r\n // breakdown (applied / remaining). serverTotalsFromPaymentIntent stays the\r\n // pristine pre-gift-card snapshot so removal can restore it.\r\n if (checkoutConfig && serverTotalsFromPaymentIntent) {\r\n const amountDue = appliedCard.requiresStripe\r\n ? (appliedCard.stripeAmount ?? 0)\r\n : 0;\r\n checkoutConfig = {\r\n ...checkoutConfig,\r\n serverTotals: {\r\n ...serverTotalsFromPaymentIntent,\r\n giftCardAmount: appliedCard.giftCardAmount ?? 0,\r\n total: amountDue,\r\n },\r\n };\r\n }\r\n\r\n if (!appliedCard.requiresStripe) {\r\n // Gift card covers full amount -- clear Stripe\r\n elements = undefined;\r\n stripe = null;\r\n paymentIntent = '';\r\n } else if (cartId && Object.keys(quantities).length > 0) {\r\n // Split payment: the gift card is now persisted on the cart, so re-create\r\n // the PaymentIntent for the REDUCED remaining amount (CreatePaymentIntentFromCart\r\n // subtracts the cart's gift card). Without this the buyer's card is confirmed\r\n // against the original full-amount PI and is overcharged (full card charge +\r\n // gift-card redemption). Mirrors handleGiftCardRemoved's re-init.\r\n initializeStripePayment();\r\n }\r\n }\r\n\r\n function handleGiftCardRemoved() {\r\n giftCardApplied = null;\r\n // Restore the pristine pre-gift-card totals immediately so the headline\r\n // total / Place-order button revert without waiting on the async re-init.\r\n if (checkoutConfig && serverTotalsFromPaymentIntent) {\r\n checkoutConfig = {\r\n ...checkoutConfig,\r\n serverTotals: serverTotalsFromPaymentIntent,\r\n };\r\n }\r\n // Re-initialize Stripe payment\r\n if (cartId && Object.keys(quantities).length > 0) {\r\n initializeStripePayment();\r\n }\r\n }\r\n\r\n // --- Navigation handlers ---\r\n function handleBack() {\r\n if (onNavigateBack) onNavigateBack();\r\n else window.history.back();\r\n }\r\n\r\n function handleRetryExpired() {\r\n if (onNavigateBack) onNavigateBack();\r\n else window.history.back();\r\n }\r\n\r\n async function handleExtendSession() {\r\n if (!cartId) return null;\r\n\r\n try {\r\n const result = await extendCheckoutSession(cartId);\r\n if (result.success) {\r\n return {\r\n newExpiryTime: result.newExpiryTime,\r\n remainingExtensions: result.remainingExtensions,\r\n };\r\n } else {\r\n logger.error('Failed to extend session:', result.error);\r\n return null;\r\n }\r\n } catch (err) {\r\n logger.error('Error extending checkout session:', err);\r\n return null;\r\n }\r\n }\r\n</script>\r\n\r\n{#if checkoutConfig}\r\n <CheckoutMain\r\n config={checkoutConfig}\r\n onPlaceOrder={handlePlaceOrder}\r\n onBack={handleBack}\r\n onRetryExpired={handleRetryExpired}\r\n onExtendSession={handleExtendSession}\r\n {stripe}\r\n {paymentIntent}\r\n bind:elements\r\n paymentError={paymentErrorMessage}\r\n {labels}\r\n />\r\n\r\n {#if !isFreeOrder}\r\n <div class=\"max-w-6xl mx-auto px-4 md:px-6 -mt-4 mb-8\">\r\n <GiftCardInput\r\n {cartId}\r\n onApplied={handleGiftCardApplied}\r\n onRemoved={handleGiftCardRemoved}\r\n disabled={processing}\r\n />\r\n </div>\r\n {/if}\r\n{:else if showError}\r\n <div class=\"p-8 text-center\">\r\n <p class=\"text-accent-danger\">{errorMessage}</p>\r\n </div>\r\n{:else}\r\n <div class=\"p-8 text-center\">\r\n <p class=\"text-muted-foreground\">\r\n {labels.loadingSecurePaymentForm || 'Loading secure payment form...'}\r\n </p>\r\n </div>\r\n{/if}\r\n"],"names":["_typeof","obj","RELEASE_TRAIN","runtimeVersionToUrlVersion","version","ORIGIN","STRIPE_JS_URL","V3_URL_REGEX","STRIPE_JS_URL_REGEX","isStripeJSURL","url","findScript","scripts","i","script","injectScript","params","queryString","headOrBody","registerWrapper","stripe","startTime","stripePromise$1","onErrorListener","onLoadListener","onError","reject","cause","onLoad","resolve","loadScript","_script$parentNode","error","initStripe","maybeStripe","args","pk","isTestKey","expectedVersion","stripePromise","loadCalled","getStripePromise","loadStripe","_len","_key","getPaymentErrorDetails","errorCode","errorType","errorMessage","declineCode","logger","createLogger","onApplied","$","$$props","onRemoved","disabled","labels","code","loading","appliedCard","showInput","handleApply","result","applyGiftCard","err","handleRemove","removeGiftCard","previousCard","handleKeydown","e","toggleInput","div","root_8","div_1","root_3","div_2","div_3","Checkmark","div_4","span","span_1","button","span_2","root","Close","$$render","consequent","alternate","div_5","div_6","span_3","span_4","div_7","root_1","span_5","node_4","div_8","root_2","span_6","span_7","formatCurrency","consequent_2","text_1","safeSlide","DURATION","button_1","fragment_1","Gift","span_8","node_5","span_9","div_9","root_6","div_10","input","button_2","span_10","root_4","consequent_4","alternate_1","div_11","root_5","Warning","span_11","node_9","consequent_5","classes","$0","$$value","consequent_6","consequent_3","alternate_2","availableTickets","venueId","organizationId","onNavigateBack","initialError","id","slug","rawEvent","event","transformEventDetail","cartId","quantities","donationAmounts","tickets","promocode","promoDiscountAmount","processing","paymentIntent","elements","paymentErrorMessage","showError","giftCardApplied","checkoutConfig","serverTotalsFromPaymentIntent","onMount","getCookie","COOKIE_NAMES","checkoutState","loadCheckoutStateFromCookies","venueServiceCharge","venueData","getVenueDetails","lines","buildOrderLines","initializeStripePayment","timerStart","storedExpiry","remaining","status","getSessionStatus","buildEventData","details","filteredQuantities","_","val","numericDonationAmounts","v","k","promoResult","applyPromoCode","paymentData","createPaymentIntent","paymentDataAny","stripeKey","evt","venueCharge","getDefaultTimezone","t","qtys","ticketList","ticketId","quantity","ticket","unitPrice","fee","calculateTicketFee","roundCurrency","serviceFeePercentage","serviceFeeCents","serviceFeeChargeType","maxServiceFeeCents","hasDonations","isFreeOrder","l","handlePlaceOrder","formData","executeGiftCardOnlyPurchase","executeFreeOrder","submitError","paymentPayload","response","validatePaymentIntent","successData","completeGiftCardPayment","_formData","handleGiftCardApplied","amountDue","handleGiftCardRemoved","handleBack","handleRetryExpired","handleExtendSession","extendCheckoutSession","CheckoutMain","node_1","GiftCardInput","node_3","p","p_1"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CheckoutTimer-CAGR7L-7.js","sources":["../node_modules/@getmicdrop/svelte-components/dist/primitives/Modal/Modal.svelte","../src/lib/public-calendar-flow/CheckoutTimer.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n /**\r\n * Legacy Modal API — backward-compatible wrapper around ModalRoot + ModalOverlay + ModalPanel.\r\n * Accepts the old flat API: bind:open, header/body/footer snippets, size, persistent, oncancel.\r\n * New code should use ModalRoot + ModalOverlay + ModalPanel directly.\r\n */\r\n import type { Snippet } from 'svelte';\r\n import ModalRoot from './ModalRoot.svelte';\r\n import ModalOverlay from './ModalOverlay.svelte';\r\n import ModalPanel from './ModalPanel.svelte';\r\n import ModalHeader from './ModalHeader.svelte';\r\n import ModalBody from './ModalBody.svelte';\r\n import ModalFooter from './ModalFooter.svelte';\r\n\r\n interface Props {\r\n open?: boolean;\r\n isProcessing?: boolean;\r\n isSuccess?: boolean;\r\n size?: 'sm' | 'md' | 'lg' | 'xl';\r\n persistent?: boolean;\r\n haptic?: boolean;\r\n oncancel?: () => void;\r\n header?: Snippet;\r\n body?: Snippet;\r\n footer?: Snippet;\r\n children?: Snippet;\r\n class?: string;\r\n 'aria-labelledby'?: string;\r\n /**\r\n * Layout variant. `'sheet'` (default) = bottom-sheet on mobile, centered\r\n * on md+. `'dialog'` = centered on all viewports. See ModalRoot for details.\r\n */\r\n variant?: 'sheet' | 'dialog';\r\n }\r\n\r\n let {\r\n open = $bindable(false),\r\n isProcessing: _isProcessing = false,\r\n isSuccess: _isSuccess = false,\r\n size = 'md',\r\n persistent = false,\r\n haptic = true,\r\n oncancel,\r\n header,\r\n body,\r\n footer,\r\n children,\r\n class: className,\r\n 'aria-labelledby': ariaLabelledby,\r\n variant = 'sheet',\r\n }: Props = $props();\r\n</script>\r\n\r\n<ModalRoot bind:open {size} {persistent} {haptic} {oncancel} {variant} class={className} aria-labelledby={ariaLabelledby}>\r\n <ModalOverlay />\r\n <ModalPanel>\r\n {#if header}<ModalHeader>{@render header()}</ModalHeader>{/if}\r\n {#if body}<ModalBody>{@render body()}</ModalBody>{/if}\r\n {#if children}<ModalBody>{@render children()}</ModalBody>{/if}\r\n {#if footer}<ModalFooter>{@render footer()}</ModalFooter>{/if}\r\n </ModalPanel>\r\n</ModalRoot>\r\n","<script lang=\"ts\">\r\n\timport { Time } from 'carbon-icons-svelte';\r\n\timport { Text } from '@getmicdrop/svelte-components';\r\n\r\n\tinterface Props {\r\n\t\tseconds: number;\r\n\t\tisUrgent: boolean;\r\n\t\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { seconds, isUrgent, labels = {}, }: Props = $props();\r\n\r\n\tlet display = $derived((() => {\r\n\t\tconst m = Math.floor(seconds / 60);\r\n\t\tconst s = seconds % 60;\r\n\t\treturn `${m.toString().padStart(2, '0')}:${s.toString().padStart(2, '0')}`;\r\n\t})());\r\n\r\n\tlet label = $derived(isUrgent ? 'Complete soon' : 'Reservation held');\r\n</script>\r\n\r\n<div class=\"timer-display text-color-secondary\" class:urgent={isUrgent}>\r\n\t<Time size={16} class=\"shrink-0\" />\r\n\t<Text size=\"sm\" class=\"font-medium tabular-nums\">\r\n\t\t{label} &middot; {display}\r\n\t</Text>\r\n</div>\r\n\r\n<style>\r\n\t.timer-display {\r\n\t\tdisplay: inline-flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.5rem;\r\n\t}\r\n\r\n\t.timer-display.urgent {\r\n\t\tcolor: hsl(var(--accent-warning)); /* orange-500 */\r\n\t}\r\n</style>\r\n"],"names":["open","$","$$props","size","persistent","haptic","variant","ModalRoot","$$anchor","$$value","ModalOverlay","node","ModalPanel","node_1","ModalHeader","ModalBody","ModalFooter","display","m","s","label","div","root","Time","Text","text","classes"],"mappings":";;;;;;iBAAA;;AAmCE,MACEA,IAAIC,EAAA,KAAAC,GAAA,QAAA,IAAa,EAAK;+BACQ,EAAK,6BACX,EAAK;AAC7B,MAAAC,yBAAO,IAAI,GACXC,+BAAa,EAAK,GAClBC,2BAAS,EAAI,GAQbC,4BAAU,OAAO;AAIpB,EAAAC,EAASC,GAAA;AAAA;aAAYL,EAAI;AAAA;;aAAGC,EAAU;AAAA;;aAAGC,EAAM;AAAA;;;;;aAAcC,EAAO;AAAA;;;;;;;QAA1D,OAAS;;;QAAT,KAASG,GAAA;;;;;AACjB,MAAAC,EAAYC,GAAA,EAAA;;AACZ,MAAAC,EAAUC,GAAA;AAAA;;;;AACI,cAAAC,EAAWN,GAAA;AAAA;;;;;;;;;;;;;;AACb,cAAAO,EAASP,GAAA;AAAA;;;;;;;;;;;;;;AACL,cAAAO,EAASP,GAAA;AAAA;;;;;;;;;;;;;;AACX,cAAAQ,EAAWR,GAAA;AAAA;;;;;;;;;;;;;;;;;;AARpB;;iBCnDR;iBAUgCP,EAAA,KAAAC,GAAA,UAAA,IAAA,OAAA,CAAA,EAAA;AAE/B,MAAIe,2BAA0B;AAC7B,UAAMC,IAAI,KAAK,kBAAgB,EAAE,GAC3BC,gBAAc;AACpB,cAAUD,EAAE,SAAQ,EAAG,SAAS,GAAG,GAAG,CAAA,IAAKC,EAAE,SAAQ,EAAG,SAAS,GAAG,GAAG,CAAA;AAAA,EACxE,IAAC,GAEGC,IAAKnB,EAAA,QAAA,MAAAC,EAAA,WAAuB,kBAAkB,kBAAkB;MAGpEmB,IAAGC,EAAA;;kBAAHD,CAAG;AACF,EAAAE,aAAW,IAAE,OAAA,YAAA;;AACb,EAAAC,EAAIX,GAAA;AAAA;;;;;AACH,MAAAZ,EAAA,gBAAA,MAAAA,EAAA,SAAAwB,GAAA,GAAAxB,EAAA,IAAAmB,CAAK,mBAAYH,CAAO,KAAA,EAAA,EAAA,CAAA;;;cAH1BI,CAAG,2CAAHA,GAAG,GAAA,oDAAA,MAAAK,GAAA,EAAA,QAAAxB,EAAA,SAAA,CAAA,CAAA,eAAHmB,CAAG;AAFI;","x_google_ignoreList":[0]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"CollectionView-Dstgu8sR.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). -->\r\n<!-- @route-escape: widget-intentional. -->\r\n<script lang=\"ts\">\r\n import { onMount, onDestroy } from 'svelte';\r\n import { goto } from '$app/navigation';\r\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\r\n import { transformCollectionData } from '$lib/public-calendar-flow/transform';\r\n import { fetchPublicCollection } from '$lib/api/events';\r\n import type { PublicCollectionData } from '$lib/api/types';\r\n import { createLogger, PasswordInput } from '@getmicdrop/svelte-components';\r\n\r\n const logger = createLogger('CollectionView');\r\n\r\n // --- Props (matches old CollectionView external interface) ---\r\n interface Props {\r\n collectionId: string | number;\r\n organizationId?: string;\r\n onNavigateToEvent?: (id: number, slug: string) => void;\r\n password?: string;\r\n displayMode?: string;\r\n showViewSwitcher?: boolean;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n collectionId,\r\n organizationId = '',\r\n onNavigateToEvent = undefined,\r\n password = undefined,\r\n displayMode = 'gallery',\r\n showViewSwitcher = true,\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // --- State ---\r\n let collection = $state<PublicCollectionData | null>(null);\r\n let isLoading = $state(true);\r\n let error = $state<string | null>(null);\r\n let isMounted = $state(false);\r\n let passwordRequired = $state(false);\r\n let passwordInput = $state('');\r\n let passwordError = $state(false);\r\n\r\n // --- Derived ---\r\n let eventData = $derived(\r\n collection ? transformCollectionData(collection) : null\r\n );\r\n\r\n // --- Load collection data ---\r\n async function loadCollection(pwd?: string): Promise<void> {\r\n if (!isMounted) return;\r\n if (!collectionId) {\r\n error = labels.noCollectionIdProvided || 'No collection ID provided';\r\n isLoading = false;\r\n return;\r\n }\r\n\r\n isLoading = true;\r\n error = null;\r\n passwordError = false;\r\n\r\n try {\r\n const data = await fetchPublicCollection(collectionId, pwd);\r\n if (!isMounted) return;\r\n\r\n if (data) {\r\n if (\r\n (data as any).passwordRequired ||\r\n (data as any).error?.code === 'PASSWORD_REQUIRED'\r\n ) {\r\n passwordRequired = true;\r\n isLoading = false;\r\n return;\r\n }\r\n collection = data;\r\n passwordRequired = false;\r\n } else {\r\n if (pwd) {\r\n passwordRequired = true;\r\n passwordError = true;\r\n isLoading = false;\r\n return;\r\n }\r\n error = labels.failedToLoadCollection || 'Failed to load collection';\r\n }\r\n } catch (err: any) {\r\n if (isMounted) {\r\n const msg = err.message || '';\r\n if (\r\n msg.includes('401') ||\r\n msg.includes('403') ||\r\n msg.includes('password')\r\n ) {\r\n passwordRequired = true;\r\n } else {\r\n error =\r\n msg || labels.failedToLoadCollection || 'Failed to load collection';\r\n }\r\n }\r\n } finally {\r\n if (isMounted) {\r\n isLoading = false;\r\n }\r\n }\r\n }\r\n\r\n function handlePasswordSubmit(e: Event): void {\r\n e.preventDefault();\r\n if (!passwordInput.trim()) return;\r\n loadCollection(passwordInput);\r\n }\r\n\r\n function handleCollectionEventClick(galleryEvent: {\r\n id?: number | string;\r\n slug: string;\r\n }): void {\r\n if (onNavigateToEvent && galleryEvent.id) {\r\n onNavigateToEvent(Number(galleryEvent.id), galleryEvent.slug);\r\n } else {\r\n // @url-builder-escape: widget-internal route; SC's url-builders cover /a admin paths, not embedded calendar navigation.\r\n goto(`/${galleryEvent.id}/${galleryEvent.slug}`);\r\n }\r\n }\r\n\r\n // --- Lifecycle ---\r\n onMount(() => {\r\n isMounted = true;\r\n loadCollection(password);\r\n });\r\n\r\n onDestroy(() => {\r\n isMounted = false;\r\n });\r\n</script>\r\n\r\n{#if isLoading}\r\n <div\r\n class=\"flex items-center justify-center py-12 text-center loading-container\"\r\n >\r\n <p>{labels.loadingCollection || 'Loading collection...'}</p>\r\n </div>\r\n{:else if passwordRequired}\r\n <div\r\n class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\"\r\n >\r\n <div class=\"password-card rounded-lg p-8 max-w-sm w-full\">\r\n <h2 class=\"password-title text-xl font-bold mb-2\">\r\n {labels.collectionPrivateTitle || 'This collection is private'}\r\n </h2>\r\n <p class=\"password-description text-sm mb-6\">\r\n {labels.collectionPrivateDescription ||\r\n 'Please enter the password to view this collection.'}\r\n </p>\r\n <form onsubmit={handlePasswordSubmit} class=\"flex flex-col gap-3\">\r\n <PasswordInput\r\n bind:value={passwordInput}\r\n placeholder={labels.enterPassword || 'Enter password'}\r\n error={passwordError\r\n ? labels.incorrectPassword ||\r\n 'Incorrect password. Please try again.'\r\n : ''}\r\n />\r\n <button\r\n type=\"submit\"\r\n class=\"password-submit px-4 py-2 rounded-lg text-sm font-semibold\"\r\n >{labels.viewCollection || 'View Collection'}</button\r\n >\r\n </form>\r\n </div>\r\n </div>\r\n{:else if error}\r\n <div\r\n class=\"flex flex-col items-center justify-center min-h-[50vh] text-center\"\r\n >\r\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {error}</p>\r\n </div>\r\n{:else if eventData}\r\n <EventExperience\r\n event={eventData}\r\n onCollectionEventClick={handleCollectionEventClick}\r\n />\r\n{/if}\r\n\r\n<style>\r\n .loading-container {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .error-text {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .password-card {\r\n background: hsl(var(--surface-primary, 0 0% 100%));\r\n box-shadow: 0 2px 10px color-mix(in srgb, black 10%, transparent);\r\n }\r\n\r\n .password-title {\r\n color: hsl(var(--text-primary, 0 0% 10%));\r\n }\r\n\r\n .password-description {\r\n color: hsl(var(--text-secondary, 0 0% 45%));\r\n }\r\n\r\n .password-submit {\r\n background: hsl(var(--brand-primary, 220 90% 56%));\r\n color: hsl(var(--text-on-primary, 0 0% 100%));\r\n }\r\n\r\n .password-submit:hover {\r\n filter: brightness(0.95);\r\n }\r\n</style>\r\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":"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","x_google_ignoreList":[0,1]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventPage-CnhccVCI.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","/**\r\n * Public-calendar URL builders. Centralizes the route shapes so call sites\r\n * stop hand-rolling `goto(`/${id}/${slug}`)` template literals\r\n * (Atlas utility-url-builders convergence). One place per route.\r\n */\r\n\r\n/** Event (or occurrence) page: `/<id>/<slug>`. */\r\nexport function buildEventUrl(id: number | string, slug: string): string {\r\n return `/${id}/${slug}`;\r\n}\r\n\r\n/** Event page by slug only: `/<slug>`. */\r\nexport function buildEventBySlugUrl(slug: string): string {\r\n return `/${slug}`;\r\n}\r\n\r\n/** Checkout for an event: `/<id>/<slug>/checkout`. */\r\nexport function buildCheckoutUrl(id: number | string, slug: string): string {\r\n return `/${id}/${slug}/checkout`;\r\n}\r\n\r\n/** Checkout success page: `/<id>/<slug>/checkout/success`. */\r\nexport function buildCheckoutSuccessUrl(\r\n id: number | string,\r\n slug: string\r\n): string {\r\n return `${buildCheckoutUrl(id, slug)}/success`;\r\n}\r\n","<!-- native-element-exception: VC is an embeddable widget — native <button>s are intentional here (widget-controlled styling on calendar cells, date selectors, checkout/nav CTAs). -->\r\n<script module>\r\n import { createLogger } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('EventPage');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { onMount } from 'svelte';\r\n import { goto } from '$app/navigation';\r\n import { Locked } from 'carbon-icons-svelte';\r\n import { InputModal, parseEventId } from '@getmicdrop/svelte-components';\r\n import type { EventId } from '@getmicdrop/svelte-components';\r\n import { toast } from '@getmicdrop/svelte-components/toast';\r\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\r\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\r\n import { validatePromoCode } from '$lib/api/promo';\r\n import {\r\n buildEventUrl,\r\n buildEventBySlugUrl,\r\n buildCheckoutUrl,\r\n } from '$lib/navigation';\r\n import {\r\n persistCheckoutState,\r\n initiateOrder,\r\n trackUTMSource,\r\n } from '$lib/utils/utils.js';\r\n import {\r\n fetchSeriesOccurrences,\r\n fetchEventDetails,\r\n checkEventPassword,\r\n } from '$lib/api';\r\n import type {\r\n EventData,\r\n PromoCodeState,\r\n OrderTotals,\r\n SeriesOccurrence,\r\n } from '$lib/public-calendar-flow/types';\r\n\r\n // --- Props (matches old EventPage external interface) ---\r\n interface Props {\r\n rawEvent?: any;\r\n eventId?: string | number;\r\n slug?: string;\r\n currentEventId?: number | null;\r\n onNavigateBack?: () => void;\r\n onBuyTickets?: (eventId: EventId, slug: string) => void;\r\n /**\r\n * Optional checkout hand-off. The standalone get-micdrop.com route lets\r\n * this default to navigating to /{id}/{slug}/checkout; the embed passes a\r\n * callback that renders Checkout in-place instead (the cart is already\r\n * created when this fires). Receives (id, slug, rawEvent).\r\n */\r\n onNavigateToCart?: (\r\n id: string | number,\r\n slug: string,\r\n rawEvent: any\r\n ) => void;\r\n organizationId?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n rawEvent: rawEventProp = undefined,\r\n eventId: eventIdProp = undefined,\r\n slug: slugProp = '',\r\n currentEventId: currentEventIdProp = undefined,\r\n onNavigateBack = undefined,\r\n onBuyTickets = undefined,\r\n onNavigateToCart = undefined,\r\n organizationId = '',\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // --- Data state ---\r\n /* svelte-ignore state_referenced_locally */\r\n let rawEvent = $state<any>(rawEventProp ?? null);\r\n /* svelte-ignore state_referenced_locally */\r\n let dataLoading = $state(!rawEventProp && !!eventIdProp);\r\n\r\n // Keep rawEvent in sync if rawEventProp changes reactively\r\n $effect(() => {\r\n if (rawEventProp) rawEvent = rawEventProp;\r\n });\r\n let dataError = $state<string | null>(null);\r\n\r\n // Transform raw API data to EventData\r\n let baseEventData = $derived(rawEvent ? transformApiEvent(rawEvent) : null);\r\n let id = $derived(eventIdProp || baseEventData?.id || '');\r\n let slug = $derived(slugProp || baseEventData?.slug || '');\r\n\r\n // Series occurrences (async enrichment)\r\n let seriesOccurrences = $state<SeriesOccurrence[]>([]);\r\n let eventData = $derived<EventData | null>(\r\n baseEventData\r\n ? {\r\n ...baseEventData,\r\n seriesOccurrences:\r\n seriesOccurrences.length > 0\r\n ? seriesOccurrences\r\n : baseEventData.seriesOccurrences || [],\r\n }\r\n : null\r\n );\r\n\r\n // --- Password protection state ---\r\n let showPasswordModal = $state(false);\r\n let isPasswordVerified = $state(false);\r\n let passwordValue = $state('');\r\n let passwordError = $state('');\r\n let passwordLoading = $state(false);\r\n\r\n // The public API strips the real password (auth models/Event.go json:\"-\") and\r\n // exposes only a boolean `hasPassword`. Gate on the transform-derived\r\n // `isPasswordProtected` (which reads hasPassword, with an admin-shaped\r\n // `password` fallback) — NOT the stripped `rawEvent.password`, which is always\r\n // undefined on the public payload and left every protected event unlocked.\r\n let requiresPassword = $derived(\r\n baseEventData?.isPasswordProtected === true ||\r\n rawEvent?.hasPassword === true\r\n );\r\n // Stay locked whenever we only hold the server's stripped teaser\r\n // (rawEvent.passwordRequired === true), even if this session previously\r\n // authenticated — the unlocked payload only arrives via a ?password= re-fetch,\r\n // so a sessionStorage flag alone must not reveal an (empty) teaser.\r\n let isLocked = $derived(\r\n requiresPassword &&\r\n !isPasswordVerified &&\r\n (rawEvent?.passwordRequired === true || !isEventAuthenticated(id))\r\n );\r\n\r\n function isEventAuthenticated(evtId: string | number): boolean {\r\n if (typeof window === 'undefined') return false;\r\n const authedEvents = JSON.parse(\r\n sessionStorage.getItem('authedEvents') || '[]'\r\n ); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n return authedEvents.includes(String(evtId));\r\n }\r\n\r\n function setEventAuthenticated(evtId: string | number): void {\r\n if (typeof window === 'undefined') return;\r\n const authedEvents = JSON.parse(\r\n sessionStorage.getItem('authedEvents') || '[]'\r\n ); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n const evtIdStr = String(evtId);\r\n if (!authedEvents.includes(evtIdStr)) {\r\n authedEvents.push(evtIdStr);\r\n sessionStorage.setItem('authedEvents', JSON.stringify(authedEvents)); // @storage-escape: authedEvents session-auth state (intentional raw sessionStorage)\r\n }\r\n }\r\n\r\n async function handlePasswordSubmit(e: any): Promise<void> {\r\n const password = e.detail?.value || passwordValue;\r\n if (!password || !id) return;\r\n passwordLoading = true;\r\n passwordError = '';\r\n try {\r\n const result = await checkEventPassword(String(id), password);\r\n if (result.valid) {\r\n // The server withholds the event's sensitive fields until the correct\r\n // password is supplied, so re-fetch the now-unlocked full payload and\r\n // swap it in (the initial load / SSR only had the stripped teaser).\r\n try {\r\n const unlocked = await fetchEventDetails(id, fetch, password);\r\n if (unlocked) rawEvent = unlocked;\r\n } catch {\r\n // Keep the teaser; still mark verified so the gate clears for UX.\r\n }\r\n setEventAuthenticated(id);\r\n isPasswordVerified = true;\r\n showPasswordModal = false;\r\n passwordValue = '';\r\n } else {\r\n passwordError =\r\n labels.incorrectPassword || 'Incorrect password. Please try again.';\r\n }\r\n } catch {\r\n passwordError =\r\n labels.unableToVerifyPassword ||\r\n 'Unable to verify password. Please try again.';\r\n } finally {\r\n passwordLoading = false;\r\n }\r\n }\r\n\r\n function handlePasswordCancel(): void {\r\n showPasswordModal = false;\r\n if (onNavigateBack) onNavigateBack();\r\n }\r\n\r\n // --- Promo state tracking for checkout persistence ---\r\n let lastPromoCode = $state('');\r\n let lastPromoDiscount = $state(0);\r\n\r\n async function handlePromoApply(code: string): Promise<PromoCodeState> {\r\n const result = await validatePromoCode(String(id), code);\r\n if (!result.valid) {\r\n return {\r\n code,\r\n isApplied: false,\r\n isValidating: false,\r\n error: result.error || 'Invalid promo code',\r\n hint: '',\r\n discountAmount: 0,\r\n discountType: '',\r\n discountTicketIds: [],\r\n revealHiddenTickets: false,\r\n revealTicketIds: [],\r\n };\r\n }\r\n lastPromoCode = result.code || code;\r\n lastPromoDiscount = result.amount || 0;\r\n return {\r\n code: result.code || code,\r\n isApplied: true,\r\n isValidating: false,\r\n error: '',\r\n hint: `${(result.code || code).toUpperCase()} applied`,\r\n discountAmount: result.amount || 0,\r\n discountType:\r\n result.discountType === 'percentage'\r\n ? '%'\r\n : result.discountType === 'fixed'\r\n ? '$'\r\n : '',\r\n discountTicketIds: [],\r\n revealHiddenTickets: result.revealHiddenTickets || false,\r\n revealTicketIds: result.revealTicketIds || [],\r\n };\r\n }\r\n\r\n function handlePromoRemove(): void {\r\n lastPromoCode = '';\r\n lastPromoDiscount = 0;\r\n }\r\n\r\n // --- Checkout callback ---\r\n async function handleCheckout(orderTotals: OrderTotals): Promise<void> {\r\n if (!eventData) return;\r\n\r\n // Reconstruct quantities and donation amounts from OrderTotals lines\r\n const quantities: Record<number, number> = {};\r\n const donationAmounts: Record<number, number> = {};\r\n\r\n for (const line of orderTotals.lines) {\r\n quantities[line.ticketId] = line.quantity;\r\n const ticket = eventData.tickets.find(t => t.id === line.ticketId);\r\n if (ticket?.isDonation) {\r\n donationAmounts[line.ticketId] = line.unitPrice;\r\n }\r\n }\r\n\r\n // Persist checkout state for downstream checkout page\r\n persistCheckoutState({\r\n eventID: String(id),\r\n quantities,\r\n donationAmounts,\r\n promocode: lastPromoCode,\r\n promoDiscountAmount: lastPromoDiscount,\r\n tickets: eventData.tickets.map(t => ({\r\n ID: t.id,\r\n name: t.name,\r\n price: t.price,\r\n type: String(t.ticketType || 0),\r\n visibility: String(t.isHidden ? 1 : 0),\r\n salesChannel: '0',\r\n })),\r\n });\r\n\r\n // Create cart (sets checkout-cartid cookie automatically)\r\n const result = await initiateOrder({\r\n eventID: id,\r\n quantities,\r\n promoCode: lastPromoCode || undefined,\r\n });\r\n if (!result?.success) {\r\n toast.error(\r\n result?.error ||\r\n labels.failedToCompleteOrder ||\r\n 'Failed to complete order. Please try again.'\r\n );\r\n return;\r\n }\r\n\r\n // Embed: render Checkout in-place. Standalone route: navigate to the\r\n // checkout page. The cart cookie is set either way by initiateOrder().\r\n if (onNavigateToCart) {\r\n onNavigateToCart(id, slug, rawEvent);\r\n } else {\r\n goto(buildCheckoutUrl(id, slug));\r\n }\r\n }\r\n\r\n // --- Navigation callbacks ---\r\n function handleCollectionEventClick(event: {\r\n id?: number | string;\r\n slug: string;\r\n }): void {\r\n if (event.id) {\r\n goto(buildEventUrl(event.id, event.slug));\r\n } else {\r\n logger.warn('Collection event missing id, navigating by slug only');\r\n goto(buildEventBySlugUrl(event.slug));\r\n }\r\n }\r\n\r\n function handleShowtimeClick(occurrence: { id: number; slug: string }): void {\r\n if (onBuyTickets) {\r\n onBuyTickets(parseEventId(occurrence.id), occurrence.slug);\r\n } else {\r\n goto(buildEventUrl(occurrence.id, occurrence.slug));\r\n }\r\n }\r\n\r\n // --- Lifecycle ---\r\n onMount(async () => {\r\n // Self-fetch mode (widget builder / color preview)\r\n if (!rawEvent && eventIdProp) {\r\n try {\r\n const fetched = await fetchEventDetails(eventIdProp);\r\n rawEvent = fetched;\r\n } catch (err: any) {\r\n dataError =\r\n err.message || labels.failedToLoadEvent || 'Failed to load event';\r\n dataLoading = false;\r\n return;\r\n }\r\n dataLoading = false;\r\n }\r\n\r\n if (!rawEvent) return;\r\n\r\n // UTM tracking — use event ID, not venue ID\r\n const evtId = rawEvent.ID || rawEvent.id;\r\n if (evtId) {\r\n trackUTMSource(evtId);\r\n }\r\n\r\n // Fetch series occurrences\r\n const seriesId = rawEvent.eventSeriesId || 0;\r\n const vId = rawEvent.venueID || rawEvent.venueId || 0;\r\n\r\n if (seriesId > 0 && vId > 0) {\r\n try {\r\n const occurrences = await fetchSeriesOccurrences(seriesId, vId);\r\n if (Array.isArray(occurrences) && occurrences.length > 0) {\r\n seriesOccurrences = occurrences.map((occ: any) => ({\r\n id: occ.id,\r\n slug: occ.slug || '',\r\n startDateTime: occ.startDateTime,\r\n endDateTime: occ.endDateTime || '',\r\n status: (occ.ctaState?.reason === 'sold_out'\r\n ? 'sold_out'\r\n : 'on_sale') as import('$lib/public-calendar-flow/types').EventStatus,\r\n ctaText: occ.ctaState?.text || 'Get tickets',\r\n ctaDisabled: occ.ctaState?.disabled || false,\r\n }));\r\n }\r\n } catch {\r\n // Non-fatal: event page works without series data\r\n }\r\n }\r\n\r\n // Password protection check\r\n if (requiresPassword && !isEventAuthenticated(id)) {\r\n showPasswordModal = true;\r\n }\r\n });\r\n</script>\r\n\r\n{#if dataLoading}\r\n <div\r\n class=\"flex items-center justify-center py-12 text-center loading-container\"\r\n >\r\n <p>{labels.loadingEvent || 'Loading event...'}</p>\r\n </div>\r\n{:else if dataError}\r\n <div\r\n class=\"flex flex-col items-center justify-center py-12 text-center gap-4\"\r\n >\r\n <p class=\"error-text\">{labels.errorPrefix || 'Error:'} {dataError}</p>\r\n {#if onNavigateBack}\r\n <button\r\n class=\"go-back-btn px-4 py-2 rounded-lg text-white\"\r\n onclick={onNavigateBack}>{labels.goBack || 'Go back'}</button\r\n >\r\n {/if}\r\n </div>\r\n{:else if eventData}\r\n {#if isLocked}\r\n <div class=\"locked-wrapper\">\r\n <div\r\n class=\"locked-overlay absolute inset-0 z-20 flex flex-col items-center justify-center min-h-96\"\r\n >\r\n <div class=\"text-center p-8\">\r\n <div\r\n class=\"locked-icon-wrapper w-20 h-20 mx-auto mb-4 rounded-full flex items-center justify-center\"\r\n >\r\n <Locked size={32} />\r\n </div>\r\n <h2 class=\"locked-title text-xl font-semibold mb-2\">\r\n {labels.passwordProtectedTitle ||\r\n 'This event is password protected'}\r\n </h2>\r\n <p\r\n class=\"locked-description text-sm max-w-xs mx-auto mb-6 leading-relaxed\"\r\n >\r\n {labels.passwordProtectedDescription ||\r\n 'Enter the event password to view details and purchase tickets.'}\r\n </p>\r\n <button\r\n class=\"unlock-btn py-3 px-6 text-white rounded-lg text-sm font-semibold cursor-pointer\"\r\n onclick={() => (showPasswordModal = true)}\r\n >\r\n {labels.enterPassword || 'Enter password'}\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"blur-content\">\r\n <EventExperience\r\n event={eventData}\r\n onCheckout={handleCheckout}\r\n onPromoApply={handlePromoApply}\r\n onPromoRemove={handlePromoRemove}\r\n onCollectionEventClick={handleCollectionEventClick}\r\n onShowtimeClick={handleShowtimeClick}\r\n />\r\n </div>\r\n </div>\r\n {:else}\r\n <EventExperience\r\n event={eventData}\r\n onCheckout={handleCheckout}\r\n onPromoApply={handlePromoApply}\r\n onPromoRemove={handlePromoRemove}\r\n onCollectionEventClick={handleCollectionEventClick}\r\n onShowtimeClick={handleShowtimeClick}\r\n />\r\n {/if}\r\n{/if}\r\n\r\n<InputModal\r\n bind:open={showPasswordModal}\r\n size=\"md\"\r\n title={labels.enterEventPassword || 'Enter event password'}\r\n description={labels.passwordModalDescription ||\r\n 'This event requires a password to view. Please enter the password provided by the event organizer.'}\r\n inputLabel={labels.passwordLabel || 'Password'}\r\n inputType=\"password\"\r\n bind:inputValue={passwordValue}\r\n inputRequired={true}\r\n errorMessage={passwordError}\r\n showError={!!passwordError}\r\n primaryButtonText={labels.unlockEvent || 'Unlock event'}\r\n secondaryButtonText={labels.goBack || 'Go back'}\r\n loading={passwordLoading}\r\n onconfirm={handlePasswordSubmit}\r\n oncancel={handlePasswordCancel}\r\n onclose={handlePasswordCancel}\r\n/>\r\n\r\n<style>\r\n .loading-container {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .error-text {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n\r\n .go-back-btn {\r\n background-color: hsl(var(--brand-primary, 224 76% 48%));\r\n }\r\n\r\n .locked-wrapper {\r\n position: relative;\r\n }\r\n\r\n .blur-content {\r\n filter: blur(8px);\r\n pointer-events: none;\r\n user-select: none;\r\n }\r\n\r\n .locked-overlay {\r\n background-color: hsl(var(--bg-primary, 0 0% 100%) / 95%);\r\n }\r\n\r\n .locked-icon-wrapper {\r\n background-color: hsl(var(--bg-secondary, 210 20% 98%));\r\n color: hsl(var(--text-tertiary, 220 9% 46%));\r\n }\r\n\r\n .locked-title {\r\n color: hsl(var(--text-primary, 222 47% 11%));\r\n }\r\n\r\n .locked-description {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .unlock-btn {\r\n background-color: hsl(var(--brand-primary, 224 76% 48%));\r\n border: none;\r\n transition: background-color 0.2s ease;\r\n }\r\n\r\n .unlock-btn:hover {\r\n opacity: 0.9;\r\n }\r\n</style>\r\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","button_1","EventExperience","InputModal","node_5"],"mappings":"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","x_google_ignoreList":[0,1,2]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ScarcityBadge-CG7Mz5YN.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>\r\n import { Badge } from '@getmicdrop/svelte-components';\r\n import { Fire } from 'carbon-icons-svelte';\r\n import { computeScarcityLevel } from '$lib/constants/scarcity';\r\n\r\n /**\r\n * ScarcityBadge - Shows urgency indicators based on ticket availability.\r\n *\r\n * Wraps SC <Badge> with venue-calendar's threshold logic. Renders to\r\n * the same primitive every other status badge uses (List, Gallery,\r\n * Calendar embed) so a \"Selling fast\" / \"Sold out\" pill is visually\r\n * identical wherever it appears.\r\n *\r\n * Thresholds are canonicalized in $lib/constants/scarcity:\r\n * URGENT_PCT=10, LOW_PCT=25, MAX_EXACT_COUNT=20.\r\n * TicketBlock.svelte uses the same source so the badge tier matches the\r\n * urgency copy on the ticket selection page.\r\n *\r\n * - 0 remaining: \"Sold out\" (red, no flame)\r\n * - <=10% remaining: \"Only X left\" with exact count (warning + flame)\r\n * - <=20% remaining (80%+ sold): \"Selling fast\" (warning + flame)\r\n * - >20% remaining: No badge\r\n *\r\n * @prop {\"browse\"|\"event\"|\"ticket\"} context - browse=vague only; event/ticket=exact at urgent\r\n * @prop {\"default\"|\"minimal\"} variant - default=SC Badge pill; minimal=transparent text+icon\r\n * @prop {boolean} isFree - Suppress scarcity badges for free events/tickets\r\n */\r\n let {\r\n remaining,\r\n total,\r\n context = 'browse',\r\n variant = 'default',\r\n isFree = false,\r\n labels = {},\r\n } = $props();\r\n\r\n const MAX_EXACT_COUNT = 20;\r\n const URGENT_PCT = 10;\r\n const LOW_PCT = 20;\r\n\r\n let percent = $derived(total > 0 ? (remaining / total) * 100 : 100);\r\n\r\n let badgeInfo = $derived.by(() => {\r\n const soldOutText = labels.statusSoldOut || 'Sold out';\r\n const sellingFastText = labels.statusSellingFast || 'Selling fast';\r\n const onlyNLeftTemplate =\r\n labels.scarcityOnlyNLeft || 'Only {remaining} left';\r\n\r\n if (remaining <= 0) {\r\n return { type: 'sold-out', text: soldOutText, showFlame: false };\r\n }\r\n if (isFree) return null;\r\n\r\n if (context === 'browse') {\r\n if (percent <= LOW_PCT) {\r\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\r\n }\r\n return null;\r\n }\r\n\r\n if (percent <= URGENT_PCT && remaining <= MAX_EXACT_COUNT) {\r\n return { type: 'scarcity', text: onlyNLeftTemplate.replace('{remaining}', String(remaining)), showFlame: true };\r\n }\r\n if (percent <= LOW_PCT) {\r\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\r\n }\r\n\r\n // Event page / Ticket page: vague at low.\r\n return { type: 'scarcity', text: sellingFastText, showFlame: true };\r\n });\r\n\r\n let scVariant = $derived(\r\n /** @type {'error' | 'warning'} */ (badgeInfo?.type === 'sold-out' ? 'error' : 'warning')\r\n );\r\n let ariaLabel = $derived(\r\n badgeInfo?.type === 'sold-out'\r\n ? (labels.statusSoldOut || 'Sold out')\r\n : `${labels.scarcityLowAvailability || 'Low availability'}: ${badgeInfo?.text}`\r\n );\r\n</script>\r\n\r\n{#if badgeInfo}\r\n {#if variant === 'minimal'}\r\n <span\r\n class=\"inline-flex items-center gap-1 text-xs leading-none {badgeInfo.type === 'sold-out' ? 'text-status-error-text' : 'text-accent-warning'}\"\r\n role=\"status\"\r\n aria-live=\"polite\"\r\n aria-label={ariaLabel}\r\n >\r\n {#if badgeInfo.showFlame}\r\n <Fire size={16} aria-hidden=\"true\" />\r\n {/if}\r\n {badgeInfo.text}\r\n </span>\r\n {:else}\r\n <Badge variant={scVariant} size=\"sm\">\r\n {#snippet leftIcon()}\r\n {#if badgeInfo.showFlame}\r\n <Fire size={16} aria-hidden=\"true\" />\r\n {/if}\r\n {/snippet}\r\n {badgeInfo.text}\r\n </Badge>\r\n {/if}\r\n{/if}\r\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-C8fIvt63.js","sources":["../src/components/Views/SeriesPage.svelte"],"sourcesContent":["<!-- @route-escape: widget-intentional. -->\r\n<script lang=\"ts\">\r\n import { goto } from '$app/navigation';\r\n import EventExperience from '$lib/public-calendar-flow/Event.svelte';\r\n import { createLogger } from '@getmicdrop/svelte-components';\r\n import { transformSeriesPageData } from '$lib/public-calendar-flow/transform';\r\n\r\n const logger = createLogger('SeriesPage');\r\n\r\n // --- Props (matches old SeriesPage external interface) ---\r\n interface Props {\r\n series: any;\r\n onNavigateToOccurrence?: (id: number, slug: string, name?: string) => void;\r\n }\r\n\r\n let { series, onNavigateToOccurrence = undefined }: Props = $props();\r\n\r\n // Transform series data to EventData for EventExperience\r\n let eventData = $derived(series ? transformSeriesPageData(series) : null);\r\n\r\n // Handle occurrence click — delegate to callback or navigate directly\r\n function handleShowtimeClick(occurrence: { id: number; slug: string }): void {\r\n if (onNavigateToOccurrence) {\r\n onNavigateToOccurrence(occurrence.id, occurrence.slug);\r\n } else {\r\n // @url-builder-escape: widget-internal route; SC's url-builders cover /a admin paths, not embedded calendar navigation.\r\n goto(`/${occurrence.id}/${occurrence.slug}`);\r\n }\r\n }\r\n</script>\r\n\r\n{#if eventData}\r\n <EventExperience\r\n event={eventData}\r\n isSeriesMaster\r\n onShowtimeClick={handleShowtimeClick}\r\n />\r\n{/if}\r\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,EAAeC,GAAA;AAAA;uBACPN,CAAS;AAAA;;yBAECE;AAAA;;;YAJhBF,CAAS,KAAAO,EAAAC,CAAA;AAAA;;;AAFN;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Success-SZNXo-Ou.js","sources":["../src/lib/public-calendar-flow/SuccessTicket.svelte","../src/lib/public-calendar-flow/SuccessActions.svelte","../src/lib/public-calendar-flow/Success.svelte","../src/components/Views/Success.svelte"],"sourcesContent":["<script lang=\"ts\">\r\n\timport { Email } from 'carbon-icons-svelte';\r\n\timport { Card, Heading, Text } from '@getmicdrop/svelte-components';\r\n\timport type { EventData, OrderTotals } from '$lib/public-calendar-flow/types';\r\n\timport OrderSummary from './OrderSummary.svelte';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\torderTotals: OrderTotals;\r\n\t\tcustomerEmail: string;\r\n\t\tshowCheckmark: boolean;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tevent, orderId, orderTotals, customerEmail, showCheckmark, showContent, labels = {},\r\n\t}: Props = $props();\r\n\r\n\tlet ticketCount = $derived(orderTotals.lines.reduce((sum, l) => sum + l.quantity, 0));\r\n\r\n\tlet headingText = $derived(\r\n\t\tevent.isRegistrationEvent ? (labels.youreRegistered || \"You're registered!\") : (labels.youreIn || \"You're in!\")\r\n\t);\r\n\r\n</script>\r\n\r\n<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-primary\">\r\n\t<div class=\"p-6 md:p-8\">\r\n\t\t<!-- Spinner → Checkmark animation -->\r\n\t\t<div class=\"flex justify-center mb-6\">\r\n\t\t\t<div class=\"indicator-container\">\r\n\t\t\t\t<!-- Spinner (visible while loading) -->\r\n\t\t\t\t<div class=\"processing-spinner\" class:fade-out={showCheckmark}></div>\r\n\r\n\t\t\t\t<!-- Animated checkmark (appears after spinner) -->\r\n\t\t\t\t<svg class=\"checkmark-svg\" class:active={showCheckmark} viewBox=\"0 0 52 52\" aria-hidden=\"true\">\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-circle\" />\r\n\t\t\t\t\t<circle cx=\"26\" cy=\"26\" r=\"24\" class=\"checkmark-fill\" />\r\n\t\t\t\t\t<path d=\"M14 27l7 7 17-17\" class=\"checkmark-check\" />\r\n\t\t\t\t</svg>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- Content (fades in after checkmark completes) -->\r\n\t\t<div class=\"content-section\" class:visible={showContent}>\r\n\t\t\t<!-- Heading -->\r\n\t\t\t<!-- TODO: swap back to <Stack gap=\"3\"> once SC's root index.js exports Stack\r\n\t\t\t (the `export *` re-export of primitives doesn't surface it, so\r\n\t\t\t `import { Stack }` fails to resolve). flex-col gap-3 is equivalent. -->\r\n\t\t\t<div class=\"flex flex-col gap-3 text-center mb-6\">\r\n\t\t\t\t<Heading level={1} size=\"xl\" weight=\"bold\">\r\n\t\t\t\t\t{headingText}\r\n\t\t\t\t</Heading>\r\n\t\t\t\t<Text size=\"lg\" class=\"font-semibold block\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<Text size=\"sm\" color=\"secondary\" class=\"block\">\r\n\t\t\t\t\t{ticketCount} {ticketCount === 1 ? (labels.ticket || 'ticket') : (labels.tickets || 'tickets')} confirmed\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order summary (same format as checkout) -->\r\n\t\t\t<div class=\"mb-6\">\r\n\t\t\t\t<OrderSummary {orderTotals}\r\n\t\t\t\t{labels} />\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Order info -->\r\n\t\t\t<div class=\"flex justify-between items-center py-3 border-t border-default\">\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold font-mono\">#{orderId}</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Email confirmation -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-2 p-3 rounded-lg bg-surface-secondary mt-4\">\r\n\t\t\t\t<Email size={16} class=\"shrink-0 text-color-muted\" />\r\n\t\t\t\t<Text size=\"xs\" color=\"secondary\">\r\n\t\t\t\t\t{labels.confirmationSentTo || 'Confirmation sent to'} {customerEmail}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t</div>\r\n\t</div>\r\n</Card>\r\n\r\n<style>\r\n\t/* Indicator container — holds spinner and checkmark in same space */\r\n\t.indicator-container {\r\n\t\tposition: relative;\r\n\t\twidth: 64px;\r\n\t\theight: 64px;\r\n\t}\r\n\r\n\t/* Spinner — rotating partial circle */\r\n\t.processing-spinner {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\tborder: 3px solid hsl(var(--stroke-primary) / 15%);\r\n\t\tborder-top-color: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tborder-radius: 50%;\r\n\t\tanimation: spin 0.7s linear infinite;\r\n\t\ttransition: opacity 0.2s ease;\r\n\t}\r\n\r\n\t.processing-spinner.fade-out {\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t@keyframes spin {\r\n\t\tto { transform: rotate(360deg); }\r\n\t}\r\n\r\n\t/* Checkmark SVG — scales in when active */\r\n\t.checkmark-svg {\r\n\t\tposition: absolute;\r\n\t\tinset: 0;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\t\topacity: 0;\r\n\t\ttransform: scale(0.6);\r\n\t\ttransition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);\r\n\t}\r\n\r\n\t.checkmark-svg.active {\r\n\t\topacity: 1;\r\n\t\ttransform: scale(1);\r\n\t}\r\n\r\n\t/* Circle outline — draws itself */\r\n\t.checkmark-circle {\r\n\t\tstroke-dasharray: 151;\r\n\t\tstroke-dashoffset: 151;\r\n\t\tstroke-width: 2;\r\n\t\tstroke: hsl(var(--accent-success, 142 71% 45%));\r\n\t\tfill: none;\r\n\t\ttransform-origin: center;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-circle {\r\n\t\tanimation: circle-draw 0.5s ease-out 0.1s forwards;\r\n\t}\r\n\r\n\t@keyframes circle-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Circle fill — fades in after outline completes */\r\n\t.checkmark-fill {\r\n\t\tfill: hsl(var(--accent-success, 142 71% 45%));\r\n\t\topacity: 0;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-fill {\r\n\t\tanimation: fill-in 0.25s ease-out 0.5s forwards;\r\n\t}\r\n\r\n\t@keyframes fill-in {\r\n\t\tto { opacity: 1; }\r\n\t}\r\n\r\n\t/* Checkmark stroke — draws after fill */\r\n\t.checkmark-check {\r\n\t\tstroke-dasharray: 36;\r\n\t\tstroke-dashoffset: 36;\r\n\t\tstroke-width: 3;\r\n\t\tstroke: hsl(var(--bg-primary));\r\n\t\tfill: none;\r\n\t\tstroke-linecap: round;\r\n\t\tstroke-linejoin: round;\r\n\t}\r\n\r\n\t.checkmark-svg.active .checkmark-check {\r\n\t\tanimation: check-draw 0.3s ease-out 0.6s forwards;\r\n\t}\r\n\r\n\t@keyframes check-draw {\r\n\t\tto { stroke-dashoffset: 0; }\r\n\t}\r\n\r\n\t/* Content section — fades in after checkmark */\r\n\t.content-section {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.content-section.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.processing-spinner {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\r\n\t\t.checkmark-svg .checkmark-circle,\r\n\t\t.checkmark-svg .checkmark-fill,\r\n\t\t.checkmark-svg .checkmark-check {\r\n\t\t\tanimation-duration: 0s;\r\n\t\t\tanimation-delay: 0s;\r\n\t\t}\r\n\r\n\t\t.content-section {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>\r\n","<!-- native-element-exception: VC is an embeddable widget — native <button>s are intentional here (widget-controlled styling on calendar cells, date selectors, checkout/nav CTAs). -->\r\n<script lang=\"ts\">\r\n\timport { onMount } from 'svelte';\r\n\timport {\r\n\t\tShare,\r\n\t\tHelp,\r\n\t\tArrowLeft,\r\n\t\tApple,\r\n\t\tCalendar,\r\n\t\tChevronDown,\r\n\t\tLocationFilled,\r\n\t} from 'carbon-icons-svelte';\r\n\timport { Button, Card, Image, Text } from '@getmicdrop/svelte-components';\r\n\timport { toast } from '@getmicdrop/svelte-components/toast';\r\n\timport type { EventData } from '$lib/public-calendar-flow/types';\r\n\timport { formatBrowseDate, formatEventTime } from '$lib/public-calendar-flow/defaults';\r\n\timport { PLACEHOLDER_IMAGE } from '$lib/utils/constants.js';\r\n\r\n\tinterface Props {\r\n\t\tevent: EventData;\r\n\t\torderId: string;\r\n\t\teventUrl: string;\r\n\t\tshowContent: boolean;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet { event, orderId, eventUrl, showContent, labels = {} }: Props = $props();\r\n\r\n\t// --- Calendar dropdown ---\r\n\tlet calendarOpen = $state(false);\r\n\r\n\tfunction toggleCalendar() {\r\n\t\tcalendarOpen = !calendarOpen;\r\n\t}\r\n\r\n\t// Close calendar dropdown when clicking outside\r\n\tonMount(() => {\r\n\t\tfunction handleClickOutside(e: MouseEvent) {\r\n\t\t\tconst target = e.target as HTMLElement;\r\n\t\t\tif (!target.closest('.calendar-dropdown')) {\r\n\t\t\t\tcalendarOpen = false;\r\n\t\t\t}\r\n\t\t}\r\n\t\tdocument.addEventListener('click', handleClickOutside);\r\n\t\treturn () => document.removeEventListener('click', handleClickOutside);\r\n\t});\r\n\r\n\t// --- Google Calendar URL ---\r\n\tlet googleCalendarUrl = $derived((() => {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForGoogle = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst params = new URLSearchParams({\r\n\t\t\taction: 'TEMPLATE',\r\n\t\t\ttext: event.title,\r\n\t\t\tdates: `${formatForGoogle(startDate)}/${formatForGoogle(endDate)}`,\r\n\t\t\tlocation: fullLocation,\r\n\t\t\tdetails: `Event: ${eventUrl}\\n\\nTicket confirmation #${orderId}`\r\n\t\t});\r\n\r\n\t\treturn `https://calendar.google.com/calendar/render?${params.toString()}`;\r\n\t})());\r\n\r\n\t// --- ICS file download (Apple Calendar) ---\r\n\tfunction downloadICS() {\r\n\t\tconst startDate = new Date(event.startDateTime);\r\n\t\tconst endDate = event.endDateTime\r\n\t\t\t? new Date(event.endDateTime)\r\n\t\t\t: new Date(startDate.getTime() + 2 * 60 * 60 * 1000);\r\n\r\n\t\tconst formatForICS = (date: Date): string => {\r\n\t\t\treturn date.toISOString().replace(/[-:]/g, '').replace(/\\.\\d{3}/, ''); // @datetime-escape: ICS/Google calendar URL format\r\n\t\t};\r\n\r\n\t\tconst uid = `order-${orderId}-event-${event.id}@micdrop.com`;\r\n\t\tconst now = formatForICS(new Date());\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst fullLocation = locationParts.join(', ');\r\n\r\n\t\tconst escapeICS = (str: string): string => {\r\n\t\t\tif (!str) return '';\r\n\t\t\treturn str.replace(/\\\\/g, '\\\\\\\\').replace(/;/g, '\\\\;').replace(/,/g, '\\\\,').replace(/\\n/g, '\\\\n');\r\n\t\t};\r\n\r\n\t\tconst icsContent = `BEGIN:VCALENDAR\r\nVERSION:2.0\r\nPRODID:-//MicDrop//Ticket Confirmation//EN\r\nCALSCALE:GREGORIAN\r\nMETHOD:PUBLISH\r\nBEGIN:VEVENT\r\nUID:${uid}\r\nDTSTAMP:${now}\r\nDTSTART:${formatForICS(startDate)}\r\nDTEND:${formatForICS(endDate)}\r\nSUMMARY:${escapeICS(event.title)}\r\nLOCATION:${escapeICS(fullLocation)}\r\nDESCRIPTION:${escapeICS(`Order #${orderId}\\n\\nView event: ${eventUrl}`)}\r\nURL:${eventUrl}\r\nSTATUS:CONFIRMED\r\nEND:VEVENT\r\nEND:VCALENDAR`;\r\n\r\n\t\tconst blob = new Blob([icsContent], { type: 'text/calendar;charset=utf-8' });\r\n\t\t// @image-handling-escape: programmatic blob-URL download (export/.ics) — SC Image canonical cannot express in-memory-blob → browser-download\r\n\t\tconst url = URL.createObjectURL(blob);\r\n\t\tconst link = document.createElement('a');\r\n\t\tlink.href = url;\r\n\t\tconst safeFilename = (event.title || 'event').replace(/[^a-zA-Z0-9\\s-]/g, '').replace(/\\s+/g, '-');\r\n\t\tlink.download = `${safeFilename}.ics`;\r\n\t\tdocument.body.appendChild(link);\r\n\t\tlink.click();\r\n\t\tdocument.body.removeChild(link);\r\n\t\tURL.revokeObjectURL(url);\r\n\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\tfunction handleGoogleCalendar() {\r\n\t\tcalendarOpen = false;\r\n\t}\r\n\r\n\t// --- Share event ---\r\n\tasync function shareEvent() {\r\n\t\tconst shareData = { url: eventUrl };\r\n\r\n\t\tif (navigator.share) {\r\n\t\t\ttry {\r\n\t\t\t\tawait navigator.share(shareData);\r\n\t\t\t} catch (err: unknown) {\r\n\t\t\t\tif (err instanceof Error && err.name !== 'AbortError') {\r\n\t\t\t\t\tfallbackShare();\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tfallbackShare();\r\n\t\t}\r\n\t}\r\n\r\n\tfunction fallbackShare() {\r\n\t\tnavigator.clipboard.writeText(eventUrl).then(() => {\r\n\t\t\ttoast.success(labels.linkCopied || 'Link copied to clipboard!');\r\n\t\t}).catch(() => {\r\n\t\t\ttoast.error(labels.copyLink || 'Could not copy link — please copy it manually: ' + eventUrl);\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Wallet handlers (mock — requires backend in production) ---\r\n\tfunction handleAppleWallet() {\r\n\t\ttoast.info('Apple Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\tfunction handleGoogleWallet() {\r\n\t\ttoast.info('Google Wallet coming soon', {\r\n\t\t\tdescription: 'Wallet integration requires backend signing infrastructure. Your ticket is confirmed — check your email.',\r\n\t\t});\r\n\t}\r\n\r\n\t// --- Directions ---\r\n\tlet directionsUrl = $derived((() => {\r\n\t\tconst locationParts = [event.venue.name, event.venue.address].filter(Boolean);\r\n\t\tconst query = encodeURIComponent(locationParts.join(', '));\r\n\t\treturn `https://www.google.com/maps/search/?api=1&query=${query}`;\r\n\t})());\r\n\r\n\t// --- Navigation ---\r\n\tfunction handleBackToEvent() {\r\n\t\twindow.location.href = eventUrl;\r\n\t}\r\n</script>\r\n\r\n<!--\r\n\tSuccessActions: Sidebar card matching BookingWidget / CheckoutSidebar pattern.\r\n\tSingle Card with event thumbnail, date summary, wallet badges, action buttons, and links.\r\n-->\r\n<div class=\"actions-wrapper\" class:visible={showContent}>\r\n\t<Card border padding={false} class=\"rounded-xl shadow-lg overflow-hidden bg-surface-secondary\">\r\n\t\t<!-- Event poster (same treatment as HeroImage — object-contain, no crop) -->\r\n\t\t<div class=\"rounded-t-xl overflow-hidden bg-surface-tertiary\">\r\n\t\t\t<Image\r\n\t\t\t\tsrc={event.imageUrl}\r\n\t\t\t\talt={event.title}\r\n\t\t\t\tfallback={PLACEHOLDER_IMAGE}\r\n\t\t\t\tfit=\"contain\"\r\n\t\t\t\tclass=\"w-full max-h-60 min-h-24\"\r\n\t\t\t/>\r\n\t\t</div>\r\n\r\n\t\t<div class=\"p-5 space-y-4\">\r\n\t\t\t<!-- Event info -->\r\n\t\t\t<div>\r\n\t\t\t\t<Text size=\"sm\" class=\"font-semibold block leading-tight\">\r\n\t\t\t\t\t{event.title}\r\n\t\t\t\t</Text>\r\n\t\t\t\t<div class=\"flex items-center gap-1.5 mt-1.5\">\r\n\t\t\t\t\t<Calendar size={16} class=\"shrink-0 icon-muted\" />\r\n\t\t\t\t\t<Text size=\"xs\" color=\"muted\">\r\n\t\t\t\t\t\t{formatBrowseDate(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{#if event.displayStartTime !== false}\r\n\t\t\t\t\t\t\t&middot; {formatEventTime(event.startDateTime, event.timezone)}\r\n\t\t\t\t\t\t{/if}\r\n\t\t\t\t\t</Text>\r\n\t\t\t\t</div>\r\n\t\t\t\t<Text size=\"xs\" color=\"muted\" class=\"block mt-0.5\">\r\n\t\t\t\t\t{event.venue.name}\r\n\t\t\t\t</Text>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Wallet badges (official brand assets) -->\r\n\t\t\t<div class=\"flex flex-col items-center gap-3\">\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleAppleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/apple-wallet.svg\"\r\n\t\t\t\t\t\talt={labels.addToAppleWallet || 'Add to Apple Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t\t<button type=\"button\" class=\"wallet-badge-btn\" onclick={handleGoogleWallet}>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-dark.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-dark\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t\t<!-- @component-image-escape: scoped-CSS selector targets this img -->\r\n\t\t\t\t\t<img\r\n\t\t\t\t\t\tsrc=\"/wallet-badges/google-wallet-light.svg\"\r\n\t\t\t\t\t\talt={labels.saveToGoogleWallet || 'Save to Google Wallet'}\r\n\t\t\t\t\t\tclass=\"wallet-badge-img google-light\"\r\n\t\t\t\t\t/>\r\n\t\t\t\t</button>\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Divider -->\r\n\t\t\t<div class=\"divider\"></div>\r\n\r\n\t\t\t<!-- Calendar dropdown (full width) -->\r\n\t\t\t<div class=\"calendar-dropdown relative\">\r\n\t\t\t\t<Button\r\n\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\tclass=\"w-full\"\r\n\t\t\t\t\tonclick={toggleCalendar}\r\n\t\t\t\t>\r\n\t\t\t\t\t<Calendar size={16} />\r\n\t\t\t\t\t{labels.addToCalendar || 'Add to Calendar'}\r\n\t\t\t\t\t<ChevronDown size={16} class=\"ml-auto transition-transform {calendarOpen ? 'rotate-180' : ''}\" />\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if calendarOpen}\r\n\t\t\t\t\t<div class=\"dropdown-menu bg-surface-primary border-default\">\r\n\t\t\t\t\t\t<a\r\n\t\t\t\t\t\t\thref={googleCalendarUrl}\r\n\t\t\t\t\t\t\trel=\"noopener noreferrer\"\r\n\t\t\t\t\t\t\tclass=\"dropdown-item text-color-primary hover:bg-surface-secondary\"\r\n\t\t\t\t\t\t\tonclick={handleGoogleCalendar}\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t<svg aria-hidden=\"true\" class=\"shrink-0\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n\t\t\t\t\t\t\t\t<path d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92a5.06 5.06 0 0 1-2.2 3.32v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.1z\" fill=\"#4285F4\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\" fill=\"#34A853\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18A10.96 10.96 0 0 0 1 12c0 1.77.42 3.45 1.18 4.93l3.66-2.84z\" fill=\"#FBBC05\"/>\r\n\t\t\t\t\t\t\t\t<path d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\" fill=\"#EA4335\"/>\r\n\t\t\t\t\t\t\t</svg>\r\n\t\t\t\t\t\t\t{labels.googleCalendar || 'Google Calendar'}\r\n\t\t\t\t\t\t</a>\r\n\t\t\t\t\t\t<button type=\"button\" class=\"dropdown-item text-color-primary hover:bg-surface-secondary\" onclick={downloadICS}>\r\n\t\t\t\t\t\t\t<Apple size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t\t{labels.appleCalendar || 'Apple Calendar (.ics)'}\r\n\t\t\t\t\t\t</button>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Share + Directions row -->\r\n\t\t\t<div class=\"flex gap-2\">\r\n\t\t\t\t<Button variant=\"default\" size=\"md\" class=\"flex-1\" onclick={shareEvent}>\r\n\t\t\t\t\t<Share size={16} />\r\n\t\t\t\t\t{labels.share || 'Share'}\r\n\t\t\t\t</Button>\r\n\r\n\t\t\t\t{#if event.venue.address}\r\n\t\t\t\t\t<Button\r\n\t\t\t\t\t\tvariant=\"default\"\r\n\t\t\t\t\t\tsize=\"md\"\r\n\t\t\t\t\t\tclass=\"flex-1\"\r\n\t\t\t\t\t\thref={directionsUrl}\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<LocationFilled size={16} />\r\n\t\t\t\t\t\t{labels.map || 'Map'}\r\n\t\t\t\t\t</Button>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\r\n\t\t\t<!-- Text links -->\r\n\t\t\t<div class=\"flex items-center justify-center gap-4 pt-1\">\r\n\t\t\t\t<button type=\"button\" class=\"text-link text-color-muted hover:text-color-secondary\" onclick={handleBackToEvent}>\r\n\t\t\t\t\t<ArrowLeft size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t{labels.backToEvent || 'Back to event'}\r\n\t\t\t\t</button>\r\n\r\n\t\t\t\t{#if event.venue.contactEmail}\r\n\t\t\t\t\t<span class=\"text-color-muted\">·</span>\r\n\t\t\t\t\t<a\r\n\t\t\t\t\t\thref=\"mailto:{event.venue.contactEmail}?subject=Help with Order {orderId}\"\r\n\t\t\t\t\t\tclass=\"text-link text-color-muted hover:text-color-secondary\"\r\n\t\t\t\t\t>\r\n\t\t\t\t\t\t<Help size={16} class=\"shrink-0\" />\r\n\t\t\t\t\t\t{labels.needHelp || 'Need help?'}\r\n\t\t\t\t\t</a>\r\n\t\t\t\t{/if}\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</Card>\r\n</div>\r\n\r\n<style>\r\n\t/* Wrapper — fades in with content */\r\n\t.actions-wrapper {\r\n\t\topacity: 0;\r\n\t\ttransform: translateY(8px);\r\n\t\ttransition: opacity 0.5s ease, transform 0.5s ease;\r\n\t}\r\n\r\n\t.actions-wrapper.visible {\r\n\t\topacity: 1;\r\n\t\ttransform: translateY(0);\r\n\t}\r\n\r\n\t/* Sidebar poster — same object-contain treatment as HeroImage */\r\n\t/* Wallet badges — official brand assets, no modifications per guidelines */\r\n\t.wallet-badge-btn {\r\n\t\tdisplay: block;\r\n\t\ttransition-property: opacity;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t.wallet-badge-btn:hover {\r\n\t\topacity: 0.85;\r\n\t}\r\n\r\n\t.wallet-badge-btn:active {\r\n\t\topacity: 0.7;\r\n\t}\r\n\r\n\t.wallet-badge-img {\r\n\t\theight: 44px;\r\n\t\twidth: auto;\r\n\t}\r\n\r\n\t/* Google badge: show dark variant in light mode, light variant in dark mode */\r\n\t.google-light {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t/* Calendar dropdown menu */\r\n\t.dropdown-menu {\r\n\t\tposition: absolute;\r\n\t\ttop: 100%;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\tmargin-top: 0.25rem;\r\n\t\tpadding-top: 0.25rem;\r\n\t\tpadding-bottom: 0.25rem;\r\n\t\tborder-radius: 0.5rem;\r\n\t\tbox-shadow: 0 10px 15px -3px rgb(0 0 0 / 10%), 0 4px 6px -4px rgb(0 0 0 / 10%);\r\n\t\tz-index: var(--z-navigation);\r\n\t\tborder-width: 1px;\r\n\t\tborder-style: solid;\r\n\t}\r\n\r\n\t.dropdown-item {\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.625rem;\r\n\t\twidth: 100%;\r\n\t\tpadding: 0.5rem 0.75rem;\r\n\t\tfont-size: 0.875rem;\r\n\t\tline-height: 1.25rem;\r\n\t\ttext-align: left;\r\n\t\ttransition-property: color, background-color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Text links */\r\n\t.text-link {\r\n\t\tdisplay: inline-flex;\r\n\t\talign-items: center;\r\n\t\tgap: 0.25rem;\r\n\t\tfont-size: 0.75rem;\r\n\t\tline-height: 1rem;\r\n\t\ttransition-property: color;\r\n\t\ttransition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\r\n\t\ttransition-duration: 150ms;\r\n\t}\r\n\r\n\t/* Reduced motion */\r\n\t@media (prefers-reduced-motion: reduce) {\r\n\t\t.actions-wrapper {\r\n\t\t\ttransition-duration: 0s;\r\n\t\t}\r\n\t}\r\n</style>","<script lang=\"ts\">\r\n\timport { toTicketId } from '@getmicdrop/svelte-components';\r\n\timport { onMount } from 'svelte';\r\n\timport type { EventData, OrderTotals, OrderLine, SuccessData } from '$lib/public-calendar-flow/types';\r\n\timport {\r\n\t\tmockEvent,\r\n\t\tmockFreeEvent,\r\n\t\tmockRegistrationEvent,\r\n\t\tmockDonationEvent\r\n\t} from '$lib/public-calendar-flow/mock-data';\r\n\timport { calculateTax } from '$lib/public-calendar-flow/defaults';\r\n\r\n\timport SuccessTicket from './SuccessTicket.svelte';\r\n\timport SuccessActions from './SuccessActions.svelte';\r\n\timport { mergeLabels } from '$lib/public-calendar-flow/i18n/labels.js';\r\n\timport { dataToggleStore, type ToggleOption } from '$lib/public-calendar-flow/data-toggle-store.svelte';\r\n\r\n\t// --- DataToggle ---\r\n\ttype SuccessVariant = 'default' | 'free' | 'registration' | 'donation';\r\n\r\n\tconst successStateOptions: ToggleOption[] = [\r\n\t\t{ value: 'default', label: 'Standard', color: 'bg-accent-success' },\r\n\t\t{ value: 'free', label: 'Free', color: 'bg-sky-500' },\r\n\t\t{ value: 'registration', label: 'Registration', color: 'bg-brand-primary' },\r\n\t\t{ value: 'donation', label: 'Donation', color: 'bg-accent-danger' }\r\n\t];\r\n\r\n\tlet dataVariant = $derived(dataToggleStore.current as SuccessVariant);\r\n\r\n\t// --- Props (dual-mode: showcase vs production) ---\r\n\tinterface Props {\r\n\t\t/** Pre-built success data for production mode. Absence = showcase. */\r\n\t\tdata?: SuccessData;\r\n\t\t/** Event page URL for production navigation and sharing. */\r\n\t\teventUrl?: string;\r\n\t\tlabels?: Record<string, string>;\r\n\t}\r\n\r\n\tlet {\r\n\t\tdata: dataProp = undefined,\r\n\t\teventUrl: eventUrlProp = undefined,\r\n\t\tlabels = {},\r\n\t}: Props = $props();\r\n\r\n\tconst mergedLabels = $derived(mergeLabels(labels));\r\n\r\n\tlet isShowcaseMode = $derived(!dataProp);\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tdataToggleStore.options = successStateOptions;\r\n\t\tdataToggleStore.current = 'default';\r\n\t\tdataToggleStore.isActive = true;\r\n\t\treturn () => {\r\n\t\t\tdataToggleStore.isActive = false;\r\n\t\t\tdataToggleStore.options = [];\r\n\t\t};\r\n\t});\r\n\r\n\t// --- Mock data per variant ---\r\n\tconst variantData: Record<SuccessVariant, SuccessData> = {\r\n\t\tdefault: {\r\n\t\t\tevent: mockEvent,\r\n\t\t\torderId: '12847',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(101), ticketName: 'General Admission', quantity: 2, unitPrice: 25, fee: 2.5, subtotal: 50 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(102), ticketName: 'VIP Front Row', quantity: 1, unitPrice: 55, fee: 5.5, subtotal: 55 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'customer@example.com'\r\n\t\t},\r\n\t\tfree: {\r\n\t\t\tevent: mockFreeEvent,\r\n\t\t\torderId: '12848',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(201), ticketName: 'Free Entry', quantity: 2, unitPrice: 0, fee: 0, subtotal: 0 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'comedy.fan@gmail.com'\r\n\t\t},\r\n\t\tregistration: {\r\n\t\t\tevent: mockRegistrationEvent,\r\n\t\t\torderId: '12849',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(301), ticketName: 'Workshop Seat', quantity: 1, unitPrice: 75, fee: 7.5, subtotal: 75 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'learner@example.com'\r\n\t\t},\r\n\t\tdonation: {\r\n\t\t\tevent: mockDonationEvent,\r\n\t\t\torderId: '12850',\r\n\t\t\tlines: [\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(401), ticketName: 'Donation', quantity: 1, unitPrice: 25, fee: 0, subtotal: 25 },\r\n\t\t\t\t// eslint-disable-next-line micdrop/boundary-only-as-cast -- mock data: static showcase ticketIds\r\n\t\t\t\t{ ticketId: toTicketId(402), ticketName: 'Standard Admission', quantity: 1, unitPrice: 30, fee: 3, subtotal: 30 }\r\n\t\t\t],\r\n\t\t\tcustomerEmail: 'generous@example.com'\r\n\t\t}\r\n\t};\r\n\r\n\tlet current: SuccessData = $derived(isShowcaseMode ? variantData[dataVariant] : dataProp!);\r\n\r\n\t// Build OrderTotals — the server's persisted order is authoritative\r\n\t// (basePrice/tax/surcharge/totalPrice match what Stripe charged).\r\n\t// Fall back to a local sum-of-lines for showcase mode only.\r\n\tlet orderTotals: OrderTotals = $derived((() => {\r\n\t\tconst lines = current.lines;\r\n\t\tif (current.serverTotals) {\r\n\t\t\treturn {\r\n\t\t\t\tlines,\r\n\t\t\t\tsubtotal: current.serverTotals.subtotal,\r\n\t\t\t\tfees: current.serverTotals.fees,\r\n\t\t\t\ttaxes: current.serverTotals.taxes,\r\n\t\t\t\ttotal: current.serverTotals.total,\r\n\t\t\t\tpromoDiscount: current.serverTotals.promoDiscount,\r\n\t\t\t\tgiftCardAmount: current.serverTotals.giftCardAmount\r\n\t\t\t};\r\n\t\t}\r\n\t\tconst subtotal = lines.reduce((sum, l) => sum + l.subtotal, 0);\r\n\t\tconst fees = lines.reduce((sum, l) => sum + l.fee * l.quantity, 0);\r\n\t\tconst taxes = calculateTax(subtotal + fees, current.event.venue.taxPercentage);\r\n\t\treturn {\r\n\t\t\tlines,\r\n\t\t\tsubtotal,\r\n\t\t\tfees,\r\n\t\t\ttaxes,\r\n\t\t\ttotal: subtotal + fees + taxes,\r\n\t\t\tpromoDiscount: 0,\r\n\t\t\tgiftCardAmount: 0\r\n\t\t};\r\n\t})());\r\n\r\n\tlet eventUrl = $derived(\r\n\t\tisShowcaseMode\r\n\t\t\t? (() => {\r\n\t\t\t\tif (typeof window === 'undefined') return '#';\r\n\t\t\t\treturn `${window.location.origin}/e/${current.event.id}-${current.event.slug}`;\r\n\t\t\t})()\r\n\t\t\t: (eventUrlProp || '#')\r\n\t);\r\n\r\n\t// --- Animation ---\r\n\tlet showCheckmark = $state(false);\r\n\tlet showContent = $state(false);\r\n\tlet reducedMotion = $state(false);\r\n\r\n\tfunction runAnimations() {\r\n\t\tif (reducedMotion) {\r\n\t\t\tshowCheckmark = true;\r\n\t\t\tshowContent = true;\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tshowCheckmark = false;\r\n\t\tshowContent = false;\r\n\t\tsetTimeout(() => { showCheckmark = true; }, 800);\r\n\t\tsetTimeout(() => { showContent = true; }, 1600);\r\n\t}\r\n\r\n\t$effect(() => {\r\n\t\tif (!isShowcaseMode) return;\r\n\t\tconst _v = dataVariant;\r\n\t\trunAnimations();\r\n\t});\r\n\r\n\tonMount(() => {\r\n\t\treducedMotion = window.matchMedia('(prefers-reduced-motion: reduce)').matches;\r\n\t\trunAnimations();\r\n\t});\r\n</script>\r\n\r\n<div class=\"w-full min-h-screen bg-surface-primary text-color-primary\">\r\n\t<div class=\"max-w-6xl mx-auto px-4 py-6 md:px-6 md:py-8\">\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- DESKTOP: Two-column layout (1fr 360px) -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"hidden md:grid grid-cols-booking-split gap-8 items-start\">\r\n\r\n\t\t\t<!-- LEFT COLUMN: Confirmation card -->\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<!-- RIGHT COLUMN: Sticky sidebar with event info + actions -->\r\n\t\t\t<div class=\"sticky top-6\">\r\n\t\t\t\t<SuccessActions\r\n\t\t\t\t\tevent={current.event}\r\n\t\t\t\t\torderId={current.orderId}\r\n\t\t\t\t\t{eventUrl}\r\n\t\t\t\t\t{showContent}\r\n\t\t\t\t\tlabels={mergedLabels}\r\n\t\t\t\t/>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\r\n\t\t<!-- ============================================== -->\r\n\t\t<!-- MOBILE: Single column -->\r\n\t\t<!-- ============================================== -->\r\n\t\t<div class=\"md:hidden space-y-6\">\r\n\t\t\t<SuccessTicket\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{orderTotals}\r\n\t\t\t\tcustomerEmail={current.customerEmail}\r\n\t\t\t\t{showCheckmark}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\r\n\t\t\t<SuccessActions\r\n\t\t\t\tevent={current.event}\r\n\t\t\t\torderId={current.orderId}\r\n\t\t\t\t{eventUrl}\r\n\t\t\t\t{showContent}\r\n\t\t\t\tlabels={mergedLabels}\r\n\t\t\t/>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n\r\n","<script module>\r\n import { createLogger, toTicketId } from '@getmicdrop/svelte-components';\r\n const logger = createLogger('Success');\r\n</script>\r\n\r\n<script lang=\"ts\">\r\n import { onMount } from 'svelte';\r\n import {\r\n getOrder,\r\n clearCheckoutCookies,\r\n removeCookie,\r\n } from '$lib/utils/utils.js';\r\n import { getEmbedConfig } from '$lib/config.js';\r\n import { postCheckoutComplete } from '$lib/embed-bridge.js';\r\n import { transformApiEvent } from '$lib/public-calendar-flow/transform';\r\n import SuccessMain from '$lib/public-calendar-flow/Success.svelte';\r\n import type { SuccessData, OrderLine } from '$lib/public-calendar-flow/types';\r\n\r\n // --- Props ---\r\n interface Props {\r\n data?: any;\r\n browseUrl?: string;\r\n /**\r\n * Override for the canonical event URL used by the success actions\r\n * (\"view event\" / share). The full-page get-micdrop.com route lets this\r\n * default to the current origin; the embed (running on the venue's\r\n * origin) must pass the get-micdrop.com URL so those links don't 404.\r\n */\r\n eventUrl?: string;\r\n labels?: Record<string, string>;\r\n }\r\n\r\n let {\r\n data = {},\r\n browseUrl = '/',\r\n eventUrl: eventUrlProp = undefined,\r\n labels = {},\r\n }: Props = $props();\r\n\r\n // --- State ---\r\n let successData = $state<SuccessData | null>(null);\r\n let eventUrl = $state('');\r\n let loadError = $state<string | null>(null);\r\n let loading = $state(true);\r\n\r\n onMount(async () => {\r\n const {\r\n id,\r\n slug,\r\n event: rawEvent,\r\n orderId: paramOrderId,\r\n orderUuid: paramOrderUuid,\r\n customerEmail: paramEmail,\r\n ticketCount: paramTicketCount,\r\n } = data || {};\r\n\r\n // Opt-in host notification (configureVenueCalendar({embed:{...}})).\r\n // Emitted at mount: the order is already complete when Success renders,\r\n // and a later getOrder failure must not swallow the event. Non-PII payload.\r\n {\r\n const { postMessageOnSuccess, postMessageTargetOrigin } =\r\n getEmbedConfig();\r\n if (postMessageOnSuccess) {\r\n // postCheckoutComplete validates the origin and never throws — a bad\r\n // origin logs one warning and no-ops inside the bridge, so it can't\r\n // crash this render. We deliberately ignore the boolean here.\r\n postCheckoutComplete(\r\n // orderId covers the embed successData shape; orderUuid covers the\r\n // full-page route, whose +page.js reads BOTH ?orderId= and\r\n // ?orderUuid= query params (success/+page.js:26-27) and either may\r\n // be the populated one. Success.svelte already destructures both\r\n // (paramOrderId/paramOrderUuid above). Non-PII payload (id + eventId).\r\n {\r\n orderId: String(paramOrderId || paramOrderUuid || ''),\r\n eventId: id ?? data?.eventId ?? rawEvent?.id ?? null,\r\n },\r\n postMessageTargetOrigin\r\n );\r\n }\r\n }\r\n\r\n // Build event URL — an explicit override (embed → get-micdrop.com origin)\r\n // wins; otherwise use the current origin (the full-page route).\r\n eventUrl = eventUrlProp || `${window.location.origin}/e/${id}-${slug}`;\r\n\r\n // Transform event data\r\n let eventData;\r\n try {\r\n eventData = transformApiEvent(rawEvent);\r\n } catch (e) {\r\n logger.warn('Success: transformApiEvent failed:', e);\r\n loadError = labels.failedToLoadEventData || 'Failed to load event data.';\r\n loading = false;\r\n return;\r\n }\r\n\r\n // Fetch order data\r\n let resolvedOrderId = paramOrderId || '';\r\n let resolvedEmail = paramEmail || '';\r\n let orderLines: OrderLine[] = [];\r\n let serverTotals: any = null;\r\n\r\n if (resolvedOrderId) {\r\n try {\r\n const order = await getOrder(resolvedOrderId);\r\n if (order) {\r\n // Extract email\r\n resolvedEmail = order.customerEmail || resolvedEmail;\r\n // Map purchased tickets to OrderLine[] by grouping by ticketTypeId + ticketName\r\n const tickets = ((order as any).purchasedTickets ||\r\n (order as any).tickets ||\r\n []) as any[];\r\n const grouped = new Map<string, OrderLine>();\r\n\r\n for (const ticket of tickets) {\r\n const key = `${ticket.ticketTypeId || ticket.ticketId || 0}-${ticket.ticketName || ticket.name || ''}`;\r\n const existing = grouped.get(key);\r\n if (existing) {\r\n existing.quantity += 1;\r\n existing.subtotal += ticket.purchasePrice || ticket.price || 0;\r\n } else {\r\n grouped.set(key, {\r\n ticketId: ticket.ticketTypeId || ticket.ticketId || 0,\r\n ticketName:\r\n ticket.ticketName ||\r\n ticket.name ||\r\n labels.ticketFallbackName ||\r\n 'Ticket',\r\n quantity: 1,\r\n unitPrice: ticket.purchasePrice || ticket.price || 0,\r\n fee: 0,\r\n subtotal: ticket.purchasePrice || ticket.price || 0,\r\n });\r\n }\r\n }\r\n\r\n orderLines = Array.from(grouped.values());\r\n\r\n // Capture the persisted, server-authoritative totals. These\r\n // match the actual Stripe charge (totalPrice = basePrice +\r\n // tax + surcharge) — don't let SuccessMain recompute from\r\n // lines, which would drop the tax + service fee.\r\n if (typeof order.totalPrice === 'number') {\r\n serverTotals = {\r\n subtotal: order.basePrice ?? 0,\r\n fees: order.surcharge ?? 0,\r\n taxes: order.tax ?? 0,\r\n total: order.totalPrice,\r\n promoDiscount: order.promoCodeStoredDiscountAmount ?? 0,\r\n giftCardAmount: order.giftCardPaymentAmount ?? 0,\r\n stripeAmount:\r\n Number(order.totalPrice) -\r\n Number(order.giftCardPaymentAmount ?? 0),\r\n };\r\n }\r\n }\r\n } catch (e) {\r\n logger.warn('Success: getOrder failed, using route params:', e);\r\n // Graceful degradation -- continue with whatever data we have\r\n }\r\n }\r\n\r\n // If no order lines from API, build a placeholder from route params\r\n if (orderLines.length === 0 && paramTicketCount > 0) {\r\n orderLines = [\r\n {\r\n ticketId: toTicketId(0),\r\n ticketName: labels.ticketFallbackName || 'Ticket',\r\n quantity: paramTicketCount,\r\n unitPrice: 0,\r\n fee: 0,\r\n subtotal: 0,\r\n },\r\n ];\r\n }\r\n\r\n // Build SuccessData\r\n successData = {\r\n event: eventData,\r\n orderId: String(resolvedOrderId),\r\n lines: orderLines,\r\n customerEmail: resolvedEmail,\r\n ...(serverTotals ? { serverTotals } : {}),\r\n };\r\n\r\n // Clear checkout cookies AFTER data is loaded (Pitfall 4)\r\n clearCheckoutCookies(String(id));\r\n removeCookie('checkout-cartid');\r\n\r\n loading = false;\r\n });\r\n</script>\r\n\r\n{#if loadError}\r\n <div\r\n class=\"flex flex-col items-center justify-center py-24 text-center gap-4 error-container\"\r\n >\r\n <p>{loadError}</p>\r\n </div>\r\n{:else if loading || !successData}\r\n <div\r\n class=\"flex items-center justify-center py-24 text-center loading-container\"\r\n >\r\n <p>{labels.loadingYourOrder || 'Loading your order'}</p>\r\n </div>\r\n{:else}\r\n <SuccessMain data={successData} {eventUrl} />\r\n{/if}\r\n\r\n<style>\r\n .loading-container {\r\n color: hsl(var(--text-secondary, 215 16% 47%));\r\n }\r\n\r\n .error-container p {\r\n color: hsl(var(--status-sold-out, 0 72% 51%));\r\n }\r\n</style>\r\n"],"names":["labels","$","$$props","ticketCount","sum","l","headingText","Card","$$anchor","div","root","div_1","div_2","div_3","svg","div_4","div_5","Heading","node","Text","node_1","node_2","div_6","OrderSummary","node_3","div_7","node_4","div_8","Email","node_6","classes","classes_1","classes_2","calendarOpen","toggleCalendar","onMount","handleClickOutside","e","googleCalendarUrl","startDate","endDate","formatForGoogle","date","fullLocation","downloadICS","formatForICS","uid","now","escapeICS","str","icsContent","blob","url","link","safeFilename","handleGoogleCalendar","shareEvent","shareData","err","fallbackShare","toast","handleAppleWallet","handleGoogleWallet","directionsUrl","locationParts","handleBackToEvent","root_6","fragment","Image","PLACEHOLDER_IMAGE","Calendar","formatEventTime","$$render","consequent","formatBrowseDate","text_3","button","img","button_1","img_1","img_2","Button","node_7","ChevronDown","node_9","root_2","a","button_2","Apple","consequent_1","node_12","Share","LocationFilled","consequent_2","div_9","button_3","ArrowLeft","a_1","fragment_9","Help","consequent_3","successStateOptions","dataVariant","dataToggleStore","dataProp","eventUrlProp","mergedLabels","mergeLabels","isShowcaseMode","variantData","mockEvent","toTicketId","mockFreeEvent","mockRegistrationEvent","mockDonationEvent","current","orderTotals","lines","subtotal","fees","taxes","calculateTax","eventUrl","showCheckmark","showContent","reducedMotion","runAnimations","SuccessTicket","SuccessActions","logger","createLogger","data","successData","loadError","loading","id","slug","rawEvent","paramOrderId","paramOrderUuid","paramEmail","paramTicketCount","postMessageOnSuccess","postMessageTargetOrigin","getEmbedConfig","postCheckoutComplete","eventData","transformApiEvent","resolvedOrderId","resolvedEmail","orderLines","serverTotals","order","getOrder","tickets","grouped","ticket","key","existing","clearCheckoutCookies","removeCookie","p","root_1","p_1","SuccessMain","alternate"],"mappings":"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"}