@justifi/webcomponents 6.0.0-rc.2 → 6.0.0-rc.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (600) hide show
  1. package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
  2. package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
  3. package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
  4. package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
  5. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +9 -9
  6. package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
  7. package/dist/cjs/business-details-core.cjs.entry.js +4 -4
  8. package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
  9. package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
  10. package/dist/cjs/card-form.cjs.entry.js +9 -6
  11. package/dist/cjs/{check-pkg-version-BfmeLSXP.js → check-pkg-version-DS_8EVX4.js} +9 -3
  12. package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
  13. package/dist/cjs/checkout.store-DJEc-So8.js +91 -0
  14. package/dist/cjs/checkouts-list-core.cjs.entry.js +11 -11
  15. package/dist/cjs/{payments-list-params-state-BNbT1fuJ.js → checkouts-list-params-state-Cewmin_p.js} +1 -1
  16. package/dist/cjs/{checkouts-table-UN5gPpQ_.js → checkouts-table-DjMdEiEW.js} +3 -3
  17. package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
  18. package/dist/cjs/custom-popper_2.cjs.entry.js +3 -3
  19. package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
  20. package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
  21. package/dist/cjs/form-control-checkbox.cjs.entry.js +5 -5
  22. package/dist/cjs/form-control-date.cjs.entry.js +4 -4
  23. package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
  24. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +5 -5
  25. package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
  26. package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
  27. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
  28. package/dist/cjs/form-control-monetary.cjs.entry.js +6 -6
  29. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +4 -4
  30. package/dist/cjs/form-control-number.cjs.entry.js +5 -5
  31. package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
  32. package/dist/cjs/form-control-select_2.cjs.entry.js +6 -6
  33. package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
  34. package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
  35. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +5 -5
  36. package/dist/cjs/{header-1-DD41iNlG.js → header-1-DRA3f4Jh.js} +1 -1
  37. package/dist/cjs/{header-3-D9Wa0IfT.js → header-3-sOdOpfx3.js} +1 -1
  38. package/dist/cjs/hidden-input_2.cjs.entry.js +8 -8
  39. package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
  40. package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
  41. package/dist/cjs/index-D-dD-aC2.js +30 -0
  42. package/dist/cjs/index.cjs.js +8 -0
  43. package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
  44. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
  45. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
  46. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +9 -9
  47. package/dist/cjs/justifi-apple-pay.cjs.entry.js +189 -150
  48. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +24 -22
  49. package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
  50. package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
  51. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
  52. package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1422 -0
  53. package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
  54. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +8 -8
  55. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +14 -14
  56. package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
  57. package/dist/cjs/justifi-details.cjs.entry.js +2 -2
  58. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +2 -2
  59. package/dist/cjs/justifi-dispute-management.cjs.entry.js +10 -10
  60. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +15 -15
  61. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
  62. package/dist/cjs/justifi-order-terminals.cjs.entry.js +13 -13
  63. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
  64. package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
  65. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
  66. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
  67. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +13 -13
  68. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +7 -7
  69. package/dist/cjs/justifi-payments-list.cjs.entry.js +14 -14
  70. package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
  71. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +13 -13
  72. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +7 -7
  73. package/dist/cjs/justifi-payouts-list.cjs.entry.js +15 -15
  74. package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
  75. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +2 -2
  76. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
  77. package/dist/cjs/justifi-skeleton.cjs.entry.js +4 -4
  78. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +9 -9
  79. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +12 -12
  80. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +8 -8
  81. package/dist/cjs/justifi-terminals-list.cjs.entry.js +14 -14
  82. package/dist/cjs/loader.cjs.js +2 -2
  83. package/dist/cjs/{package-CuNDvHTB.js → package-XG0rW7xm.js} +1 -1
  84. package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
  85. package/dist/cjs/payment-details-core.cjs.entry.js +15 -15
  86. package/dist/cjs/payment-method-option.cjs.entry.js +3 -3
  87. package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
  88. package/dist/cjs/payments-list-core.cjs.entry.js +12 -12
  89. package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
  90. package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
  91. package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
  92. package/dist/cjs/payout-details-core.cjs.entry.js +11 -11
  93. package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
  94. package/dist/cjs/payouts-list-core.cjs.entry.js +12 -12
  95. package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
  96. package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
  97. package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
  98. package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
  99. package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
  100. package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
  101. package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
  102. package/dist/cjs/table-filters-menu.cjs.entry.js +3 -3
  103. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +11 -11
  104. package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
  105. package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
  106. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +2 -2
  107. package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
  108. package/dist/cjs/terminals-list-core.cjs.entry.js +11 -11
  109. package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
  110. package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
  111. package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
  112. package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
  113. package/dist/cjs/webcomponents.cjs.js +3 -3
  114. package/dist/collection/api/Payment.js +5 -2
  115. package/dist/collection/api/index.js +1 -2
  116. package/dist/collection/api/services/apple-pay.service.js +112 -70
  117. package/dist/collection/api/services/plaid.service.js +20 -0
  118. package/dist/collection/assets/plaid-icon.svg +1 -0
  119. package/dist/collection/collection-manifest.json +3 -2
  120. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
  121. package/dist/collection/components/checkout/card-form/card-form.js +6 -3
  122. package/dist/collection/components/checkout/checkout.js +17 -39
  123. package/dist/collection/components/checkout/save-new-payment-method.js +26 -1
  124. package/dist/collection/components/checkout/saved-payment-method.js +1 -1
  125. package/dist/collection/components/checkouts-list/checkouts-list-core.js +1 -1
  126. package/dist/collection/components/checkouts-list/checkouts-list-filters.js +1 -1
  127. package/dist/collection/components/checkouts-list/checkouts-list.js +1 -1
  128. package/dist/collection/components/dispute-management/dispute-management-core.js +1 -1
  129. package/dist/collection/components/dispute-management/dispute-management.js +1 -1
  130. package/dist/collection/components/dispute-management/dispute-notification.js +1 -1
  131. package/dist/collection/components/dispute-management/dispute-response/additional-statement.js +1 -1
  132. package/dist/collection/components/dispute-management/dispute-response/cancellation-policy.js +1 -1
  133. package/dist/collection/components/dispute-management/dispute-response/customer-details.js +1 -1
  134. package/dist/collection/components/dispute-management/dispute-response/dispute-response-core.js +1 -1
  135. package/dist/collection/components/dispute-management/dispute-response/dispute-response.js +1 -1
  136. package/dist/collection/components/dispute-management/dispute-response/duplicate-charge.js +1 -1
  137. package/dist/collection/components/dispute-management/dispute-response/electronic-evidence.js +1 -1
  138. package/dist/collection/components/dispute-management/dispute-response/product-or-service.js +1 -1
  139. package/dist/collection/components/dispute-management/dispute-response/refund-policy.js +1 -1
  140. package/dist/collection/components/dispute-management/dispute-response/shipping-details.js +1 -1
  141. package/dist/collection/components/filters/table-filters-menu.js +1 -1
  142. package/dist/collection/components/gross-payment-chart/gross-payment-chart-core.js +1 -1
  143. package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
  144. package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
  145. package/dist/collection/components/modular-checkout/modular-checkout.js +233 -206
  146. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +65 -110
  147. package/dist/collection/components/modular-checkout/sub-components/bank-account-billing-form-simple.js +1 -1
  148. package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
  149. package/dist/collection/components/modular-checkout/sub-components/card-billing-form-simple.js +1 -1
  150. package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
  151. package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
  152. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +853 -0
  153. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +125 -0
  154. package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
  155. package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
  156. package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
  157. package/dist/collection/components/order-terminals/order-terminals.js +1 -1
  158. package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
  159. package/dist/collection/components/payment-details/payment-details-core.js +8 -8
  160. package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
  161. package/dist/collection/components/payments-list/payments-list-core.js +1 -1
  162. package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
  163. package/dist/collection/components/payments-list/payments-list.js +1 -1
  164. package/dist/collection/components/payout-details/payout-details-core.js +3 -3
  165. package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
  166. package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
  167. package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
  168. package/dist/collection/components/payouts-list/payouts-list.js +1 -1
  169. package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
  170. package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
  171. package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
  172. package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
  173. package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
  174. package/dist/collection/components/terminals-list/terminals-list.js +1 -1
  175. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +82 -34
  176. package/dist/collection/index.js +1 -0
  177. package/dist/collection/store/checkout.store.js +48 -2
  178. package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
  179. package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
  180. package/dist/collection/ui-components/form/form-control-date.js +2 -2
  181. package/dist/collection/ui-components/form/form-control-file-v2.js +1 -1
  182. package/dist/collection/ui-components/form/form-control-file.js +2 -2
  183. package/dist/collection/ui-components/form/form-control-monetary.js +2 -2
  184. package/dist/collection/ui-components/form/form-control-number-masked.js +2 -2
  185. package/dist/collection/ui-components/form/form-control-number.js +2 -2
  186. package/dist/collection/ui-components/form/form-control-radio.js +5 -5
  187. package/dist/collection/ui-components/form/form-control-select.js +2 -2
  188. package/dist/collection/ui-components/form/form-control-text.js +2 -2
  189. package/dist/collection/ui-components/form/form-control-textarea.js +2 -2
  190. package/dist/collection/ui-components/form/hidden-input.js +1 -1
  191. package/dist/collection/ui-components/form/iframe-input.js +3 -3
  192. package/dist/collection/ui-components/shadow-dom-components/justifi-button.js +1 -1
  193. package/dist/collection/ui-components/shadow-dom-components/justifi-header.js +1 -1
  194. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
  195. package/dist/collection/ui-components/shadow-dom-components/justifi-skeleton.js +1 -1
  196. package/dist/collection/utils/check-pkg-version.js +6 -0
  197. package/dist/collection/utils/utils.js +5 -0
  198. package/dist/docs.json +492 -105
  199. package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
  200. package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
  201. package/dist/esm/additional-questions-details_5.entry.js +3 -3
  202. package/dist/esm/{badge-D4ZXPFjL.js → badge-DSYSJcRy.js} +1 -1
  203. package/dist/esm/bank-account-document-form-inputs_4.entry.js +9 -9
  204. package/dist/esm/bank-account-form.entry.js +9 -6
  205. package/dist/esm/business-details-core.entry.js +4 -4
  206. package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
  207. package/dist/esm/{button-C0wLsDP3.js → button-CpllL0At.js} +1 -1
  208. package/dist/esm/card-form.entry.js +9 -6
  209. package/dist/esm/{check-pkg-version-BuYkk-jV.js → check-pkg-version-DhRpS7Qc.js} +9 -3
  210. package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
  211. package/dist/esm/checkout.store-OD-OX5On.js +86 -0
  212. package/dist/esm/checkouts-list-core.entry.js +11 -11
  213. package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
  214. package/dist/esm/{checkouts-table-DjGKtqoc.js → checkouts-table-Ddf2I-Ul.js} +3 -3
  215. package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
  216. package/dist/esm/custom-popper_2.entry.js +3 -3
  217. package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
  218. package/dist/esm/form-alert_5.entry.js +1 -1
  219. package/dist/esm/form-control-checkbox.entry.js +5 -5
  220. package/dist/esm/form-control-date.entry.js +4 -4
  221. package/dist/esm/{form-control-error-text-Bzfs_rxk.js → form-control-error-text-R7U07nTg.js} +1 -1
  222. package/dist/esm/form-control-file-v2_2.entry.js +5 -5
  223. package/dist/esm/{form-control-help-text-ueLctOBN.js → form-control-help-text-CRLH-2f7.js} +1 -1
  224. package/dist/esm/form-control-help-text.entry.js +1 -1
  225. package/dist/esm/form-control-monetary-provisioning.entry.js +3 -3
  226. package/dist/esm/form-control-monetary.entry.js +6 -6
  227. package/dist/esm/form-control-number-masked_2.entry.js +4 -4
  228. package/dist/esm/form-control-number.entry.js +5 -5
  229. package/dist/esm/form-control-radio.entry.js +3 -3
  230. package/dist/esm/form-control-select_2.entry.js +6 -6
  231. package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
  232. package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
  233. package/dist/esm/gross-payment-chart-core.entry.js +5 -5
  234. package/dist/esm/{header-1-BMKEv9y6.js → header-1-3M9If0gM.js} +1 -1
  235. package/dist/esm/{header-3-C3t3m27b.js → header-3-CWa41YWq.js} +1 -1
  236. package/dist/esm/hidden-input_2.entry.js +8 -8
  237. package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
  238. package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
  239. package/dist/esm/index-CbL73B6U.js +30 -0
  240. package/dist/esm/index.js +1 -1
  241. package/dist/esm/{insurance-state-d4hjThzE.js → insurance-state-CTalqbNa.js} +2 -2
  242. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +7 -7
  243. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +8 -8
  244. package/dist/esm/justifi-additional-statement_8.entry.js +9 -9
  245. package/dist/esm/justifi-apple-pay.entry.js +189 -150
  246. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +24 -22
  247. package/dist/esm/justifi-business-details.entry.js +10 -10
  248. package/dist/esm/justifi-business-form.entry.js +13 -13
  249. package/dist/esm/justifi-business-representative-form-inputs.entry.js +1 -1
  250. package/dist/esm/justifi-checkout-summary_7.entry.js +1414 -0
  251. package/dist/esm/justifi-checkout.entry.js +26 -48
  252. package/dist/esm/justifi-checkouts-list-filters.entry.js +8 -8
  253. package/dist/esm/justifi-checkouts-list.entry.js +14 -14
  254. package/dist/esm/justifi-config-provider.entry.js +3 -3
  255. package/dist/esm/justifi-details.entry.js +2 -2
  256. package/dist/esm/justifi-dispute-management-core.entry.js +2 -2
  257. package/dist/esm/justifi-dispute-management.entry.js +10 -10
  258. package/dist/esm/justifi-dispute-notification_3.entry.js +15 -15
  259. package/dist/esm/justifi-gross-payment-chart.entry.js +9 -9
  260. package/dist/esm/justifi-order-terminals.entry.js +13 -13
  261. package/dist/esm/justifi-owner-form_3.entry.js +8 -8
  262. package/dist/esm/justifi-payment-details.entry.js +11 -11
  263. package/dist/esm/justifi-payment-provisioning-core.entry.js +3 -3
  264. package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
  265. package/dist/esm/justifi-payment-transactions-list.entry.js +13 -13
  266. package/dist/esm/justifi-payments-list-filters.entry.js +7 -7
  267. package/dist/esm/justifi-payments-list.entry.js +14 -14
  268. package/dist/esm/justifi-payout-details.entry.js +10 -10
  269. package/dist/esm/justifi-payout-transactions-list.entry.js +13 -13
  270. package/dist/esm/justifi-payouts-list-filters.entry.js +7 -7
  271. package/dist/esm/justifi-payouts-list.entry.js +15 -15
  272. package/dist/esm/justifi-refund-payment.entry.js +13 -13
  273. package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
  274. package/dist/esm/justifi-season-interruption-insurance.entry.js +17 -12
  275. package/dist/esm/justifi-skeleton.entry.js +4 -4
  276. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +9 -9
  277. package/dist/esm/justifi-terminal-orders-list.entry.js +12 -12
  278. package/dist/esm/justifi-terminals-list-filters.entry.js +8 -8
  279. package/dist/esm/justifi-terminals-list.entry.js +14 -14
  280. package/dist/esm/loader.js +3 -3
  281. package/dist/esm/{package-C60pS6qh.js → package-BF0mIfcQ.js} +1 -1
  282. package/dist/esm/pagination-menu.entry.js +1 -1
  283. package/dist/esm/payment-details-core.entry.js +15 -15
  284. package/dist/esm/payment-method-option.entry.js +3 -3
  285. package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
  286. package/dist/esm/payments-list-core.entry.js +12 -12
  287. package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
  288. package/dist/esm/{payments-status-1yRdTNeS.js → payments-status-5orNU2Rd.js} +2 -2
  289. package/dist/esm/{payments-table-8RADYkma.js → payments-table-gkJV5GNK.js} +3 -3
  290. package/dist/esm/payout-details-core.entry.js +11 -11
  291. package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
  292. package/dist/esm/payouts-list-core.entry.js +12 -12
  293. package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
  294. package/dist/esm/{payouts-status-BqsQVtBp.js → payouts-status-CZPwa2AE.js} +2 -2
  295. package/dist/esm/{payouts-table-DPw7yIx8.js → payouts-table-0PtktGRd.js} +3 -3
  296. package/dist/esm/{skeleton-BmTjpTYa.js → skeleton-qMb0_Cjy.js} +1 -1
  297. package/dist/esm/{spinner-YGDOI-CS.js → spinner-DUzyWLhj.js} +1 -1
  298. package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
  299. package/dist/esm/{table-ybHxxc9f.js → table-Br3n9Xu-.js} +2 -2
  300. package/dist/esm/table-filters-menu.entry.js +3 -3
  301. package/dist/esm/terminal-orders-list-core.entry.js +11 -11
  302. package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
  303. package/dist/esm/{terminal-orders-table-D-xP5WuM.js → terminal-orders-table-DTBSIMlJ.js} +5 -5
  304. package/dist/esm/terminal-quantity-selector.entry.js +2 -2
  305. package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
  306. package/dist/esm/terminals-list-core.entry.js +11 -11
  307. package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
  308. package/dist/esm/{terminals-table-DVAPCgEr.js → terminals-table-TGUKTi7I.js} +3 -3
  309. package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
  310. package/dist/esm/{utils-DG5aMFmf.js → utils-Dg6gMUTv.js} +1 -1
  311. package/dist/esm/webcomponents.js +4 -4
  312. package/dist/module/Analytics.js +6 -0
  313. package/dist/module/ModularCheckout.js +30 -0
  314. package/dist/module/Refund.js +5 -2
  315. package/dist/module/additional-statement.js +1 -1
  316. package/dist/module/bank-account-billing-form-simple.js +1 -1
  317. package/dist/module/bank-account-form.js +5 -2
  318. package/dist/module/bank-account.js +2 -2
  319. package/dist/module/cancellation-policy.js +1 -1
  320. package/dist/module/card-billing-form-simple.js +1 -1
  321. package/dist/module/card-form.js +5 -2
  322. package/dist/module/card-form2.js +2 -2
  323. package/dist/module/checkout.store.js +49 -2
  324. package/dist/module/checkouts-list-core2.js +1 -1
  325. package/dist/module/custom-popper2.js +2 -2
  326. package/dist/module/customer-details.js +1 -1
  327. package/dist/module/dispute-management-core.js +1 -1
  328. package/dist/module/dispute-notification.js +1 -1
  329. package/dist/module/dispute-response-core.js +1 -1
  330. package/dist/module/dispute-response.js +1 -1
  331. package/dist/module/duplicate-charge.js +1 -1
  332. package/dist/module/electronic-evidence.js +1 -1
  333. package/dist/module/form-control-checkbox2.js +2 -2
  334. package/dist/module/form-control-date2.js +2 -2
  335. package/dist/module/form-control-file-v22.js +1 -1
  336. package/dist/module/form-control-file2.js +2 -2
  337. package/dist/module/form-control-monetary2.js +2 -2
  338. package/dist/module/form-control-number-masked2.js +2 -2
  339. package/dist/module/form-control-number.js +2 -2
  340. package/dist/module/form-control-radio2.js +3 -3
  341. package/dist/module/form-control-select2.js +2 -2
  342. package/dist/module/form-control-text2.js +2 -2
  343. package/dist/module/form-control-textarea2.js +2 -2
  344. package/dist/module/gross-payment-chart-core2.js +2 -2
  345. package/dist/module/hidden-input2.js +1 -1
  346. package/dist/module/iframe-input2.js +3 -3
  347. package/dist/module/index.js +1 -0
  348. package/dist/module/justifi-apple-pay.js +175 -153
  349. package/dist/module/justifi-button2.js +1 -1
  350. package/dist/module/justifi-checkout.js +63 -75
  351. package/dist/module/justifi-checkouts-list-filters.js +1 -1
  352. package/dist/module/justifi-checkouts-list.js +1 -1
  353. package/dist/module/justifi-dispute-management.js +1 -1
  354. package/dist/module/justifi-header2.js +1 -1
  355. package/dist/module/justifi-order-terminals.js +2 -2
  356. package/dist/module/justifi-payment-transactions-list.js +1 -1
  357. package/dist/module/justifi-payments-list-filters.js +2 -2
  358. package/dist/module/justifi-payments-list.js +1 -1
  359. package/dist/module/justifi-payout-transactions-list.js +1 -1
  360. package/dist/module/justifi-payouts-list-filters.js +2 -2
  361. package/dist/module/justifi-payouts-list.js +1 -1
  362. package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
  363. package/dist/module/justifi-plaid-payment-method.js +6 -0
  364. package/dist/module/justifi-radio-list-item2.js +2 -2
  365. package/dist/module/justifi-saved-payment-method.js +1 -1
  366. package/dist/module/justifi-season-interruption-insurance.js +5 -1
  367. package/dist/module/justifi-skeleton.js +1 -1
  368. package/dist/module/justifi-terminal-orders-list-filters.js +2 -2
  369. package/dist/module/justifi-terminal-orders-list.js +1 -1
  370. package/dist/module/justifi-terminals-list-filters.js +1 -1
  371. package/dist/module/justifi-terminals-list.js +1 -1
  372. package/dist/module/modular-checkout.js +184 -162
  373. package/dist/module/package.js +1 -1
  374. package/dist/module/payment-details-core2.js +8 -8
  375. package/dist/module/payment-method-option.js +1 -1
  376. package/dist/module/payments-list-core2.js +1 -1
  377. package/dist/module/payout-details-core2.js +3 -3
  378. package/dist/module/payouts-list-core2.js +1 -1
  379. package/dist/module/plaid-payment-method.js +635 -0
  380. package/dist/module/plaid.service.js +26 -0
  381. package/dist/module/product-or-service.js +1 -1
  382. package/dist/module/refund-policy.js +1 -1
  383. package/dist/module/save-new-payment-method.js +3 -1
  384. package/dist/module/saved-payment-methods.js +7 -5
  385. package/dist/module/sezzle-payment-method.js +14 -22
  386. package/dist/module/shipping-details.js +1 -1
  387. package/dist/module/summary.js +1 -1
  388. package/dist/module/table-filters-menu2.js +1 -1
  389. package/dist/module/terminal-orders-list-core2.js +1 -1
  390. package/dist/module/terminal-quantity-selector2.js +1 -1
  391. package/dist/module/terminals-list-core2.js +2 -2
  392. package/dist/module/tokenize-payment-method.js +45 -34
  393. package/dist/module/utils2.js +6 -1
  394. package/dist/types/api/ApplePay.d.ts +2 -2
  395. package/dist/types/api/Checkout.d.ts +9 -14
  396. package/dist/types/api/Payment.d.ts +4 -3
  397. package/dist/types/api/index.d.ts +2 -2
  398. package/dist/types/api/services/apple-pay.service.d.ts +5 -15
  399. package/dist/types/api/services/plaid.service.d.ts +12 -0
  400. package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
  401. package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
  402. package/dist/types/components/checkout/checkout.d.ts +6 -7
  403. package/dist/types/components/checkout/save-new-payment-method.d.ts +1 -0
  404. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
  405. package/dist/types/components/modular-checkout/modular-checkout.d.ts +8 -8
  406. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +2 -4
  407. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +79 -0
  408. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
  409. package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
  410. package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
  411. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +8 -6
  412. package/dist/types/components.d.ts +70 -27
  413. package/dist/types/index.d.ts +3 -0
  414. package/dist/types/store/checkout.store.d.ts +16 -3
  415. package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
  416. package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
  417. package/dist/types/utils/utils.d.ts +1 -0
  418. package/dist/webcomponents/index.esm.js +1 -0
  419. package/dist/webcomponents/p-054193e4.entry.js +1 -0
  420. package/dist/webcomponents/{p-BhdBpAn9.js → p-0Om7jLBs.js} +1 -1
  421. package/dist/webcomponents/p-0e80830f.entry.js +1 -0
  422. package/dist/webcomponents/{p-0aa78c58.entry.js → p-12175e07.entry.js} +1 -1
  423. package/dist/webcomponents/{p-fbaf62a5.entry.js → p-13c21c47.entry.js} +1 -1
  424. package/dist/webcomponents/p-20733148.entry.js +1 -0
  425. package/dist/webcomponents/{p-4a79c737.entry.js → p-225ed545.entry.js} +1 -1
  426. package/dist/webcomponents/p-2550e845.entry.js +1 -0
  427. package/dist/webcomponents/p-2ae3613e.entry.js +1 -0
  428. package/dist/webcomponents/{p-bfc38bc2.entry.js → p-319b4126.entry.js} +1 -1
  429. package/dist/webcomponents/{p-08a5cc2f.entry.js → p-431ba789.entry.js} +1 -1
  430. package/dist/webcomponents/{p-4c994761.entry.js → p-44450a94.entry.js} +1 -1
  431. package/dist/webcomponents/p-45e8185c.entry.js +1 -0
  432. package/dist/webcomponents/{p-dc245644.entry.js → p-46b6142b.entry.js} +4 -4
  433. package/dist/webcomponents/p-4e1653c2.entry.js +1 -0
  434. package/dist/webcomponents/p-53739e78.entry.js +1 -0
  435. package/dist/webcomponents/p-559be51b.entry.js +1 -0
  436. package/dist/webcomponents/p-58c766c8.entry.js +1 -0
  437. package/dist/webcomponents/{p-5ad70aae.entry.js → p-613421d4.entry.js} +1 -1
  438. package/dist/webcomponents/p-62a4a2c2.entry.js +1 -0
  439. package/dist/webcomponents/p-654d85ca.entry.js +1 -0
  440. package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
  441. package/dist/webcomponents/{p-ea1b161a.entry.js → p-664501b7.entry.js} +1 -1
  442. package/dist/webcomponents/p-6c7f08c8.entry.js +1 -0
  443. package/dist/webcomponents/p-6cf48f04.entry.js +1 -0
  444. package/dist/webcomponents/{p-03c7cee8.entry.js → p-70f51444.entry.js} +1 -1
  445. package/dist/webcomponents/p-778e9fe9.entry.js +1 -0
  446. package/dist/webcomponents/p-7922acee.entry.js +1 -0
  447. package/dist/webcomponents/p-7c463a59.entry.js +1 -0
  448. package/dist/webcomponents/{p-c6860f60.entry.js → p-7cf87637.entry.js} +1 -1
  449. package/dist/webcomponents/p-7fcbccc7.entry.js +1 -0
  450. package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
  451. package/dist/webcomponents/{p-b04cc606.entry.js → p-80331983.entry.js} +1 -1
  452. package/dist/webcomponents/{p-76a95d07.entry.js → p-8687e5d6.entry.js} +1 -1
  453. package/dist/webcomponents/p-87acb5ec.entry.js +1 -0
  454. package/dist/webcomponents/{p-7288473f.entry.js → p-8c95827f.entry.js} +1 -1
  455. package/dist/webcomponents/{p-55b7bdba.entry.js → p-8e0228df.entry.js} +1 -1
  456. package/dist/webcomponents/{p-a406bf1a.entry.js → p-8ff839a4.entry.js} +1 -1
  457. package/dist/webcomponents/p-927ecf5d.entry.js +1 -0
  458. package/dist/webcomponents/p-93ed5490.entry.js +1 -0
  459. package/dist/webcomponents/p-95a3e104.entry.js +1 -0
  460. package/dist/webcomponents/{p-a9d2dd5e.entry.js → p-95cbb655.entry.js} +1 -1
  461. package/dist/webcomponents/{p-2169c3d1.entry.js → p-95e33bcc.entry.js} +1 -1
  462. package/dist/webcomponents/{p-4cf9168d.entry.js → p-988ae9e9.entry.js} +1 -1
  463. package/dist/webcomponents/{p-e8a198fa.entry.js → p-9be67b19.entry.js} +1 -1
  464. package/dist/webcomponents/p-9c1d5a55.entry.js +1 -0
  465. package/dist/webcomponents/p-9c621697.entry.js +1 -0
  466. package/dist/webcomponents/p-9ed62efb.entry.js +1 -0
  467. package/dist/webcomponents/p-B71k50jz.js +1 -0
  468. package/dist/webcomponents/p-BF0mIfcQ.js +1 -0
  469. package/dist/webcomponents/p-BF4U0yVj.js +1 -0
  470. package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
  471. package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
  472. package/dist/webcomponents/p-BSt6p1oq.js +1 -0
  473. package/dist/webcomponents/p-BY1mRAvj.js +1 -0
  474. package/dist/webcomponents/{p-nWGo6sHu.js → p-Bb-6bNcq.js} +1 -1
  475. package/dist/webcomponents/p-BbZwa5UI.js +1 -0
  476. package/dist/webcomponents/p-BdKWuCys.js +1 -0
  477. package/dist/webcomponents/{p-BZzESzqz.js → p-BfM6X7lF.js} +1 -1
  478. package/dist/webcomponents/p-BjVfIXWC.js +1 -0
  479. package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
  480. package/dist/webcomponents/{p-wyEq9Pa1.js → p-BsGE9UDv.js} +1 -1
  481. package/dist/webcomponents/{p-CP_tg-uH.js → p-C5id7s_l.js} +1 -1
  482. package/dist/webcomponents/{p-DBsw4qpn.js → p-CAJnQLZF.js} +1 -1
  483. package/dist/webcomponents/{p-HAk7yBNq.js → p-CB0mCq1M.js} +1 -1
  484. package/dist/webcomponents/p-CItulios.js +1 -0
  485. package/dist/webcomponents/p-CaAVuW6B.js +1 -0
  486. package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
  487. package/dist/webcomponents/p-CbL73B6U.js +1 -0
  488. package/dist/webcomponents/p-CpaS1Lex.js +1 -0
  489. package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
  490. package/dist/webcomponents/p-DDUmOl3v.js +1 -0
  491. package/dist/webcomponents/p-DIDloHpm.js +1 -0
  492. package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
  493. package/dist/webcomponents/{p-DuXN7Akd.js → p-DNo0OPOP.js} +1 -1
  494. package/dist/webcomponents/{p-BUadwxkh.js → p-DRXvcLy9.js} +1 -1
  495. package/dist/webcomponents/p-Da3idOSV.js +1 -0
  496. package/dist/webcomponents/p-Dgflaz6J.js +1 -0
  497. package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
  498. package/dist/webcomponents/p-DsZZxRXY.js +1 -0
  499. package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
  500. package/dist/webcomponents/p-ED_TzwCp.js +1 -0
  501. package/dist/webcomponents/p-JyHlIFWl.js +1 -0
  502. package/dist/webcomponents/{p-D9Sv4eV5.js → p-VSSGd2zP.js} +1 -1
  503. package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
  504. package/dist/webcomponents/{p-c62e23c1.entry.js → p-a5114207.entry.js} +1 -1
  505. package/dist/webcomponents/p-a54281e8.entry.js +1 -0
  506. package/dist/webcomponents/{p-ab308ee3.entry.js → p-a7ac285c.entry.js} +1 -1
  507. package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
  508. package/dist/webcomponents/{p-1b892b3a.entry.js → p-bf2df971.entry.js} +1 -1
  509. package/dist/webcomponents/p-cff8ae71.entry.js +1 -0
  510. package/dist/webcomponents/p-d031ad31.entry.js +1 -0
  511. package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
  512. package/dist/webcomponents/p-d5d271d3.entry.js +1 -0
  513. package/dist/webcomponents/p-d8f9f287.entry.js +1 -0
  514. package/dist/webcomponents/{p-92efb3f2.entry.js → p-d9d371e1.entry.js} +1 -1
  515. package/dist/webcomponents/p-dba55699.entry.js +1 -0
  516. package/dist/webcomponents/p-e5282f6c.entry.js +1 -0
  517. package/dist/webcomponents/p-e7b66120.entry.js +1 -0
  518. package/dist/webcomponents/p-e9a5c837.entry.js +1 -0
  519. package/dist/webcomponents/p-eP3fmhta.js +1 -0
  520. package/dist/webcomponents/{p-5afbfafb.entry.js → p-eb2d9e5b.entry.js} +1 -1
  521. package/dist/webcomponents/p-ed53b213.entry.js +1 -0
  522. package/dist/webcomponents/{p-afc83e27.entry.js → p-f1cba43c.entry.js} +1 -1
  523. package/dist/webcomponents/p-f499a8de.entry.js +1 -0
  524. package/dist/webcomponents/p-f680e617.entry.js +1 -0
  525. package/dist/webcomponents/p-fa31c907.entry.js +1 -0
  526. package/dist/webcomponents/p-ff685149.entry.js +1 -0
  527. package/dist/webcomponents/p-sw5RO19U.js +1 -0
  528. package/dist/webcomponents/p-z-5r0gWn.js +1 -0
  529. package/dist/webcomponents/webcomponents.esm.js +1 -1
  530. package/package.json +2 -2
  531. package/dist/cjs/checkout.store-Cn3Jj5gi.js +0 -40
  532. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -785
  533. package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
  534. package/dist/esm/checkout.store-OAv_iY1u.js +0 -37
  535. package/dist/esm/justifi-checkout-summary_6.entry.js +0 -778
  536. package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
  537. package/dist/webcomponents/p-0aee6da6.entry.js +0 -1
  538. package/dist/webcomponents/p-0e64cd09.entry.js +0 -1
  539. package/dist/webcomponents/p-1202181b.entry.js +0 -1
  540. package/dist/webcomponents/p-1246b999.entry.js +0 -1
  541. package/dist/webcomponents/p-12c312a0.entry.js +0 -1
  542. package/dist/webcomponents/p-1a83d9f2.entry.js +0 -1
  543. package/dist/webcomponents/p-1c0c1d7b.entry.js +0 -1
  544. package/dist/webcomponents/p-1e206c92.entry.js +0 -1
  545. package/dist/webcomponents/p-281e36be.entry.js +0 -1
  546. package/dist/webcomponents/p-2988e82c.entry.js +0 -1
  547. package/dist/webcomponents/p-2a0a907d.entry.js +0 -1
  548. package/dist/webcomponents/p-32cc081a.entry.js +0 -1
  549. package/dist/webcomponents/p-387bcdee.entry.js +0 -1
  550. package/dist/webcomponents/p-41416b5f.entry.js +0 -1
  551. package/dist/webcomponents/p-42994618.entry.js +0 -1
  552. package/dist/webcomponents/p-5510b57c.entry.js +0 -1
  553. package/dist/webcomponents/p-59e8f027.entry.js +0 -1
  554. package/dist/webcomponents/p-5a5f07be.entry.js +0 -1
  555. package/dist/webcomponents/p-5acd6add.entry.js +0 -1
  556. package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
  557. package/dist/webcomponents/p-6974a44c.entry.js +0 -1
  558. package/dist/webcomponents/p-6f2b41f5.entry.js +0 -1
  559. package/dist/webcomponents/p-6f9755cc.entry.js +0 -1
  560. package/dist/webcomponents/p-7WIgS5RM.js +0 -1
  561. package/dist/webcomponents/p-7b9fa1fb.entry.js +0 -1
  562. package/dist/webcomponents/p-98939b74.entry.js +0 -1
  563. package/dist/webcomponents/p-BVD7g3cE.js +0 -1
  564. package/dist/webcomponents/p-BXKEChoo.js +0 -1
  565. package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
  566. package/dist/webcomponents/p-BmFoKOM3.js +0 -1
  567. package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
  568. package/dist/webcomponents/p-Bt388eye.js +0 -1
  569. package/dist/webcomponents/p-BtOB_CaO.js +0 -1
  570. package/dist/webcomponents/p-BySyDTv5.js +0 -1
  571. package/dist/webcomponents/p-C0AHrswP.js +0 -1
  572. package/dist/webcomponents/p-C60pS6qh.js +0 -1
  573. package/dist/webcomponents/p-CLwzqWk2.js +0 -1
  574. package/dist/webcomponents/p-CVQyw7ao.js +0 -1
  575. package/dist/webcomponents/p-D48iERjQ.js +0 -1
  576. package/dist/webcomponents/p-D7eeJWA-.js +0 -1
  577. package/dist/webcomponents/p-DD74a16D.js +0 -1
  578. package/dist/webcomponents/p-DKRXPZKS.js +0 -1
  579. package/dist/webcomponents/p-DOd8HaWV.js +0 -1
  580. package/dist/webcomponents/p-DaDsBt65.js +0 -1
  581. package/dist/webcomponents/p-DcE8SQPv.js +0 -1
  582. package/dist/webcomponents/p-Drz6LnIw.js +0 -1
  583. package/dist/webcomponents/p-WEguiGt1.js +0 -1
  584. package/dist/webcomponents/p-a1a8f6bd.entry.js +0 -1
  585. package/dist/webcomponents/p-a70bc148.entry.js +0 -1
  586. package/dist/webcomponents/p-b41d2b8f.entry.js +0 -1
  587. package/dist/webcomponents/p-b8f63e28.entry.js +0 -1
  588. package/dist/webcomponents/p-ba84c3bd.entry.js +0 -1
  589. package/dist/webcomponents/p-c7e5245a.entry.js +0 -1
  590. package/dist/webcomponents/p-cabaf013.entry.js +0 -1
  591. package/dist/webcomponents/p-cbfc8269.entry.js +0 -1
  592. package/dist/webcomponents/p-cf16498f.entry.js +0 -1
  593. package/dist/webcomponents/p-d014a155.entry.js +0 -1
  594. package/dist/webcomponents/p-e6ca1872.entry.js +0 -1
  595. package/dist/webcomponents/p-eff0b0e9.entry.js +0 -1
  596. package/dist/webcomponents/p-f3be7b2b.entry.js +0 -1
  597. package/dist/webcomponents/p-f787bc18.entry.js +0 -1
  598. package/dist/webcomponents/p-fb1904d2.entry.js +0 -1
  599. package/dist/webcomponents/p-fcb6e870.entry.js +0 -1
  600. package/dist/webcomponents/p-pska2q1M.js +0 -1
