@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.
Files changed (600) hide show
  1. package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
  2. package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
  3. package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
  4. package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
  5. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +9 -9
  6. package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
  7. package/dist/cjs/business-details-core.cjs.entry.js +4 -4
  8. package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
  9. package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
  10. package/dist/cjs/card-form.cjs.entry.js +9 -6
  11. package/dist/cjs/{check-pkg-version-BfmeLSXP.js → check-pkg-version-DS_8EVX4.js} +9 -3
  12. package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
  13. package/dist/cjs/checkout.store-DJEc-So8.js +91 -0
  14. package/dist/cjs/checkouts-list-core.cjs.entry.js +11 -11
  15. package/dist/cjs/{payments-list-params-state-BNbT1fuJ.js → checkouts-list-params-state-Cewmin_p.js} +1 -1
  16. package/dist/cjs/{checkouts-table-UN5gPpQ_.js → checkouts-table-DjMdEiEW.js} +3 -3
  17. package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
  18. package/dist/cjs/custom-popper_2.cjs.entry.js +3 -3
  19. package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
  20. package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
  21. package/dist/cjs/form-control-checkbox.cjs.entry.js +5 -5
  22. package/dist/cjs/form-control-date.cjs.entry.js +4 -4
  23. package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
  24. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +5 -5
  25. package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
  26. package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
  27. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
  28. package/dist/cjs/form-control-monetary.cjs.entry.js +6 -6
  29. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +4 -4
  30. package/dist/cjs/form-control-number.cjs.entry.js +5 -5
  31. package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
  32. package/dist/cjs/form-control-select_2.cjs.entry.js +6 -6
  33. package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
  34. package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
  35. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +5 -5
  36. package/dist/cjs/{header-1-DD41iNlG.js → header-1-DRA3f4Jh.js} +1 -1
  37. package/dist/cjs/{header-3-D9Wa0IfT.js → header-3-sOdOpfx3.js} +1 -1
  38. package/dist/cjs/hidden-input_2.cjs.entry.js +8 -8
  39. package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
  40. package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
  41. package/dist/cjs/index-D-dD-aC2.js +30 -0
  42. package/dist/cjs/index.cjs.js +8 -0
  43. package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
  44. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
  45. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
  46. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +9 -9
  47. package/dist/cjs/justifi-apple-pay.cjs.entry.js +189 -150
  48. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +24 -22
  49. package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
  50. package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
  51. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
  52. package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1422 -0
  53. package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
  54. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +8 -8
  55. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +14 -14
  56. package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
  57. package/dist/cjs/justifi-details.cjs.entry.js +2 -2
  58. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +2 -2
  59. package/dist/cjs/justifi-dispute-management.cjs.entry.js +10 -10
  60. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +15 -15
  61. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
  62. package/dist/cjs/justifi-order-terminals.cjs.entry.js +13 -13
  63. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
  64. package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
  65. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
  66. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
  67. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +13 -13
  68. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +7 -7
  69. package/dist/cjs/justifi-payments-list.cjs.entry.js +14 -14
  70. package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
  71. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +13 -13
  72. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +7 -7
  73. package/dist/cjs/justifi-payouts-list.cjs.entry.js +15 -15
  74. package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
  75. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +2 -2
  76. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
  77. package/dist/cjs/justifi-skeleton.cjs.entry.js +4 -4
  78. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +9 -9
  79. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +12 -12
  80. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +8 -8
  81. package/dist/cjs/justifi-terminals-list.cjs.entry.js +14 -14
  82. package/dist/cjs/loader.cjs.js +2 -2
  83. package/dist/cjs/{package-CuNDvHTB.js → package-XG0rW7xm.js} +1 -1
  84. package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
  85. package/dist/cjs/payment-details-core.cjs.entry.js +15 -15
  86. package/dist/cjs/payment-method-option.cjs.entry.js +3 -3
  87. package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
  88. package/dist/cjs/payments-list-core.cjs.entry.js +12 -12
  89. package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
  90. package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
  91. package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
  92. package/dist/cjs/payout-details-core.cjs.entry.js +11 -11
  93. package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
  94. package/dist/cjs/payouts-list-core.cjs.entry.js +12 -12
  95. package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
  96. package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
  97. package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
  98. package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
  99. package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
  100. package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
  101. package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
  102. package/dist/cjs/table-filters-menu.cjs.entry.js +3 -3
  103. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +11 -11
  104. package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
  105. package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
  106. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +2 -2
  107. package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
  108. package/dist/cjs/terminals-list-core.cjs.entry.js +11 -11
  109. package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
  110. package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
  111. package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
  112. package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
  113. package/dist/cjs/webcomponents.cjs.js +3 -3
  114. package/dist/collection/api/Payment.js +5 -2
  115. package/dist/collection/api/index.js +1 -2
  116. package/dist/collection/api/services/apple-pay.service.js +112 -70
  117. package/dist/collection/api/services/plaid.service.js +20 -0
  118. package/dist/collection/assets/plaid-icon.svg +1 -0
  119. package/dist/collection/collection-manifest.json +3 -2
  120. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
  121. package/dist/collection/components/checkout/card-form/card-form.js +6 -3
  122. package/dist/collection/components/checkout/checkout.js +17 -39
  123. package/dist/collection/components/checkout/save-new-payment-method.js +26 -1
  124. package/dist/collection/components/checkout/saved-payment-method.js +1 -1
  125. package/dist/collection/components/checkouts-list/checkouts-list-core.js +1 -1
  126. package/dist/collection/components/checkouts-list/checkouts-list-filters.js +1 -1
  127. package/dist/collection/components/checkouts-list/checkouts-list.js +1 -1
  128. package/dist/collection/components/dispute-management/dispute-management-core.js +1 -1
  129. package/dist/collection/components/dispute-management/dispute-management.js +1 -1
  130. package/dist/collection/components/dispute-management/dispute-notification.js +1 -1
  131. package/dist/collection/components/dispute-management/dispute-response/additional-statement.js +1 -1
  132. package/dist/collection/components/dispute-management/dispute-response/cancellation-policy.js +1 -1
  133. package/dist/collection/components/dispute-management/dispute-response/customer-details.js +1 -1
  134. package/dist/collection/components/dispute-management/dispute-response/dispute-response-core.js +1 -1
  135. package/dist/collection/components/dispute-management/dispute-response/dispute-response.js +1 -1
  136. package/dist/collection/components/dispute-management/dispute-response/duplicate-charge.js +1 -1
  137. package/dist/collection/components/dispute-management/dispute-response/electronic-evidence.js +1 -1
  138. package/dist/collection/components/dispute-management/dispute-response/product-or-service.js +1 -1
  139. package/dist/collection/components/dispute-management/dispute-response/refund-policy.js +1 -1
  140. package/dist/collection/components/dispute-management/dispute-response/shipping-details.js +1 -1
  141. package/dist/collection/components/filters/table-filters-menu.js +1 -1
  142. package/dist/collection/components/gross-payment-chart/gross-payment-chart-core.js +1 -1
  143. package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
  144. package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
  145. package/dist/collection/components/modular-checkout/modular-checkout.js +233 -206
  146. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +65 -110
  147. package/dist/collection/components/modular-checkout/sub-components/bank-account-billing-form-simple.js +1 -1
  148. package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
  149. package/dist/collection/components/modular-checkout/sub-components/card-billing-form-simple.js +1 -1
  150. package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
  151. package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
  152. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +853 -0
  153. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +125 -0
  154. package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
  155. package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
  156. package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
  157. package/dist/collection/components/order-terminals/order-terminals.js +1 -1
  158. package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
  159. package/dist/collection/components/payment-details/payment-details-core.js +8 -8
  160. package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
  161. package/dist/collection/components/payments-list/payments-list-core.js +1 -1
  162. package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
  163. package/dist/collection/components/payments-list/payments-list.js +1 -1
  164. package/dist/collection/components/payout-details/payout-details-core.js +3 -3
  165. package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
  166. package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
  167. package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
  168. package/dist/collection/components/payouts-list/payouts-list.js +1 -1
  169. package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
  170. package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
  171. package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
  172. package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
  173. package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
  174. package/dist/collection/components/terminals-list/terminals-list.js +1 -1
  175. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +82 -34
  176. package/dist/collection/index.js +1 -0
  177. package/dist/collection/store/checkout.store.js +48 -2
  178. package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
  179. package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
  180. package/dist/collection/ui-components/form/form-control-date.js +2 -2
  181. package/dist/collection/ui-components/form/form-control-file-v2.js +1 -1
  182. package/dist/collection/ui-components/form/form-control-file.js +2 -2
  183. package/dist/collection/ui-components/form/form-control-monetary.js +2 -2
  184. package/dist/collection/ui-components/form/form-control-number-masked.js +2 -2
  185. package/dist/collection/ui-components/form/form-control-number.js +2 -2
  186. package/dist/collection/ui-components/form/form-control-radio.js +5 -5
  187. package/dist/collection/ui-components/form/form-control-select.js +2 -2
  188. package/dist/collection/ui-components/form/form-control-text.js +2 -2
  189. package/dist/collection/ui-components/form/form-control-textarea.js +2 -2
  190. package/dist/collection/ui-components/form/hidden-input.js +1 -1
  191. package/dist/collection/ui-components/form/iframe-input.js +3 -3
  192. package/dist/collection/ui-components/shadow-dom-components/justifi-button.js +1 -1
  193. package/dist/collection/ui-components/shadow-dom-components/justifi-header.js +1 -1
  194. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
  195. package/dist/collection/ui-components/shadow-dom-components/justifi-skeleton.js +1 -1
  196. package/dist/collection/utils/check-pkg-version.js +6 -0
  197. package/dist/collection/utils/utils.js +5 -0
  198. package/dist/docs.json +492 -105
  199. package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
  200. package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
  201. package/dist/esm/additional-questions-details_5.entry.js +3 -3
  202. package/dist/esm/{badge-D4ZXPFjL.js → badge-DSYSJcRy.js} +1 -1
  203. package/dist/esm/bank-account-document-form-inputs_4.entry.js +9 -9
  204. package/dist/esm/bank-account-form.entry.js +9 -6
  205. package/dist/esm/business-details-core.entry.js +4 -4
  206. package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
  207. package/dist/esm/{button-C0wLsDP3.js → button-CpllL0At.js} +1 -1
  208. package/dist/esm/card-form.entry.js +9 -6
  209. package/dist/esm/{check-pkg-version-BuYkk-jV.js → check-pkg-version-DhRpS7Qc.js} +9 -3
  210. package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
  211. package/dist/esm/checkout.store-OD-OX5On.js +86 -0
  212. package/dist/esm/checkouts-list-core.entry.js +11 -11
  213. package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
  214. package/dist/esm/{checkouts-table-DjGKtqoc.js → checkouts-table-Ddf2I-Ul.js} +3 -3
  215. package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
  216. package/dist/esm/custom-popper_2.entry.js +3 -3
  217. package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
  218. package/dist/esm/form-alert_5.entry.js +1 -1
  219. package/dist/esm/form-control-checkbox.entry.js +5 -5
  220. package/dist/esm/form-control-date.entry.js +4 -4
  221. package/dist/esm/{form-control-error-text-Bzfs_rxk.js → form-control-error-text-R7U07nTg.js} +1 -1
  222. package/dist/esm/form-control-file-v2_2.entry.js +5 -5
  223. package/dist/esm/{form-control-help-text-ueLctOBN.js → form-control-help-text-CRLH-2f7.js} +1 -1
  224. package/dist/esm/form-control-help-text.entry.js +1 -1
  225. package/dist/esm/form-control-monetary-provisioning.entry.js +3 -3
  226. package/dist/esm/form-control-monetary.entry.js +6 -6
  227. package/dist/esm/form-control-number-masked_2.entry.js +4 -4
  228. package/dist/esm/form-control-number.entry.js +5 -5
  229. package/dist/esm/form-control-radio.entry.js +3 -3
  230. package/dist/esm/form-control-select_2.entry.js +6 -6
  231. package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
  232. package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
  233. package/dist/esm/gross-payment-chart-core.entry.js +5 -5
  234. package/dist/esm/{header-1-BMKEv9y6.js → header-1-3M9If0gM.js} +1 -1
  235. package/dist/esm/{header-3-C3t3m27b.js → header-3-CWa41YWq.js} +1 -1
  236. package/dist/esm/hidden-input_2.entry.js +8 -8
  237. package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
  238. package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
  239. package/dist/esm/index-CbL73B6U.js +30 -0
  240. package/dist/esm/index.js +1 -1
  241. package/dist/esm/{insurance-state-d4hjThzE.js → insurance-state-CTalqbNa.js} +2 -2
  242. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +7 -7
  243. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +8 -8
  244. package/dist/esm/justifi-additional-statement_8.entry.js +9 -9
  245. package/dist/esm/justifi-apple-pay.entry.js +189 -150
  246. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +24 -22
  247. package/dist/esm/justifi-business-details.entry.js +10 -10
  248. package/dist/esm/justifi-business-form.entry.js +13 -13
  249. package/dist/esm/justifi-business-representative-form-inputs.entry.js +1 -1
  250. package/dist/esm/justifi-checkout-summary_7.entry.js +1414 -0
  251. package/dist/esm/justifi-checkout.entry.js +26 -48
  252. package/dist/esm/justifi-checkouts-list-filters.entry.js +8 -8
  253. package/dist/esm/justifi-checkouts-list.entry.js +14 -14
  254. package/dist/esm/justifi-config-provider.entry.js +3 -3
  255. package/dist/esm/justifi-details.entry.js +2 -2
  256. package/dist/esm/justifi-dispute-management-core.entry.js +2 -2
  257. package/dist/esm/justifi-dispute-management.entry.js +10 -10
  258. package/dist/esm/justifi-dispute-notification_3.entry.js +15 -15
  259. package/dist/esm/justifi-gross-payment-chart.entry.js +9 -9
  260. package/dist/esm/justifi-order-terminals.entry.js +13 -13
  261. package/dist/esm/justifi-owner-form_3.entry.js +8 -8
  262. package/dist/esm/justifi-payment-details.entry.js +11 -11
  263. package/dist/esm/justifi-payment-provisioning-core.entry.js +3 -3
  264. package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
  265. package/dist/esm/justifi-payment-transactions-list.entry.js +13 -13
  266. package/dist/esm/justifi-payments-list-filters.entry.js +7 -7
  267. package/dist/esm/justifi-payments-list.entry.js +14 -14
  268. package/dist/esm/justifi-payout-details.entry.js +10 -10
  269. package/dist/esm/justifi-payout-transactions-list.entry.js +13 -13
  270. package/dist/esm/justifi-payouts-list-filters.entry.js +7 -7
  271. package/dist/esm/justifi-payouts-list.entry.js +15 -15
  272. package/dist/esm/justifi-refund-payment.entry.js +13 -13
  273. package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
  274. package/dist/esm/justifi-season-interruption-insurance.entry.js +17 -12
  275. package/dist/esm/justifi-skeleton.entry.js +4 -4
  276. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +9 -9
  277. package/dist/esm/justifi-terminal-orders-list.entry.js +12 -12
  278. package/dist/esm/justifi-terminals-list-filters.entry.js +8 -8
  279. package/dist/esm/justifi-terminals-list.entry.js +14 -14
  280. package/dist/esm/loader.js +3 -3
  281. package/dist/esm/{package-C60pS6qh.js → package-BF0mIfcQ.js} +1 -1
  282. package/dist/esm/pagination-menu.entry.js +1 -1
  283. package/dist/esm/payment-details-core.entry.js +15 -15
  284. package/dist/esm/payment-method-option.entry.js +3 -3
  285. package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
  286. package/dist/esm/payments-list-core.entry.js +12 -12
  287. package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
  288. package/dist/esm/{payments-status-1yRdTNeS.js → payments-status-5orNU2Rd.js} +2 -2
  289. package/dist/esm/{payments-table-8RADYkma.js → payments-table-gkJV5GNK.js} +3 -3
  290. package/dist/esm/payout-details-core.entry.js +11 -11
  291. package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
  292. package/dist/esm/payouts-list-core.entry.js +12 -12
  293. package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
  294. package/dist/esm/{payouts-status-BqsQVtBp.js → payouts-status-CZPwa2AE.js} +2 -2
  295. package/dist/esm/{payouts-table-DPw7yIx8.js → payouts-table-0PtktGRd.js} +3 -3
  296. package/dist/esm/{skeleton-BmTjpTYa.js → skeleton-qMb0_Cjy.js} +1 -1
  297. package/dist/esm/{spinner-YGDOI-CS.js → spinner-DUzyWLhj.js} +1 -1
  298. package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
  299. package/dist/esm/{table-ybHxxc9f.js → table-Br3n9Xu-.js} +2 -2
  300. package/dist/esm/table-filters-menu.entry.js +3 -3
  301. package/dist/esm/terminal-orders-list-core.entry.js +11 -11
  302. package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
  303. package/dist/esm/{terminal-orders-table-D-xP5WuM.js → terminal-orders-table-DTBSIMlJ.js} +5 -5
  304. package/dist/esm/terminal-quantity-selector.entry.js +2 -2
  305. package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
  306. package/dist/esm/terminals-list-core.entry.js +11 -11
  307. package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
  308. package/dist/esm/{terminals-table-DVAPCgEr.js → terminals-table-TGUKTi7I.js} +3 -3
  309. package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
  310. package/dist/esm/{utils-DG5aMFmf.js → utils-Dg6gMUTv.js} +1 -1
  311. package/dist/esm/webcomponents.js +4 -4
  312. package/dist/module/Analytics.js +6 -0
  313. package/dist/module/ModularCheckout.js +30 -0
  314. package/dist/module/Refund.js +5 -2
  315. package/dist/module/additional-statement.js +1 -1
  316. package/dist/module/bank-account-billing-form-simple.js +1 -1
  317. package/dist/module/bank-account-form.js +5 -2
  318. package/dist/module/bank-account.js +2 -2
  319. package/dist/module/cancellation-policy.js +1 -1
  320. package/dist/module/card-billing-form-simple.js +1 -1
  321. package/dist/module/card-form.js +5 -2
  322. package/dist/module/card-form2.js +2 -2
  323. package/dist/module/checkout.store.js +49 -2
  324. package/dist/module/checkouts-list-core2.js +1 -1
  325. package/dist/module/custom-popper2.js +2 -2
  326. package/dist/module/customer-details.js +1 -1
  327. package/dist/module/dispute-management-core.js +1 -1
  328. package/dist/module/dispute-notification.js +1 -1
  329. package/dist/module/dispute-response-core.js +1 -1
  330. package/dist/module/dispute-response.js +1 -1
  331. package/dist/module/duplicate-charge.js +1 -1
  332. package/dist/module/electronic-evidence.js +1 -1
  333. package/dist/module/form-control-checkbox2.js +2 -2
  334. package/dist/module/form-control-date2.js +2 -2
  335. package/dist/module/form-control-file-v22.js +1 -1
  336. package/dist/module/form-control-file2.js +2 -2
  337. package/dist/module/form-control-monetary2.js +2 -2
  338. package/dist/module/form-control-number-masked2.js +2 -2
  339. package/dist/module/form-control-number.js +2 -2
  340. package/dist/module/form-control-radio2.js +3 -3
  341. package/dist/module/form-control-select2.js +2 -2
  342. package/dist/module/form-control-text2.js +2 -2
  343. package/dist/module/form-control-textarea2.js +2 -2
  344. package/dist/module/gross-payment-chart-core2.js +2 -2
  345. package/dist/module/hidden-input2.js +1 -1
  346. package/dist/module/iframe-input2.js +3 -3
  347. package/dist/module/index.js +1 -0
  348. package/dist/module/justifi-apple-pay.js +175 -153
  349. package/dist/module/justifi-button2.js +1 -1
  350. package/dist/module/justifi-checkout.js +63 -75
  351. package/dist/module/justifi-checkouts-list-filters.js +1 -1
  352. package/dist/module/justifi-checkouts-list.js +1 -1
  353. package/dist/module/justifi-dispute-management.js +1 -1
  354. package/dist/module/justifi-header2.js +1 -1
  355. package/dist/module/justifi-order-terminals.js +2 -2
  356. package/dist/module/justifi-payment-transactions-list.js +1 -1
  357. package/dist/module/justifi-payments-list-filters.js +2 -2
  358. package/dist/module/justifi-payments-list.js +1 -1
  359. package/dist/module/justifi-payout-transactions-list.js +1 -1
  360. package/dist/module/justifi-payouts-list-filters.js +2 -2
  361. package/dist/module/justifi-payouts-list.js +1 -1
  362. package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
  363. package/dist/module/justifi-plaid-payment-method.js +6 -0
  364. package/dist/module/justifi-radio-list-item2.js +2 -2
  365. package/dist/module/justifi-saved-payment-method.js +1 -1
  366. package/dist/module/justifi-season-interruption-insurance.js +5 -1
  367. package/dist/module/justifi-skeleton.js +1 -1
  368. package/dist/module/justifi-terminal-orders-list-filters.js +2 -2
  369. package/dist/module/justifi-terminal-orders-list.js +1 -1
  370. package/dist/module/justifi-terminals-list-filters.js +1 -1
  371. package/dist/module/justifi-terminals-list.js +1 -1
  372. package/dist/module/modular-checkout.js +184 -162
  373. package/dist/module/package.js +1 -1
  374. package/dist/module/payment-details-core2.js +8 -8
  375. package/dist/module/payment-method-option.js +1 -1
  376. package/dist/module/payments-list-core2.js +1 -1
  377. package/dist/module/payout-details-core2.js +3 -3
  378. package/dist/module/payouts-list-core2.js +1 -1
  379. package/dist/module/plaid-payment-method.js +635 -0
  380. package/dist/module/plaid.service.js +26 -0
  381. package/dist/module/product-or-service.js +1 -1
  382. package/dist/module/refund-policy.js +1 -1
  383. package/dist/module/save-new-payment-method.js +3 -1
  384. package/dist/module/saved-payment-methods.js +7 -5
  385. package/dist/module/sezzle-payment-method.js +14 -22
  386. package/dist/module/shipping-details.js +1 -1
  387. package/dist/module/summary.js +1 -1
  388. package/dist/module/table-filters-menu2.js +1 -1
  389. package/dist/module/terminal-orders-list-core2.js +1 -1
  390. package/dist/module/terminal-quantity-selector2.js +1 -1
  391. package/dist/module/terminals-list-core2.js +2 -2
  392. package/dist/module/tokenize-payment-method.js +45 -34
  393. package/dist/module/utils2.js +6 -1
  394. package/dist/types/api/ApplePay.d.ts +2 -2
  395. package/dist/types/api/Checkout.d.ts +9 -14
  396. package/dist/types/api/Payment.d.ts +4 -3
  397. package/dist/types/api/index.d.ts +2 -2
  398. package/dist/types/api/services/apple-pay.service.d.ts +5 -15
  399. package/dist/types/api/services/plaid.service.d.ts +12 -0
  400. package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
  401. package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
  402. package/dist/types/components/checkout/checkout.d.ts +6 -7
  403. package/dist/types/components/checkout/save-new-payment-method.d.ts +1 -0
  404. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
  405. package/dist/types/components/modular-checkout/modular-checkout.d.ts +8 -8
  406. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +2 -4
  407. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +79 -0
  408. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
  409. package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
  410. package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
  411. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +8 -6
  412. package/dist/types/components.d.ts +70 -27
  413. package/dist/types/index.d.ts +3 -0
  414. package/dist/types/store/checkout.store.d.ts +16 -3
  415. package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
  416. package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
  417. package/dist/types/utils/utils.d.ts +1 -0
  418. package/dist/webcomponents/index.esm.js +1 -0
  419. package/dist/webcomponents/p-054193e4.entry.js +1 -0
  420. package/dist/webcomponents/{p-BhdBpAn9.js → p-0Om7jLBs.js} +1 -1
  421. package/dist/webcomponents/p-0e80830f.entry.js +1 -0
  422. package/dist/webcomponents/{p-0aa78c58.entry.js → p-12175e07.entry.js} +1 -1
  423. package/dist/webcomponents/{p-fbaf62a5.entry.js → p-13c21c47.entry.js} +1 -1
  424. package/dist/webcomponents/p-20733148.entry.js +1 -0
  425. package/dist/webcomponents/{p-4a79c737.entry.js → p-225ed545.entry.js} +1 -1
  426. package/dist/webcomponents/p-2550e845.entry.js +1 -0
  427. package/dist/webcomponents/p-2ae3613e.entry.js +1 -0
  428. package/dist/webcomponents/{p-bfc38bc2.entry.js → p-319b4126.entry.js} +1 -1
  429. package/dist/webcomponents/{p-08a5cc2f.entry.js → p-431ba789.entry.js} +1 -1
  430. package/dist/webcomponents/{p-4c994761.entry.js → p-44450a94.entry.js} +1 -1
  431. package/dist/webcomponents/p-45e8185c.entry.js +1 -0
  432. package/dist/webcomponents/{p-dc245644.entry.js → p-46b6142b.entry.js} +4 -4
  433. package/dist/webcomponents/p-4e1653c2.entry.js +1 -0
  434. package/dist/webcomponents/p-53739e78.entry.js +1 -0
  435. package/dist/webcomponents/p-559be51b.entry.js +1 -0
  436. package/dist/webcomponents/p-58c766c8.entry.js +1 -0
  437. package/dist/webcomponents/{p-5ad70aae.entry.js → p-613421d4.entry.js} +1 -1
  438. package/dist/webcomponents/p-62a4a2c2.entry.js +1 -0
  439. package/dist/webcomponents/p-654d85ca.entry.js +1 -0
  440. package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
  441. package/dist/webcomponents/{p-ea1b161a.entry.js → p-664501b7.entry.js} +1 -1
  442. package/dist/webcomponents/p-6c7f08c8.entry.js +1 -0
  443. package/dist/webcomponents/p-6cf48f04.entry.js +1 -0
  444. package/dist/webcomponents/{p-03c7cee8.entry.js → p-70f51444.entry.js} +1 -1
  445. package/dist/webcomponents/p-778e9fe9.entry.js +1 -0
  446. package/dist/webcomponents/p-7922acee.entry.js +1 -0
  447. package/dist/webcomponents/p-7c463a59.entry.js +1 -0
  448. package/dist/webcomponents/{p-c6860f60.entry.js → p-7cf87637.entry.js} +1 -1
  449. package/dist/webcomponents/p-7fcbccc7.entry.js +1 -0
  450. package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
  451. package/dist/webcomponents/{p-b04cc606.entry.js → p-80331983.entry.js} +1 -1
  452. package/dist/webcomponents/{p-76a95d07.entry.js → p-8687e5d6.entry.js} +1 -1
  453. package/dist/webcomponents/p-87acb5ec.entry.js +1 -0
  454. package/dist/webcomponents/{p-7288473f.entry.js → p-8c95827f.entry.js} +1 -1
  455. package/dist/webcomponents/{p-55b7bdba.entry.js → p-8e0228df.entry.js} +1 -1
  456. package/dist/webcomponents/{p-a406bf1a.entry.js → p-8ff839a4.entry.js} +1 -1
  457. package/dist/webcomponents/p-927ecf5d.entry.js +1 -0
  458. package/dist/webcomponents/p-93ed5490.entry.js +1 -0
  459. package/dist/webcomponents/p-95a3e104.entry.js +1 -0
  460. package/dist/webcomponents/{p-a9d2dd5e.entry.js → p-95cbb655.entry.js} +1 -1
  461. package/dist/webcomponents/{p-2169c3d1.entry.js → p-95e33bcc.entry.js} +1 -1
  462. package/dist/webcomponents/{p-4cf9168d.entry.js → p-988ae9e9.entry.js} +1 -1
  463. package/dist/webcomponents/{p-e8a198fa.entry.js → p-9be67b19.entry.js} +1 -1
  464. package/dist/webcomponents/p-9c1d5a55.entry.js +1 -0
  465. package/dist/webcomponents/p-9c621697.entry.js +1 -0
  466. package/dist/webcomponents/p-9ed62efb.entry.js +1 -0
  467. package/dist/webcomponents/p-B71k50jz.js +1 -0
  468. package/dist/webcomponents/p-BF0mIfcQ.js +1 -0
  469. package/dist/webcomponents/p-BF4U0yVj.js +1 -0
  470. package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
  471. package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
  472. package/dist/webcomponents/p-BSt6p1oq.js +1 -0
  473. package/dist/webcomponents/p-BY1mRAvj.js +1 -0
  474. package/dist/webcomponents/{p-nWGo6sHu.js → p-Bb-6bNcq.js} +1 -1
  475. package/dist/webcomponents/p-BbZwa5UI.js +1 -0
  476. package/dist/webcomponents/p-BdKWuCys.js +1 -0
  477. package/dist/webcomponents/{p-BZzESzqz.js → p-BfM6X7lF.js} +1 -1
  478. package/dist/webcomponents/p-BjVfIXWC.js +1 -0
  479. package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
  480. package/dist/webcomponents/{p-wyEq9Pa1.js → p-BsGE9UDv.js} +1 -1
  481. package/dist/webcomponents/{p-CP_tg-uH.js → p-C5id7s_l.js} +1 -1
  482. package/dist/webcomponents/{p-DBsw4qpn.js → p-CAJnQLZF.js} +1 -1
  483. package/dist/webcomponents/{p-HAk7yBNq.js → p-CB0mCq1M.js} +1 -1
  484. package/dist/webcomponents/p-CItulios.js +1 -0
  485. package/dist/webcomponents/p-CaAVuW6B.js +1 -0
  486. package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
  487. package/dist/webcomponents/p-CbL73B6U.js +1 -0
  488. package/dist/webcomponents/p-CpaS1Lex.js +1 -0
  489. package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
  490. package/dist/webcomponents/p-DDUmOl3v.js +1 -0
  491. package/dist/webcomponents/p-DIDloHpm.js +1 -0
  492. package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
  493. package/dist/webcomponents/{p-DuXN7Akd.js → p-DNo0OPOP.js} +1 -1
  494. package/dist/webcomponents/{p-BUadwxkh.js → p-DRXvcLy9.js} +1 -1
  495. package/dist/webcomponents/p-Da3idOSV.js +1 -0
  496. package/dist/webcomponents/p-Dgflaz6J.js +1 -0
  497. package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
  498. package/dist/webcomponents/p-DsZZxRXY.js +1 -0
  499. package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
  500. package/dist/webcomponents/p-ED_TzwCp.js +1 -0
  501. package/dist/webcomponents/p-JyHlIFWl.js +1 -0
  502. package/dist/webcomponents/{p-D9Sv4eV5.js → p-VSSGd2zP.js} +1 -1
  503. package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
  504. package/dist/webcomponents/{p-c62e23c1.entry.js → p-a5114207.entry.js} +1 -1
  505. package/dist/webcomponents/p-a54281e8.entry.js +1 -0
  506. package/dist/webcomponents/{p-ab308ee3.entry.js → p-a7ac285c.entry.js} +1 -1
  507. package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
  508. package/dist/webcomponents/{p-1b892b3a.entry.js → p-bf2df971.entry.js} +1 -1
  509. package/dist/webcomponents/p-cff8ae71.entry.js +1 -0
  510. package/dist/webcomponents/p-d031ad31.entry.js +1 -0
  511. package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
  512. package/dist/webcomponents/p-d5d271d3.entry.js +1 -0
  513. package/dist/webcomponents/p-d8f9f287.entry.js +1 -0
  514. package/dist/webcomponents/{p-92efb3f2.entry.js → p-d9d371e1.entry.js} +1 -1
  515. package/dist/webcomponents/p-dba55699.entry.js +1 -0
  516. package/dist/webcomponents/p-e5282f6c.entry.js +1 -0
  517. package/dist/webcomponents/p-e7b66120.entry.js +1 -0
  518. package/dist/webcomponents/p-e9a5c837.entry.js +1 -0
  519. package/dist/webcomponents/p-eP3fmhta.js +1 -0
  520. package/dist/webcomponents/{p-5afbfafb.entry.js → p-eb2d9e5b.entry.js} +1 -1
  521. package/dist/webcomponents/p-ed53b213.entry.js +1 -0
  522. package/dist/webcomponents/{p-afc83e27.entry.js → p-f1cba43c.entry.js} +1 -1
  523. package/dist/webcomponents/p-f499a8de.entry.js +1 -0
  524. package/dist/webcomponents/p-f680e617.entry.js +1 -0
  525. package/dist/webcomponents/p-fa31c907.entry.js +1 -0
  526. package/dist/webcomponents/p-ff685149.entry.js +1 -0
  527. package/dist/webcomponents/p-sw5RO19U.js +1 -0
  528. package/dist/webcomponents/p-z-5r0gWn.js +1 -0
  529. package/dist/webcomponents/webcomponents.esm.js +1 -1
  530. package/package.json +2 -2
  531. package/dist/cjs/checkout.store-Cn3Jj5gi.js +0 -40
  532. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -785
  533. package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
  534. package/dist/esm/checkout.store-OAv_iY1u.js +0 -37
  535. package/dist/esm/justifi-checkout-summary_6.entry.js +0 -778
  536. package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
  537. package/dist/webcomponents/p-0aee6da6.entry.js +0 -1
  538. package/dist/webcomponents/p-0e64cd09.entry.js +0 -1
  539. package/dist/webcomponents/p-1202181b.entry.js +0 -1
  540. package/dist/webcomponents/p-1246b999.entry.js +0 -1
  541. package/dist/webcomponents/p-12c312a0.entry.js +0 -1
  542. package/dist/webcomponents/p-1a83d9f2.entry.js +0 -1
  543. package/dist/webcomponents/p-1c0c1d7b.entry.js +0 -1
  544. package/dist/webcomponents/p-1e206c92.entry.js +0 -1
  545. package/dist/webcomponents/p-281e36be.entry.js +0 -1
  546. package/dist/webcomponents/p-2988e82c.entry.js +0 -1
  547. package/dist/webcomponents/p-2a0a907d.entry.js +0 -1
  548. package/dist/webcomponents/p-32cc081a.entry.js +0 -1
  549. package/dist/webcomponents/p-387bcdee.entry.js +0 -1
  550. package/dist/webcomponents/p-41416b5f.entry.js +0 -1
  551. package/dist/webcomponents/p-42994618.entry.js +0 -1
  552. package/dist/webcomponents/p-5510b57c.entry.js +0 -1
  553. package/dist/webcomponents/p-59e8f027.entry.js +0 -1
  554. package/dist/webcomponents/p-5a5f07be.entry.js +0 -1
  555. package/dist/webcomponents/p-5acd6add.entry.js +0 -1
  556. package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
  557. package/dist/webcomponents/p-6974a44c.entry.js +0 -1
  558. package/dist/webcomponents/p-6f2b41f5.entry.js +0 -1
  559. package/dist/webcomponents/p-6f9755cc.entry.js +0 -1
  560. package/dist/webcomponents/p-7WIgS5RM.js +0 -1
  561. package/dist/webcomponents/p-7b9fa1fb.entry.js +0 -1
  562. package/dist/webcomponents/p-98939b74.entry.js +0 -1
  563. package/dist/webcomponents/p-BVD7g3cE.js +0 -1
  564. package/dist/webcomponents/p-BXKEChoo.js +0 -1
  565. package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
  566. package/dist/webcomponents/p-BmFoKOM3.js +0 -1
  567. package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
  568. package/dist/webcomponents/p-Bt388eye.js +0 -1
  569. package/dist/webcomponents/p-BtOB_CaO.js +0 -1
  570. package/dist/webcomponents/p-BySyDTv5.js +0 -1
  571. package/dist/webcomponents/p-C0AHrswP.js +0 -1
  572. package/dist/webcomponents/p-C60pS6qh.js +0 -1
  573. package/dist/webcomponents/p-CLwzqWk2.js +0 -1
  574. package/dist/webcomponents/p-CVQyw7ao.js +0 -1
  575. package/dist/webcomponents/p-D48iERjQ.js +0 -1
  576. package/dist/webcomponents/p-D7eeJWA-.js +0 -1
  577. package/dist/webcomponents/p-DD74a16D.js +0 -1
  578. package/dist/webcomponents/p-DKRXPZKS.js +0 -1
  579. package/dist/webcomponents/p-DOd8HaWV.js +0 -1
  580. package/dist/webcomponents/p-DaDsBt65.js +0 -1
  581. package/dist/webcomponents/p-DcE8SQPv.js +0 -1
  582. package/dist/webcomponents/p-Drz6LnIw.js +0 -1
  583. package/dist/webcomponents/p-WEguiGt1.js +0 -1
  584. package/dist/webcomponents/p-a1a8f6bd.entry.js +0 -1
  585. package/dist/webcomponents/p-a70bc148.entry.js +0 -1
  586. package/dist/webcomponents/p-b41d2b8f.entry.js +0 -1
  587. package/dist/webcomponents/p-b8f63e28.entry.js +0 -1
  588. package/dist/webcomponents/p-ba84c3bd.entry.js +0 -1
  589. package/dist/webcomponents/p-c7e5245a.entry.js +0 -1
  590. package/dist/webcomponents/p-cabaf013.entry.js +0 -1
  591. package/dist/webcomponents/p-cbfc8269.entry.js +0 -1
  592. package/dist/webcomponents/p-cf16498f.entry.js +0 -1
  593. package/dist/webcomponents/p-d014a155.entry.js +0 -1
  594. package/dist/webcomponents/p-e6ca1872.entry.js +0 -1
  595. package/dist/webcomponents/p-eff0b0e9.entry.js +0 -1
  596. package/dist/webcomponents/p-f3be7b2b.entry.js +0 -1
  597. package/dist/webcomponents/p-f787bc18.entry.js +0 -1
  598. package/dist/webcomponents/p-fb1904d2.entry.js +0 -1
  599. package/dist/webcomponents/p-fcb6e870.entry.js +0 -1
  600. package/dist/webcomponents/p-pska2q1M.js +0 -1
