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

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 (465) hide show
  1. package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
  2. package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
  3. package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
  4. package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
  5. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +7 -7
  6. package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
  7. package/dist/cjs/business-details-core.cjs.entry.js +4 -4
  8. package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
  9. package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
  10. package/dist/cjs/card-form.cjs.entry.js +9 -6
  11. package/dist/cjs/{check-pkg-version-D_lazhBQ.js → check-pkg-version-DiQ-d5Nl.js} +9 -3
  12. package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
  13. package/dist/cjs/checkout.store-BGvYPPz0.js +88 -0
  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-DjMdEiEW.js} +3 -3
  17. package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
  18. package/dist/cjs/custom-popper_2.cjs.entry.js +1 -1
  19. package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
  20. package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
  21. package/dist/cjs/form-control-checkbox.cjs.entry.js +3 -3
  22. package/dist/cjs/form-control-date.cjs.entry.js +2 -2
  23. package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
  24. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +2 -2
  25. package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
  26. package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
  27. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
  28. package/dist/cjs/form-control-monetary.cjs.entry.js +4 -4
  29. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +2 -2
  30. package/dist/cjs/form-control-number.cjs.entry.js +3 -3
  31. package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
  32. package/dist/cjs/form-control-select_2.cjs.entry.js +2 -2
  33. package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
  34. package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
  35. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +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 +4 -4
  39. package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
  40. package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
  41. package/dist/cjs/index-D-dD-aC2.js +30 -0
  42. package/dist/cjs/index.cjs.js +8 -0
  43. package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
  44. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
  45. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
  46. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +1 -1
  47. package/dist/cjs/justifi-apple-pay.cjs.entry.js +782 -0
  48. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +16 -15
  49. package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
  50. package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
  51. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
  52. package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1421 -0
  53. package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
  54. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +7 -7
  55. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +13 -13
  56. package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
  57. package/dist/cjs/justifi-details.cjs.entry.js +2 -2
  58. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +1 -1
  59. package/dist/cjs/justifi-dispute-management.cjs.entry.js +9 -9
  60. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +12 -12
  61. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
  62. package/dist/cjs/justifi-order-terminals.cjs.entry.js +12 -12
  63. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
  64. package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
  65. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
  66. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
  67. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +12 -12
  68. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +5 -5
  69. package/dist/cjs/justifi-payments-list.cjs.entry.js +13 -13
  70. package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
  71. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +12 -12
  72. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +5 -5
  73. package/dist/cjs/justifi-payouts-list.cjs.entry.js +14 -14
  74. package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
  75. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +1 -1
  76. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
  77. package/dist/cjs/justifi-skeleton.cjs.entry.js +3 -3
  78. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +7 -7
  79. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +11 -11
  80. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +7 -7
  81. package/dist/cjs/justifi-terminals-list.cjs.entry.js +13 -13
  82. package/dist/cjs/loader.cjs.js +2 -2
  83. package/dist/cjs/{package-Cp_7Ls2E.js → package-Be2aoTf8.js} +1 -1
  84. package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
  85. package/dist/cjs/payment-details-core.cjs.entry.js +7 -7
  86. package/dist/cjs/payment-method-option.cjs.entry.js +2 -2
  87. package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
  88. package/dist/cjs/payments-list-core.cjs.entry.js +11 -11
  89. package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
  90. package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
  91. package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
  92. package/dist/cjs/payout-details-core.cjs.entry.js +8 -8
  93. package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
  94. package/dist/cjs/payouts-list-core.cjs.entry.js +11 -11
  95. package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
  96. package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
  97. package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
  98. package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
  99. package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
  100. package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
  101. package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
  102. package/dist/cjs/table-filters-menu.cjs.entry.js +2 -2
  103. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +10 -10
  104. package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
  105. package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
  106. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +1 -1
  107. package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
  108. package/dist/cjs/terminals-list-core.cjs.entry.js +10 -10
  109. package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
  110. package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
  111. package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
  112. package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
  113. package/dist/cjs/webcomponents.cjs.js +3 -3
  114. package/dist/collection/api/ApplePay.js +119 -0
  115. package/dist/collection/api/Payment.js +5 -2
  116. package/dist/collection/api/services/apple-pay.service.js +293 -0
  117. package/dist/collection/api/services/plaid.service.js +20 -0
  118. package/dist/collection/assets/plaid-icon.svg +1 -0
  119. package/dist/collection/collection-manifest.json +3 -1
  120. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
  121. package/dist/collection/components/checkout/card-form/card-form.js +6 -3
  122. package/dist/collection/components/checkout/checkout.js +17 -39
  123. package/dist/collection/components/checkout/save-new-payment-method.js +1 -1
  124. package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
  125. package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
  126. package/dist/collection/components/modular-checkout/modular-checkout.js +228 -125
  127. package/dist/collection/components/modular-checkout/sub-components/apple-pay-skeleton.js +10 -0
  128. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +509 -0
  129. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +885 -0
  130. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +124 -0
  131. package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
  132. package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
  133. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +63 -34
  134. package/dist/collection/index.js +1 -0
  135. package/dist/collection/store/checkout.store.js +46 -2
  136. package/dist/collection/ui-components/apple-pay-button.js +146 -0
  137. package/dist/collection/ui-components/form/form-control-radio.js +5 -5
  138. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
  139. package/dist/collection/utils/check-pkg-version.js +6 -0
  140. package/dist/collection/utils/utils.js +5 -0
  141. package/dist/docs.json +1037 -212
  142. package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
  143. package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
  144. package/dist/esm/additional-questions-details_5.entry.js +4 -4
  145. package/dist/esm/{badge-D_mzXSCQ.js → badge-DSYSJcRy.js} +2 -2
  146. package/dist/esm/bank-account-document-form-inputs_4.entry.js +8 -8
  147. package/dist/esm/bank-account-form.entry.js +10 -7
  148. package/dist/esm/business-details-core.entry.js +5 -5
  149. package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
  150. package/dist/esm/{button-CeR8qVS3.js → button-CpllL0At.js} +2 -2
  151. package/dist/esm/card-form.entry.js +10 -7
  152. package/dist/esm/{check-pkg-version-Bb69ihTN.js → check-pkg-version-CAnDiqiu.js} +9 -3
  153. package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
  154. package/dist/esm/checkout.store-CCdFOPCK.js +83 -0
  155. package/dist/esm/checkouts-list-core.entry.js +11 -11
  156. package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
  157. package/dist/esm/{checkouts-table-CFZYoYjn.js → checkouts-table-Ddf2I-Ul.js} +4 -4
  158. package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
  159. package/dist/esm/custom-popper_2.entry.js +2 -2
  160. package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
  161. package/dist/esm/form-alert_5.entry.js +2 -2
  162. package/dist/esm/form-control-checkbox.entry.js +4 -4
  163. package/dist/esm/form-control-date.entry.js +3 -3
  164. package/dist/esm/{form-control-error-text-D3ZwkOv-.js → form-control-error-text-R7U07nTg.js} +2 -2
  165. package/dist/esm/form-control-file-v2_2.entry.js +3 -3
  166. package/dist/esm/{form-control-help-text-C39ZW65w.js → form-control-help-text-CRLH-2f7.js} +2 -2
  167. package/dist/esm/form-control-help-text.entry.js +1 -1
  168. package/dist/esm/form-control-monetary-provisioning.entry.js +4 -4
  169. package/dist/esm/form-control-monetary.entry.js +5 -5
  170. package/dist/esm/form-control-number-masked_2.entry.js +3 -3
  171. package/dist/esm/form-control-number.entry.js +4 -4
  172. package/dist/esm/form-control-radio.entry.js +4 -4
  173. package/dist/esm/form-control-select_2.entry.js +3 -3
  174. package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
  175. package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
  176. package/dist/esm/gross-payment-chart-core.entry.js +5 -5
  177. package/dist/esm/{header-1-E-hEi3wF.js → header-1-3M9If0gM.js} +2 -2
  178. package/dist/esm/{header-3-Dm7M85kz.js → header-3-CWa41YWq.js} +2 -2
  179. package/dist/esm/hidden-input_2.entry.js +5 -5
  180. package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
  181. package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
  182. package/dist/esm/index-CbL73B6U.js +30 -0
  183. package/dist/esm/index.js +1 -1
  184. package/dist/esm/{insurance-state-CB4l8sOv.js → insurance-state-CTalqbNa.js} +3 -3
  185. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +8 -8
  186. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +9 -9
  187. package/dist/esm/justifi-additional-statement_8.entry.js +2 -2
  188. package/dist/esm/justifi-apple-pay.entry.js +780 -0
  189. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +17 -16
  190. package/dist/esm/justifi-business-details.entry.js +11 -11
  191. package/dist/esm/justifi-business-form.entry.js +14 -14
  192. package/dist/esm/justifi-business-representative-form-inputs.entry.js +2 -2
  193. package/dist/esm/justifi-checkout-summary_7.entry.js +1413 -0
  194. package/dist/esm/justifi-checkout.entry.js +26 -48
  195. package/dist/esm/justifi-checkouts-list-filters.entry.js +8 -8
  196. package/dist/esm/justifi-checkouts-list.entry.js +14 -14
  197. package/dist/esm/justifi-config-provider.entry.js +3 -3
  198. package/dist/esm/justifi-details.entry.js +3 -3
  199. package/dist/esm/justifi-dispute-management-core.entry.js +1 -1
  200. package/dist/esm/justifi-dispute-management.entry.js +9 -9
  201. package/dist/esm/justifi-dispute-notification_3.entry.js +13 -13
  202. package/dist/esm/justifi-gross-payment-chart.entry.js +10 -10
  203. package/dist/esm/justifi-order-terminals.entry.js +13 -13
  204. package/dist/esm/justifi-owner-form_3.entry.js +9 -9
  205. package/dist/esm/justifi-payment-details.entry.js +12 -12
  206. package/dist/esm/justifi-payment-provisioning-core.entry.js +4 -4
  207. package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
  208. package/dist/esm/justifi-payment-transactions-list.entry.js +13 -13
  209. package/dist/esm/justifi-payments-list-filters.entry.js +6 -6
  210. package/dist/esm/justifi-payments-list.entry.js +14 -14
  211. package/dist/esm/justifi-payout-details.entry.js +11 -11
  212. package/dist/esm/justifi-payout-transactions-list.entry.js +13 -13
  213. package/dist/esm/justifi-payouts-list-filters.entry.js +6 -6
  214. package/dist/esm/justifi-payouts-list.entry.js +15 -15
  215. package/dist/esm/justifi-refund-payment.entry.js +14 -14
  216. package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
  217. package/dist/esm/justifi-season-interruption-insurance.entry.js +18 -13
  218. package/dist/esm/justifi-skeleton.entry.js +4 -4
  219. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +8 -8
  220. package/dist/esm/justifi-terminal-orders-list.entry.js +12 -12
  221. package/dist/esm/justifi-terminals-list-filters.entry.js +8 -8
  222. package/dist/esm/justifi-terminals-list.entry.js +14 -14
  223. package/dist/esm/loader.js +3 -3
  224. package/dist/esm/{package-O3LY2Da6.js → package-CnWtPu8L.js} +1 -1
  225. package/dist/esm/pagination-menu.entry.js +2 -2
  226. package/dist/esm/{parts-CfF8KKwx.js → parts-RvUQ__Pq.js} +1 -1
  227. package/dist/esm/payment-details-core.entry.js +8 -8
  228. package/dist/esm/payment-method-option.entry.js +3 -3
  229. package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
  230. package/dist/esm/payments-list-core.entry.js +12 -12
  231. package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
  232. package/dist/esm/{payments-status-XoZrlbiZ.js → payments-status-5orNU2Rd.js} +2 -2
  233. package/dist/esm/{payments-table-Dh4P9mTb.js → payments-table-gkJV5GNK.js} +4 -4
  234. package/dist/esm/payout-details-core.entry.js +9 -9
  235. package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
  236. package/dist/esm/payouts-list-core.entry.js +12 -12
  237. package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
  238. package/dist/esm/{payouts-status-Qm2jZG1-.js → payouts-status-CZPwa2AE.js} +2 -2
  239. package/dist/esm/{payouts-table-DMVAZp-r.js → payouts-table-0PtktGRd.js} +4 -4
  240. package/dist/esm/{skeleton-DrHwsgs_.js → skeleton-qMb0_Cjy.js} +2 -2
  241. package/dist/esm/{spinner-XBq6mVJW.js → spinner-DUzyWLhj.js} +2 -2
  242. package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
  243. package/dist/esm/{table-qqt2Ew5y.js → table-Br3n9Xu-.js} +3 -3
  244. package/dist/esm/table-filters-menu.entry.js +3 -3
  245. package/dist/esm/terminal-orders-list-core.entry.js +11 -11
  246. package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
  247. package/dist/esm/{terminal-orders-table-BN4Co4T8.js → terminal-orders-table-DTBSIMlJ.js} +6 -6
  248. package/dist/esm/terminal-quantity-selector.entry.js +2 -2
  249. package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
  250. package/dist/esm/terminals-list-core.entry.js +11 -11
  251. package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
  252. package/dist/esm/{terminals-table-C8LczeG_.js → terminals-table-TGUKTi7I.js} +4 -4
  253. package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
  254. package/dist/esm/{utils-kWaZhFAd.js → utils-Dg6gMUTv.js} +2 -2
  255. package/dist/esm/webcomponents.js +4 -4
  256. package/dist/module/Analytics.js +6 -0
  257. package/dist/module/ModularCheckout.js +30 -0
  258. package/dist/module/Refund.js +5 -2
  259. package/dist/module/bank-account-form.js +5 -2
  260. package/dist/module/card-form.js +5 -2
  261. package/dist/module/checkout.store.js +47 -2
  262. package/dist/module/form-control-radio2.js +3 -3
  263. package/dist/module/gross-payment-chart-core2.js +1 -1
  264. package/dist/module/index.js +1 -0
  265. package/dist/module/justifi-apple-pay.d.ts +11 -0
  266. package/dist/module/justifi-apple-pay.js +811 -0
  267. package/dist/module/justifi-checkout.js +63 -75
  268. package/dist/module/justifi-order-terminals.js +1 -1
  269. package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
  270. package/dist/module/justifi-plaid-payment-method.js +6 -0
  271. package/dist/module/justifi-radio-list-item2.js +2 -2
  272. package/dist/module/justifi-season-interruption-insurance.js +5 -1
  273. package/dist/module/modular-checkout.js +179 -101
  274. package/dist/module/package.js +1 -1
  275. package/dist/module/plaid-payment-method.js +687 -0
  276. package/dist/module/save-new-payment-method.js +1 -1
  277. package/dist/module/saved-payment-methods.js +7 -5
  278. package/dist/module/sezzle-payment-method.js +14 -22
  279. package/dist/module/terminals-list-core2.js +1 -1
  280. package/dist/module/tokenize-payment-method.js +44 -34
  281. package/dist/module/utils2.js +6 -1
  282. package/dist/types/api/ApplePay.d.ts +196 -0
  283. package/dist/types/api/Checkout.d.ts +9 -14
  284. package/dist/types/api/Payment.d.ts +4 -3
  285. package/dist/types/api/services/apple-pay.service.d.ts +55 -0
  286. package/dist/types/api/services/plaid.service.d.ts +12 -0
  287. package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
  288. package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
  289. package/dist/types/components/checkout/checkout.d.ts +6 -7
  290. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
  291. package/dist/types/components/modular-checkout/modular-checkout.d.ts +13 -4
  292. package/dist/types/components/modular-checkout/sub-components/apple-pay-skeleton.d.ts +6 -0
  293. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +39 -0
  294. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +80 -0
  295. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
  296. package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
  297. package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
  298. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +7 -6
  299. package/dist/types/components.d.ts +172 -11
  300. package/dist/types/index.d.ts +2 -0
  301. package/dist/types/store/checkout.store.d.ts +14 -3
  302. package/dist/types/ui-components/apple-pay-button.d.ts +17 -0
  303. package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
  304. package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
  305. package/dist/types/utils/utils.d.ts +1 -0
  306. package/dist/webcomponents/index.esm.js +1 -0
  307. package/dist/webcomponents/p-0803d130.entry.js +1 -0
  308. package/dist/webcomponents/{p-Dvxpy_P1.js → p-0Om7jLBs.js} +1 -1
  309. package/dist/webcomponents/{p-0932f6a9.entry.js → p-117b7f47.entry.js} +1 -1
  310. package/dist/webcomponents/p-17093105.entry.js +1 -0
  311. package/dist/webcomponents/{p-f01953ea.entry.js → p-1a08b47f.entry.js} +1 -1
  312. package/dist/webcomponents/p-1bcb3852.entry.js +1 -0
  313. package/dist/webcomponents/{p-ae4297dd.entry.js → p-1eb2b847.entry.js} +1 -1
  314. package/dist/webcomponents/{p-dd257e60.entry.js → p-2f7aa249.entry.js} +1 -1
  315. package/dist/webcomponents/{p-28c7bef7.entry.js → p-2fa34c82.entry.js} +4 -4
  316. package/dist/webcomponents/{p-08ea8974.entry.js → p-33311d41.entry.js} +1 -1
  317. package/dist/webcomponents/p-336c31b3.entry.js +1 -0
  318. package/dist/webcomponents/{p-22be0859.entry.js → p-3f33c940.entry.js} +1 -1
  319. package/dist/webcomponents/{p-f3a757b2.entry.js → p-442f86e8.entry.js} +1 -1
  320. package/dist/webcomponents/{p-a8205044.entry.js → p-44450a94.entry.js} +1 -1
  321. package/dist/webcomponents/{p-cebe360b.entry.js → p-464e7a8e.entry.js} +1 -1
  322. package/dist/webcomponents/{p-ba8ae31f.entry.js → p-50392803.entry.js} +1 -1
  323. package/dist/webcomponents/p-52cbd667.entry.js +1 -0
  324. package/dist/webcomponents/{p-ded22005.entry.js → p-54ca3070.entry.js} +1 -1
  325. package/dist/webcomponents/{p-77515be6.entry.js → p-5ad0f438.entry.js} +1 -1
  326. package/dist/webcomponents/{p-6e18d13f.entry.js → p-613421d4.entry.js} +1 -1
  327. package/dist/webcomponents/{p-9b75aced.entry.js → p-62d12566.entry.js} +1 -1
  328. package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
  329. package/dist/webcomponents/p-6cf30a24.entry.js +1 -0
  330. package/dist/webcomponents/{p-48bccf3b.entry.js → p-70f51444.entry.js} +1 -1
  331. package/dist/webcomponents/{p-a4172773.entry.js → p-729dbd8f.entry.js} +1 -1
  332. package/dist/webcomponents/p-77948b46.entry.js +1 -0
  333. package/dist/webcomponents/{p-1d53f0b8.entry.js → p-7bcfaff4.entry.js} +1 -1
  334. package/dist/webcomponents/{p-b0bfa20f.entry.js → p-7cf87637.entry.js} +1 -1
  335. package/dist/webcomponents/{p-dfd7c212.entry.js → p-7dd74e6f.entry.js} +1 -1
  336. package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
  337. package/dist/webcomponents/{p-3d85d046.entry.js → p-80331983.entry.js} +1 -1
  338. package/dist/webcomponents/{p-d0e24727.entry.js → p-85f20746.entry.js} +1 -1
  339. package/dist/webcomponents/{p-79055216.entry.js → p-8687e5d6.entry.js} +1 -1
  340. package/dist/webcomponents/p-89ecd650.entry.js +1 -0
  341. package/dist/webcomponents/p-8a6718b6.entry.js +1 -0
  342. package/dist/webcomponents/p-8d6b81ba.entry.js +1 -0
  343. package/dist/webcomponents/{p-a7d5e434.entry.js → p-8d743490.entry.js} +1 -1
  344. package/dist/webcomponents/{p-8f0339de.entry.js → p-8f7396b1.entry.js} +1 -1
  345. package/dist/webcomponents/{p-15777cfe.entry.js → p-8ff839a4.entry.js} +1 -1
  346. package/dist/webcomponents/{p-57143978.entry.js → p-95cbb655.entry.js} +1 -1
  347. package/dist/webcomponents/{p-ae5a3c2a.entry.js → p-98cffba9.entry.js} +1 -1
  348. package/dist/webcomponents/{p-4ba144ac.entry.js → p-9a2c044f.entry.js} +1 -1
  349. package/dist/webcomponents/{p-904a95e5.entry.js → p-9be67b19.entry.js} +1 -1
  350. package/dist/webcomponents/{p-df199396.entry.js → p-9e8021a1.entry.js} +1 -1
  351. package/dist/webcomponents/{p-131d799c.entry.js → p-9fc0ea58.entry.js} +1 -1
  352. package/dist/webcomponents/p-9fc567d8.entry.js +1 -0
  353. package/dist/webcomponents/{p-424f491c.entry.js → p-9fcff84c.entry.js} +1 -1
  354. package/dist/webcomponents/p-B71k50jz.js +1 -0
  355. package/dist/webcomponents/p-BF4U0yVj.js +1 -0
  356. package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
  357. package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
  358. package/dist/webcomponents/p-BSt6p1oq.js +1 -0
  359. package/dist/webcomponents/p-BY1mRAvj.js +1 -0
  360. package/dist/webcomponents/{p-YND5pTuF.js → p-Bb-6bNcq.js} +1 -1
  361. package/dist/webcomponents/p-BbZwa5UI.js +1 -0
  362. package/dist/webcomponents/p-BdKWuCys.js +1 -0
  363. package/dist/webcomponents/p-BfM6X7lF.js +1 -0
  364. package/dist/webcomponents/{p-BbYVgLcf.js → p-BjVfIXWC.js} +1 -1
  365. package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
  366. package/dist/webcomponents/{p-BisQ61nK.js → p-BsGE9UDv.js} +1 -1
  367. package/dist/webcomponents/{p-BeszVz87.js → p-C5id7s_l.js} +1 -1
  368. package/dist/webcomponents/{p-CsNubTqD.js → p-CAJnQLZF.js} +1 -1
  369. package/dist/webcomponents/{p-Bz164TKZ.js → p-CB0mCq1M.js} +1 -1
  370. package/dist/webcomponents/p-CaAVuW6B.js +1 -0
  371. package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
  372. package/dist/webcomponents/p-CbL73B6U.js +1 -0
  373. package/dist/webcomponents/p-CnWtPu8L.js +1 -0
  374. package/dist/webcomponents/p-CpaS1Lex.js +1 -0
  375. package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
  376. package/dist/webcomponents/p-DDUmOl3v.js +1 -0
  377. package/dist/webcomponents/p-DIDloHpm.js +1 -0
  378. package/dist/webcomponents/p-DIjoBk44.js +1 -0
  379. package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
  380. package/dist/webcomponents/{p-DO3INvI2.js → p-DNo0OPOP.js} +1 -1
  381. package/dist/webcomponents/{p-BTkXk7ol.js → p-DRXvcLy9.js} +1 -1
  382. package/dist/webcomponents/{p-BNz6wy4f.js → p-DZYcH7jA.js} +1 -1
  383. package/dist/webcomponents/p-Da3idOSV.js +1 -0
  384. package/dist/webcomponents/p-Dgflaz6J.js +1 -0
  385. package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
  386. package/dist/webcomponents/p-DsZZxRXY.js +1 -0
  387. package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
  388. package/dist/webcomponents/p-ED_TzwCp.js +1 -0
  389. package/dist/webcomponents/p-JyHlIFWl.js +1 -0
  390. package/dist/webcomponents/{p-CfF8KKwx.js → p-RvUQ__Pq.js} +1 -1
  391. package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
  392. package/dist/webcomponents/{p-c3a2c619.entry.js → p-a55f07af.entry.js} +1 -1
  393. package/dist/webcomponents/{p-40ba49e4.entry.js → p-aa6194ef.entry.js} +1 -1
  394. package/dist/webcomponents/{p-d77908ca.entry.js → p-ab6a5dc9.entry.js} +1 -1
  395. package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
  396. package/dist/webcomponents/{p-283cd78b.entry.js → p-af9c4174.entry.js} +1 -1
  397. package/dist/webcomponents/{p-f47095cd.entry.js → p-b7d2f2eb.entry.js} +1 -1
  398. package/dist/webcomponents/p-bbc4b4cb.entry.js +1 -0
  399. package/dist/webcomponents/{p-36d72e2d.entry.js → p-c599e526.entry.js} +1 -1
  400. package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
  401. package/dist/webcomponents/{p-6849bf8e.entry.js → p-d62cd269.entry.js} +1 -1
  402. package/dist/webcomponents/{p-ff3377e7.entry.js → p-d9dd7d24.entry.js} +1 -1
  403. package/dist/webcomponents/p-dd7352da.entry.js +1 -0
  404. package/dist/webcomponents/{p-7c51805a.entry.js → p-e8a67dc7.entry.js} +1 -1
  405. package/dist/webcomponents/p-eP3fmhta.js +1 -0
  406. package/dist/webcomponents/p-eb2d9e5b.entry.js +1 -0
  407. package/dist/webcomponents/{p-1f8cd44e.entry.js → p-eddaca4e.entry.js} +1 -1
  408. package/dist/webcomponents/{p-9106fd74.entry.js → p-ef32fe0e.entry.js} +1 -1
  409. package/dist/webcomponents/{p-c5b48e8d.entry.js → p-f1cba43c.entry.js} +1 -1
  410. package/dist/webcomponents/{p-e830a580.entry.js → p-f1f0b405.entry.js} +1 -1
  411. package/dist/webcomponents/p-f499a8de.entry.js +1 -0
  412. package/dist/webcomponents/{p-828a61b9.entry.js → p-f4d0cdf0.entry.js} +1 -1
  413. package/dist/webcomponents/{p-818f51fd.entry.js → p-f680e617.entry.js} +1 -1
  414. package/dist/webcomponents/{p-bea4309d.entry.js → p-f7c4222f.entry.js} +1 -1
  415. package/dist/webcomponents/p-fa1884b4.entry.js +1 -0
  416. package/dist/webcomponents/p-sw5RO19U.js +1 -0
  417. package/dist/webcomponents/p-z-5r0gWn.js +1 -0
  418. package/dist/webcomponents/webcomponents.esm.js +1 -1
  419. package/package.json +2 -2
  420. package/dist/cjs/checkout.store-CV_fuGQw.js +0 -39
  421. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -698
  422. package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
  423. package/dist/esm/checkout.store-B60siz2l.js +0 -36
  424. package/dist/esm/justifi-checkout-summary_6.entry.js +0 -691
  425. package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
  426. package/dist/webcomponents/p-09e768fe.entry.js +0 -1
  427. package/dist/webcomponents/p-0dcc83ac.entry.js +0 -1
  428. package/dist/webcomponents/p-1bdce018.entry.js +0 -1
  429. package/dist/webcomponents/p-2f31a4e5.entry.js +0 -1
  430. package/dist/webcomponents/p-3a4ca4df.entry.js +0 -1
  431. package/dist/webcomponents/p-466f33d7.entry.js +0 -1
  432. package/dist/webcomponents/p-57802e57.entry.js +0 -1
  433. package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
  434. package/dist/webcomponents/p-7322c86e.entry.js +0 -1
  435. package/dist/webcomponents/p-7WIgS5RM.js +0 -1
  436. package/dist/webcomponents/p-89e27079.entry.js +0 -1
  437. package/dist/webcomponents/p-BC8YDY7M.js +0 -1
  438. package/dist/webcomponents/p-BVD7g3cE.js +0 -1
  439. package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
  440. package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
  441. package/dist/webcomponents/p-Bt388eye.js +0 -1
  442. package/dist/webcomponents/p-BySyDTv5.js +0 -1
  443. package/dist/webcomponents/p-C1fMfnu0.js +0 -1
  444. package/dist/webcomponents/p-CCME-fyU.js +0 -1
  445. package/dist/webcomponents/p-CLwzqWk2.js +0 -1
  446. package/dist/webcomponents/p-CVQyw7ao.js +0 -1
  447. package/dist/webcomponents/p-C_CXv7AN.js +0 -1
  448. package/dist/webcomponents/p-CwZKT93w.js +0 -1
  449. package/dist/webcomponents/p-D599ZMGU.js +0 -1
  450. package/dist/webcomponents/p-DD74a16D.js +0 -1
  451. package/dist/webcomponents/p-DaDsBt65.js +0 -1
  452. package/dist/webcomponents/p-JgbsbAhz.js +0 -1
  453. package/dist/webcomponents/p-O3LY2Da6.js +0 -1
  454. package/dist/webcomponents/p-WEguiGt1.js +0 -1
  455. package/dist/webcomponents/p-be06d86a.entry.js +0 -1
  456. package/dist/webcomponents/p-dd689b5e.entry.js +0 -1
  457. package/dist/webcomponents/p-dd6d6ddb.entry.js +0 -1
  458. package/dist/webcomponents/p-e859ece8.entry.js +0 -1
  459. package/dist/webcomponents/p-eaea7cc1.entry.js +0 -1
  460. package/dist/webcomponents/p-fa33df9f.entry.js +0 -1
  461. package/dist/webcomponents/p-ff869ded.entry.js +0 -1
  462. package/dist/webcomponents/p-pska2q1M.js +0 -1
  463. package/dist/webcomponents/p-qMrd7_Gp.js +0 -1
  464. package/dist/webcomponents/p-vRhNRfmB.js +0 -1
  465. package/dist/webcomponents/p-zrUQD0Wr.js +0 -1
