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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (571) hide show
  1. package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
  2. package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
  3. package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
  4. package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
  5. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +7 -7
  6. package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
  7. package/dist/cjs/business-details-core.cjs.entry.js +4 -4
  8. package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
  9. package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
  10. package/dist/cjs/card-form.cjs.entry.js +9 -6
  11. package/dist/cjs/{check-pkg-version-D_lazhBQ.js → check-pkg-version-B85-DAz3.js} +9 -3
  12. package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
  13. package/dist/cjs/checkout.store-CDQXaOcP.js +90 -0
  14. package/dist/cjs/checkouts-list-core.cjs.entry.js +11 -11
  15. package/dist/cjs/{payments-list-params-state-BNbT1fuJ.js → checkouts-list-params-state-Cewmin_p.js} +1 -1
  16. package/dist/cjs/{checkouts-table-UN5gPpQ_.js → checkouts-table-DjMdEiEW.js} +3 -3
  17. package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
  18. package/dist/cjs/custom-popper_2.cjs.entry.js +3 -3
  19. package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
  20. package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
  21. package/dist/cjs/form-control-checkbox.cjs.entry.js +5 -5
  22. package/dist/cjs/form-control-date.cjs.entry.js +4 -4
  23. package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
  24. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +2 -2
  25. package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
  26. package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
  27. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
  28. package/dist/cjs/form-control-monetary.cjs.entry.js +4 -4
  29. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +2 -2
  30. package/dist/cjs/form-control-number.cjs.entry.js +3 -3
  31. package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
  32. package/dist/cjs/form-control-select_2.cjs.entry.js +4 -4
  33. package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
  34. package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
  35. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +5 -5
  36. package/dist/cjs/{header-1-DD41iNlG.js → header-1-DRA3f4Jh.js} +1 -1
  37. package/dist/cjs/{header-3-D9Wa0IfT.js → header-3-sOdOpfx3.js} +1 -1
  38. package/dist/cjs/hidden-input_2.cjs.entry.js +4 -4
  39. package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
  40. package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
  41. package/dist/cjs/index-D-dD-aC2.js +30 -0
  42. package/dist/cjs/index.cjs.js +8 -0
  43. package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
  44. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
  45. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
  46. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +9 -9
  47. package/dist/cjs/justifi-apple-pay.cjs.entry.js +782 -0
  48. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +21 -19
  49. package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
  50. package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
  51. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
  52. package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1421 -0
  53. package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
  54. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +8 -8
  55. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +14 -14
  56. package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
  57. package/dist/cjs/justifi-details.cjs.entry.js +2 -2
  58. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +2 -2
  59. package/dist/cjs/justifi-dispute-management.cjs.entry.js +10 -10
  60. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +15 -15
  61. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
  62. package/dist/cjs/justifi-order-terminals.cjs.entry.js +13 -13
  63. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
  64. package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
  65. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
  66. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
  67. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +13 -13
  68. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +7 -7
  69. package/dist/cjs/justifi-payments-list.cjs.entry.js +14 -14
  70. package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
  71. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +13 -13
  72. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +7 -7
  73. package/dist/cjs/justifi-payouts-list.cjs.entry.js +15 -15
  74. package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
  75. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +1 -1
  76. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
  77. package/dist/cjs/justifi-skeleton.cjs.entry.js +3 -3
  78. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +9 -9
  79. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +12 -12
  80. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +8 -8
  81. package/dist/cjs/justifi-terminals-list.cjs.entry.js +14 -14
  82. package/dist/cjs/loader.cjs.js +2 -2
  83. package/dist/cjs/{package-Cp_7Ls2E.js → package-BL9z319y.js} +1 -1
  84. package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
  85. package/dist/cjs/payment-details-core.cjs.entry.js +15 -15
  86. package/dist/cjs/payment-method-option.cjs.entry.js +3 -3
  87. package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
  88. package/dist/cjs/payments-list-core.cjs.entry.js +12 -12
  89. package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
  90. package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
  91. package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
  92. package/dist/cjs/payout-details-core.cjs.entry.js +11 -11
  93. package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
  94. package/dist/cjs/payouts-list-core.cjs.entry.js +12 -12
  95. package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
  96. package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
  97. package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
  98. package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
  99. package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
  100. package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
  101. package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
  102. package/dist/cjs/table-filters-menu.cjs.entry.js +3 -3
  103. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +11 -11
  104. package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
  105. package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
  106. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +2 -2
  107. package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
  108. package/dist/cjs/terminals-list-core.cjs.entry.js +11 -11
  109. package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
  110. package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
  111. package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
  112. package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
  113. package/dist/cjs/webcomponents.cjs.js +3 -3
  114. package/dist/collection/api/ApplePay.js +119 -0
  115. package/dist/collection/api/Payment.js +5 -2
  116. package/dist/collection/api/index.js +1 -2
  117. package/dist/collection/api/services/apple-pay.service.js +293 -0
  118. package/dist/collection/api/services/plaid.service.js +20 -0
  119. package/dist/collection/assets/plaid-icon.svg +1 -0
  120. package/dist/collection/collection-manifest.json +4 -2
  121. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
  122. package/dist/collection/components/checkout/card-form/card-form.js +6 -3
  123. package/dist/collection/components/checkout/checkout.js +17 -39
  124. package/dist/collection/components/checkout/save-new-payment-method.js +26 -1
  125. package/dist/collection/components/checkouts-list/checkouts-list-core.js +1 -1
  126. package/dist/collection/components/checkouts-list/checkouts-list-filters.js +1 -1
  127. package/dist/collection/components/checkouts-list/checkouts-list.js +1 -1
  128. package/dist/collection/components/dispute-management/dispute-management-core.js +1 -1
  129. package/dist/collection/components/dispute-management/dispute-management.js +1 -1
  130. package/dist/collection/components/dispute-management/dispute-notification.js +1 -1
  131. package/dist/collection/components/dispute-management/dispute-response/additional-statement.js +1 -1
  132. package/dist/collection/components/dispute-management/dispute-response/cancellation-policy.js +1 -1
  133. package/dist/collection/components/dispute-management/dispute-response/customer-details.js +1 -1
  134. package/dist/collection/components/dispute-management/dispute-response/dispute-response-core.js +1 -1
  135. package/dist/collection/components/dispute-management/dispute-response/dispute-response.js +1 -1
  136. package/dist/collection/components/dispute-management/dispute-response/duplicate-charge.js +1 -1
  137. package/dist/collection/components/dispute-management/dispute-response/electronic-evidence.js +1 -1
  138. package/dist/collection/components/dispute-management/dispute-response/product-or-service.js +1 -1
  139. package/dist/collection/components/dispute-management/dispute-response/refund-policy.js +1 -1
  140. package/dist/collection/components/dispute-management/dispute-response/shipping-details.js +1 -1
  141. package/dist/collection/components/filters/table-filters-menu.js +1 -1
  142. package/dist/collection/components/gross-payment-chart/gross-payment-chart-core.js +1 -1
  143. package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
  144. package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
  145. package/dist/collection/components/modular-checkout/modular-checkout.js +263 -150
  146. package/dist/collection/components/modular-checkout/sub-components/apple-pay-skeleton.js +10 -0
  147. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +509 -0
  148. package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
  149. package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
  150. package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
  151. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +853 -0
  152. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +125 -0
  153. package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
  154. package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
  155. package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
  156. package/dist/collection/components/order-terminals/order-terminals.js +1 -1
  157. package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
  158. package/dist/collection/components/payment-details/payment-details-core.js +8 -8
  159. package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
  160. package/dist/collection/components/payments-list/payments-list-core.js +1 -1
  161. package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
  162. package/dist/collection/components/payments-list/payments-list.js +1 -1
  163. package/dist/collection/components/payout-details/payout-details-core.js +3 -3
  164. package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
  165. package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
  166. package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
  167. package/dist/collection/components/payouts-list/payouts-list.js +1 -1
  168. package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
  169. package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
  170. package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
  171. package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
  172. package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
  173. package/dist/collection/components/terminals-list/terminals-list.js +1 -1
  174. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +82 -34
  175. package/dist/collection/index.js +1 -0
  176. package/dist/collection/store/checkout.store.js +48 -2
  177. package/dist/collection/ui-components/apple-pay-button.js +146 -0
  178. package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
  179. package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
  180. package/dist/collection/ui-components/form/form-control-date.js +2 -2
  181. package/dist/collection/ui-components/form/form-control-radio.js +5 -5
  182. package/dist/collection/ui-components/form/form-control-select.js +2 -2
  183. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
  184. package/dist/collection/utils/check-pkg-version.js +6 -0
  185. package/dist/collection/utils/utils.js +5 -0
  186. package/dist/docs.json +1061 -212
  187. package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
  188. package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
  189. package/dist/esm/additional-questions-details_5.entry.js +4 -4
  190. package/dist/esm/{badge-D_mzXSCQ.js → badge-DSYSJcRy.js} +2 -2
  191. package/dist/esm/bank-account-document-form-inputs_4.entry.js +8 -8
  192. package/dist/esm/bank-account-form.entry.js +10 -7
  193. package/dist/esm/business-details-core.entry.js +5 -5
  194. package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
  195. package/dist/esm/{button-CeR8qVS3.js → button-CpllL0At.js} +2 -2
  196. package/dist/esm/card-form.entry.js +10 -7
  197. package/dist/esm/{check-pkg-version-Bb69ihTN.js → check-pkg-version-CeFbumLK.js} +9 -3
  198. package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
  199. package/dist/esm/checkout.store-CKOWX2jL.js +85 -0
  200. package/dist/esm/checkouts-list-core.entry.js +12 -12
  201. package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
  202. package/dist/esm/{checkouts-table-CFZYoYjn.js → checkouts-table-Ddf2I-Ul.js} +4 -4
  203. package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
  204. package/dist/esm/custom-popper_2.entry.js +4 -4
  205. package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
  206. package/dist/esm/form-alert_5.entry.js +2 -2
  207. package/dist/esm/form-control-checkbox.entry.js +6 -6
  208. package/dist/esm/form-control-date.entry.js +5 -5
  209. package/dist/esm/{form-control-error-text-D3ZwkOv-.js → form-control-error-text-R7U07nTg.js} +2 -2
  210. package/dist/esm/form-control-file-v2_2.entry.js +3 -3
  211. package/dist/esm/{form-control-help-text-C39ZW65w.js → form-control-help-text-CRLH-2f7.js} +2 -2
  212. package/dist/esm/form-control-help-text.entry.js +1 -1
  213. package/dist/esm/form-control-monetary-provisioning.entry.js +4 -4
  214. package/dist/esm/form-control-monetary.entry.js +5 -5
  215. package/dist/esm/form-control-number-masked_2.entry.js +3 -3
  216. package/dist/esm/form-control-number.entry.js +4 -4
  217. package/dist/esm/form-control-radio.entry.js +4 -4
  218. package/dist/esm/form-control-select_2.entry.js +5 -5
  219. package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
  220. package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
  221. package/dist/esm/gross-payment-chart-core.entry.js +6 -6
  222. package/dist/esm/{header-1-E-hEi3wF.js → header-1-3M9If0gM.js} +2 -2
  223. package/dist/esm/{header-3-Dm7M85kz.js → header-3-CWa41YWq.js} +2 -2
  224. package/dist/esm/hidden-input_2.entry.js +5 -5
  225. package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
  226. package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
  227. package/dist/esm/index-CbL73B6U.js +30 -0
  228. package/dist/esm/index.js +1 -1
  229. package/dist/esm/{insurance-state-CB4l8sOv.js → insurance-state-CTalqbNa.js} +3 -3
  230. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +8 -8
  231. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +9 -9
  232. package/dist/esm/justifi-additional-statement_8.entry.js +10 -10
  233. package/dist/esm/justifi-apple-pay.entry.js +780 -0
  234. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +22 -20
  235. package/dist/esm/justifi-business-details.entry.js +11 -11
  236. package/dist/esm/justifi-business-form.entry.js +14 -14
  237. package/dist/esm/justifi-business-representative-form-inputs.entry.js +2 -2
  238. package/dist/esm/justifi-checkout-summary_7.entry.js +1413 -0
  239. package/dist/esm/justifi-checkout.entry.js +26 -48
  240. package/dist/esm/justifi-checkouts-list-filters.entry.js +9 -9
  241. package/dist/esm/justifi-checkouts-list.entry.js +15 -15
  242. package/dist/esm/justifi-config-provider.entry.js +3 -3
  243. package/dist/esm/justifi-details.entry.js +3 -3
  244. package/dist/esm/justifi-dispute-management-core.entry.js +2 -2
  245. package/dist/esm/justifi-dispute-management.entry.js +10 -10
  246. package/dist/esm/justifi-dispute-notification_3.entry.js +16 -16
  247. package/dist/esm/justifi-gross-payment-chart.entry.js +10 -10
  248. package/dist/esm/justifi-order-terminals.entry.js +14 -14
  249. package/dist/esm/justifi-owner-form_3.entry.js +9 -9
  250. package/dist/esm/justifi-payment-details.entry.js +12 -12
  251. package/dist/esm/justifi-payment-provisioning-core.entry.js +4 -4
  252. package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
  253. package/dist/esm/justifi-payment-transactions-list.entry.js +14 -14
  254. package/dist/esm/justifi-payments-list-filters.entry.js +8 -8
  255. package/dist/esm/justifi-payments-list.entry.js +15 -15
  256. package/dist/esm/justifi-payout-details.entry.js +11 -11
  257. package/dist/esm/justifi-payout-transactions-list.entry.js +14 -14
  258. package/dist/esm/justifi-payouts-list-filters.entry.js +8 -8
  259. package/dist/esm/justifi-payouts-list.entry.js +16 -16
  260. package/dist/esm/justifi-refund-payment.entry.js +14 -14
  261. package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
  262. package/dist/esm/justifi-season-interruption-insurance.entry.js +18 -13
  263. package/dist/esm/justifi-skeleton.entry.js +4 -4
  264. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +10 -10
  265. package/dist/esm/justifi-terminal-orders-list.entry.js +13 -13
  266. package/dist/esm/justifi-terminals-list-filters.entry.js +9 -9
  267. package/dist/esm/justifi-terminals-list.entry.js +15 -15
  268. package/dist/esm/loader.js +3 -3
  269. package/dist/esm/{package-O3LY2Da6.js → package-CxLeEBSa.js} +1 -1
  270. package/dist/esm/pagination-menu.entry.js +2 -2
  271. package/dist/esm/{parts-CfF8KKwx.js → parts-RvUQ__Pq.js} +1 -1
  272. package/dist/esm/payment-details-core.entry.js +16 -16
  273. package/dist/esm/payment-method-option.entry.js +4 -4
  274. package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
  275. package/dist/esm/payments-list-core.entry.js +13 -13
  276. package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
  277. package/dist/esm/{payments-status-XoZrlbiZ.js → payments-status-5orNU2Rd.js} +2 -2
  278. package/dist/esm/{payments-table-Dh4P9mTb.js → payments-table-gkJV5GNK.js} +4 -4
  279. package/dist/esm/payout-details-core.entry.js +12 -12
  280. package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
  281. package/dist/esm/payouts-list-core.entry.js +13 -13
  282. package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
  283. package/dist/esm/{payouts-status-Qm2jZG1-.js → payouts-status-CZPwa2AE.js} +2 -2
  284. package/dist/esm/{payouts-table-DMVAZp-r.js → payouts-table-0PtktGRd.js} +4 -4
  285. package/dist/esm/{skeleton-DrHwsgs_.js → skeleton-qMb0_Cjy.js} +2 -2
  286. package/dist/esm/{spinner-XBq6mVJW.js → spinner-DUzyWLhj.js} +2 -2
  287. package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
  288. package/dist/esm/{table-qqt2Ew5y.js → table-Br3n9Xu-.js} +3 -3
  289. package/dist/esm/table-filters-menu.entry.js +4 -4
  290. package/dist/esm/terminal-orders-list-core.entry.js +12 -12
  291. package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
  292. package/dist/esm/{terminal-orders-table-BN4Co4T8.js → terminal-orders-table-DTBSIMlJ.js} +6 -6
  293. package/dist/esm/terminal-quantity-selector.entry.js +3 -3
  294. package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
  295. package/dist/esm/terminals-list-core.entry.js +12 -12
  296. package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
  297. package/dist/esm/{terminals-table-C8LczeG_.js → terminals-table-TGUKTi7I.js} +4 -4
  298. package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
  299. package/dist/esm/{utils-kWaZhFAd.js → utils-Dg6gMUTv.js} +2 -2
  300. package/dist/esm/webcomponents.js +4 -4
  301. package/dist/module/Analytics.js +6 -0
  302. package/dist/module/ModularCheckout.js +30 -0
  303. package/dist/module/Refund.js +5 -2
  304. package/dist/module/additional-statement.js +1 -1
  305. package/dist/module/bank-account-form.js +5 -2
  306. package/dist/module/bank-account.js +2 -2
  307. package/dist/module/cancellation-policy.js +1 -1
  308. package/dist/module/card-form.js +5 -2
  309. package/dist/module/card-form2.js +2 -2
  310. package/dist/module/checkout.store.js +49 -2
  311. package/dist/module/checkouts-list-core2.js +1 -1
  312. package/dist/module/custom-popper2.js +2 -2
  313. package/dist/module/customer-details.js +1 -1
  314. package/dist/module/dispute-management-core.js +1 -1
  315. package/dist/module/dispute-notification.js +1 -1
  316. package/dist/module/dispute-response-core.js +1 -1
  317. package/dist/module/dispute-response.js +1 -1
  318. package/dist/module/duplicate-charge.js +1 -1
  319. package/dist/module/electronic-evidence.js +1 -1
  320. package/dist/module/form-control-checkbox2.js +2 -2
  321. package/dist/module/form-control-date2.js +2 -2
  322. package/dist/module/form-control-radio2.js +3 -3
  323. package/dist/module/form-control-select2.js +2 -2
  324. package/dist/module/gross-payment-chart-core2.js +2 -2
  325. package/dist/module/index.js +1 -0
  326. package/dist/module/justifi-apple-pay.d.ts +11 -0
  327. package/dist/module/justifi-apple-pay.js +811 -0
  328. package/dist/module/justifi-checkout.js +63 -75
  329. package/dist/module/justifi-checkouts-list-filters.js +1 -1
  330. package/dist/module/justifi-checkouts-list.js +1 -1
  331. package/dist/module/justifi-dispute-management.js +1 -1
  332. package/dist/module/justifi-order-terminals.js +2 -2
  333. package/dist/module/justifi-payment-transactions-list.js +1 -1
  334. package/dist/module/justifi-payments-list-filters.js +2 -2
  335. package/dist/module/justifi-payments-list.js +1 -1
  336. package/dist/module/justifi-payout-transactions-list.js +1 -1
  337. package/dist/module/justifi-payouts-list-filters.js +2 -2
  338. package/dist/module/justifi-payouts-list.js +1 -1
  339. package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
  340. package/dist/module/justifi-plaid-payment-method.js +6 -0
  341. package/dist/module/justifi-radio-list-item2.js +2 -2
  342. package/dist/module/justifi-season-interruption-insurance.js +5 -1
  343. package/dist/module/justifi-terminal-orders-list-filters.js +2 -2
  344. package/dist/module/justifi-terminal-orders-list.js +1 -1
  345. package/dist/module/justifi-terminals-list-filters.js +1 -1
  346. package/dist/module/justifi-terminals-list.js +1 -1
  347. package/dist/module/modular-checkout.js +214 -106
  348. package/dist/module/package.js +1 -1
  349. package/dist/module/payment-details-core2.js +8 -8
  350. package/dist/module/payment-method-option.js +1 -1
  351. package/dist/module/payments-list-core2.js +1 -1
  352. package/dist/module/payout-details-core2.js +3 -3
  353. package/dist/module/payouts-list-core2.js +1 -1
  354. package/dist/module/plaid-payment-method.js +635 -0
  355. package/dist/module/plaid.service.js +26 -0
  356. package/dist/module/product-or-service.js +1 -1
  357. package/dist/module/refund-policy.js +1 -1
  358. package/dist/module/save-new-payment-method.js +3 -1
  359. package/dist/module/saved-payment-methods.js +7 -5
  360. package/dist/module/sezzle-payment-method.js +14 -22
  361. package/dist/module/shipping-details.js +1 -1
  362. package/dist/module/summary.js +1 -1
  363. package/dist/module/table-filters-menu2.js +1 -1
  364. package/dist/module/terminal-orders-list-core2.js +1 -1
  365. package/dist/module/terminal-quantity-selector2.js +1 -1
  366. package/dist/module/terminals-list-core2.js +2 -2
  367. package/dist/module/tokenize-payment-method.js +45 -34
  368. package/dist/module/utils2.js +6 -1
  369. package/dist/types/api/ApplePay.d.ts +196 -0
  370. package/dist/types/api/Checkout.d.ts +9 -14
  371. package/dist/types/api/Payment.d.ts +4 -3
  372. package/dist/types/api/index.d.ts +2 -2
  373. package/dist/types/api/services/apple-pay.service.d.ts +55 -0
  374. package/dist/types/api/services/plaid.service.d.ts +12 -0
  375. package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
  376. package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
  377. package/dist/types/components/checkout/checkout.d.ts +6 -7
  378. package/dist/types/components/checkout/save-new-payment-method.d.ts +1 -0
  379. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
  380. package/dist/types/components/modular-checkout/modular-checkout.d.ts +14 -6
  381. package/dist/types/components/modular-checkout/sub-components/apple-pay-skeleton.d.ts +6 -0
  382. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +39 -0
  383. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +79 -0
  384. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
  385. package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
  386. package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
  387. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +8 -6
  388. package/dist/types/components.d.ts +182 -19
  389. package/dist/types/index.d.ts +3 -0
  390. package/dist/types/store/checkout.store.d.ts +16 -3
  391. package/dist/types/ui-components/apple-pay-button.d.ts +17 -0
  392. package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
  393. package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
  394. package/dist/types/utils/utils.d.ts +1 -0
  395. package/dist/webcomponents/index.esm.js +1 -0
  396. package/dist/webcomponents/p-06283633.entry.js +1 -0
  397. package/dist/webcomponents/{p-Dvxpy_P1.js → p-0Om7jLBs.js} +1 -1
  398. package/dist/webcomponents/{p-283cd78b.entry.js → p-0ff04742.entry.js} +1 -1
  399. package/dist/webcomponents/p-19c7e6a5.entry.js +1 -0
  400. package/dist/webcomponents/p-2430761e.entry.js +1 -0
  401. package/dist/webcomponents/{p-f01953ea.entry.js → p-2953b537.entry.js} +1 -1
  402. package/dist/webcomponents/{p-f47095cd.entry.js → p-29d05416.entry.js} +1 -1
  403. package/dist/webcomponents/p-2b39ab97.entry.js +1 -0
  404. package/dist/webcomponents/{p-7c51805a.entry.js → p-2d14f144.entry.js} +1 -1
  405. package/dist/webcomponents/{p-1d53f0b8.entry.js → p-2f658457.entry.js} +1 -1
  406. package/dist/webcomponents/{p-08ea8974.entry.js → p-33311d41.entry.js} +1 -1
  407. package/dist/webcomponents/p-35ae3497.entry.js +1 -0
  408. package/dist/webcomponents/{p-6849bf8e.entry.js → p-3fe420c4.entry.js} +1 -1
  409. package/dist/webcomponents/p-402caa84.entry.js +1 -0
  410. package/dist/webcomponents/p-406ebea6.entry.js +1 -0
  411. package/dist/webcomponents/p-42d4ea58.entry.js +1 -0
  412. package/dist/webcomponents/{p-4ba144ac.entry.js → p-431ba789.entry.js} +1 -1
  413. package/dist/webcomponents/{p-a8205044.entry.js → p-44450a94.entry.js} +1 -1
  414. package/dist/webcomponents/{p-28c7bef7.entry.js → p-46b6142b.entry.js} +4 -4
  415. package/dist/webcomponents/p-48e32b40.entry.js +1 -0
  416. package/dist/webcomponents/p-4c3d8cef.entry.js +1 -0
  417. package/dist/webcomponents/p-4e1653c2.entry.js +1 -0
  418. package/dist/webcomponents/{p-df199396.entry.js → p-522e7b24.entry.js} +1 -1
  419. package/dist/webcomponents/p-52cbd667.entry.js +1 -0
  420. package/dist/webcomponents/p-537aa971.entry.js +1 -0
  421. package/dist/webcomponents/{p-ae4297dd.entry.js → p-53daaca6.entry.js} +1 -1
  422. package/dist/webcomponents/{p-7322c86e.entry.js → p-5c17360c.entry.js} +1 -1
  423. package/dist/webcomponents/{p-6e18d13f.entry.js → p-613421d4.entry.js} +1 -1
  424. package/dist/webcomponents/p-62d3d62c.entry.js +1 -0
  425. package/dist/webcomponents/p-63300c63.entry.js +1 -0
  426. package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
  427. package/dist/webcomponents/{p-bea4309d.entry.js → p-67332ff8.entry.js} +1 -1
  428. package/dist/webcomponents/{p-48bccf3b.entry.js → p-70f51444.entry.js} +1 -1
  429. package/dist/webcomponents/p-7186f4a7.entry.js +1 -0
  430. package/dist/webcomponents/p-71f9c48a.entry.js +1 -0
  431. package/dist/webcomponents/p-778e9fe9.entry.js +1 -0
  432. package/dist/webcomponents/p-77948b46.entry.js +1 -0
  433. package/dist/webcomponents/{p-b0bfa20f.entry.js → p-7cf87637.entry.js} +1 -1
  434. package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
  435. package/dist/webcomponents/{p-3d85d046.entry.js → p-80331983.entry.js} +1 -1
  436. package/dist/webcomponents/{p-79055216.entry.js → p-8687e5d6.entry.js} +1 -1
  437. package/dist/webcomponents/{p-a7d5e434.entry.js → p-8d743490.entry.js} +1 -1
  438. package/dist/webcomponents/{p-15777cfe.entry.js → p-8ff839a4.entry.js} +1 -1
  439. package/dist/webcomponents/{p-57143978.entry.js → p-95cbb655.entry.js} +1 -1
  440. package/dist/webcomponents/{p-904a95e5.entry.js → p-9be67b19.entry.js} +1 -1
  441. package/dist/webcomponents/p-9c997d0b.entry.js +1 -0
  442. package/dist/webcomponents/{p-c3a2c619.entry.js → p-9c9a4eb7.entry.js} +1 -1
  443. package/dist/webcomponents/p-9d37b85f.entry.js +1 -0
  444. package/dist/webcomponents/p-9fc567d8.entry.js +1 -0
  445. package/dist/webcomponents/p-B71k50jz.js +1 -0
  446. package/dist/webcomponents/p-BF4U0yVj.js +1 -0
  447. package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
  448. package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
  449. package/dist/webcomponents/p-BSt6p1oq.js +1 -0
  450. package/dist/webcomponents/p-BY1mRAvj.js +1 -0
  451. package/dist/webcomponents/{p-YND5pTuF.js → p-Bb-6bNcq.js} +1 -1
  452. package/dist/webcomponents/p-BbZwa5UI.js +1 -0
  453. package/dist/webcomponents/p-BdKWuCys.js +1 -0
  454. package/dist/webcomponents/p-BfM6X7lF.js +1 -0
  455. package/dist/webcomponents/{p-BbYVgLcf.js → p-BjVfIXWC.js} +1 -1
  456. package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
  457. package/dist/webcomponents/{p-BisQ61nK.js → p-BsGE9UDv.js} +1 -1
  458. package/dist/webcomponents/{p-BeszVz87.js → p-C5id7s_l.js} +1 -1
  459. package/dist/webcomponents/{p-CsNubTqD.js → p-CAJnQLZF.js} +1 -1
  460. package/dist/webcomponents/{p-Bz164TKZ.js → p-CB0mCq1M.js} +1 -1
  461. package/dist/webcomponents/p-CY7N7-0P.js +1 -0
  462. package/dist/webcomponents/p-CaAVuW6B.js +1 -0
  463. package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
  464. package/dist/webcomponents/p-CbL73B6U.js +1 -0
  465. package/dist/webcomponents/p-CpaS1Lex.js +1 -0
  466. package/dist/webcomponents/p-CxLeEBSa.js +1 -0
  467. package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
  468. package/dist/webcomponents/p-DDUmOl3v.js +1 -0
  469. package/dist/webcomponents/p-DIDloHpm.js +1 -0
  470. package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
  471. package/dist/webcomponents/{p-DO3INvI2.js → p-DNo0OPOP.js} +1 -1
  472. package/dist/webcomponents/{p-BTkXk7ol.js → p-DRXvcLy9.js} +1 -1
  473. package/dist/webcomponents/p-Da3idOSV.js +1 -0
  474. package/dist/webcomponents/p-Dgflaz6J.js +1 -0
  475. package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
  476. package/dist/webcomponents/p-DsZZxRXY.js +1 -0
  477. package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
  478. package/dist/webcomponents/p-ED_TzwCp.js +1 -0
  479. package/dist/webcomponents/p-JyHlIFWl.js +1 -0
  480. package/dist/webcomponents/{p-CfF8KKwx.js → p-RvUQ__Pq.js} +1 -1
  481. package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
  482. package/dist/webcomponents/{p-36d72e2d.entry.js → p-a6748a1d.entry.js} +1 -1
  483. package/dist/webcomponents/{p-ded22005.entry.js → p-a7ac285c.entry.js} +1 -1
  484. package/dist/webcomponents/{p-40ba49e4.entry.js → p-aa6194ef.entry.js} +1 -1
  485. package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
  486. package/dist/webcomponents/p-bc45aa92.entry.js +1 -0
  487. package/dist/webcomponents/p-bc81d165.entry.js +1 -0
  488. package/dist/webcomponents/p-c4c88660.entry.js +1 -0
  489. package/dist/webcomponents/p-c8bed49a.entry.js +1 -0
  490. package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
  491. package/dist/webcomponents/{p-cebe360b.entry.js → p-e13d6ed3.entry.js} +1 -1
  492. package/dist/webcomponents/p-e6d1ed81.entry.js +1 -0
  493. package/dist/webcomponents/p-e7b66120.entry.js +1 -0
  494. package/dist/webcomponents/p-e9a5c837.entry.js +1 -0
  495. package/dist/webcomponents/p-eP3fmhta.js +1 -0
  496. package/dist/webcomponents/p-eb2d9e5b.entry.js +1 -0
  497. package/dist/webcomponents/{p-d77908ca.entry.js → p-ed901f9d.entry.js} +1 -1
  498. package/dist/webcomponents/{p-c5b48e8d.entry.js → p-f1cba43c.entry.js} +1 -1
  499. package/dist/webcomponents/{p-828a61b9.entry.js → p-f3c312b1.entry.js} +1 -1
  500. package/dist/webcomponents/p-f499a8de.entry.js +1 -0
  501. package/dist/webcomponents/{p-818f51fd.entry.js → p-f680e617.entry.js} +1 -1
  502. package/dist/webcomponents/p-f849a34e.entry.js +1 -0
  503. package/dist/webcomponents/p-fa1884b4.entry.js +1 -0
  504. package/dist/webcomponents/p-sw5RO19U.js +1 -0
  505. package/dist/webcomponents/{p-BNz6wy4f.js → p-xuDuc7qr.js} +1 -1
  506. package/dist/webcomponents/p-z-5r0gWn.js +1 -0
  507. package/dist/webcomponents/webcomponents.esm.js +1 -1
  508. package/package.json +2 -2
  509. package/dist/cjs/checkout.store-CV_fuGQw.js +0 -39
  510. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -698
  511. package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
  512. package/dist/esm/checkout.store-B60siz2l.js +0 -36
  513. package/dist/esm/justifi-checkout-summary_6.entry.js +0 -691
  514. package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
  515. package/dist/webcomponents/p-0932f6a9.entry.js +0 -1
  516. package/dist/webcomponents/p-09e768fe.entry.js +0 -1
  517. package/dist/webcomponents/p-0dcc83ac.entry.js +0 -1
  518. package/dist/webcomponents/p-131d799c.entry.js +0 -1
  519. package/dist/webcomponents/p-1bdce018.entry.js +0 -1
  520. package/dist/webcomponents/p-1f8cd44e.entry.js +0 -1
  521. package/dist/webcomponents/p-22be0859.entry.js +0 -1
  522. package/dist/webcomponents/p-2f31a4e5.entry.js +0 -1
  523. package/dist/webcomponents/p-3a4ca4df.entry.js +0 -1
  524. package/dist/webcomponents/p-424f491c.entry.js +0 -1
  525. package/dist/webcomponents/p-466f33d7.entry.js +0 -1
  526. package/dist/webcomponents/p-57802e57.entry.js +0 -1
  527. package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
  528. package/dist/webcomponents/p-77515be6.entry.js +0 -1
  529. package/dist/webcomponents/p-7WIgS5RM.js +0 -1
  530. package/dist/webcomponents/p-89e27079.entry.js +0 -1
  531. package/dist/webcomponents/p-8f0339de.entry.js +0 -1
  532. package/dist/webcomponents/p-9106fd74.entry.js +0 -1
  533. package/dist/webcomponents/p-9b75aced.entry.js +0 -1
  534. package/dist/webcomponents/p-BC8YDY7M.js +0 -1
  535. package/dist/webcomponents/p-BVD7g3cE.js +0 -1
  536. package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
  537. package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
  538. package/dist/webcomponents/p-Bt388eye.js +0 -1
  539. package/dist/webcomponents/p-BySyDTv5.js +0 -1
  540. package/dist/webcomponents/p-C1fMfnu0.js +0 -1
  541. package/dist/webcomponents/p-CCME-fyU.js +0 -1
  542. package/dist/webcomponents/p-CLwzqWk2.js +0 -1
  543. package/dist/webcomponents/p-CVQyw7ao.js +0 -1
  544. package/dist/webcomponents/p-C_CXv7AN.js +0 -1
  545. package/dist/webcomponents/p-CwZKT93w.js +0 -1
  546. package/dist/webcomponents/p-D599ZMGU.js +0 -1
  547. package/dist/webcomponents/p-DD74a16D.js +0 -1
  548. package/dist/webcomponents/p-DaDsBt65.js +0 -1
  549. package/dist/webcomponents/p-JgbsbAhz.js +0 -1
  550. package/dist/webcomponents/p-O3LY2Da6.js +0 -1
  551. package/dist/webcomponents/p-WEguiGt1.js +0 -1
  552. package/dist/webcomponents/p-a4172773.entry.js +0 -1
  553. package/dist/webcomponents/p-ae5a3c2a.entry.js +0 -1
  554. package/dist/webcomponents/p-ba8ae31f.entry.js +0 -1
  555. package/dist/webcomponents/p-be06d86a.entry.js +0 -1
  556. package/dist/webcomponents/p-d0e24727.entry.js +0 -1
  557. package/dist/webcomponents/p-dd257e60.entry.js +0 -1
  558. package/dist/webcomponents/p-dd689b5e.entry.js +0 -1
  559. package/dist/webcomponents/p-dd6d6ddb.entry.js +0 -1
  560. package/dist/webcomponents/p-dfd7c212.entry.js +0 -1
  561. package/dist/webcomponents/p-e830a580.entry.js +0 -1
  562. package/dist/webcomponents/p-e859ece8.entry.js +0 -1
  563. package/dist/webcomponents/p-eaea7cc1.entry.js +0 -1
  564. package/dist/webcomponents/p-f3a757b2.entry.js +0 -1
  565. package/dist/webcomponents/p-fa33df9f.entry.js +0 -1
  566. package/dist/webcomponents/p-ff3377e7.entry.js +0 -1
  567. package/dist/webcomponents/p-ff869ded.entry.js +0 -1
  568. package/dist/webcomponents/p-pska2q1M.js +0 -1
  569. package/dist/webcomponents/p-qMrd7_Gp.js +0 -1
  570. package/dist/webcomponents/p-vRhNRfmB.js +0 -1
  571. package/dist/webcomponents/p-zrUQD0Wr.js +0 -1