@@ -0,0 +1,853 @@
1
+ import { h } from "@stencil/core";
2
+ import { checkoutStore, onChange } from "../../../store/checkout.store";
3
+ import { StyledHost } from "../../../ui-components";
4
+ import plaidLogoSvg from "../../../assets/plaid-icon.svg";
5
+ import { PlaidService } from "../../../api/services/plaid.service";
6
+ import { ComponentErrorSeverity } from "../../../api/ComponentError";
7
+ import { PaymentMethodTypes } from "../../../api";
8
+ // Plaid-specific error codes
9
+ export var PlaidErrorCodes;
10
+ (function (PlaidErrorCodes) {
11
+ PlaidErrorCodes["PLAID_SDK_LOAD_FAILED"] = "plaid-sdk-load-failed";
12
+ PlaidErrorCodes["PLAID_LINK_INIT_FAILED"] = "plaid-link-init-failed";
13
+ PlaidErrorCodes["PLAID_LINK_TOKEN_FAILED"] = "plaid-link-token-failed";
14
+ PlaidErrorCodes["PLAID_AUTHENTICATION_FAILED"] = "plaid-authentication-failed";
15
+ PlaidErrorCodes["PLAID_BANK_NOT_SUPPORTED"] = "plaid-bank-not-supported";
16
+ PlaidErrorCodes["PLAID_TOKEN_EXPIRED"] = "plaid-token-expired";
17
+ PlaidErrorCodes["PLAID_NETWORK_ERROR"] = "plaid-network-error";
18
+ PlaidErrorCodes["PLAID_USER_CANCELLED"] = "plaid-user-cancelled";
19
+ PlaidErrorCodes["PLAID_TIMEOUT"] = "plaid-timeout";
20
+ PlaidErrorCodes["PLAID_INVALID_CREDENTIALS"] = "plaid-invalid-credentials";
21
+ PlaidErrorCodes["PLAID_ACCOUNT_LOCKED"] = "plaid-account-locked";
22
+ PlaidErrorCodes["PLAID_MAINTENANCE"] = "plaid-maintenance";
23
+ PlaidErrorCodes["PLAID_RATE_LIMITED"] = "plaid-rate-limited";
24
+ })(PlaidErrorCodes || (PlaidErrorCodes = {}));
25
+ // Plaid error message mapping
26
+ const PLAID_ERROR_MESSAGES = {
27
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: 'Unable to load Plaid. Please refresh the page and try again.',
28
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: 'Unable to initialize bank connection. Please try again.',
29
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: 'Unable to connect to bank service. Please try again.',
30
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: 'Bank authentication failed. Please try again.',
31
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: 'Your bank is not currently supported. Please try a different payment method.',
32
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: 'Your bank session has expired. Please reconnect your account.',
33
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: 'Network connection issue. Please check your internet connection and try again.',
34
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: 'Bank connection was cancelled. Click to try again.',
35
+ [PlaidErrorCodes.PLAID_TIMEOUT]: 'Bank connection timed out. Please try again.',
36
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: 'Invalid bank credentials. Please check your username and password.',
37
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: 'Your bank account is temporarily locked. Please contact your bank.',
38
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: 'Bank service is temporarily unavailable. Please try again later.',
39
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: 'Too many connection attempts. Please wait a moment and try again.',
40
+ };
41
+ // Plaid error severity mapping
42
+ const PLAID_ERROR_SEVERITY = {
43
+ [PlaidErrorCodes.PLAID_SDK_LOAD_FAILED]: ComponentErrorSeverity.ERROR,
44
+ [PlaidErrorCodes.PLAID_LINK_INIT_FAILED]: ComponentErrorSeverity.ERROR,
45
+ [PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED]: ComponentErrorSeverity.ERROR,
46
+ [PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED]: ComponentErrorSeverity.ERROR,
47
+ [PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED]: ComponentErrorSeverity.WARNING,
48
+ [PlaidErrorCodes.PLAID_TOKEN_EXPIRED]: ComponentErrorSeverity.WARNING,
49
+ [PlaidErrorCodes.PLAID_NETWORK_ERROR]: ComponentErrorSeverity.WARNING,
50
+ [PlaidErrorCodes.PLAID_USER_CANCELLED]: ComponentErrorSeverity.INFO,
51
+ [PlaidErrorCodes.PLAID_TIMEOUT]: ComponentErrorSeverity.WARNING,
52
+ [PlaidErrorCodes.PLAID_INVALID_CREDENTIALS]: ComponentErrorSeverity.ERROR,
53
+ [PlaidErrorCodes.PLAID_ACCOUNT_LOCKED]: ComponentErrorSeverity.ERROR,
54
+ [PlaidErrorCodes.PLAID_MAINTENANCE]: ComponentErrorSeverity.WARNING,
55
+ [PlaidErrorCodes.PLAID_RATE_LIMITED]: ComponentErrorSeverity.WARNING,
56
+ };
57
+ export class PlaidPaymentMethod {
58
+ constructor() {
59
+ this.isAuthenticating = false;
60
+ this.publicToken = null;
61
+ this.linkToken = null;
62
+ this.linkTokenId = null;
63
+ this.error = null;
64
+ this.plaidLink = null;
65
+ this.isSelected = false;
66
+ this.retryCount = 0;
67
+ this.isRetrying = false;
68
+ this.plaidService = new PlaidService();
69
+ this.maxRetries = 3;
70
+ this.retryDelay = 2000; // 2 seconds
71
+ this.timeoutId = null;
72
+ this.abortController = null;
73
+ this.hasLoggedDisabledWarning = false;
74
+ this.waitForStoreAndInitialize = () => {
75
+ // Check if store has necessary data
76
+ if (checkoutStore.authToken && checkoutStore.accountId && checkoutStore.checkoutId) {
77
+ this.initializePlaidLink();
78
+ }
79
+ else {
80
+ // Wait a bit and try again
81
+ setTimeout(() => {
82
+ this.waitForStoreAndInitialize();
83
+ }, 100);
84
+ }
85
+ };
86
+ this.initializePlaidLink = async () => {
87
+ try {
88
+ // Check if Plaid is available globally
89
+ if (typeof window.Plaid === 'undefined') {
90
+ this.handleError({
91
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
92
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
93
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
94
+ retryable: true,
95
+ userAction: 'Refresh the page and try again'
96
+ });
97
+ return;
98
+ }
99
+ // Get link token from backend
100
+ await this.getLinkToken();
101
+ if (!this.linkToken) {
102
+ this.handleError({
103
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
104
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
105
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED],
106
+ retryable: true,
107
+ userAction: 'Click to try again'
108
+ });
109
+ return;
110
+ }
111
+ // Initialize Plaid Link
112
+ const Plaid = window.Plaid;
113
+ this.plaidLink = Plaid.create({
114
+ token: this.linkToken,
115
+ onSuccess: this.handlePlaidSuccess,
116
+ onExit: this.handlePlaidExit,
117
+ onEvent: this.handlePlaidEvent,
118
+ onLoad: this.handlePlaidLoad,
119
+ });
120
+ }
121
+ catch (error) {
122
+ this.handleError({
123
+ code: PlaidErrorCodes.PLAID_LINK_INIT_FAILED,
124
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
125
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_LINK_INIT_FAILED],
126
+ originalError: error,
127
+ retryable: true,
128
+ userAction: 'Click to try again'
129
+ });
130
+ }
131
+ };
132
+ this.getLinkToken = async () => {
133
+ var _a, _b, _c, _d, _e;
134
+ try {
135
+ if (!checkoutStore.authToken || !checkoutStore.accountId) {
136
+ this.handleError({
137
+ code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
138
+ message: 'Missing authentication. Please refresh the page and try again.',
139
+ severity: ComponentErrorSeverity.ERROR,
140
+ retryable: false,
141
+ userAction: 'Refresh the page'
142
+ });
143
+ return;
144
+ }
145
+ // Create abort controller for timeout handling
146
+ this.abortController = new AbortController();
147
+ // Set timeout for the request
148
+ this.timeoutId = setTimeout(() => {
149
+ var _a;
150
+ (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
151
+ }, 30000); // 30 second timeout
152
+ const response = await this.plaidService.getLinkToken(checkoutStore.authToken, checkoutStore.accountId, checkoutStore.checkoutId, this.abortController.signal);
153
+ // Clear timeout
154
+ if (this.timeoutId) {
155
+ clearTimeout(this.timeoutId);
156
+ this.timeoutId = null;
157
+ }
158
+ if (response.error) {
159
+ const errorMessage = typeof response.error === 'string'
160
+ ? response.error
161
+ : response.error.message || 'Failed to get link token';
162
+ throw new Error(errorMessage);
163
+ }
164
+ // Some backends may return an id along with the link token
165
+ this.linkToken = response.data.link_token;
166
+ // Try to capture link token id if present in envelope
167
+ 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;
168
+ if (this.linkTokenId) {
169
+ checkoutStore.plaidLinkTokenId = this.linkTokenId;
170
+ }
171
+ }
172
+ catch (error) {
173
+ // Clear timeout
174
+ if (this.timeoutId) {
175
+ clearTimeout(this.timeoutId);
176
+ this.timeoutId = null;
177
+ }
178
+ let errorCode = PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
179
+ let message = PLAID_ERROR_MESSAGES[errorCode];
180
+ let retryable = true;
181
+ // Handle specific error types
182
+ if (error.name === 'AbortError') {
183
+ errorCode = PlaidErrorCodes.PLAID_TIMEOUT;
184
+ message = PLAID_ERROR_MESSAGES[errorCode];
185
+ retryable = true;
186
+ }
187
+ 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'))) {
188
+ errorCode = PlaidErrorCodes.PLAID_NETWORK_ERROR;
189
+ message = PLAID_ERROR_MESSAGES[errorCode];
190
+ retryable = true;
191
+ }
192
+ 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'))) {
193
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
194
+ message = 'Authentication failed. Please refresh the page and try again.';
195
+ retryable = false;
196
+ }
197
+ this.handleError({
198
+ code: errorCode,
199
+ message: message,
200
+ severity: PLAID_ERROR_SEVERITY[errorCode],
201
+ originalError: error,
202
+ retryable,
203
+ userAction: retryable ? 'Click to try again' : 'Refresh the page'
204
+ });
205
+ }
206
+ };
207
+ this.mapApiErrorToPlaidError = (apiError) => {
208
+ if (typeof apiError === 'string') {
209
+ if (apiError.includes('rate_limit'))
210
+ return PlaidErrorCodes.PLAID_RATE_LIMITED;
211
+ if (apiError.includes('maintenance'))
212
+ return PlaidErrorCodes.PLAID_MAINTENANCE;
213
+ if (apiError.includes('not_authenticated'))
214
+ return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
215
+ }
216
+ if (apiError === null || apiError === void 0 ? void 0 : apiError.code) {
217
+ switch (apiError.code) {
218
+ case 'rate_limited': return PlaidErrorCodes.PLAID_RATE_LIMITED;
219
+ case 'maintenance': return PlaidErrorCodes.PLAID_MAINTENANCE;
220
+ case 'not_authenticated': return PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
221
+ case 'invalid_parameter': return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
222
+ default: return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
223
+ }
224
+ }
225
+ return PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED;
226
+ };
227
+ this.openPlaidLink = () => {
228
+ if (this.plaidLink && this.linkToken) {
229
+ this.isAuthenticating = true;
230
+ this.clearError();
231
+ this.plaidLink.open();
232
+ }
233
+ };
234
+ this.handlePlaidSuccess = (publicToken, _metadata) => {
235
+ this.publicToken = publicToken;
236
+ this.isAuthenticating = false;
237
+ this.clearError();
238
+ this.retryCount = 0; // Reset retry count on success
239
+ // Ensure the component remains selected after successful authentication
240
+ if (!this.isSelected) {
241
+ this.isSelected = true;
242
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
243
+ }
244
+ // Emit success event for parent components
245
+ this.plaidErrorRecovered.emit({
246
+ code: 'plaid-success',
247
+ message: 'Bank account connected successfully',
248
+ severity: ComponentErrorSeverity.INFO
249
+ });
250
+ // Store public token in checkout store; exchange will be handled on submit
251
+ checkoutStore.plaidPublicToken = publicToken;
252
+ };
253
+ // Exchange logic moved to Modular Checkout submit flow.
254
+ this.handlePlaidExit = (err, _metadata) => {
255
+ this.isAuthenticating = false;
256
+ if (err) {
257
+ this.handlePlaidError(err);
258
+ }
259
+ else {
260
+ // User closed the modal without error
261
+ // If user closed without completing authentication, ensure component remains selected
262
+ // but clear any existing tokens to force re-authentication
263
+ if (this.isSelected && !this.publicToken) {
264
+ // Component is selected but no token, this is expected state
265
+ }
266
+ }
267
+ };
268
+ this.handlePlaidEvent = (eventName, metadata) => {
269
+ // Handle specific events if needed
270
+ switch (eventName) {
271
+ case 'OPEN':
272
+ this.isAuthenticating = true;
273
+ break;
274
+ case 'CLOSE':
275
+ this.isAuthenticating = false;
276
+ break;
277
+ case 'ERROR':
278
+ this.handlePlaidError(metadata);
279
+ break;
280
+ case 'HANDOFF':
281
+ // User is being redirected to their bank
282
+ break;
283
+ case 'TRANSITION_VIEW':
284
+ // Plaid Link view transition
285
+ break;
286
+ }
287
+ };
288
+ this.handlePlaidLoad = () => {
289
+ };
290
+ this.handlePlaidError = (error) => {
291
+ let errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
292
+ let message = PLAID_ERROR_MESSAGES[errorCode];
293
+ let retryable = true;
294
+ let userAction = 'Click to try again';
295
+ // Map Plaid error codes to our error codes
296
+ if (error.error_code) {
297
+ switch (error.error_code) {
298
+ case 'INVALID_CREDENTIALS':
299
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
300
+ message = PLAID_ERROR_MESSAGES[errorCode];
301
+ retryable = true;
302
+ break;
303
+ case 'ITEM_LOGIN_REQUIRED':
304
+ errorCode = PlaidErrorCodes.PLAID_INVALID_CREDENTIALS;
305
+ message = 'Your bank requires re-authentication. Please try again.';
306
+ retryable = true;
307
+ break;
308
+ case 'ITEM_LOCKED':
309
+ errorCode = PlaidErrorCodes.PLAID_ACCOUNT_LOCKED;
310
+ message = PLAID_ERROR_MESSAGES[errorCode];
311
+ retryable = false;
312
+ userAction = 'Contact your bank';
313
+ break;
314
+ case 'INSTITUTION_NOT_RESPONDING':
315
+ errorCode = PlaidErrorCodes.PLAID_MAINTENANCE;
316
+ message = PLAID_ERROR_MESSAGES[errorCode];
317
+ retryable = true;
318
+ break;
319
+ case 'RATE_LIMIT_EXCEEDED':
320
+ errorCode = PlaidErrorCodes.PLAID_RATE_LIMITED;
321
+ message = PLAID_ERROR_MESSAGES[errorCode];
322
+ retryable = true;
323
+ break;
324
+ case 'INVALID_REQUEST':
325
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
326
+ message = 'Invalid request. Please try again.';
327
+ retryable = true;
328
+ break;
329
+ case 'PLAID_ERROR':
330
+ errorCode = PlaidErrorCodes.PLAID_AUTHENTICATION_FAILED;
331
+ message = error.error_message || 'Bank authentication failed. Please try again.';
332
+ retryable = true;
333
+ break;
334
+ default:
335
+ // Use the error message from Plaid if available
336
+ if (error.error_message) {
337
+ message = error.error_message;
338
+ }
339
+ break;
340
+ }
341
+ }
342
+ // Handle specific error messages
343
+ if (error.error_message) {
344
+ const lowerMessage = error.error_message.toLowerCase();
345
+ if (lowerMessage.includes('not supported') || lowerMessage.includes('unsupported')) {
346
+ errorCode = PlaidErrorCodes.PLAID_BANK_NOT_SUPPORTED;
347
+ message = PLAID_ERROR_MESSAGES[errorCode];
348
+ retryable = false;
349
+ userAction = 'Try a different payment method';
350
+ }
351
+ else if (lowerMessage.includes('expired') || lowerMessage.includes('timeout')) {
352
+ errorCode = PlaidErrorCodes.PLAID_TOKEN_EXPIRED;
353
+ message = PLAID_ERROR_MESSAGES[errorCode];
354
+ retryable = true;
355
+ }
356
+ }
357
+ this.handleError({
358
+ code: errorCode,
359
+ message,
360
+ severity: PLAID_ERROR_SEVERITY[errorCode],
361
+ originalError: error,
362
+ retryable,
363
+ userAction
364
+ });
365
+ this.isAuthenticating = false;
366
+ // Even with an error, the component should remain selected to allow retry
367
+ if (this.isSelected) {
368
+ }
369
+ };
370
+ this.handleError = (plaidError) => {
371
+ this.error = plaidError;
372
+ // Emit error event for parent components
373
+ this.plaidError.emit({
374
+ code: plaidError.code,
375
+ message: plaidError.message,
376
+ severity: plaidError.severity,
377
+ data: {
378
+ originalError: plaidError.originalError,
379
+ retryable: plaidError.retryable,
380
+ userAction: plaidError.userAction,
381
+ retryCount: this.retryCount
382
+ }
383
+ });
384
+ console.error('Plaid error:', plaidError);
385
+ // Auto-retry for retryable errors if under max retries
386
+ if (plaidError.retryable && this.retryCount < this.maxRetries) {
387
+ this.scheduleRetry();
388
+ }
389
+ };
390
+ this.scheduleRetry = () => {
391
+ if (this.isRetrying)
392
+ return;
393
+ this.isRetrying = true;
394
+ this.retryCount++;
395
+ setTimeout(() => {
396
+ this.isRetrying = false;
397
+ this.clearError();
398
+ this.waitForStoreAndInitialize();
399
+ }, this.retryDelay * this.retryCount); // Exponential backoff
400
+ };
401
+ this.clearError = () => {
402
+ if (this.error) {
403
+ this.error = null;
404
+ this.retryCount = 0;
405
+ }
406
+ };
407
+ // Watch for store changes to sync component state
408
+ this.syncWithStore = () => {
409
+ const shouldBeSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
410
+ if (this.isSelected !== shouldBeSelected) {
411
+ this.isSelected = shouldBeSelected;
412
+ }
413
+ };
414
+ }
415
+ onSelectionChange(newValue) {
416
+ // Ensure store is updated when component selection changes
417
+ if (newValue && checkoutStore.selectedPaymentMethod.type !== PaymentMethodTypes.plaid) {
418
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
419
+ }
420
+ // Auto-start Plaid flow when selected and ready
421
+ if (newValue &&
422
+ this.plaidLink &&
423
+ !this.publicToken &&
424
+ !this.isAuthenticating &&
425
+ !this.error) {
426
+ this.openPlaidLink();
427
+ }
428
+ }
429
+ componentDidRender() {
430
+ if (!this.scriptRef)
431
+ return;
432
+ this.scriptRef.onload = () => {
433
+ // Wait for store to be populated before initializing
434
+ this.waitForStoreAndInitialize();
435
+ };
436
+ // Add error handler for script loading failures
437
+ this.scriptRef.onerror = () => {
438
+ this.handleError({
439
+ code: PlaidErrorCodes.PLAID_SDK_LOAD_FAILED,
440
+ message: PLAID_ERROR_MESSAGES[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
441
+ severity: PLAID_ERROR_SEVERITY[PlaidErrorCodes.PLAID_SDK_LOAD_FAILED],
442
+ retryable: true,
443
+ userAction: 'Refresh the page and try again'
444
+ });
445
+ };
446
+ }
447
+ componentWillLoad() {
448
+ // Initialize selection state based on store
449
+ this.isSelected = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid;
450
+ }
451
+ async resolvePaymentMethod() {
452
+ if (!this.publicToken) {
453
+ return { validationError: true };
454
+ }
455
+ return {
456
+ token: this.publicToken,
457
+ data: {
458
+ type: 'bank_account',
459
+ plaid_public_token: this.publicToken
460
+ }
461
+ };
462
+ }
463
+ // Returns a usable payment method token for checkout completion.
464
+ // Will perform the backend exchange if the token is not yet present in the store.
465
+ async getPaymentToken() {
466
+ return checkoutStore.paymentToken;
467
+ }
468
+ async handleSelectionClick() {
469
+ // Update local selection state
470
+ this.isSelected = true;
471
+ // Update store selection
472
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
473
+ // If there's an error, clear it and try to initialize again
474
+ if (this.error) {
475
+ this.clearError();
476
+ this.waitForStoreAndInitialize();
477
+ return;
478
+ }
479
+ // If Plaid Link is ready and no public token exists, open Plaid Link
480
+ if (this.plaidLink && !this.publicToken && !this.isAuthenticating) {
481
+ this.openPlaidLink();
482
+ }
483
+ }
484
+ // Method to handle external selection changes (e.g., from other payment methods)
485
+ async setSelected(selected) {
486
+ this.isSelected = selected;
487
+ if (selected) {
488
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.plaid };
489
+ }
490
+ }
491
+ // Method to check if component is currently selected
492
+ async isCurrentlySelected() {
493
+ return this.isSelected;
494
+ }
495
+ // Method to handle external deselection (when another payment method is selected)
496
+ async deselect() {
497
+ this.isSelected = false;
498
+ // Don't clear the public token or error state as they might be needed if user reselects
499
+ }
500
+ // Method to reset component state (useful for testing or error recovery)
501
+ async reset() {
502
+ this.publicToken = null;
503
+ this.clearError();
504
+ this.isAuthenticating = false;
505
+ this.linkToken = null;
506
+ this.plaidLink = null;
507
+ this.retryCount = 0;
508
+ this.isRetrying = false;
509
+ // Clear any pending timeouts
510
+ if (this.timeoutId) {
511
+ clearTimeout(this.timeoutId);
512
+ this.timeoutId = null;
513
+ }
514
+ // Abort any pending requests
515
+ if (this.abortController) {
516
+ this.abortController.abort();
517
+ this.abortController = null;
518
+ }
519
+ }
520
+ // Method to check if component is ready for authentication
521
+ async isReadyForAuthentication() {
522
+ return !!(this.plaidLink && this.linkToken && !this.isAuthenticating);
523
+ }
524
+ // Method to manually retry after an error
525
+ async retry() {
526
+ if (this.error && this.error.retryable) {
527
+ this.clearError();
528
+ this.waitForStoreAndInitialize();
529
+ }
530
+ }
531
+ // Method to get current error information
532
+ async getErrorInfo() {
533
+ return this.error;
534
+ }
535
+ componentDidLoad() {
536
+ // Set up store change listener to keep component in sync
537
+ const unsubscribe = onChange('selectedPaymentMethod', this.syncWithStore);
538
+ // Store unsubscribe function for cleanup
539
+ this.unsubscribeFromStore = unsubscribe;
540
+ }
541
+ disconnectedCallback() {
542
+ // Clean up store subscription
543
+ if (this.unsubscribeFromStore) {
544
+ this.unsubscribeFromStore();
545
+ }
546
+ // Clean up timeouts and abort controllers
547
+ if (this.timeoutId) {
548
+ clearTimeout(this.timeoutId);
549
+ }
550
+ if (this.abortController) {
551
+ this.abortController.abort();
552
+ }
553
+ }
554
+ render() {
555
+ // Only allow use if enabled in checkout settings
556
+ if (checkoutStore.bankAccountVerification !== true) {
557
+ if (!this.hasLoggedDisabledWarning) {
558
+ // Log once per component lifecycle
559
+ console.warn('[PlaidPaymentMethod] bank_account_verification is disabled. Component will not render.');
560
+ this.hasLoggedDisabledWarning = true;
561
+ }
562
+ return null;
563
+ }
564
+ const plaidLogo = (h("img", { class: "plaid-logo-img", src: plaidLogoSvg, alt: "Plaid", title: "Plaid", style: {
565
+ display: 'inline',
566
+ width: '20px',
567
+ height: '20px',
568
+ marginLeft: '5px',
569
+ marginTop: '-2px',
570
+ } }));
571
+ const renderErrorState = () => {
572
+ if (!this.error)
573
+ return null;
574
+ const errorClass = this.error.severity === ComponentErrorSeverity.ERROR
575
+ ? 'text-danger'
576
+ : this.error.severity === ComponentErrorSeverity.WARNING
577
+ ? 'text-warning'
578
+ : 'text-info';
579
+ 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...")))));
580
+ };
581
+ const renderStatusState = () => {
582
+ if (this.error)
583
+ return null;
584
+ if (this.isAuthenticating) {
585
+ return (h("div", { class: "text-info mt-2" }, h("small", null, "Connecting to your bank...")));
586
+ }
587
+ if (this.publicToken) {
588
+ return (h("div", { class: "text-success mt-2" }, h("small", null, "\u2713 Bank account connected successfully")));
589
+ }
590
+ if (this.isSelected && !this.publicToken && !this.error && !this.isAuthenticating) {
591
+ return (h("div", { class: "text-muted mt-2" }, h("small", null, "Click to connect your bank account")));
592
+ }
593
+ return null;
594
+ };
595
+ 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())));
596
+ }
597
+ static get is() { return "justifi-plaid-payment-method"; }
598
+ static get encapsulation() { return "shadow"; }
599
+ static get states() {
600
+ return {
601
+ "isAuthenticating": {},
602
+ "publicToken": {},
603
+ "linkToken": {},
604
+ "linkTokenId": {},
605
+ "error": {},
606
+ "plaidLink": {},
607
+ "isSelected": {},
608
+ "retryCount": {},
609
+ "isRetrying": {}
610
+ };
611
+ }
612
+ static get events() {
613
+ return [{
614
+ "method": "paymentMethodOptionSelected",
615
+ "name": "paymentMethodOptionSelected",
616
+ "bubbles": true,
617
+ "cancelable": true,
618
+ "composed": true,
619
+ "docs": {
620
+ "tags": [],
621
+ "text": ""
622
+ },
623
+ "complexType": {
624
+ "original": "any",
625
+ "resolved": "any",
626
+ "references": {}
627
+ }
628
+ }, {
629
+ "method": "plaidError",
630
+ "name": "plaidError",
631
+ "bubbles": true,
632
+ "cancelable": true,
633
+ "composed": true,
634
+ "docs": {
635
+ "tags": [],
636
+ "text": ""
637
+ },
638
+ "complexType": {
639
+ "original": "any",
640
+ "resolved": "any",
641
+ "references": {}
642
+ }
643
+ }, {
644
+ "method": "plaidErrorRecovered",
645
+ "name": "plaidErrorRecovered",
646
+ "bubbles": true,
647
+ "cancelable": true,
648
+ "composed": true,
649
+ "docs": {
650
+ "tags": [],
651
+ "text": ""
652
+ },
653
+ "complexType": {
654
+ "original": "any",
655
+ "resolved": "any",
656
+ "references": {}
657
+ }
658
+ }];
659
+ }
660
+ static get methods() {
661
+ return {
662
+ "resolvePaymentMethod": {
663
+ "complexType": {
664
+ "signature": "() => Promise<PaymentMethodPayload>",
665
+ "parameters": [],
666
+ "references": {
667
+ "Promise": {
668
+ "location": "global",
669
+ "id": "global::Promise"
670
+ },
671
+ "PaymentMethodPayload": {
672
+ "location": "import",
673
+ "path": "../../checkout/payment-method-payload",
674
+ "id": "src/components/checkout/payment-method-payload.ts::PaymentMethodPayload"
675
+ }
676
+ },
677
+ "return": "Promise<PaymentMethodPayload>"
678
+ },
679
+ "docs": {
680
+ "text": "",
681
+ "tags": []
682
+ }
683
+ },
684
+ "getPaymentToken": {
685
+ "complexType": {
686
+ "signature": "() => Promise<string | undefined>",
687
+ "parameters": [],
688
+ "references": {
689
+ "Promise": {
690
+ "location": "global",
691
+ "id": "global::Promise"
692
+ }
693
+ },
694
+ "return": "Promise<string>"
695
+ },
696
+ "docs": {
697
+ "text": "",
698
+ "tags": []
699
+ }
700
+ },
701
+ "handleSelectionClick": {
702
+ "complexType": {
703
+ "signature": "() => Promise<void>",
704
+ "parameters": [],
705
+ "references": {
706
+ "Promise": {
707
+ "location": "global",
708
+ "id": "global::Promise"
709
+ }
710
+ },
711
+ "return": "Promise<void>"
712
+ },
713
+ "docs": {
714
+ "text": "",
715
+ "tags": []
716
+ }
717
+ },
718
+ "setSelected": {
719
+ "complexType": {
720
+ "signature": "(selected: boolean) => Promise<void>",
721
+ "parameters": [{
722
+ "name": "selected",
723
+ "type": "boolean",
724
+ "docs": ""
725
+ }],
726
+ "references": {
727
+ "Promise": {
728
+ "location": "global",
729
+ "id": "global::Promise"
730
+ }
731
+ },
732
+ "return": "Promise<void>"
733
+ },
734
+ "docs": {
735
+ "text": "",
736
+ "tags": []
737
+ }
738
+ },
739
+ "isCurrentlySelected": {
740
+ "complexType": {
741
+ "signature": "() => Promise<boolean>",
742
+ "parameters": [],
743
+ "references": {
744
+ "Promise": {
745
+ "location": "global",
746
+ "id": "global::Promise"
747
+ }
748
+ },
749
+ "return": "Promise<boolean>"
750
+ },
751
+ "docs": {
752
+ "text": "",
753
+ "tags": []
754
+ }
755
+ },
756
+ "deselect": {
757
+ "complexType": {
758
+ "signature": "() => Promise<void>",
759
+ "parameters": [],
760
+ "references": {
761
+ "Promise": {
762
+ "location": "global",
763
+ "id": "global::Promise"
764
+ }
765
+ },
766
+ "return": "Promise<void>"
767
+ },
768
+ "docs": {
769
+ "text": "",
770
+ "tags": []
771
+ }
772
+ },
773
+ "reset": {
774
+ "complexType": {
775
+ "signature": "() => Promise<void>",
776
+ "parameters": [],
777
+ "references": {
778
+ "Promise": {
779
+ "location": "global",
780
+ "id": "global::Promise"
781
+ }
782
+ },
783
+ "return": "Promise<void>"
784
+ },
785
+ "docs": {
786
+ "text": "",
787
+ "tags": []
788
+ }
789
+ },
790
+ "isReadyForAuthentication": {
791
+ "complexType": {
792
+ "signature": "() => Promise<boolean>",
793
+ "parameters": [],
794
+ "references": {
795
+ "Promise": {
796
+ "location": "global",
797
+ "id": "global::Promise"
798
+ }
799
+ },
800
+ "return": "Promise<boolean>"
801
+ },
802
+ "docs": {
803
+ "text": "",
804
+ "tags": []
805
+ }
806
+ },
807
+ "retry": {
808
+ "complexType": {
809
+ "signature": "() => Promise<void>",
810
+ "parameters": [],
811
+ "references": {
812
+ "Promise": {
813
+ "location": "global",
814
+ "id": "global::Promise"
815
+ }
816
+ },
817
+ "return": "Promise<void>"
818
+ },
819
+ "docs": {
820
+ "text": "",
821
+ "tags": []
822
+ }
823
+ },
824
+ "getErrorInfo": {
825
+ "complexType": {
826
+ "signature": "() => Promise<PlaidError | null>",
827
+ "parameters": [],
828
+ "references": {
829
+ "Promise": {
830
+ "location": "global",
831
+ "id": "global::Promise"
832
+ },
833
+ "PlaidError": {
834
+ "location": "global",
835
+ "id": "global::PlaidError"
836
+ }
837
+ },
838
+ "return": "Promise<PlaidError>"
839
+ },
840
+ "docs": {
841
+ "text": "",
842
+ "tags": []
843
+ }
844
+ }
845
+ };
846
+ }
847
+ static get watchers() {
848
+ return [{
849
+ "propName": "isSelected",
850
+ "methodName": "onSelectionChange"
851
+ }];
852
+ }
853
+ }