@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
@@ -1,25 +1,27 @@
1
- import { h, Host } from "@stencil/core";
2
- import { checkoutStore, onChange } from "../../store/checkout.store";
1
+ import { h, Host, } from "@stencil/core";
2
+ import { checkoutStore, onAnyChange, getAvailablePaymentMethodTypes } from "../../store/checkout.store";
3
3
  import JustifiAnalytics from "../../api/Analytics";
4
4
  import { checkPkgVersion } from "../../utils/check-pkg-version";
5
- import { ComponentErrorCodes, ComponentErrorMessages, ComponentErrorSeverity, ICheckoutStatus } from "../../api";
6
- import { makeCheckoutComplete, makeGetCheckout } from "../../actions/checkout/checkout-actions";
5
+ import { ComponentErrorCodes, ComponentErrorMessages, ComponentErrorSeverity, ICheckoutStatus, PaymentMethodTypes, } from "../../api";
6
+ import { makeCheckoutComplete, makeGetCheckout, } from "../../actions/checkout/checkout-actions";
7
7
  import { CheckoutService } from "../../api/services/checkout.service";
8
+ import { PlaidService } from "../../api/services/plaid.service";
8
9
  import { insuranceValues, insuranceValuesOn, hasInsuranceValueChanged } from "../insurance/insurance-state";