@@ -1,7 +1,7 @@
1
1
  export * from './Api';
2
2
  export * from './ComponentEvents';
3
3
  export * from './ComponentError';
4
- export * from './Checkout';
4
+ export { Completion, Checkout, ICheckoutPaymentMode, ICheckoutPaymentModeParam, ICheckoutStatus, CompletionStatuses, } from './Checkout';
5
5
  export * from './Insurance';
6
6
  export * from './Pagination';
7
7
  export * from './Payment';
@@ -16,7 +16,6 @@ export * from './Document';
16
16
  export * from './Refund';
17
17
  export * from './Business';
18
18
  export * from './Identity';
19
- export * from './Document';
20
19
  export * from './Dispute';
21
20
  export * from './GrossVolume';
22
21
  // In a future PR I would like to update the naming of the BankAccount Payment Method class in Payment.ts so this import can be updated to be written the same as the others in this file.
@@ -0,0 +1,293 @@
1
+ import { Api } from "../Api";
2
+ import { ApplePaySessionStatus, ApplePayHelpers, ApplePayConfig, ApplePayPaymentRequest, } from "../ApplePay";
3
+ export class ApplePayService {
4
+ constructor() {
5
+ this.api = Api();
6
+ }
7
+ /**
8
+ * Initialize Apple Pay configuration
9
+ */
10
+ initialize(applePayConfig) {
11
+ this.applePayConfig = new ApplePayConfig(applePayConfig);
12
+ if (!this.applePayConfig.isValid) {
13
+ throw new Error('Invalid Apple Pay configuration provided');
14
+ }
15
+ }
16
+ /**
17
+ * Validate merchant with Apple Pay servers via API
18
+ */
19
+ async validateMerchant(authToken, accountId) {
20
+ const endpoint = 'apple_pay/merchant_session';
21
+ try {
22
+ const response = await this.api.post({
23
+ endpoint,
24
+ authToken,
25
+ headers: {
26
+ 'Sub-Account': accountId,
27
+ },
28
+ });
29
+ return response;
30
+ }
31
+ catch (error) {
32
+ console.error('Backend validation failed:', error);
33
+ throw new Error('Merchant validation failed');
34
+ }
35
+ }
36
+ /**
37
+ * Process Apple Pay payment via API (fixed to match original logic)
38
+ */
39
+ async processPayment(authToken, accountId, payload) {
40
+ const endpoint = 'apple_pay/process_token';
41
+ const result = await this.api.post({
42
+ endpoint,
43
+ authToken,
44
+ body: payload,
45
+ headers: {
46
+ 'Sub-Account': accountId,
47
+ },
48
+ });
49
+ return {
50
+ success: result.id && !!result.data.token,
51
+ data: result,
52
+ };
53
+ }
54
+ /**
55
+ * Check if Apple Pay is available on this device/browser
56
+ */
57
+ isAvailable() {
58
+ return (ApplePayHelpers.isApplePaySupported() && ApplePayHelpers.canMakePayments());
59
+ }
60
+ /**
61
+ * Check if the user has an active card for the merchant
62
+ */
63
+ async canMakePaymentsWithActiveCard() {
64
+ if (!this.applePayConfig) {
65
+ throw new Error('Apple Pay not initialized. Call initialize() first.');
66
+ }
67
+ return await ApplePayHelpers.canMakePaymentsWithActiveCard(this.applePayConfig.merchantIdentifier);
68
+ }
69
+ /**
70
+ * Start Apple Pay session
71
+ */
72
+ async startPaymentSession(paymentRequest, authToken, accountId) {
73
+ if (!this.applePayConfig) {
74
+ throw new Error('Apple Pay not initialized. Call initialize() first.');
75
+ }
76
+ // if (!this.isAvailable()) {
77
+ // throw new Error('Apple Pay is not available on this device/browser');
78
+ // }
79
+ const request = new ApplePayPaymentRequest(paymentRequest);
80
+ if (!request.isValid) {
81
+ throw new Error('Invalid payment request provided');
82
+ }
83
+ this.currentPaymentRequest = request;
84
+ return new Promise((resolve, reject) => {
85
+ try {
86
+ this.currentSession = new window.ApplePaySession(3, request);
87
+ this.setupSessionEventHandlers(resolve, reject, authToken, accountId);
88
+ this.currentSession.begin();
89
+ }
90
+ catch (error) {
91
+ reject({
92
+ success: false,
93
+ error: {
94
+ code: 'SESSION_ERROR',
95
+ message: error instanceof Error
96
+ ? error.message
97
+ : 'Failed to start Apple Pay session',
98
+ },
99
+ });
100
+ }
101
+ });
102
+ }
103
+ /**
104
+ * Abort current Apple Pay session
105
+ */
106
+ abortPaymentSession() {
107
+ if (this.currentSession) {
108
+ this.currentSession.abort();
109
+ this.currentSession = undefined;
110
+ this.currentPaymentRequest = undefined;
111
+ }
112
+ }
113
+ /**
114
+ * Setup Apple Pay session event handlers
115
+ */
116
+ setupSessionEventHandlers(resolve, reject, authToken, accountId) {
117
+ if (!this.currentSession ||
118
+ !this.applePayConfig ||
119
+ !this.currentPaymentRequest) {
120
+ return;
121
+ }
122
+ this.currentSession.onvalidatemerchant = async () => {
123
+ try {
124
+ if (!authToken) {
125
+ throw new Error('Authentication token not provided.');
126
+ }
127
+ const merchantSession = await this.validateMerchant(authToken, accountId);
128
+ try {
129
+ this.currentSession.completeMerchantValidation(merchantSession);
130
+ }
131
+ catch (completionError) {
132
+ console.error('Error calling completeMerchantValidation:', completionError);
133
+ throw completionError;
134
+ }
135
+ }
136
+ catch (error) {
137
+ console.error('=== MERCHANT VALIDATION ERROR ===');
138
+ console.error('Error during merchant validation:', error);
139
+ console.error('Error stack:', error.stack);
140
+ this.currentSession.abort();
141
+ reject({
142
+ success: false,
143
+ error: {
144
+ code: 'MERCHANT_VALIDATION_ERROR',
145
+ message: error instanceof Error
146
+ ? error.message
147
+ : 'Merchant validation failed',
148
+ },
149
+ });
150
+ }
151
+ };
152
+ this.currentSession.onpaymentauthorized = async (event) => {
153
+ try {
154
+ const payment = event.payment;
155
+ const paymentPayload = Object.assign(Object.assign({}, payment.token), { product_details: {
156
+ name: this.currentPaymentRequest.total.label,
157
+ price: ApplePayHelpers.parseAmount(this.currentPaymentRequest.total.amount),
158
+ description: this.currentPaymentRequest.total.label,
159
+ } });
160
+ const paymentResult = await this.processPayment(authToken, accountId, paymentPayload);
161
+ if (paymentResult.success) {
162
+ this.currentSession.completePayment({
163
+ status: ApplePaySessionStatus.STATUS_SUCCESS,
164
+ });
165
+ resolve({
166
+ success: true,
167
+ token: payment.token,
168
+ paymentMethodId: paymentResult.data.id,
169
+ });
170
+ }
171
+ else {
172
+ console.error('PSP reported payment failure:', paymentResult.data);
173
+ this.currentSession.completePayment({
174
+ status: ApplePaySessionStatus.STATUS_FAILURE,
175
+ });
176
+ reject({
177
+ success: false,
178
+ error: {
179
+ code: 'PAYMENT_PROCESSING_ERROR',
180
+ message: 'Payment processing failed',
181
+ },
182
+ });
183
+ }
184
+ }
185
+ catch (error) {
186
+ console.error('=== PAYMENT PROCESSING ERROR ===');
187
+ console.error('Error processing payment:', error);
188
+ console.error('Error stack:', error.stack);
189
+ this.currentSession.completePayment({
190
+ status: ApplePaySessionStatus.STATUS_FAILURE,
191
+ });
192
+ reject({
193
+ success: false,
194
+ error: {
195
+ code: 'PAYMENT_PROCESSING_ERROR',
196
+ message: error instanceof Error
197
+ ? error.message
198
+ : 'Payment processing failed',
199
+ },
200
+ });
201
+ }
202
+ finally {
203
+ this.currentSession = undefined;
204
+ this.currentPaymentRequest = undefined;
205
+ }
206
+ };
207
+ this.currentSession.onpaymentmethodselected = () => {
208
+ const paymentUpdate = {
209
+ newTotal: this.currentPaymentRequest.total,
210
+ newLineItems: this.currentPaymentRequest.lineItems || [],
211
+ };
212
+ try {
213
+ this.currentSession.completePaymentMethodSelection(paymentUpdate);
214
+ }
215
+ catch (error) {
216
+ console.error('Error completing payment method selection:', error);
217
+ this.currentSession.abort();
218
+ }
219
+ };
220
+ this.currentSession.onshippingmethodselected = () => {
221
+ this.currentSession.completeShippingMethodSelection({
222
+ status: ApplePaySessionStatus.STATUS_SUCCESS,
223
+ newTotal: this.currentPaymentRequest.total,
224
+ newLineItems: this.currentPaymentRequest.lineItems || [],
225
+ });
226
+ };
227
+ this.currentSession.oncancel = (event) => {
228
+ if (event.sessionError) {
229
+ console.error(event.sessionError);
230
+ switch (event.sessionError.code) {
231
+ case 'unknown':
232
+ console.error('Unknown error - likely merchant validation issue');
233
+ console.error('This usually means:');
234
+ console.error('1. Merchant certificate is invalid or expired');
235
+ console.error('2. Merchant identifier mismatch');
236
+ console.error('3. Backend validation endpoint issues');
237
+ break;
238
+ case 'invalidMerchantSession':
239
+ console.error('Invalid merchant session provided');
240
+ console.error('Check that the merchant session from backend is valid');
241
+ break;
242
+ case 'userCancel':
243
+ console.error('User cancelled the payment');
244
+ break;
245
+ default:
246
+ console.error('Other error code:', event.sessionError.code);
247
+ }
248
+ }
249
+ this.currentSession = undefined;
250
+ this.currentPaymentRequest = undefined;
251
+ reject({
252
+ success: false,
253
+ error: {
254
+ code: 'USER_CANCELLED',
255
+ message: 'User cancelled the Apple Pay session',
256
+ },
257
+ });
258
+ };
259
+ if ('onerror' in this.currentSession) {
260
+ this.currentSession.onerror = (error) => {
261
+ console.error('=== APPLE PAY SESSION ERROR ===');
262
+ console.error('Session error:', error);
263
+ this.currentSession = undefined;
264
+ this.currentPaymentRequest = undefined;
265
+ reject({
266
+ success: false,
267
+ error: {
268
+ code: 'SESSION_ERROR',
269
+ message: 'Apple Pay session error occurred',
270
+ },
271
+ });
272
+ };
273
+ }
274
+ }
275
+ /**
276
+ * Create a basic payment request
277
+ */
278
+ static createPaymentRequest(amount, label, countryCode = 'US', currencyCode = 'USD') {
279
+ return {
280
+ countryCode,
281
+ currencyCode,
282
+ merchantCapabilities: ApplePayHelpers.getDefaultMerchantCapabilities(),
283
+ supportedNetworks: ApplePayHelpers.getDefaultSupportedNetworks(),
284
+ total: ApplePayHelpers.createLineItem(label, amount),
285
+ };
286
+ }
287
+ /**
288
+ * Get current configuration
289
+ */
290
+ getApplePayConfig() {
291
+ return this.applePayConfig;
292
+ }
293
+ }
@@ -0,0 +1,20 @@
1
+ import { Api } from "..";
2
+ const api = Api();
3
+ export class PlaidService {
4
+ async getLinkToken(authToken, accountId, checkoutId, signal) {
5
+ const endpoint = `plaid/${accountId}/link`;
6
+ const body = { checkout_id: checkoutId };
7
+ return api.post({ endpoint, body, authToken, signal });
8
+ }
9
+ async tokenizeBankAccount(authToken, accountId, publicToken, linkTokenId, paymentMethodGroupId, signal) {
10
+ const endpoint = `plaid/${accountId}/tokenize`;
11
+ const body = { public_token: publicToken };
12
+ if (linkTokenId) {
13
+ body.link_token_id = linkTokenId;
14
+ }
15
+ if (paymentMethodGroupId) {
16
+ body.payment_method_group_id = paymentMethodGroupId;
17
+ }
18
+ return api.post({ endpoint, body, authToken, signal });
19
+ }
20
+ }
@@ -0,0 +1 @@
1
+ <svg height="48" viewBox="0 0 28 29" xmlns="http://www.w3.org/2000/svg" class="css-1rdaj8m"><g fill="#111" fill-rule="evenodd"><path d="M25.7629 26.2628L28 17.5309L24.9691 14.5001L27.9999 11.4691L25.7628 2.73706L17.0309 0.5L14.0001 3.531L10.969 0.50014L2.23706 2.73734L0 11.4691L3.03128 14.4999L0.00014 17.531L2.2372 26.2629L10.9691 28.5L14.0001 25.469L17.031 28.4999L25.7629 26.2628ZM15.7321 23.7371L18.6186 20.8505L22.2912 24.5233L17.6956 25.7007L15.7321 23.7371ZM11.1136 9.88154L14.0003 6.99502L16.8868 9.8814L14.0001 12.7679L11.1136 9.88154ZM12.2682 14.5L9.38154 17.3865L6.49502 14.5L9.38154 11.6135L12.2682 14.5ZM18.6187 11.6133L21.5053 14.5L18.6186 17.3865L15.7321 14.5L18.6187 11.6133ZM16.8867 19.1186L14.0001 22.0051L11.1135 19.1185L14.0001 16.2319L16.8867 19.1186ZM10.3044 25.7007L5.70864 24.5233L9.38154 20.8504L12.2682 23.7371L10.3044 25.7007ZM4.76308 16.2319L7.6496 19.1185L3.9767 22.7914L2.7993 18.1957L4.76308 16.2319ZM3.9767 6.20836L7.64974 9.8814L4.76308 12.7681L2.7993 10.8041L3.9767 6.20836ZM12.2683 5.26294L9.38168 8.1496L5.70892 4.4767L10.3047 3.2993L12.2683 5.26294ZM17.6959 3.2993L22.2915 4.4767L18.6186 8.14946L15.7321 5.26294L17.6959 3.2993ZM23.2372 12.7681L20.3505 9.8814L24.0233 6.20878L25.2007 10.8046L23.2372 12.7681ZM24.0233 22.7914L20.3505 19.1186L23.2372 16.2321L25.2007 18.1957L24.0233 22.7914Z"></path></g></svg>
@@ -50,6 +50,7 @@
50
50
  "components/modular-checkout/sub-components/card-billing-form-simple.js",
