{"version":3,"sources":["webpack:///./app/javascript/src/stripe.js","webpack:///./node_modules/@stripe/stripe-js/dist/stripe.esm.js"],"names":["window","loadStripeForm","$","length","publishable_key","toggleLoader","show","toggleClass","parents","prop","showCardError","event","displayError","document","getElementById","error","textContent","message","createPaymentMethod","cardElement","customerId","priceId","stripe","type","card","then","result","createSubscription","paymentMethodId","paymentMethod","id","fetch","base_subscription_url","method","headers","attr","body","JSON","stringify","response","json","subscription","handlePaymentThatRequiresCustomerAction","handlePaymentMethodRequired","onSubscriptionComplete","status","latest_invoice","payment_intent","localStorage","setItem","invoice","isRetry","paymentIntent","confirmCardPayment","client_secret","payment_method","subscriptionId","ok","location","alert","click","loadStripe","locale","elements","style","base","color","fontFamily","fontSmoothing","fontSize","invalid","iconColor","create","hidePostalCode","mount","on","paymentForm","addEventListener","evt","preventDefault","V3_URL","V3_URL_REGEX","EXISTING_SCRIPT_MESSAGE","stripePromise","loadScript","params","Promise","resolve","reject","Stripe","console","warn","script","scripts","querySelectorAll","concat","i","test","src","findScript","queryString","advancedFraudSignals","createElement","headOrBody","head","Error","appendChild","injectScript","initStripe","maybeStripe","args","startTime","apply","undefined","_registerWrapper","name","version","registerWrapper","stripePromise$1","loadCalled","err","_len","arguments","Array","_key","Date","now"],"mappings":"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","file":"js/3-9cb4d73a95a890cdc7fe.chunk.js","sourcesContent":["import { loadStripe } from \"@stripe/stripe-js\";\n\nwindow.loadStripeForm = async () => {\n if ($(\"#card-element\").length > 0 && window.publishable_key) {\n if ($('input[name=\"pricing\"]:checked').length == 0) {\n // Initialize plan informations\n $('input[name=\"pricing\"]:first').click();\n }\n\n const stripe = await loadStripe(window.publishable_key, { locale: \"fr\" });\n const elements = stripe.elements();\n\n const style = {\n base: {\n color: \"#32325d\",\n fontFamily: '\"Helvetica Neue\", Helvetica, sans-serif',\n fontSmoothing: \"antialiased\",\n fontSize: \"16px\",\n \"::placeholder\": {\n color: \"#aab7c4\",\n },\n },\n invalid: {\n color: \"#fa755a\",\n iconColor: \"#fa755a\",\n },\n };\n\n const cardElement = elements.create(\"card\", {\n hidePostalCode: true,\n style: style,\n });\n cardElement.mount(\"#card-element\");\n cardElement.on(\"change\", (event) => {\n showCardError(event);\n });\n\n function toggleLoader(show = true) {\n $(\".loader\").toggleClass(\"d-none\", !show);\n $(\".loader\").parents(\"button\").prop(\"disabled\", show);\n }\n\n function showCardError(event) {\n let displayError = document.getElementById(\"card-errors\");\n if (event.error) {\n displayError.textContent = event.error.message;\n toggleLoader(false);\n } else {\n displayError.textContent = \"\";\n }\n }\n\n let paymentForm = document.getElementById(\"payment-form\");\n if (paymentForm) {\n paymentForm.addEventListener(\"submit\", function (evt) {\n evt.preventDefault();\n toggleLoader();\n\n createPaymentMethod(cardElement);\n });\n }\n\n function createPaymentMethod(cardElement, customerId, priceId) {\n return stripe\n .createPaymentMethod({\n type: \"card\",\n card: cardElement,\n })\n .then((result) => {\n if (result.error) {\n showCardError(result);\n } else {\n createSubscription({\n customerId: customerId,\n paymentMethodId: result.paymentMethod.id,\n priceId: priceId,\n });\n }\n });\n }\n\n function createSubscription({ customerId, paymentMethodId, priceId }) {\n return (\n fetch(\n `${window.base_subscription_url}/${window.priceId()}/subscriptions`,\n {\n method: \"post\",\n headers: {\n \"Content-type\": \"application/json\",\n \"X-CSRF-Token\": $('meta[name=\"csrf-token\"]').attr(\"content\"),\n },\n body: JSON.stringify({\n customerId: window.customerId,\n paymentMethodId: paymentMethodId,\n }),\n }\n )\n .then((response) => {\n return response.json();\n })\n // If the card is declined, display an error to the user.\n .then((result) => {\n if (result.error) {\n // The card had an error when trying to attach it to a customer.\n throw result;\n }\n return result;\n })\n // Normalize the result to contain the object returned by Stripe.\n // Add the addional details we need.\n .then((result) => {\n return {\n paymentMethodId: paymentMethodId,\n priceId: window.priceId(),\n subscription: result,\n };\n })\n // Some payment methods require a customer to be on session\n // to complete the payment process. Check the status of the\n // payment intent to handle these actions.\n .then(handlePaymentThatRequiresCustomerAction)\n // If attaching this card to a Customer object succeeds,\n // but attempts to charge the customer fail, you\n // get a requires_payment_method error.\n .then(handlePaymentMethodRequired)\n // No more actions required. Provision your service for the user.\n .then(onSubscriptionComplete)\n .catch((error) => {\n // An error has happened. Display the failure to the user here.\n // We utilize the HTML element we created.\n showCardError(error);\n })\n );\n }\n\n function handlePaymentMethodRequired({\n subscription,\n paymentMethodId,\n priceId,\n }) {\n if (subscription.status === \"active\") {\n // subscription is active, no customer actions required.\n return { subscription, priceId, paymentMethodId };\n } else if (\n subscription.latest_invoice.payment_intent.status ===\n \"requires_payment_method\"\n ) {\n // Using localStorage to store the state of the retry here\n // (feel free to replace with what you prefer)\n // Store the latest invoice ID and status\n localStorage.setItem(\"latestInvoiceId\", subscription.latest_invoice.id);\n localStorage.setItem(\n \"latestInvoicePaymentIntentStatus\",\n subscription.latest_invoice.payment_intent.status\n );\n throw { error: { message: \"Your card was declined.\" } };\n } else {\n return { subscription, priceId, paymentMethodId };\n }\n }\n\n function handlePaymentThatRequiresCustomerAction({\n subscription,\n invoice,\n priceId,\n paymentMethodId,\n isRetry,\n }) {\n if (subscription && subscription.status === \"active\") {\n // subscription is active, no customer actions required.\n return { subscription, priceId, paymentMethodId };\n }\n\n // If it's a first payment attempt, the payment intent is on the subscription latest invoice.\n // If it's a retry, the payment intent will be on the invoice itself.\n let paymentIntent = invoice\n ? invoice.payment_intent\n : subscription.latest_invoice.payment_intent;\n if (\n paymentIntent.status === \"requires_action\" ||\n (isRetry === true && paymentIntent.status === \"requires_payment_method\")\n ) {\n return stripe\n .confirmCardPayment(paymentIntent.client_secret, {\n payment_method: paymentMethodId,\n })\n .then((result) => {\n if (result.error) {\n // start code flow to handle updating the payment details\n // Display error message in your UI.\n // The card was declined (i.e. insufficient funds, card has expired, etc)\n throw result;\n } else {\n if (result.paymentIntent.status === \"succeeded\") {\n // There's a risk of the customer closing the window before callback\n // execution. To handle this case, set up a webhook endpoint and\n // listen to invoice.payment_succeeded. This webhook endpoint\n // returns an Invoice.\n return {\n priceId: priceId,\n subscription: subscription,\n invoice: invoice,\n paymentMethodId: paymentMethodId,\n };\n }\n }\n });\n } else {\n // No customer action needed\n return { subscription, priceId, paymentMethodId };\n }\n }\n\n function onSubscriptionComplete(result) {\n // Payment was successful.\n fetch(\n `${\n window.base_subscription_url\n }/${window.priceId()}/subscriptions/confirm`,\n {\n method: \"post\",\n headers: {\n \"Content-type\": \"application/json\",\n \"X-CSRF-Token\": $('meta[name=\"csrf-token\"]').attr(\"content\"),\n },\n body: JSON.stringify({\n subscriptionId: result.subscription.id,\n }),\n }\n ).then((response) => {\n toggleLoader(false);\n if (response.ok) {\n window.location = `${\n window.base_subscription_url\n }/${window.priceId()}/subscriptions/success`;\n } else {\n alert(\"Une erreur est survenue\");\n }\n });\n }\n }\n};\n\nwindow.loadStripeForm();\n\n$(document).on(\"turbolinks:load\", function () {\n window.loadStripeForm();\n});\n","var V3_URL = 'https://js.stripe.com/v3';\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\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 findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(V3_URL, \"\\\"]\"));\n\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n\n if (!V3_URL_REGEX.test(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(V3_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 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: \"1.38.1\",\n startTime: startTime\n });\n};\n\nvar stripePromise = null;\n\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise !== null) {\n return stripePromise;\n }\n\n stripePromise = new Promise(function (resolve, reject) {\n if (typeof window === '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 }\n\n script.addEventListener('load', function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n });\n script.addEventListener('error', function () {\n reject(new Error('Failed to load Stripe.js'));\n });\n } catch (error) {\n reject(error);\n return;\n }\n });\n return stripePromise;\n};\n\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\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// own script injection.\n\n\nvar stripePromise$1 = Promise.resolve().then(function () {\n return loadScript(null);\n});\nvar loadCalled = false;\nstripePromise$1[\"catch\"](function (err) {\n if (!loadCalled) {\n console.warn(err);\n }\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();\n return stripePromise$1.then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\n\nexport { loadStripe };"],"sourceRoot":""}