10
+ import { PAYMENT_MODE } from "./ModularCheckout";
9
11
  export class ModularCheckout {
10
12
  constructor() {
11
- this.savePaymentMethod = false;
13
+ this.plaidService = new PlaidService();
12
14
  this.handleApplePayCompleted = (event) => {
13
- const { success, token, error } = event.detail;
15
+ const { success, token, paymentMethodId, error } = event.detail;
14
16
  if (success && token) {
15
- this.applePayToken = token;
16
- // Complete the checkout with Apple Pay token
17
- this.submitCheckoutWithApplePay();
17
+ checkoutStore.paymentToken = paymentMethodId;
18
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.applePay };
19
+ this.submitCheckout();
18
20
  }
19
21
  else {
20
- console.error('Apple Pay completed but failed:', error);
22
+ console.error("Apple Pay completed but failed:", error);
21
23
  this.errorEvent.emit({
22
- message: (error === null || error === void 0 ? void 0 : error.message) || 'Apple Pay payment failed',
24
+ message: (error === null || error === void 0 ? void 0 : error.message) || "Apple Pay payment failed",
23
25
  errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
24
26
  severity: ComponentErrorSeverity.ERROR,
25
27
  });
@@ -27,59 +29,48 @@ export class ModularCheckout {
27
29
  };
28
30
  this.handleApplePayError = (event) => {
29
31
  const { error } = event.detail;
30
- console.error('Apple Pay error:', error);
32
+ console.error("Apple Pay error:", error);
31
33
  this.errorEvent.emit({
32
- message: error || 'Apple Pay error occurred',
34
+ message: error || "Apple Pay error occurred",
33
35
  errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
34
36
  severity: ComponentErrorSeverity.ERROR,
35
37
  });
36
38
  };
37
39
  this.handleApplePayCancelled = () => {
38
- console.log('Apple Pay cancelled by user');
39
- // Reset the token if cancelled
40
- this.applePayToken = undefined;
40
+ checkoutStore.paymentToken = undefined;
41
+ checkoutStore.selectedPaymentMethod = undefined;
41
42
  };
42
43
  }
43
- savePaymentMethodChanged(newValue) {
44
- checkoutStore.savePaymentMethod = newValue;
45
- }
46
44
  connectedCallback() {
45
+ console.log("connectedCallback", checkoutStore.checkoutLoaded);
47
46
  this.observer = new MutationObserver(() => {
48
47
  this.queryFormRefs();
49
48
  this.setupApplePayListeners(); // set up again listeners when DOM changes
50
49
  });
51
50
  this.observer.observe(this.hostEl, {
52
51
  childList: true,
53
- subtree: true
52
+ subtree: true,
54
53
  });
55
54
  checkoutStore.checkoutId = this.checkoutId;
56
55
  const config = {
57
56
  authToken: this.authToken,
58
57
  checkoutId: this.checkoutId,
59
- service: new CheckoutService()
58
+ service: new CheckoutService(),
60
59
  };
61
60
  this.getCheckout = makeGetCheckout(config);
62
61
  this.completeCheckout = makeCheckoutComplete(config);
63
- onChange('selectedPaymentMethod', (newValue) => {
64
- this.paymentMethodChangedEvent.emit(newValue);
62
+ // Emit checkout-changed whenever any store key changes
63
+ onAnyChange(() => {
64
+ this.emitCheckoutChanged();
65
65
  });
66
66
  }
67
67
  componentWillLoad() {
68
- if (!this.authToken || !this.checkoutId) {
69
- this.errorEvent.emit({
70
- message: ComponentErrorMessages.NOT_AUTHENTICATED,
71
- errorCode: ComponentErrorCodes.NOT_AUTHENTICATED,
72
- severity: ComponentErrorSeverity.ERROR,
73
- });
74
- return;
75
- }
76
68
  this.analytics = new JustifiAnalytics(this);
77
69
  checkPkgVersion();
78
70
  checkoutStore.authToken = this.authToken;
79
- checkoutStore.savePaymentMethod = this.savePaymentMethod;
80
71
  this.fetchCheckout();
81
72
  // Refresh the checkout data when insurance values actually change (not on initial load)
82
- insuranceValuesOn('set', (key) => {
73
+ insuranceValuesOn("set", (key) => {
83
74
  const value = insuranceValues[key];
84
75
  if (value !== undefined && hasInsuranceValueChanged(key, value)) {
85
76
  this.fetchCheckout();
@@ -96,9 +87,18 @@ export class ModularCheckout {
96
87
  this.removeApplePayListeners();
97
88
  }
98
89
  fetchCheckout() {
90
+ if (!this.authToken || !this.checkoutId) {
91
+ this.errorEvent.emit({
92
+ message: ComponentErrorMessages.NOT_AUTHENTICATED,
93
+ errorCode: ComponentErrorCodes.NOT_AUTHENTICATED,
94
+ severity: ComponentErrorSeverity.ERROR,
95
+ });
96
+ return;
97
+ }
99
98
  if (this.getCheckout) {
100
99
  this.getCheckout({
101
100
  onSuccess: ({ checkout }) => {
101
+ this.updateStore(checkout);
102
102
  if (checkout.status === ICheckoutStatus.completed) {
103
103
  this.errorEvent.emit({
104
104
  message: ComponentErrorMessages.CHECKOUT_ALREADY_COMPLETED,
@@ -115,7 +115,6 @@ export class ModularCheckout {
115
115
  });
116
116
  return;
117
117
  }
118
- this.updateStore(checkout);
119
118
  },
120
119
  onError: (error) => {
121
120
  this.errorEvent.emit({
@@ -123,186 +122,217 @@ export class ModularCheckout {
123
122
  errorCode: ComponentErrorCodes.FETCH_ERROR,
124
123
  severity: ComponentErrorSeverity.ERROR,
125
124
  });
126
- }
125
+ },
127
126
  });
128
127
  }
129
128
  }
130
129
  updateStore(checkout) {
131
- var _a, _b, _c, _d;
130
+ var _a, _b, _c, _d, _e;
132
131
  checkoutStore.accountId = checkout.account_id;
132
+ checkoutStore.checkoutLoaded = true;
133
133
  checkoutStore.paymentMethods = checkout.payment_methods;
134
134
  checkoutStore.paymentMethodGroupId = checkout.payment_method_group_id;
135
135
  checkoutStore.paymentDescription = checkout.payment_description;
136
136
  checkoutStore.totalAmount = checkout.total_amount;
137
137
  checkoutStore.paymentAmount = checkout.payment_amount;
138
138
  checkoutStore.bnplEnabled = checkout.payment_settings.bnpl_payments;
139
- checkoutStore.bnplProviderClientId = (_a = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _a === void 0 ? void 0 : _a.provider_client_id;
140
- checkoutStore.bnplProviderMode = (_b = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _b === void 0 ? void 0 : _b.provider_mode;
141
- checkoutStore.bnplProviderApiVersion = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_api_version;
142
- checkoutStore.bnplProviderCheckoutUrl = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_checkout_url;
139
+ checkoutStore.insuranceEnabled = checkout.payment_settings.insurance_payments;
140
+ checkoutStore.bankAccountVerification = (_a = checkout.payment_settings) === null || _a === void 0 ? void 0 : _a.bank_account_verification;
141
+ checkoutStore.bnplProviderClientId = (_b = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _b === void 0 ? void 0 : _b.provider_client_id;
142
+ checkoutStore.bnplProviderMode = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_mode;
143
+ checkoutStore.bnplProviderApiVersion = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_api_version;
144
+ checkoutStore.bnplProviderCheckoutUrl =
145
+ (_e = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _e === void 0 ? void 0 : _e.provider_checkout_url;
146
+ }
147
+ emitCheckoutChanged() {
148
+ const detail = {
149
+ availablePaymentMethodTypes: getAvailablePaymentMethodTypes(),
150
+ selectedPaymentMethod: checkoutStore.selectedPaymentMethod,
151
+ savedPaymentMethods: checkoutStore.paymentMethods,
152
+ };
153
+ this.checkoutChangedEvent.emit(detail);
143
154
  }
144
155
  queryFormRefs() {
145
- this.paymentMethodFormRef = this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form');
146
- this.billingFormRef = this.hostEl.querySelector('justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full');
156
+ this.billingFormRef = this.hostEl.querySelector("justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full");
157
+ this.applePayRef = this.hostEl.querySelector("justifi-apple-pay");
158
+ this.paymentMethodFormRef =
159
+ this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form, justifi-tokenize-payment-method');
147
160
  this.insuranceFormRef = this.hostEl.querySelector('justifi-season-interruption-insurance');
148
- this.sezzlePaymentMethodRef = this.hostEl.querySelector('justifi-sezzle-payment-method');
149
- this.applePayRef = this.hostEl.querySelector('justifi-apple-pay');
150
161
  }
151
162
  setupApplePayListeners() {
152
163
  if (this.applePayRef) {
153
- this.applePayRef.addEventListener('applePayCompleted', this.handleApplePayCompleted);
154
- this.applePayRef.addEventListener('applePayError', this.handleApplePayError);
155
- this.applePayRef.addEventListener('applePayCancelled', this.handleApplePayCancelled);
164
+ this.applePayRef.addEventListener("applePayCompleted", this.handleApplePayCompleted);
165
+ this.applePayRef.addEventListener("applePayError", this.handleApplePayError);
166
+ this.applePayRef.addEventListener("applePayCancelled", this.handleApplePayCancelled);
156
167
  }
157
168
  }
158
169
  removeApplePayListeners() {
159
170
  if (this.applePayRef) {
160
- this.applePayRef.removeEventListener('applePayCompleted', this.handleApplePayCompleted);
161
- this.applePayRef.removeEventListener('applePayError', this.handleApplePayError);
162
- this.applePayRef.removeEventListener('applePayCancelled', this.handleApplePayCancelled);
163
- }
164
- }
165
- async submitCheckoutWithApplePay() {
166
- if (!this.applePayToken) {
167
- this.errorEvent.emit({
168
- message: 'No Apple Pay token available',
169
- errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
170
- severity: ComponentErrorSeverity.ERROR,
171
- });
172
- return;
171
+ this.applePayRef.removeEventListener("applePayCompleted", this.handleApplePayCompleted);
172
+ this.applePayRef.removeEventListener("applePayError", this.handleApplePayError);
173
+ this.applePayRef.removeEventListener("applePayCancelled", this.handleApplePayCancelled);
173
174
  }
174
- const payment = {
175
- payment_mode: 'apple_pay',
176
- payment_token: this.applePayToken,
177
- };
178
- this.completeCheckout({
179
- payment,
180
- onSuccess: ({ checkout }) => {
181
- this.submitEvent.emit({
182
- checkout,
183
- message: 'Apple Pay checkout completed successfully',
184
- });
185
- },
186
- onError: (error) => {
187
- this.errorEvent.emit({
188
- message: error.message,
189
- errorCode: ComponentErrorCodes.COMPLETE_CHECKOUT_ERROR,
190
- severity: ComponentErrorSeverity.ERROR,
191
- });
192
- },
193
- });
194
175
  }
195
176
  async tokenizePaymentMethod(tokenizeArgs) {
196
177
  var _a, _b, _c;
197
- const billingInfoValues = (_b = await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues())) !== null && _b !== void 0 ? _b : {};
178
+ const billingInfoValues = (_b = (await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues()))) !== null && _b !== void 0 ? _b : {};
198
179
  const combinedBillingInfo = Object.assign(Object.assign({}, tokenizeArgs), billingInfoValues);
199
180
  const paymentMethodMetadata = Object.assign({ accountId: checkoutStore.accountId, payment_method_group_id: undefined }, combinedBillingInfo);
200
181
  if (checkoutStore.savePaymentMethod) {
201
- paymentMethodMetadata.payment_method_group_id = checkoutStore.paymentMethodGroupId;
182
+ paymentMethodMetadata.payment_method_group_id =
183
+ checkoutStore.paymentMethodGroupId;
202
184
  }
203
- return (_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
185
+ const tokenizeResult = await ((_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
204
186
  clientId: this.authToken,
205
187
  paymentMethodMetadata,
206
188
  account: checkoutStore.accountId,
207
- });
208
- }
209
- async getPaymentMethod(submitCheckoutArgs) {
210
- // If Apple Pay token is available, return a placeholder since we handle it differently
211
- if (this.applePayToken) {
212
- return 'apple_pay_token';
213
- }
214
- // If we have a payment token from the store (set by tokenize-payment-method), use it
215
- if (checkoutStore.paymentToken) {
216
- return checkoutStore.paymentToken;
217
- }
218
- // Fallback to the original tokenization logic for backward compatibility
219
- if (!this.paymentMethodFormRef) {
220
- return checkoutStore.selectedPaymentMethod;
189
+ }));
190
+ if (tokenizeResult.error) {
191
+ return tokenizeResult;
221
192
  }
222
- const { error, id: token } = await this.tokenizePaymentMethod(submitCheckoutArgs);
223
- if (error) {
224
- this.errorEvent.emit({
225
- errorCode: error.code,
226
- message: error.message,
227
- severity: ComponentErrorSeverity.ERROR,
228
- });
229
- return undefined;
230
- }
231
- return token;
193
+ checkoutStore.paymentToken = tokenizeResult.id;
194
+ return tokenizeResult.id;
195
+ }
196
+ // set the selected payment method to the checkout store from outside the component
197
+ async setSelectedPaymentMethod(paymentMethod) {
198
+ checkoutStore.selectedPaymentMethod = paymentMethod;
199
+ checkoutStore.paymentToken = paymentMethod.id || undefined;
232
200
  }
201
+ // if validation fails, the error will be emitted by the component
233
202
  async validate() {
234
- var _a, _b;
235
- // If Apple Pay token is available, validation is already complete
236
- if (this.applePayToken) {
203
+ const promises = [];
204
+ if (checkoutStore.insuranceEnabled && this.insuranceFormRef) {
205
+ promises.push(this.insuranceFormRef.validate());
206
+ }
207
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card && checkoutStore.selectedPaymentMethod.id === undefined;
208
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount && checkoutStore.selectedPaymentMethod.id === undefined;
209
+ // For new card/bank account, validate payment method + billing.
210
+ if (isNewCard ||
211
+ isNewBankAccount) {
212
+ if (this.paymentMethodFormRef)
213
+ promises.push(this.paymentMethodFormRef.validate());
214
+ if (this.billingFormRef)
215
+ promises.push(this.billingFormRef.validate());
216
+ }
217
+ if (promises.length === 0)
218
+ return true;
219
+ try {
220
+ const results = await Promise.all(promises);
221
+ // Normalize different validator return shapes:
222
+ // - boolean -> use it directly
223
+ // - object -> look for isValid; treat missing isValid as falsey only if explicitly false
224
+ const resultsAreValid = results.every(r => typeof r === 'boolean' ? r : (r === null || r === void 0 ? void 0 : r.isValid) !== false);
225
+ if (!resultsAreValid) {
226
+ this.errorEvent.emit({
227
+ message: 'Validation error',
228
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
229
+ severity: ComponentErrorSeverity.ERROR,
230
+ });
231
+ return false;
232
+ }
237
233
  return true;
238
234
  }
239
- const promises = [
240
- (_a = this.paymentMethodFormRef) === null || _a === void 0 ? void 0 : _a.validate(),
241
- (_b = this.billingFormRef) === null || _b === void 0 ? void 0 : _b.validate()
242
- ];
243
- if (this.insuranceFormRef) {
244
- promises.push(this.insuranceFormRef.validate());
235
+ catch (_a) {
236
+ // If any validator throws/rejects, consider the whole validation failed.
237
+ return false;
245
238
  }
246
- const validationResults = await Promise.all(promises);
247
- return validationResults.every(result => (result === null || result === void 0 ? void 0 : result.isValid) !== false);
248
239
  }
249
240
  async submitCheckout(submitCheckoutArgs) {
250
241
  var _a;
251
- // If Apple Pay token is available, use Apple Pay flow
252
- if (this.applePayToken) {
253
- await this.submitCheckoutWithApplePay();
254
- return;
255
- }
256
242
  const isValid = await this.validate();
257
- if (!isValid) {
258
- this.errorEvent.emit({
259
- message: 'Please fill in all required fields.',
260
- errorCode: ComponentErrorCodes.VALIDATION_ERROR,
261
- severity: ComponentErrorSeverity.ERROR,
262
- });
263
- return;
243
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card &&
244
+ checkoutStore.selectedPaymentMethod.id === undefined;
245
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount &&
246
+ checkoutStore.selectedPaymentMethod.id === undefined;
247
+ const isPlaid = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
248
+ const shouldTokenize = isNewCard || isNewBankAccount;
249
+ if (shouldTokenize) {
250
+ const tokenizeResult = await this.tokenizePaymentMethod(submitCheckoutArgs);
251
+ if (tokenizeResult === null || tokenizeResult === void 0 ? void 0 : tokenizeResult.error) {
252
+ this.errorEvent.emit({
253
+ message: tokenizeResult.error.message,
254
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
255
+ severity: ComponentErrorSeverity.ERROR,
256
+ });
257
+ return;
258
+ }
264
259
  }
265
- let payment;
266
- if (checkoutStore.selectedPaymentMethod === 'sezzle') {
267
- const insuranceValidation = this.insuranceFormRef ? await this.insuranceFormRef.validate() : { isValid: true };
268
- const sezzleResult = await this.sezzlePaymentMethodRef.resolvePaymentMethod(insuranceValidation);
269
- if (sezzleResult.error) {
260
+ // For Plaid, perform exchange at submit time using stored public token and link token id
261
+ if (isPlaid && !checkoutStore.paymentToken) {
262
+ const publicToken = checkoutStore.plaidPublicToken;
263
+ const linkTokenId = checkoutStore.plaidLinkTokenId;
264
+ if (!publicToken) {
270
265
  this.errorEvent.emit({
271
- message: sezzleResult.error.message,
266
+ message: 'Missing Plaid public token. Please connect your bank.',
272
267
  errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
273
268
  severity: ComponentErrorSeverity.ERROR,
274
269
  });
275
270
  return;
276
271
  }
277
- else if (((_a = sezzleResult.bnpl) === null || _a === void 0 ? void 0 : _a.status) === 'success') {
278
- payment = {
279
- payment_mode: 'bnpl',
280
- payment_token: undefined,
281
- };
272
+ try {
273
+ const response = await this.plaidService.tokenizeBankAccount(checkoutStore.authToken, checkoutStore.accountId, publicToken, linkTokenId || undefined, checkoutStore.savePaymentMethod ? checkoutStore.paymentMethodGroupId : undefined);
274
+ if (response === null || response === void 0 ? void 0 : response.error) {
275
+ this.errorEvent.emit({
276
+ message: typeof response.error === 'string' ? response.error : response.error.message || 'Failed to tokenize bank account',
277
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
278
+ severity: ComponentErrorSeverity.ERROR,
279
+ });
280
+ return;
281
+ }
282
+ const paymentMethod = response === null || response === void 0 ? void 0 : response.data;
283
+ 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);
284
+ checkoutStore.paymentToken = token;
282
285
  }
283
- }
284
- else {
285
- const paymentMethod = await this.getPaymentMethod(submitCheckoutArgs);
286
- if (!paymentMethod) {
286
+ catch (err) {
287
287
  this.errorEvent.emit({
288
- message: 'Payment method tokenization failed.',
288
+ message: (err === null || err === void 0 ? void 0 : err.message) || 'Plaid exchange error',
289
289
  errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
290
290
  severity: ComponentErrorSeverity.ERROR,
291
291
  });
292
292
  return;
293
293
  }
294
- ;
295
- payment = {
296
- payment_mode: 'ecom',
297
- payment_token: paymentMethod,
298
- };
299
294
  }
295
+ if (!isValid) {
296
+ this.errorEvent.emit({
297
+ message: "Please fill in all required fields.",
298
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
299
+ severity: ComponentErrorSeverity.ERROR,
300
+ });
301
+ return;
302
+ }
303
+ if (!checkoutStore.paymentToken) {
304
+ this.errorEvent.emit({
305
+ message: 'Payment token not found.',
306
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
307
+ severity: ComponentErrorSeverity.ERROR,
308
+ });
309
+ return;
310
+ }
311
+ let payment;
312
+ const mapTypeToPaymentMode = (type) => {
313
+ switch (type) {
314
+ case PaymentMethodTypes.card:
315
+ case PaymentMethodTypes.bankAccount:
316
+ case PaymentMethodTypes.plaid:
317
+ return PAYMENT_MODE.ECOM;
318
+ case PaymentMethodTypes.sezzle:
319
+ return PAYMENT_MODE.BNPL;
320
+ case PaymentMethodTypes.applePay:
321
+ return PAYMENT_MODE.APPLE_PAY;
322
+ default:
323
+ return undefined;
324
+ }
325
+ };
326
+ payment = {
327
+ payment_mode: mapTypeToPaymentMode(checkoutStore.selectedPaymentMethod.type),
328
+ payment_token: checkoutStore.paymentToken,
329
+ };
300
330
  this.completeCheckout({
301
331
  payment,
302
332
  onSuccess: ({ checkout }) => {
303
333
  this.submitEvent.emit({
304
334
  checkout,
305
- message: 'Checkout completed successfully',
335
+ message: "Checkout completed successfully",
306
336
  });
307
337
  },
308
338
  onError: (error) => {
@@ -314,11 +344,8 @@ export class ModularCheckout {
314
344
  },
315
345
  });
316
346
  }
317
- async setSelectedPaymentMethod(paymentMethodId) {
318
- checkoutStore.selectedPaymentMethod = paymentMethodId;
319
- }
320
347
  render() {
321
- return (h(Host, { key: '1b0c613494dde43962dc963618d5a81c4423b218' }));
348
+ return h(Host, { key: '2cbac33c57dd2cad327f156a4630b1dba9bf3252' });
322
349
  }
323
350
  static get is() { return "justifi-modular-checkout"; }
324
351
  static get properties() {
@@ -360,26 +387,6 @@ export class ModularCheckout {
360
387
  "getter": false,
361
388
  "setter": false,
362
389
  "reflect": false
363
- },
364
- "savePaymentMethod": {
365
- "type": "boolean",
366
- "attribute": "save-payment-method",
367
- "mutable": false,
368
- "complexType": {
369
- "original": "boolean",
370
- "resolved": "boolean",
371
- "references": {}
372
- },
373
- "required": false,
374
- "optional": true,
375
- "docs": {
376
- "tags": [],
377
- "text": ""
378
- },
379
- "getter": false,
380
- "setter": false,
381
- "reflect": false,
382
- "defaultValue": "false"
383
390
  }
384
391
  };
385
392
  }
@@ -415,8 +422,8 @@ export class ModularCheckout {
415
422
  "references": {}
416
423
  }
417
424
  }, {
418
- "method": "paymentMethodChangedEvent",
419
- "name": "payment-method-changed",
425
+ "method": "checkoutChangedEvent",
426
+ "name": "checkout-changed",
420
427
  "bubbles": true,
421
428
  "cancelable": true,
422
429
  "composed": true,
@@ -425,69 +432,95 @@ export class ModularCheckout {
425
432
  "text": ""
426
433
  },
427
434
  "complexType": {
428
- "original": "string",
429
- "resolved": "string",
430
- "references": {}
435
+ "original": "CheckoutChangedEventDetail",
436
+ "resolved": "CheckoutChangedEventDetail",
437
+ "references": {
438
+ "CheckoutChangedEventDetail": {
439
+ "location": "import",
440
+ "path": "./ModularCheckout",
441
+ "id": "src/components/modular-checkout/ModularCheckout.ts::CheckoutChangedEventDetail"
442
+ }
443
+ }
431
444
  }
432
445
  }];
433
446
  }
434
447
  static get methods() {
435
448
  return {
436
- "validate": {
449
+ "setSelectedPaymentMethod": {
437
450
  "complexType": {
438
- "signature": "() => Promise<boolean>",
439
- "parameters": [],
451
+ "signature": "(paymentMethod: ICheckoutPaymentMethod | { type: PaymentMethodTypes; }) => Promise<void>",
452
+ "parameters": [{
453
+ "name": "paymentMethod",
454
+ "type": "ICheckoutPaymentMethod | { type: PaymentMethodTypes; }",
455
+ "docs": ""
456
+ }],
440
457
  "references": {
441
458
  "Promise": {
442
459
  "location": "global",
443
460
  "id": "global::Promise"
461
+ },
462
+ "ICheckoutPaymentMethod": {
463
+ "location": "import",
464
+ "path": "../../api",
465
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
466
+ },
467
+ "PaymentMethodTypes": {
468
+ "location": "import",
469
+ "path": "../../api",
470
+ "id": "src/api/index.ts::PaymentMethodTypes"
444
471
  }
445
472
  },
446
- "return": "Promise<boolean>"
473
+ "return": "Promise<void>"
447
474
  },
448
475
  "docs": {
449
476
  "text": "",
450
477
  "tags": []
451
478
  }
452
479
  },
453
- "submitCheckout": {
480
+ "validate": {
454
481
  "complexType": {
455
- "signature": "(submitCheckoutArgs?: BillingFormFields) => Promise<void>",
456
- "parameters": [{
457
- "name": "submitCheckoutArgs",
458
- "type": "BillingFormFields",
459
- "docs": ""
460
- }],
482
+ "signature": "() => Promise<boolean>",
483
+ "parameters": [],
461
484
  "references": {
462
485
  "Promise": {
463
486
  "location": "global",
464
487
  "id": "global::Promise"
465
488
  },
466
- "BillingFormFields": {
489
+ "ICheckoutPaymentMethod": {
467
490
  "location": "import",
468
- "path": "../../components",
469
- "id": "src/components.d.ts::BillingFormFields"
491
+ "path": "../../api",
492
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
470
493
  }
471
494
  },
472
- "return": "Promise<void>"
495
+ "return": "Promise<boolean>"
473
496
  },
474
497
  "docs": {
475
498
  "text": "",
476
499
  "tags": []
477
500
  }
478
501
  },
479
- "setSelectedPaymentMethod": {
502
+ "submitCheckout": {
480
503
  "complexType": {
481
- "signature": "(paymentMethodId: string) => Promise<void>",
504
+ "signature": "(submitCheckoutArgs?: BillingFormFields) => Promise<void>",
482
505
  "parameters": [{
483
- "name": "paymentMethodId",
484
- "type": "string",
506
+ "name": "submitCheckoutArgs",
507
+ "type": "BillingFormFields",
485
508
  "docs": ""
486
509
  }],
487
510
  "references": {
488
511
  "Promise": {
489
512
  "location": "global",
490
513
  "id": "global::Promise"
514
+ },
515
+ "BillingFormFields": {
516
+ "location": "import",
517
+ "path": "../../components",
518
+ "id": "src/components.d.ts::BillingFormFields"
519
+ },
520
+ "ICheckoutPaymentMethod": {
521
+ "location": "import",
522
+ "path": "../../api",
523
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
491
524
  }
492
525
  },
493
526
  "return": "Promise<void>"
@@ -500,10 +533,4 @@ export class ModularCheckout {
500
533
  };
501
534
  }
502
535
  static get elementRef() { return "hostEl"; }
503
- static get watchers() {
504
- return [{
505
- "propName": "savePaymentMethod",
506
- "methodName": "savePaymentMethodChanged"
507
- }];
508
- }
509
536
  }