@@ -0,0 +1,1414 @@
1
+ import { r as registerInstance, h, c as createEvent, H as Host, g as getElement } from './index-Bn7inNWG.js';
2
+ import { z as text, r as radioListItem } from './parts-RvUQ__Pq.js';
3
+ import { f as formatCurrency } from './utils-BscIVFn8.js';
4
+ import { c as checkoutStore, o as onAnyChange, g as getAvailablePaymentMethodTypes, a as onChange } from './checkout.store-OD-OX5On.js';
5
+ import { S as StyledHost } from './styled-host-CTAGIN84.js';
6
+ import './event-types-CZfYo5-1.js';
7
+ import { H as Header1 } from './header-1-3M9If0gM.js';
8
+ import { H as Header2, b as insuranceValuesOn, h as hasInsuranceValueChanged, i as insuranceValues } from './insurance-state-CTalqbNa.js';
9
+ import { H as Header3 } from './header-3-CWa41YWq.js';
10
+ import { J as JustifiAnalytics, c as checkPkgVersion } from './check-pkg-version-DhRpS7Qc.js';
11
+ import './config-state-DZeVYerv.js';
12
+ import './dinero-HXpYMWUU.js';
13
+ import { C as ComponentErrorSeverity, a as ComponentErrorCodes, b as ComponentErrorMessages } from './ComponentError-Cjcsf8ku.js';
14
+ import { P as PaymentMethodTypes, I as ICheckoutStatus } from './Refund-CVh70dXA.js';
15
+ import './Pagination-CLHwhyvu.js';
16
+ import './Business-BCoP0TAV.js';
17
+ import './Dispute-BH0Xfn-F.js';
18
+ import { g as getErrorCode, a as getErrorMessage } from './utils-BeQLScSm.js';
19
+ import { C as CheckoutService } from './checkout.service-Bbgi1I6V.js';
20
+ import { A as Api } from './Api-DAWuvzbl.js';
21
+ import { a as PAYMENT_MODE, b as PAYMENT_METHOD_TYPES, P as PAYMENT_METHODS } from './index-CbL73B6U.js';
22
+ import { C as CardBrandLabels } from './payment-method-option-utils-lUHAQVFl.js';
23
+ import './index-B_KxSZIF.js';
24
+ import './package-BF0mIfcQ.js';
25
+ import './helpers-Mu7LQT-w.js';
26
+ import './state-options-BX8GieXu.js';
27
+
28
+ const Summary = class {
29
+ constructor(hostRef) {
30
+ registerInstance(this, hostRef);
31
+ }
32
+ render() {
33
+ return (h(StyledHost, { key: '3161e6f6a196c79d684574cafbc90bcf741b2150' }, h("section", { key: '594b4485ed4fd9d7c1ee7f4556f071139f92ef0c' }, h("div", { key: '5c2d14677dda6fc7ddcb074d4887b839385dca3a' }, h("div", { key: 'fb850cd7e9c11741349710696dd4e6241c98e805', part: text }, checkoutStore === null || checkoutStore === void 0 ? void 0 : checkoutStore.paymentDescription), h("div", { key: '959014d7fa2a9c97bae0c986313a604930c1e0f3' }, h("span", { key: '14ab0932a083568419b1c36c95f9072c73962b11', part: text }, "Total"), "\u00A0", h("span", { key: '08a9e00332253070ae984b77eb2a9bab88eb3472', part: text }, formatCurrency(+(checkoutStore === null || checkoutStore === void 0 ? void 0 : checkoutStore.totalAmount))))))));
34
+ }
35
+ };
36
+
37
+ const Header = class {
38
+ constructor(hostRef) {
39
+ registerInstance(this, hostRef);
40
+ this.levels = {
41
+ h1: Header1,
42
+ h2: Header2,
43
+ h3: Header3,
44
+ };
45
+ this.level = 'h1';
46
+ }
47
+ render() {
48
+ const HeaderComponent = this.levels[this.level];
49
+ return (h(StyledHost, { key: 'eb3651b698897193d34a6c6456cd57dd0bd0bc43' }, h(HeaderComponent, { key: '39caee687f93d3d4d90e62d9fbcae318eaa8022e', text: this.text, class: this.class })));
50
+ }
51
+ };
52
+
53
+ const makeGetCheckout = ({ authToken, checkoutId, service }) => async ({ onSuccess, onError }) => {
54
+ var _a;
55
+ try {
56
+ const response = await service.fetchCheckout(authToken, checkoutId);
57
+ if (!response.error) {
58
+ const checkout = response.data;
59
+ onSuccess({ checkout });
60
+ }
61
+ else {
62
+ const responseError = getErrorMessage(response.error);
63
+ const code = getErrorCode((_a = response.error) === null || _a === void 0 ? void 0 : _a.code);
64
+ return onError({
65
+ error: responseError,
66
+ code,
67
+ severity: ComponentErrorSeverity.ERROR,
68
+ });
69
+ }
70
+ }
71
+ catch (error) {
72
+ const code = getErrorCode(error === null || error === void 0 ? void 0 : error.code);
73
+ return onError({
74
+ error: error.message || error,
75
+ code,
76
+ severity: ComponentErrorSeverity.ERROR,
77
+ });
78
+ }
79
+ };
80
+ const makeCheckoutComplete = ({ authToken, checkoutId, service }) => async ({ payment, onSuccess, onError }) => {
81
+ var _a;
82
+ try {
83
+ const response = await service.complete(authToken, checkoutId, payment);
84
+ if (!response.error) {
85
+ const checkout = response.data;
86
+ onSuccess({ checkout });
87
+ }
88
+ else {
89
+ const responseError = getErrorMessage(response.error);
90
+ const code = getErrorCode((_a = response.error) === null || _a === void 0 ? void 0 : _a.code);
91
+ return onError({
92
+ error: responseError,
93
+ code,
94
+ severity: ComponentErrorSeverity.ERROR,
95
+ });
96
+ }
97
+ }
98
+ catch (error) {
99
+ const code = getErrorCode(error === null || error === void 0 ? void 0 : error.code);
100
+ return onError({
101
+ error: error.message || error,
102
+ code,
103
+ severity: ComponentErrorSeverity.ERROR,
104
+ });
105
+ }
106
+ };
107
+
108
+ const api = Api();
109
+ class PlaidService {
110
+ async getLinkToken(authToken, accountId, checkoutId, signal) {
111
+ const endpoint = `plaid/${accountId}/link`;
112
+ const body = { checkout_id: checkoutId };
113
+ return api.post({ endpoint, body, authToken, signal });
114
+ }
115
+ async tokenizeBankAccount(authToken, accountId, publicToken, linkTokenId, paymentMethodGroupId, signal) {
116
+ const endpoint = `plaid/${accountId}/tokenize`;
117
+ const body = { public_token: publicToken };
118
+ if (linkTokenId) {
119
+ body.link_token_id = linkTokenId;
120
+ }
121
+ if (paymentMethodGroupId) {
122
+ body.payment_method_group_id = paymentMethodGroupId;
123
+ }
124
+ return api.post({ endpoint, body, authToken, signal });
125
+ }
126
+ }
127
+
128
+ const ModularCheckout = class {
129
+ constructor(hostRef) {
130
+ registerInstance(this, hostRef);
131
+ this.errorEvent = createEvent(this, "error-event");
132
+ this.submitEvent = createEvent(this, "submit-event");
133
+ this.checkoutChangedEvent = createEvent(this, "checkout-changed");
134
+ this.plaidService = new PlaidService();
135
+ this.handleApplePayCompleted = (event) => {
136
+ const { success, token, paymentMethodId, error } = event.detail;
137
+ if (success && token) {
138
+ checkoutStore.paymentToken = paymentMethodId;
139
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.applePay };
140
+ this.submitCheckout();
141
+ }
142
+ else {
143
+ console.error("Apple Pay completed but failed:", error);
144
+ this.errorEvent.emit({
145
+ message: (error === null || error === void 0 ? void 0 : error.message) || "Apple Pay payment failed",
146
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
147
+ severity: ComponentErrorSeverity.ERROR,
148
+ });
149
+ }
150
+ };
151
+ this.handleApplePayError = (event) => {
152
+ const { error } = event.detail;
153
+ console.error("Apple Pay error:", error);
154
+ this.errorEvent.emit({
155
+ message: error || "Apple Pay error occurred",
156
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
157
+ severity: ComponentErrorSeverity.ERROR,
158
+ });
159
+ };
160
+ this.handleApplePayCancelled = () => {
161
+ checkoutStore.paymentToken = undefined;
162
+ checkoutStore.selectedPaymentMethod = undefined;
163
+ };
164
+ }
165
+ connectedCallback() {
166
+ console.log("connectedCallback", checkoutStore.checkoutLoaded);
167
+ this.observer = new MutationObserver(() => {
168
+ this.queryFormRefs();
169
+ this.setupApplePayListeners(); // set up again listeners when DOM changes
170
+ });
171
+ this.observer.observe(this.hostEl, {
172
+ childList: true,
173
+ subtree: true,
174
+ });
175
+ checkoutStore.checkoutId = this.checkoutId;
176
+ const config = {
177
+ authToken: this.authToken,
178
+ checkoutId: this.checkoutId,
179
+ service: new CheckoutService(),
180
+ };
181
+ this.getCheckout = makeGetCheckout(config);
182
+ this.completeCheckout = makeCheckoutComplete(config);
183
+ // Emit checkout-changed whenever any store key changes
184
+ onAnyChange(() => {
185
+ this.emitCheckoutChanged();
186
+ });
187
+ }
188
+ componentWillLoad() {
189
+ this.analytics = new JustifiAnalytics(this);
190
+ checkPkgVersion();
191
+ checkoutStore.authToken = this.authToken;
192
+ this.fetchCheckout();
193
+ // Refresh the checkout data when insurance values actually change (not on initial load)
194
+ insuranceValuesOn("set", (key) => {
195
+ const value = insuranceValues[key];
196
+ if (value !== undefined && hasInsuranceValueChanged(key, value)) {
197
+ this.fetchCheckout();
198
+ }
199
+ });
200
+ }
201
+ componentDidLoad() {
202
+ this.queryFormRefs();
203
+ this.setupApplePayListeners();
204
+ }
205
+ disconnectedCallback() {
206
+ var _a;
207
+ (_a = this.observer) === null || _a === void 0 ? void 0 : _a.disconnect();
208
+ this.removeApplePayListeners();
209
+ }
210
+ fetchCheckout() {
211
+ if (!this.authToken || !this.checkoutId) {
212
+ this.errorEvent.emit({
213
+ message: ComponentErrorMessages.NOT_AUTHENTICATED,
214
+ errorCode: ComponentErrorCodes.NOT_AUTHENTICATED,
215
+ severity: ComponentErrorSeverity.ERROR,
216
+ });
217
+ return;
218
+ }
219
+ if (this.getCheckout) {
220
+ this.getCheckout({
221
+ onSuccess: ({ checkout }) => {
222
+ this.updateStore(checkout);
223
+ if (checkout.status === ICheckoutStatus.completed) {
224
+ this.errorEvent.emit({
225
+ message: ComponentErrorMessages.CHECKOUT_ALREADY_COMPLETED,
226
+ errorCode: ComponentErrorCodes.CHECKOUT_ALREADY_COMPLETED,
227
+ severity: ComponentErrorSeverity.ERROR,
228
+ });
229
+ return;
230
+ }
231
+ else if (checkout.status === ICheckoutStatus.expired) {
232
+ this.errorEvent.emit({
233
+ message: ComponentErrorMessages.CHECKOUT_EXPIRED,
234
+ errorCode: ComponentErrorCodes.CHECKOUT_EXPIRED,
235
+ severity: ComponentErrorSeverity.ERROR,
236
+ });
237
+ return;
238
+ }
239
+ },
240
+ onError: (error) => {
241
+ this.errorEvent.emit({
242
+ message: error.message,
243
+ errorCode: ComponentErrorCodes.FETCH_ERROR,
244
+ severity: ComponentErrorSeverity.ERROR,
245
+ });
246
+ },
247
+ });
248
+ }
249
+ }
250
+ updateStore(checkout) {
251
+ var _a, _b, _c, _d, _e;
252
+ checkoutStore.accountId = checkout.account_id;
253
+ checkoutStore.checkoutLoaded = true;
254
+ checkoutStore.paymentMethods = checkout.payment_methods;
255
+ checkoutStore.paymentMethodGroupId = checkout.payment_method_group_id;
256
+ checkoutStore.paymentDescription = checkout.payment_description;
257
+ checkoutStore.totalAmount = checkout.total_amount;
258
+ checkoutStore.paymentAmount = checkout.payment_amount;
259
+ checkoutStore.bnplEnabled = checkout.payment_settings.bnpl_payments;
260
+ checkoutStore.insuranceEnabled = checkout.payment_settings.insurance_payments;
261
+ checkoutStore.bankAccountVerification = (_a = checkout.payment_settings) === null || _a === void 0 ? void 0 : _a.bank_account_verification;
262
+ checkoutStore.bnplProviderClientId = (_b = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _b === void 0 ? void 0 : _b.provider_client_id;
263
+ checkoutStore.bnplProviderMode = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_mode;
264
+ checkoutStore.bnplProviderApiVersion = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_api_version;
265
+ checkoutStore.bnplProviderCheckoutUrl =
266
+ (_e = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _e === void 0 ? void 0 : _e.provider_checkout_url;
267
+ }
268
+ emitCheckoutChanged() {
269
+ const detail = {
270
+ availablePaymentMethodTypes: getAvailablePaymentMethodTypes(),
271
+ selectedPaymentMethod: checkoutStore.selectedPaymentMethod,
272
+ savedPaymentMethods: checkoutStore.paymentMethods,
273
+ };
274
+ this.checkoutChangedEvent.emit(detail);
275
+ }
276
+ queryFormRefs() {
277
+ this.billingFormRef = this.hostEl.querySelector("justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full");
278
+ this.applePayRef = this.hostEl.querySelector("justifi-apple-pay");
279
+ this.paymentMethodFormRef =
280
+ this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form, justifi-tokenize-payment-method');
281
+ this.insuranceFormRef = this.hostEl.querySelector('justifi-season-interruption-insurance');
282
+ }
283
+ setupApplePayListeners() {
284
+ if (this.applePayRef) {
285
+ this.applePayRef.addEventListener("applePayCompleted", this.handleApplePayCompleted);
286
+ this.applePayRef.addEventListener("applePayError", this.handleApplePayError);
287
+ this.applePayRef.addEventListener("applePayCancelled", this.handleApplePayCancelled);
288
+ }
289
+ }
290
+ removeApplePayListeners() {
291
+ if (this.applePayRef) {
292
+ this.applePayRef.removeEventListener("applePayCompleted", this.handleApplePayCompleted);
293
+ this.applePayRef.removeEventListener("applePayError", this.handleApplePayError);
294
+ this.applePayRef.removeEventListener("applePayCancelled", this.handleApplePayCancelled);
295
+ }
296
+ }
297
+ async tokenizePaymentMethod(tokenizeArgs) {
298
+ var _a, _b, _c;
299
+ const billingInfoValues = (_b = (await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues()))) !== null && _b !== void 0 ? _b : {};
300
+ const combinedBillingInfo = Object.assign(Object.assign({}, tokenizeArgs), billingInfoValues);
301
+ const paymentMethodMetadata = Object.assign({ accountId: checkoutStore.accountId, payment_method_group_id: undefined }, combinedBillingInfo);
302
+ if (checkoutStore.savePaymentMethod) {
303
+ paymentMethodMetadata.payment_method_group_id =
304
+ checkoutStore.paymentMethodGroupId;
305
+ }
306
+ const tokenizeResult = await ((_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
307
+ clientId: this.authToken,
308
+ paymentMethodMetadata,
309
+ account: checkoutStore.accountId,
310
+ }));
311
+ if (tokenizeResult.error) {
312
+ return tokenizeResult;
313
+ }
314
+ checkoutStore.paymentToken = tokenizeResult.id;
315
+ return tokenizeResult.id;
316
+ }
317
+ // set the selected payment method to the checkout store from outside the component
318
+ async setSelectedPaymentMethod(paymentMethod) {
319
+ checkoutStore.selectedPaymentMethod = paymentMethod;
320
+ checkoutStore.paymentToken = paymentMethod.id || undefined;
321
+ }
322
+ // if validation fails, the error will be emitted by the component
323
+ async validate() {
324
+ const promises = [];
325
+ if (checkoutStore.insuranceEnabled && this.insuranceFormRef) {
326
+ promises.push(this.insuranceFormRef.validate());
327
+ }
328
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card && checkoutStore.selectedPaymentMethod.id === undefined;
329
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount && checkoutStore.selectedPaymentMethod.id === undefined;
330
+ // For new card/bank account, validate payment method + billing.
331
+ if (isNewCard ||
332
+ isNewBankAccount) {
333
+ if (this.paymentMethodFormRef)
334
+ promises.push(this.paymentMethodFormRef.validate());
335
+ if (this.billingFormRef)
336
+ promises.push(this.billingFormRef.validate());
337
+ }
338
+ if (promises.length === 0)
339
+ return true;
340
+ try {
341
+ const results = await Promise.all(promises);
342
+ // Normalize different validator return shapes:
343
+ // - boolean -> use it directly
344
+ // - object -> look for isValid; treat missing isValid as falsey only if explicitly false
345
+ const resultsAreValid = results.every(r => typeof r === 'boolean' ? r : (r === null || r === void 0 ? void 0 : r.isValid) !== false);
346
+ if (!resultsAreValid) {
347
+ this.errorEvent.emit({
348
+ message: 'Validation error',
349
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
350
+ severity: ComponentErrorSeverity.ERROR,
351
+ });
352
+ return false;
353
+ }
354
+ return true;
355
+ }
356
+ catch (_a) {
357
+ // If any validator throws/rejects, consider the whole validation failed.
358
+ return false;
359
+ }
360
+ }
361
+ async submitCheckout(submitCheckoutArgs) {
362
+ var _a;
363
+ const isValid = await this.validate();
364
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card &&
365
+ checkoutStore.selectedPaymentMethod.id === undefined;
366
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount &&
367
+ checkoutStore.selectedPaymentMethod.id === undefined;
368
+ const isPlaid = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
369
+ const shouldTokenize = isNewCard || isNewBankAccount;
370
+ if (shouldTokenize) {
371
+ const tokenizeResult = await this.tokenizePaymentMethod(submitCheckoutArgs);
372
+ if (tokenizeResult === null || tokenizeResult === void 0 ? void 0 : tokenizeResult.error) {
373
+ this.errorEvent.emit({
374
+ message: tokenizeResult.error.message,
375
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
376
+ severity: ComponentErrorSeverity.ERROR,
377
+ });
378
+ return;
379
+ }
380
+ }
381
+ // For Plaid, perform exchange at submit time using stored public token and link token id
382
+ if (isPlaid && !checkoutStore.paymentToken) {
383
+ const publicToken = checkoutStore.plaidPublicToken;
384
+ const linkTokenId = checkoutStore.plaidLinkTokenId;
385
+ if (!publicToken) {
386
+ this.errorEvent.emit({
387
+ message: 'Missing Plaid public token. Please connect your bank.',
388
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
389
+ severity: ComponentErrorSeverity.ERROR,
390
+ });
391
+ return;
392
+ }
393
+ try {
394
+ const response = await this.plaidService.tokenizeBankAccount(checkoutStore.authToken, checkoutStore.accountId, publicToken, linkTokenId || undefined, checkoutStore.savePaymentMethod ? checkoutStore.paymentMethodGroupId : undefined);
395
+ if (response === null || response === void 0 ? void 0 : response.error) {
396
+ this.errorEvent.emit({
397
+ message: typeof response.error === 'string' ? response.error : response.error.message || 'Failed to tokenize bank account',
398
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
399
+ severity: ComponentErrorSeverity.ERROR,
400
+ });
401
+ return;
402
+ }
403
+ const paymentMethod = response === null || response === void 0 ? void 0 : response.data;
404
+ const token = ((_a = paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.bank_account) === null || _a === void 0 ? void 0 : _a.token) || (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.token) || (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id);
405
+ checkoutStore.paymentToken = token;
406
+ }
407
+ catch (err) {
408
+ this.errorEvent.emit({
409
+ message: (err === null || err === void 0 ? void 0 : err.message) || 'Plaid exchange error',
410
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
411
+ severity: ComponentErrorSeverity.ERROR,
412
+ });
413
+ return;
414
+ }
415
+ }
416
+ if (!isValid) {
417
+ this.errorEvent.emit({
418
+ message: "Please fill in all required fields.",
419
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
420
+ severity: ComponentErrorSeverity.ERROR,
421
+ });
422
+ return;
423
+ }
424
+ if (!checkoutStore.paymentToken) {
425
+ this.errorEvent.emit({
426
+ message: 'Payment token not found.',
427
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
428
+ severity: ComponentErrorSeverity.ERROR,
429
+ });
430
+ return;
431
+ }
432
+ let payment;
433
+ const mapTypeToPaymentMode = (type) => {
434
+ switch (type) {
435
+ case PaymentMethodTypes.card:
436
+ case PaymentMethodTypes.bankAccount:
437
+ case PaymentMethodTypes.plaid:
438
+ return PAYMENT_MODE.ECOM;
439
+ case PaymentMethodTypes.sezzle:
440
+ return PAYMENT_MODE.BNPL;
441
+ case PaymentMethodTypes.applePay:
442
+ return PAYMENT_MODE.APPLE_PAY;
443
+ default:
444
+ return undefined;
445
+ }
446
+ };
447
+ payment = {
448
+ payment_mode: mapTypeToPaymentMode(checkoutStore.selectedPaymentMethod.type),
449
+ payment_token: checkoutStore.paymentToken,
450
+ };
451
+ this.completeCheckout({
452
+ payment,
453
+ onSuccess: ({ checkout }) => {
454
+ this.submitEvent.emit({
455
+ checkout,
456
+ message: "Checkout completed successfully",
457
+ });
458
+ },
459
+ onError: (error) => {
460
+ this.errorEvent.emit({
461
+ message: error.message,
462
+ errorCode: ComponentErrorCodes.COMPLETE_CHECKOUT_ERROR,
463
+ severity: ComponentErrorSeverity.ERROR,
464
+ });
465
+ },
466
+ });
467
+ }
468
+ render() {
469
+ return h(Host, { key: '2cbac33c57dd2cad327f156a4630b1dba9bf3252' });
470
+ }
471
+ get hostEl() { return getElement(this); }
472
+ };
473
+
474
+ const plaidIconSvg = '';
475
+
476
+ // Plaid-specific error codes
477
+ var PlaidErrorCodes;
478
+ (function (PlaidErrorCodes) {
479
+ PlaidErrorCodes["PLAID_SDK_LOAD_FAILED"] = "plaid-sdk-load-failed";
480
+ PlaidErrorCodes["PLAID_LINK_INIT_FAILED"] = "plaid-link-init-failed";
481
+ PlaidErrorCodes["PLAID_LINK_TOKEN_FAILED"] = "plaid-link-token-failed";
482
+ PlaidErrorCodes["PLAID_AUTHENTICATION_FAILED"] = "plaid-authentication-failed";
483
+ PlaidErrorCodes["PLAID_BANK_NOT_SUPPORTED"] = "plaid-bank-not-supported";
484
+ PlaidErrorCodes["PLAID_TOKEN_EXPIRED"] = "plaid-token-expired";
485
+ PlaidErrorCodes["PLAID_NETWORK_ERROR"] = "plaid-network-error";
486
+ PlaidErrorCodes["PLAID_USER_CANCELLED"] = "plaid-user-cancelled";
487
+ PlaidErrorCodes["PLAID_TIMEOUT"] = "plaid-timeout";
488
+ PlaidErrorCodes["PLAID_INVALID_CREDENTIALS"] = "plaid-invalid-credentials";
489
+ PlaidErrorCodes["PLAID_ACCOUNT_LOCKED"] = "plaid-account-locked";
490
+ PlaidErrorCodes["PLAID_MAINTENANCE"] = "plaid-maintenance";
491
+ PlaidErrorCodes["PLAID_RATE_LIMITED"] = "plaid-rate-limited";
492
+ })(PlaidErrorCodes || (PlaidErrorCodes = {}));
493
+ // Plaid error message mapping
494
+ const PLAID_ERROR_MESSAGES = {
495
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: 'Unable to load Plaid. Please refresh the page and try again.',
496
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: 'Unable to initialize bank connection. Please try again.',
497
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: 'Unable to connect to bank service. Please try again.',
498
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: 'Bank authentication failed. Please try again.',
499
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: 'Your bank is not currently supported. Please try a different payment method.',
500
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: 'Your bank session has expired. Please reconnect your account.',
501
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: 'Network connection issue. Please check your internet connection and try again.',
502
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: 'Bank connection was cancelled. Click to try again.',
503
+ [PlaidErrorCodes.PLAID_TIMEOUT]: 'Bank connection timed out. Please try again.',
504
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: 'Invalid bank credentials. Please check your username and password.',
505
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: 'Your bank account is temporarily locked. Please contact your bank.',
506
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: 'Bank service is temporarily unavailable. Please try again later.',
507
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: 'Too many connection attempts. Please wait a moment and try again.',
508
+ };
509
+ // Plaid error severity mapping
510
+ const PLAID_ERROR_SEVERITY = {
511
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: ComponentErrorSeverity.ERROR,
512
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: ComponentErrorSeverity.ERROR,
513
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: ComponentErrorSeverity.ERROR,
514
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: ComponentErrorSeverity.ERROR,
515
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: ComponentErrorSeverity.WARNING,
516
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: ComponentErrorSeverity.WARNING,
517
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: ComponentErrorSeverity.WARNING,
518
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: ComponentErrorSeverity.INFO,
519
+ [PlaidErrorCodes.PLAID_TIMEOUT]: ComponentErrorSeverity.WARNING,
520
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: ComponentErrorSeverity.ERROR,
521
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: ComponentErrorSeverity.ERROR,
522
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: ComponentErrorSeverity.WARNING,
523
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: ComponentErrorSeverity.WARNING,
524
+ };
525
+ const PlaidPaymentMethod = class {
526
+ constructor(hostRef) {
527
+ registerInstance(this, hostRef);
528
+ this.paymentMethodOptionSelected = createEvent(this, "paymentMethodOptionSelected");
529
+ this.plaidError = createEvent(this, "plaidError");
530
+ this.plaidErrorRecovered = createEvent(this, "plaidErrorRecovered");
531
+ this.isAuthenticating = false;
532
+ this.publicToken = null;
533
+ this.linkToken = null;
534
+ this.linkTokenId = null;
535
+ this.error = null;
536
+ this.plaidLink = null;
537
+ this.isSelected = false;
538
+ this.retryCount = 0;
539
+ this.isRetrying = false;
540
+ this.plaidService = new PlaidService();
541
+ this.maxRetries = 3;
542
+ this.retryDelay = 2000; // 2 seconds
543
+ this.timeoutId = null;
544
+ this.abortController = null;
545
+ this.hasLoggedDisabledWarning = false;
546
+ this.waitForStoreAndInitialize = () => {
547
+ // Check if store has necessary data
548
+ if (checkoutStore.authToken && checkoutStore.accountId && checkoutStore.checkoutId) {
549
+ this.initializePlaidLink();
550
+ }
551
+ else {
552
+ // Wait a bit and try again
553
+ setTimeout(() => {
554
+ this.waitForStoreAndInitialize();
555
+ }, 100);
556
+ }
557
+ };
558
+ this.initializePlaidLink = async () => {
559
+ try {
560
+ // Check if Plaid is available globally
561
+ if (typeof window.Plaid === 'undefined') {
562
+ this.handleError({
563
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
564
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
565
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
566
+ retryable: true,
567
+ userAction: 'Refresh the page and try again'
568
+ });
569
+ return;
570
+ }
571
+ // Get link token from backend
572
+ await this.getLinkToken();
573
+ if (!this.linkToken) {
574
+ this.handleError({
575
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
576
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
577
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
578
+ retryable: true,
579
+ userAction: 'Click to try again'
580
+ });
581
+ return;
582
+ }
583
+ // Initialize Plaid Link
584
+ const Plaid = window.Plaid;
585
+ this.plaidLink = Plaid.create({
586
+ token: this.linkToken,
587
+ onSuccess: this.handlePlaidSuccess,
588
+ onExit: this.handlePlaidExit,
589
+ onEvent: this.handlePlaidEvent,
590
+ onLoad: this.handlePlaidLoad,
591
+ });
592
+ }
593
+ catch (error) {
594
+ this.handleError({
595
+ code: PlaidErrorCodes.PLAID_LINK_INIT_FAILED,
596
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
597
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
598
+ originalError: error,
599
+ retryable: true,
600
+ userAction: 'Click to try again'
601
+ });
602
+ }
603
+ };
604
+ this.getLinkToken = async () => {
605
+ var _a, _b, _c, _d, _e;
606
+ try {
607
+ if (!checkoutStore.authToken || !checkoutStore.accountId) {
608
+ this.handleError({
609
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
610
+ message: 'Missing authentication. Please refresh the page and try again.',
611
+ severity: ComponentErrorSeverity.ERROR,
612
+ retryable: false,
613
+ userAction: 'Refresh the page'
614
+ });
615
+ return;
616
+ }
617
+ // Create abort controller for timeout handling
618
+ this.abortController = new AbortController();
619
+ // Set timeout for the request
620
+ this.timeoutId = setTimeout(() => {
621
+ var _a;
622
+ (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
623
+ }, 30000); // 30 second timeout
624
+ const response = await this.plaidService.getLinkToken(checkoutStore.authToken, checkoutStore.accountId, checkoutStore.checkoutId, this.abortController.signal);
625
+ // Clear timeout
626
+ if (this.timeoutId) {
627
+ clearTimeout(this.timeoutId);
628
+ this.timeoutId = null;
629
+ }
630
+ if (response.error) {
631
+ const errorMessage = typeof response.error === 'string'
632
+ ? response.error
633
+ : response.error.message || 'Failed to get link token';
634
+ throw new Error(errorMessage);
635
+ }
636
+ // Some backends may return an id along with the link token
637
+ this.linkToken = response.data.link_token;
638
+ // Try to capture link token id if present in envelope
639
+ this.linkTokenId = (response === null || response === void 0 ? void 0 : response.id) || ((_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.id) || null;
640
+ if (this.linkTokenId) {
641
+ checkoutStore.plaidLinkTokenId = this.linkTokenId;
642
+ }
643
+ }
644
+ catch (error) {
645
+ // Clear timeout
646
+ if (this.timeoutId) {
647
+ clearTimeout(this.timeoutId);
648
+ this.timeoutId = null;
649
+ }
650
+ let errorCode = PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
651
+ let message = PLAID_ERROR_MESSAGES[errorCode];
652
+ let retryable = true;
653
+ // Handle specific error types
654
+ if (error.name === 'AbortError') {
655
+ errorCode = PlaidErrorCodes.PLAID_TIMEOUT;
656
+ message = PLAID_ERROR_MESSAGES[errorCode];
657
+ retryable = true;
658
+ }
659
+ else if (((_b = error.message) === null || _b === void 0 ? void 0 : _b.includes('network')) || ((_c = error.message) === null || _c === void 0 ? void 0 : _c.includes('fetch'))) {
660
+ errorCode = PlaidErrorCodes.PLAID_NETWORK_ERROR;
661
+ message = PLAID_ERROR_MESSAGES[errorCode];
662
+ retryable = true;
663
+ }
664
+ else if (((_d = error.message) === null || _d === void 0 ? void 0 : _d.includes('401')) || ((_e = error.message) === null || _e === void 0 ? void 0 : _e.includes('unauthorized'))) {
665
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
666
+ message = 'Authentication failed. Please refresh the page and try again.';
667
+ retryable = false;
668
+ }
669
+ this.handleError({
670
+ code: errorCode,
671
+ message: message,
672
+ severity: PLAID_ERROR_SEVERITY[errorCode],
673
+ originalError: error,
674
+ retryable,
675
+ userAction: retryable ? 'Click to try again' : 'Refresh the page'
676
+ });
677
+ }
678
+ };
679
+ this.mapApiErrorToPlaidError = (apiError) => {
680
+ if (typeof apiError === 'string') {
681
+ if (apiError.includes('rate_limit'))
682
+ return PlaidErrorCodes.PLAID_RATE_LIMITED;
683
+ if (apiError.includes('maintenance'))
684
+ return PlaidErrorCodes.PLAID_MAINTENANCE;
685
+ if (apiError.includes('not_authenticated'))
686
+ return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
687
+ }
688
+ if (apiError === null || apiError === void 0 ? void 0 : apiError.code) {
689
+ switch (apiError.code) {
690
+ case 'rate_limited': return PlaidErrorCodes.PLAID_RATE_LIMITED;
691
+ case 'maintenance': return PlaidErrorCodes.PLAID_MAINTENANCE;
692
+ case 'not_authenticated': return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
693
+ case 'invalid_parameter': return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
694
+ default: return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
695
+ }
696
+ }
697
+ return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
698
+ };
699
+ this.openPlaidLink = () => {
700
+ if (this.plaidLink && this.linkToken) {
701
+ this.isAuthenticating = true;
702
+ this.clearError();
703
+ this.plaidLink.open();
704
+ }
705
+ };
706
+ this.handlePlaidSuccess = (publicToken, _metadata) => {
707
+ this.publicToken = publicToken;
708
+ this.isAuthenticating = false;
709
+ this.clearError();
710
+ this.retryCount = 0; // Reset retry count on success
711
+ // Ensure the component remains selected after successful authentication
712
+ if (!this.isSelected) {
713
+ this.isSelected = true;
714
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
715
+ }
716
+ // Emit success event for parent components
717
+ this.plaidErrorRecovered.emit({
718
+ code: 'plaid-success',
719
+ message: 'Bank account connected successfully',
720
+ severity: ComponentErrorSeverity.INFO
721
+ });
722
+ // Store public token in checkout store; exchange will be handled on submit
723
+ checkoutStore.plaidPublicToken = publicToken;
724
+ };
725
+ // Exchange logic moved to Modular Checkout submit flow.
726
+ this.handlePlaidExit = (err, _metadata) => {
727
+ this.isAuthenticating = false;
728
+ if (err) {
729
+ this.handlePlaidError(err);
730
+ }
731
+ };
732
+ this.handlePlaidEvent = (eventName, metadata) => {
733
+ // Handle specific events if needed
734
+ switch (eventName) {
735
+ case 'OPEN':
736
+ this.isAuthenticating = true;
737
+ break;
738
+ case 'CLOSE':
739
+ this.isAuthenticating = false;
740
+ break;
741
+ case 'ERROR':
742
+ this.handlePlaidError(metadata);
743
+ break;
744
+ }
745
+ };
746
+ this.handlePlaidLoad = () => {
747
+ };
748
+ this.handlePlaidError = (error) => {
749
+ let errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
750
+ let message = PLAID_ERROR_MESSAGES[errorCode];
751
+ let retryable = true;
752
+ let userAction = 'Click to try again';
753
+ // Map Plaid error codes to our error codes
754
+ if (error.error_code) {
755
+ switch (error.error_code) {
756
+ case 'INVALID_CREDENTIALS':
757
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
758
+ message = PLAID_ERROR_MESSAGES[errorCode];
759
+ retryable = true;
760
+ break;
761
+ case 'ITEM_LOGIN_REQUIRED':
762
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
763
+ message = 'Your bank requires re-authentication. Please try again.';
764
+ retryable = true;
765
+ break;
766
+ case 'ITEM_LOCKED':
767
+ errorCode = PlaidErrorCodes.PLAID_ACCOUNT_LOCKED;
768
+ message = PLAID_ERROR_MESSAGES[errorCode];
769
+ retryable = false;
770
+ userAction = 'Contact your bank';
771
+ break;
772
+ case 'INSTITUTION_NOT_RESPONDING':
773
+ errorCode = PlaidErrorCodes.PLAID_MAINTENANCE;
774
+ message = PLAID_ERROR_MESSAGES[errorCode];
775
+ retryable = true;
776
+ break;
777
+ case 'RATE_LIMIT_EXCEEDED':
778
+ errorCode = PlaidErrorCodes.PLAID_RATE_LIMITED;
779
+ message = PLAID_ERROR_MESSAGES[errorCode];
780
+ retryable = true;
781
+ break;
782
+ case 'INVALID_REQUEST':
783
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
784
+ message = 'Invalid request. Please try again.';
785
+ retryable = true;
786
+ break;
787
+ case 'PLAID_ERROR':
788
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
789
+ message = error.error_message || 'Bank authentication failed. Please try again.';
790
+ retryable = true;
791
+ break;
792
+ default:
793
+ // Use the error message from Plaid if available
794
+ if (error.error_message) {
795
+ message = error.error_message;
796
+ }
797
+ break;
798
+ }
799
+ }
800
+ // Handle specific error messages
801
+ if (error.error_message) {
802
+ const lowerMessage = error.error_message.toLowerCase();
803
+ if (lowerMessage.includes('not supported') || lowerMessage.includes('unsupported')) {
804
+ errorCode = PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED;
805
+ message = PLAID_ERROR_MESSAGES[errorCode];
806
+ retryable = false;
807
+ userAction = 'Try a different payment method';
808
+ }
809
+ else if (lowerMessage.includes('expired') || lowerMessage.includes('timeout')) {
810
+ errorCode = PlaidErrorCodes.PLAID_TOKEN_EXPIRED;
811
+ message = PLAID_ERROR_MESSAGES[errorCode];
812
+ retryable = true;
813
+ }
814
+ }
815
+ this.handleError({
816
+ code: errorCode,
817
+ message,
818
+ severity: PLAID_ERROR_SEVERITY[errorCode],
819
+ originalError: error,
820
+ retryable,
821
+ userAction
822
+ });
823
+ this.isAuthenticating = false;
824
+ };
825
+ this.handleError = (plaidError) => {
826
+ this.error = plaidError;
827
+ // Emit error event for parent components
828
+ this.plaidError.emit({
829
+ code: plaidError.code,
830
+ message: plaidError.message,
831
+ severity: plaidError.severity,
832
+ data: {
833
+ originalError: plaidError.originalError,
834
+ retryable: plaidError.retryable,
835
+ userAction: plaidError.userAction,
836
+ retryCount: this.retryCount
837
+ }
838
+ });
839
+ console.error('Plaid error:', plaidError);
840
+ // Auto-retry for retryable errors if under max retries
841
+ if (plaidError.retryable && this.retryCount < this.maxRetries) {
842
+ this.scheduleRetry();
843
+ }
844
+ };
845
+ this.scheduleRetry = () => {
846
+ if (this.isRetrying)
847
+ return;
848
+ this.isRetrying = true;
849
+ this.retryCount++;
850
+ setTimeout(() => {
851
+ this.isRetrying = false;
852
+ this.clearError();
853
+ this.waitForStoreAndInitialize();
854
+ }, this.retryDelay * this.retryCount); // Exponential backoff
855
+ };
856
+ this.clearError = () => {
857
+ if (this.error) {
858
+ this.error = null;
859
+ this.retryCount = 0;
860
+ }
861
+ };
862
+ // Watch for store changes to sync component state
863
+ this.syncWithStore = () => {
864
+ const shouldBeSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
865
+ if (this.isSelected !== shouldBeSelected) {
866
+ this.isSelected = shouldBeSelected;
867
+ }
868
+ };
869
+ }
870
+ onSelectionChange(newValue) {
871
+ // Ensure store is updated when component selection changes
872
+ if (newValue && checkoutStore.selectedPaymentMethod.type !== PaymentMethodTypes.plaid) {
873
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
874
+ }
875
+ // Auto-start Plaid flow when selected and ready
876
+ if (newValue &&
877
+ this.plaidLink &&
878
+ !this.publicToken &&
879
+ !this.isAuthenticating &&
880
+ !this.error) {
881
+ this.openPlaidLink();
882
+ }
883
+ }
884
+ componentDidRender() {
885
+ if (!this.scriptRef)
886
+ return;
887
+ this.scriptRef.onload = () => {
888
+ // Wait for store to be populated before initializing
889
+ this.waitForStoreAndInitialize();
890
+ };
891
+ // Add error handler for script loading failures
892
+ this.scriptRef.onerror = () => {
893
+ this.handleError({
894
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
895
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
896
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
897
+ retryable: true,
898
+ userAction: 'Refresh the page and try again'
899
+ });
900
+ };
901
+ }
902
+ componentWillLoad() {
903
+ // Initialize selection state based on store
904
+ this.isSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
905
+ }
906
+ async resolvePaymentMethod() {
907
+ if (!this.publicToken) {
908
+ return { validationError: true };
909
+ }
910
+ return {
911
+ token: this.publicToken,
912
+ data: {
913
+ type: 'bank_account',
914
+ plaid_public_token: this.publicToken
915
+ }
916
+ };
917
+ }
918
+ // Returns a usable payment method token for checkout completion.
919
+ // Will perform the backend exchange if the token is not yet present in the store.
920
+ async getPaymentToken() {
921
+ return checkoutStore.paymentToken;
922
+ }
923
+ async handleSelectionClick() {
924
+ // Update local selection state
925
+ this.isSelected = true;
926
+ // Update store selection
927
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
928
+ // If there's an error, clear it and try to initialize again
929
+ if (this.error) {
930
+ this.clearError();
931
+ this.waitForStoreAndInitialize();
932
+ return;
933
+ }
934
+ // If Plaid Link is ready and no public token exists, open Plaid Link
935
+ if (this.plaidLink && !this.publicToken && !this.isAuthenticating) {
936
+ this.openPlaidLink();
937
+ }
938
+ }
939
+ // Method to handle external selection changes (e.g., from other payment methods)
940
+ async setSelected(selected) {
941
+ this.isSelected = selected;
942
+ if (selected) {
943
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
944
+ }
945
+ }
946
+ // Method to check if component is currently selected
947
+ async isCurrentlySelected() {
948
+ return this.isSelected;
949
+ }
950
+ // Method to handle external deselection (when another payment method is selected)
951
+ async deselect() {
952
+ this.isSelected = false;
953
+ // Don't clear the public token or error state as they might be needed if user reselects
954
+ }
955
+ // Method to reset component state (useful for testing or error recovery)
956
+ async reset() {
957
+ this.publicToken = null;
958
+ this.clearError();
959
+ this.isAuthenticating = false;
960
+ this.linkToken = null;
961
+ this.plaidLink = null;
962
+ this.retryCount = 0;
963
+ this.isRetrying = false;
964
+ // Clear any pending timeouts
965
+ if (this.timeoutId) {
966
+ clearTimeout(this.timeoutId);
967
+ this.timeoutId = null;
968
+ }
969
+ // Abort any pending requests
970
+ if (this.abortController) {
971
+ this.abortController.abort();
972
+ this.abortController = null;
973
+ }
974
+ }
975
+ // Method to check if component is ready for authentication
976
+ async isReadyForAuthentication() {
977
+ return !!(this.plaidLink && this.linkToken && !this.isAuthenticating);
978
+ }
979
+ // Method to manually retry after an error
980
+ async retry() {
981
+ if (this.error && this.error.retryable) {
982
+ this.clearError();
983
+ this.waitForStoreAndInitialize();
984
+ }
985
+ }
986
+ // Method to get current error information
987
+ async getErrorInfo() {
988
+ return this.error;
989
+ }
990
+ componentDidLoad() {
991
+ // Set up store change listener to keep component in sync
992
+ const unsubscribe = onChange('selectedPaymentMethod', this.syncWithStore);
993
+ // Store unsubscribe function for cleanup
994
+ this.unsubscribeFromStore = unsubscribe;
995
+ }
996
+ disconnectedCallback() {
997
+ // Clean up store subscription
998
+ if (this.unsubscribeFromStore) {
999
+ this.unsubscribeFromStore();
1000
+ }
1001
+ // Clean up timeouts and abort controllers
1002
+ if (this.timeoutId) {
1003
+ clearTimeout(this.timeoutId);
1004
+ }
1005
+ if (this.abortController) {
1006
+ this.abortController.abort();
1007
+ }
1008
+ }
1009
+ render() {
1010
+ // Only allow use if enabled in checkout settings
1011
+ if (checkoutStore.bankAccountVerification !== true) {
1012
+ if (!this.hasLoggedDisabledWarning) {
1013
+ // Log once per component lifecycle
1014
+ console.warn('[PlaidPaymentMethod] bank_account_verification is disabled. Component will not render.');
1015
+ this.hasLoggedDisabledWarning = true;
1016
+ }
1017
+ return null;
1018
+ }
1019
+ const plaidLogo = (h("img", { class: "plaid-logo-img", src: plaidIconSvg, alt: "Plaid", title: "Plaid", style: {
1020
+ display: 'inline',
1021
+ width: '20px',
1022
+ height: '20px',
1023
+ marginLeft: '5px',
1024
+ marginTop: '-2px',
1025
+ } }));
1026
+ const renderErrorState = () => {
1027
+ if (!this.error)
1028
+ return null;
1029
+ const errorClass = this.error.severity === ComponentErrorSeverity.ERROR
1030
+ ? 'text-danger'
1031
+ : this.error.severity === ComponentErrorSeverity.WARNING
1032
+ ? 'text-warning'
1033
+ : 'text-info';
1034
+ return (h("div", { class: `${errorClass} mt-2` }, h("small", null, this.error.message), h("br", null), h("small", { class: "text-muted" }, this.error.userAction, this.error.retryable && this.retryCount < this.maxRetries && (h("span", null, " \u2022 Auto-retry in progress...")))));
1035
+ };
1036
+ const renderStatusState = () => {
1037
+ if (this.error)
1038
+ return null;
1039
+ if (this.isAuthenticating) {
1040
+ return (h("div", { class: "text-info mt-2" }, h("small", null, "Connecting to your bank...")));
1041
+ }
1042
+ if (this.publicToken) {
1043
+ return (h("div", { class: "text-success mt-2" }, h("small", null, "\u2713 Bank account connected successfully")));
1044
+ }
1045
+ if (this.isSelected && !this.publicToken && !this.error && !this.isAuthenticating) {
1046
+ return (h("div", { class: "text-muted mt-2" }, h("small", null, "Click to connect your bank account")));
1047
+ }
1048
+ return null;
1049
+ };
1050
+ return (h(StyledHost, { class: "payment-method" }, h("script", { src: "https://cdn.plaid.com/link/v2/stable/link-initialize.js", async: true, ref: (el) => (this.scriptRef = el) }), h("div", { title: "Pay with Plaid" }, h("div", { onClick: (event) => { event.preventDefault(); this.handleSelectionClick(); } }, "Pay with Bank Account ", plaidLogo, " "), renderErrorState(), renderStatusState())));
1051
+ }
1052
+ static get watchers() { return {
1053
+ "isSelected": ["onSelectionChange"]
1054
+ }; }
1055
+ };
1056
+
1057
+ const SavedPaymentMethods = class {
1058
+ constructor(hostRef) {
1059
+ registerInstance(this, hostRef);
1060
+ this.onPaymentMethodOptionClick = (paymentMethod) => (e) => {
1061
+ e.preventDefault();
1062
+ checkoutStore.selectedPaymentMethod = paymentMethod;
1063
+ checkoutStore.paymentToken = paymentMethod.id;
1064
+ };
1065
+ this.isAllowedPaymentMethod = (paymentMethod) => {
1066
+ if (paymentMethod.type === PAYMENT_METHOD_TYPES.CARD && checkoutStore.disableCreditCard) {
1067
+ return false;
1068
+ }
1069
+ if (paymentMethod.type === PAYMENT_METHOD_TYPES.BANK_ACCOUNT && checkoutStore.disableBankAccount) {
1070
+ return false;
1071
+ }
1072
+ return true;
1073
+ };
1074
+ }
1075
+ componentWillLoad() {
1076
+ if (!checkoutStore.paymentMethods.length) {
1077
+ console.warn('No saved payment methods available.');
1078
+ }
1079
+ if (checkoutStore.disablePaymentMethodGroup) {
1080
+ console.warn('Payment method group is disabled.');
1081
+ }
1082
+ }
1083
+ render() {
1084
+ if (checkoutStore.disablePaymentMethodGroup) {
1085
+ return null;
1086
+ }
1087
+ return (h(StyledHost, null, h("div", { class: "saved-payment-methods" }, checkoutStore.paymentMethods.length ? checkoutStore.paymentMethods
1088
+ .filter(this.isAllowedPaymentMethod)
1089
+ .map((paymentMethod) => (h("div", { class: "radio-list-item p-3", part: radioListItem, onClick: this.onPaymentMethodOptionClick(paymentMethod) }, h("form-control-radio", { name: "paymentMethodType", value: paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id, checked: checkoutStore.paymentToken === (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id), label: `${CardBrandLabels[paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.brand] || ''} *${paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.acct_last_four}` })))) : null)));
1090
+ }
1091
+ };
1092
+
1093
+ const sezzleLogo = (h("img", { class: "sezzle-smart-button-logo-img", src: "https://media.sezzle.com/branding/2.0/Sezzle_Logo_FullColor.svg", alt: "Sezzle", style: {
1094
+ display: 'inline',
1095
+ width: '80px',
1096
+ marginLeft: '5px',
1097
+ marginTop: '-5px',
1098
+ } }));
1099
+ const SezzlePaymentMethod = class {
1100
+ constructor(hostRef) {
1101
+ registerInstance(this, hostRef);
1102
+ this.paymentMethodOptionSelected = createEvent(this, "paymentMethodOptionSelected");
1103
+ this.paymentMethodOptionId = PAYMENT_METHODS.SEZZLE;
1104
+ this.initializeSezzleCheckout = () => {
1105
+ let resolveSezzlePromise;
1106
+ this.sezzlePromise = new Promise((resolve) => { resolveSezzlePromise = resolve; });
1107
+ const amount = Number(checkoutStore.paymentAmount);
1108
+ const Checkout = window.Checkout;
1109
+ const checkout = new Checkout({
1110
+ mode: 'popup',
1111
+ publicKey: checkoutStore.bnplProviderClientId,
1112
+ apiMode: checkoutStore.bnplProviderMode,
1113
+ apiVersion: checkoutStore.bnplProviderApiVersion,
1114
+ });
1115
+ checkout.sezzleButtonElement = this.sezzleButtonRef;
1116
+ checkout.init({
1117
+ onClick: function (event) {
1118
+ event.preventDefault();
1119
+ checkout.startCheckout({
1120
+ checkout_url: checkoutStore.bnplProviderCheckoutUrl,
1121
+ });
1122
+ },
1123
+ onComplete: (event) => resolveSezzlePromise({ bnpl: event.data }),
1124
+ onCancel: (event) => resolveSezzlePromise({ bnpl: event.data }),
1125
+ onFailure: (event) => resolveSezzlePromise({ bnpl: event.data }),
1126
+ });
1127
+ this.sezzleCheckout = checkout;
1128
+ this.installmentPlan = this.sezzleCheckout.getInstallmentPlan(amount);
1129
+ };
1130
+ }
1131
+ componentDidRender() {
1132
+ if (!this.scriptRef)
1133
+ return;
1134
+ this.scriptRef.onload = () => {
1135
+ this.sezzleButtonRef = document.createElement('button');
1136
+ this.initializeSezzleCheckout();
1137
+ };
1138
+ }
1139
+ async resolvePaymentMethod(insuranceValidation) {
1140
+ if (!insuranceValidation.isValid) {
1141
+ return { validationError: true };
1142
+ }
1143
+ this.sezzleButtonRef.click();
1144
+ return this.sezzlePromise;
1145
+ }
1146
+ async handleSelectionClick() {
1147
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.sezzle };
1148
+ this.paymentMethodOptionSelected.emit(this.paymentMethodOptionId);
1149
+ }
1150
+ render() {
1151
+ var _a, _b;
1152
+ if (!checkoutStore.bnplEnabled || checkoutStore.disableBnpl) {
1153
+ console.warn('justifi-sezzle-payment-method: BNPL is not enabled for this account.');
1154
+ return null;
1155
+ }
1156
+ return (h(StyledHost, { class: "payment-method" }, h("script", { src: "https://checkout-sdk.sezzle.com/checkout.min.js", async: true, ref: (el) => (this.scriptRef = el) }), h("div", null, h("div", null, "Buy now, pay later with ", sezzleLogo), this.installmentPlan && (h("small", null, h("span", null, (_a = this.installmentPlan) === null || _a === void 0 ? void 0 : _a.installments.length), "\u00A0", h("span", null, this.installmentPlan.schedule, " payments of"), "\u00A0", h("span", { class: "fw-bold" }, formatCurrency((_b = this.installmentPlan) === null || _b === void 0 ? void 0 : _b.installments[0].amountInCents)))))));
1157
+ }
1158
+ };
1159
+
1160
+ // Constants
1161
+ const PAYMENT_METHOD_TYPE_LABELS = {
1162
+ [PaymentMethodTypes.bankAccount]: 'New bank account',
1163
+ [PaymentMethodTypes.card]: 'New credit or debit card',
1164
+ };
1165
+ const ERROR_MESSAGES = {
1166
+ AUTH_TOKEN_REQUIRED: 'Auth token is required when using the tokenize-payment-method component not slotted in justifi-modular-checkout',
1167
+ ACCOUNT_ID_REQUIRED: 'Account ID is required when using the tokenize-payment-method component not slotted in justifi-modular-checkout',
1168
+ FORM_NOT_READY: 'Payment form not ready',
1169
+ VALIDATION_ERROR: 'Validation error',
1170
+ };
1171
+ const TokenizePaymentMethod = class {
1172
+ constructor(hostRef) {
1173
+ registerInstance(this, hostRef);
1174
+ this.errorEvent = createEvent(this, "error-event");
1175
+ this.submitEvent = createEvent(this, "submit-event");
1176
+ this.computedHideSubmitButton = false;
1177
+ this.isLoading = false;
1178
+ this.submitButtonText = 'Submit';
1179
+ }
1180
+ paymentMethodsChanged() {
1181
+ this.setDefaultSelectedPaymentMethod();
1182
+ }
1183
+ connectedCallback() {
1184
+ this.setDefaultSelectedPaymentMethod();
1185
+ this.setComputedHideSubmitButton();
1186
+ }
1187
+ disconnectedCallback() {
1188
+ var _a;
1189
+ (_a = this.analytics) === null || _a === void 0 ? void 0 : _a.cleanup();
1190
+ if (this.unsubscribeFromStore) {
1191
+ this.unsubscribeFromStore();
1192
+ }
1193
+ }
1194
+ componentWillLoad() {
1195
+ checkPkgVersion();
1196
+ this.analytics = new JustifiAnalytics(this);
1197
+ }
1198
+ handleRadioClick(event) {
1199
+ this.selectedPaymentMethod = event.detail;
1200
+ checkoutStore.selectedPaymentMethod = { type: event.detail };
1201
+ }
1202
+ async fillBillingForm(fields) {
1203
+ var _a;
1204
+ (_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.fill(fields);
1205
+ }
1206
+ async tokenizePaymentMethod(event) {
1207
+ event === null || event === void 0 ? void 0 : event.preventDefault();
1208
+ this.validateRequiredProps();
1209
+ this.isLoading = true;
1210
+ try {
1211
+ const validation = await this.validate();
1212
+ if (!validation.isValid) {
1213
+ this.errorEvent.emit({
1214
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
1215
+ message: ERROR_MESSAGES.VALIDATION_ERROR,
1216
+ });
1217
+ this.isLoading = false;
1218
+ return;
1219
+ }
1220
+ const tokenizeResponse = await this.resolvePaymentMethod({ isValid: true });
1221
+ if (tokenizeResponse.error) {
1222
+ this.emitError({
1223
+ errorCode: tokenizeResponse.error.code,
1224
+ message: tokenizeResponse.error.message,
1225
+ });
1226
+ }
1227
+ this.submitEvent.emit({ response: tokenizeResponse });
1228
+ return tokenizeResponse;
1229
+ }
1230
+ catch (error) {
1231
+ const errorResponse = this.createErrorResponse(ComponentErrorCodes.TOKENIZE_ERROR, error.message);
1232
+ this.emitError({
1233
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
1234
+ message: error.message,
1235
+ });
1236
+ this.submitEvent.emit({ response: errorResponse });
1237
+ return errorResponse;
1238
+ }
1239
+ finally {
1240
+ this.isLoading = false;
1241
+ }
1242
+ }
1243
+ async validate() {
1244
+ if (!this.areFormsReady()) {
1245
+ return { isValid: false, errors: { general: ERROR_MESSAGES.FORM_NOT_READY } };
1246
+ }
1247
+ const [billingValidation, paymentMethodValidation] = await Promise.all([
1248
+ this.billingFormRef.validate(),
1249
+ this.paymentMethodFormRef.validate(),
1250
+ ]);
1251
+ const result = {
1252
+ isValid: billingValidation.isValid && paymentMethodValidation.isValid,
1253
+ errors: Object.assign(Object.assign({}, billingValidation.errors), paymentMethodValidation.errors),
1254
+ };
1255
+ return result;
1256
+ }
1257
+ async tokenize() {
1258
+ try {
1259
+ const billingFormFieldValues = await this.billingFormRef.getValues();
1260
+ const config = {
1261
+ clientId: this.authToken || checkoutStore.authToken,
1262
+ account: this.accountId || checkoutStore.accountId,
1263
+ paymentMethodMetadata: this.buildPaymentMethodMetadata(billingFormFieldValues),
1264
+ };
1265
+ return await this.paymentMethodFormRef.tokenize(config);
1266
+ }
1267
+ catch (error) {
1268
+ return error;
1269
+ }
1270
+ }
1271
+ // 9. Local methods
1272
+ validateRequiredProps() {
1273
+ if (!this.authToken && !checkoutStore.authToken) {
1274
+ this.emitError({
1275
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
1276
+ message: ERROR_MESSAGES.AUTH_TOKEN_REQUIRED,
1277
+ });
1278
+ }
1279
+ if (!this.accountId && !checkoutStore.accountId) {
1280
+ this.emitError({
1281
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
1282
+ message: ERROR_MESSAGES.ACCOUNT_ID_REQUIRED,
1283
+ });
1284
+ }
1285
+ }
1286
+ setDefaultSelectedPaymentMethod() {
1287
+ if (this.selectedPaymentMethod) {
1288
+ return;
1289
+ }
1290
+ if (!this.disableCreditCard) {
1291
+ this.selectedPaymentMethod = PaymentMethodTypes.card;
1292
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.card };
1293
+ }
1294
+ else if (!this.disableBankAccount) {
1295
+ this.selectedPaymentMethod = PaymentMethodTypes.bankAccount;
1296
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.bankAccount };
1297
+ }
1298
+ }
1299
+ setComputedHideSubmitButton() {
1300
+ // If hideSubmitButton prop is explicitly set, use that value
1301
+ if (this.hideSubmitButton !== undefined) {
1302
+ this.computedHideSubmitButton = this.hideSubmitButton;
1303
+ return;
1304
+ }
1305
+ // Otherwise, auto-detect if component is slotted within modular-checkout
1306
+ const isWithinModularCheckout = this.isSlottedWithinModularCheckout();
1307
+ this.computedHideSubmitButton = isWithinModularCheckout;
1308
+ }
1309
+ isSlottedWithinModularCheckout() {
1310
+ var _a;
1311
+ let parent = (_a = this.host) === null || _a === void 0 ? void 0 : _a.parentElement;
1312
+ while (parent) {
1313
+ if (parent.tagName === 'JUSTIFI-MODULAR-CHECKOUT') {
1314
+ return true;
1315
+ }
1316
+ parent = parent.parentElement;
1317
+ }
1318
+ return false;
1319
+ }
1320
+ get availablePaymentMethods() {
1321
+ const methods = [];
1322
+ if (!this.disableCreditCard) {
1323
+ methods.push(PaymentMethodTypes.card);
1324
+ }
1325
+ if (!this.disableBankAccount) {
1326
+ methods.push(PaymentMethodTypes.bankAccount);
1327
+ }
1328
+ return methods;
1329
+ }
1330
+ areFormsReady() {
1331
+ return !!(this.billingFormRef && this.paymentMethodFormRef);
1332
+ }
1333
+ emitError(errorData) {
1334
+ this.errorEvent.emit(Object.assign(Object.assign({}, errorData), { severity: ComponentErrorSeverity.ERROR }));
1335
+ }
1336
+ createErrorResponse(code, message) {
1337
+ return {
1338
+ error: {
1339
+ code: code,
1340
+ message,
1341
+ decline_code: undefined,
1342
+ },
1343
+ };
1344
+ }
1345
+ async resolvePaymentMethod(insuranceValidation) {
1346
+ if (!this.areFormsReady()) {
1347
+ return this.createErrorResponse('form_not_ready', ERROR_MESSAGES.FORM_NOT_READY);
1348
+ }
1349
+ try {
1350
+ const validation = await this.validate();
1351
+ if (!validation.isValid || !insuranceValidation.isValid) {
1352
+ const errorMessage = Object.values(validation.errors)[0] || ERROR_MESSAGES.VALIDATION_ERROR;
1353
+ return {
1354
+ validationError: true,
1355
+ error: {
1356
+ code: 'validation_error',
1357
+ message: String(errorMessage),
1358
+ decline_code: undefined,
1359
+ },
1360
+ };
1361
+ }
1362
+ const result = await this.performTokenization();
1363
+ return result;
1364
+ }
1365
+ catch (error) {
1366
+ return { error };
1367
+ }
1368
+ }
1369
+ async performTokenization() {
1370
+ var _a, _b;
1371
+ const tokenizeResponse = await this.tokenize();
1372
+ if (tokenizeResponse.error) {
1373
+ return { error: tokenizeResponse.error };
1374
+ }
1375
+ const tokenizeResponseData = tokenizeResponse.data;
1376
+ return {
1377
+ token: ((_a = tokenizeResponseData.card) === null || _a === void 0 ? void 0 : _a.token) || ((_b = tokenizeResponseData.bank_account) === null || _b === void 0 ? void 0 : _b.token),
1378
+ data: tokenizeResponseData,
1379
+ };
1380
+ }
1381
+ buildPaymentMethodMetadata(billingFormFieldValues) {
1382
+ return this.shouldSavePaymentMethod
1383
+ ? Object.assign(Object.assign({}, billingFormFieldValues), { payment_method_group_id: this.paymentMethodGroupID }) : Object.assign({}, billingFormFieldValues);
1384
+ }
1385
+ get paymentMethodGroupID() {
1386
+ return this.paymentMethodGroupId || checkoutStore.paymentMethodGroupId;
1387
+ }
1388
+ get shouldSavePaymentMethod() {
1389
+ return !!(this.paymentMethodGroupId || checkoutStore.savePaymentMethod);
1390
+ }
1391
+ get shouldHideRadioInput() {
1392
+ return this.disableCreditCard || this.disableBankAccount;
1393
+ }
1394
+ renderPaymentMethodOption(paymentMethodType) {
1395
+ const isSelected = this.selectedPaymentMethod === paymentMethodType && checkoutStore.selectedPaymentMethod.id === undefined;
1396
+ return (h("div", { class: "payment-method" }, h("justifi-radio-list-item", { name: "paymentMethodType", value: paymentMethodType, checked: isSelected, label: PAYMENT_METHOD_TYPE_LABELS[paymentMethodType], hidden: this.shouldHideRadioInput }), isSelected && this.renderSelectedPaymentMethodForm(paymentMethodType)));
1397
+ }
1398
+ renderSelectedPaymentMethodForm(paymentMethodId) {
1399
+ return (h("div", { class: "mt-4 pb-4" }, this.renderPaymentMethodForm(paymentMethodId), h("div", { class: "mt-4" }, h("justifi-billing-form", { ref: (el) => (this.billingFormRef = el), hideCardBillingForm: this.hideCardBillingForm, hideBankAccountBillingForm: this.hideBankAccountBillingForm, paymentMethodType: paymentMethodId })), h("div", { class: "mt-4" }, h("justifi-save-new-payment-method", { hidden: !this.paymentMethodGroupID, label: this.savePaymentMethodLabel }))));
1400
+ }
1401
+ renderPaymentMethodForm(paymentMethodId) {
1402
+ return paymentMethodId === PaymentMethodTypes.card ? (h("justifi-card-form", { ref: (el) => (this.paymentMethodFormRef = el) })) : (h("justifi-bank-account-form", { ref: (el) => (this.paymentMethodFormRef = el) }));
1403
+ }
1404
+ render() {
1405
+ return (h(StyledHost, { key: '27acb4552c8e2431792108448608c039baa705c6' }, h("form", { key: '914d43a641bbc484da9399d9d7b938215666862b' }, h("fieldset", { key: '4df90b4279eaa9c02268074c1d4c630c75e54f26' }, h("div", { key: 'b4b8895c7e5b9a3e615d357e2a6fdba5c245decb', class: "row gy-3" }, h("div", { key: '10ecdd6afffef324179fabcab340e4290c22f594', class: "col-12" }, this.availablePaymentMethods.map((method) => this.renderPaymentMethodOption(method))), h("div", { key: '3327294952c67643c9c77178f801bbbba09fd511', class: "col-12" }, h("justifi-button", { key: '6de96d2c0065f676e696433f8ef6438527830437', text: this.submitButtonText, variant: "primary", type: "submit", clickHandler: (e) => this.tokenizePaymentMethod(e), isLoading: this.isLoading, "data-testid": "submit-button", hidden: this.computedHideSubmitButton })))))));
1406
+ }
1407
+ get host() { return getElement(this); }
1408
+ static get watchers() { return {
1409
+ "disableCreditCard": ["paymentMethodsChanged"],
1410
+ "disableBankAccount": ["paymentMethodsChanged"]
1411
+ }; }
1412
+ };
1413
+
1414
+ export { Summary as justifi_checkout_summary, Header as justifi_header, ModularCheckout as justifi_modular_checkout, PlaidPaymentMethod as justifi_plaid_payment_method, SavedPaymentMethods as justifi_saved_payment_methods, SezzlePaymentMethod as justifi_sezzle_payment_method, TokenizePaymentMethod as justifi_tokenize_payment_method };