@justifi/webcomponents 6.0.0-rc.1 → 6.0.0-rc.11

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