@justifi/webcomponents 6.0.0-rc.2 → 6.0.0-rc.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
- package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
- package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
- package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
- package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +9 -9
- package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
- package/dist/cjs/business-details-core.cjs.entry.js +4 -4
- package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
- package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
- package/dist/cjs/card-form.cjs.entry.js +9 -6
- package/dist/cjs/{check-pkg-version-BfmeLSXP.js → check-pkg-version-DS_8EVX4.js} +9 -3
- package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
- package/dist/cjs/checkout.store-DJEc-So8.js +91 -0
- package/dist/cjs/checkouts-list-core.cjs.entry.js +11 -11
- package/dist/cjs/{payments-list-params-state-BNbT1fuJ.js → checkouts-list-params-state-Cewmin_p.js} +1 -1
- package/dist/cjs/{checkouts-table-UN5gPpQ_.js → checkouts-table-DjMdEiEW.js} +3 -3
- package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
- package/dist/cjs/custom-popper_2.cjs.entry.js +3 -3
- package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
- package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
- package/dist/cjs/form-control-checkbox.cjs.entry.js +5 -5
- package/dist/cjs/form-control-date.cjs.entry.js +4 -4
- package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
- package/dist/cjs/form-control-file-v2_2.cjs.entry.js +5 -5
- package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
- package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
- package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
- package/dist/cjs/form-control-monetary.cjs.entry.js +6 -6
- package/dist/cjs/form-control-number-masked_2.cjs.entry.js +4 -4
- package/dist/cjs/form-control-number.cjs.entry.js +5 -5
- package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
- package/dist/cjs/form-control-select_2.cjs.entry.js +6 -6
- package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
- package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
- package/dist/cjs/gross-payment-chart-core.cjs.entry.js +5 -5
- package/dist/cjs/{header-1-DD41iNlG.js → header-1-DRA3f4Jh.js} +1 -1
- package/dist/cjs/{header-3-D9Wa0IfT.js → header-3-sOdOpfx3.js} +1 -1
- package/dist/cjs/hidden-input_2.cjs.entry.js +8 -8
- package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
- package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
- package/dist/cjs/index-D-dD-aC2.js +30 -0
- package/dist/cjs/index.cjs.js +8 -0
- package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
- package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
- package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
- package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +9 -9
- package/dist/cjs/justifi-apple-pay.cjs.entry.js +189 -150
- package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +24 -22
- package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
- package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
- package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
- package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1422 -0
- package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
- package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +8 -8
- package/dist/cjs/justifi-checkouts-list.cjs.entry.js +14 -14
- package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
- package/dist/cjs/justifi-details.cjs.entry.js +2 -2
- package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +2 -2
- package/dist/cjs/justifi-dispute-management.cjs.entry.js +10 -10
- package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +15 -15
- package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
- package/dist/cjs/justifi-order-terminals.cjs.entry.js +13 -13
- package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
- package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
- package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
- package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
- package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +13 -13
- package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +7 -7
- package/dist/cjs/justifi-payments-list.cjs.entry.js +14 -14
- package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
- package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +13 -13
- package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +7 -7
- package/dist/cjs/justifi-payouts-list.cjs.entry.js +15 -15
- package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
- package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +2 -2
- package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
- package/dist/cjs/justifi-skeleton.cjs.entry.js +4 -4
- package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +9 -9
- package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +12 -12
- package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +8 -8
- package/dist/cjs/justifi-terminals-list.cjs.entry.js +14 -14
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/{package-CuNDvHTB.js → package-XG0rW7xm.js} +1 -1
- package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
- package/dist/cjs/payment-details-core.cjs.entry.js +15 -15
- package/dist/cjs/payment-method-option.cjs.entry.js +3 -3
- package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
- package/dist/cjs/payments-list-core.cjs.entry.js +12 -12
- package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
- package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
- package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
- package/dist/cjs/payout-details-core.cjs.entry.js +11 -11
- package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
- package/dist/cjs/payouts-list-core.cjs.entry.js +12 -12
- package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
- package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
- package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
- package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
- package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
- package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
- package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
- package/dist/cjs/table-filters-menu.cjs.entry.js +3 -3
- package/dist/cjs/terminal-orders-list-core.cjs.entry.js +11 -11
- package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
- package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
- package/dist/cjs/terminal-quantity-selector.cjs.entry.js +2 -2
- package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
- package/dist/cjs/terminals-list-core.cjs.entry.js +11 -11
- package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
- package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
- package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
- package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
- package/dist/cjs/webcomponents.cjs.js +3 -3
- package/dist/collection/api/Payment.js +5 -2
- package/dist/collection/api/index.js +1 -2
- package/dist/collection/api/services/apple-pay.service.js +112 -70
- package/dist/collection/api/services/plaid.service.js +20 -0
- package/dist/collection/assets/plaid-icon.svg +1 -0
- package/dist/collection/collection-manifest.json +3 -2
- package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
- package/dist/collection/components/checkout/card-form/card-form.js +6 -3
- package/dist/collection/components/checkout/checkout.js +17 -39
- package/dist/collection/components/checkout/save-new-payment-method.js +26 -1
- package/dist/collection/components/checkout/saved-payment-method.js +1 -1
- package/dist/collection/components/checkouts-list/checkouts-list-core.js +1 -1
- package/dist/collection/components/checkouts-list/checkouts-list-filters.js +1 -1
- package/dist/collection/components/checkouts-list/checkouts-list.js +1 -1
- package/dist/collection/components/dispute-management/dispute-management-core.js +1 -1
- package/dist/collection/components/dispute-management/dispute-management.js +1 -1
- package/dist/collection/components/dispute-management/dispute-notification.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/additional-statement.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/cancellation-policy.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/customer-details.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/dispute-response-core.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/dispute-response.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/duplicate-charge.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/electronic-evidence.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/product-or-service.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/refund-policy.js +1 -1
- package/dist/collection/components/dispute-management/dispute-response/shipping-details.js +1 -1
- package/dist/collection/components/filters/table-filters-menu.js +1 -1
- package/dist/collection/components/gross-payment-chart/gross-payment-chart-core.js +1 -1
- package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
- package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
- package/dist/collection/components/modular-checkout/modular-checkout.js +233 -206
- package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +65 -110
- package/dist/collection/components/modular-checkout/sub-components/bank-account-billing-form-simple.js +1 -1
- package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
- package/dist/collection/components/modular-checkout/sub-components/card-billing-form-simple.js +1 -1
- package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
- package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
- package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +853 -0
- package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +125 -0
- package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
- package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
- package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
- package/dist/collection/components/order-terminals/order-terminals.js +1 -1
- package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
- package/dist/collection/components/payment-details/payment-details-core.js +8 -8
- package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
- package/dist/collection/components/payments-list/payments-list-core.js +1 -1
- package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
- package/dist/collection/components/payments-list/payments-list.js +1 -1
- package/dist/collection/components/payout-details/payout-details-core.js +3 -3
- package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
- package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
- package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
- package/dist/collection/components/payouts-list/payouts-list.js +1 -1
- package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
- package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
- package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
- package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
- package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
- package/dist/collection/components/terminals-list/terminals-list.js +1 -1
- package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +82 -34
- package/dist/collection/index.js +1 -0
- package/dist/collection/store/checkout.store.js +48 -2
- package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
- package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
- package/dist/collection/ui-components/form/form-control-date.js +2 -2
- package/dist/collection/ui-components/form/form-control-file-v2.js +1 -1
- package/dist/collection/ui-components/form/form-control-file.js +2 -2
- package/dist/collection/ui-components/form/form-control-monetary.js +2 -2
- package/dist/collection/ui-components/form/form-control-number-masked.js +2 -2
- package/dist/collection/ui-components/form/form-control-number.js +2 -2
- package/dist/collection/ui-components/form/form-control-radio.js +5 -5
- package/dist/collection/ui-components/form/form-control-select.js +2 -2
- package/dist/collection/ui-components/form/form-control-text.js +2 -2
- package/dist/collection/ui-components/form/form-control-textarea.js +2 -2
- package/dist/collection/ui-components/form/hidden-input.js +1 -1
- package/dist/collection/ui-components/form/iframe-input.js +3 -3
- package/dist/collection/ui-components/shadow-dom-components/justifi-button.js +1 -1
- package/dist/collection/ui-components/shadow-dom-components/justifi-header.js +1 -1
- package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
- package/dist/collection/ui-components/shadow-dom-components/justifi-skeleton.js +1 -1
- package/dist/collection/utils/check-pkg-version.js +6 -0
- package/dist/collection/utils/utils.js +5 -0
- package/dist/docs.json +492 -105
- package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
- package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
- package/dist/esm/additional-questions-details_5.entry.js +3 -3
- package/dist/esm/{badge-D4ZXPFjL.js → badge-DSYSJcRy.js} +1 -1
- package/dist/esm/bank-account-document-form-inputs_4.entry.js +9 -9
- package/dist/esm/bank-account-form.entry.js +9 -6
- package/dist/esm/business-details-core.entry.js +4 -4
- package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
- package/dist/esm/{button-C0wLsDP3.js → button-CpllL0At.js} +1 -1
- package/dist/esm/card-form.entry.js +9 -6
- package/dist/esm/{check-pkg-version-BuYkk-jV.js → check-pkg-version-DhRpS7Qc.js} +9 -3
- package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
- package/dist/esm/checkout.store-OD-OX5On.js +86 -0
- package/dist/esm/checkouts-list-core.entry.js +11 -11
- package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
- package/dist/esm/{checkouts-table-DjGKtqoc.js → checkouts-table-Ddf2I-Ul.js} +3 -3
- package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
- package/dist/esm/custom-popper_2.entry.js +3 -3
- package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
- package/dist/esm/form-alert_5.entry.js +1 -1
- package/dist/esm/form-control-checkbox.entry.js +5 -5
- package/dist/esm/form-control-date.entry.js +4 -4
- package/dist/esm/{form-control-error-text-Bzfs_rxk.js → form-control-error-text-R7U07nTg.js} +1 -1
- package/dist/esm/form-control-file-v2_2.entry.js +5 -5
- package/dist/esm/{form-control-help-text-ueLctOBN.js → form-control-help-text-CRLH-2f7.js} +1 -1
- package/dist/esm/form-control-help-text.entry.js +1 -1
- package/dist/esm/form-control-monetary-provisioning.entry.js +3 -3
- package/dist/esm/form-control-monetary.entry.js +6 -6
- package/dist/esm/form-control-number-masked_2.entry.js +4 -4
- package/dist/esm/form-control-number.entry.js +5 -5
- package/dist/esm/form-control-radio.entry.js +3 -3
- package/dist/esm/form-control-select_2.entry.js +6 -6
- package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
- package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
- package/dist/esm/gross-payment-chart-core.entry.js +5 -5
- package/dist/esm/{header-1-BMKEv9y6.js → header-1-3M9If0gM.js} +1 -1
- package/dist/esm/{header-3-C3t3m27b.js → header-3-CWa41YWq.js} +1 -1
- package/dist/esm/hidden-input_2.entry.js +8 -8
- package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
- package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
- package/dist/esm/index-CbL73B6U.js +30 -0
- package/dist/esm/index.js +1 -1
- package/dist/esm/{insurance-state-d4hjThzE.js → insurance-state-CTalqbNa.js} +2 -2
- package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +7 -7
- package/dist/esm/justifi-additional-questions-form-step_9.entry.js +8 -8
- package/dist/esm/justifi-additional-statement_8.entry.js +9 -9
- package/dist/esm/justifi-apple-pay.entry.js +189 -150
- package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +24 -22
- package/dist/esm/justifi-business-details.entry.js +10 -10
- package/dist/esm/justifi-business-form.entry.js +13 -13
- package/dist/esm/justifi-business-representative-form-inputs.entry.js +1 -1
- package/dist/esm/justifi-checkout-summary_7.entry.js +1414 -0
- package/dist/esm/justifi-checkout.entry.js +26 -48
- package/dist/esm/justifi-checkouts-list-filters.entry.js +8 -8
- package/dist/esm/justifi-checkouts-list.entry.js +14 -14
- package/dist/esm/justifi-config-provider.entry.js +3 -3
- package/dist/esm/justifi-details.entry.js +2 -2
- package/dist/esm/justifi-dispute-management-core.entry.js +2 -2
- package/dist/esm/justifi-dispute-management.entry.js +10 -10
- package/dist/esm/justifi-dispute-notification_3.entry.js +15 -15
- package/dist/esm/justifi-gross-payment-chart.entry.js +9 -9
- package/dist/esm/justifi-order-terminals.entry.js +13 -13
- package/dist/esm/justifi-owner-form_3.entry.js +8 -8
- package/dist/esm/justifi-payment-details.entry.js +11 -11
- package/dist/esm/justifi-payment-provisioning-core.entry.js +3 -3
- package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
- package/dist/esm/justifi-payment-transactions-list.entry.js +13 -13
- package/dist/esm/justifi-payments-list-filters.entry.js +7 -7
- package/dist/esm/justifi-payments-list.entry.js +14 -14
- package/dist/esm/justifi-payout-details.entry.js +10 -10
- package/dist/esm/justifi-payout-transactions-list.entry.js +13 -13
- package/dist/esm/justifi-payouts-list-filters.entry.js +7 -7
- package/dist/esm/justifi-payouts-list.entry.js +15 -15
- package/dist/esm/justifi-refund-payment.entry.js +13 -13
- package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
- package/dist/esm/justifi-season-interruption-insurance.entry.js +17 -12
- package/dist/esm/justifi-skeleton.entry.js +4 -4
- package/dist/esm/justifi-terminal-orders-list-filters.entry.js +9 -9
- package/dist/esm/justifi-terminal-orders-list.entry.js +12 -12
- package/dist/esm/justifi-terminals-list-filters.entry.js +8 -8
- package/dist/esm/justifi-terminals-list.entry.js +14 -14
- package/dist/esm/loader.js +3 -3
- package/dist/esm/{package-C60pS6qh.js → package-BF0mIfcQ.js} +1 -1
- package/dist/esm/pagination-menu.entry.js +1 -1
- package/dist/esm/payment-details-core.entry.js +15 -15
- package/dist/esm/payment-method-option.entry.js +3 -3
- package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
- package/dist/esm/payments-list-core.entry.js +12 -12
- package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
- package/dist/esm/{payments-status-1yRdTNeS.js → payments-status-5orNU2Rd.js} +2 -2
- package/dist/esm/{payments-table-8RADYkma.js → payments-table-gkJV5GNK.js} +3 -3
- package/dist/esm/payout-details-core.entry.js +11 -11
- package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
- package/dist/esm/payouts-list-core.entry.js +12 -12
- package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
- package/dist/esm/{payouts-status-BqsQVtBp.js → payouts-status-CZPwa2AE.js} +2 -2
- package/dist/esm/{payouts-table-DPw7yIx8.js → payouts-table-0PtktGRd.js} +3 -3
- package/dist/esm/{skeleton-BmTjpTYa.js → skeleton-qMb0_Cjy.js} +1 -1
- package/dist/esm/{spinner-YGDOI-CS.js → spinner-DUzyWLhj.js} +1 -1
- package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
- package/dist/esm/{table-ybHxxc9f.js → table-Br3n9Xu-.js} +2 -2
- package/dist/esm/table-filters-menu.entry.js +3 -3
- package/dist/esm/terminal-orders-list-core.entry.js +11 -11
- package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
- package/dist/esm/{terminal-orders-table-D-xP5WuM.js → terminal-orders-table-DTBSIMlJ.js} +5 -5
- package/dist/esm/terminal-quantity-selector.entry.js +2 -2
- package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
- package/dist/esm/terminals-list-core.entry.js +11 -11
- package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
- package/dist/esm/{terminals-table-DVAPCgEr.js → terminals-table-TGUKTi7I.js} +3 -3
- package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
- package/dist/esm/{utils-DG5aMFmf.js → utils-Dg6gMUTv.js} +1 -1
- package/dist/esm/webcomponents.js +4 -4
- package/dist/module/Analytics.js +6 -0
- package/dist/module/ModularCheckout.js +30 -0
- package/dist/module/Refund.js +5 -2
- package/dist/module/additional-statement.js +1 -1
- package/dist/module/bank-account-billing-form-simple.js +1 -1
- package/dist/module/bank-account-form.js +5 -2
- package/dist/module/bank-account.js +2 -2
- package/dist/module/cancellation-policy.js +1 -1
- package/dist/module/card-billing-form-simple.js +1 -1
- package/dist/module/card-form.js +5 -2
- package/dist/module/card-form2.js +2 -2
- package/dist/module/checkout.store.js +49 -2
- package/dist/module/checkouts-list-core2.js +1 -1
- package/dist/module/custom-popper2.js +2 -2
- package/dist/module/customer-details.js +1 -1
- package/dist/module/dispute-management-core.js +1 -1
- package/dist/module/dispute-notification.js +1 -1
- package/dist/module/dispute-response-core.js +1 -1
- package/dist/module/dispute-response.js +1 -1
- package/dist/module/duplicate-charge.js +1 -1
- package/dist/module/electronic-evidence.js +1 -1
- package/dist/module/form-control-checkbox2.js +2 -2
- package/dist/module/form-control-date2.js +2 -2
- package/dist/module/form-control-file-v22.js +1 -1
- package/dist/module/form-control-file2.js +2 -2
- package/dist/module/form-control-monetary2.js +2 -2
- package/dist/module/form-control-number-masked2.js +2 -2
- package/dist/module/form-control-number.js +2 -2
- package/dist/module/form-control-radio2.js +3 -3
- package/dist/module/form-control-select2.js +2 -2
- package/dist/module/form-control-text2.js +2 -2
- package/dist/module/form-control-textarea2.js +2 -2
- package/dist/module/gross-payment-chart-core2.js +2 -2
- package/dist/module/hidden-input2.js +1 -1
- package/dist/module/iframe-input2.js +3 -3
- package/dist/module/index.js +1 -0
- package/dist/module/justifi-apple-pay.js +175 -153
- package/dist/module/justifi-button2.js +1 -1
- package/dist/module/justifi-checkout.js +63 -75
- package/dist/module/justifi-checkouts-list-filters.js +1 -1
- package/dist/module/justifi-checkouts-list.js +1 -1
- package/dist/module/justifi-dispute-management.js +1 -1
- package/dist/module/justifi-header2.js +1 -1
- package/dist/module/justifi-order-terminals.js +2 -2
- package/dist/module/justifi-payment-transactions-list.js +1 -1
- package/dist/module/justifi-payments-list-filters.js +2 -2
- package/dist/module/justifi-payments-list.js +1 -1
- package/dist/module/justifi-payout-transactions-list.js +1 -1
- package/dist/module/justifi-payouts-list-filters.js +2 -2
- package/dist/module/justifi-payouts-list.js +1 -1
- package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
- package/dist/module/justifi-plaid-payment-method.js +6 -0
- package/dist/module/justifi-radio-list-item2.js +2 -2
- package/dist/module/justifi-saved-payment-method.js +1 -1
- package/dist/module/justifi-season-interruption-insurance.js +5 -1
- package/dist/module/justifi-skeleton.js +1 -1
- package/dist/module/justifi-terminal-orders-list-filters.js +2 -2
- package/dist/module/justifi-terminal-orders-list.js +1 -1
- package/dist/module/justifi-terminals-list-filters.js +1 -1
- package/dist/module/justifi-terminals-list.js +1 -1
- package/dist/module/modular-checkout.js +184 -162
- package/dist/module/package.js +1 -1
- package/dist/module/payment-details-core2.js +8 -8
- package/dist/module/payment-method-option.js +1 -1
- package/dist/module/payments-list-core2.js +1 -1
- package/dist/module/payout-details-core2.js +3 -3
- package/dist/module/payouts-list-core2.js +1 -1
- package/dist/module/plaid-payment-method.js +635 -0
- package/dist/module/plaid.service.js +26 -0
- package/dist/module/product-or-service.js +1 -1
- package/dist/module/refund-policy.js +1 -1
- package/dist/module/save-new-payment-method.js +3 -1
- package/dist/module/saved-payment-methods.js +7 -5
- package/dist/module/sezzle-payment-method.js +14 -22
- package/dist/module/shipping-details.js +1 -1
- package/dist/module/summary.js +1 -1
- package/dist/module/table-filters-menu2.js +1 -1
- package/dist/module/terminal-orders-list-core2.js +1 -1
- package/dist/module/terminal-quantity-selector2.js +1 -1
- package/dist/module/terminals-list-core2.js +2 -2
- package/dist/module/tokenize-payment-method.js +45 -34
- package/dist/module/utils2.js +6 -1
- package/dist/types/api/ApplePay.d.ts +2 -2
- package/dist/types/api/Checkout.d.ts +9 -14
- package/dist/types/api/Payment.d.ts +4 -3
- package/dist/types/api/index.d.ts +2 -2
- package/dist/types/api/services/apple-pay.service.d.ts +5 -15
- package/dist/types/api/services/plaid.service.d.ts +12 -0
- package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
- package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
- package/dist/types/components/checkout/checkout.d.ts +6 -7
- package/dist/types/components/checkout/save-new-payment-method.d.ts +1 -0
- package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
- package/dist/types/components/modular-checkout/modular-checkout.d.ts +8 -8
- package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +2 -4
- package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +79 -0
- package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
- package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
- package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
- package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +8 -6
- package/dist/types/components.d.ts +70 -27
- package/dist/types/index.d.ts +3 -0
- package/dist/types/store/checkout.store.d.ts +16 -3
- package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
- package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
- package/dist/types/utils/utils.d.ts +1 -0
- package/dist/webcomponents/index.esm.js +1 -0
- package/dist/webcomponents/p-054193e4.entry.js +1 -0
- package/dist/webcomponents/{p-BhdBpAn9.js → p-0Om7jLBs.js} +1 -1
- package/dist/webcomponents/p-0e80830f.entry.js +1 -0
- package/dist/webcomponents/{p-0aa78c58.entry.js → p-12175e07.entry.js} +1 -1
- package/dist/webcomponents/{p-fbaf62a5.entry.js → p-13c21c47.entry.js} +1 -1
- package/dist/webcomponents/p-20733148.entry.js +1 -0
- package/dist/webcomponents/{p-4a79c737.entry.js → p-225ed545.entry.js} +1 -1
- package/dist/webcomponents/p-2550e845.entry.js +1 -0
- package/dist/webcomponents/p-2ae3613e.entry.js +1 -0
- package/dist/webcomponents/{p-bfc38bc2.entry.js → p-319b4126.entry.js} +1 -1
- package/dist/webcomponents/{p-08a5cc2f.entry.js → p-431ba789.entry.js} +1 -1
- package/dist/webcomponents/{p-4c994761.entry.js → p-44450a94.entry.js} +1 -1
- package/dist/webcomponents/p-45e8185c.entry.js +1 -0
- package/dist/webcomponents/{p-dc245644.entry.js → p-46b6142b.entry.js} +4 -4
- package/dist/webcomponents/p-4e1653c2.entry.js +1 -0
- package/dist/webcomponents/p-53739e78.entry.js +1 -0
- package/dist/webcomponents/p-559be51b.entry.js +1 -0
- package/dist/webcomponents/p-58c766c8.entry.js +1 -0
- package/dist/webcomponents/{p-5ad70aae.entry.js → p-613421d4.entry.js} +1 -1
- package/dist/webcomponents/p-62a4a2c2.entry.js +1 -0
- package/dist/webcomponents/p-654d85ca.entry.js +1 -0
- package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
- package/dist/webcomponents/{p-ea1b161a.entry.js → p-664501b7.entry.js} +1 -1
- package/dist/webcomponents/p-6c7f08c8.entry.js +1 -0
- package/dist/webcomponents/p-6cf48f04.entry.js +1 -0
- package/dist/webcomponents/{p-03c7cee8.entry.js → p-70f51444.entry.js} +1 -1
- package/dist/webcomponents/p-778e9fe9.entry.js +1 -0
- package/dist/webcomponents/p-7922acee.entry.js +1 -0
- package/dist/webcomponents/p-7c463a59.entry.js +1 -0
- package/dist/webcomponents/{p-c6860f60.entry.js → p-7cf87637.entry.js} +1 -1
- package/dist/webcomponents/p-7fcbccc7.entry.js +1 -0
- package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
- package/dist/webcomponents/{p-b04cc606.entry.js → p-80331983.entry.js} +1 -1
- package/dist/webcomponents/{p-76a95d07.entry.js → p-8687e5d6.entry.js} +1 -1
- package/dist/webcomponents/p-87acb5ec.entry.js +1 -0
- package/dist/webcomponents/{p-7288473f.entry.js → p-8c95827f.entry.js} +1 -1
- package/dist/webcomponents/{p-55b7bdba.entry.js → p-8e0228df.entry.js} +1 -1
- package/dist/webcomponents/{p-a406bf1a.entry.js → p-8ff839a4.entry.js} +1 -1
- package/dist/webcomponents/p-927ecf5d.entry.js +1 -0
- package/dist/webcomponents/p-93ed5490.entry.js +1 -0
- package/dist/webcomponents/p-95a3e104.entry.js +1 -0
- package/dist/webcomponents/{p-a9d2dd5e.entry.js → p-95cbb655.entry.js} +1 -1
- package/dist/webcomponents/{p-2169c3d1.entry.js → p-95e33bcc.entry.js} +1 -1
- package/dist/webcomponents/{p-4cf9168d.entry.js → p-988ae9e9.entry.js} +1 -1
- package/dist/webcomponents/{p-e8a198fa.entry.js → p-9be67b19.entry.js} +1 -1
- package/dist/webcomponents/p-9c1d5a55.entry.js +1 -0
- package/dist/webcomponents/p-9c621697.entry.js +1 -0
- package/dist/webcomponents/p-9ed62efb.entry.js +1 -0
- package/dist/webcomponents/p-B71k50jz.js +1 -0
- package/dist/webcomponents/p-BF0mIfcQ.js +1 -0
- package/dist/webcomponents/p-BF4U0yVj.js +1 -0
- package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
- package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
- package/dist/webcomponents/p-BSt6p1oq.js +1 -0
- package/dist/webcomponents/p-BY1mRAvj.js +1 -0
- package/dist/webcomponents/{p-nWGo6sHu.js → p-Bb-6bNcq.js} +1 -1
- package/dist/webcomponents/p-BbZwa5UI.js +1 -0
- package/dist/webcomponents/p-BdKWuCys.js +1 -0
- package/dist/webcomponents/{p-BZzESzqz.js → p-BfM6X7lF.js} +1 -1
- package/dist/webcomponents/p-BjVfIXWC.js +1 -0
- package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
- package/dist/webcomponents/{p-wyEq9Pa1.js → p-BsGE9UDv.js} +1 -1
- package/dist/webcomponents/{p-CP_tg-uH.js → p-C5id7s_l.js} +1 -1
- package/dist/webcomponents/{p-DBsw4qpn.js → p-CAJnQLZF.js} +1 -1
- package/dist/webcomponents/{p-HAk7yBNq.js → p-CB0mCq1M.js} +1 -1
- package/dist/webcomponents/p-CItulios.js +1 -0
- package/dist/webcomponents/p-CaAVuW6B.js +1 -0
- package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
- package/dist/webcomponents/p-CbL73B6U.js +1 -0
- package/dist/webcomponents/p-CpaS1Lex.js +1 -0
- package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
- package/dist/webcomponents/p-DDUmOl3v.js +1 -0
- package/dist/webcomponents/p-DIDloHpm.js +1 -0
- package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
- package/dist/webcomponents/{p-DuXN7Akd.js → p-DNo0OPOP.js} +1 -1
- package/dist/webcomponents/{p-BUadwxkh.js → p-DRXvcLy9.js} +1 -1
- package/dist/webcomponents/p-Da3idOSV.js +1 -0
- package/dist/webcomponents/p-Dgflaz6J.js +1 -0
- package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
- package/dist/webcomponents/p-DsZZxRXY.js +1 -0
- package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
- package/dist/webcomponents/p-ED_TzwCp.js +1 -0
- package/dist/webcomponents/p-JyHlIFWl.js +1 -0
- package/dist/webcomponents/{p-D9Sv4eV5.js → p-VSSGd2zP.js} +1 -1
- package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
- package/dist/webcomponents/{p-c62e23c1.entry.js → p-a5114207.entry.js} +1 -1
- package/dist/webcomponents/p-a54281e8.entry.js +1 -0
- package/dist/webcomponents/{p-ab308ee3.entry.js → p-a7ac285c.entry.js} +1 -1
- package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
- package/dist/webcomponents/{p-1b892b3a.entry.js → p-bf2df971.entry.js} +1 -1
- package/dist/webcomponents/p-cff8ae71.entry.js +1 -0
- package/dist/webcomponents/p-d031ad31.entry.js +1 -0
- package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
- package/dist/webcomponents/p-d5d271d3.entry.js +1 -0
- package/dist/webcomponents/p-d8f9f287.entry.js +1 -0
- package/dist/webcomponents/{p-92efb3f2.entry.js → p-d9d371e1.entry.js} +1 -1
- package/dist/webcomponents/p-dba55699.entry.js +1 -0
- package/dist/webcomponents/p-e5282f6c.entry.js +1 -0
- package/dist/webcomponents/p-e7b66120.entry.js +1 -0
- package/dist/webcomponents/p-e9a5c837.entry.js +1 -0
- package/dist/webcomponents/p-eP3fmhta.js +1 -0
- package/dist/webcomponents/{p-5afbfafb.entry.js → p-eb2d9e5b.entry.js} +1 -1
- package/dist/webcomponents/p-ed53b213.entry.js +1 -0
- package/dist/webcomponents/{p-afc83e27.entry.js → p-f1cba43c.entry.js} +1 -1
- package/dist/webcomponents/p-f499a8de.entry.js +1 -0
- package/dist/webcomponents/p-f680e617.entry.js +1 -0
- package/dist/webcomponents/p-fa31c907.entry.js +1 -0
- package/dist/webcomponents/p-ff685149.entry.js +1 -0
- package/dist/webcomponents/p-sw5RO19U.js +1 -0
- package/dist/webcomponents/p-z-5r0gWn.js +1 -0
- package/dist/webcomponents/webcomponents.esm.js +1 -1
- package/package.json +2 -2
- package/dist/cjs/checkout.store-Cn3Jj5gi.js +0 -40
- package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -785
- package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
- package/dist/esm/checkout.store-OAv_iY1u.js +0 -37
- package/dist/esm/justifi-checkout-summary_6.entry.js +0 -778
- package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
- package/dist/webcomponents/p-0aee6da6.entry.js +0 -1
- package/dist/webcomponents/p-0e64cd09.entry.js +0 -1
- package/dist/webcomponents/p-1202181b.entry.js +0 -1
- package/dist/webcomponents/p-1246b999.entry.js +0 -1
- package/dist/webcomponents/p-12c312a0.entry.js +0 -1
- package/dist/webcomponents/p-1a83d9f2.entry.js +0 -1
- package/dist/webcomponents/p-1c0c1d7b.entry.js +0 -1
- package/dist/webcomponents/p-1e206c92.entry.js +0 -1
- package/dist/webcomponents/p-281e36be.entry.js +0 -1
- package/dist/webcomponents/p-2988e82c.entry.js +0 -1
- package/dist/webcomponents/p-2a0a907d.entry.js +0 -1
- package/dist/webcomponents/p-32cc081a.entry.js +0 -1
- package/dist/webcomponents/p-387bcdee.entry.js +0 -1
- package/dist/webcomponents/p-41416b5f.entry.js +0 -1
- package/dist/webcomponents/p-42994618.entry.js +0 -1
- package/dist/webcomponents/p-5510b57c.entry.js +0 -1
- package/dist/webcomponents/p-59e8f027.entry.js +0 -1
- package/dist/webcomponents/p-5a5f07be.entry.js +0 -1
- package/dist/webcomponents/p-5acd6add.entry.js +0 -1
- package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
- package/dist/webcomponents/p-6974a44c.entry.js +0 -1
- package/dist/webcomponents/p-6f2b41f5.entry.js +0 -1
- package/dist/webcomponents/p-6f9755cc.entry.js +0 -1
- package/dist/webcomponents/p-7WIgS5RM.js +0 -1
- package/dist/webcomponents/p-7b9fa1fb.entry.js +0 -1
- package/dist/webcomponents/p-98939b74.entry.js +0 -1
- package/dist/webcomponents/p-BVD7g3cE.js +0 -1
- package/dist/webcomponents/p-BXKEChoo.js +0 -1
- package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
- package/dist/webcomponents/p-BmFoKOM3.js +0 -1
- package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
- package/dist/webcomponents/p-Bt388eye.js +0 -1
- package/dist/webcomponents/p-BtOB_CaO.js +0 -1
- package/dist/webcomponents/p-BySyDTv5.js +0 -1
- package/dist/webcomponents/p-C0AHrswP.js +0 -1
- package/dist/webcomponents/p-C60pS6qh.js +0 -1
- package/dist/webcomponents/p-CLwzqWk2.js +0 -1
- package/dist/webcomponents/p-CVQyw7ao.js +0 -1
- package/dist/webcomponents/p-D48iERjQ.js +0 -1
- package/dist/webcomponents/p-D7eeJWA-.js +0 -1
- package/dist/webcomponents/p-DD74a16D.js +0 -1
- package/dist/webcomponents/p-DKRXPZKS.js +0 -1
- package/dist/webcomponents/p-DOd8HaWV.js +0 -1
- package/dist/webcomponents/p-DaDsBt65.js +0 -1
- package/dist/webcomponents/p-DcE8SQPv.js +0 -1
- package/dist/webcomponents/p-Drz6LnIw.js +0 -1
- package/dist/webcomponents/p-WEguiGt1.js +0 -1
- package/dist/webcomponents/p-a1a8f6bd.entry.js +0 -1
- package/dist/webcomponents/p-a70bc148.entry.js +0 -1
- package/dist/webcomponents/p-b41d2b8f.entry.js +0 -1
- package/dist/webcomponents/p-b8f63e28.entry.js +0 -1
- package/dist/webcomponents/p-ba84c3bd.entry.js +0 -1
- package/dist/webcomponents/p-c7e5245a.entry.js +0 -1
- package/dist/webcomponents/p-cabaf013.entry.js +0 -1
- package/dist/webcomponents/p-cbfc8269.entry.js +0 -1
- package/dist/webcomponents/p-cf16498f.entry.js +0 -1
- package/dist/webcomponents/p-d014a155.entry.js +0 -1
- package/dist/webcomponents/p-e6ca1872.entry.js +0 -1
- package/dist/webcomponents/p-eff0b0e9.entry.js +0 -1
- package/dist/webcomponents/p-f3be7b2b.entry.js +0 -1
- package/dist/webcomponents/p-f787bc18.entry.js +0 -1
- package/dist/webcomponents/p-fb1904d2.entry.js +0 -1
- package/dist/webcomponents/p-fcb6e870.entry.js +0 -1
- package/dist/webcomponents/p-pska2q1M.js +0 -1
|
@@ -1,23 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Api } from "../Api";
|
|
2
2
|
import { ApplePaySessionStatus, ApplePayHelpers, ApplePayConfig, ApplePayPaymentRequest, } from "../ApplePay";
|
|
3
3
|
export class ApplePayService {
|
|
4
4
|
constructor() {
|
|
5
|
-
this.
|
|
6
|
-
}
|
|
7
|
-
/**
|
|
8
|
-
* Set custom API base URL
|
|
9
|
-
*/
|
|
10
|
-
setApiBaseUrl(url) {
|
|
11
|
-
this.apiBaseUrl = url;
|
|
12
|
-
}
|
|
13
|
-
/**
|
|
14
|
-
* Set authentication token
|
|
15
|
-
*/
|
|
16
|
-
setAuthToken(authToken) {
|
|
17
|
-
this.authToken = authToken;
|
|
18
|
-
}
|
|
19
|
-
setAccountId(accountId) {
|
|
20
|
-
this.accountId = accountId;
|
|
5
|
+
this.api = Api();
|
|
21
6
|
}
|
|
22
7
|
/**
|
|
23
8
|
* Initialize Apple Pay configuration
|
|
@@ -31,55 +16,36 @@ export class ApplePayService {
|
|
|
31
16
|
/**
|
|
32
17
|
* Validate merchant with Apple Pay servers via API
|
|
33
18
|
*/
|
|
34
|
-
async validateMerchant(authToken) {
|
|
35
|
-
const endpoint =
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
console.log('Response status:', response.status);
|
|
50
|
-
if (!response.ok) {
|
|
51
|
-
const errorData = await response.text();
|
|
52
|
-
console.error('Backend validation failed - Raw response:', errorData);
|
|
53
|
-
try {
|
|
54
|
-
const jsonError = JSON.parse(errorData);
|
|
55
|
-
console.error('Backend validation failed - Parsed error:', jsonError);
|
|
56
|
-
}
|
|
57
|
-
catch (parseError) {
|
|
58
|
-
console.error('Could not parse error response as JSON:', parseError);
|
|
59
|
-
}
|
|
60
|
-
throw new Error(`Merchant validation failed: ${response.status}`);
|
|
19
|
+
async validateMerchant(authToken, accountId) {
|
|
20
|
+
const endpoint = 'apple_pay/merchant_session';
|
|
21
|
+
try {
|
|
22
|
+
const response = await this.api.post({
|
|
23
|
+
endpoint,
|
|
24
|
+
authToken,
|
|
25
|
+
headers: {
|
|
26
|
+
'Sub-Account': accountId,
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
return response;
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
console.error('Backend validation failed:', error);
|
|
33
|
+
throw new Error('Merchant validation failed');
|
|
61
34
|
}
|
|
62
|
-
const merchantSession = await response.json();
|
|
63
|
-
console.log('Merchant session received:', merchantSession);
|
|
64
|
-
return merchantSession;
|
|
65
35
|
}
|
|
66
36
|
/**
|
|
67
37
|
* Process Apple Pay payment via API (fixed to match original logic)
|
|
68
38
|
*/
|
|
69
|
-
async processPayment(authToken, payload) {
|
|
70
|
-
const endpoint =
|
|
71
|
-
const
|
|
72
|
-
|
|
73
|
-
|
|
39
|
+
async processPayment(authToken, accountId, payload) {
|
|
40
|
+
const endpoint = 'apple_pay/process_token';
|
|
41
|
+
const result = await this.api.post({
|
|
42
|
+
endpoint,
|
|
43
|
+
authToken,
|
|
44
|
+
body: payload,
|
|
74
45
|
headers: {
|
|
75
|
-
'
|
|
76
|
-
Accept: 'application/json',
|
|
77
|
-
Authorization: `Bearer ${authToken}`,
|
|
78
|
-
'Sub-Account': this.accountId,
|
|
46
|
+
'Sub-Account': accountId,
|
|
79
47
|
},
|
|
80
|
-
body: JSON.stringify(body),
|
|
81
48
|
});
|
|
82
|
-
const result = await response.json();
|
|
83
49
|
return {
|
|
84
50
|
success: result.id && !!result.data.token,
|
|
85
51
|
data: result,
|
|
@@ -103,25 +69,67 @@ export class ApplePayService {
|
|
|
103
69
|
/**
|
|
104
70
|
* Start Apple Pay session
|
|
105
71
|
*/
|
|
106
|
-
async startPaymentSession(paymentRequest) {
|
|
72
|
+
async startPaymentSession(paymentRequest, authToken, accountId) {
|
|
73
|
+
// Begin verbose diagnostics for easier debugging in the field
|
|
74
|
+
console.groupCollapsed('[ApplePayService] startPaymentSession called');
|
|
75
|
+
console.log('[ApplePayService] raw paymentRequest:', JSON.stringify(paymentRequest, null, 2));
|
|
76
|
+
console.log('[ApplePayService] has authToken:', Boolean(authToken));
|
|
77
|
+
console.log('[ApplePayService] accountId:', accountId);
|
|
78
|
+
console.log('[ApplePayService] has config:', Boolean(this.applePayConfig));
|
|
107
79
|
if (!this.applePayConfig) {
|
|
80
|
+
console.error('[ApplePayService] Missing applePayConfig. Did you call initialize()?');
|
|
81
|
+
console.groupEnd();
|
|
108
82
|
throw new Error('Apple Pay not initialized. Call initialize() first.');
|
|
109
83
|
}
|
|
110
84
|
// if (!this.isAvailable()) {
|
|
111
85
|
// throw new Error('Apple Pay is not available on this device/browser');
|
|
112
86
|
// }
|
|
113
87
|
const request = new ApplePayPaymentRequest(paymentRequest);
|
|
88
|
+
console.log('[ApplePayService] created ApplePayPaymentRequest:', request);
|
|
114
89
|
if (!request.isValid) {
|
|
90
|
+
const missingFields = [];
|
|
91
|
+
if (!request.countryCode)
|
|
92
|
+
missingFields.push('countryCode');
|
|
93
|
+
if (!request.currencyCode)
|
|
94
|
+
missingFields.push('currencyCode');
|
|
95
|
+
if (!request.merchantCapabilities ||
|
|
96
|
+
request.merchantCapabilities.length === 0)
|
|
97
|
+
missingFields.push('merchantCapabilities');
|
|
98
|
+
if (!request.supportedNetworks || request.supportedNetworks.length === 0)
|
|
99
|
+
missingFields.push('supportedNetworks');
|
|
100
|
+
if (!request.total || !request.total.label || !request.total.amount)
|
|
101
|
+
missingFields.push('total');
|
|
102
|
+
console.error('[ApplePayService] Payment request is invalid. Missing/invalid:', missingFields);
|
|
103
|
+
console.groupEnd();
|
|
115
104
|
throw new Error('Invalid payment request provided');
|
|
116
105
|
}
|
|
117
106
|
this.currentPaymentRequest = request;
|
|
118
107
|
return new Promise((resolve, reject) => {
|
|
119
108
|
try {
|
|
109
|
+
console.log('[ApplePayService] About to instantiate ApplePaySession');
|
|
110
|
+
// Defensive checks for Apple Pay environment
|
|
111
|
+
if (typeof window === 'undefined' || !('ApplePaySession' in window)) {
|
|
112
|
+
console.error('[ApplePayService] ApplePaySession not available on window');
|
|
113
|
+
console.groupEnd();
|
|
114
|
+
return reject({
|
|
115
|
+
success: false,
|
|
116
|
+
error: {
|
|
117
|
+
code: 'APPLE_PAY_UNAVAILABLE',
|
|
118
|
+
message: 'ApplePaySession API is not available in this environment',
|
|
119
|
+
},
|
|
120
|
+
});
|
|
121
|
+
}
|
|
120
122
|
this.currentSession = new window.ApplePaySession(3, request);
|
|
121
|
-
|
|
123
|
+
console.log('[ApplePayService] ApplePaySession instantiated:', this.currentSession);
|
|
124
|
+
this.setupSessionEventHandlers(resolve, reject, authToken, accountId);
|
|
125
|
+
console.log('[ApplePayService] Event handlers set. Beginning session...');
|
|
122
126
|
this.currentSession.begin();
|
|
127
|
+
console.log('[ApplePayService] Session.begin() called');
|
|
128
|
+
console.groupEnd();
|
|
123
129
|
}
|
|
124
130
|
catch (error) {
|
|
131
|
+
console.error('[ApplePayService] Exception while starting session:', error);
|
|
132
|
+
console.groupEnd();
|
|
125
133
|
reject({
|
|
126
134
|
success: false,
|
|
127
135
|
error: {
|
|
@@ -147,20 +155,30 @@ export class ApplePayService {
|
|
|
147
155
|
/**
|
|
148
156
|
* Setup Apple Pay session event handlers
|
|
149
157
|
*/
|
|
150
|
-
setupSessionEventHandlers(resolve, reject) {
|
|
158
|
+
setupSessionEventHandlers(resolve, reject, authToken, accountId) {
|
|
151
159
|
if (!this.currentSession ||
|
|
152
160
|
!this.applePayConfig ||
|
|
153
161
|
!this.currentPaymentRequest) {
|
|
162
|
+
console.error('[ApplePayService] setupSessionEventHandlers called without required state', {
|
|
163
|
+
hasSession: Boolean(this.currentSession),
|
|
164
|
+
hasConfig: Boolean(this.applePayConfig),
|
|
165
|
+
hasPaymentRequest: Boolean(this.currentPaymentRequest),
|
|
166
|
+
});
|
|
154
167
|
return;
|
|
155
168
|
}
|
|
156
169
|
this.currentSession.onvalidatemerchant = async () => {
|
|
170
|
+
console.groupCollapsed('[ApplePayService] onvalidatemerchant');
|
|
157
171
|
try {
|
|
158
|
-
|
|
159
|
-
|
|
172
|
+
console.log('[ApplePayService] accountId:', accountId);
|
|
173
|
+
if (!authToken) {
|
|
174
|
+
console.error('[ApplePayService] Missing authToken for merchant validation');
|
|
175
|
+
throw new Error('Authentication token not provided.');
|
|
160
176
|
}
|
|
161
|
-
const merchantSession = await this.validateMerchant(
|
|
177
|
+
const merchantSession = await this.validateMerchant(authToken, accountId);
|
|
178
|
+
console.log('[ApplePayService] merchantSession received');
|
|
162
179
|
try {
|
|
163
180
|
this.currentSession.completeMerchantValidation(merchantSession);
|
|
181
|
+
console.log('[ApplePayService] completeMerchantValidation called');
|
|
164
182
|
}
|
|
165
183
|
catch (completionError) {
|
|
166
184
|
console.error('Error calling completeMerchantValidation:', completionError);
|
|
@@ -170,7 +188,9 @@ export class ApplePayService {
|
|
|
170
188
|
catch (error) {
|
|
171
189
|
console.error('=== MERCHANT VALIDATION ERROR ===');
|
|
172
190
|
console.error('Error during merchant validation:', error);
|
|
173
|
-
|
|
191
|
+
if (error && error.stack) {
|
|
192
|
+
console.error('Error stack:', error.stack);
|
|
193
|
+
}
|
|
174
194
|
this.currentSession.abort();
|
|
175
195
|
reject({
|
|
176
196
|
success: false,
|
|
@@ -182,26 +202,34 @@ export class ApplePayService {
|
|
|
182
202
|
},
|
|
183
203
|
});
|
|
184
204
|
}
|
|
205
|
+
console.groupEnd();
|
|
185
206
|
};
|
|
186
207
|
this.currentSession.onpaymentauthorized = async (event) => {
|
|
208
|
+
var _a;
|
|
209
|
+
console.groupCollapsed('[ApplePayService] onpaymentauthorized');
|
|
187
210
|
try {
|
|
188
211
|
const payment = event.payment;
|
|
212
|
+
console.log('[ApplePayService] payment payload snapshot:', {
|
|
213
|
+
hasToken: Boolean(payment === null || payment === void 0 ? void 0 : payment.token),
|
|
214
|
+
tokenType: ((_a = payment === null || payment === void 0 ? void 0 : payment.token) === null || _a === void 0 ? void 0 : _a.paymentData) ? 'paymentData' : 'raw',
|
|
215
|
+
});
|
|
189
216
|
const paymentPayload = Object.assign(Object.assign({}, payment.token), { product_details: {
|
|
190
217
|
name: this.currentPaymentRequest.total.label,
|
|
191
218
|
price: ApplePayHelpers.parseAmount(this.currentPaymentRequest.total.amount),
|
|
192
219
|
description: this.currentPaymentRequest.total.label,
|
|
193
220
|
} });
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
const paymentResult = await this.processPayment(this.authToken, paymentPayload);
|
|
221
|
+
console.log('[ApplePayService] paymentPayload prepared');
|
|
222
|
+
const paymentResult = await this.processPayment(authToken, accountId, paymentPayload);
|
|
223
|
+
console.log('[ApplePayService] processPayment result:', paymentResult);
|
|
198
224
|
if (paymentResult.success) {
|
|
199
225
|
this.currentSession.completePayment({
|
|
200
226
|
status: ApplePaySessionStatus.STATUS_SUCCESS,
|
|
201
227
|
});
|
|
228
|
+
console.log('[ApplePayService] Payment success; resolving');
|
|
202
229
|
resolve({
|
|
203
230
|
success: true,
|
|
204
231
|
token: payment.token,
|
|
232
|
+
paymentMethodId: paymentResult.data.id,
|
|
205
233
|
});
|
|
206
234
|
}
|
|
207
235
|
else {
|
|
@@ -221,7 +249,9 @@ export class ApplePayService {
|
|
|
221
249
|
catch (error) {
|
|
222
250
|
console.error('=== PAYMENT PROCESSING ERROR ===');
|
|
223
251
|
console.error('Error processing payment:', error);
|
|
224
|
-
|
|
252
|
+
if (error && error.stack) {
|
|
253
|
+
console.error('Error stack:', error.stack);
|
|
254
|
+
}
|
|
225
255
|
this.currentSession.completePayment({
|
|
226
256
|
status: ApplePaySessionStatus.STATUS_FAILURE,
|
|
227
257
|
});
|
|
@@ -236,31 +266,40 @@ export class ApplePayService {
|
|
|
236
266
|
});
|
|
237
267
|
}
|
|
238
268
|
finally {
|
|
269
|
+
console.log('[ApplePayService] Cleaning up session state');
|
|
239
270
|
this.currentSession = undefined;
|
|
240
271
|
this.currentPaymentRequest = undefined;
|
|
241
272
|
}
|
|
273
|
+
console.groupEnd();
|
|
242
274
|
};
|
|
243
275
|
this.currentSession.onpaymentmethodselected = () => {
|
|
276
|
+
console.groupCollapsed('[ApplePayService] onpaymentmethodselected');
|
|
244
277
|
const paymentUpdate = {
|
|
245
278
|
newTotal: this.currentPaymentRequest.total,
|
|
246
279
|
newLineItems: this.currentPaymentRequest.lineItems || [],
|
|
247
280
|
};
|
|
248
281
|
try {
|
|
249
282
|
this.currentSession.completePaymentMethodSelection(paymentUpdate);
|
|
283
|
+
console.log('[ApplePayService] completePaymentMethodSelection called');
|
|
250
284
|
}
|
|
251
285
|
catch (error) {
|
|
252
286
|
console.error('Error completing payment method selection:', error);
|
|
253
287
|
this.currentSession.abort();
|
|
254
288
|
}
|
|
289
|
+
console.groupEnd();
|
|
255
290
|
};
|
|
256
291
|
this.currentSession.onshippingmethodselected = () => {
|
|
292
|
+
console.groupCollapsed('[ApplePayService] onshippingmethodselected');
|
|
257
293
|
this.currentSession.completeShippingMethodSelection({
|
|
258
294
|
status: ApplePaySessionStatus.STATUS_SUCCESS,
|
|
259
295
|
newTotal: this.currentPaymentRequest.total,
|
|
260
296
|
newLineItems: this.currentPaymentRequest.lineItems || [],
|
|
261
297
|
});
|
|
298
|
+
console.log('[ApplePayService] completeShippingMethodSelection called');
|
|
299
|
+
console.groupEnd();
|
|
262
300
|
};
|
|
263
301
|
this.currentSession.oncancel = (event) => {
|
|
302
|
+
console.groupCollapsed('[ApplePayService] oncancel');
|
|
264
303
|
if (event.sessionError) {
|
|
265
304
|
console.error(event.sessionError);
|
|
266
305
|
switch (event.sessionError.code) {
|
|
@@ -291,9 +330,11 @@ export class ApplePayService {
|
|
|
291
330
|
message: 'User cancelled the Apple Pay session',
|
|
292
331
|
},
|
|
293
332
|
});
|
|
333
|
+
console.groupEnd();
|
|
294
334
|
};
|
|
295
335
|
if ('onerror' in this.currentSession) {
|
|
296
336
|
this.currentSession.onerror = (error) => {
|
|
337
|
+
console.groupCollapsed('[ApplePayService] onerror');
|
|
297
338
|
console.error('=== APPLE PAY SESSION ERROR ===');
|
|
298
339
|
console.error('Session error:', error);
|
|
299
340
|
this.currentSession = undefined;
|
|
@@ -305,6 +346,7 @@ export class ApplePayService {
|
|
|
305
346
|
message: 'Apple Pay session error occurred',
|
|
306
347
|
},
|
|
307
348
|
});
|
|
349
|
+
console.groupEnd();
|
|
308
350
|
};
|
|
309
351
|
}
|
|
310
352
|
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Api } from "..";
|
|
2
|
+
const api = Api();
|
|
3
|
+
export class PlaidService {
|
|
4
|
+
async getLinkToken(authToken, accountId, checkoutId, signal) {
|
|
5
|
+
const endpoint = `plaid/${accountId}/link`;
|
|
6
|
+
const body = { checkout_id: checkoutId };
|
|
7
|
+
return api.post({ endpoint, body, authToken, signal });
|
|
8
|
+
}
|
|
9
|
+
async tokenizeBankAccount(authToken, accountId, publicToken, linkTokenId, paymentMethodGroupId, signal) {
|
|
10
|
+
const endpoint = `plaid/${accountId}/tokenize`;
|
|
11
|
+
const body = { public_token: publicToken };
|
|
12
|
+
if (linkTokenId) {
|
|
13
|
+
body.link_token_id = linkTokenId;
|
|
14
|
+
}
|
|
15
|
+
if (paymentMethodGroupId) {
|
|
16
|
+
body.payment_method_group_id = paymentMethodGroupId;
|
|
17
|
+
}
|
|
18
|
+
return api.post({ endpoint, body, authToken, signal });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg height="48" viewBox="0 0 28 29" xmlns="http://www.w3.org/2000/svg" class="css-1rdaj8m"><g fill="#111" fill-rule="evenodd"><path d="M25.7629 26.2628L28 17.5309L24.9691 14.5001L27.9999 11.4691L25.7628 2.73706L17.0309 0.5L14.0001 3.531L10.969 0.50014L2.23706 2.73734L0 11.4691L3.03128 14.4999L0.00014 17.531L2.2372 26.2629L10.9691 28.5L14.0001 25.469L17.031 28.4999L25.7629 26.2628ZM15.7321 23.7371L18.6186 20.8505L22.2912 24.5233L17.6956 25.7007L15.7321 23.7371ZM11.1136 9.88154L14.0003 6.99502L16.8868 9.8814L14.0001 12.7679L11.1136 9.88154ZM12.2682 14.5L9.38154 17.3865L6.49502 14.5L9.38154 11.6135L12.2682 14.5ZM18.6187 11.6133L21.5053 14.5L18.6186 17.3865L15.7321 14.5L18.6187 11.6133ZM16.8867 19.1186L14.0001 22.0051L11.1135 19.1185L14.0001 16.2319L16.8867 19.1186ZM10.3044 25.7007L5.70864 24.5233L9.38154 20.8504L12.2682 23.7371L10.3044 25.7007ZM4.76308 16.2319L7.6496 19.1185L3.9767 22.7914L2.7993 18.1957L4.76308 16.2319ZM3.9767 6.20836L7.64974 9.8814L4.76308 12.7681L2.7993 10.8041L3.9767 6.20836ZM12.2683 5.26294L9.38168 8.1496L5.70892 4.4767L10.3047 3.2993L12.2683 5.26294ZM17.6959 3.2993L22.2915 4.4767L18.6186 8.14946L15.7321 5.26294L17.6959 3.2993ZM23.2372 12.7681L20.3505 9.8814L24.0233 6.20878L25.2007 10.8046L23.2372 12.7681ZM24.0233 22.7914L20.3505 19.1186L23.2372 16.2321L25.2007 18.1957L24.0233 22.7914Z"></path></g></svg>
|
|
@@ -50,6 +50,7 @@
|
|
|
50
50
|
"components/modular-checkout/sub-components/card-billing-form-simple.js",
|
|
51
51
|
"components/modular-checkout/sub-components/bank-account-billing-form-simple.js",
|
|
52
52
|
"components/checkout/card-form/card-form.js",
|
|
53
|
+
"ui-components/form/form-control-checkbox.js",
|
|
53
54
|
"components/checkouts-list/checkouts-list-core.js",
|
|
54
55
|
"components/checkouts-list/checkouts-list-filters.js",
|
|
55
56
|
"components/checkouts-list/checkouts-list.js",
|
|
@@ -77,6 +78,7 @@
|
|
|
77
78
|
"components/modular-checkout/sub-components/bank-account.js",
|
|
78
79
|
"components/modular-checkout/sub-components/card-form.js",
|
|
79
80
|
"components/modular-checkout/sub-components/payment-method-option.js",
|
|
81
|
+
"components/modular-checkout/sub-components/plaid-payment-method.js",
|
|
80
82
|
"components/modular-checkout/sub-components/saved-payment-methods.js",
|
|
81
83
|
"components/modular-checkout/sub-components/sezzle-payment-method.js",
|
|
82
84
|
"components/modular-checkout/sub-components/summary.js",
|
|
@@ -104,7 +106,6 @@
|
|
|
104
106
|
"components/terminals-list/terminals-list.js",
|
|
105
107
|
"components/tokenize-payment-method/tokenize-payment-method.js",
|
|
106
108
|
"ui-components/custom-popper/custom-popper.js",
|
|
107
|
-
"ui-components/form/form-control-checkbox.js",
|
|
108
109
|
"ui-components/form/form-control-file-v2.js",
|
|
109
110
|
"ui-components/form/form-control-file.js",
|
|
110
111
|
"ui-components/form/form-control-monetary.js",
|
|
@@ -124,7 +125,7 @@
|
|
|
124
125
|
],
|
|
125
126
|
"compiler": {
|
|
126
127
|
"name": "@stencil/core",
|
|
127
|
-
"version": "4.36.
|
|
128
|
+
"version": "4.36.3",
|
|
128
129
|
"typescriptVersion": "5.5.4"
|
|
129
130
|
},
|
|
130
131
|
"collections": [],
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { h, Host } from "@stencil/core";
|
|
2
2
|
import BankAccountFormSkeleton from "./bank-account-form-skeleton";
|
|
3
3
|
import { configState, waitForConfig } from "../../config-provider/config-state";
|
|
4
|
+
import { generateTabId } from "../../../utils/utils";
|
|
4
5
|
export class BankAccountForm {
|
|
5
6
|
constructor() {
|
|
6
7
|
this.isReady = false;
|
|
@@ -8,6 +9,7 @@ export class BankAccountForm {
|
|
|
8
9
|
async componentWillLoad() {
|
|
9
10
|
await waitForConfig();
|
|
10
11
|
this.iframeOrigin = configState.iframeOrigin;
|
|
12
|
+
this.tabId = generateTabId();
|
|
11
13
|
}
|
|
12
14
|
componentDidRender() {
|
|
13
15
|
const elements = [
|
|
@@ -31,16 +33,17 @@ export class BankAccountForm {
|
|
|
31
33
|
return this.accountNumberIframeElement.tokenize(clientId, paymentMethodMetadata, account);
|
|
32
34
|
}
|
|
33
35
|
render() {
|
|
34
|
-
return (h(Host, { key: '
|
|
36
|
+
return (h(Host, { key: '7ee7c6e3c26ab1a90bdbf7215fe13f65aade1025' }, h(BankAccountFormSkeleton, { key: 'e4afc94a21b041972d031cfce88a102f763932d1', isReady: this.isReady }), h("div", { key: '8980e0dc0048dbd9cd93a4f93fab8c4cbfeef611', class: "container-fluid p-0", style: {
|
|
35
37
|
opacity: this.isReady ? '1' : '0',
|
|
36
38
|
height: this.isReady ? 'auto' : '0',
|
|
37
|
-
} }, h("div", { key: '
|
|
39
|
+
} }, h("div", { key: 'd04bb6b18498de9646ba6e2ee32f223774a72cc7', class: "row mb-3" }, h("iframe-input", { key: '7eb29da8beff34cbe5d2b7c151fec433d17f8555', inputId: "accountNumber", ref: (el) => (this.accountNumberIframeElement = el), label: "Account Number", iframeOrigin: `${this.iframeOrigin}/v2/accountNumber?tabId=${this.tabId}` })), h("div", { key: 'c6345cddc37cbe5627ca4581fb98be55b85550a6', class: "row" }, h("iframe-input", { key: '0bf71a22e9126e04f15f213d84953ccfd3388ef0', inputId: "routingNumber", ref: (el) => (this.routingNumberIframeElement = el), label: "Routing Number", iframeOrigin: `${this.iframeOrigin}/v2/routingNumber?tabId=${this.tabId}` })))));
|
|
38
40
|
}
|
|
39
41
|
static get is() { return "bank-account-form"; }
|
|
40
42
|
static get states() {
|
|
41
43
|
return {
|
|
42
44
|
"isReady": {},
|
|
43
|
-
"iframeOrigin": {}
|
|
45
|
+
"iframeOrigin": {},
|
|
46
|
+
"tabId": {}
|
|
44
47
|
};
|
|
45
48
|
}
|
|
46
49
|
static get methods() {
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { h, Host } from "@stencil/core";
|
|
2
2
|
import CardFormSkeleton from "./card-form-skeleton";
|
|
3
3
|
import { configState, waitForConfig } from "../../config-provider/config-state";
|
|
4
|
+
import { generateTabId } from "../../../utils/utils";
|
|
4
5
|
export class CardForm {
|
|
5
6
|
constructor() {
|
|
6
7
|
this.isReady = false;
|
|
@@ -8,6 +9,7 @@ export class CardForm {
|
|
|
8
9
|
async componentWillLoad() {
|
|
9
10
|
await waitForConfig();
|
|
10
11
|
this.iframeOrigin = configState.iframeOrigin;
|
|
12
|
+
this.tabId = generateTabId();
|
|
11
13
|
}
|
|
12
14
|
componentDidRender() {
|
|
13
15
|
const elements = [
|
|
@@ -35,16 +37,17 @@ export class CardForm {
|
|
|
35
37
|
return this.cardNumberIframeElement.tokenize(clientId, paymentMethodMetadata, account);
|
|
36
38
|
}
|
|
37
39
|
render() {
|
|
38
|
-
return (h(Host, { key: '
|
|
40
|
+
return (h(Host, { key: '8a6454e0a16e0a26762627f7a42527ab243c1c7a' }, h(CardFormSkeleton, { key: 'ed7386f746518e1ebb62d1bf9bc2e98778d9804e', isReady: this.isReady }), h("div", { key: 'f3092bcce1626f04a079ebcf64f0cdf06a7029a8', class: "container-fluid p-0", style: {
|
|
39
41
|
opacity: this.isReady ? '1' : '0',
|
|
40
42
|
height: this.isReady ? 'auto' : '0',
|
|
41
|
-
} }, h("div", { key: '
|
|
43
|
+
} }, h("div", { key: '3e211e500bef824aff5b6bf6cdedc99435cacfd4', class: "mb-3" }, h("iframe-input", { key: '6ad14a317fd6cad6d6535ba661684e31c325c5ab', inputId: "cardNumber", ref: (el) => (this.cardNumberIframeElement = el), label: "Card Number", iframeOrigin: `${this.iframeOrigin}/v2/cardNumber?tabId=${this.tabId}` })), h("div", { key: '931e9f1b047ff57c2b37bb2947e29f6708f239d9', class: "d-flex align-items-start" }, h("div", { key: '5ca19fbf9047bd6595557890b0bdbbf0d2e65de9', class: "flex-fill me-3" }, h("iframe-input", { key: 'c99f426b77308b15fcb174e8adbe8c120abc58b5', inputId: "expirationMonth", ref: (el) => (this.expirationMonthIframeElement = el), label: "Exp. Month", iframeOrigin: `${this.iframeOrigin}/v2/expirationMonth?tabId=${this.tabId}` })), h("div", { key: '677b8fb8f33a021afda90a8b4e13b5f44b5fe694', class: "flex-fill me-3" }, h("iframe-input", { key: '9bcf91464c5f2ca77b339f2fe299db6027aa9f8b', inputId: "expirationYear", ref: (el) => (this.expirationYearIframeElement = el), label: "Exp. Year", iframeOrigin: `${this.iframeOrigin}/v2/expirationYear?tabId=${this.tabId}` })), h("div", { key: '9b5c52d9cc5b30eedf522801c3f8f6c0530757ce', class: "flex-fill" }, h("iframe-input", { key: '3e73df1c7119193a239fcd2f5212967e109cff83', inputId: "CVV", ref: (el) => (this.cvvIframeElement = el), label: "CVV", iframeOrigin: `${this.iframeOrigin}/v2/CVV?tabId=${this.tabId}` }))))));
|
|
42
44
|
}
|
|
43
45
|
static get is() { return "card-form"; }
|
|
44
46
|
static get states() {
|
|
45
47
|
return {
|
|
46
48
|
"isReady": {},
|
|
47
|
-
"iframeOrigin": {}
|
|
49
|
+
"iframeOrigin": {},
|
|
50
|
+
"tabId": {}
|
|
48
51
|
};
|
|
49
52
|
}
|
|
50
53
|
static get methods() {
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
import { h } from "@stencil/core";
|
|
2
2
|
import JustifiAnalytics from "../../api/Analytics";
|
|
3
|
+
import { PaymentMethodTypes } from "../../api";
|
|
3
4
|
import { checkPkgVersion } from "../../utils/check-pkg-version";
|
|
4
|
-
import { ComponentErrorCodes, ComponentErrorSeverity } from "../../api/ComponentError";
|
|
5
5
|
import { checkoutStore } from "../../store/checkout.store";
|
|
6
6
|
import { checkoutSummary } from "../../styles/parts";
|
|
7
7
|
import { StyledHost } from "../../ui-components";
|
|
8
|
+
import { PAYMENT_METHODS } from "../modular-checkout/ModularCheckout";
|
|
8
9
|
export class Checkout {
|
|
9
10
|
constructor() {
|
|
11
|
+
this.availablePaymentMethods = [];
|
|
10
12
|
this.errorMessage = '';
|
|
11
13
|
this.insuranceToggled = false;
|
|
12
14
|
this.isSubmitting = false; // This is used to prevent multiple submissions and is different from loading state
|
|
@@ -36,23 +38,11 @@ export class Checkout {
|
|
|
36
38
|
checkoutComplete(_event) {
|
|
37
39
|
this.isSubmitting = false;
|
|
38
40
|
}
|
|
39
|
-
checkoutError(
|
|
41
|
+
checkoutError(_event) {
|
|
40
42
|
this.isSubmitting = false;
|
|
41
|
-
console.error('checkout error', event.detail);
|
|
42
43
|
}
|
|
43
|
-
|
|
44
|
-
this.
|
|
45
|
-
if (event.detail.response.error) {
|
|
46
|
-
this.isSubmitting = false;
|
|
47
|
-
this.errorEvent.emit({
|
|
48
|
-
errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
|
|
49
|
-
message: event.detail.response.error.message,
|
|
50
|
-
severity: ComponentErrorSeverity.ERROR
|
|
51
|
-
});
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
// Now submit the checkout with the tokenized payment method
|
|
55
|
-
await this.submitCheckoutWithToken();
|
|
44
|
+
checkoutChanged(event) {
|
|
45
|
+
this.availablePaymentMethods = event.detail.availablePaymentMethodTypes;
|
|
56
46
|
}
|
|
57
47
|
async fillBillingForm(fields) {
|
|
58
48
|
var _a;
|
|
@@ -60,12 +50,9 @@ export class Checkout {
|
|
|
60
50
|
(_a = this.tokenizePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.fillBillingForm(fields);
|
|
61
51
|
}
|
|
62
52
|
async validate() {
|
|
63
|
-
var _a
|
|
64
|
-
const
|
|
65
|
-
|
|
66
|
-
return {
|
|
67
|
-
isValid: ((_c = tokenizeValidation === null || tokenizeValidation === void 0 ? void 0 : tokenizeValidation.isValid) !== null && _c !== void 0 ? _c : true) && (modularValidation !== null && modularValidation !== void 0 ? modularValidation : true)
|
|
68
|
-
};
|
|
53
|
+
var _a;
|
|
54
|
+
const modularValidation = await ((_a = this.modularCheckoutRef) === null || _a === void 0 ? void 0 : _a.validate());
|
|
55
|
+
return { isValid: modularValidation };
|
|
69
56
|
}
|
|
70
57
|
updateStore() {
|
|
71
58
|
checkoutStore.checkoutId = this.checkoutId;
|
|
@@ -78,24 +65,15 @@ export class Checkout {
|
|
|
78
65
|
async submit(_event) {
|
|
79
66
|
var _a;
|
|
80
67
|
this.isSubmitting = true;
|
|
81
|
-
|
|
82
|
-
(_a = this.tokenizePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.tokenizePaymentMethod();
|
|
83
|
-
}
|
|
84
|
-
async submitCheckoutWithToken() {
|
|
85
|
-
if (!this.tokenizedPaymentMethod || this.tokenizedPaymentMethod.error) {
|
|
86
|
-
this.isSubmitting = false;
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
// Set the payment token in the store for the modular checkout to use
|
|
90
|
-
checkoutStore.paymentToken = this.tokenizedPaymentMethod.token;
|
|
91
|
-
// Submit the checkout
|
|
92
|
-
this.modularCheckoutRef.submitCheckout(checkoutStore.billingFormFields);
|
|
68
|
+
(_a = this.modularCheckoutRef) === null || _a === void 0 ? void 0 : _a.submitCheckout(checkoutStore.billingFormFields);
|
|
93
69
|
}
|
|
94
70
|
get showPaymentTypeHeader() {
|
|
95
71
|
return !this.disableCreditCard && !this.disableBankAccount;
|
|
96
72
|
}
|
|
97
73
|
render() {
|
|
98
|
-
return (h(StyledHost, { key: '
|
|
74
|
+
return (h(StyledHost, { key: '61cab7c3b5ca01ea70f35d23df100c2e7bd0c03a' }, h("justifi-modular-checkout", { key: '67ed6c7b2a6bbbec0e24b47b24c2eb73b82abc43', ref: (el) => {
|
|
75
|
+
this.modularCheckoutRef = el;
|
|
76
|
+
}, authToken: this.authToken, checkoutId: this.checkoutId }, h("div", { key: 'b02aaa188db4d619ab3f14a336fe33f4113f2799', class: "row gy-3 jfi-checkout-core" }, h("div", { key: '2c8c019f86bc181d7d05848993ff3782f1fe3ed2', class: "col-12", part: checkoutSummary }, h("justifi-header", { key: '00eb81f75652c80108ad24620b72a977a09192d9', text: "Summary", level: "h2", class: "fs-5 fw-bold pb-3" }), h("section", { key: '346d90b8cca657a1af0eea96244ef105d1274abe' }, h("justifi-checkout-summary", { key: '68784e0b3ef83b6a87d8084fe19dbce7d3348169' }))), h("div", { key: 'bb04ad56ed5074cc272c47e013c7647cc6cf5c2d', class: "col-12 mt-4" }, h("slot", { key: 'a0955737dc7af83b01608abe7818af666ac08d87', name: "insurance" })), h("div", { key: '7025fb6b7ad229879f2198f12a79e07871691b6a', class: "col-12 mt-4" }, h("justifi-header", { key: 'a7823342698429e7845cb341bba2de41f461f6c2', text: "Payment", level: "h2", class: "fs-5 fw-bold pb-3" }), this.showPaymentTypeHeader && (h("justifi-header", { key: 'b579b51c7f6adec31c7e1d39981634328a22b0c2', text: "Select payment type", level: "h3", class: "fs-6 fw-bold lh-lg" })), h("div", { key: '496812c7404b914acc03052018b06b5ebedfd230', class: "d-flex flex-column" }, h("section", { key: '227d6e265d947a5035d8e072b6ea9a87e04faa97' }, h("div", { key: 'b06b49af43c4fce8251c7b227bcc2f2dce5b531a' }, h("justifi-saved-payment-methods", { key: 'd5629c6248d780c5ce8b69c88b4bf866baab2c53' }), this.availablePaymentMethods.includes(PAYMENT_METHODS.SEZZLE) && (h("justifi-radio-list-item", { key: 'dbaf7d54d8c26315faea5537eb821a4a9314d2c4', name: "paymentMethodType", value: PAYMENT_METHODS.SEZZLE, checked: checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.sezzle, label: h("justifi-sezzle-payment-method", { ref: (el) => (this.sezzlePaymentMethodRef = el) }), "onRadio-click": () => { var _a; (_a = this.sezzlePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.handleSelectionClick(); } })), this.availablePaymentMethods.includes(PAYMENT_METHODS.PLAID) && (h("justifi-radio-list-item", { key: 'dad1c44a06f6e60d27d737d36ff68d536244776b', name: "paymentMethodType", value: PAYMENT_METHODS.PLAID, checked: checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid, label: h("justifi-plaid-payment-method", { ref: (el) => (this.plaidPaymentMethodRef = el) }), "onRadio-click": () => { var _a; (_a = this.plaidPaymentMethodRef) === null || _a === void 0 ? void 0 : _a.handleSelectionClick(); } })), h("justifi-tokenize-payment-method", { key: '2bf37f35ae9cb51a6622d4e3f4244359fd40606d', ref: (el) => (this.tokenizePaymentMethodRef = el), authToken: this.authToken, accountId: checkoutStore.accountId, disableCreditCard: this.disableCreditCard, disableBankAccount: this.disableBankAccount, hideCardBillingForm: this.hideCardBillingForm, hideBankAccountBillingForm: this.hideBankAccountBillingForm, hideSubmitButton: true, paymentMethodGroupId: checkoutStore.paymentMethodGroupId }))))), h("div", { key: 'a29f2e940b8c2970d09af0fdce278344cd70833a', class: "mt-4" }, h("justifi-button", { key: '6a076cff574520eaf3303cb4792227365eaf25ae', text: "Pay", type: "submit", variant: "primary", clickHandler: (e) => this.submit(e), disabled: this.isSubmitting, isLoading: this.isSubmitting, customStyle: { width: '100%', textAlign: "center" } }))))));
|
|
99
77
|
}
|
|
100
78
|
static get is() { return "justifi-checkout"; }
|
|
101
79
|
static get properties() {
|
|
@@ -262,13 +240,13 @@ export class Checkout {
|
|
|
262
240
|
}
|
|
263
241
|
static get states() {
|
|
264
242
|
return {
|
|
243
|
+
"availablePaymentMethods": {},
|
|
265
244
|
"checkout": {},
|
|
266
245
|
"complete": {},
|
|
267
246
|
"errorMessage": {},
|
|
268
247
|
"insuranceToggled": {},
|
|
269
248
|
"isSubmitting": {},
|
|
270
|
-
"serverError": {}
|
|
271
|
-
"tokenizedPaymentMethod": {}
|
|
249
|
+
"serverError": {}
|
|
272
250
|
};
|
|
273
251
|
}
|
|
274
252
|
static get events() {
|
|
@@ -419,8 +397,8 @@ export class Checkout {
|
|
|
419
397
|
"capture": false,
|
|
420
398
|
"passive": false
|
|
421
399
|
}, {
|
|
422
|
-
"name": "
|
|
423
|
-
"method": "
|
|
400
|
+
"name": "checkout-changed",
|
|
401
|
+
"method": "checkoutChanged",
|
|
424
402
|
"target": undefined,
|
|
425
403
|
"capture": false,
|
|
426
404
|
"passive": false
|
|
@@ -3,6 +3,7 @@ import { StyledHost } from "../../ui-components";
|
|
|
3
3
|
import { checkoutStore } from "../../store/checkout.store";
|
|
4
4
|
export class SaveNewPaymentMethod {
|
|
5
5
|
constructor() {
|
|
6
|
+
this.label = 'Save New Payment Method';
|
|
6
7
|
this.isChecked = false;
|
|
7
8
|
this.handleCheckboxChange = (_name, value) => {
|
|
8
9
|
this.isChecked = value;
|
|
@@ -11,10 +12,34 @@ export class SaveNewPaymentMethod {
|
|
|
11
12
|
};
|
|
12
13
|
}
|
|
13
14
|
render() {
|
|
14
|
-
return (h(StyledHost, { key: '
|
|
15
|
+
return (h(StyledHost, { key: 'c3808f4373067144ded9db353e48fe9cd3df59bc' }, h("form-control-checkbox", { key: '2f104a35497fdc1397c014c4c4ed646f7b389239', label: this.label || 'Save New Payment Method', name: "saveNewPaymentMethod", checked: this.isChecked, inputHandler: this.handleCheckboxChange })));
|
|
15
16
|
}
|
|
16
17
|
static get is() { return "justifi-save-new-payment-method"; }
|
|
17
18
|
static get encapsulation() { return "shadow"; }
|
|
19
|
+
static get properties() {
|
|
20
|
+
return {
|
|
21
|
+
"label": {
|
|
22
|
+
"type": "string",
|
|
23
|
+
"attribute": "label",
|
|
24
|
+
"mutable": false,
|
|
25
|
+
"complexType": {
|
|
26
|
+
"original": "string",
|
|
27
|
+
"resolved": "string",
|
|
28
|
+
"references": {}
|
|
29
|
+
},
|
|
30
|
+
"required": false,
|
|
31
|
+
"optional": true,
|
|
32
|
+
"docs": {
|
|
33
|
+
"tags": [],
|
|
34
|
+
"text": ""
|
|
35
|
+
},
|
|
36
|
+
"getter": false,
|
|
37
|
+
"setter": false,
|
|
38
|
+
"reflect": false,
|
|
39
|
+
"defaultValue": "'Save New Payment Method'"
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
}
|
|
18
43
|
static get states() {
|
|
19
44
|
return {
|
|
20
45
|
"isChecked": {}
|