51
51
  "components/modular-checkout/sub-components/bank-account-billing-form-simple.js",
52
52
  "components/checkout/card-form/card-form.js",
53
+ "ui-components/form/form-control-checkbox.js",
53
54
  "components/checkouts-list/checkouts-list-core.js",
54
55
  "components/checkouts-list/checkouts-list-filters.js",
55
56
  "components/checkouts-list/checkouts-list.js",
@@ -73,9 +74,11 @@
73
74
  "components/gross-payment-chart/gross-payment-chart.js",
74
75
  "components/insurance/season-interruption/season-interruption-insurance.js",
75
76
  "components/modular-checkout/modular-checkout.js",
77
+ "components/modular-checkout/sub-components/apple-pay.js",
76
78
  "components/modular-checkout/sub-components/bank-account.js",
77
79
  "components/modular-checkout/sub-components/card-form.js",
78
80
  "components/modular-checkout/sub-components/payment-method-option.js",
81
+ "components/modular-checkout/sub-components/plaid-payment-method.js",
79
82
  "components/modular-checkout/sub-components/saved-payment-methods.js",
80
83
  "components/modular-checkout/sub-components/sezzle-payment-method.js",
81
84
  "components/modular-checkout/sub-components/summary.js",
@@ -103,7 +106,6 @@
103
106
  "components/terminals-list/terminals-list.js",