@@ -0,0 +1,687 @@
1
+ import { proxyCustomElement, HTMLElement, createEvent, h } from '@stencil/core/internal/client';
2
+ import { c as checkoutStore, a as onChange } from './checkout.store.js';
3
+ import { S as StyledHost } from './styled-host.js';
4
+ import './details.js';
5
+ import './event-types.js';
6
+ import './justifi-radio-list-item2.js';
7
+ import { A as Api } from './Api.js';
8
+ import { C as ComponentErrorSeverity, P as PaymentMethodTypes } from './Refund.js';
9
+ import './Pagination.js';
10
+ import './Business.js';
11
+ import './config-state.js';
12
+ import './dinero.js';
13
+
14
+ const plaidIconSvg = '';
15
+
16
+ const api = Api();
17
+ class PlaidService {
18
+ async getLinkToken(authToken, accountId, checkoutId, signal) {
19
+ const endpoint = `plaid/${accountId}/link`;
20
+ const body = { checkout_id: checkoutId };
21
+ return api.post({ endpoint, body, authToken, signal });
22
+ }
23
+ async tokenizeBankAccount(authToken, accountId, publicToken, linkTokenId, paymentMethodGroupId, signal) {
24
+ const endpoint = `plaid/${accountId}/tokenize`;
25
+ const body = { public_token: publicToken };
26
+ if (linkTokenId) {
27
+ body.link_token_id = linkTokenId;
28
+ }
29
+ if (paymentMethodGroupId) {
30
+ body.payment_method_group_id = paymentMethodGroupId;
31
+ }
32
+ return api.post({ endpoint, body, authToken, signal });
33
+ }
34
+ }
35
+
36
+ // Plaid-specific error codes
37
+ var PlaidErrorCodes;
38
+ (function (PlaidErrorCodes) {
39
+ PlaidErrorCodes["PLAID_SDK_LOAD_FAILED"] = "plaid-sdk-load-failed";
40
+ PlaidErrorCodes["PLAID_LINK_INIT_FAILED"] = "plaid-link-init-failed";
41
+ PlaidErrorCodes["PLAID_LINK_TOKEN_FAILED"] = "plaid-link-token-failed";
42
+ PlaidErrorCodes["PLAID_AUTHENTICATION_FAILED"] = "plaid-authentication-failed";
43
+ PlaidErrorCodes["PLAID_BANK_NOT_SUPPORTED"] = "plaid-bank-not-supported";
44
+ PlaidErrorCodes["PLAID_TOKEN_EXPIRED"] = "plaid-token-expired";
45
+ PlaidErrorCodes["PLAID_NETWORK_ERROR"] = "plaid-network-error";
46
+ PlaidErrorCodes["PLAID_USER_CANCELLED"] = "plaid-user-cancelled";
47
+ PlaidErrorCodes["PLAID_TIMEOUT"] = "plaid-timeout";
48
+ PlaidErrorCodes["PLAID_INVALID_CREDENTIALS"] = "plaid-invalid-credentials";
49
+ PlaidErrorCodes["PLAID_ACCOUNT_LOCKED"] = "plaid-account-locked";
50
+ PlaidErrorCodes["PLAID_MAINTENANCE"] = "plaid-maintenance";
51
+ PlaidErrorCodes["PLAID_RATE_LIMITED"] = "plaid-rate-limited";
52
+ })(PlaidErrorCodes || (PlaidErrorCodes = {}));
53
+ // Plaid error message mapping
54
+ const PLAID_ERROR_MESSAGES = {
55
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: 'Unable to load Plaid. Please refresh the page and try again.',
56
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: 'Unable to initialize bank connection. Please try again.',
57
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: 'Unable to connect to bank service. Please try again.',
58
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: 'Bank authentication failed. Please try again.',
59
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: 'Your bank is not currently supported. Please try a different payment method.',
60
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: 'Your bank session has expired. Please reconnect your account.',
61
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: 'Network connection issue. Please check your internet connection and try again.',
62
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: 'Bank connection was cancelled. Click to try again.',
63
+ [PlaidErrorCodes.PLAID_TIMEOUT]: 'Bank connection timed out. Please try again.',
64
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: 'Invalid bank credentials. Please check your username and password.',
65
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: 'Your bank account is temporarily locked. Please contact your bank.',
66
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: 'Bank service is temporarily unavailable. Please try again later.',
67
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: 'Too many connection attempts. Please wait a moment and try again.',
68
+ };
69
+ // Plaid error severity mapping
70
+ const PLAID_ERROR_SEVERITY = {
71
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: ComponentErrorSeverity.ERROR,
72
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: ComponentErrorSeverity.ERROR,
73
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: ComponentErrorSeverity.ERROR,
74
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: ComponentErrorSeverity.ERROR,
75
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: ComponentErrorSeverity.WARNING,
76
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: ComponentErrorSeverity.WARNING,
77
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: ComponentErrorSeverity.WARNING,
78
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: ComponentErrorSeverity.INFO,
79
+ [PlaidErrorCodes.PLAID_TIMEOUT]: ComponentErrorSeverity.WARNING,
80
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: ComponentErrorSeverity.ERROR,
81
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: ComponentErrorSeverity.ERROR,
82
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: ComponentErrorSeverity.WARNING,
83
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: ComponentErrorSeverity.WARNING,
84
+ };
85
+ const PlaidPaymentMethod = /*@__PURE__*/ proxyCustomElement(class PlaidPaymentMethod extends HTMLElement {
86
+ constructor() {
87
+ super();
88
+ this.__registerHost();
89
+ this.__attachShadow();
90
+ this.paymentMethodOptionSelected = createEvent(this, "paymentMethodOptionSelected", 7);
91
+ this.plaidError = createEvent(this, "plaidError", 7);
92
+ this.plaidErrorRecovered = createEvent(this, "plaidErrorRecovered", 7);
93
+ this.isAuthenticating = false;
94
+ this.publicToken = null;
95
+ this.linkToken = null;
96
+ this.linkTokenId = null;
97
+ this.error = null;
98
+ this.plaidLink = null;
99
+ this.isSelected = false;
100
+ this.retryCount = 0;
101
+ this.isRetrying = false;
102
+ this.plaidService = new PlaidService();
103
+ this.maxRetries = 3;
104
+ this.retryDelay = 2000; // 2 seconds
105
+ this.timeoutId = null;
106
+ this.abortController = null;
107
+ this.hasLoggedDisabledWarning = false;
108
+ this.waitForStoreAndInitialize = () => {
109
+ // Check if store has necessary data
110
+ if (checkoutStore.authToken && checkoutStore.accountId && checkoutStore.checkoutId) {
111
+ this.initializePlaidLink();
112
+ }
113
+ else {
114
+ // Wait a bit and try again
115
+ setTimeout(() => {
116
+ this.waitForStoreAndInitialize();
117
+ }, 100);
118
+ }
119
+ };
120
+ this.initializePlaidLink = async () => {
121
+ try {
122
+ // Check if Plaid is available globally
123
+ if (typeof window.Plaid === 'undefined') {
124
+ this.handleError({
125
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
126
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
127
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
128
+ retryable: true,
129
+ userAction: 'Refresh the page and try again'
130
+ });
131
+ return;
132
+ }
133
+ // Get link token from backend
134
+ await this.getLinkToken();
135
+ if (!this.linkToken) {
136
+ this.handleError({
137
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
138
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
139
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
140
+ retryable: true,
141
+ userAction: 'Click to try again'
142
+ });
143
+ return;
144
+ }
145
+ // Initialize Plaid Link
146
+ const Plaid = window.Plaid;
147
+ this.plaidLink = Plaid.create({
148
+ token: this.linkToken,
149
+ onSuccess: this.handlePlaidSuccess,
150
+ onExit: this.handlePlaidExit,
151
+ onEvent: this.handlePlaidEvent,
152
+ onLoad: this.handlePlaidLoad,
153
+ });
154
+ }
155
+ catch (error) {
156
+ this.handleError({
157
+ code: PlaidErrorCodes.PLAID_LINK_INIT_FAILED,
158
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
159
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
160
+ originalError: error,
161
+ retryable: true,
162
+ userAction: 'Click to try again'
163
+ });
164
+ }
165
+ };
166
+ this.getLinkToken = async () => {
167
+ var _a, _b, _c, _d, _e;
168
+ try {
169
+ if (!checkoutStore.authToken || !checkoutStore.accountId) {
170
+ this.handleError({
171
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
172
+ message: 'Missing authentication. Please refresh the page and try again.',
173
+ severity: ComponentErrorSeverity.ERROR,
174
+ retryable: false,
175
+ userAction: 'Refresh the page'
176
+ });
177
+ return;
178
+ }
179
+ // Create abort controller for timeout handling
180
+ this.abortController = new AbortController();
181
+ // Set timeout for the request
182
+ this.timeoutId = setTimeout(() => {
183
+ var _a;
184
+ (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
185
+ }, 30000); // 30 second timeout
186
+ const response = await this.plaidService.getLinkToken(checkoutStore.authToken, checkoutStore.accountId, checkoutStore.checkoutId, this.abortController.signal);
187
+ // Clear timeout
188
+ if (this.timeoutId) {
189
+ clearTimeout(this.timeoutId);
190
+ this.timeoutId = null;
191
+ }
192
+ if (response.error) {
193
+ const errorMessage = typeof response.error === 'string'
194
+ ? response.error
195
+ : response.error.message || 'Failed to get link token';
196
+ throw new Error(errorMessage);
197
+ }
198
+ // Some backends may return an id along with the link token
199
+ this.linkToken = response.data.link_token;
200
+ // Try to capture link token id if present in envelope
201
+ 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;
202
+ }
203
+ catch (error) {
204
+ // Clear timeout
205
+ if (this.timeoutId) {
206
+ clearTimeout(this.timeoutId);
207
+ this.timeoutId = null;
208
+ }
209
+ let errorCode = PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
210
+ let message = PLAID_ERROR_MESSAGES[errorCode];
211
+ let retryable = true;
212
+ // Handle specific error types
213
+ if (error.name === 'AbortError') {
214
+ errorCode = PlaidErrorCodes.PLAID_TIMEOUT;
215
+ message = PLAID_ERROR_MESSAGES[errorCode];
216
+ retryable = true;
217
+ }
218
+ 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'))) {
219
+ errorCode = PlaidErrorCodes.PLAID_NETWORK_ERROR;
220
+ message = PLAID_ERROR_MESSAGES[errorCode];
221
+ retryable = true;
222
+ }
223
+ 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'))) {
224
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
225
+ message = 'Authentication failed. Please refresh the page and try again.';
226
+ retryable = false;
227
+ }
228
+ this.handleError({
229
+ code: errorCode,
230
+ message: message,
231
+ severity: PLAID_ERROR_SEVERITY[errorCode],
232
+ originalError: error,
233
+ retryable,
234
+ userAction: retryable ? 'Click to try again' : 'Refresh the page'
235
+ });
236
+ }
237
+ };
238
+ this.mapApiErrorToPlaidError = (apiError) => {
239
+ if (typeof apiError === 'string') {
240
+ if (apiError.includes('rate_limit'))
241
+ return PlaidErrorCodes.PLAID_RATE_LIMITED;
242
+ if (apiError.includes('maintenance'))
243
+ return PlaidErrorCodes.PLAID_MAINTENANCE;
244
+ if (apiError.includes('not_authenticated'))
245
+ return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
246
+ }
247
+ if (apiError === null || apiError === void 0 ? void 0 : apiError.code) {
248
+ switch (apiError.code) {
249
+ case 'rate_limited': return PlaidErrorCodes.PLAID_RATE_LIMITED;
250
+ case 'maintenance': return PlaidErrorCodes.PLAID_MAINTENANCE;
251
+ case 'not_authenticated': return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
252
+ case 'invalid_parameter': return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
253
+ default: return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
254
+ }
255
+ }
256
+ return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
257
+ };
258
+ this.openPlaidLink = () => {
259
+ if (this.plaidLink && this.linkToken) {
260
+ this.isAuthenticating = true;
261
+ this.clearError();
262
+ this.plaidLink.open();
263
+ }
264
+ };
265
+ this.handlePlaidSuccess = (publicToken, _metadata) => {
266
+ this.publicToken = publicToken;
267
+ this.isAuthenticating = false;
268
+ this.clearError();
269
+ this.retryCount = 0; // Reset retry count on success
270
+ // Ensure the component remains selected after successful authentication
271
+ if (!this.isSelected) {
272
+ this.isSelected = true;
273
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
274
+ }
275
+ // Emit success event for parent components
276
+ this.plaidErrorRecovered.emit({
277
+ code: 'plaid-success',
278
+ message: 'Bank account connected successfully',
279
+ severity: ComponentErrorSeverity.INFO
280
+ });
281
+ // Immediately exchange the public token for a payment method token via backend
282
+ this.exchangePublicTokenForPaymentMethod();
283
+ };
284
+ this.exchangePublicTokenForPaymentMethod = async () => {
285
+ var _a;
286
+ if (!this.publicToken) {
287
+ console.error('[PlaidPaymentMethod] exchange: missing publicToken');
288
+ return;
289
+ }
290
+ if (!checkoutStore.authToken || !checkoutStore.accountId) {
291
+ console.error('[PlaidPaymentMethod] exchange: missing auth/account context');
292
+ return;
293
+ }
294
+ try {
295
+ const response = await this.plaidService.tokenizeBankAccount(checkoutStore.authToken, checkoutStore.accountId, this.publicToken, this.linkTokenId || undefined, checkoutStore.savePaymentMethod ? checkoutStore.paymentMethodGroupId : undefined);
296
+ if (response === null || response === void 0 ? void 0 : response.error) {
297
+ console.error('[PlaidPaymentMethod] exchange: backend error', response.error);
298
+ return;
299
+ }
300
+ // Extract token from payment method response
301
+ const paymentMethod = response === null || response === void 0 ? void 0 : response.data;
302
+ 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);
303
+ if (!token) {
304
+ console.error('[PlaidPaymentMethod] exchange: no token in response');
305
+ return;
306
+ }
307
+ // Save for downstream submit flows
308
+ checkoutStore.paymentToken = token;
309
+ }
310
+ catch (err) {
311
+ console.error('[PlaidPaymentMethod] exchange: exception', {
312
+ message: (err === null || err === void 0 ? void 0 : err.message) || String(err),
313
+ });
314
+ }
315
+ };
316
+ this.handlePlaidExit = (err, _metadata) => {
317
+ this.isAuthenticating = false;
318
+ if (err) {
319
+ this.handlePlaidError(err);
320
+ }
321
+ };
322
+ this.handlePlaidEvent = (eventName, metadata) => {
323
+ // Handle specific events if needed
324
+ switch (eventName) {
325
+ case 'OPEN':
326
+ this.isAuthenticating = true;
327
+ break;
328
+ case 'CLOSE':
329
+ this.isAuthenticating = false;
330
+ break;
331
+ case 'ERROR':
332
+ this.handlePlaidError(metadata);
333
+ break;
334
+ }
335
+ };
336
+ this.handlePlaidLoad = () => {
337
+ };
338
+ this.handlePlaidError = (error) => {
339
+ let errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
340
+ let message = PLAID_ERROR_MESSAGES[errorCode];
341
+ let retryable = true;
342
+ let userAction = 'Click to try again';
343
+ // Map Plaid error codes to our error codes
344
+ if (error.error_code) {
345
+ switch (error.error_code) {
346
+ case 'INVALID_CREDENTIALS':
347
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
348
+ message = PLAID_ERROR_MESSAGES[errorCode];
349
+ retryable = true;
350
+ break;
351
+ case 'ITEM_LOGIN_REQUIRED':
352
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
353
+ message = 'Your bank requires re-authentication. Please try again.';
354
+ retryable = true;
355
+ break;
356
+ case 'ITEM_LOCKED':
357
+ errorCode = PlaidErrorCodes.PLAID_ACCOUNT_LOCKED;
358
+ message = PLAID_ERROR_MESSAGES[errorCode];
359
+ retryable = false;
360
+ userAction = 'Contact your bank';
361
+ break;
362
+ case 'INSTITUTION_NOT_RESPONDING':
363
+ errorCode = PlaidErrorCodes.PLAID_MAINTENANCE;
364
+ message = PLAID_ERROR_MESSAGES[errorCode];
365
+ retryable = true;
366
+ break;
367
+ case 'RATE_LIMIT_EXCEEDED':
368
+ errorCode = PlaidErrorCodes.PLAID_RATE_LIMITED;
369
+ message = PLAID_ERROR_MESSAGES[errorCode];
370
+ retryable = true;
371
+ break;
372
+ case 'INVALID_REQUEST':
373
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
374
+ message = 'Invalid request. Please try again.';
375
+ retryable = true;
376
+ break;
377
+ case 'PLAID_ERROR':
378
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
379
+ message = error.error_message || 'Bank authentication failed. Please try again.';
380
+ retryable = true;
381
+ break;
382
+ default:
383
+ // Use the error message from Plaid if available
384
+ if (error.error_message) {
385
+ message = error.error_message;
386
+ }
387
+ break;
388
+ }
389
+ }
390
+ // Handle specific error messages
391
+ if (error.error_message) {
392
+ const lowerMessage = error.error_message.toLowerCase();
393
+ if (lowerMessage.includes('not supported') || lowerMessage.includes('unsupported')) {
394
+ errorCode = PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED;
395
+ message = PLAID_ERROR_MESSAGES[errorCode];
396
+ retryable = false;
397
+ userAction = 'Try a different payment method';
398
+ }
399
+ else if (lowerMessage.includes('expired') || lowerMessage.includes('timeout')) {
400
+ errorCode = PlaidErrorCodes.PLAID_TOKEN_EXPIRED;
401
+ message = PLAID_ERROR_MESSAGES[errorCode];
402
+ retryable = true;
403
+ }
404
+ }
405
+ this.handleError({
406
+ code: errorCode,
407
+ message,
408
+ severity: PLAID_ERROR_SEVERITY[errorCode],
409
+ originalError: error,
410
+ retryable,
411
+ userAction
412
+ });
413
+ this.isAuthenticating = false;
414
+ };
415
+ this.handleError = (plaidError) => {
416
+ this.error = plaidError;
417
+ // Emit error event for parent components
418
+ this.plaidError.emit({
419
+ code: plaidError.code,
420
+ message: plaidError.message,
421
+ severity: plaidError.severity,
422
+ data: {
423
+ originalError: plaidError.originalError,
424
+ retryable: plaidError.retryable,
425
+ userAction: plaidError.userAction,
426
+ retryCount: this.retryCount
427
+ }
428
+ });
429
+ console.error('Plaid error:', plaidError);
430
+ // Auto-retry for retryable errors if under max retries
431
+ if (plaidError.retryable && this.retryCount < this.maxRetries) {
432
+ this.scheduleRetry();
433
+ }
434
+ };
435
+ this.scheduleRetry = () => {
436
+ if (this.isRetrying)
437
+ return;
438
+ this.isRetrying = true;
439
+ this.retryCount++;
440
+ setTimeout(() => {
441
+ this.isRetrying = false;
442
+ this.clearError();
443
+ this.waitForStoreAndInitialize();
444
+ }, this.retryDelay * this.retryCount); // Exponential backoff
445
+ };
446
+ this.clearError = () => {
447
+ if (this.error) {
448
+ this.error = null;
449
+ this.retryCount = 0;
450
+ }
451
+ };
452
+ // Watch for store changes to sync component state
453
+ this.syncWithStore = () => {
454
+ const shouldBeSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
455
+ if (this.isSelected !== shouldBeSelected) {
456
+ this.isSelected = shouldBeSelected;
457
+ }
458
+ };
459
+ }
460
+ onSelectionChange(newValue) {
461
+ // Ensure store is updated when component selection changes
462
+ if (newValue && checkoutStore.selectedPaymentMethod.type !== PaymentMethodTypes.plaid) {
463
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
464
+ }
465
+ // Auto-start Plaid flow when selected and ready
466
+ if (newValue &&
467
+ this.plaidLink &&
468
+ !this.publicToken &&
469
+ !this.isAuthenticating &&
470
+ !this.error) {
471
+ this.openPlaidLink();
472
+ }
473
+ }
474
+ componentDidRender() {
475
+ if (!this.scriptRef)
476
+ return;
477
+ this.scriptRef.onload = () => {
478
+ // Wait for store to be populated before initializing
479
+ this.waitForStoreAndInitialize();
480
+ };
481
+ // Add error handler for script loading failures
482
+ this.scriptRef.onerror = () => {
483
+ this.handleError({
484
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
485
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
486
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
487
+ retryable: true,
488
+ userAction: 'Refresh the page and try again'
489
+ });
490
+ };
491
+ }
492
+ componentWillLoad() {
493
+ // Initialize selection state based on store
494
+ this.isSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
495
+ }
496
+ async resolvePaymentMethod() {
497
+ if (!this.publicToken) {
498
+ return { validationError: true };
499
+ }
500
+ return {
501
+ token: this.publicToken,
502
+ data: {
503
+ type: 'bank_account',
504
+ plaid_public_token: this.publicToken
505
+ }
506
+ };
507
+ }
508
+ // Returns a usable payment method token for checkout completion.
509
+ // Will perform the backend exchange if the token is not yet present in the store.
510
+ async getPaymentToken() {
511
+ if (checkoutStore.paymentToken) {
512
+ return checkoutStore.paymentToken;
513
+ }
514
+ await this.exchangePublicTokenForPaymentMethod();
515
+ return checkoutStore.paymentToken;
516
+ }
517
+ async handleSelectionClick() {
518
+ // Update local selection state
519
+ this.isSelected = true;
520
+ // Update store selection
521
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
522
+ // If there's an error, clear it and try to initialize again
523
+ if (this.error) {
524
+ this.clearError();
525
+ this.waitForStoreAndInitialize();
526
+ return;
527
+ }
528
+ // If Plaid Link is ready and no public token exists, open Plaid Link
529
+ if (this.plaidLink && !this.publicToken && !this.isAuthenticating) {
530
+ this.openPlaidLink();
531
+ }
532
+ }
533
+ // Method to handle external selection changes (e.g., from other payment methods)
534
+ async setSelected(selected) {
535
+ this.isSelected = selected;
536
+ if (selected) {
537
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
538
+ }
539
+ }
540
+ // Method to check if component is currently selected
541
+ async isCurrentlySelected() {
542
+ return this.isSelected;
543
+ }
544
+ // Method to handle external deselection (when another payment method is selected)
545
+ async deselect() {
546
+ this.isSelected = false;
547
+ // Don't clear the public token or error state as they might be needed if user reselects
548
+ }
549
+ // Method to reset component state (useful for testing or error recovery)
550
+ async reset() {
551
+ this.publicToken = null;
552
+ this.clearError();
553
+ this.isAuthenticating = false;
554
+ this.linkToken = null;
555
+ this.plaidLink = null;
556
+ this.retryCount = 0;
557
+ this.isRetrying = false;
558
+ // Clear any pending timeouts
559
+ if (this.timeoutId) {
560
+ clearTimeout(this.timeoutId);
561
+ this.timeoutId = null;
562
+ }
563
+ // Abort any pending requests
564
+ if (this.abortController) {
565
+ this.abortController.abort();
566
+ this.abortController = null;
567
+ }
568
+ }
569
+ // Method to check if component is ready for authentication
570
+ async isReadyForAuthentication() {
571
+ return !!(this.plaidLink && this.linkToken && !this.isAuthenticating);
572
+ }
573
+ // Method to manually retry after an error
574
+ async retry() {
575
+ if (this.error && this.error.retryable) {
576
+ this.clearError();
577
+ this.waitForStoreAndInitialize();
578
+ }
579
+ }
580
+ // Method to get current error information
581
+ async getErrorInfo() {
582
+ return this.error;
583
+ }
584
+ componentDidLoad() {
585
+ // Set up store change listener to keep component in sync
586
+ const unsubscribe = onChange('selectedPaymentMethod', this.syncWithStore);
587
+ // Store unsubscribe function for cleanup
588
+ this.unsubscribeFromStore = unsubscribe;
589
+ }
590
+ disconnectedCallback() {
591
+ // Clean up store subscription
592
+ if (this.unsubscribeFromStore) {
593
+ this.unsubscribeFromStore();
594
+ }
595
+ // Clean up timeouts and abort controllers
596
+ if (this.timeoutId) {
597
+ clearTimeout(this.timeoutId);
598
+ }
599
+ if (this.abortController) {
600
+ this.abortController.abort();
601
+ }
602
+ }
603
+ render() {
604
+ // Only allow use if enabled in checkout settings
605
+ if (checkoutStore.bankAccountVerification !== true) {
606
+ if (!this.hasLoggedDisabledWarning) {
607
+ // Log once per component lifecycle
608
+ console.warn('[PlaidPaymentMethod] bank_account_verification is disabled. Component will not render.');
609
+ this.hasLoggedDisabledWarning = true;
610
+ }
611
+ return null;
612
+ }
613
+ const plaidLogo = (h("img", { class: "plaid-logo-img", src: plaidIconSvg, alt: "Plaid", title: "Plaid", style: {
614
+ display: 'inline',
615
+ width: '20px',
616
+ height: '20px',
617
+ marginLeft: '5px',
618
+ marginTop: '-2px',
619
+ } }));
620
+ const renderErrorState = () => {
621
+ if (!this.error)
622
+ return null;
623
+ const errorClass = this.error.severity === ComponentErrorSeverity.ERROR
624
+ ? 'text-danger'
625
+ : this.error.severity === ComponentErrorSeverity.WARNING
626
+ ? 'text-warning'
627
+ : 'text-info';
628
+ return (h("div", { class: `${errorClass} mt-2` }, h("small", null, this.error.message), h("br", null), h("small", { class: "text-muted" }, this.error.userAction, this.error.retryable && this.retryCount < this.maxRetries && (h("span", null, " \u2022 Auto-retry in progress...")))));
629
+ };
630
+ const renderStatusState = () => {
631
+ if (this.error)
632
+ return null;
633
+ if (this.isAuthenticating) {
634
+ return (h("div", { class: "text-info mt-2" }, h("small", null, "Connecting to your bank...")));
635
+ }
636
+ if (this.publicToken) {
637
+ return (h("div", { class: "text-success mt-2" }, h("small", null, "\u2713 Bank account connected successfully")));
638
+ }
639
+ if (this.isSelected && !this.publicToken && !this.error && !this.isAuthenticating) {
640
+ return (h("div", { class: "text-muted mt-2" }, h("small", null, "Click to connect your bank account")));
641
+ }
642
+ return null;
643
+ };
644
+ return (h(StyledHost, { class: "payment-method" }, h("script", { src: "https://cdn.plaid.com/link/v2/stable/link-initialize.js", async: true, ref: (el) => (this.scriptRef = el) }), h("div", { title: "Pay with Plaid" }, h("div", { onClick: (event) => { event.preventDefault(); this.handleSelectionClick(); } }, "Pay with Bank Account ", plaidLogo, " "), renderErrorState(), renderStatusState())));
645
+ }
646
+ static get watchers() { return {
647
+ "isSelected": ["onSelectionChange"]
648
+ }; }
649
+ }, [257, "justifi-plaid-payment-method", {
650
+ "isAuthenticating": [32],
651
+ "publicToken": [32],
652
+ "linkToken": [32],
653
+ "linkTokenId": [32],
654
+ "error": [32],
655
+ "plaidLink": [32],
656
+ "isSelected": [32],
657
+ "retryCount": [32],
658
+ "isRetrying": [32],
659
+ "resolvePaymentMethod": [64],
660
+ "getPaymentToken": [64],
661
+ "handleSelectionClick": [64],
662
+ "setSelected": [64],
663
+ "isCurrentlySelected": [64],
664
+ "deselect": [64],
665
+ "reset": [64],
666
+ "isReadyForAuthentication": [64],
667
+ "retry": [64],
668
+ "getErrorInfo": [64]
669
+ }, undefined, {
670
+ "isSelected": ["onSelectionChange"]
671
+ }]);
672
+ function defineCustomElement() {
673
+ if (typeof customElements === "undefined") {
674
+ return;
675
+ }
676
+ const components = ["justifi-plaid-payment-method"];
677
+ components.forEach(tagName => { switch (tagName) {
678
+ case "justifi-plaid-payment-method":
679
+ if (!customElements.get(tagName)) {
680
+ customElements.define(tagName, PlaidPaymentMethod);
681
+ }
682
+ break;
683
+ } });
684
+ }
685
+ defineCustomElement();
686
+
687
+ export { PlaidPaymentMethod as P, defineCustomElement as d };