@justifi/webcomponents 6.0.0-rc.5 → 6.0.0-rc.6

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