104
107
  "components/tokenize-payment-method/tokenize-payment-method.js",
105
108
  "ui-components/custom-popper/custom-popper.js",
106
- "ui-components/form/form-control-checkbox.js",
107
109
  "ui-components/form/form-control-file-v2.js",
108
110
  "ui-components/form/form-control-file.js",
109
111
  "ui-components/form/form-control-monetary.js",
@@ -123,7 +125,7 @@
123
125
  ],
124
126
  "compiler": {
125
127
  "name": "@stencil/core",
126
- "version": "4.36.2",
128
+ "version": "4.36.3",
127
129
  "typescriptVersion": "5.5.4"
128
130
  },
129
131
  "collections": [],
@@ -1,6 +1,7 @@
1
1
  import { h, Host } from "@stencil/core";
2
2
  import BankAccountFormSkeleton from "./bank-account-form-skeleton";
3
3
  import { configState, waitForConfig } from "../../config-provider/config-state";
4
+ import { generateTabId } from "../../../utils/utils";
4
5
  export class BankAccountForm {
5
6
  constructor() {
6
7
  this.isReady = false;
@@ -8,6 +9,7 @@ export class BankAccountForm {
8
9
  async componentWillLoad() {
9
10
  await waitForConfig();
10
11
  this.iframeOrigin = configState.iframeOrigin;
12
+ this.tabId = generateTabId();
11
13
  }
12
14
  componentDidRender() {
13
15
  const elements = [
@@ -31,16 +33,17 @@ export class BankAccountForm {
31
33
  return this.accountNumberIframeElement.tokenize(clientId, paymentMethodMetadata, account);
32
34
  }
33
35
  render() {
34
- return (h(Host, { key: 'b6cdf5a9320d92a5390daaa0a5218274f2dfc178' }, h(BankAccountFormSkeleton, { key: '286fcc38a26820d166ced0bc886143ed3d880da4', isReady: this.isReady }), h("div", { key: '041fcacff70d7cdfc0c8f41258bd9db18703e4c1', class: "container-fluid p-0", style: {
36
+ return (h(Host, { key: '7ee7c6e3c26ab1a90bdbf7215fe13f65aade1025' }, h(BankAccountFormSkeleton, { key: 'e4afc94a21b041972d031cfce88a102f763932d1', isReady: this.isReady }), h("div", { key: '8980e0dc0048dbd9cd93a4f93fab8c4cbfeef611', class: "container-fluid p-0", style: {
35
37
  opacity: this.isReady ? '1' : '0',
36
38
  height: this.isReady ? 'auto' : '0',
37
- } }, h("div", { key: '94dc0eb0d79b40ade96e1961611e3e7a8eef20ea', class: "row mb-3" }, h("iframe-input", { key: '41c82b772e7873a45409e35ed56dfea16c20c2ee', inputId: "accountNumber", ref: (el) => (this.accountNumberIframeElement = el), label: "Account Number", iframeOrigin: `${this.iframeOrigin}/v2/accountNumber` })), h("div", { key: '1c95618a50e2d36a3a9a3a7b691ae0dfa6a09936', class: "row" }, h("iframe-input", { key: '28a4dde70c8f55b4f6bf6ce2d3beee6acbebbc0b', inputId: "routingNumber", ref: (el) => (this.routingNumberIframeElement = el), label: "Routing Number", iframeOrigin: `${this.iframeOrigin}/v2/routingNumber` })))));
39
+ } }, h("div", { key: 'd04bb6b18498de9646ba6e2ee32f223774a72cc7', class: "row mb-3" }, h("iframe-input", { key: '7eb29da8beff34cbe5d2b7c151fec433d17f8555', inputId: "accountNumber", ref: (el) => (this.accountNumberIframeElement = el), label: "Account Number", iframeOrigin: `${this.iframeOrigin}/v2/accountNumber?tabId=${this.tabId}` })), h("div", { key: 'c6345cddc37cbe5627ca4581fb98be55b85550a6', class: "row" }, h("iframe-input", { key: '0bf71a22e9126e04f15f213d84953ccfd3388ef0', inputId: "routingNumber", ref: (el) => (this.routingNumberIframeElement = el), label: "Routing Number", iframeOrigin: `${this.iframeOrigin}/v2/routingNumber?tabId=${this.tabId}` })))));
38
40
  }
39
41
  static get is() { return "bank-account-form"; }
40
42
  static get states() {
41
43
  return {
42
44
  "isReady": {},
43
- "iframeOrigin": {}
45
+ "iframeOrigin": {},
46
+ "tabId": {}
44
47
  };
45
48
  }
46
49
  static get methods() {
@@ -1,6 +1,7 @@
1
1
  import { h, Host } from "@stencil/core";
2
2
  import CardFormSkeleton from "./card-form-skeleton";
3
3
  import { configState, waitForConfig } from "../../config-provider/config-state";
4
+ import { generateTabId } from "../../../utils/utils";
4
5
  export class CardForm {
5
6
  constructor() {
6
7
  this.isReady = false;
@@ -8,6 +9,7 @@ export class CardForm {
8
9
  async componentWillLoad() {
9
10
  await waitForConfig();
10
11
  this.iframeOrigin = configState.iframeOrigin;
12
+ this.tabId = generateTabId();
11
13
  }
12
14
  componentDidRender() {
13
15
  const elements = [
@@ -35,16 +37,17 @@ export class CardForm {
35
37
  return this.cardNumberIframeElement.tokenize(clientId, paymentMethodMetadata, account);
36
38
  }
37
39
  render() {
38
- return (h(Host, { key: 'd5e5c74e5e3be0bb5a9603a89724d23cc6216d6c' }, h(CardFormSkeleton, { key: 'a1e90d74ca6e72678255590a94937932a9520046', isReady: this.isReady }), h("div", { key: 'bb303552ed581492de8ebb0d83cea751ddd90a09', class: "container-fluid p-0", style: {
40
+ return (h(Host, { key: '8a6454e0a16e0a26762627f7a42527ab243c1c7a' }, h(CardFormSkeleton, { key: 'ed7386f746518e1ebb62d1bf9bc2e98778d9804e', isReady: this.isReady }), h("div", { key: 'f3092bcce1626f04a079ebcf64f0cdf06a7029a8', class: "container-fluid p-0", style: {
39
41
  opacity: this.isReady ? '1' : '0',
40
42
  height: this.isReady ? 'auto' : '0',
41
- } }, h("div", { key: '9641c97124a504729b1eba3e8704d8fd3fda7fde', class: "mb-3" }, h("iframe-input", { key: 'a5a73c00c2ac0cd12ef98b155a40108248529fb7', inputId: "cardNumber", ref: (el) => (this.cardNumberIframeElement = el), label: "Card Number", iframeOrigin: `${this.iframeOrigin}/v2/cardNumber` })), h("div", { key: 'dad1b83f028745aa8b85a8e552f702d5daa3ac6f', class: "d-flex align-items-start" }, h("div", { key: '5de05029d93a81d5ad8c799135863e8cdd1e8619', class: "flex-fill me-3" }, h("iframe-input", { key: '4ec81652e51187bbaa25600299f8cb89f0c41c5c', inputId: "expirationMonth", ref: (el) => (this.expirationMonthIframeElement = el), label: "Exp. Month", iframeOrigin: `${this.iframeOrigin}/v2/expirationMonth` })), h("div", { key: '0280f01efdbbfa3542036fa4ee7baec130e42688', class: "flex-fill me-3" }, h("iframe-input", { key: 'b13dba61a6bd18529e70987029592b5b7307e74b', inputId: "expirationYear", ref: (el) => (this.expirationYearIframeElement = el), label: "Exp. Year", iframeOrigin: `${this.iframeOrigin}/v2/expirationYear` })), h("div", { key: 'edf1e383a148a2d535c4733a2b5af2d8e31e2f43', class: "flex-fill" }, h("iframe-input", { key: 'd63e832db1a089f36909db23cacb110f6571535c', inputId: "CVV", ref: (el) => (this.cvvIframeElement = el), label: "CVV", iframeOrigin: `${this.iframeOrigin}/v2/CVV` }))))));
43
+ } }, h("div", { key: '3e211e500bef824aff5b6bf6cdedc99435cacfd4', class: "mb-3" }, h("iframe-input", { key: '6ad14a317fd6cad6d6535ba661684e31c325c5ab', inputId: "cardNumber", ref: (el) => (this.cardNumberIframeElement = el), label: "Card Number", iframeOrigin: `${this.iframeOrigin}/v2/cardNumber?tabId=${this.tabId}` })), h("div", { key: '931e9f1b047ff57c2b37bb2947e29f6708f239d9', class: "d-flex align-items-start" }, h("div", { key: '5ca19fbf9047bd6595557890b0bdbbf0d2e65de9', class: "flex-fill me-3" }, h("iframe-input", { key: 'c99f426b77308b15fcb174e8adbe8c120abc58b5', inputId: "expirationMonth", ref: (el) => (this.expirationMonthIframeElement = el), label: "Exp. Month", iframeOrigin: `${this.iframeOrigin}/v2/expirationMonth?tabId=${this.tabId}` })), h("div", { key: '677b8fb8f33a021afda90a8b4e13b5f44b5fe694', class: "flex-fill me-3" }, h("iframe-input", { key: '9bcf91464c5f2ca77b339f2fe299db6027aa9f8b', inputId: "expirationYear", ref: (el) => (this.expirationYearIframeElement = el), label: "Exp. Year", iframeOrigin: `${this.iframeOrigin}/v2/expirationYear?tabId=${this.tabId}` })), h("div", { key: '9b5c52d9cc5b30eedf522801c3f8f6c0530757ce', class: "flex-fill" }, h("iframe-input", { key: '3e73df1c7119193a239fcd2f5212967e109cff83', inputId: "CVV", ref: (el) => (this.cvvIframeElement = el), label: "CVV", iframeOrigin: `${this.iframeOrigin}/v2/CVV?tabId=${this.tabId}` }))))));
42
44
  }
43
45
  static get is() { return "card-form"; }
44
46
  static get states() {
45
47
  return {
46
48
  "isReady": {},
47
- "iframeOrigin": {}
49
+ "iframeOrigin": {},
50
+ "tabId": {}
48
51
  };
49
52
  }
50
53
  static get methods() {
@@ -1,12 +1,14 @@
1
1
  import { h } from "@stencil/core";
2
2
  import JustifiAnalytics from "../../api/Analytics";
3
+ import { PaymentMethodTypes } from "../../api";
3
4
  import { checkPkgVersion } from "../../utils/check-pkg-version";
4
- import { ComponentErrorCodes, ComponentErrorSeverity } from "../../api/ComponentError";
5
5
  import { checkoutStore } from "../../store/checkout.store";
6
6
  import { checkoutSummary } from "../../styles/parts";
7
7
  import { StyledHost } from "../../ui-components";
8
+ import { PAYMENT_METHODS } from "../modular-checkout/ModularCheckout";
8
9
  export class Checkout {
9
10
  constructor() {
11
+ this.availablePaymentMethods = [];
10
12
  this.errorMessage = '';
11
13
  this.insuranceToggled = false;
12
14
  this.isSubmitting = false; // This is used to prevent multiple submissions and is different from loading state
@@ -36,23 +38,11 @@ export class Checkout {
36
38
  checkoutComplete(_event) {
37
39
  this.isSubmitting = false;
38
40
  }
39
- checkoutError(event) {
41
+ checkoutError(_event) {
40
42
  this.isSubmitting = false;
41
- console.error('checkout error', event.detail);
42
43
  }
43
- async handleTokenizeSubmit(event) {
44
- this.tokenizedPaymentMethod = event.detail.response;
45
- if (event.detail.response.error) {
46
- this.isSubmitting = false;
47
- this.errorEvent.emit({
48
- errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
49
- message: event.detail.response.error.message,
50
- severity: ComponentErrorSeverity.ERROR
51
- });
52
- return;
53
- }
54
- // Now submit the checkout with the tokenized payment method
55
- await this.submitCheckoutWithToken();
44
+ checkoutChanged(event) {
45
+ this.availablePaymentMethods = event.detail.availablePaymentMethodTypes;
56
46
  }
57
47
  async fillBillingForm(fields) {
58
48
  var _a;
@@ -60,12 +50,9 @@ export class Checkout {
60
50
  (_a = this.tokenizePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.fillBillingForm(fields);
61
51
  }
62
52
  async validate() {
63
- var _a, _b, _c;
64
- const tokenizeValidation = await ((_a = this.tokenizePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.validate());
65
- const modularValidation = await ((_b = this.modularCheckoutRef) === null || _b === void 0 ? void 0 : _b.validate());
66
- return {
67
- isValid: ((_c = tokenizeValidation === null || tokenizeValidation === void 0 ? void 0 : tokenizeValidation.isValid) !== null && _c !== void 0 ? _c : true) && (modularValidation !== null && modularValidation !== void 0 ? modularValidation : true)
68
- };
53
+ var _a;
54
+ const modularValidation = await ((_a = this.modularCheckoutRef) === null || _a === void 0 ? void 0 : _a.validate());
55
+ return { isValid: modularValidation };
69
56
  }
70
57
  updateStore() {
71
58
  checkoutStore.checkoutId = this.checkoutId;
@@ -78,24 +65,15 @@ export class Checkout {
78
65
  async submit(_event) {
79
66
  var _a;
80
67
  this.isSubmitting = true;
81
- // Trigger the tokenize payment method submission
82
- (_a = this.tokenizePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.tokenizePaymentMethod();
83
- }
84
- async submitCheckoutWithToken() {
85
- if (!this.tokenizedPaymentMethod || this.tokenizedPaymentMethod.error) {
86
- this.isSubmitting = false;
87
- return;
88
- }
89
- // Set the payment token in the store for the modular checkout to use
90
- checkoutStore.paymentToken = this.tokenizedPaymentMethod.token;
91
- // Submit the checkout
92
- this.modularCheckoutRef.submitCheckout(checkoutStore.billingFormFields);
68
+ (_a = this.modularCheckoutRef) === null || _a === void 0 ? void 0 : _a.submitCheckout(checkoutStore.billingFormFields);
93
69
  }
94
70
  get showPaymentTypeHeader() {
95
71
  return !this.disableCreditCard && !this.disableBankAccount;
96
72
  }
97
73
  render() {
98
- return (h(StyledHost, { key: '516d33e24d351df623d07b8c27113568b2868aa0' }, h("justifi-modular-checkout", { key: 'd75f9484d6b77cf6ddb11f56beaa47ade1dead3f', ref: (el) => (this.modularCheckoutRef = el), authToken: this.authToken, checkoutId: this.checkoutId, savePaymentMethod: checkoutStore.savePaymentMethod }, h("div", { key: '05984eb0fb57e63d2f89d3eb8d37bcaa3e212547', class: "row gy-3 jfi-checkout-core" }, h("div", { key: '4bf6c78f9052118d24c8258c1926ebeccea304ef', class: "col-12", part: checkoutSummary }, h("justifi-header", { key: '772ce7a33a42025e37891dc72bc89ee164dfafa7', text: "Summary", level: "h2", class: "fs-5 fw-bold pb-3" }), h("section", { key: 'abaee0bf9c978fcaff1941cfa61fa08f64312d60' }, h("justifi-checkout-summary", { key: '8833e3a419f769b6df1f73aaf58fa0f3d761e726' }))), h("div", { key: 'a1f4ed10a8c0e87ab229a4d28893e623c6db6162', class: "col-12 mt-4" }, h("slot", { key: 'c80d7f40db60e1b8cf4f408d44f9c0bbe17bcd24', name: "insurance" })), h("div", { key: '1c75a9d0d5cc74cc5a804218960f5be9e3532bbe', class: "col-12 mt-4" }, h("justifi-header", { key: '8800e249bc4d92cf38611eaefc8230ad5f35c447', text: "Payment", level: "h2", class: "fs-5 fw-bold pb-3" }), this.showPaymentTypeHeader && (h("justifi-header", { key: 'bff61808c64fa281230642d385c6081a51276e9d', text: "Select payment type", level: "h3", class: "fs-6 fw-bold lh-lg" })), h("div", { key: '1bfbac09bc3e91d07e2eb003c38cbf2bc3bea1cd', class: "d-flex flex-column" }, h("section", { key: 'd383841d037516896511f72e40d3eb3fd6f9c272' }, h("div", { key: '5440f8343465f39697ca87f3bcdfe3f5fa511685' }, h("justifi-saved-payment-methods", { key: '23ee2270b2ffecd43cc8d608482a4f77d7ce0ee3' }), h("justifi-sezzle-payment-method", { key: '0a5577cb1070563ba5fb7dd8c3b05977ee340bd6' }), h("justifi-tokenize-payment-method", { key: 'd03e8a971e532781c7d9087345fe1b4a8741f492', ref: (el) => (this.tokenizePaymentMethodRef = el), authToken: this.authToken, accountId: checkoutStore.accountId, disableCreditCard: this.disableCreditCard, disableBankAccount: this.disableBankAccount, hideCardBillingForm: this.hideCardBillingForm, hideBankAccountBillingForm: this.hideBankAccountBillingForm, hideSubmitButton: true, paymentMethodGroupId: checkoutStore.paymentMethodGroupId }))))), h("div", { key: '9e488234ee43bed70992e190a23b1faf5fe61308', class: "mt-4" }, h("justifi-button", { key: '31571a8fda37762731679d69b9017e1b553bef8a', text: "Pay", type: "submit", variant: "primary", clickHandler: (e) => this.submit(e), disabled: this.isSubmitting, isLoading: this.isSubmitting, customStyle: { width: '100%', textAlign: "center" } }))))));
74
+ return (h(StyledHost, { key: '61cab7c3b5ca01ea70f35d23df100c2e7bd0c03a' }, h("justifi-modular-checkout", { key: '67ed6c7b2a6bbbec0e24b47b24c2eb73b82abc43', ref: (el) => {
75
+ this.modularCheckoutRef = el;
76
+ }, authToken: this.authToken, checkoutId: this.checkoutId }, h("div", { key: 'b02aaa188db4d619ab3f14a336fe33f4113f2799', class: "row gy-3 jfi-checkout-core" }, h("div", { key: '2c8c019f86bc181d7d05848993ff3782f1fe3ed2', class: "col-12", part: checkoutSummary }, h("justifi-header", { key: '00eb81f75652c80108ad24620b72a977a09192d9', text: "Summary", level: "h2", class: "fs-5 fw-bold pb-3" }), h("section", { key: '346d90b8cca657a1af0eea96244ef105d1274abe' }, h("justifi-checkout-summary", { key: '68784e0b3ef83b6a87d8084fe19dbce7d3348169' }))), h("div", { key: 'bb04ad56ed5074cc272c47e013c7647cc6cf5c2d', class: "col-12 mt-4" }, h("slot", { key: 'a0955737dc7af83b01608abe7818af666ac08d87', name: "insurance" })), h("div", { key: '7025fb6b7ad229879f2198f12a79e07871691b6a', class: "col-12 mt-4" }, h("justifi-header", { key: 'a7823342698429e7845cb341bba2de41f461f6c2', text: "Payment", level: "h2", class: "fs-5 fw-bold pb-3" }), this.showPaymentTypeHeader && (h("justifi-header", { key: 'b579b51c7f6adec31c7e1d39981634328a22b0c2', text: "Select payment type", level: "h3", class: "fs-6 fw-bold lh-lg" })), h("div", { key: '496812c7404b914acc03052018b06b5ebedfd230', class: "d-flex flex-column" }, h("section", { key: '227d6e265d947a5035d8e072b6ea9a87e04faa97' }, h("div", { key: 'b06b49af43c4fce8251c7b227bcc2f2dce5b531a' }, h("justifi-saved-payment-methods", { key: 'd5629c6248d780c5ce8b69c88b4bf866baab2c53' }), this.availablePaymentMethods.includes(PAYMENT_METHODS.SEZZLE) && (h("justifi-radio-list-item", { key: 'dbaf7d54d8c26315faea5537eb821a4a9314d2c4', name: "paymentMethodType", value: PAYMENT_METHODS.SEZZLE, checked: checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.sezzle, label: h("justifi-sezzle-payment-method", { ref: (el) => (this.sezzlePaymentMethodRef = el) }), "onRadio-click": () => { var _a; (_a = this.sezzlePaymentMethodRef) === null || _a === void 0 ? void 0 : _a.handleSelectionClick(); } })), this.availablePaymentMethods.includes(PAYMENT_METHODS.PLAID) && (h("justifi-radio-list-item", { key: 'dad1c44a06f6e60d27d737d36ff68d536244776b', name: "paymentMethodType", value: PAYMENT_METHODS.PLAID, checked: checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.plaid, label: h("justifi-plaid-payment-method", { ref: (el) => (this.plaidPaymentMethodRef = el) }), "onRadio-click": () => { var _a; (_a = this.plaidPaymentMethodRef) === null || _a === void 0 ? void 0 : _a.handleSelectionClick(); } })), h("justifi-tokenize-payment-method", { key: '2bf37f35ae9cb51a6622d4e3f4244359fd40606d', ref: (el) => (this.tokenizePaymentMethodRef = el), authToken: this.authToken, accountId: checkoutStore.accountId, disableCreditCard: this.disableCreditCard, disableBankAccount: this.disableBankAccount, hideCardBillingForm: this.hideCardBillingForm, hideBankAccountBillingForm: this.hideBankAccountBillingForm, hideSubmitButton: true, paymentMethodGroupId: checkoutStore.paymentMethodGroupId }))))), h("div", { key: 'a29f2e940b8c2970d09af0fdce278344cd70833a', class: "mt-4" }, h("justifi-button", { key: '6a076cff574520eaf3303cb4792227365eaf25ae', text: "Pay", type: "submit", variant: "primary", clickHandler: (e) => this.submit(e), disabled: this.isSubmitting, isLoading: this.isSubmitting, customStyle: { width: '100%', textAlign: "center" } }))))));
99
77
  }
100
78
  static get is() { return "justifi-checkout"; }
101
79
  static get properties() {
@@ -262,13 +240,13 @@ export class Checkout {
262
240
  }
263
241
  static get states() {
264
242
  return {
243
+ "availablePaymentMethods": {},
265
244
  "checkout": {},
266
245
  "complete": {},
267
246
  "errorMessage": {},
268
247
  "insuranceToggled": {},
269
248
  "isSubmitting": {},
270
- "serverError": {},
271
- "tokenizedPaymentMethod": {}
249
+ "serverError": {}
272
250
  };
273
251
  }
274
252
  static get events() {
@@ -419,8 +397,8 @@ export class Checkout {
419
397
  "capture": false,
420
398
  "passive": false
421
399
  }, {
422
- "name": "submit-event",
423
- "method": "handleTokenizeSubmit",
400
+ "name": "checkout-changed",
401
+ "method": "checkoutChanged",
424
402
  "target": undefined,
425
403
  "capture": false,
426
404
  "passive": false
@@ -3,6 +3,7 @@ import { StyledHost } from "../../ui-components";
3
3
  import { checkoutStore } from "../../store/checkout.store";
4
4
  export class SaveNewPaymentMethod {
5
5
  constructor() {
6
+ this.label = 'Save New Payment Method';
6
7
  this.isChecked = false;
7
8
  this.handleCheckboxChange = (_name, value) => {
8
9
  this.isChecked = value;
@@ -11,10 +12,34 @@ export class SaveNewPaymentMethod {
11
12
  };
12
13
  }
13
14
  render() {
14
- return (h(StyledHost, { key: 'f23a4f992eef86df7ebfa86f4b46b232456016b2' }, h("div", { key: '0ef7c08423451655318751a6377f0ba8ffda3c7c', class: "mt-4 form-check" }, h("form-control-checkbox", { key: '609527d08abb45603ea683a051cf9c09435fc5bc', label: "Save new payment method", name: "saveNewPaymentMethod", checked: this.isChecked, inputHandler: this.handleCheckboxChange }))));
15
+ return (h(StyledHost, { key: 'c3808f4373067144ded9db353e48fe9cd3df59bc' }, h("form-control-checkbox", { key: '2f104a35497fdc1397c014c4c4ed646f7b389239', label: this.label || 'Save New Payment Method', name: "saveNewPaymentMethod", checked: this.isChecked, inputHandler: this.handleCheckboxChange })));
15
16
  }
16
17
  static get is() { return "justifi-save-new-payment-method"; }
17
18
  static get encapsulation() { return "shadow"; }
19
+ static get properties() {
20
+ return {
21
+ "label": {
22
+ "type": "string",
23
+ "attribute": "label",
24
+ "mutable": false,
25
+ "complexType": {
26
+ "original": "string",
27
+ "resolved": "string",
28
+ "references": {}
29
+ },
30
+ "required": false,
31
+ "optional": true,
32
+ "docs": {
33
+ "tags": [],
34
+ "text": ""
35
+ },
36
+ "getter": false,
37
+ "setter": false,
38
+ "reflect": false,
39
+ "defaultValue": "'Save New Payment Method'"
40
+ }
41
+ };
42
+ }
18
43
  static get states() {
19
44
  return {
20
45
  "isChecked": {}
@@ -118,7 +118,7 @@ export class CheckoutsListCore {
118
118
  return !this.showEmptyState && !this.showErrorState && !this.loading;
119
119
  }
120
120
  render() {
121
- return (h(TableWrapper, { key: 'ac27fa8b086e64e53a287f96be1d1212a7c23fc3' }, h(TableComponent, { key: '965b9e4761f686a254297a753b638952181d9758' }, h(TableHead, { key: '41502bb86d87acd8f730f22705d82a2bb4c3787c' }, h(TableHeadRow, { key: '9aa770a8bbb3c9623fde336580dcecda0ee6909e' }, this.checkoutsTable.columnData.map((column) => column))), h(TableBody, { key: 'ad20f6287a2eefd0aa659925cf4be8a03766c1c2' }, h(TableLoadingState, { key: 'bdd7d89bed12c4451199b59e2793cc3d4dbc24a8', columnSpan: this.checkoutsTable.columnKeys.length, isLoading: this.loading }), h(TableEmptyState, { key: '8b89063a5cc78beb42a52375c431e834583ef12a', isEmpty: this.showEmptyState, columnSpan: this.checkoutsTable.columnKeys.length }), h(TableErrorState, { key: 'a557b0a68af21a5501139433f980a6c083536d71', columnSpan: this.checkoutsTable.columnKeys.length, errorMessage: this.errorMessage }), this.showRowData && this.checkoutsTable.rowData.map((data, index) => (h(TableRow, { "data-test-id": "table-row", "data-row-entity-id": this.entityId[index], onClick: this.rowClickHandler }, data)))), this.paging && (h(TableFoot, { key: '0ba995e692b70214b1f63f3fbb7e05e76f229304' }, h(TableFootRow, { key: '25703345e36b46ce3a4cd9d09893c744b6db4d86' }, h(TableFootCell, { key: '07f5df6019322cb80053e4c061a2b5cb6ba7187e', colSpan: this.checkoutsTable.columnData.length }, h("pagination-menu", { key: 'daf2dd74a5f24192c9052a2906459a6d2b53544d', paging: Object.assign(Object.assign({}, this.paging), { handleClickPrevious: this.handleClickPrevious, handleClickNext: this.handleClickNext }) }))))))));
121
+ return (h(TableWrapper, { key: 'c411d1c3a54fd8a331f0c5cdbae344e231482c0f' }, h(TableComponent, { key: '21774546f3500612497943869017fa7c712dff7e' }, h(TableHead, { key: 'c4e745ead905a393ff1b0cd0fba23db2fcc03ad8' }, h(TableHeadRow, { key: '88063d0baedd1febe0febcab1ccefc512accfd7d' }, this.checkoutsTable.columnData.map((column) => column))), h(TableBody, { key: 'e2534bc13d9e015f127c5396bbe73545d92536b4' }, h(TableLoadingState, { key: '0f0958fa87403652880222365cf7f88dd33335cc', columnSpan: this.checkoutsTable.columnKeys.length, isLoading: this.loading }), h(TableEmptyState, { key: '588bb80d518892791ed2134dd5405940e7c28db7', isEmpty: this.showEmptyState, columnSpan: this.checkoutsTable.columnKeys.length }), h(TableErrorState, { key: '219cce1137232c64b7c9188042c4aaca7e0e91b6', columnSpan: this.checkoutsTable.columnKeys.length, errorMessage: this.errorMessage }), this.showRowData && this.checkoutsTable.rowData.map((data, index) => (h(TableRow, { "data-test-id": "table-row", "data-row-entity-id": this.entityId[index], onClick: this.rowClickHandler }, data)))), this.paging && (h(TableFoot, { key: '16978b3be698ceabd1d19b9eaa3f85c01a862b83' }, h(TableFootRow, { key: 'cd26e5b6f03dff77e09dfb4f9962e7601b2e40dc' }, h(TableFootCell, { key: '508008cf682b393549a839453d4b4c2eee1f67a4', colSpan: this.checkoutsTable.columnData.length }, h("pagination-menu", { key: '688702c35e666def509ccb77b88b88ddd5e0d58a', paging: Object.assign(Object.assign({}, this.paging), { handleClickPrevious: this.handleClickPrevious, handleClickNext: this.handleClickNext }) }))))))));
122
122
  }
123
123
  static get is() { return "checkouts-list-core"; }
124
124
  static get properties() {