{"version":3,"sources":["apis/response.ts","apis/utils.ts","apis/auth.ts","apis/charges.ts","apis/configuration.ts","apis/customers.ts","apis/payLink.ts","apis/paymentSources.ts","store/types/customization.ts","store/types/global.ts","store/actions/splitio.ts","store/selectors/global.ts","store/selectors/number.ts","store/selectors/format.ts","store/selectors/authentication.ts","store/selectors/customizations.ts","store/selectors/paymentSources.ts","store/selectors/payLink.ts","store/selectors/index.ts","store/actions/attribution.ts","store/constants.ts","store/actions/authentication.ts","config.ts","store/actions/global.ts","store/actions/customer.ts","store/actions/payLink.ts","store/actions/charge.ts","store/actions/paymentSources.ts","store/actions/credit.ts","components/PortalRoute.tsx","message.ts","components/FormFeedback.tsx","components/VerificationCodeModal.tsx","components/NavMenu.tsx","components/Powered.tsx","components/Footer.tsx","components/Layout.tsx","components/PhoneNumberInput.tsx","components/MerchantImg.tsx","pages/LoginPage.tsx","components/dropin/AddPaymentSourceButton.tsx","components/StrongholdPay.tsx","components/Pagination.tsx","components/charge/ChargeStatusBadge.tsx","components/PlaceholderLoader.tsx","components/TableBody.tsx","components/charge/ChargesTable.tsx","components/SupportCard.tsx","components/ConfirmationModal.tsx","components/PaymentSourceActions.tsx","components/split/ToggleSplit.tsx","components/Merchant.tsx","components/NewPaymentSourceLinkedModal.tsx","pages/HomePage.tsx","pages/LinkAccountPage.tsx","pages/LogoutPage.tsx","components/dropin/AddChargeDropinButton.tsx","components/checkout/CheckoutTotal.tsx","components/NumberInput.tsx","components/TipSelection.tsx","components/TipMessage.tsx","components/dropin/PaymentAuthorizationAggreement.tsx","components/PaymentSourceList.tsx","components/PayLinkSuccessCard.tsx","components/PaymentSourceRequiredWarning.tsx","components/UploadedDocuments.tsx","components/checkout/OrderItem.tsx","pages/PayLink/CheckoutPage.tsx","pages/PayLink/BankLinkPage.tsx","components/dropin/AddTipDropinButton.tsx","pages/PayLink/TipPage.tsx","segment.ts","components/auth/SignupForm.tsx","pages/SignUpPage.tsx","pages/PayLink/PayLinkPage.tsx","pages/ErrorHandler.tsx","App.tsx","store/reducers/authentication.ts","store/reducers/global.ts","store/reducers/payLink.ts","store/reducers/charge.ts","store/reducers/paymentSources.ts","store/reducers/credit.ts","store/reducers/attribution.ts","store/index.ts","index.tsx","store/configureStore.ts"],"names":["ResponseErrorType","ResponseErrorCode","ResponseError","type","code","property","message","name","Error","request","config","a","token","localStorage","getItem","merge","headers","Authorization","axios","res","data","error","errorData","response","Unknown","resendVerificationToken","method","url","result","signup","verify","login","fetchMerchant","fetchProfile","CHARGE_STATUS","listCharges","options","query","stringify","limit","getConfiguration","get","getCustomerToken","addCustomer","payLinkId","customerId","deactivatePaymentSource","sourceId","CustomizationType","SPLIT_FLAG","fetchSplitTreatmentAction","flag","dispatch","getState","selectTreatmentValue","splitio","getTreatments","splitNames","fetchMerchantTreatmentsAction","merchant","sdkBrowserConfig","core","authorizationKey","global","configuration","split","api_key","key","id","initSplitSdk","Object","values","isActionRequesting","requests","status","find","el","isRequesting","getActionStatus","statuses","getResponseError","responseError","isPropertyError","propertyName","getErrorMessage","transform","InvalidField","length","MissingField","ValueTaken","getErrorCode","getActionError","actions","action","undefined","getTitle","state","display_name","headerTitle","join","separator","getPortalLink","merchantShortName","origin","replace","isMerchantRoute","window","location","match","getSplitFlagValue","flags","formattedFlag","SIMPLE_CHECKOUT","treatment","amountToString","amount","value","toFixed","getTipAmount","tipType","tipValue","originalAmount","Math","round","getAmountDetails","tipAmount","convenienceFee","processingFee","taxAmount","totalAmount","subAmount","creditValue","totalAmountWithFees","fullAmount","formatDateTimeMinutes","moment","format","formatDate","formatAmount","parseInt","toLocaleString","minimumFractionDigits","maximumFractionDigits","formatKB","size","getFullName","authenticationState","customer","individual","first_name","last_name","getCustomization","customizations","customization","CardType","getExitUrlCallback","payLink","callbacks","exit_url","getCallbackQuery","callback","getSuccessUrlCallback","callbackUrl","paymentSourceId","chargeId","tipId","success_url","paymentSources","paymentSourceSelected","charge","tip","parsed","parse","protocol","host","pathname","merchantQuery","search","querystring","mapKeys","obj","pay_link_id","pay_link_type","pay_link_callback","payment_source_id","charge_id","tip_id","getPaymentSourceSelected","arr","getTypeOfCard","provider","toLowerCase","Visa","MasterCard","DinersClub","AmericanExpress","selectors","number","authentication","setIntegrationIdAction","integrationId","payload","setApiVersionAction","apiVersion","isAuthenticatedAction","isAuthenticated","setTokenAction","save","setItem","removeItem","updateCustomerAction","loginAction","username","merchant_short_name","resetActionStatusAction","setActionRequestingAction","api","Promise","resolve","setTimeout","loadedSplits","treatments","showSimpleWorkflow","with_order_items","setActionResponseErrorAction","PayLinkExpired","setErrorMessageAction","PayLinkCanceled","MerchantSoftwareError","PaylinkChargeAmountModified","NotFound","InvalidApiKey","LiveNotApproved","InvalidChargeStatus","PayLinkMissingCharge","PayLinkMissingOrder","ServerError","link","integration_id","setPayLinkAction","version","CustomerRequired","api_version","setPaymentSourcesAction","payment_sources","filter","s","active","setCreditValueAction","available_credit","fetchChargesAction","resendTokenAction","mobile","email","authMethod","signupAction","date_of_birth","verifyAction","fetchProfileAction","logoutAction","api_environment","environment","stronghold_pay_host","sentry_dsn","analytics","getStrongholdPayClient","publishableKey","Stronghold","ROUTE","errorCode","updateHeaderTitleAction","headerPartial","fetchConfiguration","newConfiguration","Sentry","dsn","fetchCustomerTokenAction","updatePayLinkAction","setPayLinkCustomerAction","setChargesAction","list","body","addPaymentSourceAction","removePaymentSourceAction","selectPaymentSourceAction","deactivatePaymentSourceAction","isNewPaymentSourceLinkedAction","isNewPaymentSourceLinked","PortalRoute","ready","this","props","authenticate","setState","allowUnauthenticated","hasPaymentSource","hasCharge","paymentSourceRequired","to","href","React","withRouter","connect","items","bindActionCreators","MESSAGE","ERROR_COMMON_TITLE","ERROR_COMMON","CANCELED_LINK_TITLE","CANCELED_LINK","ORDER_NOT_FOUND_TITLE","ORDER_NOT_FOUND","ORDER_AMOUNT_MODIFIED_TITLE","ORDER_AMOUNT_MODIFIED","EXPIRED_LINK_TITLE","EXPIRED_LINK_SUB_TITLE","EXPIRED_LINK","PAYMENT_METHOD_SELECT_TITLE","PAYMENT_METHOD_CHANGE","PAYMENT_METHOD_NONE","PAYMENT_METHOD_NEEDED","ERROR_MERCHANT_SOFTWARE_TITLE","ERROR_MERCHANT_SOFTWARE","ERROR_INVALID_CONFIGURATION_TITLE","ERROR_INVALID_CONFIGURATION","ERROR_LIVE_NOT_APPROVED_TITLE","ERROR_LIVE_NOT_APPROVED","ERROR_USERNAME_NOT_FOUNT","identifier","ERROR_INCORRECT_CODE","CHECK_AND_TRY_AGAIN","SELECT_OR_ADD_TIP","INVALID_CHARGE_STATUS_TITLE","INVALID_CHARGE_STATUS","FormFeedback","InvalidCredentials","VerificationCodeModal","onToggle","onClose","onSubmit","event","preventDefault","onSuccess","show","isResending","Modal","isOpen","toggle","centered","ModalHeader","ModalBody","className","mask","placeholder","onChange","e","currentTarget","ref","input","inputElement","focus","responseErrorCode","ModalFooter","color","onClick","onResend","disabled","icon","faLongArrowAltRight","fixedWidth","NavMenu","merchantDisplayName","direction","outline","caret","faUserCircle","right","style","minWidth","divider","Powered","imgSrc","isBlack","src","alt","height","Footer","LayoutBreadcrumbs","isLastItem","index","listClassName","map","title","Layout","children","navbar","breadcrumbItems","footer","PhoneNumberInput","isInvalid","country","containerClass","inputProps","imageUrl","image_url","displayName","maxHeight","LoginPage","authenticationMethod","onLogin","short_name","showModal","reload","history","push","params","bind","paramsObject","slice","faMobileAlt","autoComplete","invalid","faAt","navToSignup","background","border","cursor","fontSize","padding","linkCustomer","AddPaymentSourceButton","paymentSource","customerToken","addPaymentSource","payLinkCode","onExit","onReady","isRequestingCustomerToken","addSourcesAction","showAsLink","iconColor","iconClass","faUniversity","isLoading","isDisabled","data-sh","publishableApiKey","attribution","marginTop","getPageSkip","page","Pagination","skipped","total","currentPage","floor","getCurrentPage","paginationInfo","Paginator","build","getPaginationInfo","lastPageSkip","total_pages","previousBigStep","current_page","has","hasPagesLeft","first_page","skip","getPreviousBigStep","nextBigStep","last_page","getNextBigStep","pages","i","first","last","has_next_page","ChargeStatusBadge","textColor","text","pill","PlaceholderLoader","width","TableBody","rows","row","columns","col","ChargesTable","hasNoRows","charges","renderNoRows","noRowsComponent","hover","responsive","chargesLimit","created_at","chargesTotal","chargesSkipped","onGoTo","SupportCard","faLifeRing","ConfirmationModal","formatErrorMessage","spinner","PaymentSourceActions","onActionClick","toggleModal","paymentSourcesToDelete","item","unique_hash","forEach","errorMessage","ToggleSplit","componentDidMount","unactiveComponent","street_location","street1","street2","street3","city","postcode","NewPaymentSourceLinkedModal","HomePage","fetchCharges","lg","faIdCard","xs","fullName","uniqBy","label","faReceipt","LinkAccountPage","maxWidth","LogoutPage","AddChargeDropinButton","skipSuccessScreen","skipPayScreen","beneficiaryName","tipBeneficiaryName","onError","updatePaymentMethod","updatePaymentSource","ERROR_CODE","PAYMENT_SOURCE_LOGIN_REQUIRED","PAYMENT_SOURCE_INACTIVE","payAmount","creditAmount","isAuthorizingPayment","noSource","paymentSourceLabel","subButtonElement","faMoneyBill","CheckoutTotal","amountDetails","taxAmountStr","convenienceFeeStr","subAmountStr","tipAmountStr","creditAmountStr","fullAmountStr","VALID_FIRST","VALID_NEXT","NumberInput","handleKeyDown","max","onValueChange","keyCode","blur","test","nextValue","valueString","toString","nextValueString","Number","valueDisplay","pow","digits","prefix","suffix","trunc","abs","isFinite","isNaN","inputMode","onKeyDown","Component","TipSelection","tipInput","selectTip","getAmount","onSetAmount","toggleAmountField","tips","tipAmounts","showAmountField","includes","setDefaultValueOnChange","tipModel","value1","value2","value3","isPercentage","tipAmount1","innerRef","isPercent","tipSubValue","renderTipButton","TipMessage","tipData","orderAmount","orderCreatedAt","forOrder","budtender","display","justifyContent","alignItems","textAlign","details","display_message","originalAmountStr","PaymentAuthorizationAggreement","amountStr","PaymentSourceList","onSelectPaymentSource","onSelect","renderCardTypeIcon","faCcVisa","faCcMastercard","faCcAmex","faCcDinersClub","buttonText","buttonIconColor","canAddPaymentSource","flush","buttonColor","content","provider_name","selectable","check","checked","readOnly","stopPropagation","button","PayLinkSuccessCard","updateProgressBar","successUrlCallback","progressEnabled","progress","redirecting","setInterval","merchantName","faCheck","striped","animated","PaymentSourceRequiredWarning","UploadedDocuments","order","documents","document","file_name","file_size","download","target","rel","OrderItem","total_amount","price","description","quantity","faImage","CheckoutPage","orderSummary","continueButton","onScroll","isFirstButtonInViewport","isEndButtonInViewport","showSticky","top","getBoundingClientRect","innerHeight","offset","scrollToPayment","scrollTo","convenience_fee","payment_processing_fee","tax_amount","sub_amount","renderQuickPay","totalAmountWithTip","renderItems","ListGroup","ListGroupItem","renderPaymentMethod","header","renderTip","hasTipError","renderPdf","renderTotal","payment","beneficiary_name","block","renderSuccessMsg","success_msg","fileList","addEventListener","removeEventListener","ownProps","SuccessScreen","credits","BankLinkPage","isUsed","paymentMethods","source","AddTipDropinButton","TipPage","getAmountStr","renderOrderDetails","tipCustomization","displayMessage","drawerId","drawer_id","terminalId","terminal_id","SignupForm","toggleAuthMethod","show_sms","dobRaw","tryLogin","isMobile","resend","onSignup","resetForm","fn","noValidate","placeholderText","selected","wrapperClassName","dateFormat","showYearDropdown","scrollableYearDropdown","yearDropdownItemNumber","showMonthDropdown","scrollableMonthYearDropdown","maxDate","add","toDate","calendarClassName","popperClassName","dayClassName","date","inline","lineHeight","SignUpPage","next","step","previous","onLinkSuccess","faCircle","classes","faDotCircle","faCircleRegular","steps","borderRadius","navToLogin","textDecoration","noGutters","getStep","PayLinkPage","navigateToLogin","navigateToSignup","loaded","exitUrlCallback","borderWidth","payLinkPage","exit","faArrowLeft","ErrorHandler","reloadPage","subTitle","faRedo","App","prevProps","analyticsWriteKey","load","configurationStatus","Helmet","path","component","write_key","identify","userid","unloadedState","clone","legal_name","ENVIRONMENT","live","publishable","last_used_at","unloadedActionStatusState","reducers","updated","segment","unionBy","publishable_api_key","tmp","api_keys","LOCATION_CHANGE","splitReducer","baseUrl","getElementsByTagName","getAttribute","createBrowserHistory","basename","store","initialState","middleware","thunk","routerMiddleware","rootReducer","combineReducers","router","connectRouter","enhancers","windowIfDefined","__REDUX_DEVTOOLS_EXTENSION__","createStore","compose","applyMiddleware","configureStore","ReactDOM","getElementById"],"mappings":"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","file":"static/js/main.2fce454a.chunk.js","sourcesContent":["export enum ResponseErrorType {\n    Unknown = 'unknown',\n    ValidationError = 'validation_error',\n}\n\nexport enum ResponseErrorCode {\n    // =========================\n    // Portal\n    Unknown = 'unknown',\n    InvalidCredentials = 'invalid_credentials',\n\n    // =========================\n    // Pay API errors\n\n    // Api error\n    ServerError = 'server_error',\n    ConnectionError = 'connection_error',\n\n    // Merchant software error\n    MerchantSoftwareError = 'merchant_software_error',\n\n    // Authentication error\n    InvalidApiKey = 'invalid_api_key',\n    ForbiddenResource = 'forbidden_resource',\n    InvalidAccessToken = 'invalid_access_token',\n    LiveNotApproved = 'live_not_approved',\n\n    // Invalid request\n    NotFound = 'not_found',\n    InvalidId = 'invalid_id',\n    TicketNotFound = 'ticket_not_found',\n    DispensaryNotFound = 'dispensary_not_found',\n    SandboxOnly = 'sandbox_only',\n\n    // Object error\n    InvalidOperation = 'invalid_operation',\n    PaymentSourceAlreadyExists = 'payment_source_already_exists',\n    PaymentSourceLoginRequired = 'payment_source_login_required',\n    PaymentSourceUnavailable = 'payment_source_unavailable',\n    InsufficientBalance = 'insufficient_balance',\n    CustomerBlocked = 'customer_blocked',\n    PayLinkCanceled = 'pay_link_canceled',\n    PayLinkExpired = 'pay_link_expired',\n    PaylinkChargeAmountModified = 'paylink_charge_amount_modified',\n    PayLinkChargeAlreadyPaid = 'pay_link_charge_already_paid',\n    CustomerRequired = 'customer_required',\n    InvalidChargeStatus = 'invalid_charge_status',\n    PayLinkMissingCharge = 'paylink_missing_charge',\n    PayLinkMissingOrder = 'paylink_missing_order',\n\n    // Validation error\n    MissingField = 'missing_field',\n    InvalidField = 'invalid_field',\n    ValueTaken = 'value_taken',\n}\n\nexport interface PortalResponseError {\n    type: string;\n    code: string;\n    property: string | null;\n    message: string | null;\n}\n\nexport class ResponseError extends Error implements PortalResponseError {\n    type: ResponseErrorType;\n    code: ResponseErrorCode;\n    property: string | null;\n    message: string;\n\n    public constructor(\n        type: ResponseErrorType,\n        code: ResponseErrorCode,\n        property: string | null = null,\n        message: string,\n    ) {\n        super(`${type}: ${code}, ${property}`);\n        this.name = 'ResponseError';\n        this.type = type;\n        this.code = code;\n        this.property = property;\n        this.message = message;\n    }\n}\n\nexport interface PortalResponse<T> {\n    result: T;\n}\n\nexport interface ListSegment<T> {\n    total: number;\n    limit: number;\n    skipped: number;\n    items: T[];\n}\n\nexport interface PortalResponseFailed {\n    error: PortalResponseError | null;\n}\n","import axios, { AxiosError, AxiosRequestConfig } from 'axios';\nimport { PortalResponse, PortalResponseFailed, ResponseError, ResponseErrorCode, ResponseErrorType } from './response';\nimport { merge } from 'lodash';\n\nexport const segmentListLimit = 20;\n\nexport type RequestConfig = AxiosRequestConfig;\n\nexport async function request<T>(config: RequestConfig): Promise<PortalResponse<T>> {\n    const token = localStorage.getItem('token');\n    if (token) {\n        config = merge(config, {\n            headers: { Authorization: `Bearer ${token}` },\n        });\n    }\n\n    try {\n        const res = await axios.request(config);\n        return res.data;\n    } catch (e) {\n        const error = e as AxiosError<PortalResponseFailed>;\n        const errorData = error && error.response && error.response.data.error;\n        if (!errorData)\n            throw new ResponseError(\n                ResponseErrorType.Unknown,\n                ResponseErrorCode.Unknown,\n                null,\n                'Something went wrong.',\n            );\n        throw new ResponseError(\n            errorData.type as ResponseErrorType,\n            errorData.code as ResponseErrorCode,\n            errorData.property,\n            errorData.message ?? '',\n        );\n    }\n}\n","import { request } from './utils';\nimport { DeepPartial } from 'redux';\nimport { PayLinkModel } from './payLink';\nimport { PaymentSource } from '@stronghold/pay-dropin';\nimport { MerchantModel } from './types';\n\nexport type AuthenticationMethod = 'sms' | 'email' | 'link';\n\nexport interface AuthenticationModel {\n    method: AuthenticationMethod;\n}\n\nexport interface CustomerIndividualDetails {\n    email: string | null;\n    mobile: string | null;\n    first_name: string | null;\n    last_name: string | null;\n    date_of_birth: string | null;\n}\n\nexport interface CustomerModel {\n    id: string | null;\n    country: string | null;\n    state: string | null;\n    individual: CustomerIndividualDetails;\n    payment_sources: PaymentSource[];\n}\n\nexport interface SignupRequestModel {\n    authentication: AuthenticationModel;\n    customer: DeepPartial<CustomerModel>;\n    merchant_short_name?: string;\n}\n\nexport interface LoginRequestModel {\n    authentication: AuthenticationModel;\n    username: string;\n    with_order_items?: boolean;\n    merchant_short_name?: string;\n}\n\nexport interface ProfileResponseModel {\n    customer: CustomerModel;\n}\n\nexport interface VerifyRequestModel {\n    token: string;\n    code: string;\n}\n\nexport interface LoginResponseModel {\n    authentication: AuthenticationModel;\n    token: string;\n    customer: CustomerModel;\n    link?: PayLinkModel;\n}\n\nexport interface SignupResponseModel {\n    authentication: AuthenticationModel;\n    token: string;\n    customer: CustomerModel;\n}\n\nexport async function resendVerificationToken(data: SignupRequestModel) {\n    const res = await request<SignupResponseModel>({\n        method: 'POST',\n        url: '/api/auth/resend',\n        data,\n    });\n    return res.result;\n}\n\nexport async function signup(data: SignupRequestModel) {\n    const res = await request<SignupResponseModel>({\n        method: 'POST',\n        url: '/api/auth/signup',\n        data,\n    });\n    return res.result;\n}\n\nexport async function verify(data: VerifyRequestModel) {\n    const res = await request<VerifyRequestModel>({\n        method: 'POST',\n        url: '/api/auth/verify',\n        data,\n    });\n    return res.result;\n}\n\nexport async function login(data: LoginRequestModel) {\n    const res = await request<LoginResponseModel>({\n        method: 'POST',\n        url: '/api/auth/login',\n        data,\n    });\n\n    return res.result;\n}\n\nexport async function fetchMerchant(code: string) {\n    const res = await request<MerchantModel>({\n        method: 'GET',\n        url: `/api/auth/merchant/${code}`,\n    });\n\n    return res.result;\n}\n\nexport async function fetchProfile() {\n    const res = await request<ProfileResponseModel>({\n        method: 'GET',\n        url: '/api/auth/profile',\n    });\n    return res.result;\n}\n","import { request, segmentListLimit } from './utils';\nimport { ListSegment } from './response';\nimport { stringify } from 'querystring';\n\nexport enum CHARGE_STATUS {\n    CREATED = 'created',\n    AUTHORIZED = 'authorized',\n    CAPTURED = 'captured',\n    CANCELED = 'canceled',\n    ATTEMPTING_COLLECTION = 'attempting_collection',\n    CAPTURE_FAILED = 'capture_failed',\n    DISPUTED = 'disputed',\n    REFUND_PENDING = 'refund_pending',\n    REFUNDED = 'refunded',\n    STOPPED_COLLECTION = 'stopped_collection',\n}\n\nexport interface ChargeModel {\n    id: string;\n    type: 'bank_debit' | 'bank_debit_cnp';\n    status: CHARGE_STATUS;\n    merchant_convenience_fee: number;\n    fee: number;\n    amount: number;\n    currency: string;\n    customer_id: string;\n    payment_source_id: string;\n    external_id: string | null;\n    created_at: string;\n    authorized_at: string | null;\n    captured_at: string | null;\n    convenience_fee: number | null;\n    payment_processing_fee: number | null;\n}\n\nexport async function listCharges(\n    options: {\n        skip?: number;\n        limit?: number;\n        customerId?: string;\n        status?: string[];\n        from?: string;\n        to?: string;\n        search?: string;\n    } = {},\n) {\n    const query = stringify({\n        limit: segmentListLimit,\n        ...options,\n    });\n\n    const res = await request<ListSegment<ChargeModel>>({\n        method: 'GET',\n        url: `/api/customers/charges?${query}`,\n    });\n    return res.result;\n}\n","import axios from 'axios';\nimport { PortalResponse } from './response';\nimport { ApiKeyModel, Environment, MerchantModel } from './types';\n\nexport interface ConfigurationModel {\n    api_environment: 'live' | 'sandbox';\n    environment: Environment;\n    merchant?: MerchantModel;\n    publishable_api_key?: ApiKeyModel;\n    stronghold_pay_host: string;\n    sentry_dsn: string;\n    analytics: {\n        write_key?: string;\n        environment: 'Development' | 'Sandbox' | 'Live';\n    };\n    split: {\n        api_key: string;\n    };\n    integration_id: string;\n    api_version: string;\n}\n\nexport async function getConfiguration() {\n    const res = await axios.get<PortalResponse<ConfigurationModel>>('/api/configuration');\n    return res.data.result;\n}\n","import { TokenModel } from '../store/types';\nimport { request } from './utils';\n\nexport async function getCustomerToken() {\n    const res = await request<TokenModel>({\n        method: 'GET',\n        url: '/api/customers/token',\n    });\n    return res.result;\n}\n","import { CustomerModel } from './auth';\nimport { MerchantModel, OrderItemModel, ApiKeyModel } from './types';\nimport { ENVIRONMENT, Charge, Tip } from '@stronghold/pay-dropin';\nimport { DeepPartial } from 'redux';\nimport { request } from './utils';\n\nexport type PayLinkType = 'checkout' | 'bank_link' | 'tipping';\nexport type PayLinkStatus = 'created' | 'used';\n\nexport interface PayLinkTipModel extends DeepPartial<Tip> {\n    beneficiary_name: string;\n    details: {\n        display_message?: string;\n        drawer_id?: string;\n        terminal_id?: string;\n    };\n}\n\nexport interface PayLinkOrderModel {\n    sub_amount: number;\n    total_amount: number;\n    tax_amount: number;\n    convenience_fee: number;\n    payment_processing_fee: number;\n    items: OrderItemModel[];\n    documents: PayLinkOrderDocumentModel[];\n}\n\nexport interface PayLinkOrderDocumentModel {\n    url: string;\n    file_name: string;\n    file_size: number;\n}\n\nexport interface PayLinkModel {\n    id: string;\n    created_at: string;\n    expires_at: string;\n    type: PayLinkType;\n    customer: CustomerModel;\n    environment: ENVIRONMENT;\n    status: PayLinkStatus;\n    charge?: Charge;\n    tip?: PayLinkTipModel | Tip;\n    order?: PayLinkOrderModel;\n    callbacks?: {\n        success_url: string;\n        exit_url: string;\n    };\n    // Internal pay link\n    api_keys: { publishable: ApiKeyModel };\n    merchant: MerchantModel;\n    available_credit: number;\n    integration_id: string;\n    version: string;\n}\n\nexport async function addCustomer(payLinkId: string, customerId: string) {\n    const res = await request<PayLinkModel>({\n        method: 'PUT',\n        url: '/api/links/' + payLinkId + '/customer/' + customerId,\n    });\n    return res.result;\n}\n","import { request } from './utils';\nimport { ListSegment } from './response';\nimport { PaymentSource } from '@stronghold/pay-dropin';\n\nexport async function fetchPaymentSources() {\n    const res = await request<ListSegment<PaymentSource>>({\n        method: 'GET',\n        url: `/api/payment-sources`,\n    });\n    return res.result;\n}\n\nexport async function deactivatePaymentSource(sourceId: string) {\n    const res = await request<PaymentSource>({\n        method: 'DELETE',\n        url: `/api/payment-sources/${sourceId}`,\n    });\n    return res.result;\n}\n","export type TipType = 'percentage' | 'fixed';\n\nexport enum CustomizationType {\n    SuccessScreen = 'portal::checkout:success_text/v1',\n}\n\nexport interface TipCustomizationModel {\n    type: TipType;\n    value1: number;\n    value2: number;\n    value3: number;\n}\n\nexport interface Customization {\n    data: string;\n    type: CustomizationType;\n}\n\nexport interface CustomizationModel {\n    tip: TipCustomizationModel;\n    items: Customization[];\n}\n","// -----------------\n// STATE - This defines the type of data maintained in the Redux store.\n\nimport { ResponseError, ResponseErrorCode } from '../../apis';\nimport { ApiKeyModel, ConfigurationModel, MerchantModel } from '../../apis';\n\nexport type ActionName =\n    | 'login'\n    | 'signup'\n    | 'verify'\n    | 'error'\n    | 'set_error_message'\n    | 'authenticate'\n    | 'fetch_api_keys'\n    | 'fetch_charges'\n    | 'fetch_configuration'\n    | 'fetch_payouts'\n    | 'fetch_transactions'\n    | 'fetch_customer_token'\n    | 'fetch_customer_sources'\n    | 'authorize_payment'\n    | 'fetch_pay_link'\n    | 'update_payment_source'\n    | 'fetch_payment_sources'\n    | 'set_pay_link_customer';\n\nexport interface ActionStatus {\n    name: ActionName;\n    isRequesting: boolean;\n    responseError?: ResponseError;\n}\n\nexport interface HeaderTitle {\n    separator: string;\n    values: string[];\n}\n\n// Split\nexport enum SPLIT_FLAG {\n    SIMPLE_CHECKOUT = 'Simple_Checkout',\n}\n\nexport type ConfigurationStatus = 'unloaded' | 'loaded' | 'error';\n\nexport interface GlobalState {\n    actions: ActionStatus[];\n    configuration: ConfigurationModel;\n    configurationStatus: ConfigurationStatus;\n    error: {\n        errorCode: ResponseErrorCode | null;\n        show: boolean;\n    };\n    headerTitle: HeaderTitle;\n    publishableApiKey: ApiKeyModel;\n    merchant: MerchantModel;\n}\n","import { AppThunkAction } from '../index';\nimport { ApplicationAction } from './index';\nimport { MerchantModel } from '../../apis';\nimport { initSplitSdk, selectTreatmentValue } from '@splitsoftware/splitio-redux';\nimport { getTreatments } from '@splitsoftware/splitio-redux';\nimport { SPLIT_FLAG } from '../types';\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n\nexport function fetchSplitTreatmentAction(flag: string): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        // If treatment already in the list, return directly\n        if (selectTreatmentValue(getState().splitio, flag)) {\n            return;\n        }\n\n        await getTreatments({ splitNames: [flag] });\n    };\n}\n\nexport function fetchMerchantTreatmentsAction(merchant: MerchantModel): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        // fetch splits\n        // each environment has its own api-key can be found on the admin settings page app.split.io\n        const sdkBrowserConfig = {\n            core: {\n                authorizationKey: getState().global.configuration.split.api_key,\n                key: merchant.id,\n            },\n        };\n\n        dispatch(initSplitSdk({ config: sdkBrowserConfig }) as unknown as ApplicationAction);\n        dispatch(getTreatments({ splitNames: Object.values(SPLIT_FLAG) }) as unknown as ApplicationAction);\n    };\n}\n","import { ActionName, ActionStatus, GlobalState, SPLIT_FLAG } from '../types';\nimport { ResponseError, ResponseErrorCode } from '../../apis';\nimport { ISplitTreatments } from '@splitsoftware/splitio-redux/lib/types';\n\nexport function isActionRequesting(requests: ActionStatus[], name: ActionName): boolean {\n    const status = requests.find((el) => el.name === name);\n    if (!status) return false;\n    return status.isRequesting;\n}\n\nexport function getActionStatus(statuses: ActionStatus[], name: ActionName) {\n    return statuses.find((el) => el.name === name);\n}\n\nexport function getResponseError(statuses: ActionStatus[], name: ActionName) {\n    const status = getActionStatus(statuses, name);\n    if (!status) return null;\n    return status.responseError || null;\n}\n\nexport function isPropertyError(propertyName: string | null, error: ResponseError | null) {\n    return (error && error.property === propertyName) || false;\n}\n\nexport interface GetErrorMessageOptions {\n    transform?: (responseErrorCode: ResponseErrorCode) => string | undefined;\n}\n\nexport function getErrorMessage(error: ResponseError | null, options: GetErrorMessageOptions = {}) {\n    if (!error) return null;\n\n    if (options.transform) {\n        const result = options.transform(error.code);\n        if (result) {\n            return result;\n        }\n    }\n\n    switch (error.code) {\n        case ResponseErrorCode.InvalidField:\n            return error.message == null || error.message.length == 0 ? 'Value is not valid.' : error.message;\n        case ResponseErrorCode.MissingField:\n            return 'Value is required.';\n        case ResponseErrorCode.ValueTaken:\n            return 'Value is already taken.';\n        default:\n            return 'Something went wrong. Please try again.';\n    }\n}\n\nexport function getErrorCode(error: ResponseError | null) {\n    return error && error.code;\n}\n\nexport const getActionError = (name: ActionName, actions: ActionStatus[]) => {\n    const action = getActionStatus(actions, name);\n    return action ? action.responseError : undefined;\n};\n\nexport function getTitle(state: GlobalState): string {\n    let result = (state.merchant && state.merchant.display_name) || 'Stronghold';\n    const headerTitle = state.headerTitle;\n    if (headerTitle.values.length > 0) {\n        result = [...headerTitle.values, result].join(` ${headerTitle.separator} `);\n    }\n    return result;\n}\n\nexport function getPortalLink(merchantShortName: string, origin: string): string {\n    origin = origin.replace('strongholdpay', 'onstrongholdpay');\n    origin = origin.replace('://sandbox', `://${merchantShortName}-sandbox`);\n    origin = origin.replace('://development', `://${merchantShortName}-development`);\n    origin = origin.replace('://staging', `://${merchantShortName}-staging`);\n    origin = origin.replace('://onstrongholdpay', `://${merchantShortName}.onstrongholdpay`);\n\n    return origin;\n}\n\nexport function isMerchantRoute() {\n    const regex = /\\/\\/(sandbox)?((-)?staging|(-)?development)?(\\.)?((on)?strongholdpay)/gm;\n\n    return !window.location.origin.match(regex);\n}\n\n/**\n * This function set the default value for the flag\n * TODO: See if the return type is something else than a boolean, we could type the flags directly\n * @param name\n * @param flags\n */\nexport function getSplitFlagValue(name: SPLIT_FLAG, flags: ISplitTreatments): boolean {\n    flags = flags || {};\n    const formattedFlag = flags[SPLIT_FLAG.SIMPLE_CHECKOUT];\n    const treatment = Object.values(formattedFlag)[0].treatment;\n    switch (name) {\n        case SPLIT_FLAG.SIMPLE_CHECKOUT:\n            return treatment === 'on' ? true : false;\n        default:\n            throw new Error('Not implemented flag value');\n    }\n}\n","import { TipType } from '../types';\n\nexport function amountToString(amount: number | null) {\n    const value = ((amount || 0) / 100).toFixed(2);\n\n    return `$${value}`;\n}\n\nexport function getTipAmount(tipType: TipType, tipValue: number, originalAmount: number) {\n    // If fixed amount, return the value directly\n    if (tipType === 'fixed') {\n        return tipValue;\n    }\n\n    // Percent\n    else if (tipType === 'percentage') {\n        return Math.round((originalAmount * tipValue) / 10000);\n    }\n\n    throw new Error(`Tip type ${tipType} not implemented`);\n}\n\nexport function getAmountDetails(data: {\n    subAmount: number;\n    totalAmount: number;\n    taxAmount: number;\n    convenienceFee?: number;\n    processingFee?: number;\n    tipAmount?: number;\n    tipType: TipType;\n    creditValue?: number;\n}) {\n    const {\n        tipType,\n        tipAmount = 0,\n        convenienceFee = 0,\n        processingFee = 0,\n        taxAmount,\n        totalAmount,\n        subAmount,\n        creditValue = 0,\n    } = data;\n\n    const totalAmountWithFees = totalAmount + convenienceFee;\n    const fullAmount = totalAmountWithFees + tipAmount + processingFee - creditValue;\n\n    return {\n        totalAmount,\n        taxAmount,\n        convenienceFee,\n        processingFee,\n        subAmount,\n        tipAmount,\n        tipType,\n        totalAmountWithFees,\n        // Prevent charge amount going below zero\n        fullAmount: fullAmount > 0 ? fullAmount : 0,\n        creditValue: creditValue,\n    };\n}\n","import moment from 'moment';\n\n// Date\nexport const formatDateTimeMinutes = (value: string | null) => (value ? moment(value).format('MMM DD h:mm a') : null);\nexport const formatDate = (value: string | null) => (value ? moment(value).format('MMM DD') : null);\n\n// Currency\nexport function formatAmount(amount: number | string) {\n    const num = typeof amount === 'string' ? parseInt(amount) : amount;\n    const value = ((num || 0) / 100).toLocaleString('en-US', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n    return `$${value}`;\n}\n\n// Bytes\nexport function formatKB(size: number) {\n    return Math.round(size / 1024).toFixed(2);\n}\n","import { AuthenticationState } from '../types';\n\nexport function getFullName(authenticationState: AuthenticationState) {\n    return `${authenticationState.customer.individual.first_name} ${authenticationState.customer.individual.last_name}`;\n}\n","import { CustomizationType, Customization } from '../types';\n\nexport function getCustomization(customizations: Customization[], type: CustomizationType) {\n    const customization = customizations.find((el) => el.type === type);\n    if (!customization) return null;\n    return customization.data;\n}\n","import { ApplicationState } from '../index';\n\nexport enum CardType {\n    Visa = 'visa',\n    MasterCard = 'mastercard',\n    AmericanExpress = 'amex',\n    DinersClub = 'dinersclub',\n}\n\nexport function getPaymentSourceSelected(state: ApplicationState) {\n    return state.paymentSources.arr.find((el) => el.id === state.paymentSources.paymentSourceSelected) || null;\n}\n\nexport function getTypeOfCard(provider: string): CardType | undefined {\n    switch (provider.toLowerCase()) {\n        case 'visa':\n            return CardType.Visa;\n        case 'mastercard':\n            return CardType.MasterCard;\n        case 'dinersclub':\n            return CardType.DinersClub;\n        case 'amex':\n            return CardType.AmericanExpress;\n    }\n}\n","import { PayLinkCallback } from '../types';\nimport querystring from 'querystring';\nimport url from 'url';\nimport { mapKeys } from 'lodash';\nimport { ApplicationState } from '../index';\n\nexport function getExitUrlCallback(state: ApplicationState) {\n    if (!state.payLink.data) {\n        return null;\n    }\n    const payLink = state.payLink.data;\n    if (!payLink.callbacks || !payLink.callbacks.exit_url) {\n        return null;\n    }\n\n    return getCallbackQuery(state, { callback: 'exit' });\n}\n\nexport function getSuccessUrlCallback(state: ApplicationState) {\n    if (!state.payLink.data) {\n        return null;\n    }\n    const payLink = state.payLink.data;\n    if (!payLink.callbacks || !payLink.callbacks.exit_url || payLink.status === 'created') {\n        return null;\n    }\n\n    return getCallbackQuery(state, { callback: 'success' });\n}\n\nexport function getCallbackQuery(state: ApplicationState, options: { callback: PayLinkCallback }) {\n    if (!state.payLink.data) {\n        throw new Error('No PayLink to get the callback query from.');\n    }\n    const payLink = state.payLink.data;\n\n    if (!payLink.callbacks) {\n        throw new Error('PayLink is not compatible with the callbacks feature.');\n    }\n    const callbacks = payLink.callbacks;\n\n    const { callback } = options;\n    let callbackUrl: string;\n\n    let paymentSourceId: string | undefined;\n    let chargeId: string | undefined;\n    let tipId: string | undefined;\n    if (callback === 'success') {\n        callbackUrl = callbacks.success_url;\n        paymentSourceId = state.paymentSources.paymentSourceSelected || undefined;\n        chargeId = payLink.charge?.id;\n        tipId = payLink.tip?.id;\n    } else {\n        callbackUrl = callbacks.exit_url;\n    }\n\n    const parsed = url.parse(callbackUrl);\n    let result = `${parsed.protocol}//${parsed.host}${parsed.pathname}`;\n    let merchantQuery = parsed.search ? querystring.parse(parsed.search.replace(/^(\\?)/i, '')) : {};\n    merchantQuery = mapKeys(merchantQuery, (value, key) => `custom_${key}`);\n    const obj = {\n        ...merchantQuery,\n        pay_link_id: payLink.id,\n        pay_link_type: payLink.type,\n        pay_link_callback: callback,\n        payment_source_id: paymentSourceId,\n        charge_id: chargeId,\n        tip_id: tipId,\n    };\n\n    const query = querystring.stringify(obj);\n    result += `?${query}`;\n    return result;\n}\n","import * as global from './global';\nimport * as number from './number';\nimport * as format from './format';\nimport * as authentication from './authentication';\nimport * as customizations from './customizations';\nimport * as payLink from './payLink';\nimport * as paymentSources from './paymentSources';\n\nconst selectors = {\n    global,\n    number,\n    authentication,\n    customizations,\n    format,\n    payLink,\n    paymentSources,\n};\n\nexport default selectors;\n","import { SET_INTEGRATION_ID, SET_API_VERSION } from '../constants';\n\nexport interface SetIntegrationIdAction {\n    type: SET_INTEGRATION_ID;\n    payload: {\n        integrationId: string;\n    };\n}\n\nexport const setIntegrationIdAction = (integrationId: string): SetIntegrationIdAction => ({\n    type: SET_INTEGRATION_ID,\n    payload: {\n        integrationId: integrationId,\n    },\n});\n\nexport interface SetApiVersionAction {\n    type: SET_API_VERSION;\n    payload: {\n        apiVersion: string;\n    };\n}\n\nexport const setApiVersionAction = (apiVersion: string): SetApiVersionAction => ({\n    type: SET_API_VERSION,\n    payload: {\n        apiVersion: apiVersion,\n    },\n});\n\nexport type AttributionAction = SetIntegrationIdAction | SetApiVersionAction;\n","export const SET_ACTION_REQUEST_STATUS = 'SET_ACTION_REQUEST_STATUS';\nexport type SET_ACTION_REQUEST_STATUS = typeof SET_ACTION_REQUEST_STATUS;\nexport const SET_ACTION_RESPONSE_ERROR = 'SET_ACTION_RESPONSE_ERROR';\nexport type SET_ACTION_RESPONSE_ERROR = typeof SET_ACTION_RESPONSE_ERROR;\nexport const SET_ERROR_MESSAGE = 'SET_ERROR_MESSAGE';\nexport type SET_ERROR_MESSAGE = typeof SET_ERROR_MESSAGE;\nexport const RESET_ACTION_STATUS = 'RESET_ACTION_STATUS';\nexport type RESET_ACTION_STATUS = typeof RESET_ACTION_STATUS;\nexport const SET_CONFIGURATION = 'SET_CONFIGURATION';\nexport type SET_CONFIGURATION = typeof SET_CONFIGURATION;\nexport const SET_CONFIGURATION_STATUS = 'SET_CONFIGURATION_STATUS';\nexport type SET_CONFIGURATION_STATUS = typeof SET_CONFIGURATION_STATUS;\nexport const UPDATE_HEADER_TITLE = 'UPDATE_HEADER_TITLE';\nexport type UPDATE_HEADER_TITLE = typeof UPDATE_HEADER_TITLE;\nexport const LOCATION_CHANGE = '@@router/LOCATION_CHANGE';\nexport type LOCATION_CHANGE = typeof LOCATION_CHANGE;\n\n// Authentication\nexport const SET_TOKEN = 'SET_TOKEN';\nexport type SET_TOKEN = typeof SET_TOKEN;\nexport const IS_AUTHENTICATED = 'IS_AUTHENTICATED';\nexport type IS_AUTHENTICATED = typeof IS_AUTHENTICATED;\nexport const UPDATE_CUSTOMER = 'UPDATE_CUSTOMER';\nexport type UPDATE_CUSTOMER = typeof UPDATE_CUSTOMER;\n\n// Payment sources\nexport const ADD_PAYMENT_SOURCE = 'ADD_PAYMENT_SOURCE';\nexport const SET_PAYMENT_SOURCES = 'SET_PAYMENT_SOURCES';\nexport const UPDATE_PAYMENT_SOURCE = 'UPDATE_PAYMENT_SOURCE';\nexport const REMOVE_PAYMENT_SOURCE = 'REMOVE_PAYMENT_SOURCE';\nexport const SELECT_PAYMENT_SOURCE = 'SELECT_PAYMENT_SOURCE';\nexport const IS_NEW_PAYMENT_SOURCE_LINKED = 'IS_NEW_PAYMENT_SOURCE_LINKED';\n\n// Pay Link\nexport const SET_PAY_LINK = 'SET_PAY_LINK';\nexport type SET_PAY_LINK = typeof SET_PAY_LINK;\nexport const UPDATE_PAY_LINK = 'UPDATE_PAY_LINK';\n\nexport const SET_PAY_LINK_CUSTOMER = 'SET_PAY_LINK_CUSTOMER';\nexport type SET_PAY_LINK_CUSTOMER = typeof SET_PAY_LINK_CUSTOMER;\n\n// Customer\nexport const SET_CUSTOMER_TOKEN = 'SET_CUSTOMER_TOKEN';\nexport type SET_CUSTOMER_TOKEN = typeof SET_CUSTOMER_TOKEN;\n\n// Charges\nexport const SET_CHARGES = 'SET_CHARGES';\nexport type SET_CHARGES = typeof SET_CHARGES;\nexport const CLEAN_CHARGES = 'CLEAN_CHARGES';\nexport type CLEAN_CHARGES = typeof CLEAN_CHARGES;\n\n// Credits\nexport const SET_CREDIT_VALUE = 'SET_CREDIT_VALUE';\nexport type SET_CREDIT_VALUE = typeof SET_CREDIT_VALUE;\n\n// Attribution\nexport const SET_INTEGRATION_ID = 'SET_INTEGRATION_ID';\nexport type SET_INTEGRATION_ID = typeof SET_INTEGRATION_ID;\nexport const SET_API_VERSION = 'SET_API_VERSION';\nexport type SET_API_VERSION = typeof SET_API_VERSION;\n","import { IS_AUTHENTICATED, SET_TOKEN, UPDATE_CUSTOMER } from '../constants';\nimport { AppThunkAction } from '../index';\nimport {\n    ApplicationAction,\n    fetchChargesAction,\n    resetActionStatusAction,\n    setActionRequestingAction,\n    setActionResponseErrorAction,\n    setCreditValueAction,\n    setErrorMessageAction,\n    setPayLinkAction,\n    setPaymentSourcesAction,\n} from './index';\nimport * as api from '../../apis';\nimport { AuthenticationMethod, CustomerModel, LoginResponseModel, ResponseError, ResponseErrorCode } from '../../apis';\nimport { DeepPartial } from 'redux';\nimport { fetchMerchantTreatmentsAction } from './splitio';\nimport { SPLIT_FLAG } from '../types';\nimport selectors from '../selectors';\nimport { setApiVersionAction, setIntegrationIdAction } from './attribution';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\ninterface IsAuthenticatedAction {\n    type: IS_AUTHENTICATED;\n    payload: {\n        isAuthenticated: boolean;\n    };\n}\n\nexport function isAuthenticatedAction(isAuthenticated: boolean): IsAuthenticatedAction {\n    return {\n        type: IS_AUTHENTICATED,\n        payload: { isAuthenticated },\n    };\n}\n\ninterface SetTokenAction {\n    type: SET_TOKEN;\n    payload: {\n        token: string | null;\n    };\n}\n\nexport function setTokenAction(token: string | null = null, save = true): SetTokenAction {\n    if (save) {\n        if (!!token) {\n            localStorage.setItem('token', token);\n        } else {\n            localStorage.removeItem('token');\n        }\n    }\n\n    return {\n        type: SET_TOKEN,\n        payload: { token },\n    };\n}\n\ninterface UpdateCustomerAction {\n    type: UPDATE_CUSTOMER;\n    payload: {\n        customer: DeepPartial<CustomerModel>;\n    };\n}\n\nexport function updateCustomerAction(customer: DeepPartial<CustomerModel>): UpdateCustomerAction {\n    return {\n        type: UPDATE_CUSTOMER,\n        payload: { customer },\n    };\n}\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type AuthenticationAction = IsAuthenticatedAction | SetTokenAction | UpdateCustomerAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n\nconst waitForSplits = () => {\n    return new Promise((resolve) => {\n        setTimeout(() => resolve(), 200);\n    });\n};\n\nexport function loginAction(\n    authentication: AuthenticationMethod,\n    username: string,\n    merchant_short_name?: string,\n): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        if (getState().authentication.isAuthenticated) {\n            return;\n        }\n\n        dispatch(resetActionStatusAction('login'));\n        dispatch(setActionRequestingAction('login', true));\n\n        let result: LoginResponseModel;\n        let showSimpleWorkflow;\n        try {\n            // fetch merchant as we need an identifier to send to split to retrieve feature flags\n            const merchant = await api.fetchMerchant(username);\n            if (merchant) {\n                dispatch(fetchMerchantTreatmentsAction(merchant) as unknown as ApplicationAction);\n            }\n            // allow split treatments to load\n            await waitForSplits();\n            const loadedSplits = getState().splitio.treatments;\n            showSimpleWorkflow = selectors.global.getSplitFlagValue(SPLIT_FLAG.SIMPLE_CHECKOUT, loadedSplits);\n        } catch (e) {\n            // Login action should continue despite failure to retrieve SIMPLE_CHECKOUT split settings\n        }\n\n        try {\n            result = await api.login({\n                authentication: {\n                    method: authentication,\n                },\n                username,\n                with_order_items: !showSimpleWorkflow,\n                merchant_short_name,\n            });\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                e.property = e.property && e.property.replace('customer.', '');\n                dispatch(setActionResponseErrorAction('login', e));\n\n                if (authentication === 'link') {\n                    // Handle link availability errors\n                    if (e.code === ResponseErrorCode.PayLinkExpired) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.PayLinkExpired));\n                    } else if (e.code === ResponseErrorCode.PayLinkCanceled) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.PayLinkCanceled));\n                    } else if (e.code === ResponseErrorCode.MerchantSoftwareError) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.MerchantSoftwareError));\n                    } else if (e.code === ResponseErrorCode.PaylinkChargeAmountModified) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.PaylinkChargeAmountModified));\n                    } else if (e.code === ResponseErrorCode.NotFound) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.NotFound));\n                    } else if (e.code === ResponseErrorCode.InvalidApiKey) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.InvalidApiKey));\n                    } else if (e.code === ResponseErrorCode.LiveNotApproved) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.LiveNotApproved));\n                    } else if (e.code === ResponseErrorCode.InvalidChargeStatus) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.InvalidChargeStatus));\n                    } else if (e.code === ResponseErrorCode.PayLinkMissingCharge) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.PayLinkMissingCharge));\n                    } else if (e.code === ResponseErrorCode.PayLinkMissingOrder) {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.PayLinkMissingOrder));\n                    } else {\n                        dispatch(setErrorMessageAction(ResponseErrorCode.ServerError));\n                    }\n                }\n            }\n            dispatch(setActionRequestingAction('login', false));\n            throw e;\n        }\n        let integrationId;\n        if (result.link) {\n            integrationId = result.link.integration_id;\n            dispatch(setPayLinkAction(result.link));\n            dispatch(setApiVersionAction('v' + result.link.version));\n            if (!result.link.customer) {\n                dispatch(setActionRequestingAction('login', false));\n                throw ResponseErrorCode.CustomerRequired;\n            } else {\n                // Is authenticated directly if login using link only\n                dispatch(isAuthenticatedAction(true));\n            }\n        } else {\n            integrationId = getState().global.configuration.integration_id;\n            dispatch(setApiVersionAction(getState().global.configuration.api_version));\n        }\n\n        dispatch(setTokenAction(result.token));\n        dispatch(updateCustomerAction(result.customer));\n        dispatch(setPaymentSourcesAction(result.customer.payment_sources.filter((s) => s.active) || []));\n        dispatch(setCreditValueAction(result.link?.available_credit || 0));\n        dispatch(setIntegrationIdAction(integrationId));\n\n        // If authentication not link, we fetch the charges as well\n        if (authentication !== 'link') {\n            await fetchChargesAction()(dispatch, getState);\n        }\n\n        dispatch(setActionRequestingAction('login', false));\n    };\n}\n\nexport function resendTokenAction(\n    mobile: string,\n    email: string,\n    authMethod: AuthenticationMethod,\n): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        dispatch(resetActionStatusAction('verify'));\n        dispatch(setActionRequestingAction('verify', true));\n        dispatch(setTokenAction(null));\n        let error: Error | null = null;\n\n        try {\n            const result = await api.resendVerificationToken({\n                authentication: { method: authMethod },\n                customer: { individual: { mobile, email } },\n            });\n            dispatch(setTokenAction(result.token));\n        } catch (e) {\n            const responseError = e as ResponseError;\n            responseError.property = responseError.property && responseError.property.replace('customer.', '');\n            dispatch(setActionResponseErrorAction('verify', responseError));\n            error = responseError;\n        } finally {\n            dispatch(setActionRequestingAction('verify', false));\n        }\n        if (error) {\n            throw error;\n        }\n    };\n}\n\nexport function signupAction(\n    first_name: string,\n    last_name: string,\n    date_of_birth: string,\n    mobile: string,\n    email: string,\n    method: AuthenticationMethod,\n    merchant_short_name?: string,\n): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        dispatch(resetActionStatusAction('signup'));\n        dispatch(setActionRequestingAction('signup', true));\n\n        let error: Error | null = null;\n\n        try {\n            const result = await api.signup({\n                authentication: { method },\n                customer: {\n                    individual: { first_name, last_name, date_of_birth, mobile, email },\n                },\n                merchant_short_name,\n            });\n            dispatch(updateCustomerAction(result.customer));\n            dispatch(setTokenAction(result.token));\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                e.property = e.property && e.property.replace('customer.', '');\n                dispatch(setActionResponseErrorAction('signup', e));\n            }\n            error = e;\n        } finally {\n            dispatch(setActionRequestingAction('signup', false));\n        }\n        if (error) {\n            throw error;\n        }\n    };\n}\n\nexport function verifyAction(code: string): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        dispatch(resetActionStatusAction('verify'));\n        dispatch(setActionRequestingAction('verify', true));\n\n        const token = getState().authentication.token || '';\n\n        let error: Error | null = null;\n\n        try {\n            const result = await api.verify({ code, token });\n            dispatch(setTokenAction(result.token));\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                dispatch(setActionResponseErrorAction('verify', e));\n            }\n            error = e;\n        } finally {\n            dispatch(setActionRequestingAction('verify', false));\n        }\n\n        if (error) {\n            throw error;\n        }\n    };\n}\n\nexport function fetchProfileAction(): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        // If authenticated, return directly\n        if (getState().authentication.isAuthenticated) {\n            return;\n        }\n\n        // Check existing token\n        const token = localStorage.getItem('token');\n        // If no token present, we dont try to authenticate\n        if (!token) {\n            return;\n        }\n\n        dispatch(setActionRequestingAction('authenticate', true));\n\n        let error: Error | null = null;\n        try {\n            const result = await api.fetchProfile();\n            dispatch(isAuthenticatedAction(true));\n            dispatch(updateCustomerAction(result.customer));\n            dispatch(setPaymentSourcesAction(result.customer.payment_sources.filter((s) => s.active) || []));\n\n            // We fetch the charges as well\n            await fetchChargesAction()(dispatch, getState);\n        } catch (e) {\n            error = e;\n            localStorage.removeItem('token');\n        } finally {\n            dispatch(setActionRequestingAction('authenticate', false));\n        }\n        if (error) {\n            throw error;\n        }\n    };\n}\n\nexport function logoutAction(): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        dispatch(isAuthenticatedAction(false));\n        dispatch(setTokenAction(null));\n    };\n}\n","import { merge } from 'lodash';\nimport * as Stronghold from '@stronghold/pay-dropin';\nimport * as Sentry from '@sentry/browser';\nimport { ConfigurationModel } from './apis';\n\nexport const FORMAT_DATE = 'YYYY-MM-DD';\n\n// Open ID authentication\nexport const configuration: ConfigurationModel = {\n    api_environment: 'live',\n    environment: 'development',\n    stronghold_pay_host: '',\n    sentry_dsn: '',\n    analytics: {\n        environment: 'Development',\n    },\n    split: {\n        api_key: '',\n    },\n    integration_id: '',\n    api_version: 'v2',\n};\n\nexport function setConfiguration(newConfiguration: ConfigurationModel) {\n    merge(configuration, newConfiguration);\n\n    if (configuration.sentry_dsn) {\n        Sentry.init({\n            dsn: configuration.sentry_dsn,\n            environment: configuration.environment,\n        });\n    }\n}\n\nexport function getStrongholdPayClient(\n    publishableKey: string,\n    environment: Stronghold.ENVIRONMENT,\n    apiVersion: string,\n    integrationId?: string,\n) {\n    return Stronghold.Pay({\n        environment,\n        host: configuration.stronghold_pay_host,\n        publishableKey: publishableKey || '',\n        integrationId: integrationId,\n        apiVersion: apiVersion,\n    });\n}\n\n// Router\nexport const ROUTE = {\n    HOME: '/',\n    LOGIN: '/login',\n    LOGIN_CODE: '/login/code',\n    SIGN_UP: '/signup',\n    LOGOUT: '/logout',\n    LINK_ACCOUNT: '/link-account',\n    PROFILES: '/profiles',\n    PAYMENT_SOURCES: '/payment-sources',\n    SUPPORT: '/support',\n    LINK: '/l/:code?',\n};\n","import { ActionName, ConfigurationStatus, HeaderTitle } from '../types';\nimport {\n    RESET_ACTION_STATUS,\n    SET_ACTION_REQUEST_STATUS,\n    SET_ACTION_RESPONSE_ERROR,\n    SET_CONFIGURATION,\n    SET_CONFIGURATION_STATUS,\n    SET_ERROR_MESSAGE,\n    UPDATE_HEADER_TITLE,\n} from '../constants';\nimport { AppThunkAction } from '../index';\nimport { ApplicationAction } from './index';\nimport { setConfiguration } from '../../config';\nimport { ConfigurationModel, getConfiguration, ResponseErrorCode } from '../../apis';\nimport { ResponseError } from '../../apis';\nimport { LocationChangeAction } from 'connected-react-router';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\nexport interface SetActionRequestingAction {\n    type: SET_ACTION_REQUEST_STATUS;\n    payload: {\n        name: ActionName;\n        isRequesting: boolean;\n    };\n}\n\nexport function setActionRequestingAction(name: ActionName, isRequesting: boolean): SetActionRequestingAction {\n    return {\n        type: SET_ACTION_REQUEST_STATUS,\n        payload: {\n            name,\n            isRequesting,\n        },\n    };\n}\n\nexport interface SetActionResponseErrorAction {\n    type: SET_ACTION_RESPONSE_ERROR;\n    payload: {\n        name: ActionName;\n        error: ResponseError;\n    };\n}\n\nexport function setActionResponseErrorAction(name: ActionName, error: ResponseError): SetActionResponseErrorAction {\n    return {\n        type: SET_ACTION_RESPONSE_ERROR,\n        payload: {\n            name,\n            error,\n        },\n    };\n}\n\nexport interface SetErrorMessageAction {\n    type: SET_ERROR_MESSAGE;\n    payload: {\n        errorCode: ResponseErrorCode;\n    };\n}\n\nexport function setErrorMessageAction(errorCode: ResponseErrorCode = ResponseErrorCode.Unknown): SetErrorMessageAction {\n    return {\n        type: SET_ERROR_MESSAGE,\n        payload: {\n            errorCode,\n        },\n    };\n}\n\nexport interface ResetActionStatusAction {\n    type: RESET_ACTION_STATUS;\n    payload: {\n        name: ActionName;\n    };\n}\n\nexport function resetActionStatusAction(name: ActionName): ResetActionStatusAction {\n    return {\n        type: RESET_ACTION_STATUS,\n        payload: {\n            name,\n        },\n    };\n}\n\nexport interface SetConfigurationAction {\n    type: SET_CONFIGURATION;\n    payload: {\n        configuration: ConfigurationModel;\n    };\n}\n\nexport function setConfigurationAction(configuration: ConfigurationModel): SetConfigurationAction {\n    return {\n        type: SET_CONFIGURATION,\n        payload: {\n            configuration,\n        },\n    };\n}\n\nexport interface SetConfigurationStatusAction {\n    type: SET_CONFIGURATION_STATUS;\n    payload: { status: ConfigurationStatus };\n}\n\nexport function setConfigurationStatusAction(status: ConfigurationStatus): SetConfigurationStatusAction {\n    return {\n        type: SET_CONFIGURATION_STATUS,\n        payload: { status },\n    };\n}\n\nexport interface UpdateHeaderTitleAction {\n    type: UPDATE_HEADER_TITLE;\n    payload: {\n        headerPartial: Partial<HeaderTitle>;\n    };\n}\n\nexport function updateHeaderTitleAction(headerPartial: Partial<HeaderTitle>): UpdateHeaderTitleAction {\n    return {\n        type: UPDATE_HEADER_TITLE,\n        payload: {\n            headerPartial,\n        },\n    };\n}\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type GlobalAction =\n    | SetActionRequestingAction\n    | SetActionResponseErrorAction\n    | ResetActionStatusAction\n    | SetConfigurationAction\n    | SetConfigurationStatusAction\n    | SetErrorMessageAction\n    | UpdateHeaderTitleAction\n    | LocationChangeAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n\nexport function fetchConfiguration(): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        dispatch(setActionRequestingAction('fetch_configuration', true));\n        try {\n            const result = await getConfiguration();\n\n            setConfiguration(result);\n            dispatch(setConfigurationAction(result));\n        } catch (e) {\n            dispatch(setConfigurationStatusAction('error'));\n            dispatch(setErrorMessageAction());\n        }\n\n        dispatch(setActionRequestingAction('fetch_configuration', false));\n    };\n}\n","import * as api from '../../apis';\nimport { SET_CUSTOMER_TOKEN } from '../constants';\nimport { setActionRequestingAction } from './global';\nimport { AppThunkAction } from '../index';\nimport { ApplicationAction } from './index';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\nexport interface SetCustomerTokenAction {\n    type: SET_CUSTOMER_TOKEN;\n    payload: {\n        token: string | null;\n    };\n}\n\nexport const setCustomerTokenAction = (token: string | null): SetCustomerTokenAction => ({\n    type: SET_CUSTOMER_TOKEN,\n    payload: {\n        token,\n    },\n});\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type CustomerAction = SetCustomerTokenAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n\nexport function fetchCustomerTokenAction(): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        await dispatch(setActionRequestingAction('fetch_customer_token', true));\n        try {\n            const result = await api.getCustomerToken();\n            await dispatch(setCustomerTokenAction(result.token));\n            await dispatch(setActionRequestingAction('fetch_customer_token', false));\n        } catch (e) {\n            dispatch(setActionRequestingAction('fetch_customer_token', false));\n            throw e;\n        }\n    };\n}\n","import { SET_PAY_LINK, UPDATE_PAY_LINK } from '../constants';\nimport { PayLinkModel } from '../../apis';\nimport { DeepPartial } from 'redux';\nimport { AppThunkAction } from '../index';\nimport { ApplicationAction, setActionRequestingAction } from './index';\nimport * as api from '../../apis';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\nexport interface SetPayLinkAction {\n    type: SET_PAY_LINK;\n    payload: {\n        link: PayLinkModel;\n    };\n}\n\nexport const setPayLinkAction = (link: PayLinkModel): SetPayLinkAction => ({\n    type: SET_PAY_LINK,\n    payload: {\n        link,\n    },\n});\n\nexport interface UpdatePayLinkAction {\n    type: typeof UPDATE_PAY_LINK;\n    payload: { payLink: DeepPartial<PayLinkModel> };\n}\n\nexport const updatePayLinkAction = (payLink: DeepPartial<PayLinkModel>): UpdatePayLinkAction => ({\n    type: UPDATE_PAY_LINK,\n    payload: { payLink },\n});\n\nexport function setPayLinkCustomerAction(payLinkId: string, customerId: string): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        await dispatch(setActionRequestingAction('set_pay_link_customer', true));\n        try {\n            await api.addCustomer(payLinkId, customerId);\n            await dispatch(setActionRequestingAction('set_pay_link_customer', false));\n        } catch (e) {\n            dispatch(setActionRequestingAction('set_pay_link_customer', false));\n            throw e;\n        }\n    };\n}\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type PayLinkAction = SetPayLinkAction | UpdatePayLinkAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n","import * as api from '../../apis';\nimport { ChargeModel, ListSegment, ResponseError } from '../../apis';\nimport { CLEAN_CHARGES, SET_CHARGES } from '../constants';\nimport { setActionRequestingAction, setActionResponseErrorAction } from './global';\nimport { AppThunkAction } from '../index';\nimport { ApplicationAction } from './index';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\nexport interface SetChargesAction {\n    type: SET_CHARGES;\n    payload: {\n        list: ListSegment<ChargeModel>;\n    };\n}\n\nexport const setChargesAction = (list: ListSegment<ChargeModel>): SetChargesAction => ({\n    type: SET_CHARGES,\n    payload: {\n        list,\n    },\n});\n\nexport interface CleanChargesAction {\n    type: CLEAN_CHARGES;\n}\n\nexport const cleanChargesAction = (): CleanChargesAction => ({\n    type: CLEAN_CHARGES,\n});\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type ChargeAction = SetChargesAction | CleanChargesAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\nexport interface FetchChargesActionOptions {\n    search?: string;\n    settlementId?: string;\n    skip?: number;\n    limit?: number;\n    status?: string[];\n    from?: string;\n    to?: string;\n}\n\nexport function fetchChargesAction(options: FetchChargesActionOptions = {}): AppThunkAction<ApplicationAction> {\n    return async (dispatch, getState) => {\n        const customerId = getState().authentication.customer.id;\n        if (!customerId) return;\n\n        await dispatch(setActionRequestingAction('fetch_charges', true));\n\n        try {\n            const body = await api.listCharges(options);\n            await dispatch(setChargesAction(body));\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                dispatch(setActionResponseErrorAction('fetch_charges', e));\n            }\n        } finally {\n            await dispatch(setActionRequestingAction('fetch_charges', false));\n        }\n    };\n}\n","import * as api from '../../apis';\nimport {\n    ADD_PAYMENT_SOURCE,\n    REMOVE_PAYMENT_SOURCE,\n    SELECT_PAYMENT_SOURCE,\n    SET_PAYMENT_SOURCES,\n    UPDATE_PAYMENT_SOURCE,\n    IS_NEW_PAYMENT_SOURCE_LINKED,\n} from '../constants';\nimport { setActionRequestingAction, setActionResponseErrorAction } from './global';\nimport { AppThunkAction } from '../index';\nimport { ApplicationAction } from './index';\nimport { ResponseError } from '../../apis';\nimport { PaymentSource } from '@stronghold/pay-dropin';\n\n// -----------------\n// ACTIONS - These are serializable (hence replayable) descriptions of state transitions.\n// They do not themselves have any side-effects; they just describe something that is going to happen.\n\nexport interface SetPaymentSourcesAction {\n    type: typeof SET_PAYMENT_SOURCES;\n    payload: {\n        arr: PaymentSource[];\n    };\n}\n\nexport const setPaymentSourcesAction = (arr: PaymentSource[]): SetPaymentSourcesAction => ({\n    type: SET_PAYMENT_SOURCES,\n    payload: {\n        arr,\n    },\n});\n\nexport interface AddPaymentSourceAction {\n    type: typeof ADD_PAYMENT_SOURCE;\n    payload: {\n        data: PaymentSource;\n    };\n}\n\nexport const addPaymentSourceAction = (data: PaymentSource): AddPaymentSourceAction => ({\n    type: ADD_PAYMENT_SOURCE,\n    payload: {\n        data,\n    },\n});\n\nexport interface UpdatePaymentSourceAction {\n    type: typeof UPDATE_PAYMENT_SOURCE;\n    payload: {\n        data: PaymentSource;\n    };\n}\n\nexport const updatePaymentSourceAction = (data: PaymentSource): UpdatePaymentSourceAction => ({\n    type: UPDATE_PAYMENT_SOURCE,\n    payload: {\n        data,\n    },\n});\n\nexport interface RemovePaymentSourceAction {\n    type: typeof REMOVE_PAYMENT_SOURCE;\n    payload: {\n        paymentSourceId: string;\n    };\n}\n\nexport const removePaymentSourceAction = (paymentSourceId: string): RemovePaymentSourceAction => ({\n    type: REMOVE_PAYMENT_SOURCE,\n    payload: { paymentSourceId },\n});\n\nexport interface SelectPaymentSourceAction {\n    type: typeof SELECT_PAYMENT_SOURCE;\n    payload: { paymentSourceId: string };\n}\n\nexport const selectPaymentSourceAction = (paymentSourceId: string): SelectPaymentSourceAction => ({\n    type: SELECT_PAYMENT_SOURCE,\n    payload: { paymentSourceId },\n});\n\n// Declare a 'discriminated union' type. This guarantees that all references to 'type' properties contain one of the\n// declared type strings (and not any other arbitrary string).\nexport type PaymentSourcesAction =\n    | SetPaymentSourcesAction\n    | AddPaymentSourceAction\n    | UpdatePaymentSourceAction\n    | RemovePaymentSourceAction\n    | SelectPaymentSourceAction\n    | IsNewPaymentSourceLinkedAction;\n\n// ----------------\n// ACTION CREATORS - These are functions exposed to UI components that will trigger a state transition.\n// They don't directly mutate state, but they can have external side-effects (such as loading data).\n\nexport interface FetchPaymentSourcesActionOptions {\n    customerId?: string;\n    active?: boolean;\n}\n\nexport function deactivatePaymentSourceAction(sourceId: string): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        await dispatch(setActionRequestingAction('update_payment_source', true));\n        try {\n            const result = await api.deactivatePaymentSource(sourceId);\n            await dispatch(updatePaymentSourceAction(result));\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                dispatch(setActionResponseErrorAction('update_payment_source', e));\n            }\n            throw e;\n        } finally {\n            await dispatch(setActionRequestingAction('update_payment_source', false));\n        }\n    };\n}\n\nexport function fetchPaymentSourcesAction(): AppThunkAction<ApplicationAction> {\n    return async (dispatch) => {\n        await dispatch(setActionRequestingAction('fetch_payment_sources', true));\n        try {\n            const result = await api.fetchPaymentSources();\n            await dispatch(setPaymentSourcesAction(result.items));\n        } catch (e) {\n            if (e instanceof ResponseError) {\n                dispatch(setActionResponseErrorAction('fetch_payment_sources', e));\n            }\n        } finally {\n            await dispatch(setActionRequestingAction('fetch_payment_sources', false));\n        }\n    };\n}\n\ninterface IsNewPaymentSourceLinkedAction {\n    type: typeof IS_NEW_PAYMENT_SOURCE_LINKED;\n    payload: {\n        isNewPaymentSourceLinked: boolean;\n    };\n}\n\nexport function isNewPaymentSourceLinkedAction(isNewPaymentSourceLinked: boolean): IsNewPaymentSourceLinkedAction {\n    return {\n        type: IS_NEW_PAYMENT_SOURCE_LINKED,\n        payload: { isNewPaymentSourceLinked },\n    };\n}\n","import { SET_CREDIT_VALUE } from '../constants';\n\nexport interface SetCreditValueAction {\n    type: SET_CREDIT_VALUE;\n    payload: {\n        creditValue: number;\n    };\n}\n\nexport const setCreditValueAction = (creditValue: number): SetCreditValueAction => ({\n    type: SET_CREDIT_VALUE,\n    payload: {\n        creditValue: creditValue,\n    },\n});\n\nexport type CreditAction = SetCreditValueAction;\n","import 'react';\nimport * as React from 'react';\nimport { Redirect, Route, RouteComponentProps, RouteProps, withRouter } from 'react-router-dom';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { fetchProfileAction } from '../store/actions';\nimport { ROUTE } from '../config';\nimport selectors from '../store/selectors';\n\ninterface StateProps {\n    isAuthenticated: boolean;\n    hasPaymentSource: boolean;\n    hasCharge: boolean;\n}\n\ntype OwnProps = RouteComponentProps &\n    RouteProps & {\n        authenticate: boolean;\n        allowUnauthenticated?: boolean;\n        paymentSourceRequired?: boolean;\n        isMerchantRoute?: boolean;\n    };\n\ninterface DispatchProps {\n    fetchProfileAction: typeof fetchProfileAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ntype State = {\n    ready: boolean;\n};\n\nclass PortalRoute extends React.PureComponent<Props, State> {\n    public state: State = {\n        ready: false,\n    };\n\n    async componentDidMount() {\n        try {\n            if (this.props.authenticate) {\n                await this.props.fetchProfileAction();\n            }\n        } catch {\n            // Error\n        } finally {\n            this.setState({ ready: true });\n        }\n    }\n\n    public render() {\n        const {\n            isAuthenticated,\n            authenticate,\n            allowUnauthenticated = false,\n            isMerchantRoute = false,\n            hasPaymentSource,\n            hasCharge,\n            paymentSourceRequired = false,\n        } = this.props;\n        const { ready } = this.state;\n        if (!ready) {\n            return null;\n        }\n\n        // If authentication asked and mandatory and the user is not authenticated\n        // We redirect to the login page\n        if (authenticate && !allowUnauthenticated && !isAuthenticated) {\n            return <Redirect to={ROUTE.SIGN_UP} />;\n        }\n\n        // If the payment sources are required and the customer do not have a payment source\n        // We redirect to the link account page\n        if (isAuthenticated && !hasPaymentSource && paymentSourceRequired && !hasCharge) {\n            return <Redirect to={ROUTE.LINK_ACCOUNT} />;\n        }\n\n        if (isMerchantRoute && !selectors.global.isMerchantRoute()) {\n            window.location.href = 'https://strongholdpay.com';\n            return null;\n        }\n\n        return <Route {...this.props} />;\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    isAuthenticated: state.authentication.isAuthenticated,\n    hasPaymentSource: state.paymentSources.arr.length > 0,\n    hasCharge: state.charge.list.items.length > 0,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchProfileAction,\n        },\n        dispatch,\n    );\n\nexport default withRouter(connect(mapStateToProps, mapDispatchToProps)(PortalRoute));\n","const MESSAGE = {\n    ERROR_COMMON_TITLE: 'Sorry, something went wrong',\n    ERROR_COMMON: 'We weren’t able to process your request. Please go back and try again later.',\n    CANCELED_LINK_TITLE: 'Canceled Link',\n    CANCELED_LINK:\n        'This link to pay is no longer active. Please contact the merchant for another way to make your payment.',\n    ORDER_NOT_FOUND_TITLE: 'Page Not Found',\n    ORDER_NOT_FOUND: `We had a problem finding the associated page. Please try again in a few minutes.`,\n    ORDER_AMOUNT_MODIFIED_TITLE: 'Order Total has changed',\n    ORDER_AMOUNT_MODIFIED:\n        \"Your order total has changed. Please reload and make sure you're aware of the changes before completing your order.\",\n    EXPIRED_LINK_TITLE: 'Expired Link',\n    EXPIRED_LINK_SUB_TITLE: 'The link has expired and can no longer be used.',\n    EXPIRED_LINK: 'Please call the merchant and ask them to send you a new link.',\n    PAYMENT_METHOD_SELECT_TITLE: 'Select a payment method',\n    PAYMENT_METHOD_CHANGE: 'Change your payment method',\n    PAYMENT_METHOD_NONE: 'In order to complete a payment, you must securely link a payment method.',\n    PAYMENT_METHOD_NEEDED: 'You need to select an account to complete your payment.',\n    ERROR_MERCHANT_SOFTWARE_TITLE: 'Merchant Software Error',\n    ERROR_MERCHANT_SOFTWARE:\n        'We are unable to process your payment due to an error with the software the merchant uses.',\n    ERROR_INVALID_CONFIGURATION_TITLE: 'Configuration problem',\n    ERROR_INVALID_CONFIGURATION:\n        'Oops, it looks like the Portal configuration is wrong. Please check the credentials used.',\n    ERROR_LIVE_NOT_APPROVED_TITLE: 'Live approval required',\n    ERROR_LIVE_NOT_APPROVED:\n        \"Your Stronghold account has not been fully approved. Please use test credentials or contact Stronghold's onboarding team.\",\n    ERROR_USERNAME_NOT_FOUNT: (identifier?: 'mobile' | 'email') =>\n        `We couldn't find any payments made with this ${identifier || 'identifier'}.`,\n    ERROR_INCORRECT_CODE: 'Incorrect code.',\n    CHECK_AND_TRY_AGAIN: 'Please check and try again.',\n    SELECT_OR_ADD_TIP: 'Choose a suggested tip amount or add a custom amount:',\n    INVALID_CHARGE_STATUS_TITLE: 'Charge Status Error',\n    INVALID_CHARGE_STATUS:\n        'The charge associated with this link is not in a payable state so we have canceled this link. Please contact the merchant for another way to make your payment.',\n};\n\nexport default MESSAGE;\n","import * as React from 'react';\nimport selectors from '../store/selectors';\nimport { ResponseError, ResponseErrorCode } from '../apis';\nimport BsFormFeedback from 'reactstrap/lib/FormFeedback';\nimport MESSAGE from '../message';\nimport { GetErrorMessageOptions } from '../store/selectors/global';\n\ninterface Props {\n    error?: ResponseError | null;\n    options?: GetErrorMessageOptions;\n    data?: {\n        identifier?: 'mobile' | 'email';\n    };\n}\n\nexport default function FormFeedback(props: Props) {\n    const { error, options, data = {} } = props;\n\n    if (!error) {\n        return null;\n    }\n\n    let message = <React.Fragment>{selectors.global.getErrorMessage(error, options)}</React.Fragment>;\n\n    if (selectors.global.getErrorCode(error) === ResponseErrorCode.InvalidCredentials) {\n        message = (\n            <React.Fragment>\n                {MESSAGE.ERROR_USERNAME_NOT_FOUNT(data.identifier)} {MESSAGE.CHECK_AND_TRY_AGAIN}\n            </React.Fragment>\n        );\n    }\n\n    return <BsFormFeedback>{message}</BsFormFeedback>;\n}\n","import * as React from 'react';\nimport { FormEvent } from 'react';\nimport { Button, Modal, ModalBody, ModalFooter, ModalHeader } from 'reactstrap';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faLongArrowAltRight } from '@fortawesome/free-solid-svg-icons/faLongArrowAltRight';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport selectors from '../store/selectors';\nimport { AuthenticationMethod, ResponseError, ResponseErrorCode } from '../apis';\nimport { verifyAction } from '../store/actions';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport MaskedInput from 'react-text-mask';\nimport FormFeedback from './FormFeedback';\nimport FormGroup from 'reactstrap/lib/FormGroup';\nimport Form from 'reactstrap/lib/Form';\nimport MESSAGE from '../message';\n\ninterface StateProps {\n    isRequesting: boolean;\n    error: ResponseError | null;\n}\n\ntype OwnProps = {\n    show: boolean;\n    authenticationMethod: AuthenticationMethod;\n    value: string;\n    isResending: boolean;\n    onClose: () => void;\n    onResend: () => void;\n    onSuccess?: () => void;\n};\n\ninterface DispatchProps {\n    verify: typeof verifyAction;\n}\n\ntype Props = OwnProps & StateProps & DispatchProps;\n\ntype State = {\n    code: string;\n};\n\nclass VerificationCodeModal extends React.Component<Props> {\n    public state: State = {\n        code: '',\n    };\n\n    onToggle = () => {\n        this.props.onClose();\n    };\n\n    onSubmit = async (event: FormEvent<HTMLFormElement>) => {\n        event.preventDefault();\n        try {\n            await this.props.verify(this.state.code);\n            if (this.props.onSuccess) {\n                this.props.onSuccess();\n            }\n        } catch {\n            // Error\n        }\n    };\n\n    render() {\n        const { show, isRequesting, error, isResending } = this.props;\n\n        return (\n            <Modal isOpen={show} toggle={this.onToggle} centered>\n                <Form onSubmit={this.onSubmit}>\n                    <ModalHeader toggle={this.onToggle}>Verification</ModalHeader>\n                    <ModalBody>\n                        <p>\n                            Enter the verification code sent to <strong>{this.props.value}</strong>.\n                        </p>\n                        <FormGroup className=\"mb-0\">\n                            {this.props.show ? (\n                                <MaskedInput\n                                    mask={[/[0-9]/, ' ', /[0-9]/, ' ', /[0-9]/, ' ', /[0-9]/]}\n                                    type=\"text\"\n                                    placeholder=\"X X X X\"\n                                    className={[\n                                        'form-control form-control-lg text-center',\n                                        error ? 'is-invalid' : '',\n                                    ].join(' ')}\n                                    onChange={(e) => this.setState({ code: e.currentTarget.value })}\n                                    ref={(input) => {\n                                        setTimeout(() => {\n                                            if (input && input.inputElement) {\n                                                input.inputElement.focus();\n                                            }\n                                        }, 500);\n                                    }}\n                                />\n                            ) : null}\n                            <FormFeedback\n                                error={error}\n                                options={{\n                                    transform: (responseErrorCode: ResponseErrorCode) => {\n                                        if (responseErrorCode === ResponseErrorCode.InvalidField) {\n                                            return `${MESSAGE.ERROR_INCORRECT_CODE} ${MESSAGE.CHECK_AND_TRY_AGAIN}`;\n                                        }\n                                    },\n                                }}\n                            />\n                        </FormGroup>\n                    </ModalBody>\n                    <ModalFooter className=\"d-flex justify-content-between\">\n                        <Button color=\"light\" onClick={this.props.onResend} disabled={isResending}>\n                            Resend\n                        </Button>\n                        <Button type={'submit'} disabled={isResending || this.props.isRequesting} color=\"primary\">\n                            Verify{' '}\n                            {isRequesting || isResending ? (\n                                <Spinner type=\"grow\" color=\"white\" size={'sm'} />\n                            ) : (\n                                <FontAwesomeIcon icon={faLongArrowAltRight} fixedWidth />\n                            )}\n                        </Button>\n                    </ModalFooter>\n                </Form>\n            </Modal>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    error: selectors.global.getResponseError(state.global.actions, 'verify'),\n    isRequesting: selectors.global.isActionRequesting(state.global.actions, 'verify'),\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            verify: verifyAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(VerificationCodeModal);\n","import * as React from 'react';\nimport { Link, RouteComponentProps, withRouter } from 'react-router-dom';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport Container from 'reactstrap/lib/Container';\nimport Dropdown from 'reactstrap/lib/Dropdown';\nimport DropdownToggle from 'reactstrap/lib/DropdownToggle';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faUserCircle } from '@fortawesome/free-solid-svg-icons/faUserCircle';\nimport DropdownMenu from 'reactstrap/lib/DropdownMenu';\nimport DropdownItem from 'reactstrap/lib/DropdownItem';\nimport { ROUTE } from '../config';\nimport selectors from '../store/selectors';\n\ninterface StateProps {\n    isAuthenticated: boolean;\n    name: string;\n    merchantDisplayName: string;\n}\n\ntype OwnProps = RouteComponentProps;\n\ntype Props = StateProps & OwnProps;\n\ntype State = {\n    isOpen: boolean;\n};\n\nclass NavMenu extends React.PureComponent<Props, State> {\n    public state: State = {\n        isOpen: false,\n    };\n\n    toggle = () => {\n        this.setState({ isOpen: !this.state.isOpen });\n    };\n\n    public render() {\n        return (\n            <Container className=\"py-3 d-flex justify-content-between\">\n                <div className=\"h4 m-0\">\n                    <strong>{this.props.merchantDisplayName}</strong> Customer Payments\n                </div>\n                <Dropdown isOpen={this.state.isOpen} toggle={this.toggle} direction=\"down\">\n                    <DropdownToggle\n                        size=\"sm\"\n                        color=\"primary\"\n                        outline\n                        caret={false}\n                        className=\"d-flex align-items-center rounded-circle p-1\"\n                    >\n                        <FontAwesomeIcon icon={faUserCircle} size=\"2x\" />\n                    </DropdownToggle>\n                    <DropdownMenu right>\n                        <DropdownItem disabled style={{ minWidth: 230 }}>\n                            <div className=\"h5\">{this.props.name}</div>\n                        </DropdownItem>\n                        <DropdownItem divider />\n                        <Link className=\"dropdown-item\" to={ROUTE.LOGOUT}>\n                            <div>Sign out</div>\n                        </Link>\n                    </DropdownMenu>\n                </Dropdown>\n            </Container>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    isAuthenticated: state.authentication.isAuthenticated,\n    name: selectors.authentication.getFullName(state.authentication),\n    merchantDisplayName: state.global.merchant.display_name,\n});\n\nexport default withRouter(connect(mapStateToProps)(NavMenu));\n","import * as React from 'react';\n\ninterface Props {\n    isBlack: boolean;\n}\n\nexport default function Powered(props: Props) {\n    let imgSrc = '/images/';\n\n    if (props.isBlack) {\n        imgSrc += 'Powered-by-Stronghold.png';\n    } else {\n        imgSrc += 'Powered-by-Stronghold_1-p-500.png';\n    }\n\n    return (\n        <div className=\"\">\n            <img src={`${imgSrc}`} className=\"img-responsive\" alt=\"Stronghold Pay\" height={30} />\n        </div>\n    );\n}\n","import * as React from 'react';\nimport Powered from './Powered';\nimport Container from 'reactstrap/lib/Container';\n\nexport default function Footer() {\n    return (\n        <div className=\"w-100\">\n            <Container className=\"p-3 p-md-4 text-center\">\n                <Powered isBlack={true} />\n            </Container>\n        </div>\n    );\n}\n","import * as React from 'react';\nimport NavMenu from './NavMenu';\nimport Breadcrumb from 'reactstrap/lib/Breadcrumb';\nimport BreadcrumbItem from 'reactstrap/lib/BreadcrumbItem';\nimport { Link } from 'react-router-dom';\nimport Footer from './Footer';\n\nexport interface LayoutBreadcrumbItem {\n    href: string;\n    title: string | JSX.Element;\n}\n\ninterface Props {\n    navbar?: boolean;\n    centered?: boolean;\n    className?: string;\n    children: JSX.Element | JSX.Element[];\n    breadcrumbItems?: LayoutBreadcrumbItem[];\n    footer?: boolean;\n}\n\nexport function LayoutBreadcrumbs(props: { items?: LayoutBreadcrumbItem[] }) {\n    const { items = [] } = props;\n\n    if (items.length === 0) return null;\n\n    const isLastItem = (index: number) => index + 1 === items.length;\n\n    return (\n        <div className=\"bg-white border-bottom shadow-sm\">\n            <div className=\"mw-lg mx-auto\">\n                <Breadcrumb listClassName=\"mb-0\">\n                    {items.map((value, key) => (\n                        <BreadcrumbItem key={key} active={isLastItem(key)}>\n                            {isLastItem(key) ? value.title : <Link to={value.href}>{value.title}</Link>}\n                        </BreadcrumbItem>\n                    ))}\n                </Breadcrumb>\n            </div>\n        </div>\n    );\n}\n\nexport default function Layout(props: Props) {\n    const { children, navbar = true, className = '', breadcrumbItems = [], centered = false } = props;\n\n    if (centered) {\n        return (\n            <div className=\"d-flex flex-column h-100\">\n                <div className=\"flex-fill py-3 container mw-md d-flex align-items-center justify-content-center\">\n                    {children}\n                </div>\n                {props.footer !== false && <Footer />}\n            </div>\n        );\n    }\n\n    return (\n        <div className=\"d-flex flex-column h-100\">\n            {navbar && <NavMenu />}\n            <LayoutBreadcrumbs items={breadcrumbItems} />\n            <div className={['container', 'mx-auto', 'flex-grow-1', className || 'mw-lg'].join(' ')}>{children}</div>\n            <Footer />\n        </div>\n    );\n}\n","import * as React from 'react';\nimport PhoneInput from 'react-phone-input-2';\n\ninterface Props {\n    value: string;\n    placeholder?: string;\n    isInvalid: boolean;\n    onChange: (phone: string) => void;\n    disabled?: boolean;\n}\n\nclass PhoneNumberInput extends React.Component<Props> {\n    render() {\n        const { value, placeholder, isInvalid, onChange, disabled } = this.props;\n\n        return (\n            <PhoneInput\n                placeholder={placeholder && 'Enter mobile phone number'}\n                value={value}\n                country={'us'}\n                onChange={(mobile) => {\n                    mobile = mobile.replace(/[^0-9+]/g, '');\n                    onChange(`+${mobile}`);\n                }}\n                containerClass={['form-control', isInvalid ? 'is-invalid' : ''].join(' ')}\n                disabled={disabled}\n                inputProps={{\n                    name: 'mobile_phone_number',\n                    className: [\n                        disabled ? 'disabled' : '',\n                        'border-top-0',\n                        'border-right-0',\n                        'border-left-0',\n                        'border-bottom-0',\n                    ].join(' '),\n                    disabled: disabled,\n                }}\n            />\n        );\n    }\n}\n\nexport default PhoneNumberInput;\n","import * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\n\ninterface StateProps {\n    imageUrl: string | null;\n    displayName: string;\n}\n\ninterface OwnProps extends React.HTMLAttributes<HTMLDivElement> {\n    maxHeight?: number;\n}\n\ntype Props = StateProps & OwnProps;\n\nfunction MerchantImg(props: Props) {\n    const { imageUrl, displayName, maxHeight = 170, className = '' } = props;\n\n    if (!imageUrl) {\n        return null;\n    }\n\n    return (\n        <img\n            src={imageUrl}\n            alt={displayName}\n            className={['img-responsive', className].join(' ')}\n            style={{ maxHeight }}\n        />\n    );\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    imageUrl: state.global.merchant.image_url,\n    displayName: state.global.merchant.display_name,\n});\n\nexport default connect(mapStateToProps)(MerchantImg);\n","import 'react';\nimport * as React from 'react';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport Form from 'reactstrap/lib/Form';\nimport Input from 'reactstrap/lib/Input';\nimport { Link, RouteComponentProps, withRouter } from 'react-router-dom';\nimport Button from 'reactstrap/lib/Button';\nimport { FormEvent } from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport selectors from '../store/selectors';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport {\n    isAuthenticatedAction,\n    loginAction,\n    resetActionStatusAction,\n    setPayLinkCustomerAction,\n} from '../store/actions';\nimport { AuthenticationMethod, CustomerModel, addCustomer, ResponseError, PayLinkModel } from '../apis';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { ROUTE } from '../config';\nimport { faAt } from '@fortawesome/free-solid-svg-icons/faAt';\nimport VerificationCodeModal from '../components/VerificationCodeModal';\nimport { faMobileAlt } from '@fortawesome/free-solid-svg-icons/faMobileAlt';\nimport FormGroup from 'reactstrap/lib/FormGroup';\nimport * as querystring from 'querystring';\nimport Layout from '../components/Layout';\nimport PhoneNumberInput from '../components/PhoneNumberInput';\nimport FormFeedback from '../components/FormFeedback';\nimport Label from 'reactstrap/lib/Label';\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\nimport MerchantImg from '../components/MerchantImg';\n\ninterface LoginParams {\n    mobile: string;\n    email: string;\n}\n\ninterface StateProps {\n    isRequesting: boolean;\n    error: ResponseError | null;\n    merchantDisplayName: string;\n    customer: CustomerModel | null;\n    link: PayLinkModel | null;\n}\n\ntype OwnProps = { navToSignup?: () => void } & RouteComponentProps;\n\ninterface DispatchProps {\n    login: typeof loginAction;\n    isAuthenticatedAction: typeof isAuthenticatedAction;\n    resetActionStatusAction: () => void;\n    linkCustomer: typeof setPayLinkCustomerAction;\n}\n\ntype Props = OwnProps & StateProps & DispatchProps & RouteComponentProps<{ code: string }>;\n\ninterface State {\n    authenticationMethod: AuthenticationMethod;\n    mobile: string;\n    email: string;\n    showModal: boolean;\n    code?: string;\n}\n\nclass LoginPage extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = {\n            authenticationMethod: 'sms',\n            mobile: '',\n            email: '',\n            showModal: false,\n            code: this.props.match.params.code,\n        };\n\n        this.onSubmit = this.onSubmit.bind(this);\n    }\n\n    componentDidMount() {\n        const params = querystring.parse(this.props.location.search.slice(1));\n        const paramsObject = params as Partial<LoginParams>;\n        this.setState({\n            mobile: paramsObject.mobile || '',\n            email: paramsObject.email || '',\n        });\n    }\n\n    username = (authenticationMethod?: AuthenticationMethod) => {\n        return (authenticationMethod || this.state.authenticationMethod) === 'email'\n            ? this.state.email\n            : this.state.mobile;\n    };\n\n    onLogin = async (authenticationMethod: AuthenticationMethod) => {\n        try {\n            this.setState({ authenticationMethod });\n            await this.props.login(\n                authenticationMethod,\n                this.username(authenticationMethod),\n                this.props.link?.merchant.short_name,\n            );\n            this.setState({ showModal: true });\n        } catch {\n            // Error\n        }\n    };\n\n    onSubmit = (authenticationMethod: AuthenticationMethod) => async (event: FormEvent<HTMLFormElement>) => {\n        event.preventDefault();\n        this.onLogin(authenticationMethod);\n    };\n\n    onResend = () => this.onLogin(this.state.authenticationMethod);\n\n    onSuccess = async () => {\n        this.props.isAuthenticatedAction(true);\n        if (this.state.code && this.props.customer?.id) {\n            await addCustomer(this.state.code, this.props.customer.id);\n            window.location.reload();\n        } else {\n            this.props.history.push(ROUTE.HOME);\n        }\n    };\n\n    toggle = () => {\n        this.setState({ showModal: !this.state.showModal });\n    };\n\n    isInvalid = (method: AuthenticationMethod) => {\n        return (\n            this.state.authenticationMethod === method && selectors.global.isPropertyError('username', this.props.error)\n        );\n    };\n\n    render() {\n        const { isRequesting, error, merchantDisplayName } = this.props;\n        const { authenticationMethod, mobile, email, showModal } = this.state;\n        return (\n            <Layout navbar={false} centered>\n                <Card className=\"text-center shadow-lg mw-sm\">\n                    <CardBody className=\"p-md-4\">\n                        <div className=\"h4\">\n                            <strong>{merchantDisplayName}</strong> Customer Payments\n                        </div>\n                        <MerchantImg />\n                        <div className=\"lead mt-4\">Enter your email or mobile number to receive a login code.</div>\n                    </CardBody>\n                    <CardBody className=\"p-md-4 border-top\">\n                        <Label>Mobile</Label>\n                        <Form id=\"mobile-form\" onSubmit={this.onSubmit('sms')} className=\"d-flex align-items-baseline\">\n                            <FormGroup className=\"d-flex justify-content-center mb-0 gap-1 w-100\">\n                                <div className=\"col-9\">\n                                    <PhoneNumberInput\n                                        value={mobile}\n                                        isInvalid={this.isInvalid('sms')}\n                                        onChange={(mobile: string) => this.setState({ mobile })}\n                                        disabled={isRequesting}\n                                    />\n                                    <FormFeedback error={error} data={{ identifier: 'mobile' }} />\n                                </div>\n                                <div className=\"col-3\">\n                                    <Button\n                                        disabled={isRequesting}\n                                        color={'primary'}\n                                        className=\"w-100 d-flex justify-content-center align-items-center\"\n                                        style={{ height: '40px' }}\n                                    >\n                                        {isRequesting && authenticationMethod === 'sms' ? (\n                                            <Spinner type=\"grow\" color=\"white\" size={'sm'} />\n                                        ) : (\n                                            <FontAwesomeIcon icon={faMobileAlt} fixedWidth />\n                                        )}\n                                    </Button>\n                                </div>\n                            </FormGroup>\n                        </Form>\n                        <Row className=\"my-3 d-flex\">\n                            <Col>\n                                <hr />\n                            </Col>\n                            <Col className=\"d-flex align-items-center justify-content-center\">\n                                <div>Or</div>\n                            </Col>\n                            <Col>\n                                <hr />\n                            </Col>\n                        </Row>\n                        <Label>Email</Label>\n                        <Form id=\"email-form\" onSubmit={this.onSubmit('email')} className=\"d-flex align-items-baseline\">\n                            <FormGroup className=\"d-flex justify-content-center mb-0 gap-1 w-100\">\n                                <div className=\"col-9\">\n                                    <Input\n                                        type=\"email\"\n                                        placeholder=\"Your Email address\"\n                                        autoComplete=\"email\"\n                                        disabled={isRequesting}\n                                        value={email}\n                                        className=\"w-100\"\n                                        onChange={(e) => {\n                                            this.props.resetActionStatusAction();\n                                            this.setState({\n                                                email: e.currentTarget.value,\n                                            });\n                                        }}\n                                        invalid={this.isInvalid('email')}\n                                    />\n                                    <FormFeedback error={error} data={{ identifier: 'email' }} />\n                                </div>\n\n                                <div className=\"col-3\">\n                                    <Button\n                                        disabled={isRequesting}\n                                        color={'primary'}\n                                        className=\"w-100 d-flex justify-content-center align-items-center\"\n                                        style={{ height: '40px' }}\n                                    >\n                                        {isRequesting && authenticationMethod === 'email' ? (\n                                            <Spinner type=\"grow\" color=\"white\" size={'sm'} />\n                                        ) : (\n                                            <FontAwesomeIcon icon={faAt} fixedWidth />\n                                        )}\n                                    </Button>\n                                </div>\n                            </FormGroup>\n                        </Form>\n                        <VerificationCodeModal\n                            show={showModal}\n                            value={this.username()}\n                            onClose={this.toggle}\n                            onResend={this.onResend}\n                            isResending={isRequesting}\n                            onSuccess={this.onSuccess}\n                            authenticationMethod={authenticationMethod}\n                        />\n                    </CardBody>\n                    <CardBody className=\"border-top\">\n                        Don&apos;t have an account?\n                        {this.props.navToSignup ? (\n                            <button\n                                onClick={this.props.navToSignup}\n                                style={{\n                                    background: 'none',\n                                    border: 'none',\n                                    color: 'blue',\n                                    cursor: 'pointer',\n                                    fontSize: 'inherit',\n                                    padding: 5,\n                                }}\n                            >\n                                Sign Up\n                            </button>\n                        ) : (\n                            <Link to={ROUTE.SIGN_UP} style={{ padding: 5 }}>\n                                Sign Up\n                            </Link>\n                        )}\n                    </CardBody>\n                </Card>\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    error: selectors.global.getResponseError(state.global.actions, 'login'),\n    isRequesting: selectors.global.isActionRequesting(state.global.actions, 'login'),\n    merchantDisplayName: state.global.merchant.display_name,\n    customer: state.authentication.customer,\n    link: state.payLink.data ? state.payLink.data : null,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            login: loginAction,\n            isAuthenticatedAction: isAuthenticatedAction,\n            resetActionStatusAction: () => dispatch(resetActionStatusAction('login')),\n            linkCustomer: setPayLinkCustomerAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(LoginPage));\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n\nimport * as React from 'react';\nimport Button, { ButtonProps } from 'reactstrap/lib/Button';\nimport { getStrongholdPayClient } from '../../config';\nimport { addPaymentSourceAction, fetchCustomerTokenAction, selectPaymentSourceAction } from '../../store/actions';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { OnExit, AddPaymentSourceOnSuccess, PaymentSource } from '@stronghold/pay-dropin';\nimport { ApplicationState } from '../../store';\nimport selectors from '../../store/selectors';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faUniversity } from '@fortawesome/free-solid-svg-icons/faUniversity';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { ApiKeyModel } from '../../apis';\n\ninterface StateProps {\n    publishableKey: ApiKeyModel | null;\n    customerToken: string;\n    isRequestingCustomerToken: boolean;\n    integrationId?: string;\n    apiVersion: string;\n}\n\ninterface OwnProps extends ButtonProps {\n    onSuccess?: AddPaymentSourceOnSuccess;\n    iconColor?: string;\n    payLinkId?: string;\n}\n\ninterface DispatchProps {\n    fetchCustomerTokenAction: typeof fetchCustomerTokenAction;\n    addPaymentSourceAction: typeof addPaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ninterface State {\n    ready: boolean;\n    paymentSource: PaymentSource | null;\n}\n\nclass AddPaymentSourceButton extends React.Component<Props, State> {\n    public state: State = {\n        ready: true,\n        paymentSource: null,\n    };\n\n    onClick = async () => {\n        if (!this.props.publishableKey) return;\n\n        this.setState({ ready: false });\n\n        try {\n            await this.props.fetchCustomerTokenAction();\n        } catch {\n            this.setState({ ready: true });\n            return;\n        }\n\n        // If for whatever reason there is no customer token, throw\n        if (!this.props.customerToken) throw new Error('no customer token');\n\n        const client = getStrongholdPayClient(\n            this.props.publishableKey.key,\n            this.props.publishableKey.environment,\n            this.props.apiVersion,\n            this.props.integrationId,\n        );\n        client.addPaymentSource(this.props.customerToken, {\n            payLinkCode: this.props.payLinkId,\n            onSuccess: this.onSuccess,\n            onExit: this.onExit,\n            onReady: () => this.setState({ ready: true }),\n        });\n    };\n\n    onSuccess: AddPaymentSourceOnSuccess = (paymentSource) => {\n        this.props.addPaymentSourceAction(paymentSource);\n        this.props.selectPaymentSourceAction(paymentSource.id);\n        this.setState({ paymentSource });\n    };\n\n    onExit: OnExit = () => {\n        if (!this.state.ready) {\n            this.setState({ ready: true });\n        }\n        if (this.state.paymentSource && this.props.onSuccess) {\n            this.props.onSuccess(this.state.paymentSource);\n        }\n    };\n\n    render() {\n        const {\n            children = <React.Fragment>Link a Payment Method</React.Fragment>,\n            isRequestingCustomerToken,\n            customerToken,\n            addSourcesAction,\n            fetchCustomerTokenAction,\n            showAsLink,\n            onExit,\n            onSuccess,\n            publishableKey,\n            addPaymentSourceAction,\n            iconColor,\n            payLinkId,\n            ...props\n        } = this.props;\n        const { ready } = this.state;\n\n        const color = props.color || 'primary';\n        const iconClass = `text-${iconColor || 'white'}`;\n\n        let icon = <FontAwesomeIcon icon={faUniversity} fixedWidth className={iconClass} />;\n\n        const isLoading = !ready;\n        const isDisabled = isLoading || props.disabled || !publishableKey;\n\n        if (isLoading) {\n            icon = <Spinner type=\"grow\" className={iconClass} size=\"sm\" />;\n        }\n\n        return (\n            <Button\n                {...props}\n                color={color}\n                onClick={this.onClick}\n                disabled={isDisabled}\n                data-sh=\"add-payment-source-button\"\n            >\n                {children}\n                <span className=\"ml-1\">{icon}</span>\n            </Button>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    publishableKey: state.global.publishableApiKey,\n    customerToken: state.authentication.customerToken || '',\n    isRequestingCustomerToken: selectors.global.isActionRequesting(state.global.actions, 'fetch_customer_token'),\n    integrationId: state.attribution?.integrationId,\n    apiVersion: state.attribution.apiVersion,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchCustomerTokenAction,\n            addPaymentSourceAction,\n            selectPaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(AddPaymentSourceButton);\n","import * as React from 'react';\nimport Powered from './Powered';\nimport { MerchantModel } from '../apis';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport MerchantImg from '../components/MerchantImg';\n\ninterface Props {\n    merchant: MerchantModel;\n}\n\nfunction StrongholdPay(props: Props) {\n    return (\n        <div data-sh=\"stronghold-pay\">\n            <MerchantImg />\n            <h3 style={{ marginTop: 30 }}>\n                <span>{props.merchant.display_name}</span>\n            </h3>\n\n            <Powered isBlack={false} />\n        </div>\n    );\n}\n\nconst mapStateToProps: MapStateToPropsParam<Props, void, ApplicationState> = (state) => ({\n    merchant: state.global.merchant,\n});\n\nexport default connect(mapStateToProps)(StrongholdPay);\n","import * as React from 'react';\nimport Paginator, { PaginationInformation } from 'paginator';\nimport PaginationBS from 'reactstrap/lib/Pagination';\nimport PaginationItem from 'reactstrap/lib/PaginationItem';\nimport PaginationLink from 'reactstrap/lib/PaginationLink';\n\nexport interface Props {\n    total: number;\n    skipped: number;\n    limit: number;\n    length?: number;\n    onClick: (skip: number) => void;\n    disabled?: boolean;\n}\n\nconst bigStep = 10;\n\nexport function getPaginationInfo(total: number, limit: number, length: number, currentPage: number) {\n    const paginator = new Paginator(limit, length);\n    return paginator.build(total, currentPage);\n}\n\nexport const getCurrentPage = (skipped: number, limit: number) => Math.floor(skipped / limit) + 1;\nexport const getPageSkip = (page: number, limit: number) => (page - 1) * limit;\nexport const getPreviousBigStep = (paginationInfo: PaginationInformation, limit: number) => {\n    const page = paginationInfo.current_page - bigStep;\n    const has = page > 1;\n    const hasPagesLeft = paginationInfo.first_page > 2;\n    const skip = getPageSkip(page, limit);\n    return { page, has, hasPagesLeft, skip };\n};\nexport const getNextBigStep = (paginationInfo: PaginationInformation, limit: number) => {\n    const page = paginationInfo.current_page + bigStep;\n    const has = page < paginationInfo.total_pages;\n    const hasPagesLeft = paginationInfo.last_page < paginationInfo.total_pages - 1;\n    const skip = getPageSkip(page, limit);\n    return { page, has, hasPagesLeft, skip };\n};\n\nexport default function Pagination(props: Props) {\n    const { limit, length = 5, skipped, total, onClick, disabled = false } = props;\n\n    if (total === 0) {\n        return null;\n    }\n\n    const currentPage = getCurrentPage(skipped, limit);\n    const paginationInfo = getPaginationInfo(total, limit, length, currentPage);\n\n    const firstPageSkip = 0;\n    const lastPageSkip = getPageSkip(paginationInfo.total_pages, limit);\n\n    const previousBigStep = getPreviousBigStep(paginationInfo, limit);\n    const nextBigStep = getNextBigStep(paginationInfo, limit);\n\n    const pages: JSX.Element[] = [];\n    for (let i = paginationInfo.first_page; i < paginationInfo.last_page + 1; i++) {\n        pages.push(\n            <PaginationItem key={`page-${i}`} active={i === paginationInfo.current_page} disabled={disabled}>\n                <PaginationLink\n                    onClick={i !== paginationInfo.current_page ? () => onClick(getPageSkip(i, limit)) : undefined}\n                >\n                    {i}\n                </PaginationLink>\n            </PaginationItem>,\n        );\n    }\n\n    return (\n        <PaginationBS listClassName=\"justify-content-center mt-2\">\n            {paginationInfo.first_page > 1 ? (\n                <PaginationItem disabled={disabled}>\n                    <PaginationLink onClick={() => onClick(firstPageSkip)}>1</PaginationLink>\n                </PaginationItem>\n            ) : null}\n            {previousBigStep.has ? (\n                <PaginationItem disabled={disabled}>\n                    <PaginationLink first onClick={() => onClick(previousBigStep.skip)} />\n                </PaginationItem>\n            ) : null}\n            {!previousBigStep.has && previousBigStep.hasPagesLeft ? (\n                <PaginationItem disabled={true}>\n                    <PaginationLink>...</PaginationLink>\n                </PaginationItem>\n            ) : null}\n            {pages}\n            {!nextBigStep.has && nextBigStep.hasPagesLeft ? (\n                <PaginationItem disabled={true}>\n                    <PaginationLink>...</PaginationLink>\n                </PaginationItem>\n            ) : null}\n            {nextBigStep.has ? (\n                <PaginationItem disabled={disabled}>\n                    <PaginationLink last onClick={() => onClick(nextBigStep.skip)} />\n                </PaginationItem>\n            ) : null}\n            {paginationInfo.last_page < paginationInfo.total_pages ? (\n                <PaginationItem disabled={!paginationInfo.has_next_page || disabled}>\n                    <PaginationLink onClick={() => onClick(lastPageSkip)}>{paginationInfo.total_pages}</PaginationLink>\n                </PaginationItem>\n            ) : null}\n        </PaginationBS>\n    );\n}\n","import * as React from 'react';\nimport { CHARGE_STATUS } from '../../apis';\nimport Badge from 'reactstrap/lib/Badge';\n\nexport interface Props {\n    status: CHARGE_STATUS;\n}\n\nexport default function ChargeStatusBadge(props: Props) {\n    const { status } = props;\n    let textColor = 'primary';\n    let text = status.replace('_', ' ');\n\n    if (status === 'captured') {\n        textColor = 'success';\n        text = 'Completed';\n    } else if (status === 'authorized') {\n        textColor = 'warning';\n        text = 'Pending';\n    } else if (status === 'attempting_collection') {\n        textColor = 'warning';\n        text = 'Retrying';\n    } else if (status === 'disputed') {\n        textColor = 'warning';\n        text = 'Disputed';\n    } else if (status === 'refund_pending') {\n        textColor = 'warning';\n        text = 'Processing refund';\n    } else if (status === 'refunded') {\n        textColor = 'primary';\n        text = 'Refunded';\n    } else if (status === 'capture_failed') {\n        textColor = 'danger';\n        text = 'Insufficient funds';\n    } else if (status === 'stopped_collection') {\n        textColor = 'danger';\n        text = 'Stopped Collection';\n    } else if (status === 'canceled') {\n        textColor = 'danger';\n        text = 'Canceled';\n    }\n\n    return (\n        <Badge pill color={textColor}>\n            {text}\n        </Badge>\n    );\n}\n","import * as React from 'react';\n\nexport interface Props {\n    isLoading: boolean;\n    width?: string;\n    children?: React.ReactNode;\n}\n\nexport default class PlaceholderLoader extends React.Component<Props> {\n    render() {\n        const { isLoading, children, width } = this.props;\n\n        if (!isLoading) {\n            return children || null;\n        }\n\n        return (\n            <div\n                className=\"placeholder-animated\"\n                style={{\n                    width: width || '100px',\n                }}\n            >\n                -\n            </div>\n        );\n    }\n}\n","import * as React from 'react';\nimport PlaceholderLoader from './PlaceholderLoader';\n\nexport type Props = React.PropsWithChildren<{\n    isLoading: boolean;\n    rows: number;\n    columns: number;\n}>;\n\nexport default function TableBody(props: Props) {\n    if (!props.isLoading) {\n        return <tbody>{props.children}</tbody>;\n    }\n\n    const rows: JSX.Element[] = [];\n\n    for (let row = 0; row < props.rows; row++) {\n        const columns: JSX.Element[] = [];\n        for (let col = 0; col < props.columns; col++) {\n            columns.push(\n                <td key={`table-body-column-${col}`}>\n                    <PlaceholderLoader isLoading={true} />\n                </td>,\n            );\n        }\n        rows.push(<tr key={`table-body-row-${row}`}>{columns}</tr>);\n    }\n\n    return <tbody>{rows}</tbody>;\n}\n","import * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport { ChargeModel } from '../../apis';\nimport { isActionRequesting } from '../../store/selectors/global';\nimport Table from 'reactstrap/lib/Table';\nimport selectors from '../../store/selectors';\nimport Pagination from '../../components/Pagination';\nimport ChargeStatusBadge from './ChargeStatusBadge';\nimport TableBody from '../TableBody';\n\ninterface StateProps {\n    charges: ChargeModel[];\n    chargesTotal: number;\n    chargesSkipped: number;\n    chargesLimit: number;\n    isLoading: boolean;\n}\n\ninterface OwnerProps {\n    customerId?: string;\n    isLoading?: boolean;\n    onGoTo: (page: number, skip: number) => void;\n    noRowsComponent?: () => React.ReactNode;\n}\n\ntype Props = StateProps & OwnerProps;\n\nclass ChargesTable extends React.Component<Props> {\n    hasNoRows = () => this.props.charges.length === 0 && !this.props.isLoading;\n\n    renderNoRows = () => {\n        if (!this.hasNoRows()) return null;\n        return (\n            <div className=\"text-center p-5\">\n                {this.props.noRowsComponent ? this.props.noRowsComponent() : 'There are no transactions to display'}\n            </div>\n        );\n    };\n\n    render() {\n        return (\n            <React.Fragment>\n                <Table hover responsive className={['table-sm', this.hasNoRows() ? 'mb-0' : ''].join(' ')}>\n                    <thead>\n                        <tr>\n                            <th style={{ minWidth: 140 }}>Date</th>\n                            <th>Status</th>\n                            <th>Amount</th>\n                        </tr>\n                    </thead>\n                    <TableBody isLoading={this.props.isLoading} rows={this.props.chargesLimit} columns={4}>\n                        {this.props.charges.map((charge, index) => (\n                            <tr key={index}>\n                                <td>{selectors.format.formatDateTimeMinutes(charge.created_at)}</td>\n                                <td>\n                                    <ChargeStatusBadge status={charge.status} />\n                                </td>\n                                <td>{selectors.format.formatAmount(charge.amount)}</td>\n                            </tr>\n                        ))}\n                    </TableBody>\n                </Table>\n                {this.renderNoRows()}\n                <Pagination\n                    total={this.props.chargesTotal}\n                    limit={this.props.chargesLimit}\n                    skipped={this.props.chargesSkipped}\n                    onClick={(skip) => this.props.onGoTo(skip / this.props.chargesLimit + 1, skip)}\n                    disabled={this.props.isLoading}\n                />\n            </React.Fragment>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnerProps, ApplicationState> = (\n    state,\n    { isLoading = false },\n) => ({\n    charges: state.charge.list.items,\n    chargesSkipped: state.charge.list.skipped,\n    chargesTotal: state.charge.list.total,\n    chargesLimit: state.charge.list.limit,\n    isLoading: isActionRequesting(state.global.actions, 'fetch_charges') || isLoading,\n});\n\nexport default connect(mapStateToProps)(ChargesTable);\n","import * as React from 'react';\nimport { Card, CardBody, CardHeader } from 'reactstrap';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faLifeRing } from '@fortawesome/free-solid-svg-icons/faLifeRing';\n\nexport default function SupportCard() {\n    return (\n        <Card>\n            <CardHeader>\n                <div className=\"d-flex align-items-center\">\n                    <FontAwesomeIcon size={'lg'} icon={faLifeRing} className=\"mr-2\" />\n                    <div>Support</div>\n                </div>\n            </CardHeader>\n            <CardBody>\n                Need Help? Email{' '}\n                <a href=\"mailto:happiness@stronghold.co?Subject=Assistance - Stronghold Pay\">happiness@stronghold.co</a>{' '}\n                for assistance.\n            </CardBody>\n        </Card>\n    );\n}\n","import * as React from 'react';\nimport { Button, Modal, ModalHeader, ModalBody, ModalFooter, Spinner } from 'reactstrap';\nimport { PaymentSourceActionType } from './PaymentSourceActions';\nimport { ResponseError } from '../apis';\nimport Alert from 'reactstrap/lib/Alert';\n\ntype Props = {\n    showModal: boolean;\n    amount: number;\n    toggle: () => void;\n    onSubmit: () => void;\n    type: PaymentSourceActionType;\n    error: ResponseError | null;\n    isLoading: boolean;\n};\n\nexport default class ConfirmationModal extends React.Component<Props> {\n    formatErrorMessage = (errorCode: string) => {\n        switch (errorCode) {\n            case 'payment_source_has_pending_charge':\n                return 'Unable to unlink this payment source due to a recent change on an associated charge.';\n            default:\n                return 'An error has occured during the action.';\n        }\n    };\n\n    render() {\n        const { showModal, type, isLoading, error } = this.props;\n        const spinner = <Spinner type=\"grow\" color=\"black\" size=\"sm\" className=\"mr-1\" />;\n        const title = 'Payment Source';\n\n        const message = (\n            <span>\n                {' '}\n                Are you sure you want to <strong>{type}</strong> the {title}?\n            </span>\n        );\n\n        return (\n            <Modal isOpen={showModal} toggle={this.props.toggle}>\n                <ModalHeader className=\"text-capitalize\" toggle={this.props.toggle}>{`${type} ${title}`}</ModalHeader>\n                <ModalBody>\n                    <div className=\"my-3\">{message}</div>\n                    {error && (\n                        <Alert color=\"danger\">{error.code ? this.formatErrorMessage(error.code) : error.message}</Alert>\n                    )}\n                </ModalBody>\n                <ModalFooter>\n                    <Button color=\"primary\" disabled={isLoading} onClick={this.props.onSubmit}>\n                        {isLoading ? spinner : null}\n                        <span>Confirm</span>\n                    </Button>\n                    <Button color=\"secondary\" disabled={isLoading} onClick={this.props.toggle}>\n                        Cancel\n                    </Button>\n                </ModalFooter>\n            </Modal>\n        );\n    }\n}\n","import * as React from 'react';\nimport { Button, ButtonProps } from 'reactstrap';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport Badge from 'reactstrap/lib/Badge';\nimport { ResponseError } from '../apis';\nimport { PaymentSource } from '@stronghold/pay-dropin';\nimport { ApplicationState } from '../store';\nimport selectors from '../store/selectors';\nimport { deactivatePaymentSourceAction, removePaymentSourceAction } from '../store/actions';\nimport { filter } from 'lodash';\nimport ConfirmationModal from './ConfirmationModal';\n\ninterface StateProps {\n    errorMessage: ResponseError | null;\n    paymentSources: PaymentSource[];\n}\n\ninterface OwnProps extends ButtonProps {\n    paymentSource: PaymentSource;\n    customerId: string;\n}\n\ninterface DispatchProps {\n    deactivatePaymentSourceAction: typeof deactivatePaymentSourceAction;\n    removePaymentSourceAction: typeof removePaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\nexport type PaymentSourceActionType = 'remove' | null;\n\ninterface State {\n    ready: boolean;\n    showModal: boolean;\n    action: PaymentSourceActionType;\n}\n\nclass PaymentSourceActions extends React.Component<Props, State> {\n    public state: State = {\n        ready: true,\n        showModal: false,\n        action: null,\n    };\n\n    onActionClick = async (action: PaymentSourceActionType) => {\n        if (action === null) return;\n        await this.setState({ action });\n        this.toggleModal();\n    };\n\n    toggleModal = () => this.setState({ showModal: !this.state.showModal });\n\n    onSubmit = async () => {\n        const { paymentSource, paymentSources } = this.props;\n        this.setState({ ready: false });\n        try {\n            if (this.state.action === null) return;\n\n            const paymentSourcesToDelete = filter(\n                paymentSources,\n                (item) => item.unique_hash === paymentSource.unique_hash,\n            );\n\n            // remove payment sources\n            for (const el of paymentSourcesToDelete) {\n                await this.props.deactivatePaymentSourceAction(el.id);\n            }\n\n            this.toggleModal();\n            setTimeout(() => {\n                paymentSourcesToDelete.forEach((el) => this.props.removePaymentSourceAction(el.id));\n            }, 500);\n        } catch {\n            this.setState({ ready: true });\n            // Error\n        }\n        this.setState({ ready: true });\n    };\n\n    render() {\n        const { paymentSource, errorMessage } = this.props;\n\n        const { showModal } = this.state;\n        const isLoading = !this.state.ready;\n        const action = paymentSource.active ? 'remove' : null;\n\n        return (\n            <React.Fragment>\n                <ConfirmationModal\n                    amount={0}\n                    isLoading={isLoading}\n                    error={errorMessage}\n                    type={action}\n                    showModal={showModal}\n                    toggle={this.toggleModal}\n                    onSubmit={this.onSubmit}\n                />\n                {paymentSource.active ? (\n                    <Button\n                        className=\"text-capitalize\"\n                        color=\"link\"\n                        size=\"sm\"\n                        onClick={() => this.onActionClick(action)}\n                    >\n                        {action}\n                    </Button>\n                ) : (\n                    <Badge color={'danger'}>Deactivated</Badge>\n                )}\n            </React.Fragment>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    paymentSources: state.paymentSources.arr,\n    errorMessage: selectors.global.getResponseError(state.global.actions, 'update_payment_source'),\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            deactivatePaymentSourceAction,\n            removePaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PaymentSourceActions);\n","import * as React from 'react';\nimport { SPLIT_FLAG } from '../../store/types';\nimport { PropsWithChildren, ReactNode } from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport { selectTreatmentValue } from '@splitsoftware/splitio-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { fetchSplitTreatmentAction } from '../../store/actions/splitio';\n\ntype OwnProps = PropsWithChildren<{\n    flag: SPLIT_FLAG;\n    unactiveComponent?: ReactNode;\n}>;\n\ninterface StateProps {\n    treatment: string | null;\n}\n\ninterface DispatchProps {\n    fetchSplitTreatmentAction: typeof fetchSplitTreatmentAction;\n}\n\ntype Props = OwnProps & StateProps & DispatchProps;\n\nclass ToggleSplit extends React.Component<Props> {\n    componentDidMount = async () => {\n        const { flag } = this.props;\n        await this.props.fetchSplitTreatmentAction(flag);\n    };\n\n    render() {\n        const { treatment, unactiveComponent, children } = this.props;\n\n        if (treatment === 'on') {\n            return children;\n        }\n\n        return unactiveComponent || null;\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state, props: OwnProps) => ({\n    treatment: selectTreatmentValue(state.splitio, props.flag, state.global.merchant.id),\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchSplitTreatmentAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ToggleSplit);\n","import * as React from 'react';\nimport { MerchantModel } from '../apis';\nimport MerchantImg from './MerchantImg';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\n\ninterface StateProps {\n    merchant: MerchantModel;\n}\n\ntype Props = StateProps;\n\nfunction Merchant(props: Props) {\n    const { merchant } = props;\n\n    return (\n        <div data-sh=\"merchant\">\n            <MerchantImg />\n            <div className={'lead'}>{merchant.display_name}</div>\n            <small>{merchant.street_location.street1}, </small>\n            <small>{merchant.street_location.street2} </small>\n            <small>{merchant.street_location.street3} </small>\n            <small>\n                {merchant.street_location.city}, {merchant.street_location.state} {merchant.street_location.postcode}\n            </small>\n        </div>\n    );\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, void, ApplicationState> = (state) => ({\n    merchant: state.global.merchant,\n});\n\nexport default connect(mapStateToProps)(Merchant);\n","import * as React from 'react';\nimport { Button, Modal, ModalBody, ModalFooter, ModalHeader } from 'reactstrap';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { isNewPaymentSourceLinkedAction } from '../store/actions';\nimport { connect } from 'react-redux';\n\ntype OwnProps = {\n    showModal: boolean;\n};\n\ninterface DispatchProps {\n    isNewPaymentSourceLinkedAction: typeof isNewPaymentSourceLinkedAction;\n}\n\ntype Props = OwnProps & DispatchProps;\n\nclass NewPaymentSourceLinkedModal extends React.Component<Props> {\n    toggle = () => {\n        this.props.isNewPaymentSourceLinkedAction(false);\n    };\n\n    render() {\n        const { showModal } = this.props;\n        const message = <span> You’ve successfully linked your bank account and can use this payment method.</span>;\n        return (\n            <Modal isOpen={showModal} toggle={this.toggle}>\n                <ModalHeader className=\"text-capitalize\" toggle={this.toggle}>\n                    Congratulations!\n                </ModalHeader>\n                <ModalBody>\n                    <div className=\"my-3\">{message}</div>\n                </ModalBody>\n                <ModalFooter>\n                    <Button color=\"primary\" onClick={this.toggle}>\n                        <span>Close</span>\n                    </Button>\n                </ModalFooter>\n            </Modal>\n        );\n    }\n}\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            isNewPaymentSourceLinkedAction,\n        },\n        dispatch,\n    );\n\nexport default connect(null, mapDispatchToProps)(NewPaymentSourceLinkedModal);\n","import 'react';\nimport * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { Card, CardBody } from 'reactstrap';\nimport Layout from '../components/Layout';\nimport { Redirect } from 'react-router';\nimport { ROUTE } from '../config';\nimport selectors from '../store/selectors';\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\nimport CardHeader from 'reactstrap/lib/CardHeader';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faUniversity } from '@fortawesome/free-solid-svg-icons/faUniversity';\nimport { faIdCard } from '@fortawesome/free-solid-svg-icons/faIdCard';\nimport AddPaymentSourceButton from '../components/dropin/AddPaymentSourceButton';\nimport { PaymentSource } from '@stronghold/pay-dropin';\nimport StrongholdPay from '../components/StrongholdPay';\nimport { faReceipt } from '@fortawesome/free-solid-svg-icons/faReceipt';\nimport ChargesTable from '../components/charge/ChargesTable';\nimport { fetchChargesAction, deactivatePaymentSourceAction } from '../store/actions';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport SupportCard from '../components/SupportCard';\nimport PaymentSourceActions from '../components/PaymentSourceActions';\nimport { uniqBy } from 'lodash';\nimport ToggleSplit from '../components/split/ToggleSplit';\nimport { SPLIT_FLAG } from '../store/types';\nimport Merchant from '../components/Merchant';\nimport NewPaymentSourceLinkedModal from '../components/NewPaymentSourceLinkedModal';\n\ninterface StateProps {\n    isAuthenticated: boolean;\n    fullName: string;\n    email: string | null;\n    mobile: string | null;\n    paymentSources: PaymentSource[];\n    customerId: string | null;\n    isNewPaymentSourceLinked: boolean;\n}\n\ninterface DispatchProps {\n    fetchChargesAction: typeof fetchChargesAction;\n    deactivatePaymentSourceAction: typeof deactivatePaymentSourceAction;\n}\n\ntype Props = DispatchProps & StateProps;\n\nclass HomePage extends React.Component<Props> {\n    componentDidMount = async () => {\n        this.fetchCharges();\n    };\n\n    fetchCharges = (skip?: number) => {\n        this.props.fetchChargesAction({ skip });\n    };\n\n    render() {\n        const { isAuthenticated, customerId, paymentSources, isNewPaymentSourceLinked } = this.props;\n\n        if (!isAuthenticated) {\n            return <Redirect to={ROUTE.LOGIN} />;\n        }\n\n        return (\n            <Layout className=\"container\">\n                <Row>\n                    <Col lg={8} className=\"order-2 order-lg-1\">\n                        <Card>\n                            <CardHeader className=\"d-flex align-items-center\">\n                                <FontAwesomeIcon size={'lg'} icon={faIdCard} className=\"mr-2\" />\n                                <div>Profile</div>\n                            </CardHeader>\n                            <CardBody className=\"\">\n                                <Row className=\"mb-3\">\n                                    <Col className=\"font-weight-bold\" xs={4}>\n                                        Name\n                                    </Col>\n                                    <Col>{this.props.fullName}</Col>\n                                </Row>\n                                <Row className=\"mb-3\">\n                                    <Col className=\"font-weight-bold\" xs={4}>\n                                        Mobile\n                                    </Col>\n                                    <Col className=\"\">{this.props.mobile || '—'}</Col>\n                                </Row>\n                                <Row>\n                                    <Col className=\"font-weight-bold\" xs={4}>\n                                        Email\n                                    </Col>\n                                    <Col className=\"\">{this.props.email || '—'}</Col>\n                                </Row>\n                            </CardBody>\n                        </Card>\n                        <Card>\n                            <CardHeader>\n                                <div className=\"d-flex align-items-center\">\n                                    <FontAwesomeIcon size={'lg'} icon={faUniversity} className=\"mr-2\" />\n                                    <div>Payment Methods</div>\n                                </div>\n                            </CardHeader>\n                            <ul className=\"list-group list-group-flush\">\n                                {customerId &&\n                                    paymentSources &&\n                                    uniqBy(paymentSources, 'unique_hash').map((el) => (\n                                        <li\n                                            key={el.id}\n                                            className=\"list-group-item d-flex justify-content-between align-items-center\"\n                                        >\n                                            <div className=\"h5 my-0\">{el.label}</div>\n                                            <div className=\"h5 my-0\">\n                                                <PaymentSourceActions paymentSource={el} customerId={customerId} />\n                                            </div>\n                                        </li>\n                                    ))}\n                            </ul>\n                            <CardBody>\n                                <div className=\"d-flex justify-content-end\">\n                                    <AddPaymentSourceButton size={'sm'} />\n                                </div>\n                            </CardBody>\n                        </Card>\n                        <Card>\n                            <CardHeader className=\"d-flex align-items-center\">\n                                <FontAwesomeIcon size={'lg'} icon={faReceipt} className=\"mr-2\" />\n                                <div>Transactions</div>\n                            </CardHeader>\n                            <ChargesTable onGoTo={(page, skip) => this.fetchCharges(skip)} />\n                        </Card>\n                    </Col>\n                    <Col lg={4} className=\"order-1 order-lg-2\">\n                        <Card>\n                            <CardBody className=\"text-center\">\n                                <ToggleSplit flag={SPLIT_FLAG.SIMPLE_CHECKOUT} unactiveComponent={<Merchant />}>\n                                    <StrongholdPay />\n                                </ToggleSplit>\n                            </CardBody>\n                        </Card>\n                        <SupportCard />\n                    </Col>\n                </Row>\n                <NewPaymentSourceLinkedModal showModal={isNewPaymentSourceLinked} />\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, void, ApplicationState> = (state) => ({\n    isAuthenticated: state.authentication.isAuthenticated,\n    fullName: selectors.authentication.getFullName(state.authentication),\n    customerId: state.authentication.customer.id,\n    email: state.authentication.customer.individual.email,\n    mobile: state.authentication.customer.individual.mobile,\n    paymentSources: state.paymentSources.arr,\n    isNewPaymentSourceLinked: state.paymentSources.isNewPaymentSourceLinked,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchChargesAction,\n            deactivatePaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(HomePage);\n","import 'react';\nimport * as React from 'react';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport Form from 'reactstrap/lib/Form';\nimport { RouteComponentProps, withRouter } from 'react-router';\nimport AddPaymentSourceButton from '../components/dropin/AddPaymentSourceButton';\nimport { ROUTE } from '../config';\nimport Layout from '../components/Layout';\nimport MerchantImg from '../components/MerchantImg';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { isNewPaymentSourceLinkedAction } from '../store/actions';\nimport { bindActionCreators, Dispatch } from 'redux';\n\ninterface StateProps {\n    merchantDisplayName: string;\n}\n\ninterface DispatchProps {\n    isNewPaymentSourceLinkedAction: typeof isNewPaymentSourceLinkedAction;\n}\n\ntype Props = StateProps & DispatchProps & RouteComponentProps;\n\nclass LinkAccountPage extends React.PureComponent<Props> {\n    onSuccess = () => {\n        this.props.isNewPaymentSourceLinkedAction(true);\n        this.props.history.push(ROUTE.HOME);\n    };\n\n    public render() {\n        return (\n            <Layout navbar={false} centered>\n                <Card className=\"shadow-lg text-center\" style={{ maxWidth: 500 }}>\n                    <CardBody className=\"p-md-5\">\n                        <div className=\"h4\">\n                            Link account for <strong>{this.props.merchantDisplayName}</strong>\n                        </div>\n                        <MerchantImg />\n                        <div className=\"lead mb-4\">\n                            <p>\n                                In order to make payments you will need to securely verify and link your bank details.\n                            </p>\n                            <p>Your credentials will never be stored or shared.</p>\n                        </div>\n                        <Form>\n                            <AddPaymentSourceButton onSuccess={() => this.onSuccess()} />\n                        </Form>\n                    </CardBody>\n                </Card>\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, void, ApplicationState> = (state) => ({\n    merchantDisplayName: state.global.merchant.display_name,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            isNewPaymentSourceLinkedAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(LinkAccountPage));\n","import * as React from 'react';\nimport { RouteComponentProps, withRouter } from 'react-router-dom';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { logoutAction } from '../store/actions';\nimport { ROUTE } from '../config';\n\ntype OwnProps = RouteComponentProps;\n\ninterface DispatchProps {\n    logoutAction: typeof logoutAction;\n}\n\ntype Props = DispatchProps & OwnProps;\n\nclass LogoutPage extends React.Component<Props> {\n    componentDidMount(): void {\n        this.props.logoutAction();\n        this.props.history.push(ROUTE.LOGIN);\n    }\n\n    render() {\n        return null;\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<void, OwnProps, ApplicationState> = () => ({});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            logoutAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(LogoutPage));\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n\nimport * as React from 'react';\nimport Button from 'reactstrap/lib/Button';\nimport { getStrongholdPayClient } from '../../config';\nimport { fetchCustomerTokenAction, setActionRequestingAction, removePaymentSourceAction } from '../../store/actions';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { ChargeOnSuccess, ERROR_CODE, OnError, OnExit } from '@stronghold/pay-dropin';\nimport { ApplicationState } from '../../store';\nimport selectors from '../../store/selectors';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { ButtonProps } from 'reactstrap';\nimport { faMoneyBill } from '@fortawesome/free-solid-svg-icons/faMoneyBill';\nimport { ApiKeyModel } from '../../apis';\n\ninterface StateProps {\n    publishableKey: ApiKeyModel | null;\n    customerToken: string;\n    noSource: boolean;\n    isAuthorizingPayment: boolean;\n    integrationId?: string;\n    apiVersion: string;\n}\n\ninterface OwnProps extends ButtonProps {\n    payLinkCode: string;\n    paymentSourceId: string;\n    amount: number;\n    tipAmount?: number;\n    tipBeneficiaryName?: string;\n    onSuccess: ChargeOnSuccess;\n    creditAmount?: number;\n    processingFee?: number;\n}\n\ninterface DispatchProps {\n    fetchCustomerTokenAction: typeof fetchCustomerTokenAction;\n    setActionRequestingAction: typeof setActionRequestingAction;\n    removePaymentSourceAction: typeof removePaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ninterface State {\n    ready: boolean;\n}\n\nclass AddChargeDropinButton extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = { ready: true };\n    }\n\n    charge = async () => {\n        // Return if no key\n        if (!this.props.publishableKey) return;\n\n        this.props.setActionRequestingAction('authorize_payment', true);\n        try {\n            await this.props.fetchCustomerTokenAction();\n        } catch (e) {\n            this.props.setActionRequestingAction('authorize_payment', false);\n            // Something wrong happen, possibly display an error in the future\n            return;\n        }\n\n        // If for whatever reason there is no customer token, throw\n        if (!this.props.customerToken) throw new Error('no customer token');\n\n        const client = getStrongholdPayClient(\n            this.props.publishableKey.key,\n            this.props.publishableKey.environment,\n            this.props.apiVersion,\n            this.props.integrationId,\n        );\n        client.charge(this.props.customerToken, {\n            payLinkCode: this.props.payLinkCode,\n            skipSuccessScreen: true,\n            skipPayScreen: true,\n            charge: {\n                amount: this.props.amount,\n                paymentSourceId: this.props.paymentSourceId,\n            },\n            tip: this.props.tipAmount\n                ? {\n                      amount: this.props.tipAmount,\n                      beneficiaryName: this.props.tipBeneficiaryName || '',\n                  }\n                : undefined,\n            onSuccess: this.onSuccess,\n            onExit: this.onExit,\n            onError: this.onError,\n        });\n    };\n\n    updatePaymentMethod = async () => {\n        // Return if no key\n        if (!this.props.publishableKey) return;\n\n        this.setState({ ready: false });\n\n        const client = getStrongholdPayClient(\n            this.props.publishableKey.key,\n            this.props.publishableKey.environment,\n            this.props.apiVersion,\n            this.props.integrationId,\n        );\n        client.updatePaymentSource(this.props.customerToken, {\n            onSuccess: () => this.setState({ ready: true }),\n            onExit: () => this.setState({ ready: true }),\n            onError: (e) => {\n                this.setState({ ready: true });\n            },\n            paymentSourceId: this.props.paymentSourceId,\n        });\n    };\n\n    onSuccess: ChargeOnSuccess = (charge) => {\n        this.props.setActionRequestingAction('authorize_payment', false);\n        if (this.props.onSuccess) {\n            this.props.onSuccess(charge);\n        }\n    };\n\n    onError: OnError = async (e) => {\n        if (e.code === ERROR_CODE.PAYMENT_SOURCE_LOGIN_REQUIRED) {\n            this.setState({ ready: false });\n            // TODO: see how to fix latency of event listener\n            setTimeout(() => this.updatePaymentMethod(), 200);\n            return;\n        } else if (e.code === ERROR_CODE.PAYMENT_SOURCE_INACTIVE) {\n            this.setState({ ready: false });\n            this.props.removePaymentSourceAction(this.props.paymentSourceId);\n            return;\n        }\n        this.props.setActionRequestingAction('authorize_payment', false);\n    };\n\n    onExit: OnExit = () => {\n        this.props.setActionRequestingAction('authorize_payment', false);\n    };\n\n    render() {\n        const payAmount =\n            this.props.amount +\n            (this.props.tipAmount || 0) -\n            (this.props.creditAmount || 0) +\n            (this.props.processingFee || 0);\n        const {\n            children = <>PAY {selectors.number.amountToString(payAmount > 0 ? payAmount : 0)}</>,\n            payLinkCode,\n            isAuthorizingPayment,\n            customerToken,\n            paymentSourceId,\n            onSuccess,\n            onExit,\n            fetchCustomerTokenAction,\n            noSource,\n            setActionRequestingAction,\n            publishableKey,\n            merchantDisplayName,\n            paymentSourceLabel,\n            amount,\n            tipAmount = 0,\n            tipBeneficiaryName,\n            subButtonElement,\n            ...props\n        } = this.props;\n        const { ready } = this.state;\n\n        let icon = <FontAwesomeIcon icon={faMoneyBill} fixedWidth />;\n\n        const isLoading = isAuthorizingPayment;\n        const isDisabled = isLoading || noSource || props.disabled || !publishableKey || !ready || !amount;\n\n        if (isLoading) {\n            icon = <Spinner type=\"grow\" color=\"white\" size=\"sm\" />;\n        }\n\n        return (\n            <Button color=\"primary\" {...props} onClick={this.charge} data-sh=\"charge-button\" disabled={isDisabled}>\n                {children}\n                <span className=\"ml-2\">{icon}</span>\n            </Button>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    publishableKey: state.global.publishableApiKey,\n    customerToken: state.authentication.customerToken || '',\n    noSource: state.paymentSources.arr.length === 0,\n    isAuthorizingPayment: selectors.global.isActionRequesting(state.global.actions, 'authorize_payment'),\n    integrationId: state.attribution?.integrationId,\n    apiVersion: state.attribution.apiVersion,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchCustomerTokenAction,\n            setActionRequestingAction,\n            removePaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(AddChargeDropinButton);\n","import * as React from 'react';\nimport selectors from '../../store/selectors';\nimport { TipType } from '../../store/types';\n\nexport interface Props {\n    subAmount: number;\n    taxAmount: number;\n    convenienceFee: number;\n    processingFee: number;\n    totalAmount: number;\n    tipValue?: number;\n    tipType: TipType;\n    creditValue?: number;\n}\n\nexport default function CheckoutTotal(props: Props) {\n    const amountDetails = selectors.number.getAmountDetails({\n        convenienceFee: props.convenienceFee,\n        processingFee: props.processingFee,\n        taxAmount: props.taxAmount,\n        totalAmount: props.totalAmount,\n        subAmount: props.subAmount,\n        tipAmount: props.tipValue,\n        tipType: props.tipType,\n        creditValue: props.creditValue,\n    });\n\n    const taxAmountStr = amountDetails.taxAmount ? selectors.number.amountToString(amountDetails.taxAmount) : null;\n    const convenienceFeeStr =\n        amountDetails.convenienceFee || amountDetails.processingFee\n            ? selectors.number.amountToString(amountDetails.convenienceFee + amountDetails.processingFee)\n            : null;\n    const subAmountStr = selectors.number.amountToString(amountDetails.subAmount);\n    const tipAmountStr = amountDetails.tipAmount ? selectors.number.amountToString(amountDetails.tipAmount) : null;\n    const creditAmountStr = amountDetails.creditValue\n        ? selectors.number.amountToString(amountDetails.creditValue)\n        : null;\n    const fullAmountStr = selectors.number.amountToString(amountDetails.fullAmount);\n\n    return (\n        <div data-sh=\"order-amounts\">\n            <div className=\"d-flex justify-content-between h6\">\n                <div className=\"text-muted\">Subtotal</div>\n                <div className=\"text-muted\" data-sh=\"sub-amount\">\n                    {subAmountStr}\n                </div>\n            </div>\n            {taxAmountStr ? (\n                <div className=\"d-flex justify-content-between h6\">\n                    <div className=\"text-muted\">Tax</div>\n                    <div className=\"text-muted\" data-sh=\"tax-amount\">\n                        {taxAmountStr}\n                    </div>\n                </div>\n            ) : null}\n            {convenienceFeeStr ? (\n                <div className=\"d-flex justify-content-between h6\">\n                    <div className=\"text-muted\">Convenience Fee</div>\n                    <div className=\"text-muted\" data-sh=\"convenience-fee-amount\">\n                        {convenienceFeeStr}\n                    </div>\n                </div>\n            ) : null}\n            {tipAmountStr ? (\n                <div className=\"d-flex justify-content-between h6 font-weight-bold\">\n                    <div className=\"text-muted\">Tip</div>\n                    <div className=\"text-muted\" data-sh=\"tip-amount\">\n                        {tipAmountStr}\n                    </div>\n                </div>\n            ) : null}\n            {creditAmountStr ? (\n                <div className=\"d-flex justify-content-between h6\">\n                    <div className=\"text-muted\">Credit Amount</div>\n                    <div className=\"text-muted\" data-sh=\"credit-amount\">\n                        ({creditAmountStr})\n                    </div>\n                </div>\n            ) : null}\n            <div className=\"d-flex justify-content-between h5 font-weight-bolder\">\n                <div className=\"text\">Total</div>\n                <div className=\"text\" data-sh=\"amount\">\n                    {fullAmountStr}\n                </div>\n            </div>\n        </div>\n    );\n}\n","import React, { KeyboardEvent } from 'react';\nimport { Input, InputProps } from 'reactstrap';\n\ninterface Props extends InputProps {\n    className?: string;\n    max?: number;\n    onValueChange: (value: number) => void;\n    value: number;\n    prefix?: string;\n    suffix?: string;\n    digits?: number;\n}\n\nconst VALID_FIRST = /^[1-9]{1}$/;\nconst VALID_NEXT = /^[0-9]{1}$/;\nconst DELETE_KEY_CODE = 8;\nconst RETURN_KEY_CODE = 13;\n\nexport default class NumberInput extends React.Component<Props> {\n    handleKeyDown = (e: KeyboardEvent<HTMLDivElement>) => {\n        const { value, max, onValueChange } = this.props;\n        const { key, keyCode } = e;\n\n        if (keyCode === RETURN_KEY_CODE) {\n            e.currentTarget.blur();\n        }\n\n        if (\n            (value === 0 && !VALID_FIRST.test(key)) ||\n            (value !== 0 && !VALID_NEXT.test(key) && keyCode !== DELETE_KEY_CODE)\n        ) {\n            return;\n        }\n        const valueString = value.toString();\n        let nextValue: number;\n\n        if (keyCode !== DELETE_KEY_CODE) {\n            const nextValueString: string = value === 0 ? key : `${valueString}${key}`;\n            nextValue = Number.parseInt(nextValueString, 10);\n        } else {\n            const nextValueString = valueString.slice(0, -1);\n            nextValue = nextValueString === '' ? 0 : Number.parseInt(nextValueString, 10);\n        }\n\n        if (max && nextValue > max) {\n            return;\n        }\n\n        onValueChange(nextValue);\n    };\n\n    valueDisplay = () => {\n        const value = this.props.value / Math.pow(10, this.props.digits || 0);\n        return `${this.props.prefix || ''}${value.toFixed(this.props.digits || 0)}${this.props.suffix || ''}`;\n    };\n\n    render() {\n        const { className, value, ...props } = this.props;\n        const valueAbsTrunc = Math.trunc(Math.abs(value));\n\n        if (value !== valueAbsTrunc || !Number.isFinite(value) || Number.isNaN(value)) {\n            throw new Error(`invalid value property`);\n        }\n        return (\n            <Input\n                {...props}\n                className={className}\n                inputMode=\"numeric\"\n                onKeyDown={this.handleKeyDown}\n                value={this.valueDisplay()}\n            />\n        );\n    }\n}\n","import * as React from 'react';\nimport NumberInput from './NumberInput';\nimport { Button } from 'reactstrap';\nimport selectors from '../store/selectors';\nimport { TipCustomizationModel, TipType } from '../store/types';\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\n\ninterface Props {\n    originalAmount: number;\n    tipModel: TipCustomizationModel;\n    amount: number;\n    setDefaultValueOnChange?: boolean;\n    onSetAmount: (value: number, error: boolean) => void;\n}\n\ninterface State {\n    showAmountField: boolean;\n    errorMessage: string | null;\n    tips: number[];\n    tipType: TipType;\n}\n\nexport default class TipSelection extends React.Component<Props, State> {\n    private tipInput: HTMLInputElement | null = null;\n\n    constructor(props: Props) {\n        super(props);\n        this.state = {\n            showAmountField: false,\n            errorMessage: null,\n            tips: [],\n            tipType: 'fixed',\n        };\n    }\n\n    async componentDidMount() {\n        const tips = [this.props.tipModel.value1, this.props.tipModel.value2, this.props.tipModel.value3];\n        const isPercentage = this.props.tipModel.type === 'percentage';\n        // tips less than $1 throw an error at checkout, an issue when using type is percentage\n        // default to [1,2,3]\n        const tipAmount1 = selectors.number.getTipAmount(\n            this.props.tipModel.type,\n            this.props.tipModel.value1,\n            this.props.originalAmount,\n        );\n        if (isPercentage && tipAmount1 < 100) {\n            await this.setState({ tips: [100, 200, 300], tipType: 'fixed' });\n        } else {\n            await this.setState({ tips, tipType: this.props.tipModel.type });\n        }\n    }\n\n    selectTip = (tipValue: number): void => {\n        const amount = this.getAmount(tipValue);\n        this.onSetAmount(this.props.amount === amount ? 0 : amount);\n    };\n\n    toggleAmountField = async (): Promise<void> => {\n        const { tips, tipType } = this.state;\n        const tipAmounts = tips.map((tip) => selectors.number.getTipAmount(tipType, tip, this.props.originalAmount));\n        let tipAmount = this.props.amount;\n        // If we show the amount, we set to zero\n        if (this.props.amount === 0) {\n            this.props.onSetAmount(0, false);\n        } else {\n            if (this.state.showAmountField) {\n                // If tip amount does not match a default value, we set the second as a default\n                if (!tipAmounts.includes(this.props.amount)) {\n                    tipAmount = this.props.setDefaultValueOnChange ? tipAmounts[1] : 0;\n                }\n            }\n            this.props.onSetAmount(tipAmount, false);\n        }\n\n        await this.setState({\n            showAmountField: !this.state.showAmountField,\n            errorMessage: null,\n        });\n\n        if (this.tipInput && this.state.showAmountField) {\n            this.tipInput.focus();\n        }\n    };\n\n    onSetAmount = (tip: number): void => {\n        let errorMessage: string | null = null;\n        // We don't use custom percent amounts, it will always be fixed\n        if (this.state.showAmountField) {\n            if (tip === 0) {\n                // Not an error\n            } else if (tip < 100) {\n                errorMessage = 'Minimum tip amount is $1.00';\n            } else if (tip >= 10000) {\n                errorMessage = 'Maximum tip amount is $100';\n            }\n        }\n\n        this.setState({ errorMessage }, () => this.props.onSetAmount(tip, !!errorMessage));\n    };\n\n    getAmount = (value: number): number => {\n        const { originalAmount } = this.props;\n        const { tipType } = this.state;\n        return selectors.number.getTipAmount(tipType, value, originalAmount);\n    };\n\n    render() {\n        const { amount } = this.props;\n        const { tips, tipType } = this.state;\n\n        const renderTipButton = (tip: number) => {\n            const isPercent = tipType === 'percentage';\n            const tipSubValue = isPercent\n                ? selectors.number.amountToString(\n                      selectors.number.getTipAmount(tipType, tip, this.props.originalAmount),\n                  )\n                : null;\n\n            const tipValue = isPercent\n                ? `${Math.round(tip / 100)}%`\n                : selectors.number.amountToString(\n                      selectors.number.getTipAmount(tipType, tip, this.props.originalAmount),\n                  );\n\n            return (\n                <Col className=\"px-2\" key={tip}>\n                    <Button\n                        onClick={() => this.selectTip(tip)}\n                        outline={amount !== tip}\n                        active={amount === this.getAmount(tip)}\n                        size=\"lg\"\n                        className={'btn-tip'}\n                    >\n                        {tipValue}\n                        {/* only show for percentage tips */}\n                        {tipSubValue && <div className=\"dollar-amount\">{tipSubValue}</div>}\n                    </Button>\n                </Col>\n            );\n        };\n\n        return (\n            <div className=\"text-center\" data-sh=\"tip-selection\">\n                <div className=\"d-flex justify-content-center align-items-center mb-4\" data-sh=\"tip-value\">\n                    {this.state.showAmountField ? (\n                        <div className=\"d-block\">\n                            <NumberInput\n                                innerRef={(input) => {\n                                    this.tipInput = input as HTMLInputElement;\n                                }}\n                                className=\"mx-auto form-control-tip active\"\n                                onValueChange={this.onSetAmount}\n                                max={100000}\n                                value={this.props.amount}\n                                prefix={'$'}\n                                digits={2}\n                            />\n                            {this.state.errorMessage ? (\n                                <div className=\"mt-3 font-italic text-danger\">{this.state.errorMessage}</div>\n                            ) : null}\n                        </div>\n                    ) : (\n                        <Row className=\"justify-content-center\">{tips.map((tip) => renderTipButton(tip))}</Row>\n                    )}\n                </div>\n                <Button className=\"btn-custom-tip\" onClick={this.toggleAmountField} data-sh=\"tip-custom-button\">\n                    {!this.state.showAmountField ? 'Enter Custom Amount' : 'Use Predefined Amount'}\n                </Button>\n            </div>\n        );\n    }\n}\n","import * as React from 'react';\nimport { PayLinkTipModel, MerchantModel } from '../apis';\nimport selectors from '../store/selectors';\n\ninterface Props {\n    tipData: PayLinkTipModel;\n    merchant: MerchantModel;\n    orderAmount?: number;\n    orderCreatedAt?: string;\n}\n\nexport default function TipMessage(props: Props) {\n    const { tipData, orderAmount, orderCreatedAt } = props;\n    let forOrder = null;\n\n    let budtender = (\n        <React.Fragment>\n            <div\n                style={{ display: 'flex', justifyContent: 'center', alignItems: 'center', textAlign: 'center' }}\n                className=\"mt-3\"\n            >\n                <div>Tips go directly to our employees. Thank you for shopping with us.</div>\n            </div>\n        </React.Fragment>\n    );\n    if (tipData.details.display_message) {\n        budtender = (\n            <div className=\"mb-2\" data-sh=\"message\">\n                {tipData.details.display_message}\n            </div>\n        );\n    }\n    if (orderAmount) {\n        const originalAmountStr = selectors.number.amountToString(orderAmount);\n        forOrder = (\n            <small className=\"text-muted\">\n                for {originalAmountStr}\n                {orderCreatedAt ? <span> on {selectors.format.formatDateTimeMinutes(orderCreatedAt)}</span> : null}\n            </small>\n        );\n    }\n\n    return (\n        <div data-sh=\"tip-message\">\n            {budtender}\n            {forOrder}\n        </div>\n    );\n}\n","import * as React from 'react';\nimport selectors from '../../store/selectors';\n\ninterface Props {\n    merchantDisplayName: string;\n    paymentSourceLabel: string;\n    amount: number;\n}\n\nexport default function PaymentAuthorizationAggreement(props: Props) {\n    const { amount, merchantDisplayName, paymentSourceLabel } = props;\n    const amountStr = selectors.number.amountToString(amount);\n\n    return (\n        <div className=\"text-center mt-3\">\n            <small>\n                By clicking Pay above, you agree to the{' '}\n                <a href=\"https://stronghold.co/legal\">Stronghold Pay End User Agreement</a> and you authorize{' '}\n                <strong>{merchantDisplayName}</strong> to electronically debit your{' '}\n                <strong>{paymentSourceLabel}</strong> for <strong>{amountStr}</strong>.\n            </small>\n        </div>\n    );\n}\n","import * as React from 'react';\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { PaymentSource } from '@stronghold/pay-dropin';\nimport ListGroupItem from 'reactstrap/lib/ListGroupItem';\nimport FormGroup from 'reactstrap/lib/FormGroup';\nimport { Input } from 'reactstrap';\nimport Label from 'reactstrap/lib/Label';\nimport ListGroup from 'reactstrap/lib/ListGroup';\nimport MESSAGE from '../message';\nimport AddPaymentSourceButton from './dropin/AddPaymentSourceButton';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { deactivatePaymentSourceAction } from '../store/actions';\nimport PaymentSourceActions from './PaymentSourceActions';\nimport { uniqBy } from 'lodash';\nimport selectors from '../store/selectors';\nimport { CardType } from '../store/selectors/paymentSources';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCcVisa } from '@fortawesome/free-brands-svg-icons';\nimport { faCcMastercard } from '@fortawesome/free-brands-svg-icons';\nimport { faCcDinersClub } from '@fortawesome/free-brands-svg-icons';\nimport { faCcAmex } from '@fortawesome/free-brands-svg-icons';\n\ninterface StateProps {\n    paymentSources: PaymentSource[];\n    customerId: string | null;\n    payLinkId?: string;\n}\n\ntype OwnProps = {\n    paymentSourceId?: string | null;\n    onSelect?: (paymentSource: PaymentSource) => void;\n    disabled?: boolean;\n    canAddPaymentSource?: boolean;\n    flush?: boolean;\n};\n\ninterface DispatchProps {\n    deactivatePaymentSourceAction: typeof deactivatePaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\nclass PaymentSourceList extends React.PureComponent<Props> {\n    get selectable(): boolean {\n        return !!this.props.onSelect;\n    }\n\n    onSelectPaymentSource = (paymentSource: PaymentSource) => {\n        if (this.props.onSelect) {\n            this.props.onSelect(paymentSource);\n        }\n    };\n\n    renderCardTypeIcon = (provider: string) => {\n        switch (selectors.paymentSources.getTypeOfCard(provider)) {\n            case CardType.Visa:\n                return <FontAwesomeIcon className=\"mr-2\" size={'2x'} icon={faCcVisa} fixedWidth />;\n            case CardType.MasterCard:\n                return <FontAwesomeIcon className=\"mr-2\" size={'2x'} icon={faCcMastercard} fixedWidth />;\n            case CardType.AmericanExpress:\n                return <FontAwesomeIcon className=\"mr-2\" size={'2x'} icon={faCcAmex} fixedWidth />;\n            case CardType.DinersClub:\n                return <FontAwesomeIcon className=\"mr-2\" size={'2x'} icon={faCcDinersClub} fixedWidth />;\n            default:\n                return null;\n        }\n    };\n\n    render() {\n        const {\n            customerId,\n            disabled,\n            paymentSourceId,\n            paymentSources,\n            canAddPaymentSource = true,\n            flush = false,\n            payLinkId,\n        } = this.props;\n\n        let list = <div>{MESSAGE.PAYMENT_METHOD_NONE}</div>;\n        let buttonColor = 'primary';\n        let buttonText;\n        let buttonIconColor;\n\n        if (this.props.paymentSources.length > 0) {\n            buttonColor = 'light';\n            buttonIconColor = 'dark';\n            buttonText = MESSAGE.PAYMENT_METHOD_CHANGE;\n            list = (\n                <ListGroup data-sh=\"payment-sources\" flush={flush}>\n                    {customerId &&\n                        paymentSources &&\n                        uniqBy(paymentSources, 'unique_hash').map((el, key) => {\n                            let content = (\n                                <Label className=\"mb-0\" data-sh=\"name\">\n                                    <div className=\"d-flex align-items-center\">\n                                        {this.renderCardTypeIcon(el.provider_name)}\n                                        <span>{el.label}</span>\n                                    </div>\n                                </Label>\n                            );\n\n                            if (this.selectable) {\n                                content = (\n                                    <FormGroup check className=\"d-flex align-items-center\">\n                                        <Input\n                                            type=\"radio\"\n                                            name={`payment_source_${key}`}\n                                            checked={paymentSourceId === el.id}\n                                            readOnly={true}\n                                            className=\"mt-0\"\n                                        />\n                                        {content}\n                                        <div className=\"ml-auto\" onClick={(e) => e.stopPropagation()}>\n                                            <PaymentSourceActions paymentSource={el} customerId={customerId} />\n                                        </div>\n                                    </FormGroup>\n                                );\n                            }\n\n                            return (\n                                <ListGroupItem\n                                    key={key}\n                                    onClick={() => this.onSelectPaymentSource(el)}\n                                    active={el.id === paymentSourceId}\n                                    action={this.selectable}\n                                >\n                                    {content}\n                                </ListGroupItem>\n                            );\n                        })}\n                </ListGroup>\n            );\n        }\n\n        let button = <></>;\n\n        if (canAddPaymentSource) {\n            button = (\n                <div className=\"text-center mt-2\">\n                    <AddPaymentSourceButton\n                        color={buttonColor}\n                        size=\"md\"\n                        iconColor={buttonIconColor}\n                        disabled={disabled}\n                        onSuccess={this.onSelectPaymentSource}\n                        payLinkId={payLinkId}\n                    >\n                        {buttonText}\n                    </AddPaymentSourceButton>\n                </div>\n            );\n        }\n\n        return (\n            <React.Fragment>\n                <Row className=\"my-3 d-flex\">\n                    {this.props.paymentSources.length > 0 ? (\n                        <Col className=\"text-center\">{list}</Col>\n                    ) : (\n                        <Col>{button}</Col>\n                    )}\n                </Row>\n                <Row className=\"my-3 d-flex\">\n                    {this.props.paymentSources.length > 0 ? (\n                        <Col>{button}</Col>\n                    ) : (\n                        <Col className=\"text-center mt-4\">{list}</Col>\n                    )}\n                </Row>\n            </React.Fragment>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    paymentSources: state.paymentSources.arr,\n    customerId: state.authentication.customer.id,\n    payLinkId: state.payLink.data?.id,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            deactivatePaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PaymentSourceList);\n","import * as React from 'react';\nimport { PropsWithChildren } from 'react';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport MerchantImg from './MerchantImg';\nimport Card from 'reactstrap/lib/Card';\nimport Progress from 'reactstrap/lib/Progress';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport selectors from '../store/selectors';\nimport { faCheck } from '@fortawesome/free-solid-svg-icons/faCheck';\n\ninterface StateProps {\n    successUrlCallback: string | null;\n    merchantName: string;\n}\n\ntype OwnProps = PropsWithChildren<{\n    title: string;\n}>;\n\ntype Props = StateProps & OwnProps;\n\ninterface State {\n    progressEnabled: boolean;\n    progress: number;\n    redirecting: boolean;\n}\n\nclass PayLinkSuccessCard extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = {\n            progressEnabled: false,\n            progress: 0,\n            redirecting: false,\n        };\n    }\n\n    componentDidMount() {\n        if (this.props.successUrlCallback) {\n            this.setState({ progressEnabled: true });\n            setInterval(() => {\n                this.updateProgressBar();\n            }, 100);\n        }\n    }\n\n    updateProgressBar = () => {\n        if (!this.props.successUrlCallback) return;\n        if (!this.state.progressEnabled) return;\n\n        if (this.state.progress < 100) {\n            this.setState({ progress: this.state.progress + 3 });\n        } else {\n            setTimeout(() => {\n                if (this.props.successUrlCallback && !this.state.redirecting) {\n                    this.setState({ redirecting: true });\n                    window.location.href = this.props.successUrlCallback;\n                }\n            }, 500);\n        }\n    };\n\n    componentWillUnmount() {\n        this.setState({ progressEnabled: false });\n    }\n\n    render() {\n        const { title, children, merchantName } = this.props;\n        const { progress, progressEnabled } = this.state;\n\n        return (\n            <div className=\"h-100 d-flex align-items-center\">\n                <Card className=\"shadow-lg text-center mw-sm mx-auto m-3\">\n                    <CardBody className=\"p-md-5\">\n                        <MerchantImg className=\"mb-3\" />\n                        <h3 className=\"text-success\" data-sh=\"message\">\n                            {title} <FontAwesomeIcon icon={faCheck} />\n                        </h3>\n                        {children}\n                    </CardBody>\n                    {progressEnabled ? (\n                        <>\n                            <small>\n                                Taking you back to <strong>{merchantName}</strong>...\n                            </small>\n                            <Progress value={progress} striped animated className=\"progress-bar-bottom\" />\n                        </>\n                    ) : null}\n                </Card>\n            </div>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => {\n    return {\n        successUrlCallback: selectors.payLink.getSuccessUrlCallback(state),\n        merchantName: state.global.merchant.display_name,\n    };\n};\n\nconst mapDispatchToProps = (dispatch: Dispatch) => bindActionCreators({}, dispatch);\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PayLinkSuccessCard);\n","import * as React from 'react';\nimport MESSAGE from '../message';\n\nexport default function PaymentSourceRequiredWarning() {\n    return (\n        <div\n            style={{ display: 'flex', justifyContent: 'center', alignItems: 'center', textAlign: 'center' }}\n            className=\"mt-3\"\n        >\n            <div>{MESSAGE.PAYMENT_METHOD_NONE}</div>\n        </div>\n    );\n}\n","import React from 'react';\nimport { PayLinkModel, PayLinkOrderModel } from '../apis';\nimport TableBody from './TableBody';\nimport Table from 'reactstrap/lib/Table';\nimport selectors from '../store/selectors';\n\ninterface StateProps {\n    order: PayLinkOrderModel;\n}\n\ninterface OwnProps {\n    link: PayLinkModel | null;\n}\ntype Props = StateProps & OwnProps;\n\nexport default class UploadedDocuments extends React.Component<Props> {\n    render() {\n        return (\n            <div>\n                {this.props.order.documents && (\n                    <Table hover responsive className=\"table-sm\">\n                        <thead>\n                            <tr>\n                                <th style={{ minWidth: 140 }}>Name</th>\n                                <th>Size</th>\n                                <th>Link</th>\n                            </tr>\n                        </thead>\n                        <TableBody isLoading={false} rows={this.props.order.documents.length} columns={3}>\n                            {this.props.order.documents.map((document, index) => (\n                                <tr key={index}>\n                                    <td>{document.file_name}</td>\n                                    <td>{`${selectors.format.formatKB(document.file_size)} KB`}</td>\n                                    <td>\n                                        <a href={document.url} download={document.url} target=\"_blank\" rel=\"noreferrer\">\n                                            Download\n                                        </a>\n                                    </td>\n                                </tr>\n                            ))}\n                        </TableBody>\n                    </Table>\n                )}\n            </div>\n        );\n    }\n}\n","import * as React from 'react';\nimport Media from 'reactstrap/lib/Media';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faImage } from '@fortawesome/free-solid-svg-icons/faImage';\nimport selectors from '../../store/selectors';\nimport { OrderItemModel } from '../../apis';\n\nexport interface Props {\n    item: OrderItemModel;\n}\n\nexport default function OrderItem(props: Props) {\n    const { total_amount, price, description, image_url, name, quantity } = props.item;\n    return (\n        <Media className={`align-items-stretch`} data-sh=\"order-item\">\n            {image_url ? (\n                <img className=\"mr-3\" src={image_url} alt={name} width={52} height={52} />\n            ) : (\n                <FontAwesomeIcon icon={faImage} style={{ fontSize: 52 }} color={'lightgray'} className=\"mr-3\" />\n            )}\n            <div className=\"media-body d-flex justify-content-between\">\n                <div className=\"d-flex flex-column\">\n                    <div data-sh=\"name\">{name}</div>\n                    {description ? (\n                        <small data-sh=\"description\" className=\"text-break text-muted\">\n                            {description}\n                        </small>\n                    ) : null}\n                    {!!price && price !== total_amount ? (\n                        <small data-sh=\"price\">{selectors.number.amountToString(price)} per item</small>\n                    ) : null}\n                    <small data-sh=\"quantity\">x {quantity}</small>\n                </div>\n                <div className=\"d-flex justify-content-between\">\n                    <div data-sh=\"amount\" className=\"h5 mb-0 font-weight-bolder\">\n                        {selectors.number.amountToString(total_amount)}\n                    </div>\n                </div>\n            </div>\n        </Media>\n    );\n}\n","import * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { Card, CardBody, Button, ListGroupItem, ListGroup } from 'reactstrap';\nimport {\n    selectPaymentSourceAction,\n    setErrorMessageAction,\n    updateHeaderTitleAction,\n    updatePayLinkAction,\n} from '../../store/actions';\nimport { MerchantModel, PayLinkModel, PayLinkOrderModel, PayLinkTipModel } from '../../apis';\nimport { ChargeOnSuccess, PaymentSource } from '@stronghold/pay-dropin';\nimport CardHeader from 'reactstrap/lib/CardHeader';\nimport AddChargeDropinButton from '../../components/dropin/AddChargeDropinButton';\nimport CheckoutTotal from '../../components/checkout/CheckoutTotal';\nimport selectors from '../../store/selectors';\nimport MESSAGE from '../../message';\nimport TipSelection from '../../components/TipSelection';\nimport TipMessage from '../../components/TipMessage';\nimport PaymentAuthorizationAggreement from '../../components/dropin/PaymentAuthorizationAggreement';\nimport PaymentSourceList from '../../components/PaymentSourceList';\nimport { CustomizationType, SPLIT_FLAG, TipCustomizationModel } from '../../store/types';\nimport PayLinkSuccessCard from '../../components/PayLinkSuccessCard';\nimport PaymentSourceRequiredWarning from '../../components/PaymentSourceRequiredWarning';\nimport UploadedDocuments from '../../components/UploadedDocuments';\nimport StrongholdPay from '../../components/StrongholdPay';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faLongArrowAltRight } from '@fortawesome/free-solid-svg-icons';\nimport OrderItem from '../../components/checkout/OrderItem';\nimport ToggleSplit from '../../components/split/ToggleSplit';\n\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\n\ninterface StateProps {\n    paymentSources: PaymentSource[];\n    paymentSourceSelected: PaymentSource | null;\n    isAuthorizingPayment: boolean;\n    success_msg: string | null;\n    order: PayLinkOrderModel;\n    tipModel: TipCustomizationModel;\n    tipData: PayLinkTipModel;\n    merchant: MerchantModel;\n    creditValue: number;\n}\n\ninterface OwnProps {\n    link: PayLinkModel;\n}\n\ninterface DispatchProps {\n    setErrorMessageAction: typeof setErrorMessageAction;\n    updateHeaderTitleAction: typeof updateHeaderTitleAction;\n    updatePayLinkAction: typeof updatePayLinkAction;\n    selectPaymentSourceAction: typeof selectPaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ninterface State {\n    showSticky: boolean;\n    tipValue: number;\n    hasTipError: boolean;\n    fileList: PayLinkOrderModel | null;\n}\n\nclass CheckoutPage extends React.Component<Props, State> {\n    private orderSummary: HTMLDivElement | null = null;\n    private continueButton: HTMLDivElement | null = null;\n\n    constructor(props: Props) {\n        super(props);\n        this.state = {\n            showSticky: true,\n            tipValue: 0,\n            hasTipError: false,\n            fileList: null,\n        };\n    }\n\n    async componentDidMount() {\n        await this.props.updateHeaderTitleAction({\n            values: ['Checkout'],\n        });\n\n        window.addEventListener('scroll', this.onScroll);\n    }\n\n    componentWillUnmount() {\n        window.removeEventListener('scroll', this.onScroll);\n    }\n\n    onScroll = () => {\n        if (this.isFirstButtonInViewport() || !this.isEndButtonInViewport()) {\n            this.setState({ showSticky: true });\n        } else {\n            this.setState({ showSticky: false });\n        }\n    };\n\n    isFirstButtonInViewport = () => {\n        if (!this.continueButton) return false;\n        const top = this.continueButton.getBoundingClientRect().top;\n        return top >= 0 && top <= window.innerHeight;\n    };\n\n    isEndButtonInViewport = (offset = 0) => {\n        if (!this.orderSummary) return false;\n        const top = this.orderSummary.getBoundingClientRect().top;\n        return top + offset >= 0 && top - offset <= window.innerHeight;\n    };\n\n    scrollToPayment = () => {\n        if (!this.orderSummary) return false;\n        window.scrollTo(0, this.orderSummary.getBoundingClientRect().top);\n    };\n\n    onSuccess: ChargeOnSuccess = (charge) => {\n        this.props.updatePayLinkAction({ status: 'used', charge });\n    };\n\n    getAmountDetails = () => {\n        return selectors.number.getAmountDetails({\n            tipAmount: this.state.tipValue,\n            tipType: this.props.tipModel.type,\n            convenienceFee: this.props.order.convenience_fee,\n            processingFee: this.props.order.payment_processing_fee,\n            taxAmount: this.props.order.tax_amount,\n            totalAmount: this.props.order.total_amount,\n            subAmount: this.props.order.sub_amount,\n            creditValue: this.props.creditValue,\n        });\n    };\n\n    renderQuickPay = () => {\n        const amountDetails = this.getAmountDetails();\n        const totalAmountWithTip = selectors.number.amountToString(amountDetails.fullAmount);\n        return (\n            <>\n                <Card\n                    className={`sticky slider ${this.state.showSticky ? 'opened' : 'closed'}`}\n                    data-sh=\"sticky-slider\"\n                >\n                    <CardBody className=\"px-md-5 py-md-4 d-flex justify-content-between\">\n                        <div>\n                            <p className=\"m-0 text-primary font-weight-bold\">Order Total</p>\n                            <p className=\"m-0 font-weight-bold\" data-sh=\"amount\">\n                                {totalAmountWithTip}\n                            </p>\n                        </div>\n                        <Button\n                            className=\"text-uppercase\"\n                            disabled={this.props.isAuthorizingPayment}\n                            color={'primary'}\n                            onClick={this.scrollToPayment}\n                        >\n                            Pay Now\n                            <FontAwesomeIcon icon={faLongArrowAltRight} fixedWidth />\n                        </Button>\n                    </CardBody>\n                </Card>\n                <div ref={(el) => (this.continueButton = el)} className=\"mb-3\" />\n                <Card></Card>\n            </>\n        );\n    };\n\n    renderItems = () => {\n        if (this.props.order.items.length === 0) {\n            return null;\n        }\n\n        return (\n            <React.Fragment>\n                <CardHeader>Items</CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <ListGroup flush>\n                        {this.props.order.items.map((el, key) => (\n                            <ListGroupItem key={key} className=\"px-0 py-md-4\" id={`order-item-${key + 1}`}>\n                                <OrderItem item={el} />\n                            </ListGroupItem>\n                        ))}\n                    </ListGroup>\n                </CardBody>\n            </React.Fragment>\n        );\n    };\n\n    renderPaymentMethod = () => {\n        const header = MESSAGE.PAYMENT_METHOD_SELECT_TITLE;\n\n        return (\n            <>\n                <CardHeader>\n                    <strong>{header}</strong>\n                </CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <div className=\"pl-md-5 pr-md-5\">\n                        <PaymentSourceList\n                            paymentSourceId={this.props.paymentSourceSelected?.id}\n                            onSelect={(paymentSource) => this.props.selectPaymentSourceAction(paymentSource.id)}\n                            disabled={this.props.isAuthorizingPayment}\n                        />\n                    </div>\n                </CardBody>\n            </>\n        );\n    };\n\n    renderTip = () => {\n        const { tipModel, tipData, merchant } = this.props;\n\n        const amountDetails = this.getAmountDetails();\n        if (!tipData) return null;\n\n        return (\n            <React.Fragment>\n                <CardHeader>\n                    <strong>Add a tip</strong>\n                </CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <div className=\"pl-md-5 pr-md-5\">\n                        <Row className=\"my-3 d-flex\">\n                            <Col>\n                                <div className=\"text-center mb-2\">{MESSAGE.SELECT_OR_ADD_TIP}</div>\n                                <TipSelection\n                                    originalAmount={amountDetails.totalAmountWithFees + amountDetails.processingFee}\n                                    tipModel={tipModel}\n                                    amount={this.state.tipValue}\n                                    onSetAmount={(tipValue, hasTipError) => this.setState({ tipValue, hasTipError })}\n                                />\n                            </Col>\n                        </Row>\n                        <Row className=\"my-3 d-flex\">\n                            <Col>\n                                <TipMessage tipData={tipData} merchant={merchant} />\n                            </Col>\n                        </Row>\n                    </div>\n                </CardBody>\n            </React.Fragment>\n        );\n    };\n\n    renderPdf = () => {\n        const { order, link } = this.props;\n\n        if (this.props.order.documents && this.props.order.documents.length === 0) {\n            return null;\n        }\n        return (\n            <React.Fragment>\n                <CardHeader>Order Documents</CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <div className=\"text-center mb-3\">\n                        <UploadedDocuments order={order} link={link} />\n                    </div>\n                </CardBody>\n            </React.Fragment>\n        );\n    };\n\n    renderTotal = () => {\n        const { isAuthorizingPayment, order, link, tipModel, paymentSourceSelected } = this.props;\n        const { id, merchant } = link;\n        const { tipValue, hasTipError } = this.state;\n\n        const amountDetails = this.getAmountDetails();\n\n        const payment = (\n            <React.Fragment>\n                <AddChargeDropinButton\n                    payLinkCode={id}\n                    paymentSourceId={paymentSourceSelected?.id || ''}\n                    amount={amountDetails.totalAmountWithFees}\n                    tipAmount={amountDetails.tipAmount}\n                    creditAmount={amountDetails.creditValue}\n                    processingFee={amountDetails.processingFee}\n                    tipBeneficiaryName={link.tip ? link.tip.beneficiary_name : undefined}\n                    disabled={!paymentSourceSelected?.id || isAuthorizingPayment || hasTipError}\n                    onSuccess={this.onSuccess}\n                    size=\"lg\"\n                    className=\"mt-3 mb-1\"\n                    block\n                />\n                {paymentSourceSelected ? (\n                    <PaymentAuthorizationAggreement\n                        merchantDisplayName={merchant.display_name}\n                        paymentSourceLabel={paymentSourceSelected.label}\n                        amount={amountDetails.fullAmount}\n                    />\n                ) : (\n                    <PaymentSourceRequiredWarning />\n                )}\n            </React.Fragment>\n        );\n\n        return (\n            <CardBody className=\"p-md-5 border-top\">\n                <div className=\"pl-md-5 pr-md-5\">\n                    <CheckoutTotal\n                        totalAmount={order.total_amount}\n                        convenienceFee={order.convenience_fee}\n                        processingFee={order.payment_processing_fee}\n                        subAmount={order.sub_amount}\n                        taxAmount={order.tax_amount}\n                        tipValue={tipValue || undefined}\n                        tipType={tipModel.type}\n                        creditValue={this.props.creditValue}\n                    />\n                    {payment}\n                    <div ref={(el) => (this.orderSummary = el)} />\n                </div>\n            </CardBody>\n        );\n    };\n\n    renderSuccessMsg = () => {\n        const { display_name } = this.props.link.merchant;\n        const { success_msg } = this.props;\n\n        return (\n            <div data-sh=\"description\">\n                <p>{`Your payment to ${display_name} was received.`}</p>\n                <div>{success_msg}</div>\n            </div>\n        );\n    };\n\n    render() {\n        const { status } = this.props.link;\n\n        if (status === 'used') {\n            return <PayLinkSuccessCard title=\"Success\">{this.renderSuccessMsg()}</PayLinkSuccessCard>;\n        }\n\n        return (\n            <div onScroll={this.onScroll} className=\"mt-3\">\n                <Card>\n                    <CardBody className=\"p-md-5 text-center\">\n                        <StrongholdPay />\n                    </CardBody>\n                    <ToggleSplit flag={SPLIT_FLAG.SIMPLE_CHECKOUT} unactiveComponent={this.renderItems()}>\n                        {null}\n                    </ToggleSplit>\n                    {this.renderPdf()}\n                    {this.renderPaymentMethod()}\n                    {this.renderTip()}\n                    {this.renderTotal()}\n                </Card>\n            </div>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state, ownProps) => {\n    return {\n        paymentSources: state.paymentSources.arr,\n        paymentSourceSelected: selectors.paymentSources.getPaymentSourceSelected(state),\n        tipModel: state.global.merchant.customization.tip,\n        success_msg: selectors.customizations.getCustomization(\n            state.global.merchant.customization.items,\n            CustomizationType.SuccessScreen,\n        ),\n        isAuthorizingPayment: selectors.global.isActionRequesting(state.global.actions, 'authorize_payment'),\n        order: ownProps.link.order as PayLinkOrderModel, // Link must have an order here\n        tipData: ownProps.link.tip as PayLinkTipModel,\n        merchant: state.global.merchant,\n        creditValue: state.credits.creditValue,\n    };\n};\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            setErrorMessageAction,\n            updateHeaderTitleAction,\n            updatePayLinkAction,\n            selectPaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CheckoutPage);\n","import * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport {\n    setErrorMessageAction,\n    updatePayLinkAction,\n    updateHeaderTitleAction,\n    selectPaymentSourceAction,\n} from '../../store/actions';\nimport { PayLinkModel } from '../../apis';\nimport { PaymentSource } from '@stronghold/pay-dropin';\nimport StrongholdPay from '../../components/StrongholdPay';\nimport CardHeader from 'reactstrap/lib/CardHeader';\nimport AddPaymentSourceButton from '../../components/dropin/AddPaymentSourceButton';\nimport PaymentSourceList from '../../components/PaymentSourceList';\nimport PayLinkSuccessCard from '../../components/PayLinkSuccessCard';\nimport ToggleSplit from '../../components/split/ToggleSplit';\nimport { SPLIT_FLAG } from '../../store/types';\nimport Merchant from '../../components/Merchant';\n\ninterface StateProps {\n    paymentSources: PaymentSource[];\n    isUsed: boolean;\n}\n\ninterface OwnProps {\n    link: PayLinkModel;\n}\n\ninterface DispatchProps {\n    setErrorMessageAction: typeof setErrorMessageAction;\n    updateHeaderTitleAction: typeof updateHeaderTitleAction;\n    updatePayLinkAction: typeof updatePayLinkAction;\n    selectPaymentSourceAction: typeof selectPaymentSourceAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\nclass BankLinkPage extends React.Component<Props> {\n    async componentDidMount() {\n        await this.props.updateHeaderTitleAction({\n            values: ['Bank Link'],\n        });\n    }\n\n    render() {\n        const { isUsed } = this.props;\n\n        if (isUsed) {\n            return (\n                <PayLinkSuccessCard title=\"Success\">\n                    <div>\n                        Your bank account has been linked successfully and you are{' '}\n                        <strong>ready to make payments.</strong>\n                    </div>\n                </PayLinkSuccessCard>\n            );\n        }\n\n        let paymentMethods = <></>;\n\n        if (this.props.paymentSources.length > 0) {\n            paymentMethods = (\n                <Card>\n                    <CardHeader>Linked Payment Methods</CardHeader>\n                    <PaymentSourceList canAddPaymentSource={false} flush={true} />\n                </Card>\n            );\n        }\n\n        return (\n            <>\n                <Card className=\"mt-3\">\n                    <CardBody className=\"p-md-5 text-center\">\n                        <ToggleSplit flag={SPLIT_FLAG.SIMPLE_CHECKOUT} unactiveComponent={<Merchant />}>\n                            <StrongholdPay />\n                        </ToggleSplit>\n                        <br />\n                    </CardBody>\n                </Card>\n                {paymentMethods}\n                <Card>\n                    <CardBody className=\"p-md-5 text-center\">\n                        <div className=\"mb-3\">\n                            Link a bank account to make payments with{' '}\n                            <strong>{this.props.link.merchant.display_name}</strong>.\n                        </div>\n                        <AddPaymentSourceButton\n                            onSuccess={(source) => {\n                                this.props.updatePayLinkAction({ status: 'used' });\n                                this.props.selectPaymentSourceAction(source.id);\n                            }}\n                            payLinkId={this.props.link.id}\n                            block\n                            size=\"lg\"\n                        />\n                    </CardBody>\n                </Card>\n            </>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state, ownProps) => ({\n    paymentSources: state.paymentSources.arr,\n    isUsed: ownProps.link.status === 'used',\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            setErrorMessageAction,\n            updateHeaderTitleAction,\n            updatePayLinkAction,\n            selectPaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(BankLinkPage);\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n\nimport * as React from 'react';\nimport Button from 'reactstrap/lib/Button';\nimport { getStrongholdPayClient } from '../../config';\nimport { fetchCustomerTokenAction, setActionRequestingAction } from '../../store/actions';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { ERROR_CODE, OnError, OnExit, TipDropin, TipOnSuccess } from '@stronghold/pay-dropin';\nimport { ApplicationState } from '../../store';\nimport selectors from '../../store/selectors';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { ButtonProps } from 'reactstrap';\nimport { faMoneyBill } from '@fortawesome/free-solid-svg-icons/faMoneyBill';\nimport { ApiKeyModel } from '../../apis';\n\ninterface StateProps {\n    publishableKey: ApiKeyModel | null;\n    customerToken: string;\n    noSource: boolean;\n    isAuthorizingPayment: boolean;\n    integrationId?: string;\n    apiVersion: string;\n}\n\ninterface OwnProps extends ButtonProps {\n    payLinkCode: string;\n    tip: TipDropin;\n    onSuccess: TipOnSuccess;\n}\n\ninterface DispatchProps {\n    fetchCustomerTokenAction: typeof fetchCustomerTokenAction;\n    setActionRequestingAction: typeof setActionRequestingAction;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ninterface State {\n    ready: boolean;\n}\n\nclass AddTipDropinButton extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = { ready: true };\n    }\n\n    charge = async () => {\n        // Return if no key\n        if (!this.props.publishableKey) return;\n\n        this.props.setActionRequestingAction('authorize_payment', true);\n        try {\n            await this.props.fetchCustomerTokenAction();\n        } catch (e) {\n            this.props.setActionRequestingAction('authorize_payment', false);\n            // Something wrong happen, possibly display an error in the future\n            return;\n        }\n\n        // If for whatever reason there is no customer token, throw\n        if (!this.props.customerToken) throw new Error('no customer token');\n\n        const client = getStrongholdPayClient(\n            this.props.publishableKey.key,\n            this.props.publishableKey.environment,\n            this.props.apiVersion,\n            this.props.integrationId,\n        );\n        client.tip(this.props.customerToken, {\n            payLinkCode: this.props.payLinkCode,\n            skipPayScreen: true,\n            skipSuccessScreen: true,\n            tip: {\n                amount: this.props.tip.amount,\n                beneficiaryName: this.props.tip.beneficiaryName,\n                paymentSourceId: this.props.tip.paymentSourceId,\n                chargeId: this.props.tip.chargeId,\n                details: this.props.tip.details,\n            },\n            onSuccess: this.onSuccess,\n            onExit: this.onExit,\n            onError: this.onError,\n        });\n    };\n\n    updatePaymentMethod = async () => {\n        // Return if no key\n        if (!this.props.publishableKey) return;\n\n        this.setState({ ready: false });\n\n        const client = getStrongholdPayClient(\n            this.props.publishableKey.key,\n            this.props.publishableKey.environment,\n            this.props.apiVersion,\n            this.props.integrationId,\n        );\n        client.updatePaymentSource(this.props.customerToken, {\n            onSuccess: () => this.setState({ ready: true }),\n            onExit: () => this.setState({ ready: true }),\n            onError: (e) => {\n                this.setState({ ready: true });\n            },\n            paymentSourceId: this.props.paymentSourceId,\n        });\n    };\n\n    onSuccess: TipOnSuccess = (charge) => {\n        this.props.setActionRequestingAction('authorize_payment', false);\n        if (this.props.onSuccess) {\n            this.props.onSuccess(charge);\n        }\n    };\n\n    onError: OnError = async (e) => {\n        if (e.code === ERROR_CODE.PAYMENT_SOURCE_LOGIN_REQUIRED) {\n            this.setState({ ready: false });\n            // TODO: see how to fix latency of event listener\n            setTimeout(() => this.updatePaymentMethod(), 200);\n            return;\n        }\n        this.props.setActionRequestingAction('authorize_payment', false);\n    };\n\n    onExit: OnExit = () => {\n        this.props.setActionRequestingAction('authorize_payment', false);\n    };\n\n    render() {\n        const {\n            children = <React.Fragment>PAY</React.Fragment>,\n            payLinkCode,\n            isAuthorizingPayment,\n            customerToken,\n            paymentSourceId,\n            onSuccess,\n            onExit,\n            fetchCustomerTokenAction,\n            noSource,\n            setActionRequestingAction,\n            publishableKey,\n            chargeId,\n            tip,\n            ...props\n        } = this.props;\n        const { ready } = this.state;\n\n        let icon = <FontAwesomeIcon icon={faMoneyBill} fixedWidth />;\n\n        const isLoading = isAuthorizingPayment;\n        const isDisabled = isLoading || noSource || props.disabled || !publishableKey || !ready || !tip.amount;\n\n        if (isLoading) {\n            icon = <Spinner type=\"grow\" color=\"white\" size=\"sm\" />;\n        }\n\n        return (\n            <Button color=\"primary\" {...props} onClick={this.charge} data-sh=\"charge-button\" disabled={isDisabled}>\n                {children}\n                <span className=\"ml-2\">{icon}</span>\n            </Button>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    publishableKey: state.global.publishableApiKey,\n    customerToken: state.authentication.customerToken || '',\n    noSource: state.paymentSources.arr.length === 0,\n    isAuthorizingPayment: selectors.global.isActionRequesting(state.global.actions, 'authorize_payment'),\n    integrationId: state.attribution?.integrationId,\n    apiVersion: state.attribution.apiVersion,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchCustomerTokenAction,\n            setActionRequestingAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(AddTipDropinButton);\n","import * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport {\n    selectPaymentSourceAction,\n    setErrorMessageAction,\n    updateHeaderTitleAction,\n    updatePayLinkAction,\n} from '../../store/actions';\nimport CardHeader from 'reactstrap/lib/CardHeader';\nimport selectors from '../../store/selectors';\nimport StrongholdPay from '../../components/StrongholdPay';\nimport { Charge, PaymentSource, TipOnSuccess } from '@stronghold/pay-dropin';\nimport { PayLinkModel, PayLinkTipModel } from '../../apis';\nimport PaymentSourceList from '../../components/PaymentSourceList';\nimport MESSAGE from '../../message';\nimport TipSelection from '../../components/TipSelection';\nimport TipMessage from '../../components/TipMessage';\nimport PaymentAuthorizationAggreement from '../../components/dropin/PaymentAuthorizationAggreement';\nimport AddTipDropinButton from '../../components/dropin/AddTipDropinButton';\nimport { SPLIT_FLAG, TipCustomizationModel } from '../../store/types';\nimport PayLinkSuccessCard from '../../components/PayLinkSuccessCard';\nimport PaymentSourceRequiredWarning from '../../components/PaymentSourceRequiredWarning';\nimport ToggleSplit from '../../components/split/ToggleSplit';\nimport Merchant from '../../components/Merchant';\n\ninterface StateProps {\n    paymentSources: PaymentSource[];\n    paymentSourceSelected: PaymentSource | null;\n    isAuthorizingPayment: boolean;\n    tipCustomization: TipCustomizationModel;\n    tipData: PayLinkTipModel;\n    charge: Charge;\n}\n\ninterface DispatchProps {\n    setErrorMessageAction: typeof setErrorMessageAction;\n    updateHeaderTitleAction: typeof updateHeaderTitleAction;\n    updatePayLinkAction: typeof updatePayLinkAction;\n    selectPaymentSourceAction: typeof selectPaymentSourceAction;\n}\n\ninterface OwnProps {\n    link: PayLinkModel;\n}\n\ntype Props = StateProps & OwnProps & DispatchProps;\n\ninterface State {\n    tipValue: number;\n    hasTipError: boolean;\n}\n\nclass TipPage extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n        this.state = {\n            tipValue: selectors.number.getTipAmount(\n                this.props.tipCustomization.type,\n                this.props.tipCustomization.value2,\n                this.props.charge.amount,\n            ),\n            hasTipError: false,\n        };\n    }\n\n    async componentDidMount() {\n        let title = 'Tip';\n        if (this.props.tipData.beneficiary_name) {\n            title = `${this.props.tipData.beneficiary_name} ${title}`;\n        }\n        this.props.updateHeaderTitleAction({\n            values: [title],\n        });\n    }\n\n    onSuccess: TipOnSuccess = (tip) => {\n        this.props.updatePayLinkAction({\n            status: 'used',\n            tip,\n        });\n    };\n\n    getAmount = () => this.state.tipValue;\n    getAmountStr = () => selectors.number.amountToString(this.getAmount());\n\n    renderOrderDetails = () => {\n        const { charge, link, tipData } = this.props;\n\n        return (\n            <CardBody className=\"p-md-5 text-center border-top\">\n                <TipMessage\n                    tipData={tipData}\n                    merchant={link.merchant}\n                    orderAmount={charge.amount}\n                    orderCreatedAt={charge.created_at}\n                />\n            </CardBody>\n        );\n    };\n\n    renderTip = () => {\n        const { charge, tipCustomization } = this.props;\n        return (\n            <React.Fragment>\n                <CardHeader>Add a tip</CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <TipSelection\n                        originalAmount={charge.amount}\n                        tipModel={tipCustomization}\n                        amount={this.state.tipValue}\n                        setDefaultValueOnChange\n                        onSetAmount={(tipValue, hasTipError) => this.setState({ tipValue, hasTipError })}\n                    />\n                </CardBody>\n            </React.Fragment>\n        );\n    };\n\n    renderPaymentMethod = () => {\n        const header = MESSAGE.PAYMENT_METHOD_SELECT_TITLE;\n\n        return (\n            <>\n                <CardHeader>{header}</CardHeader>\n                <CardBody className=\"p-md-5\">\n                    <PaymentSourceList\n                        paymentSourceId={this.props.paymentSourceSelected?.id}\n                        onSelect={(paymentSource) => this.props.selectPaymentSourceAction(paymentSource.id)}\n                        disabled={this.props.isAuthorizingPayment}\n                    />\n                </CardBody>\n            </>\n        );\n    };\n\n    renderTotal = () => {\n        const { isAuthorizingPayment, link, charge, tipData, paymentSourceSelected } = this.props;\n        const { hasTipError } = this.state;\n\n        return (\n            <CardBody className=\"p-md-5 border-top\">\n                <div className=\"text-muted text-center mb-2\">\n                    Your order was {selectors.number.amountToString(charge.amount)}\n                </div>\n                <AddTipDropinButton\n                    payLinkCode={link.id}\n                    tip={{\n                        chargeId: charge.id,\n                        paymentSourceId: paymentSourceSelected?.id || '',\n                        beneficiaryName: tipData.beneficiary_name,\n                        amount: this.getAmount(),\n                        details: tipData.details\n                            ? {\n                                  displayMessage: tipData.details.display_message,\n                                  drawerId: tipData.details.drawer_id,\n                                  terminalId: tipData.details.terminal_id,\n                              }\n                            : undefined,\n                    }}\n                    disabled={!paymentSourceSelected?.id || isAuthorizingPayment || hasTipError}\n                    onSuccess={this.onSuccess}\n                    size=\"lg\"\n                    className=\"mb-1\"\n                    block\n                >\n                    Tip {this.getAmountStr()}\n                </AddTipDropinButton>\n                {paymentSourceSelected ? (\n                    <PaymentAuthorizationAggreement\n                        merchantDisplayName={link.merchant.display_name}\n                        paymentSourceLabel={paymentSourceSelected.label}\n                        amount={this.getAmount()}\n                    />\n                ) : (\n                    <PaymentSourceRequiredWarning />\n                )}\n            </CardBody>\n        );\n    };\n\n    render() {\n        const { link, tipData } = this.props;\n        const { status } = link;\n\n        if (status === 'used') {\n            return (\n                <PayLinkSuccessCard title=\"Success\">\n                    <p>\n                        Your tip{' '}\n                        <span>\n                            to <span className=\"text-capitalize\">{tipData.beneficiary_name}</span>\n                        </span>{' '}\n                        was received.\n                    </p>\n                    <div>{\"Thanks for tipping! — We've updated your order receipt.\"}</div>\n                </PayLinkSuccessCard>\n            );\n        }\n\n        return (\n            <Card className=\"mt-3\">\n                <CardBody className=\"p-md-5 text-center\">\n                    <ToggleSplit flag={SPLIT_FLAG.SIMPLE_CHECKOUT} unactiveComponent={<Merchant />}>\n                        <StrongholdPay />\n                    </ToggleSplit>\n                </CardBody>\n                {this.renderOrderDetails()}\n                {this.renderTip()}\n                {this.renderPaymentMethod()}\n                {this.renderTotal()}\n            </Card>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state, ownProps) => {\n    return {\n        paymentSources: state.paymentSources.arr,\n        paymentSourceSelected: selectors.paymentSources.getPaymentSourceSelected(state),\n        tipCustomization: state.global.merchant.customization.tip,\n        isAuthorizingPayment: selectors.global.isActionRequesting(state.global.actions, 'authorize_payment'),\n        tipData: ownProps.link.tip as PayLinkTipModel,\n        charge: ownProps.link.charge as Charge,\n    };\n};\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            setErrorMessageAction,\n            updateHeaderTitleAction,\n            updatePayLinkAction,\n            selectPaymentSourceAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(TipPage);\n","let environment: string | null;\n\nexport default {\n    set environment(value: string | null) {\n        environment = value;\n    },\n\n    identify(userid: string) {\n        if (!environment) return;\n        analytics.identify(userid);\n    },\n};\n","import * as React from 'react';\nimport { FormEvent } from 'react';\nimport Form from 'reactstrap/lib/Form';\nimport Input from 'reactstrap/lib/Input';\nimport Button from 'reactstrap/lib/Button';\nimport FormGroup from 'reactstrap/lib/FormGroup';\nimport Label from 'reactstrap/lib/Label';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport {\n    resendTokenAction,\n    resetActionStatusAction,\n    setPayLinkCustomerAction,\n    signupAction,\n} from '../../store/actions';\nimport { ApplicationState } from '../../store';\nimport {\n    AuthenticationMethod,\n    CustomerModel,\n    addCustomer,\n    ResponseError,\n    ResponseErrorCode,\n    PayLinkModel,\n} from '../../apis';\nimport selectors from '../../store/selectors';\nimport ReactDatePicker from 'react-datepicker';\nimport moment from 'moment';\nimport { FORMAT_DATE } from '../../config';\nimport FormFeedback from 'reactstrap/lib/FormFeedback';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faLongArrowAltRight } from '@fortawesome/free-solid-svg-icons/faLongArrowAltRight';\nimport PhoneNumberInput from '../PhoneNumberInput';\nimport querystring from 'querystring';\nimport { Link } from 'react-router-dom';\nimport VerificationCodeModal from '../VerificationCodeModal';\n\ninterface StateProps {\n    isRequesting: boolean;\n    error: ResponseError | null;\n    customer: CustomerModel | null;\n    link: PayLinkModel | null;\n    environment: string;\n}\n\ninterface DispatchProps {\n    resetForm: typeof resetActionStatusAction;\n    signup: typeof signupAction;\n    resend: typeof resendTokenAction;\n    linkCustomer: typeof setPayLinkCustomerAction;\n}\n\ninterface OwnProps {\n    onSuccess: () => void;\n    payLinkId?: string;\n}\n\ntype Props = StateProps & DispatchProps & OwnProps;\n\ninterface State {\n    first_name: string;\n    last_name: string;\n    date_of_birth: Date | null;\n    mobile: string;\n    email: string;\n    authenticationMethod: AuthenticationMethod;\n    show_sms: boolean;\n    showModal: boolean;\n}\n\nfunction onSubmit(fn: () => void) {\n    return (event: FormEvent<HTMLFormElement>) => {\n        event.preventDefault();\n        fn();\n    };\n}\n\nclass SignupForm extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = {\n            date_of_birth: null,\n            first_name: '',\n            last_name: '',\n            email: '',\n            mobile: '',\n            authenticationMethod: 'sms',\n            show_sms: true,\n            showModal: false,\n        };\n\n        this.onSignup = this.onSignup.bind(this);\n    }\n\n    toggleAuthMethod = (authMethod: AuthenticationMethod) =>\n        this.setState({\n            show_sms: authMethod === 'sms',\n            authenticationMethod: authMethod,\n        });\n\n    toggleModal = () => {\n        this.setState({ showModal: !this.state.showModal });\n    };\n\n    componentDidMount(): void {\n        this.props.resetForm('signup');\n    }\n\n    dobRaw = () => (this.state.date_of_birth ? moment(this.state.date_of_birth).format(FORMAT_DATE) : '');\n\n    async onSignup() {\n        try {\n            await this.props.signup(\n                this.state.first_name,\n                this.state.last_name,\n                this.dobRaw(),\n                this.state.mobile,\n                this.state.email,\n                this.state.authenticationMethod,\n                this.props.link?.merchant.short_name,\n            );\n            if (!this.props.error) {\n                // Display verification modal\n                this.setState({ showModal: true });\n            }\n            if (this.props.payLinkId && this.props.customer?.id) {\n                await addCustomer(this.props.payLinkId, this.props.customer.id);\n            }\n        } catch (error) {\n            // catching error now\n        }\n    }\n\n    tryLogin = (isMobile: boolean) => {\n        let query;\n        if (isMobile) {\n            query = querystring.stringify({ mobile: this.state.mobile });\n        } else {\n            query = querystring.stringify({ email: this.state.email });\n        }\n        return (\n            <React.Fragment>\n                {isMobile ? 'Mobile phone number' : 'Email'} already taken. Please{' '}\n                <Link to={`/login?${query}`}>login</Link> using this {isMobile ? 'phone number' : 'email address'}.\n            </React.Fragment>\n        );\n    };\n\n    onResend = async () => {\n        try {\n            await this.props.resend(this.state.mobile, this.state.email, this.state.authenticationMethod);\n            this.setState({ showModal: true });\n        } catch (error) {\n            // Error\n        }\n    };\n\n    render() {\n        const { error, isRequesting } = this.props;\n\n        return (\n            <React.Fragment>\n                <Form onSubmit={onSubmit(this.onSignup)} noValidate>\n                    <FormGroup>\n                        <Label>First Name</Label>\n                        <Input\n                            id={'input-fname'}\n                            key={'input-fname'}\n                            type=\"text\"\n                            placeholder=\"Your First Name\"\n                            autoComplete=\"given-name\"\n                            value={this.state.first_name}\n                            onChange={(e) => this.setState({ first_name: e.currentTarget.value })}\n                            invalid={selectors.global.isPropertyError('individual.first_name', error)}\n                        />\n                        <FormFeedback>{selectors.global.getErrorMessage(error)}</FormFeedback>\n                    </FormGroup>\n                    <FormGroup>\n                        <Label>Last Name</Label>\n                        <Input\n                            id={'input-lname'}\n                            type=\"text\"\n                            placeholder=\"Your Last Name\"\n                            autoComplete=\"family-name\"\n                            value={this.state.last_name}\n                            onChange={(e) => this.setState({ last_name: e.currentTarget.value })}\n                            invalid={selectors.global.isPropertyError('individual.last_name', error)}\n                        />\n                        <FormFeedback>{selectors.global.getErrorMessage(error)}</FormFeedback>\n                    </FormGroup>\n                    <FormGroup>\n                        <Label>Date of Birth</Label>\n                        <ReactDatePicker\n                            className={[\n                                'form-control',\n                                selectors.global.isPropertyError('individual.date_of_birth', error) ? 'is-invalid' : '',\n                            ].join(' ')}\n                            placeholderText={'11/30/1990'}\n                            autoComplete=\"dob\"\n                            selected={this.state.date_of_birth}\n                            wrapperClassName={'w-100'}\n                            dateFormat={'MM/dd/yyyy'}\n                            showYearDropdown\n                            scrollableYearDropdown={true}\n                            yearDropdownItemNumber={100}\n                            showMonthDropdown={true}\n                            scrollableMonthYearDropdown={true}\n                            maxDate={moment().add(-15, 'y').toDate()}\n                            calendarClassName={'date-picker-calendar'}\n                            popperClassName={'date-picker-popper'}\n                            dayClassName={() => 'DAY'}\n                            onChange={(date) => {\n                                this.setState({ date_of_birth: date });\n                            }}\n                        />\n                        <p className=\"text-danger small\">\n                            {selectors.global.isPropertyError('individual.date_of_birth', error)\n                                ? selectors.global.getErrorMessage(error)\n                                : ''}\n                        </p>\n                    </FormGroup>\n                    <FormGroup inline>\n                        <Label>Preferred Contact Method</Label>\n                        <div className=\"radio\">\n                            <label className={'contact-method'}>\n                                <input\n                                    type=\"radio\"\n                                    value=\"SMS\"\n                                    checked={this.state.authenticationMethod === 'sms'}\n                                    onChange={() => {\n                                        this.toggleAuthMethod('sms');\n                                    }}\n                                />\n                                SMS\n                            </label>\n                            <label className={'contact-method'}>\n                                <input\n                                    type=\"radio\"\n                                    value=\"Email\"\n                                    checked={this.state.authenticationMethod === 'email'}\n                                    onChange={() => {\n                                        this.toggleAuthMethod('email');\n                                    }}\n                                />\n                                Email\n                            </label>\n                        </div>\n                        {this.state.show_sms ? (\n                            <FormGroup>\n                                <PhoneNumberInput\n                                    placeholder=\"Enter mobile phone number\"\n                                    value={this.state.mobile}\n                                    isInvalid={selectors.global.isPropertyError('individual.mobile', error)}\n                                    onChange={(mobile: string) => this.setState({ mobile })}\n                                />\n                                <FormFeedback>\n                                    {selectors.global.getErrorCode(error) === ResponseErrorCode.ValueTaken\n                                        ? this.tryLogin(true)\n                                        : selectors.global.getErrorMessage(error)}\n                                </FormFeedback>\n                            </FormGroup>\n                        ) : (\n                            <FormGroup>\n                                <Input\n                                    id={'input-email'}\n                                    key={'input-email'}\n                                    type=\"email\"\n                                    placeholder=\"Enter email address\"\n                                    autoComplete=\"email\"\n                                    value={this.state.email}\n                                    onChange={(e) => this.setState({ email: e.currentTarget.value })}\n                                    invalid={selectors.global.isPropertyError('individual.email', error)}\n                                />\n                                <FormFeedback>\n                                    {selectors.global.getErrorCode(error) === ResponseErrorCode.ValueTaken\n                                        ? this.tryLogin(false)\n                                        : selectors.global.getErrorMessage(error)}\n                                </FormFeedback>\n                            </FormGroup>\n                        )}\n                    </FormGroup>\n                    <Button type={'submit'} disabled={isRequesting} color={'primary'} block>\n                        Sign Up{' '}\n                        {isRequesting ? (\n                            <Spinner type=\"grow\" color=\"white\" size={'sm'} />\n                        ) : (\n                            <FontAwesomeIcon icon={faLongArrowAltRight} fixedWidth />\n                        )}\n                    </Button>\n\n                    <FormGroup className=\"mt-1\" style={{ lineHeight: 1.1 }}>\n                        <small>\n                            By clicking <strong>Sign Up</strong>, you agree to receive SMS messages for account\n                            verification and security purposes. Message frequency varies. Message and data rates may\n                            apply. Reply HELP for info, STOP to cancel.{' '}\n                        </small>\n                        <br />\n                        <small>\n                            View our Privacy Policy and SMS Terms at{' '}\n                            <a href=\"https://stronghold.co/legal\">https://stronghold.co/legal</a>\n                        </small>\n                    </FormGroup>\n                </Form>\n                <VerificationCodeModal\n                    show={this.state.showModal}\n                    value={this.state.authenticationMethod === 'sms' ? this.state.mobile : this.state.email}\n                    isResending={isRequesting}\n                    onClose={this.toggleModal}\n                    onResend={this.onResend}\n                    authenticationMethod={this.state.authenticationMethod}\n                    onSuccess={() => this.props.onSuccess()}\n                />\n            </React.Fragment>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    link: state.payLink.data ? state.payLink.data : null,\n    error: selectors.global.getResponseError(state.global.actions, 'signup'),\n    isRequesting: selectors.global.isActionRequesting(state.global.actions, 'signup'),\n    customer: state.authentication.customer,\n    environment: state.global.configuration.api_environment,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            resetForm: resetActionStatusAction,\n            signup: signupAction,\n            resend: resendTokenAction,\n            linkCustomer: setPayLinkCustomerAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SignupForm);\n","import * as React from 'react';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport { Link, RouteComponentProps, withRouter } from 'react-router-dom';\nimport Progress from 'reactstrap/lib/Progress';\nimport Row from 'reactstrap/lib/Row';\nimport Col from 'reactstrap/lib/Col';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCircle } from '@fortawesome/free-solid-svg-icons/faCircle';\nimport { faDotCircle } from '@fortawesome/free-solid-svg-icons/faDotCircle';\nimport { faCircle as faCircleRegular } from '@fortawesome/free-regular-svg-icons/faCircle';\nimport { ROUTE } from '../config';\nimport SignupForm from '../components/auth/SignupForm';\nimport AddPaymentSourceButton from '../components/dropin/AddPaymentSourceButton';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport Layout from '../components/Layout';\nimport MerchantImg from '../components/MerchantImg';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { isNewPaymentSourceLinkedAction } from '../store/actions';\n\ninterface StateProps {\n    merchantDisplayName: string;\n}\n\ninterface DispatchProps {\n    isNewPaymentSourceLinkedAction: typeof isNewPaymentSourceLinkedAction;\n}\n\ntype OwnProps = { navToLogin?: () => void } & RouteComponentProps;\n\ntype Props = OwnProps & StateProps & DispatchProps & RouteComponentProps<{ code: string }>;\n\ninterface State {\n    step: number;\n    code?: string;\n}\n\ninterface Step {\n    step: number;\n    title: string;\n}\n\nclass SignUpPage extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = {\n            step: 1,\n            code: this.props.match.params.code,\n        };\n    }\n\n    next = () => {\n        if (this.state.code) {\n            window.location.reload();\n        } else {\n            this.setState({ step: this.state.step + 1 });\n        }\n    };\n\n    previous = () => {\n        this.setState({ step: this.state.step - 1 });\n    };\n\n    getStep(step: Step, key: number) {\n        let icon = faCircle;\n        let title = <React.Fragment>{step.title}</React.Fragment>;\n        const classes = ['p-2', 'd-flex', 'align-items-center'];\n        if (step.step === this.state.step) {\n            icon = faDotCircle;\n            title = <strong>{title}</strong>;\n        } else if (step.step > this.state.step) {\n            icon = faCircleRegular;\n        }\n\n        if (step.step !== this.state.step) {\n            classes.push('border-bottom');\n        }\n\n        if (step.step > 1) {\n            classes.push('border-left');\n        }\n\n        return (\n            <Col key={key} className={classes.join(' ')}>\n                <FontAwesomeIcon icon={icon} className=\"mr-1 text-primary\" />\n                <small>{title}</small>\n            </Col>\n        );\n    }\n\n    onLinkSuccess = () => {\n        this.props.isNewPaymentSourceLinkedAction(true);\n        this.props.history.push(ROUTE.HOME);\n    };\n\n    render() {\n        const steps: Step[] = [\n            {\n                step: 1,\n                title: 'Personal Details',\n            },\n            {\n                step: 2,\n                title: 'Link Account',\n            },\n        ];\n\n        const step = steps.find((el) => el.step === this.state.step) || steps[0];\n\n        let content = <SignupForm onSuccess={this.next} payLinkId={this.state.code} />;\n\n        if (step.step === 2) {\n            content = (\n                <>\n                    <p>In order to make payments, you must securely link a bank account.</p>\n                    <p>Your credentials will never be stored or shared.</p>\n\n                    <div>\n                        <AddPaymentSourceButton onSuccess={this.onLinkSuccess} block>\n                            Link and Finish Sign Up\n                        </AddPaymentSourceButton>\n                    </div>\n                </>\n            );\n        }\n\n        return (\n            <Layout navbar={false} centered>\n                <Card className=\"shadow-lg mw-sm\">\n                    <div className=\"text-center p-3 px-md-5\">\n                        <div className=\"h4\">\n                            Sign up for Payments at <strong>{this.props.merchantDisplayName}</strong>\n                        </div>\n                        <MerchantImg />\n                        <div className=\"lead\">We need a few details in order to create your account.</div>\n                    </div>\n\n                    {step.step < 2 ? (\n                        <div className=\"p-3 mb-4\">\n                            <div className=\"text-center p-3 border border-primary\" style={{ borderRadius: '4px' }}>\n                                Paid using Stronghold ACH before?\n                                {this.props.navToLogin ? (\n                                    <button\n                                        onClick={this.props.navToLogin}\n                                        style={{\n                                            background: 'none',\n                                            border: 'none',\n                                            color: 'blue',\n                                            cursor: 'pointer',\n                                            fontSize: 'inherit',\n                                            padding: 5,\n                                        }}\n                                    >\n                                        Log In\n                                    </button>\n                                ) : (\n                                    <Link to={ROUTE.LOGIN} style={{ padding: 5, textDecoration: 'underline' }}>\n                                        Log In{' '}\n                                    </Link>\n                                )}\n                            </div>\n                        </div>\n                    ) : null}\n\n                    <Progress\n                        className=\"rounded-0\"\n                        value={(step.step * 100) / steps.length}\n                        color=\"primary\"\n                        style={{ height: 5 }}\n                    />\n                    <Row noGutters>{steps.map((el, index) => this.getStep(el, index))}</Row>\n                    <CardBody>{content}</CardBody>\n                </Card>\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (\n    state: ApplicationState,\n): StateProps => ({\n    merchantDisplayName: state.global.merchant.display_name,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            isNewPaymentSourceLinkedAction: isNewPaymentSourceLinkedAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(SignUpPage));\n","import 'react';\n\nimport * as React from 'react';\nimport { RouteComponentProps, withRouter } from 'react-router-dom';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../../store';\nimport Layout from '../../components/Layout';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { PayLinkModel, ResponseErrorCode } from '../../apis';\nimport { isAuthenticatedAction, loginAction } from '../../store/actions';\nimport Spinner from 'reactstrap/lib/Spinner';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faArrowLeft } from '@fortawesome/free-solid-svg-icons/faArrowLeft';\nimport selectors from '../../store/selectors';\nimport CheckoutPage from './CheckoutPage';\nimport BankLinkPage from './BankLinkPage';\nimport TipPage from './TipPage';\nimport SignUpPage from '../SignUpPage';\nimport LoginPage from '../LoginPage';\n\ninterface StateProps {\n    link: PayLinkModel | null;\n    exitUrlCallback: string | null;\n}\n\ntype OwnProps = RouteComponentProps<{ code?: string }>;\n\ninterface DispatchProps {\n    isAuthenticatedAction: typeof isAuthenticatedAction;\n    loginAction: typeof loginAction;\n}\n\ntype Props = OwnProps & StateProps & DispatchProps;\n\ntype Page = 'signup' | 'login';\n\ninterface State {\n    loaded: boolean;\n    page?: Page;\n}\n\nclass PayLinkPage extends React.Component<Props, State> {\n    constructor(props: Props) {\n        super(props);\n\n        this.state = {\n            loaded: false,\n        };\n    }\n\n    async componentDidMount() {\n        await this.props.isAuthenticatedAction(false);\n        const code = this.props.match.params.code || '';\n\n        try {\n            await this.props.loginAction('link', code);\n            this.setState({ loaded: true });\n        } catch (e) {\n            if (e === ResponseErrorCode.CustomerRequired) {\n                this.setState({ page: 'signup' });\n                this.setState({ loaded: true });\n            }\n        }\n    }\n\n    navigateToLogin = () => {\n        this.setState({ page: 'login' });\n    };\n\n    navigateToSignup = () => {\n        this.setState({ page: 'signup' });\n    };\n\n    render() {\n        const { link, exitUrlCallback, history, location, match } = this.props;\n\n        if (this.state.loaded && this.state.page) {\n            if (this.state.page === 'login') {\n                return (\n                    <Layout navbar={false} footer={false} centered>\n                        <LoginPage\n                            history={history}\n                            match={match}\n                            location={location}\n                            navToSignup={this.navigateToSignup}\n                        />\n                    </Layout>\n                );\n            } else {\n                return (\n                    <Layout navbar={false} footer={false} centered>\n                        <SignUpPage\n                            history={history}\n                            match={match}\n                            location={location}\n                            navToLogin={this.navigateToLogin}\n                        />\n                    </Layout>\n                );\n            }\n        }\n\n        if (!this.state.loaded || !link) {\n            return (\n                <Layout navbar={false} centered>\n                    <Spinner style={{ width: '3rem', height: '3rem', borderWidth: '1px' }} color=\"secondary\" />\n                </Layout>\n            );\n        }\n\n        let payLinkPage = <></>;\n        let exit = <React.Fragment />;\n        let className = '';\n\n        if (exitUrlCallback && link.status !== 'used') {\n            exit = (\n                <div className=\"d-inline-block position-relative mt-3\" data-sh=\"exit\">\n                    <FontAwesomeIcon icon={faArrowLeft} />\n                    <a className=\"ml-3 stretched-link text-dark\" href={exitUrlCallback}>\n                        Back\n                    </a>\n                </div>\n            );\n        }\n\n        if (link.type === 'bank_link') {\n            className = 'mw-sm';\n            payLinkPage = <BankLinkPage link={link} />;\n        } else if (link.type === 'tipping') {\n            payLinkPage = <TipPage link={link} />;\n        } else if (link.type === 'checkout') {\n            payLinkPage = <CheckoutPage link={link} />;\n        } else {\n            throw new Error(`PayLink of type ${link.type} not implemented`);\n        }\n\n        return (\n            <Layout navbar={false} className={className}>\n                {exit}\n                {payLinkPage}\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => {\n    const link = state.payLink.data ? state.payLink.data : null;\n\n    return {\n        link,\n        exitUrlCallback: selectors.payLink.getExitUrlCallback(state),\n    };\n};\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            isAuthenticatedAction,\n            loginAction,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withRouter(PayLinkPage));\n","import 'react';\nimport * as React from 'react';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from '../store';\nimport Layout from '../components/Layout';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport Card from 'reactstrap/lib/Card';\nimport CardBody from 'reactstrap/lib/CardBody';\nimport MESSAGE from '../message';\nimport { ResponseErrorCode } from '../apis';\nimport Button from 'reactstrap/lib/Button';\nimport { faRedo } from '@fortawesome/free-solid-svg-icons/faRedo';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\n\ninterface StateProps {\n    show: boolean;\n    errorCode: ResponseErrorCode | null;\n}\n\ninterface OwnProps {\n    children: JSX.Element | JSX.Element[];\n}\n\ntype Props = StateProps & OwnProps;\n\nclass ErrorHandler extends React.Component<Props> {\n    reloadPage = () => {\n        window.location.reload();\n    };\n\n    render() {\n        const { errorCode, show, children } = this.props;\n\n        if (!show) {\n            return children;\n        }\n\n        let title = <>{MESSAGE.ERROR_COMMON_TITLE}</>;\n        let subTitle = null;\n        let message = <>{MESSAGE.ERROR_COMMON}</>;\n\n        if (errorCode === ResponseErrorCode.PayLinkCanceled) {\n            title = <>{MESSAGE.CANCELED_LINK_TITLE}</>;\n            message = <>{MESSAGE.CANCELED_LINK}</>;\n        } else if (errorCode === ResponseErrorCode.PayLinkExpired) {\n            title = <>{MESSAGE.EXPIRED_LINK_TITLE}</>;\n            subTitle = <>{MESSAGE.EXPIRED_LINK_SUB_TITLE}</>;\n            message = <>{MESSAGE.EXPIRED_LINK}</>;\n        } else if (\n            errorCode === ResponseErrorCode.InvalidChargeStatus ||\n            errorCode === ResponseErrorCode.PayLinkMissingOrder ||\n            errorCode === ResponseErrorCode.PayLinkMissingCharge\n        ) {\n            title = <>{MESSAGE.INVALID_CHARGE_STATUS_TITLE}</>;\n            message = <>{MESSAGE.INVALID_CHARGE_STATUS}</>;\n        } else if (errorCode === ResponseErrorCode.NotFound) {\n            title = <>{MESSAGE.ORDER_NOT_FOUND_TITLE}</>;\n            message = <>{MESSAGE.ORDER_NOT_FOUND}</>;\n        } else if (errorCode === ResponseErrorCode.PaylinkChargeAmountModified) {\n            title = <>{MESSAGE.ORDER_AMOUNT_MODIFIED_TITLE}</>;\n            message = <>{MESSAGE.ORDER_AMOUNT_MODIFIED}</>;\n        } else if (errorCode === ResponseErrorCode.MerchantSoftwareError) {\n            title = <>{MESSAGE.ERROR_MERCHANT_SOFTWARE_TITLE}</>;\n            message = <>{MESSAGE.ERROR_MERCHANT_SOFTWARE}</>;\n        } else if (errorCode === ResponseErrorCode.InvalidApiKey) {\n            title = <>{MESSAGE.ERROR_INVALID_CONFIGURATION_TITLE}</>;\n            message = <>{MESSAGE.ERROR_INVALID_CONFIGURATION}</>;\n        } else if (errorCode === ResponseErrorCode.LiveNotApproved) {\n            title = <>{MESSAGE.ERROR_LIVE_NOT_APPROVED_TITLE}</>;\n            message = <>{MESSAGE.ERROR_LIVE_NOT_APPROVED}</>;\n        }\n\n        return (\n            <Layout navbar={false} centered>\n                <Card className=\"shadow-lg text-center\" style={{ maxWidth: 500 }}>\n                    <CardBody className=\"p-md-5\">\n                        <div className=\"h4 mb-4\">{title}</div>\n                        {subTitle && <div className=\"lead mb-2\">{subTitle}</div>}\n                        <div className=\"lead mb-4\">{message}</div>\n                        {errorCode === ResponseErrorCode.PaylinkChargeAmountModified ? (\n                            <Button className=\"mb-2\" color=\"primary\" onClick={this.reloadPage}>\n                                Reload Page <FontAwesomeIcon icon={faRedo} fixedWidth />\n                            </Button>\n                        ) : (\n                            <div className=\"text-center\">\n                                <a\n                                    href=\"https://stronghold.co/happiness-support-contact\"\n                                    target=\"_blank\"\n                                    rel=\"noopener noreferrer\"\n                                >\n                                    Support\n                                </a>\n                            </div>\n                        )}\n                    </CardBody>\n                </Card>\n            </Layout>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, OwnProps, ApplicationState> = (state) => ({\n    errorCode: state.global.error.errorCode,\n    show: state.global.error.show,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) => bindActionCreators({}, dispatch);\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ErrorHandler);\n","import './styles/styles.scss';\nimport * as React from 'react';\nimport { Redirect, Route, Switch } from 'react-router';\nimport PortalRoute from './components/PortalRoute';\nimport { ROUTE } from './config';\nimport LoginPage from './pages/LoginPage';\nimport HomePage from './pages/HomePage';\nimport LinkAccountPage from './pages/LinkAccountPage';\nimport LogoutPage from './pages/LogoutPage';\nimport PayLinkPage from './pages/PayLink/PayLinkPage';\nimport { connect, MapStateToPropsParam } from 'react-redux';\nimport { ApplicationState } from './store';\nimport { bindActionCreators, Dispatch } from 'redux';\nimport { fetchConfiguration } from './store/actions';\nimport { Helmet } from 'react-helmet';\nimport selectors from './store/selectors';\nimport ErrorHandler from './pages/ErrorHandler';\nimport { ConfigurationStatus } from './store/types';\nimport SignUpPage from './pages/SignUpPage';\n\ninterface StateProps {\n    configurationStatus: ConfigurationStatus;\n    title: string;\n    analyticsWriteKey?: string;\n}\n\ninterface DispatchProps {\n    fetchConfiguration: typeof fetchConfiguration;\n}\n\ntype Props = StateProps & DispatchProps;\n\nclass App extends React.PureComponent<Props> {\n    async componentDidMount() {\n        await this.props.fetchConfiguration();\n        this.setState({ ready: true });\n    }\n\n    componentDidUpdate(prevProps: Readonly<Props>): void {\n        if (prevProps.analyticsWriteKey === this.props.analyticsWriteKey) return;\n        if (!this.props.analyticsWriteKey) return;\n\n        window.analytics.load(this.props.analyticsWriteKey);\n    }\n\n    public render() {\n        const { configurationStatus, title } = this.props;\n        if (configurationStatus === 'unloaded') {\n            return null;\n        }\n\n        return (\n            <React.Fragment>\n                <Helmet>\n                    <title>{title}</title>\n                </Helmet>\n                <ErrorHandler>\n                    <Switch>\n                        {/* Route processing pay links: l/{code} */}\n                        <Route path={ROUTE.LINK} component={PayLinkPage} />\n\n                        {/* Routes merchant specific, ex: merchant.onstrongholdpay.com */}\n                        <PortalRoute path={ROUTE.LOGIN} component={LoginPage} authenticate={false} isMerchantRoute />\n\n                        {/* Restrict to login only for now */}\n                        <Route path={ROUTE.SIGN_UP} component={SignUpPage} />\n                        <Route path={ROUTE.LOGOUT} component={LogoutPage} />\n                        <PortalRoute\n                            path={ROUTE.LINK_ACCOUNT}\n                            component={LinkAccountPage}\n                            authenticate\n                            isMerchantRoute\n                        />\n                        <PortalRoute\n                            path={ROUTE.HOME}\n                            component={HomePage}\n                            authenticate\n                            allowUnauthenticated\n                            paymentSourceRequired\n                            isMerchantRoute\n                        />\n                        <Redirect to={ROUTE.HOME} />\n                    </Switch>\n                </ErrorHandler>\n            </React.Fragment>\n        );\n    }\n}\n\nconst mapStateToProps: MapStateToPropsParam<StateProps, void, ApplicationState> = (state) => ({\n    configurationStatus: state.global.configurationStatus,\n    title: selectors.global.getTitle(state.global),\n    analyticsWriteKey: state.global.configuration.analytics.write_key,\n});\n\nconst mapDispatchToProps = (dispatch: Dispatch) =>\n    bindActionCreators(\n        {\n            fetchConfiguration,\n        },\n        dispatch,\n    );\n\nexport default connect(mapStateToProps, mapDispatchToProps)(App);\n","import { AuthenticationState } from '../types';\nimport { DeepPartial, Reducer } from 'redux';\nimport { IS_AUTHENTICATED, SET_CUSTOMER_TOKEN, SET_TOKEN, UPDATE_CUSTOMER } from '../constants';\nimport { ApplicationAction } from '../actions';\nimport { merge } from 'lodash';\nimport { CustomerModel } from '../../apis';\nimport segment from '../../segment';\n\n// ----------------\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\n\nexport const unloadedState: AuthenticationState = {\n    isAuthenticated: false,\n    token: null,\n    customer: {\n        country: null,\n        id: null,\n        state: null,\n        individual: {\n            email: null,\n            mobile: null,\n            date_of_birth: null,\n            first_name: null,\n            last_name: null,\n        },\n        payment_sources: [],\n    },\n    customerToken: null,\n};\n\nexport const authenticationReducer: Reducer<AuthenticationState, ApplicationAction> = (\n    state = unloadedState,\n    action,\n): AuthenticationState => {\n    switch (action.type) {\n        case IS_AUTHENTICATED:\n            if (!action.payload.isAuthenticated) {\n                return unloadedState;\n            }\n            return {\n                ...state,\n                isAuthenticated: action.payload.isAuthenticated,\n            };\n        case SET_TOKEN:\n            return {\n                ...state,\n                token: action.payload.token,\n            };\n        case UPDATE_CUSTOMER:\n            const updated = merge<DeepPartial<CustomerModel>, CustomerModel, DeepPartial<CustomerModel>>(\n                {},\n                state.customer,\n                action.payload.customer,\n            );\n            segment.identify(updated.id as string);\n            return {\n                ...state,\n                customer: updated,\n            };\n        case SET_CUSTOMER_TOKEN:\n            return {\n                ...state,\n                customerToken: action.payload.token,\n            };\n    }\n\n    return state;\n};\n","import { ActionStatus, GlobalState } from '../types';\nimport { Reducer } from 'redux';\nimport {\n    RESET_ACTION_STATUS,\n    SET_ACTION_REQUEST_STATUS,\n    SET_ACTION_RESPONSE_ERROR,\n    SET_CONFIGURATION,\n    SET_CONFIGURATION_STATUS,\n    SET_ERROR_MESSAGE,\n    SET_PAY_LINK,\n    UPDATE_HEADER_TITLE,\n} from '../constants';\nimport { ApplicationAction } from '../actions';\nimport { clone, unionBy } from 'lodash';\nimport { configuration } from '../../config';\nimport { ENVIRONMENT } from '@stronghold/pay-dropin';\nimport { LOCATION_CHANGE } from 'connected-react-router';\nimport segment from '../../segment';\n\n// ----------------\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\n\nconst unloadedState: GlobalState = {\n    actions: [],\n    configuration: clone(configuration),\n    configurationStatus: 'unloaded',\n    error: {\n        errorCode: null,\n        show: false,\n    },\n    headerTitle: {\n        separator: '-',\n        values: [],\n    },\n    merchant: {\n        display_name: '',\n        created_at: '',\n        id: '',\n        image_url: '',\n        legal_name: '',\n        short_name: '',\n        street_location: { city: '', country: '', postcode: '', state: '', street1: '' },\n        customization: {\n            tip: {\n                type: 'fixed',\n                value1: 0,\n                value2: 0,\n                value3: 0,\n            },\n            items: [],\n        },\n    },\n    publishableApiKey: {\n        environment: ENVIRONMENT.live,\n        publishable: true,\n        key: '',\n        created_at: '',\n        last_used_at: '',\n    },\n};\nconst unloadedActionStatusState: ActionStatus = { name: 'login', isRequesting: false };\n\nexport const globalReducer: Reducer<GlobalState, ApplicationAction> = (\n    state: GlobalState = unloadedState,\n    action,\n): GlobalState => {\n    switch (action.type) {\n        case SET_CONFIGURATION:\n            segment.environment = action.payload.configuration.analytics.environment;\n            return {\n                ...state,\n                configuration: action.payload.configuration,\n                configurationStatus: 'loaded',\n                merchant: action.payload.configuration.merchant || state.merchant,\n                publishableApiKey: action.payload.configuration.publishable_api_key || state.publishableApiKey,\n            };\n        case SET_CONFIGURATION_STATUS:\n            return {\n                ...state,\n                configurationStatus: action.payload.status,\n            };\n        case SET_ERROR_MESSAGE:\n            return {\n                ...state,\n                error: {\n                    show: true,\n                    errorCode: action.payload.errorCode,\n                },\n            };\n        case SET_ACTION_REQUEST_STATUS:\n            let tmp = state.actions.find((el) => el.name === action.payload.name);\n            tmp = tmp\n                ? clone(tmp)\n                : ({\n                      ...unloadedActionStatusState,\n                      name: action.payload.name,\n                  } as ActionStatus);\n            tmp.isRequesting = action.payload.isRequesting;\n            return {\n                ...state,\n                actions: unionBy([tmp], state.actions, (el) => el.name),\n            };\n        case SET_ACTION_RESPONSE_ERROR:\n            return {\n                ...state,\n                actions: state.actions.map((el) => {\n                    if (el.name !== action.payload.name) return el;\n                    return {\n                        ...el,\n                        responseError: action.payload.error,\n                    };\n                }),\n            };\n        case RESET_ACTION_STATUS:\n            return {\n                ...state,\n                actions: unionBy(\n                    [\n                        {\n                            ...unloadedActionStatusState,\n                            name: action.payload.name,\n                        },\n                    ],\n                    state.actions,\n                    (el) => el.name,\n                ),\n            };\n        case UPDATE_HEADER_TITLE:\n            return {\n                ...state,\n                headerTitle: {\n                    ...state.headerTitle,\n                    ...action.payload.headerPartial,\n                },\n            };\n        case SET_PAY_LINK:\n            return {\n                ...state,\n                publishableApiKey: action.payload.link.api_keys.publishable,\n                merchant: action.payload.link.merchant,\n            };\n\n        case LOCATION_CHANGE:\n            return state;\n    }\n\n    return state;\n};\n","import { PayLinkState } from '../types';\nimport { DeepPartial, Reducer } from 'redux';\nimport { ApplicationAction } from '../actions';\nimport { SET_PAY_LINK, UPDATE_PAY_LINK } from '../constants';\nimport { merge } from 'lodash';\nimport { PayLinkModel } from '../../apis';\n\n// ----------------\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\n\nconst unloadedState: PayLinkState = {\n    data: null,\n};\n\nexport const payLinkReducer: Reducer<PayLinkState, ApplicationAction> = (\n    state = unloadedState,\n    action,\n): PayLinkState => {\n    switch (action.type) {\n        case SET_PAY_LINK:\n            return {\n                ...state,\n                data: action.payload.link,\n            };\n        case UPDATE_PAY_LINK:\n            if (!state.data) {\n                return state;\n            }\n            return {\n                ...state,\n                data: merge<DeepPartial<PayLinkModel>, PayLinkModel, DeepPartial<PayLinkModel>>(\n                    {},\n                    state.data,\n                    action.payload.payLink,\n                ),\n            };\n        default:\n            return state;\n    }\n};\n","import { ChargeState } from '../types';\nimport { CLEAN_CHARGES, SET_CHARGES } from '../constants';\nimport { Reducer } from 'redux';\nimport { ApplicationAction } from '../actions';\nimport { segmentListLimit } from '../../apis';\n\n// ----------------\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\n\nconst unloadedState: ChargeState = {\n    list: {\n        items: [],\n        limit: segmentListLimit,\n        skipped: 0,\n        total: 0,\n    },\n};\n\nexport const chargeReducer: Reducer<ChargeState, ApplicationAction> = (state = unloadedState, action): ChargeState => {\n    switch (action.type) {\n        case SET_CHARGES:\n            return {\n                ...state,\n                list: action.payload.list,\n            };\n        case CLEAN_CHARGES:\n            return {\n                ...state,\n                list: unloadedState.list,\n            };\n        default:\n            return state;\n    }\n};\n","import {\n    ADD_PAYMENT_SOURCE,\n    REMOVE_PAYMENT_SOURCE,\n    SELECT_PAYMENT_SOURCE,\n    SET_PAYMENT_SOURCES,\n    UPDATE_PAYMENT_SOURCE,\n    IS_NEW_PAYMENT_SOURCE_LINKED,\n} from '../constants';\nimport { Reducer } from 'redux';\nimport { ApplicationAction } from '../actions';\nimport { PaymentSourcesState } from '../types';\nimport { filter, unionBy } from 'lodash';\n\n// ----------------\n// REDUCER - For a given state and action, returns the new state. To support time travel, this must not mutate the old state.\n\nconst unloadedState: PaymentSourcesState = {\n    arr: [],\n    paymentSourceSelected: null,\n    isNewPaymentSourceLinked: false,\n};\n\nexport const paymentSourcesReducer: Reducer<PaymentSourcesState, ApplicationAction> = (\n    state = unloadedState,\n    action,\n): PaymentSourcesState => {\n    switch (action.type) {\n        case SET_PAYMENT_SOURCES:\n            return {\n                ...state,\n                arr: action.payload.arr,\n                paymentSourceSelected: action.payload.arr.length === 1 ? action.payload.arr[0].id : null,\n            };\n        case ADD_PAYMENT_SOURCE:\n            return {\n                ...state,\n                arr: [...state.arr, action.payload.data],\n            };\n        case UPDATE_PAYMENT_SOURCE:\n            return {\n                ...state,\n                arr: unionBy([action.payload.data], state.arr, (el) => el.id),\n                paymentSourceSelected:\n                    action.payload.data.id === state.paymentSourceSelected && !action.payload.data.active\n                        ? null\n                        : state.paymentSourceSelected,\n            };\n        case REMOVE_PAYMENT_SOURCE:\n            return {\n                ...state,\n                arr: filter(state.arr, (item) => item.id !== action.payload.paymentSourceId),\n                paymentSourceSelected:\n                    state.paymentSourceSelected === action.payload.paymentSourceId ? null : state.paymentSourceSelected,\n            };\n        case SELECT_PAYMENT_SOURCE:\n            return {\n                ...state,\n                paymentSourceSelected: action.payload.paymentSourceId,\n            };\n        case IS_NEW_PAYMENT_SOURCE_LINKED:\n            return {\n                ...state,\n                isNewPaymentSourceLinked: action.payload.isNewPaymentSourceLinked,\n            };\n        default:\n            return state;\n    }\n};\n","import { Reducer } from 'redux';\nimport { ApplicationAction } from '../actions';\nimport { CreditState } from '../types';\nimport { SET_CREDIT_VALUE } from '../constants';\n\nconst unloadedState: CreditState = {\n    creditValue: 0,\n};\n\nexport const creditReducer: Reducer<CreditState, ApplicationAction> = (state = unloadedState, action): CreditState => {\n    switch (action.type) {\n        case SET_CREDIT_VALUE:\n            return {\n                ...state,\n                creditValue: action.payload.creditValue,\n            };\n        default:\n            return state;\n    }\n};\n","import { Reducer } from 'redux';\nimport { ApplicationAction } from '../actions';\nimport { AttributionState } from '../types/attribution';\nimport { SET_INTEGRATION_ID, SET_API_VERSION } from '../constants';\n\nconst unloadedState: AttributionState = {\n    integrationId: undefined,\n    apiVersion: 'v2',\n};\n\nexport const attributionReducer: Reducer<AttributionState, ApplicationAction> = (\n    state = unloadedState,\n    action,\n): AttributionState => {\n    switch (action.type) {\n        case SET_INTEGRATION_ID:\n            return {\n                ...state,\n                integrationId: action.payload.integrationId,\n            };\n        case SET_API_VERSION:\n            return {\n                ...state,\n                apiVersion: action.payload.apiVersion,\n            };\n        default:\n            return state;\n    }\n};\n","import {\n    AuthenticationState,\n    GlobalState,\n    PayLinkState,\n    ChargeState,\n    PaymentSourcesState,\n    SplitIoState,\n    CreditState,\n} from './types';\nimport { authenticationReducer, globalReducer, payLinkReducer, chargeReducer, paymentSourcesReducer } from './reducers';\nimport { splitReducer } from '@splitsoftware/splitio-redux';\nimport { creditReducer } from './reducers';\nimport { AttributionState } from './types/attribution';\nimport { attributionReducer } from './reducers/attribution';\n\n// The top-level state object\nexport interface ApplicationState {\n    authentication: AuthenticationState;\n    payLink: PayLinkState;\n    paymentSources: PaymentSourcesState;\n    global: GlobalState;\n    charge: ChargeState;\n    splitio: SplitIoState;\n    credits: CreditState;\n    attribution: AttributionState;\n}\n\n// Whenever an action is dispatched, Redux will update each top-level application state property using\n// the reducer with the matching name. It's important that the names match exactly, and that the reducer\n// acts on the corresponding ApplicationState property type.\nexport const reducers = {\n    authentication: authenticationReducer,\n    payLink: payLinkReducer,\n    paymentSources: paymentSourcesReducer,\n    global: globalReducer,\n    charge: chargeReducer,\n    splitio: splitReducer,\n    credits: creditReducer,\n    attribution: attributionReducer,\n};\n\n// This type can be used as a hint on action creators so that its 'dispatch' and 'getState' params are\n// correctly typed to match your store.\nexport interface AppThunkAction<TAction> {\n    (dispatch: (action: TAction) => void, getState: () => ApplicationState): void;\n}\n","import 'react';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport { Provider } from 'react-redux';\nimport { ConnectedRouter } from 'connected-react-router';\nimport { createBrowserHistory } from 'history';\nimport App from './App';\nimport configureStore from './store/configureStore';\n\n// Create browser history to use in the Redux store\nconst baseUrl = document.getElementsByTagName('base')[0].getAttribute('href') as string;\nexport const history = createBrowserHistory({ basename: baseUrl });\n\n// Get the application-wide store instance, prepopulating with state from the server where available.\nconst store = configureStore(history);\n\nReactDOM.render(\n    <Provider store={store}>\n        <ConnectedRouter history={history}>\n            <App />\n        </ConnectedRouter>\n    </Provider>,\n    document.getElementById('root'),\n);\n","/* eslint-disable  @typescript-eslint/no-explicit-any */\n\nimport { applyMiddleware, combineReducers, compose, createStore, Store } from 'redux';\nimport thunk from 'redux-thunk';\nimport { connectRouter, routerMiddleware } from 'connected-react-router';\nimport { History } from 'history';\nimport { ApplicationState, reducers } from './';\n\nexport default function configureStore(history: History, initialState?: ApplicationState): Store {\n    const middleware = [thunk, routerMiddleware(history)];\n\n    const rootReducer = combineReducers({\n        ...reducers,\n        router: connectRouter(history),\n    });\n\n    const enhancers = [];\n    const windowIfDefined = typeof window === 'undefined' ? null : (window as any);\n    if (windowIfDefined && windowIfDefined.__REDUX_DEVTOOLS_EXTENSION__) {\n        enhancers.push(windowIfDefined.__REDUX_DEVTOOLS_EXTENSION__());\n    }\n\n    return createStore(rootReducer, initialState, compose(applyMiddleware(...middleware), ...enhancers));\n}\n"],"sourceRoot":""}