@getmicdrop/venue-calendar 4.0.82 → 4.0.83

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 (94) hide show
  1. package/dist/CartView-DBrUqLSR.js +2365 -0
  2. package/dist/CartView-DBrUqLSR.js.map +1 -0
  3. package/dist/{Checkout-B15JygVy.js → Checkout-BAtOdBIM.js} +466 -470
  4. package/dist/Checkout-BAtOdBIM.js.map +1 -0
  5. package/dist/Checkout-BEcmGOZm.js +789 -0
  6. package/dist/Checkout-BEcmGOZm.js.map +1 -0
  7. package/dist/{CheckoutTimer-qLOtPDt3.js → CheckoutTimer-CayvrAa9.js} +13 -13
  8. package/dist/{CheckoutTimer-qLOtPDt3.js.map → CheckoutTimer-CayvrAa9.js.map} +1 -1
  9. package/dist/CollectionView-kk90OMFq.js +299 -0
  10. package/dist/CollectionView-kk90OMFq.js.map +1 -0
  11. package/dist/{Event-DZpU-Ec1.js → Event-N959l6uT.js} +1875 -1249
  12. package/dist/Event-N959l6uT.js.map +1 -0
  13. package/dist/EventPage-DaEMiLjY.js +529 -0
  14. package/dist/EventPage-DaEMiLjY.js.map +1 -0
  15. package/dist/{Heading-5CT9Nk0b.js → Heading-A_nixT3L.js} +2 -2
  16. package/dist/{Heading-5CT9Nk0b.js.map → Heading-A_nixT3L.js.map} +1 -1
  17. package/dist/{ModalHeader-CGaXzdcs.js → ModalHeader-CxMVzApa.js} +2 -2
  18. package/dist/{ModalHeader-CGaXzdcs.js.map → ModalHeader-CxMVzApa.js.map} +1 -1
  19. package/dist/ScarcityBadge-CiF-JsPl.js +90 -0
  20. package/dist/ScarcityBadge-CiF-JsPl.js.map +1 -0
  21. package/dist/SeriesPage-CQJHrpTH.js +33 -0
  22. package/dist/SeriesPage-CQJHrpTH.js.map +1 -0
  23. package/dist/Success-R-1NhLjx.js +729 -0
  24. package/dist/{Success-B4CM_cy1.js.map → Success-R-1NhLjx.js.map} +1 -1
  25. package/dist/{Text-WY42WIKI.js → Text-F6D2QvI6.js} +16 -16
  26. package/dist/{Text-WY42WIKI.js.map → Text-F6D2QvI6.js.map} +1 -1
  27. package/dist/{VenueCalendar-DMSeDRSN.js → VenueCalendar-DdRkxjxd.js} +3821 -4111
  28. package/dist/VenueCalendar-DdRkxjxd.js.map +1 -0
  29. package/dist/{ViewTicketsEmbed-AlVzNvxE.js → ViewTicketsEmbed-BwvS8VgE.js} +31 -31
  30. package/dist/{ViewTicketsEmbed-AlVzNvxE.js.map → ViewTicketsEmbed-BwvS8VgE.js.map} +1 -1
  31. package/dist/api/api.cjs.map +1 -1
  32. package/dist/api/api.mjs +3 -6
  33. package/dist/api/api.mjs.map +1 -1
  34. package/dist/{data-toggle-store.svelte-CtW4s3Vw.js → data-toggle-store.svelte-D9XyVwDW.js} +2 -2
  35. package/dist/{data-toggle-store.svelte-CtW4s3Vw.js.map → data-toggle-store.svelte-D9XyVwDW.js.map} +1 -1
  36. package/dist/{labels-BB1JG19g.js → labels-DG5wh_vD.js} +29 -30
  37. package/dist/{labels-BB1JG19g.js.map → labels-DG5wh_vD.js.map} +1 -1
  38. package/dist/seo/seo.cjs +1 -1
  39. package/dist/seo/seo.cjs.map +1 -1
  40. package/dist/seo/seo.mjs +79 -58
  41. package/dist/seo/seo.mjs.map +1 -1
  42. package/dist/{transform-BlXf-shc.js → transform-C5S2acqv.js} +2 -4
  43. package/dist/{transform-BlXf-shc.js.map → transform-C5S2acqv.js.map} +1 -1
  44. package/dist/venue-calendar.css +1 -1
  45. package/dist/venue-calendar.es.js +18 -18
  46. package/dist/venue-calendar.iife.js +31 -41
  47. package/dist/venue-calendar.iife.js.map +1 -1
  48. package/dist/venue-calendar.umd.js +24 -34
  49. package/dist/venue-calendar.umd.js.map +1 -1
  50. package/package.json +171 -170
  51. package/dist/CarouselView.legacy-DAixPl6l.js +0 -65
  52. package/dist/CarouselView.legacy-DAixPl6l.js.map +0 -1
  53. package/dist/CartView-CsdqWB24.js +0 -1744
  54. package/dist/CartView-CsdqWB24.js.map +0 -1
  55. package/dist/Checkout-B15JygVy.js.map +0 -1
  56. package/dist/Checkout-CUwOrErt.js +0 -831
  57. package/dist/Checkout-CUwOrErt.js.map +0 -1
  58. package/dist/Checkout.legacy-CrFgAYYe.js +0 -1156
  59. package/dist/Checkout.legacy-CrFgAYYe.js.map +0 -1
  60. package/dist/CollectionView-D2bRelLR.js +0 -338
  61. package/dist/CollectionView-D2bRelLR.js.map +0 -1
  62. package/dist/CollectionView.legacy-DLb5fzi-.js +0 -241
  63. package/dist/CollectionView.legacy-DLb5fzi-.js.map +0 -1
  64. package/dist/Event-DZpU-Ec1.js.map +0 -1
  65. package/dist/EventPage-CL0yuKWZ.js +0 -577
  66. package/dist/EventPage-CL0yuKWZ.js.map +0 -1
  67. package/dist/EventPage.legacy-EujdNc3A.js +0 -1324
  68. package/dist/EventPage.legacy-EujdNc3A.js.map +0 -1
  69. package/dist/FeaturedView.legacy-CbLBD-tn.js +0 -128
  70. package/dist/FeaturedView.legacy-CbLBD-tn.js.map +0 -1
  71. package/dist/GalleryCard-BcIcYghD.js +0 -93
  72. package/dist/GalleryCard-BcIcYghD.js.map +0 -1
  73. package/dist/GalleryView.legacy-XpQUg-5_.js +0 -52
  74. package/dist/GalleryView.legacy-XpQUg-5_.js.map +0 -1
  75. package/dist/GroupedListView.legacy-qvwIV5Qm.js +0 -145
  76. package/dist/GroupedListView.legacy-qvwIV5Qm.js.map +0 -1
  77. package/dist/OrderSummarySkeleton-pqfhjvKT.js +0 -632
  78. package/dist/OrderSummarySkeleton-pqfhjvKT.js.map +0 -1
  79. package/dist/ScarcityBadge-BkRFHRif.js +0 -77
  80. package/dist/ScarcityBadge-BkRFHRif.js.map +0 -1
  81. package/dist/SeriesPage-NWCA_Aez.js +0 -54
  82. package/dist/SeriesPage-NWCA_Aez.js.map +0 -1
  83. package/dist/SeriesPage.legacy-BXSwM5jV.js +0 -193
  84. package/dist/SeriesPage.legacy-BXSwM5jV.js.map +0 -1
  85. package/dist/Success-B4CM_cy1.js +0 -748
  86. package/dist/Success.legacy-BWAmPmZz.js +0 -192
  87. package/dist/Success.legacy-BWAmPmZz.js.map +0 -1
  88. package/dist/VenueCalendar-DMSeDRSN.js.map +0 -1
  89. package/dist/__SKIP_NAVIGATION__-CmipjatL.js +0 -18
  90. package/dist/__SKIP_NAVIGATION__-CmipjatL.js.map +0 -1
  91. package/dist/api-ChzBkXfo.js +0 -6
  92. package/dist/api-ChzBkXfo.js.map +0 -1
  93. package/dist/colors-CmP-sSZD.js +0 -56
  94. package/dist/colors-CmP-sSZD.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Checkout-BEcmGOZm.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,15 +1,15 @@
