{"version":3,"sources":["webpack:///./Scripts/Components/Checkout/PaymentMethods.js","webpack:///./Scripts/Components/Checkout/CheckoutCartItem.js","webpack:///./Scripts/Components/Checkout/CheckoutCart.js","webpack:///./Scripts/Components/Checkout/DeliveryMethods.js","webpack:///./Scripts/Components/Checkout/ExceedsBudgetCard.js","webpack:///../node_modules/@hookform/resolvers/dist/resolvers.mjs","webpack:///../node_modules/@hookform/resolvers/yup/dist/yup.mjs","webpack:///./Scripts/Components/Checkout/InputField.js","webpack:///./Scripts/Components/Checkout/StateField.js","webpack:///./Scripts/Components/Checkout/CountryField.js","webpack:///./Scripts/Components/Checkout/DeliveryAddressField.js","webpack:///./Scripts/Components/Checkout/CustomerInformation.js","webpack:///./Scripts/Components/Checkout/CustomerInformationValidator.js","webpack:///./Scripts/Components/Checkout/ExternalDocumentField.js","webpack:///./Scripts/Components/Checkout/PartialShipping.js","webpack:///./Scripts/Components/Checkout/DeliveryInformation.js","webpack:///./Scripts/Components/Checkout/CheckoutFieldsFactory.js","webpack:///./Scripts/Components/Checkout/Checkout.js"],"names":["paymentMethods","register","getValues","handleSubmit","formState","useFormContext","className","translate","options","map","x","id","key","type","value","defaultChecked","checked","htmlFor","text","message","article","dispatch","useDispatch","cartQuantity","setCartQuantity","useState","quantity","errorMessage","setErrorMessage","mapCartToAbort","useSelector","state","cart","useRef","updateCart","debounce","rowSystemId","current","AbortController","update","catch","ex","catchError","error","loadError","updateCartItem","newTotal","Object","values","forEach","controller","abort","increment","minQuantity","isOrderItem","maxQuantity","isAvailableInStock","useEffect","src","image","alt","style","width","display","alignItems","justifyContent","href","url","name","onClick","xmlns","height","viewBox","fill","d","stroke","strokeLinecap","strokeLinejoin","campaignPrice","price","information","index","decrement","totalCampaignPrice","totalPrice","orderRows","orderTotal","freight","length","splitPaymentApproved","setSplitPaymentApproved","setMessage","ref","disabled","s","e","o","r","setCustomValidity","reportValidity","t","fields","refs","shouldUseNativeValidation","f","n","a","assign","i","names","keys","some","startsWith","c","Promise","resolve","u","context","mode","abortEarly","then","raw","errors","inner","criteriaMode","reduce","path","types","concat","reject","label","placeholder","control","readOnly","render","field","onChange","fieldState","dependsOn","prefix","setValue","watch","countries","setCountries","fieldType","setFieldType","country","states","defaultValue","selected","hidden","abbreviation","countryPickerActive","countryPicker","active","deliveryAddressCountries","constants","includes","event","preventDefault","setOpen","checkout","deliveryAddresses","payload","filter","target","deliveryAddress","find","systemId","address1","zipCode","city","customData","companyName","handleSelectAddress","data","editable","isB2C","shouldLockEmailField","lockEmailField","canEdit","paymentMethod","keyMap","StateField","CountryField","InputField","DeliveryAddressField","title","Component","margin","endsWith","getNonEditableText","showPayment","schema","setError","clearErrors","showCompanyAddress","showDeliveryAddresses","hasSameAsBillingAddress","async","validate","fieldPath","deliveryOptions","generate","getContactInformationFields","generateAddressFields","generateB2C","generateBusinessUserSpecificFields","generateB2B","setShowPayment","setFreight","freightLoaded","setFreightLoaded","paymentOptions","checkoutMode","setTotalPrice","receiptUrl","b2c","exceedsMinimumOrderAmount","generateDeliveryAddress","address2","careOf","addressSchema","yup","required","max","when","is","otherwise","optional","shape","undefined","externalDocumentNumber","customerDetails","firstName","lastName","email","matches","phoneNumber","billingAddress","shippingAddress","methods","useForm","resolver","yupResolver","defaultValues","partialShipping","companyAddress","companyAddresses","address","generateBillingAddress","generateCustomerDetails","selectedPaymentMethod","selectedDeliveryMethod","deliveryMethods","deliveryMethod","iframeRef","isShopSpraySession","exceedsBudget","reloadPaymentWidget","orderData","innerHTML","response","post","json","checkoutOptions","checkoutKey","paymentId","containerId","language","theme","buttonRadius","Dibs","Checkout","on","window","location","initializePayment","patch","countryCode","loadCart","setFreightOption","setPartialShipping","totalExclVat","calculateFreight","disableCheckout","authenticated","checkoutData","onSubmit","dataFromCheckout","redirectUrl","console","placeOrder","textAlign","ExternalDocumentField","includeVat","orderTotalWithVat","orderTotalWithoutVat"],"mappings":"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","file":"774.ce4a32e139d1ff0dd5ea.js","sourcesContent":["import React from 'react';\nimport { useFormContext } from \"react-hook-form\";\nimport { translate } from \"../../Services/translation\";\n\nconst PaymentMethods = ({ paymentMethods }) => {\n    const { register, getValues, handleSubmit, formState } = useFormContext();\n\n    return (\n        <div>\n            <p className=\"checkout__section-title\">{translate('checkout.form.paymentmethods')}</p>\n            <div className=\"card\">\n                <div className=\"card__body card__body--large\">\n                    <div className=\"checkout__radio-container\">\n                        {\n                            paymentMethods.options.map(x => (\n                                <div>\n                                    <input\n                                        className=\"checkout__radio-button\"\n                                        id={\"payment-method-\" + x.key}\n                                        type=\"radio\"\n                                        value={x.key}\n                                        {...register('paymentMethod')}\n                                        defaultChecked={x.checked}\n                                    />\n                                    <label htmlFor={\"payment-method-\" + x.key}\n                                           className=\"checkout__radio-label\">{translate(x.text)}</label>\n\n                                    {x.message && <p className=\"checkout__text\"><br/>{x.message}</p>}\n                                </div>\n                            ))\n                        }\n                    </div>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default PaymentMethods;\n","import React, { Fragment, useEffect, useRef, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { loadError, update } from '../../Actions/Cart.action';\nimport { debounce } from 'lodash-es';\nimport { catchError } from '../../Actions/Error.action';\nimport { translate } from '../../Services/translation';\n\nconst CheckoutCartItem = ({ article }) => {\n  const dispatch = useDispatch();\n  const [cartQuantity, setCartQuantity] = useState(article.quantity);\n  const [errorMessage, setErrorMessage] = useState('');\n  const cart = useSelector((state) => state.cart);\n\n  const mapCartToAbort = useRef({});\n\n  const updateCart = useRef(\n    debounce((rowSystemId, quantity) => {\n      mapCartToAbort.current[rowSystemId] = new AbortController();\n      dispatch(\n        update(rowSystemId, quantity, mapCartToAbort.current[rowSystemId])\n      ).catch((ex) => {\n        dispatch(catchError(ex, (error) => loadError(error)));\n      });\n    }, 500)\n  ).current;\n\n  useEffect(() => {\n    setCartQuantity(article.quantity);\n  }, [article.quantity]);\n\n  function updateCartItem(newTotal) {\n    setErrorMessage('');\n\n    updateCart(article.rowSystemId, newTotal);\n\n    // Clean up function to cancel any pending requests\n    return () => {\n      Object.values(mapCartToAbort.current).forEach((controller) => {\n        controller.abort();\n      });\n    };\n  }\n\n  function isAvailableInStock(newTotal) {\n    return newTotal <= article.maxQuantity;\n    let rows = cart.orderRows.filter((x) => x.rowSys === article.rowSys);\n\n    if (rows === 0) {\n      return newTotal <= article.maxQuantity;\n    }\n\n    let amount = rows.reduce((sum, x) => sum + x.quantity, 0);\n\n    return amount + newTotal <= article.maxQuantity;\n  }\n\n  function decrement() {\n    let newTotal = cartQuantity - article.minQuantity;\n\n    if (newTotal > 0) {\n      setCartQuantity(newTotal);\n\n      return updateCartItem(newTotal);\n    }\n\n    setErrorMessage(translate('cart.item.quantity.minquantity'));\n  }\n\n  function increment() {\n    let newTotal = cartQuantity + article.minQuantity;\n\n    if (article.isOrderItem) {\n      setCartQuantity(newTotal);\n\n      return updateCartItem(newTotal);\n    }\n\n    if (isAvailableInStock(newTotal)) {\n      setCartQuantity(newTotal);\n\n      return updateCartItem(newTotal);\n    }\n\n    setErrorMessage(translate('cart.item.quantity.notenoughinstock'));\n  }\n\n  return (\n    <>\n      <div>\n        <div className=\"checkout__article-image-container\">\n          <img className=\"checkout__article-image\" src={article.image} alt=\"\" />\n        </div>\n      </div>\n      <div style={{ width: '100%' }}>\n        <div\n          style={{\n            display: 'flex',\n            alignItems: 'start',\n            justifyContent: 'space-between',\n            width: '100%',\n          }}\n        >\n          <a href={article.url} className=\"checkout__article-title\">\n            {article.name}\n          </a>\n          <button\n            type=\"button\"\n            className=\"checkout__article-button\"\n            onClick={() => dispatch(update(article.rowSystemId, 0))}\n          >\n            <svg\n              xmlns=\"http://www.w3.org/2000/svg\"\n              width=\"20\"\n              height=\"20\"\n              viewBox=\"0 0 20 20\"\n              fill=\"none\"\n            >\n              <path\n                d=\"M2.5 5H4.16667H17.5\"\n                stroke=\"#373D41\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n              <path\n                d=\"M15.8334 5.00033V16.667C15.8334 17.109 15.6578 17.5329 15.3453 17.8455C15.0327 18.1581 14.6088 18.3337 14.1667 18.3337H5.83341C5.39139 18.3337 4.96746 18.1581 4.6549 17.8455C4.34234 17.5329 4.16675 17.109 4.16675 16.667V5.00033M6.66675 5.00033V3.33366C6.66675 2.89163 6.84234 2.46771 7.1549 2.15515C7.46746 1.84259 7.89139 1.66699 8.33341 1.66699H11.6667C12.1088 1.66699 12.5327 1.84259 12.8453 2.15515C13.1578 2.46771 13.3334 2.89163 13.3334 3.33366V5.00033\"\n                stroke=\"#373D41\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n              <path\n                d=\"M8.33325 9.16699V14.167\"\n                stroke=\"#373D41\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n              <path\n                d=\"M11.6667 9.16699V14.167\"\n                stroke=\"#373D41\"\n                strokeLinecap=\"round\"\n                strokeLinejoin=\"round\"\n              />\n            </svg>\n          </button>\n        </div>\n        <div>\n          <p className=\"checkout__article-price\">\n            {article.campaignPrice ?? article.price}\n          </p>\n\n          {article.information.map((x, index) => {\n            return (\n              <p className=\"checkout__article-information\" key={index}>\n                {x}\n              </p>\n            );\n          })}\n        </div>\n        <div className=\"checkout__article-row\">\n          <div></div>\n          <div className=\"cart__content__item__product-info__item__counter\">\n            <button\n              type=\"button\"\n              id=\"itemcounter-remove\"\n              onClick={() => decrement()}\n            >\n              -\n            </button>\n            <div id=\"itemcounter-current\">{cartQuantity}</div>\n            <button\n              type=\"button\"\n              id=\"itemcounter-add\"\n              onClick={() => increment()}\n            >\n              +\n            </button>\n          </div>\n        </div>\n\n        {errorMessage && (\n          <p className=\"checkout__article-error-message\">{errorMessage}</p>\n        )}\n\n        {article.totalCampaignPrice ? (\n          <>\n            <p className=\"checkout__article-price-total checkout__article-price-total--old\">\n              {article.totalPrice}\n            </p>\n            <p className=\"checkout__article-price-total checkout__article-price-total--discounted\">\n              {article.totalCampaignPrice}\n            </p>\n          </>\n        ) : (\n          <p className=\"checkout__article-price-total\">{article.totalPrice}</p>\n        )}\n      </div>\n    </>\n  );\n};\n\nexport default CheckoutCartItem;\n","import React from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { translate } from \"../../Services/translation\";\nimport CheckoutCartItem from \"./CheckoutCartItem\";\n\nconst CheckoutCart = ({ onClick }) => {\n    const cart = useSelector((state) => state.cart);\n\n    return (\n        <div>\n            <p className=\"checkout__heading\">{translate('checkout.cart')}</p>\n            <div className=\"card\">\n                <div className=\"card__body card__body--paddingless\">\n                    <div>\n\n                        <div>\n                            <div>\n\n                            </div>\n                            <ul className=\"checkout__article-list\">\n                                {\n                                    cart.orderRows.map((x, index) => {\n                                            return (<li className=\"checkout__article-container\" key={index}>\n                                                <CheckoutCartItem article={x}/>\n                                            </li>)\n                                        }\n                                    )\n                                }\n                                <li className=\"checkout__article-container\">\n                                    <p className=\"checkout__article-total-price\">{cart.orderTotal}</p>\n                                </li>\n                            </ul>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default CheckoutCart;\n","import React from 'react';\nimport { useFormContext } from \"react-hook-form\";\nimport { translate } from \"../../Services/translation\";\n\nconst DeliveryMethods = ({ freight }) => {\n    const { register} = useFormContext();\n\n    return (\n        <div>\n            <p className=\"checkout__label checkout__label--radio\">{translate('checkout.form.deliverymethod.label')}</p>\n            {\n                freight.options.length === 0 ?\n                    <p className=\"checkout__text\">{translate('checkout.form.externalshippingtext')}</p>\n\n                    :\n                    <div>\n                        <div className=\"checkout__radio-container\">\n                            {\n                                freight.options.map(x => (\n                                    <div>\n                                        <input\n                                            className=\"checkout__radio-button\"\n                                            id={\"freight-\" + x.key}\n                                            type=\"radio\"\n                                            value={x.key}\n                                            {...register('deliveryMethod')}\n                                            defaultChecked={x.checked}\n                                        />\n                                        <label htmlFor={\"freight-\" + x.key}\n                                               className=\"checkout__radio-label\">{translate(x.text)} - {x.price}</label>\n                                    </div>\n                                ))\n                            }\n                        </div>\n                    </div>\n            }\n\n        </div>\n    );\n};\n\nexport default DeliveryMethods;\n","import React, { useEffect, useRef, useState } from 'react';\nimport { translate } from \"../../Services/translation\";\n\nconst ExceedsBudgetCard = ({ splitPaymentApproved, setSplitPaymentApproved }) => {\n    const [message, setMessage] = useState('');\n\n    useEffect(() => {\n        setMessage(\"\");\n    }, [splitPaymentApproved]);\n\n    function handleOnClick(){\n        if(!ref.current.checked){\n            setMessage(translate('checkout.forms.exceededbudget.checkbox.error'));\n\n            return;\n        }\n\n        setSplitPaymentApproved(!splitPaymentApproved);\n    }\n\n    const ref = useRef();\n\n    return (\n        <div className=\"card\">\n            <div className=\"card__body card__body--large\">\n                <div className=\"checkout__form-container\">\n\n                    <div>\n                        <p className=\"checkout__label\">{translate('checkout.form.exceededbudget.label')}</p>\n\n                        <p>{translate('checkout.forms.exceededbudget.text')}</p>\n\n                        <label className=\"checkout__checkbox-label\" htmlFor=\"exceedsbudget-checkbox\">\n                            <input className=\"checkout__checkbox\" id=\"exceedsbudget-checkbox\" ref={ref} type=\"checkbox\" disabled={splitPaymentApproved}/>\n                            <span>{translate('checkout.forms.exceededbudget.checkbox.text')}</span>\n                        </label>\n\n                        {message && <p className=\"checkout__input-validation-error\">{message}</p>}\n\n                        <button\n                            onClick={() => handleOnClick()}\n                            className=\"checkout__form-group-button\"\n                            type=\"button\">{splitPaymentApproved ? translate('checkout.forms.edit') : translate('checkout.forms.next')}\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default ExceedsBudgetCard;\n","import{get as t,set as e}from\"react-hook-form\";const s=(e,s,o)=>{if(e&&\"reportValidity\"in e){const r=t(o,s);e.setCustomValidity(r&&r.message||\"\"),e.reportValidity()}},o=(t,e)=>{for(const o in e.fields){const r=e.fields[o];r&&r.ref&&\"reportValidity\"in r.ref?s(r.ref,o,t):r.refs&&r.refs.forEach(e=>s(e,o,t))}},r=(s,r)=>{r.shouldUseNativeValidation&&o(s,r);const f={};for(const o in s){const n=t(r.fields,o),a=Object.assign(s[o]||{},{ref:n&&n.ref});if(i(r.names||Object.keys(s),o)){const s=Object.assign({},t(f,o));e(s,\"root\",a),e(f,o,s)}else e(f,o,a)}return f},i=(t,e)=>t.some(t=>t.startsWith(e+\".\"));export{r as toNestErrors,o as validateFieldsNatively};\n//# sourceMappingURL=resolvers.mjs.map\n","import{validateFieldsNatively as e,toNestErrors as t}from\"@hookform/resolvers\";import{appendErrors as r}from\"react-hook-form\";function o(o,n,a){return void 0===n&&(n={}),void 0===a&&(a={}),function(s,i,c){try{return Promise.resolve(function(t,r){try{var u=(n.context&&\"development\"===process.env.NODE_ENV&&console.warn(\"You should not used the yup options context. Please, use the 'useForm' context object instead\"),Promise.resolve(o[\"sync\"===a.mode?\"validateSync\":\"validate\"](s,Object.assign({abortEarly:!1},n,{context:i}))).then(function(t){return c.shouldUseNativeValidation&&e({},c),{values:a.raw?s:t,errors:{}}}))}catch(e){return r(e)}return u&&u.then?u.then(void 0,r):u}(0,function(e){if(!e.inner)throw e;return{values:{},errors:t((o=e,n=!c.shouldUseNativeValidation&&\"all\"===c.criteriaMode,(o.inner||[]).reduce(function(e,t){if(e[t.path]||(e[t.path]={message:t.message,type:t.type}),n){var o=e[t.path].types,a=o&&o[t.type];e[t.path]=r(t.path,n,e,t.type,a?[].concat(a,t.message):t.message)}return e},{})),c)};var o,n}))}catch(e){return Promise.reject(e)}}}export{o as yupResolver};\n//# sourceMappingURL=yup.module.js.map\n","import React from \"react\";\nimport { Controller } from 'react-hook-form';\n\nfunction InputField({ label, name, placeholder, control, readOnly = false }) {\n    return (\n        <Controller\n            control={control}\n            name={name}\n            render={({ field: { onChange, value }, fieldState: { error } }) => (\n                <div>\n                    {\n                        label && <label htmlFor=\"\"\n                                        className=\"checkout__label\">{label}</label>\n                    }\n                    <input type=\"text\"\n                           id={name}\n                           onChange={onChange}\n                           value={value}\n                           className={\"checkout__input \" + (error ? \"checkout__input--error\" : \"\")}\n                           readOnly={readOnly}\n                           placeholder={placeholder}/>\n                    {error &&\n                        <p className=\"checkout__input-validation-error\">{error.message}</p>}\n                </div>\n            )}\n        />\n    );\n}\n\nexport default InputField;\n","import React, { useEffect, useState } from \"react\";\nimport { useFormContext } from \"react-hook-form\";\nimport states from \"./States.json\";\nimport { Controller } from 'react-hook-form';\nimport InputField from \"./InputField\";\n\nfunction StateField({ label, name, placeholder, control, dependsOn, prefix, field, readOnly }) {\n    const { setValue, watch, getValues } = useFormContext();\n\n    const [countries, setCountries] = useState([]);\n    const [fieldType, setFieldType] = useState('input');\n\n    function getText(key) {\n        const completeKey = `${prefix}.${key}`;\n\n        return getValues(completeKey) ?? \"\";\n    }\n\n    const country = watch(dependsOn);\n\n    useEffect(() => {\n        switch (country) {\n            case 'US':\n                setCountries(states['usa']);\n                setFieldType('select');\n                break;\n            case 'CA':\n                setCountries(states['canada']);\n                setFieldType('select');\n                break;\n            default:\n                setCountries([]);\n                setValue(`${prefix}.${field.key}`, '');\n                setFieldType('input');\n                break;\n        }\n    }, [country]);\n\n    if (fieldType === 'select') {\n        return (\n            <Controller\n                control={control}\n                name={name}\n                render={({ field: { onChange, value }, fieldState: { error } }) => (\n                    <div>\n                        {\n                            fieldType === 'select' && <>\n                                {\n                                    label && <label htmlFor=\"\"\n                                                    className=\"checkout__label\">{label}</label>\n                                }\n                                {\n                                    fieldType === 'select' &&\n                                    <select className=\"checkout__input\" name=\"\" id=\"\"\n                                            defaultValue={getText(field)}\n                                            value={value}\n                                            disabled={readOnly}\n                                            onChange={onChange}\n                                    >\n                                        <option value=\"\" selected disabled hidden>Select state</option>\n                                        {\n                                            countries.map(x => {\n                                                return (\n                                                    <option value={x.abbreviation}>{x.abbreviation} - {x.name}</option>);\n                                            })\n                                        }\n                                    </select>\n                                }\n\n                            </>\n                        }\n                        {error &&\n                            <p className=\"checkout__input-validation-error\">{error.message}</p>}\n                    </div>\n                )}\n            />\n        )\n    }\n\n    if(fieldType === 'input'){\n        return (\n            <InputField\n                name={name}\n                control={control}\n                label={label}\n                placeholder={placeholder}\n                readOnly={readOnly}\n            />\n        )\n    }\n\n    return null;\n}\n\nexport default StateField;\n","import React from \"react\";\nimport constants from \"../../constants\";\nimport { Controller } from 'react-hook-form';\nimport { setOpen } from \"../../Actions/CountryPicker.action\";\nimport { useSelector, useDispatch } from \"react-redux\";\nimport { translate } from \"../../Services/translation\";\n\nfunction CountryField({ label, name, control, readOnly = false }) {\n    const countryPickerActive = useSelector((state) => state.countryPicker.active);\n\n    const dispatch = useDispatch();\n\n    const deliveryAddressCountries = constants.deliveryAddressCountries;\n\n    const countries = constants.countries.filter(x => {\n        if(deliveryAddressCountries.length > 0){\n            return deliveryAddressCountries.includes(x.value);\n        }\n\n        return true;\n    });\n\n    return (\n        <Controller\n            control={control}\n            name={name}\n            render={({ field: { onChange, value }, fieldState: { error } }) => (\n                <div>\n                    {\n                        label && <label htmlFor=\"\"\n                                        className=\"checkout__label\">{label}</label>\n                    }\n\n                    <select className={\"checkout__input \" + (error ? \"checkout__input--error\" : \"\")}\n                            onChange={onChange}\n                            value={value}\n                            disabled={readOnly}\n                    >\n                        <option value=\"\" selected disabled hidden>Select country</option>\n                        {\n                            countries.map(x => {\n                                return (<option value={x.value}>{x.text}</option>);\n                            })\n                        }\n                    </select>\n\n                    {error &&\n                        <p className=\"checkout__input-validation-error\">{error.message}</p>}\n\n                    {\n                        (!readOnly && countryPickerActive) &&\n                        <button className=\"checkout__country-picker-button\"\n                                type=\"button\"\n                                onClick={(event) => {event.preventDefault(); dispatch(setOpen(true))}}>{translate(\"checkout.form.changecountry\")}</button>\n                    }\n                </div>\n            )}\n        />\n    )\n}\n\nexport default CountryField;\n","import React, { useRef, useState } from \"react\";\nimport constants from \"../../constants\";\nimport { Controller } from 'react-hook-form';\nimport { useSelector } from 'react-redux';\nimport { useFormContext } from \"react-hook-form\";\n\nfunction DeliveryAddressField({ label, name, control, readOnly = false }) {\n    const checkout = useSelector((state) => state.checkout);\n\n    const ref = useRef();\n\n    const {setValue, watch} = useFormContext();\n\n    function handleSelectAddress(e, onChange) {\n        setValue('selectedAddress', e.target.value);\n\n        if (e.target.value !== 'other') {\n            const deliveryAddress = checkout.payload.deliveryAddresses.find(x => x.systemId === e.target.value);\n\n            setValue(`shippingAddress.address1`, deliveryAddress.address1);\n            setValue(`shippingAddress.zipCode`, deliveryAddress.zipCode);\n            setValue(`shippingAddress.city`, deliveryAddress.city);\n            setValue(`shippingAddress.country`, deliveryAddress.country);\n            setValue(`shippingAddress.state`, deliveryAddress.state);\n            setValue(`companyName`, deliveryAddress.customData?.companyName ?? \"\");\n        } else {\n            setValue(`shippingAddress.address1`, '');\n            setValue(`shippingAddress.zipCode`, '');\n            setValue(`shippingAddress.city`, '');\n            setValue(`shippingAddress.country`, '');\n            setValue(`shippingAddress.state`, '');\n            setValue(`companyName`, '');\n        }\n\n        onChange(e);\n    }\n\n    const deliveryAddressCountries = constants.deliveryAddressCountries;\n\n    const deliveryAddresses = checkout.payload.deliveryAddresses.filter(x => {\n        if (deliveryAddressCountries.length > 0) {\n            return deliveryAddressCountries.includes(x.country);\n        }\n\n        return true;\n    });\n\n    if(deliveryAddresses.length === 0){\n        return null;\n    }\n\n    return (\n        <Controller\n            control={control}\n            name={name}\n            render={({ field: { onChange, value }, fieldState: { error } }) => (\n                <div>\n                    {\n                        label && <label htmlFor=\"\"\n                                        className=\"checkout__label\">{label}</label>\n                    }\n\n                    <select\n                        value={value}\n                        ref={ref}\n                        onChange={(event) => handleSelectAddress(event, onChange)}\n                        className=\"checkout__input\"\n                    >\n                        {\n                            deliveryAddresses.map(x => {\n                                return (\n                                    <option\n                                        value={x.systemId}>{x.address1}, {x.zipCode}, {x.country}</option>);\n                            })\n                        }\n\n                        <option value=\"other\">Other address</option>\n\n                    </select>\n\n                    {error &&\n                        <p className=\"checkout__input-validation-error\">{error.message}</p>}\n                </div>\n            )}\n        />\n    )\n}\n\nexport default DeliveryAddressField;\n","import React from 'react';\nimport { useFormContext } from \"react-hook-form\";\nimport { translate } from \"../../Services/translation\";\nimport StateField from \"./StateField\";\nimport InputField from \"./InputField\";\nimport CountryField from \"./CountryField\";\nimport DeliveryAddressField from \"./DeliveryAddressField\";\nimport constants from \"../../constants\";\nimport { useSelector } from 'react-redux';\n\nconst CustomerInformation = ({\n                                 data,\n                                 editable,\n                                 isB2C\n                             }) => {\n    const checkout = useSelector((state) => state.checkout);\n    const shouldLockEmailField = checkout.payload.lockEmailField;\n\n    const { getValues, control } = useFormContext();\n\n    const canEdit = editable;\n\n    const { watch } = useFormContext();\n\n    const paymentMethod = watch('paymentMethod');\n\n    function getNonEditableText(key) {\n        const text = getValues(key);\n\n        if (!text) {\n            return translate('checkout.forms.not-specified');\n        }\n\n        if (key.endsWith('.country')) {\n            return constants.countries.find(x => x.value === text)?.text ?? text;\n        }\n\n        return text;\n    }\n\n    function isEditable(field) {\n        if (!isB2C && field.name?.startsWith('billingAddress.') && paymentMethod === 'invoice') {\n            return false;\n        }\n\n        return canEdit;\n    }\n\n    const keyMap = {\n        state: StateField,\n        country: CountryField,\n        text: InputField,\n        deliveryAddress: DeliveryAddressField\n    };\n\n    return (\n        <div>\n            <p className=\"checkout__form-group-title\">{translate(data.title)}</p>\n            <div className=\"checkout__form-group\">\n                {\n                    data.fields.map((x, index) => {\n                        if (x.type === 'empty') {\n                            return <div></div>\n                        }\n\n                        const Component = keyMap[x.type]\n\n                        let readOnly = x.name === 'customerDetails.email' && shouldLockEmailField;\n\n                        return (\n                            <div key={index}>\n                                {\n                                    isEditable(x) ?\n\n                                        <Component\n                                            name={x.name}\n                                            control={control}\n                                            label={x.label}\n                                            prefix={data.key}\n                                            field={x}\n                                            readOnly={readOnly}\n                                            {...x}\n                                        />\n\n                                        :\n                                        <>\n                                            {\n                                                (x.type !== 'deliveryAddress' && x.type !== 'empty') && <>\n                                                    <p className=\"checkout__label\">{x.label}</p>\n                                                    <p style={{ margin: 0 }}>{getNonEditableText(x.name)}</p></>\n                                            }\n                                        </>\n                                }\n                            </div>\n                        )\n                    })\n                }\n            </div>\n        </div>\n    );\n};\n\nexport default CustomerInformation;\n","import React from 'react';\nimport { useFormContext } from \"react-hook-form\";\nimport { translate } from \"../../Services/translation\";\nimport CustomerInformation from \"./CustomerInformation\";\n\nconst CustomerInformationValidator = ({\n                                          data,\n                                          showPayment,\n                                          schema,\n                                          onClick,\n                                          isB2C,\n                                          control\n                                      }) => {\n\n\n    const { getValues, setError, clearErrors } = useFormContext();\n\n    const onPartialSubmit = async () => {\n        try {\n            clearErrors();\n            const values = getValues();\n            await schema.validate(values, { abortEarly: false });\n            onClick();\n        } catch (errors) {\n            errors.inner.forEach(error => {\n                const fieldPath = error.path;\n                setError(fieldPath, { type: 'manual', message: error.message });\n            });\n        }\n    };\n\n\n    return (\n        <div>\n            <p className=\"checkout__section-title\">{translate('checkout.form.contactandaddressinformation')}</p>\n            <div className=\"card\">\n                <div className=\"card__body card__body--large\">\n                    <div className=\"checkout__form-container\">\n                        {\n\n                            data.map((x, index) => {\n                                return (\n                                    <CustomerInformation\n                                        control={control}\n                                        onClick={x.onClick}\n                                        key={index}\n                                        data={x}\n                                        showCompanyAddress={x.showCompanyAddress}\n                                        showDeliveryAddresses={x.showDeliveryAddresses}\n                                        hasSameAsBillingAddress={x.hasSameAsBillingAddress}\n                                        editable={!showPayment}\n                                        isB2C={isB2C}\n                                    />);\n                            })\n                        }\n\n                        <button className=\"checkout__form-group-button\" onClick={onPartialSubmit}\n                                type=\"button\">{showPayment ? translate('checkout.forms.edit') : translate('checkout.forms.next')}</button>\n                    </div>\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default CustomerInformationValidator;\n","import React from \"react\";\nimport { translate } from \"../../Services/translation\";\nimport InputField from \"./InputField\";\n\nfunction ExternalDocumentNumber({ control }) {\n    const name = \"externalDocumentNumber\";\n\n    return (\n\n        <div>\n            <>\n                <p className=\"checkout__section-title\">{translate('checkout.form.otherinformation')}</p>\n                <div className=\"card\">\n                    <div className=\"card__body card__body--large\">\n                        <div className=\"checkout__form-container\">\n\n                            <div>\n                                <p className=\"checkout__label\">{translate('checkout.form.externaldocumentnumber.label')}</p>\n\n                                <InputField\n                                    name={name}\n                                    placeholder={translate('checkout.form.externaldocumentnumber.placeholder')}\n                                />\n                            </div>\n\n                        </div>\n                    </div>\n                </div>\n                <p className=\"checkout__customs-text\">{translate('checkout.customs.text')}</p>\n            </>\n        </div>\n    );\n}\n\nexport default ExternalDocumentNumber;\n","import React from 'react';\nimport { useFormContext } from \"react-hook-form\";\nimport { translate } from \"../../Services/translation\";\n\nconst PartialShipping = ({deliveryOptions}) => {\n    const { register } = useFormContext();\n\n    if(deliveryOptions.length === 0){\n        return null;\n    }\n\n    return (\n        <div className=\"checkout__partial-shipping-container\">\n            <p className=\"checkout__label checkout__label--radio\">{translate('checkout.form.deliveryalternative.label')}</p>\n            <p className=\"checkout__text\">{translate('checkout.form.deliveryalternative.text')}</p>\n            <div>\n                <div className=\"checkout__radio-container\">\n                    {\n                        deliveryOptions.map(x => (\n                            <div>\n                                <input\n                                    className=\"checkout__radio-button\"\n                                    id={\"partial-delivery-\" + x.key}\n                                    type=\"radio\"\n                                    value={x.key}\n                                    {...register('partialShipping')}\n                                    defaultChecked={x.checked}\n                                />\n                                <label htmlFor={\"partial-delivery-\" + x.key}\n                                       className=\"checkout__radio-label\">{translate(x.text)} {x.price && <span>- {x.price}</span>}</label>\n                            </div>\n                        ))\n                    }\n                </div>\n            </div>\n        </div>\n    );\n};\n\nexport default PartialShipping;\n","import { translate } from \"../../Services/translation\";\nimport React from \"react\";\nimport DeliveryMethods from \"./DeliveryMethods\";\nimport PartialShipping from \"./PartialShipping\";\n\nfunction DeliveryInformation({ freight, paymentMethod }) {\n\n    return (\n        <div>\n            <p className=\"checkout__section-title\">{translate('checkout.form.deliveryinformation')}</p>\n            <div className=\"card\">\n                <div className=\"card__body card__body--large\">\n                    <div className=\"checkout__form-container\">\n                        {\n                            freight && <DeliveryMethods freight={freight}/>\n                        }\n                    </div>\n\n                    {freight && <PartialShipping deliveryOptions={freight.deliveryOptions}/>}\n                </div>\n            </div>\n            {\n                paymentMethod === 'credit-card' &&\n                <p className=\"checkout__customs-text\">{translate('checkout.customs.text')}</p>\n            }\n        </div>\n    )\n}\n\nexport default DeliveryInformation;\n","import constants from \"../../constants\";\nimport { translate } from \"../../Services/translation\";\n\nexport function generate(isB2C, deliveryAddressCountries) {\n    if (isB2C) {\n        return generateB2C(deliveryAddressCountries);\n    }\n\n    return generateB2B(deliveryAddressCountries);\n}\n\nfunction generateAddressFields(key, deliveryAddressCountries) {\n    return [\n        {\n            name: `${key}.address1`,\n            label: translate(\"checkout.form.address.label\"),\n            placeholder: translate(\"checkout.form.address.placeholder\"),\n            type: 'text'\n        },\n        {\n            name: `${key}.careOf`,\n            label: translate(\"checkout.form.careof.label\"),\n            placeholder: translate(\"checkout.form.careof.placeholder\"),\n            type: 'text'\n        },\n        {\n            name: `${key}.zipCode`,\n            label: translate(\"checkout.form.zipcode.label\"),\n            placeholder: translate(\"checkout.form.zipcode.placeholder\"),\n            type: 'text'\n        },\n        {\n            name: `${key}.city`,\n            label: translate(\"checkout.form.city.label\"),\n            placeholder: translate(\"checkout.form.city.placeholder\"),\n            type: 'text'\n        },\n        {\n            name: `${key}.country`,\n            label: translate(\"checkout.form.country.label\"),\n            placeholder: translate(\"checkout.form.country.placeholder\"),\n            type: 'country',\n            countries: constants.countries.filter(x => {\n                if (deliveryAddressCountries.length > 0) {\n                    return deliveryAddressCountries.includes(x.value);\n                }\n\n                return true;\n            })\n        },\n        {\n            name: `${key}.state`,\n            key: \"state\",\n            label: translate(\"checkout.form.state.label\"),\n            placeholder: translate(\"checkout.form.state.placeholder\"),\n            type: 'state',\n            dependsOn: `${key}.country`\n        },\n    ];\n}\n\nfunction generateBusinessUserSpecificFields() {\n    return [\n\n        {\n            key: \"deliveryAddress\",\n            label: translate(\"checkout.forms.deliveryaddresses\"),\n            placeholder: translate(\"checkout.forms.deliveryaddresses.placeholder\"),\n            name: 'deliveryAddress',\n            type: 'deliveryAddress'\n        },\n        {\n            key: \"companyName\",\n            label: translate(\"checkout.customerinfo.companyname\"),\n            placeholder: translate(\"checkout.form.companyname.placeholder\"),\n            name: 'companyName',\n            type: 'text'\n        }\n    ]\n}\n\nfunction generateB2B(deliveryAddressCountries) {\n    return [\n        {\n            title: \"checkout.form.contactinformation\",\n            key: 'customerDetails',\n            fields: getContactInformationFields(),\n        },\n        {\n            title: \"checkout.form.shippingaddress\",\n            key: 'shippingAddress',\n            fields: generateBusinessUserSpecificFields()\n                .concat(generateAddressFields('shippingAddress', deliveryAddressCountries)),\n        },\n        {\n            title: \"checkout.form.billingaddress\",\n            key: 'billingAddress',\n            fields: generateAddressFields('billingAddress', deliveryAddressCountries),\n        },\n    ];\n}\n\n\nfunction getContactInformationFields() {\n    return [\n        {\n            label: translate(\"checkout.form.firstname.label\"),\n            placeholder: translate(\"checkout.form.firstname.placeholder\"),\n            name: 'customerDetails.firstName',\n            type: 'text'\n        },\n        {\n            label: translate(\"checkout.form.lastname.label\"),\n            placeholder: translate(\"checkout.form.lastname.placeholder\"),\n            name: 'customerDetails.lastName',\n            type: 'text'\n        },\n        {\n            label: translate(\"checkout.form.email.label\"),\n            placeholder: translate(\"checkout.form.email.placeholder\"),\n            name: 'customerDetails.email',\n            type: 'text'\n        },\n        {\n            label: translate(\"checkout.form.phonenumber.label\"),\n            placeholder: translate(\"checkout.form.phonenumber.placeholder\"),\n            name: 'customerDetails.phoneNumber',\n            type: 'text'\n        }\n    ];\n}\n\nfunction generateB2C(deliveryAddressCountries) {\n    return [\n        {\n            title: \"checkout.form.contactinformation\",\n            key: 'customerDetails',\n            fields: getContactInformationFields(),\n        },\n        {\n            title: \"checkout.form.billingaddress\",\n            key: 'billingAddress',\n            fields: generateAddressFields('billingAddress', deliveryAddressCountries),\n        },\n        {\n            title: \"checkout.form.shippingaddress\",\n            key: 'shippingAddress',\n            fields: generateAddressFields('shippingAddress', deliveryAddressCountries),\n        },\n    ];\n}\n","import React, { useEffect, useRef, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport PaymentMethods from './PaymentMethods';\nimport { patch, post } from '../../Services/http';\nimport { FormProvider, useForm } from 'react-hook-form';\nimport CheckoutCart from './CheckoutCart';\nimport DeliveryMethods from './DeliveryMethods';\nimport { load as loadCart, load } from '../../Actions/Cart.action';\nimport { translate } from '../../Services/translation';\nimport ExceedsBudgetCard from './ExceedsBudgetCard';\nimport constants from '../../constants';\nimport * as yup from 'yup';\nimport { yupResolver } from '@hookform/resolvers/yup';\nimport CustomerInformationValidator from './CustomerInformationValidator';\nimport ExternalDocumentField from './ExternalDocumentField';\nimport DeliveryInformation from './DeliveryInformation';\nimport { generate } from './CheckoutFieldsFactory';\nimport PartialShipping from './PartialShipping';\n\nconst Checkout = () => {\n  const dispatch = useDispatch();\n  const cart = useSelector((state) => state.cart);\n  const checkout = useSelector((state) => state.checkout);\n  const [showPayment, setShowPayment] = useState(false);\n  const [freight, setFreight] = useState(false);\n  const [freightLoaded, setFreightLoaded] = useState(false);\n  const [splitPaymentApproved, setSplitPaymentApproved] = useState(false);\n  const paymentMethods = checkout.payload.paymentOptions;\n  const checkoutMode = checkout.payload.checkoutMode;\n  const deliveryAddressCountries = constants.deliveryAddressCountries;\n  const [totalPrice, setTotalPrice] = useState(cart.orderTotal);\n  const receiptUrl = checkout.payload.receiptUrl;\n  const b2c = constants.checkoutMode.privateCustomers;\n  const shouldLockEmailField = checkout.payload.lockEmailField;\n  const exceedsMinimumOrderAmount = checkout.payload.exceedsMinimumOrderAmount;\n\n  function generateCustomerDetails() {\n    const customerDetails = checkout.payload.customerDetails;\n\n    return {\n      firstName: customerDetails.firstName,\n      lastName: customerDetails.lastName,\n      email: shouldLockEmailField ? customerDetails.email : '',\n      phoneNumber: customerDetails.phoneNumber,\n    };\n  }\n\n  const ref = useRef();\n\n  const isB2C = checkoutMode === b2c;\n\n  function generateBillingAddress() {\n    let country =\n      constants.countries.length === 1 ? constants.countries[0].value : '';\n\n    if (isB2C) {\n      return {\n        address1: '',\n        address2: '',\n        careOf: '',\n        zipCode: '',\n        city: '',\n        country: country,\n        state: '',\n      };\n    }\n\n    const companyAddress = checkout.payload.companyAddresses?.[0];\n\n    if (!companyAddress) {\n      return {\n        address1: '',\n        address2: '',\n        careOf: '',\n        zipCode: '',\n        city: '',\n        country: country,\n        state: '',\n      };\n    }\n\n    return {\n      address1: companyAddress.address ?? '',\n      address2: companyAddress.address2 ?? '',\n      careOf: '',\n      zipCode: companyAddress.zipCode ?? '',\n      city: companyAddress.city ?? '',\n      country: companyAddress.country ?? '',\n      state: companyAddress.state ?? '',\n    };\n  }\n\n  function generateDeliveryAddress() {\n    let country = '';\n\n    if (isB2C) {\n      country =\n        constants.countries.length === 1 ? constants.countries[0].value : '';\n    }\n\n    const deliveryAddresses = checkout.payload.deliveryAddresses.filter((x) => {\n      if (deliveryAddressCountries.length > 0) {\n        return deliveryAddressCountries.includes(x.country);\n      }\n\n      return true;\n    });\n\n    let deliveryAddress = deliveryAddresses?.[0];\n\n    if (deliveryAddress) {\n      deliveryAddress.companyName = deliveryAddress?.customData?.companyName;\n    }\n\n    return !isB2C && deliveryAddress\n      ? deliveryAddress\n      : {\n          address1: '',\n          address2: '',\n          careOf: '',\n          zipCode: '',\n          city: '',\n          country: country,\n          state: '',\n        };\n  }\n\n  const addressSchema = {\n    address1: yup\n      .string()\n      .required(translate('forms.required'))\n      .max(100, translate('checkout.forms.errors.maxlength', 100)),\n    zipCode: yup\n      .string()\n      .required(translate('forms.required'))\n      .max(20, translate('checkout.forms.errors.maxlength', 20)),\n    city: yup\n      .string()\n      .required(translate('forms.required'))\n      .max(30, translate('checkout.forms.errors.maxlength', 30)),\n    country: yup.string().required(translate('forms.required')),\n    state: yup\n      .string()\n      .max(20, translate('checkout.forms.errors.maxlength', 20))\n      .when('country', {\n        is: (country) => ['US', 'CA'].includes(country),\n        then: (schema) => schema.required(translate('forms.required')),\n        otherwise: (schema) => schema.optional(),\n      }),\n  };\n\n  const schema = yup.object().shape({\n    companyName: !isB2C\n      ? yup.string().required(translate('forms.required'))\n      : undefined,\n    externalDocumentNumber: yup\n      .string()\n      .max(20, translate('checkout.forms.errors.maxlength', 20)),\n    customerDetails: yup.object().shape({\n      firstName: yup.string().required(translate('forms.required')),\n      lastName: yup.string().required(translate('forms.required')),\n      email: yup\n        .string()\n        .email(translate('checkout.forms.email.invalid'))\n        .required(translate('forms.required'))\n        .matches(\n          /^\\w+([\\.-]?\\w+)*@\\w+([\\.-]?\\w+)*(\\.\\w{2,3})+$/,\n          translate('checkout.forms.email.invalid')\n        ),\n      phoneNumber: yup\n        .string()\n        .matches(\n          /^\\+?[0-9 ]*$/,\n          translate('checkout.forms.phonenumber.invalid')\n        )\n        .required(translate('forms.required')),\n    }),\n    billingAddress: yup.object().shape(addressSchema),\n    shippingAddress: yup.object().shape(addressSchema),\n  });\n\n  const methods = useForm({\n    resolver: yupResolver(schema),\n    mode: 'onTouched',\n    defaultValues: {\n      partialShipping: false,\n      companyName: generateDeliveryAddress().companyName,\n      externalDocumentNumber: checkout.payload.externalDocumentNumber,\n      paymentMethod: checkout.payload.paymentOptions?.options?.find(\n        (x) => x.checked\n      )?.key,\n      billingAddress: generateBillingAddress(),\n      shippingAddress: generateDeliveryAddress(),\n      customerDetails: generateCustomerDetails(),\n      selectedPaymentMethod: checkout.payload.paymentMethods[0],\n      selectedDeliveryMethod: checkout.payload.deliveryMethods[0],\n    },\n  });\n\n  const paymentMethod = methods.watch('paymentMethod');\n  const deliveryMethod = methods.watch('deliveryMethod');\n  const shippingAddress = methods.watch('shippingAddress');\n  const partialShipping = methods.watch('partialShipping');\n\n  const iframeRef = useRef();\n\n  const isShopSpraySession = checkout.payload.isShopSpraySession;\n\n  const exceedsBudget = freight?.exceedsBudget ?? false;\n\n  useEffect(() => {\n    setShowPayment(false);\n    setFreightLoaded(false);\n  }, [paymentMethod]);\n\n  useEffect(() => {\n    if (!freightLoaded) {\n      return;\n    }\n\n    if (iframeRef.current) {\n      iframeRef.current.innerHTML = '';\n    }\n\n    setFreightOption(deliveryMethod).then(() => {\n      reloadPaymentWidget();\n    });\n  }, [deliveryMethod]);\n\n  useEffect(() => {\n    if (!showPayment) {\n      return;\n    }\n\n    if (exceedsBudget) {\n      reloadPaymentWidget();\n    } else {\n      if (iframeRef.current) {\n        iframeRef.current.innerHTML = '';\n      }\n    }\n  }, [exceedsBudget]);\n\n  useEffect(() => {\n    if (exceedsBudget) {\n      reloadPaymentWidget();\n    } else {\n      if (iframeRef.current) {\n        iframeRef.current.innerHTML = '';\n      }\n    }\n  }, [splitPaymentApproved]);\n\n  useEffect(() => {\n    setSplitPaymentApproved(false);\n  }, [showPayment]);\n\n  useEffect(() => {\n    setPartialShipping().then((response) => {\n      if (paymentMethod === 'credit-card') {\n        reloadPaymentWidget();\n      }\n    });\n  }, [partialShipping]);\n\n  useEffect(() => {\n    if (cart.totalExclVat !== totalPrice) {\n      setTotalPrice(cart.totalExclVat);\n      setShowPayment(false);\n    }\n\n    if (isShopSpraySession) {\n      calculateFreight().then(() => {\n        dispatch(loadCart());\n      });\n    }\n  }, [cart.totalExclVat]);\n\n  function reloadPaymentWidget() {\n    if (paymentMethod === 'credit-card' || (exceedsBudget && showPayment)) {\n      initializePayment(methods.getValues());\n    }\n  }\n\n  const onSubmit = (data) => {\n    if (isShopSpraySession) {\n      window.location.href =\n        '/shopspray-route/punchout-service/postbackmessage?singleEncoding=true';\n\n      return;\n    }\n\n    if (data.paymentMethod === 'invoice') {\n      placeOrder(data);\n    }\n  };\n\n  async function calculateFreight() {\n    const response = await post('/api/freight', {\n      ...methods.getValues(),\n    });\n\n    const data = await response.json();\n\n    if (data.options.length > 0) {\n      methods.setValue(\n        'deliveryMethod',\n        data.options.find((x) => x.checked).key\n      );\n    }\n\n    setFreight(data);\n  }\n\n  async function setFreightOption(value) {\n    await patch('/api/freight/', {\n      deliveryMethod: value,\n      countryCode: shippingAddress.country,\n    }).then(() => {\n      dispatch(loadCart());\n    });\n  }\n\n  async function initializePayment(orderData) {\n    if (iframeRef.current) {\n      iframeRef.current.innerHTML = '';\n    }\n\n    const response = await post('/api/payments', orderData);\n\n    const data = await response.json();\n\n    let checkoutOptions = {\n      checkoutKey: checkout?.payload?.checkoutKey,\n      paymentId: data.paymentId,\n      containerId: 'checkout-container-div',\n      language: 'en-GB',\n      theme: {\n        buttonRadius: '5px',\n      },\n    };\n\n    const netsCheckout = new Dibs.Checkout(checkoutOptions);\n\n    netsCheckout.on('payment-completed', function (response) {\n      window.location.href = receiptUrl;\n    });\n  }\n\n  async function setPartialShipping() {\n    await patch('/api/freight/setPartialShipping', {\n      ...methods.getValues(),\n    }).then(() => {\n      dispatch(loadCart());\n    });\n  }\n\n  function placeOrder(data) {\n    post('/api/checkout', data)\n      .then((response) => response.json())\n      .then((dataFromCheckout) => {\n        window.location.href = dataFromCheckout.redirectUrl;\n      })\n      .catch((error) => {\n        console.error('Error fetching data from checkout:', error);\n      });\n  }\n\n  if (checkout.payload.disableCheckout) {\n    return (\n      <div className=\"checkout\">\n        <div className=\"row\">\n          <div className=\"columns\">\n            <h2>{translate('checkout.checkoutdisabled')}</h2>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  if (!exceedsMinimumOrderAmount) {\n    return (\n      <div className=\"checkout\">\n        <div className=\"row\">\n          <div className=\"columns\">\n            <h2>{translate('checkout.minimumorderamount.required')}</h2>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  if (checkout.payload.paymentOptions.options.length === 0) {\n    return (\n      <div className=\"checkout\">\n        <div className=\"row\">\n          <div className=\"columns\">\n            <h2>{translate('checkout.nopaymentoptions')}</h2>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  if (!checkout.payload.authenticated && !isB2C) {\n    return (\n      <div className=\"checkout\">\n        <div className=\"row\">\n          <div className=\"columns\">\n            <h2>{translate('checkout.unauthenticated')}</h2>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  if (cart.orderRows.length === 0) {\n    return (\n      <div className=\"checkout\">\n        <div className=\"row\">\n          <div className=\"columns\">\n            <h2>{translate('checkout.cart.empty')}</h2>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  const checkoutData = generate(isB2C, deliveryAddressCountries);\n\n  return (\n    <div className=\"checkout\">\n      <div className=\"row\">\n        <div className=\"columns\">\n          <FormProvider {...methods}>\n            <h1 className=\"checkout__title\">{translate('checkout')}</h1>\n            <form onSubmit={methods.handleSubmit(onSubmit)} ref={ref}>\n              <div className=\"checkout__grid\">\n                <div className=\"checkout__grid-left\">\n                  <CheckoutCart />\n                </div>\n                <div className=\"checkout__grid-right\">\n                  {isShopSpraySession ? (\n                    <>\n                      {freight?.options?.length > 0 && (\n                        <div className=\"card\">\n                          <div className=\"card__body card__body--large\">\n                            <div className=\"checkout__form-container\">\n                              <DeliveryMethods freight={freight} />\n                            </div>\n                            {freight.deliveryOptions?.length > 0 && (\n                              <PartialShipping\n                                deliveryOptions={freight.deliveryOptions}\n                              />\n                            )}\n                          </div>\n                        </div>\n                      )}\n                      <div>\n                        <a\n                          href=\"/shopspray-route/punchout-service/postbackmessage?singleEncoding=true\"\n                          className=\"checkout__submit-button\"\n                          style={{ textAlign: 'center' }}\n                        >\n                          {translate('checkout.forms.complete.purchase')}\n                        </a>\n                      </div>\n                    </>\n                  ) : (\n                    <>\n                      {paymentMethods?.options?.length > 1 && (\n                        <div>\n                          <PaymentMethods paymentMethods={paymentMethods} />\n                        </div>\n                      )}\n\n                      <CustomerInformationValidator\n                        data={checkoutData}\n                        onClick={() => {\n                          if (!showPayment) {\n                            calculateFreight().then(() => {\n                              setFreightLoaded(true);\n                              setShowPayment(true);\n                              dispatch(loadCart());\n                              reloadPaymentWidget();\n                            });\n                          } else {\n                            setFreight(null);\n                            setShowPayment(false);\n                            setFreightLoaded(false);\n                          }\n                        }}\n                        showPayment={showPayment}\n                        schema={schema}\n                        isB2C={isB2C}\n                      />\n\n                      {showPayment && (\n                        <>\n                          <DeliveryInformation\n                            freight={freight}\n                            paymentMethod={paymentMethod}\n                          />\n\n                          {paymentMethod === 'invoice' ? (\n                            <>\n                              <ExternalDocumentField\n                                control={methods.control}\n                              />\n                              {exceedsBudget ? (\n                                <>\n                                  <ExceedsBudgetCard\n                                    splitPaymentApproved={splitPaymentApproved}\n                                    setSplitPaymentApproved={\n                                      setSplitPaymentApproved\n                                    }\n                                  />\n\n                                  {splitPaymentApproved && (\n                                    <div\n                                      ref={iframeRef}\n                                      id=\"checkout-container-div\"\n                                    ></div>\n                                  )}\n                                </>\n                              ) : (\n                                <div>\n                                  <p className=\"checkout__price\">\n                                    {cart.includeVat\n                                      ? translate(\n                                          'checkout.form.ordertotalinclvat',\n                                          cart.orderTotalWithVat\n                                        )\n                                      : translate(\n                                          'checkout.form.ordertotalexclvat',\n                                          cart.orderTotalWithoutVat\n                                        )}\n                                  </p>\n\n                                  <p className=\"checkout__vat\">\n                                    {cart.includeVat &&\n                                      translate(\n                                        'checkout.form.ordertotalexclvat',\n                                        cart.orderTotalWithoutVat\n                                      )}\n                                  </p>\n\n                                  <button\n                                    type=\"submit\"\n                                    className=\"checkout__submit-button\"\n                                  >\n                                    {translate(\n                                      'checkout.form.completepurchase'\n                                    )}\n                                  </button>\n                                </div>\n                              )}\n                            </>\n                          ) : (\n                            <div\n                              ref={iframeRef}\n                              id=\"checkout-container-div\"\n                            ></div>\n                          )}\n                        </>\n                      )}\n                    </>\n                  )}\n                </div>\n              </div>\n            </form>\n          </FormProvider>\n        </div>\n      </div>\n    </div>\n  );\n};\n\nexport default Checkout;\n"],"sourceRoot":""}