1
1
  import "svelte/internal/disclose-version";
2
2
  import * as e from "svelte/internal/client";
3
- import { M as R, a as U, b as j, c as y, d as B, ap as F } from "./VenueCalendar-DMSeDRSN.js";
4
- import { M as H } from "./ModalHeader-CGaXzdcs.js";
5
- import { T as O } from "./Text-WY42WIKI.js";
3
+ import { M as R, a as U, b as j, c as y, d as B, au as F } from "./VenueCalendar-DdRkxjxd.js";
4
+ import { M as H } from "./ModalHeader-CxMVzApa.js";
5
+ import { T as O } from "./Text-F6D2QvI6.js";
6
6
  var q = e.from_html("<!> <!> <!> <!>", 1), w = e.from_html("<!> <!>", 1);
7
- function K(u, t) {
7
+ function K(v, t) {
8
8
  e.push(t, !0);
9
9
  let c = e.prop(t, "open", 15, !1);
10
10
  e.prop(t, "isProcessing", 3, !1), e.prop(t, "isSuccess", 3, !1);
11
11
  let h = e.prop(t, "size", 3, "md"), s = e.prop(t, "persistent", 3, !1), f = e.prop(t, "haptic", 3, !0), m = e.prop(t, "variant", 3, "sheet");
12
- R(u, {
12
+ R(v, {
13
13
  get size() {
14
14
  return h();
15
15
  },
@@ -37,7 +37,7 @@ function K(u, t) {
37
37
  set open(i) {
38
38
  c(i);
39
39
  },
40
- children: (i, v) => {
40
+ children: (i, u) => {
41
41
  var o = w(), d = e.first_child(o);
42
42
  U(d, {});
43
43
  var P = e.sibling(d, 2);
@@ -112,11 +112,11 @@ function K(u, t) {
112
112
  }), e.pop();
113
113
  }
114
114
  var A = e.from_html("<div><!> <!></div>");
115
- function L(u, t) {
115
+ function L(v, t) {
116
116
  e.push(t, !0), e.prop(t, "labels", 19, () => ({}));
117
117
  let c = e.derived(() => (() => {
118
- const v = Math.floor(t.seconds / 60), o = t.seconds % 60;
119
- return `${v.toString().padStart(2, "0")}:${o.toString().padStart(2, "0")}`;
118
+ const u = Math.floor(t.seconds / 60), o = t.seconds % 60;
119
+ return `${u.toString().padStart(2, "0")}:${o.toString().padStart(2, "0")}`;
120
120
  })()), h = e.derived(() => t.isUrgent ? "Complete soon" : "Reservation held");
121
121
  var s = A();
122
122
  let f;
@@ -126,16 +126,16 @@ function L(u, t) {
126
126
  O(i, {
127
127
  size: "sm",
128
128
  class: "font-medium tabular-nums",
129
- children: (v, o) => {
129
+ children: (u, o) => {
130
130
  e.next();
131
131
  var d = e.text();
132
- e.template_effect(() => e.set_text(d, `${e.get(h) ?? ""} · ${e.get(c) ?? ""}`)), e.append(v, d);
132
+ e.template_effect(() => e.set_text(d, `${e.get(h) ?? ""} · ${e.get(c) ?? ""}`)), e.append(u, d);
133
133
  },
134
134
  $$slots: { default: !0 }
135
- }), e.reset(s), e.template_effect(() => f = e.set_class(s, 1, "timer-display text-color-secondary svelte-8jbi4g", null, f, { urgent: t.isUrgent })), e.append(u, s), e.pop();
135
+ }), e.reset(s), e.template_effect(() => f = e.set_class(s, 1, "timer-display text-color-secondary svelte-8jbi4g", null, f, { urgent: t.isUrgent })), e.append(v, s), e.pop();
136
136
  }
137
137
  export {
138
138
  L as C,
139
139
  K as M
140
140
  };
141
- //# sourceMappingURL=CheckoutTimer-qLOtPDt3.js.map
141
+ //# sourceMappingURL=CheckoutTimer-CayvrAa9.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CheckoutTimer-qLOtPDt3.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
+ {"version":3,"file":"CheckoutTimer-CayvrAa9.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]}
@@ -0,0 +1,299 @@
1
+ import "svelte/internal/disclose-version";
2
+ import * as e from "svelte/internal/client";
3
+ import { untrack as V, onMount as j, onDestroy as F } from "svelte";
4
+ import { g as M } from "./ScarcityBadge-CiF-JsPl.js";
5
+ import { E as O } from "./Event-N959l6uT.js";
6
+ import { b as B } from "./transform-C5S2acqv.js";
7
+ import { s as A, ay as G, ab as Q, j as U, az as H } from "./VenueCalendar-DdRkxjxd.js";
8
+ import { cubicOut as J } from "svelte/easing";
9
+ var K = e.from_html("<div></div>"), X = e.from_html('<div class="pt-2 space-y-2"><div class="flex gap-1.5"></div> <!></div>');
10
+ function Y(S, t) {
11
+ e.push(t, !0);
12
+ const b = {
13
+ tooWeak: "Too weak",
14
+ weak: "Weak",
15
+ good: "Good",
16
+ strong: "Strong"
17
+ };
18
+ let g = e.prop(t, "password", 3, ""), n = e.prop(t, "strengthText", 15, ""), x = e.prop(t, "score", 31, () => -1), c = e.prop(t, "textColor", 15, ""), f = e.prop(t, "labels", 19, () => ({})), s = e.derived(() => ({ ...b, ...f() })), d = e.state(""), v, p = e.state(null);
19
+ const y = G(() => import("./index-BsWecoW1.js"));
20
+ function C() {
21
+ y().then((r) => {
22
+ e.set(p, r.passwordStrength, !0);
23
+ }).catch(() => {
24
+ });
25
+ }
26
+ e.user_effect(() => {
27
+ g() && !e.get(p) && C();
28
+ });
29
+ let I = e.derived(() => [
30
+ {
31
+ id: 0,
32
+ value: e.get(s).tooWeak,
33
+ minDiversity: 0,
34
+ minLength: 0
35
+ },
36
+ {
37
+ id: 1,
38
+ value: e.get(s).weak,
39
+ minDiversity: 1,
40
+ minLength: 6
41
+ },
42
+ {
43
+ id: 2,
44
+ value: e.get(s).good,
45
+ minDiversity: 2,
46
+ minLength: 8
47
+ },
48
+ {
49
+ id: 3,
50
+ value: e.get(s).strong,
51
+ minDiversity: 3,
52
+ minLength: 10
53
+ }
54
+ ]);
55
+ e.user_effect(() => (clearTimeout(v), g().length === 0 ? e.set(d, "") : v = setTimeout(
56
+ () => {
57
+ e.set(d, g());
58
+ },
59
+ 400
60
+ ), () => clearTimeout(v)));
61
+ let L = e.derived(() => e.get(d) && e.get(p) ? e.get(p)(e.get(d), e.get(I)) : null), a = e.derived(() => e.get(d).length > 12 ? 3 : e.get(L)?.id ?? -1);
62
+ e.user_effect(() => {
63
+ const r = e.get(a);
64
+ V(() => x()) !== r && x(r);
65
+ });
66
+ let q = e.derived(() => e.get(a) === 0 ? e.get(s).tooWeak : e.get(a) === 1 ? e.get(s).weak : e.get(a) === 2 ? e.get(s).good : e.get(a) === 3 ? e.get(s).strong : ""), z = e.derived(() => e.get(a) < 0 ? "" : e.get(a) <= 1 ? "text-accent-danger" : "text-accent-success");
67
+ e.user_effect(() => {
68
+ const r = e.get(q);
69
+ V(() => n()) !== r && n(r);
70
+ });
71
+ let D = e.derived(() => e.get(a) <= 1 ? "bg-accent-danger" : "bg-accent-success");
72
+ e.user_effect(() => {
73
+ const r = e.get(z);
74
+ V(() => c()) !== r && c(r);
75
+ });
76
+ let k = e.derived(() => e.get(a) === 0 ? 1 : e.get(a) === 1 ? 2 : e.get(a) >= 2 ? 3 : 0);
77
+ var T = e.comment(), l = e.first_child(T);
78
+ {
79
+ var o = (r) => {
80
+ var i = X(), m = e.child(i);
81
+ e.each(m, 20, () => [0, 1, 2], e.index, (E, _) => {
82
+ var u = K();
83
+ e.template_effect(() => e.set_class(u, 1, `h-1 flex-1 rounded-full transition-colors duration-300 ${(_ < e.get(k) ? e.get(D) : "bg-bg-tertiary") ?? ""}`)), e.append(E, u);
84
+ }), e.reset(m);
85
+ var w = e.sibling(m, 2);
86
+ e.snippet(w, () => t.children ?? e.noop), e.reset(i), e.transition(3, i, () => A, () => ({ duration: 600, easing: J })), e.append(r, i);
87
+ };
88
+ e.if(l, (r) => {
89
+ e.get(d).length > 0 && r(o);
90
+ });
91
+ }
92
+ e.append(S, T), e.pop();
93
+ }
94
+ var Z = e.from_html("<p> </p>"), $ = e.from_html("<div><!> <!></div>");
95
+ function ee(S, t) {
96
+ e.push(t, !0);
97
+ const b = { passwordStrength: "Password strength:" };
98
+ let g = e.prop(t, "value", 15, ""), n = e.prop(t, "label", 3, ""), x = e.prop(t, "placeholder", 3, ""), c = e.prop(t, "name", 3, ""), f = e.prop(t, "id", 3, ""), s = e.prop(t, "required", 3, !1), d = e.prop(t, "disableBuiltInValidation", 3, !1), v = e.prop(t, "disabled", 3, !1), p = e.prop(t, "error", 3, ""), y = e.prop(t, "hint", 3, ""), C = e.prop(t, "showStrength", 3, !1), I = e.prop(t, "size", 3, "md"), L = e.prop(t, "minlength", 3, null), a = e.prop(t, "maxlength", 3, null), q = e.prop(t, "autocomplete", 3, "new-password"), z = e.prop(t, "showPasswordToggle", 3, !0), D = e.prop(t, "class", 3, ""), k = e.prop(t, "labels", 19, () => ({})), T = e.derived(() => ({ ...b, ...k() })), l = e.derived(() => d() ? !1 : s()), o = e.state(-1), r = e.state(""), i = e.state("");
99
+ var m = $(), w = e.child(m);
100
+ Q(w, {
101
+ type: "password",
102
+ get id() {
103
+ return f();
104
+ },
105
+ get name() {
106
+ return c();
107
+ },
108
+ get placeholder() {
109
+ return x();
110
+ },
111
+ get label() {
112
+ return n();
113
+ },
114
+ get required() {
115
+ return e.get(l);
116
+ },
117
+ get disabled() {
118
+ return v();
119
+ },
120
+ get size() {
121
+ return I();
122
+ },
123
+ get minlength() {
124
+ return L();
125
+ },
126
+ get maxlength() {
127
+ return a();
128
+ },
129
+ get autocomplete() {
130
+ return q();
131
+ },
132
+ get showPasswordToggle() {
133
+ return z();
134
+ },
135
+ get errorText() {
136
+ return p();
137
+ },
138
+ get hintText() {
139
+ return y();
140
+ },
141
+ get oninputchange() {
142
+ return t.oninput;
143
+ },
144
+ get onblur() {
145
+ return t.onblur;
146
+ },
147
+ get onfocus() {
148
+ return t.onfocus;
149
+ },
150
+ get value() {
151
+ return g();
152
+ },
153
+ set value(u) {
154
+ g(u);
155
+ }
156
+ });
157
+ var E = e.sibling(w, 2);
158
+ {
159
+ var _ = (u) => {
160
+ Y(u, {
161
+ get password() {
162
+ return g();
163
+ },
164
+ get score() {
165
+ return e.get(o);
166
+ },
167
+ set score(h) {
168
+ e.set(o, h, !0);
169
+ },
170
+ get strengthText() {
171
+ return e.get(r);
172
+ },
173
+ set strengthText(h) {
174
+ e.set(r, h, !0);
175
+ },
176
+ get textColor() {
177
+ return e.get(i);
178
+ },
179
+ set textColor(h) {
180
+ e.set(i, h, !0);
181
+ },
182
+ children: (h, N) => {
183
+ var P = Z(), R = e.child(P);
184
+ e.reset(P), e.template_effect(() => {
185
+ e.set_class(P, 1, `text-xs ${e.get(i) ?? ""}`), e.set_text(R, `${e.get(T).passwordStrength ?? ""} ${e.get(r) ?? ""}`);
186
+ }), e.append(h, P);
187
+ },
188
+ $$slots: { default: !0 }
189
+ });
190
+ };
191
+ e.if(E, (u) => {
192
+ C() && g() && u(_);
193
+ });
194
+ }
195
+ e.reset(m), e.template_effect(() => e.set_class(m, 1, e.clsx(D()))), e.append(S, m), e.pop();
196
+ }
197
+ var te = e.from_html('<div class="flex items-center justify-center py-12 text-center loading-container svelte-q4dz4y"><p> </p></div>'), re = e.from_html('<div class="flex flex-col items-center justify-center min-h-[50vh] text-center"><div class="password-card rounded-lg p-8 max-w-sm w-full svelte-q4dz4y"><h2 class="password-title text-xl font-bold mb-2 svelte-q4dz4y"> </h2> <p class="password-description text-sm mb-6 svelte-q4dz4y"> </p> <form class="flex flex-col gap-3"><!> <button type="submit" class="password-submit px-4 py-2 rounded-lg text-sm font-semibold svelte-q4dz4y"> </button></form></div></div>'), le = e.from_html('<div class="flex flex-col items-center justify-center min-h-[50vh] text-center"><p class="error-text svelte-q4dz4y"> </p></div>');
198
+ function ue(S, t) {
199
+ e.push(t, !0), U("CollectionView"), e.prop(t, "organizationId", 3, "");
200
+ let b = e.prop(t, "onNavigateToEvent", 3, void 0), g = e.prop(t, "password", 3, void 0);
201
+ e.prop(t, "displayMode", 3, "gallery"), e.prop(t, "showViewSwitcher", 3, !0);
202
+ let n = e.prop(t, "labels", 19, () => ({})), x = e.state(null), c = e.state(!0), f = e.state(null), s = e.state(!1), d = e.state(!1), v = e.state(""), p = e.state(!1), y = e.derived(() => e.get(x) ? B(e.get(x)) : null);
203
+ async function C(l) {
204
+ if (e.get(s)) {
205
+ if (!t.collectionId) {
206
+ e.set(f, n().noCollectionIdProvided || "No collection ID provided", !0), e.set(c, !1);
207
+ return;
208
+ }
209
+ e.set(c, !0), e.set(f, null), e.set(p, !1);
210
+ try {
211
+ const o = await H(t.collectionId, l);
212
+ if (!e.get(s)) return;
213
+ if (o) {
214
+ if (o.passwordRequired || o.error?.code === "PASSWORD_REQUIRED") {
215
+ e.set(d, !0), e.set(c, !1);
216
+ return;
217
+ }
218
+ e.set(x, o, !0), e.set(d, !1);
219
+ } else {
220
+ if (l) {
221
+ e.set(d, !0), e.set(p, !0), e.set(c, !1);
222
+ return;
223
+ }
224
+ e.set(f, n().failedToLoadCollection || "Failed to load collection", !0);
225
+ }
226
+ } catch (o) {
227
+ if (e.get(s)) {
228
+ const r = o.message || "";
229
+ r.includes("401") || r.includes("403") || r.includes("password") ? e.set(d, !0) : e.set(f, r || n().failedToLoadCollection || "Failed to load collection", !0);
230
+ }
231
+ } finally {
232
+ e.get(s) && e.set(c, !1);
233
+ }
234
+ }
235
+ }
236
+ function I(l) {
237
+ l.preventDefault(), e.get(v).trim() && C(e.get(v));
238
+ }
239
+ function L(l) {
240
+ b() && l.id ? b()(Number(l.id), l.slug) : M(`/${l.id}/${l.slug}`);
241
+ }
242
+ j(() => {
243
+ e.set(s, !0), C(g());
244
+ }), F(() => {
245
+ e.set(s, !1);
246
+ });
247
+ var a = e.comment(), q = e.first_child(a);
248
+ {
249
+ var z = (l) => {
250
+ var o = te(), r = e.child(o), i = e.child(r, !0);
251
+ e.reset(r), e.reset(o), e.template_effect(() => e.set_text(i, n().loadingCollection || "Loading collection...")), e.append(l, o);
252
+ }, D = (l) => {
253
+ var o = re(), r = e.child(o), i = e.child(r), m = e.child(i, !0);
254
+ e.reset(i);
255
+ var w = e.sibling(i, 2), E = e.child(w, !0);
256
+ e.reset(w);
257
+ var _ = e.sibling(w, 2), u = e.child(_);
258
+ {
259
+ let P = e.derived(() => n().enterPassword || "Enter password"), R = e.derived(() => e.get(p) ? n().incorrectPassword || "Incorrect password. Please try again." : "");
260
+ ee(u, {
261
+ get placeholder() {
262
+ return e.get(P);
263
+ },
264
+ get error() {
265
+ return e.get(R);
266
+ },
267
+ get value() {
268
+ return e.get(v);
269
+ },
270
+ set value(W) {
271
+ e.set(v, W, !0);
272
+ }
273
+ });
274
+ }
275
+ var h = e.sibling(u, 2), N = e.child(h, !0);
276
+ e.reset(h), e.reset(_), e.reset(r), e.reset(o), e.template_effect(() => {
277
+ e.set_text(m, n().collectionPrivateTitle || "This collection is private"), e.set_text(E, n().collectionPrivateDescription || "Please enter the password to view this collection."), e.set_text(N, n().viewCollection || "View Collection");
278
+ }), e.event("submit", _, I), e.append(l, o);
279
+ }, k = (l) => {
280
+ var o = le(), r = e.child(o), i = e.child(r);
281
+ e.reset(r), e.reset(o), e.template_effect(() => e.set_text(i, `${(n().errorPrefix || "Error:") ?? ""} ${e.get(f) ?? ""}`)), e.append(l, o);
282
+ }, T = (l) => {
283
+ O(l, {
284
+ get event() {
285
+ return e.get(y);
286
+ },
287
+ onCollectionEventClick: L
288
+ });
289
+ };
290
+ e.if(q, (l) => {
291
+ e.get(c) ? l(z) : e.get(d) ? l(D, 1) : e.get(f) ? l(k, 2) : e.get(y) && l(T, 3);
292
+ });
293
+ }
294
+ e.append(S, a), e.pop();
295
+ }
296
+ export {
297
+ ue as default
298
+ };
299
+ //# sourceMappingURL=CollectionView-kk90OMFq.js.map