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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (465) hide show
  1. package/dist/cjs/{Api-CPuq_15r.js → Api-DyimBzKT.js} +2 -2
  2. package/dist/cjs/{Refund-CqWNG8sx.js → Refund-BefKONu4.js} +6 -3
  3. package/dist/cjs/additional-questions-details_5.cjs.entry.js +3 -3
  4. package/dist/cjs/{badge-CMmPvqtE.js → badge-CcJ9H85-.js} +1 -1
  5. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +7 -7
  6. package/dist/cjs/bank-account-form.cjs.entry.js +9 -6
  7. package/dist/cjs/business-details-core.cjs.entry.js +4 -4
  8. package/dist/cjs/{business.service-C3BdUPlm.js → business.service-BB6zl4Gc.js} +2 -2
  9. package/dist/cjs/{button-CfVQSysQ.js → button-DsHDMHaa.js} +1 -1
  10. package/dist/cjs/card-form.cjs.entry.js +9 -6
  11. package/dist/cjs/{check-pkg-version-D_lazhBQ.js → check-pkg-version-DiQ-d5Nl.js} +9 -3
  12. package/dist/cjs/{checkout.service-B0ZmvWwI.js → checkout.service-B-R80p4f.js} +2 -2
  13. package/dist/cjs/checkout.store-BGvYPPz0.js +88 -0
  14. package/dist/cjs/checkouts-list-core.cjs.entry.js +10 -10
  15. package/dist/cjs/{payments-list-params-state-BNbT1fuJ.js → checkouts-list-params-state-Cewmin_p.js} +1 -1
  16. package/dist/cjs/{checkouts-table-UN5gPpQ_.js → checkouts-table-DjMdEiEW.js} +3 -3
  17. package/dist/cjs/{config-state-5xZf-jax.js → config-state-BBOZIS8x.js} +1 -1
  18. package/dist/cjs/custom-popper_2.cjs.entry.js +1 -1
  19. package/dist/cjs/{dispute.service-DsPEAcDn.js → dispute.service-B5tITFAh.js} +2 -2
  20. package/dist/cjs/form-alert_5.cjs.entry.js +1 -1
  21. package/dist/cjs/form-control-checkbox.cjs.entry.js +3 -3
  22. package/dist/cjs/form-control-date.cjs.entry.js +2 -2
  23. package/dist/cjs/{form-control-error-text-HM0zQerh.js → form-control-error-text-B-P5UDhm.js} +1 -1
  24. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +2 -2
  25. package/dist/cjs/{form-control-help-text-5KIUw1IP.js → form-control-help-text-JoZjhb9m.js} +1 -1
  26. package/dist/cjs/form-control-help-text.cjs.entry.js +1 -1
  27. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +3 -3
  28. package/dist/cjs/form-control-monetary.cjs.entry.js +4 -4
  29. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +2 -2
  30. package/dist/cjs/form-control-number.cjs.entry.js +3 -3
  31. package/dist/cjs/form-control-radio.cjs.entry.js +3 -3
  32. package/dist/cjs/form-control-select_2.cjs.entry.js +2 -2
  33. package/dist/cjs/{get-payment-details-DtCXaIMx.js → get-payment-details-BfgRmNL4.js} +2 -2
  34. package/dist/cjs/{get-subaccounts-CwCH5rC8.js → get-subaccounts-Bnfv2tEN.js} +3 -3
  35. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +4 -4
  36. package/dist/cjs/{header-1-DD41iNlG.js → header-1-DRA3f4Jh.js} +1 -1
  37. package/dist/cjs/{header-3-D9Wa0IfT.js → header-3-sOdOpfx3.js} +1 -1
  38. package/dist/cjs/hidden-input_2.cjs.entry.js +4 -4
  39. package/dist/cjs/{index-Yd9aLenr.js → index-B32W0A3m.js} +1 -1
  40. package/dist/cjs/{index-dm_GlYlb.js → index-C9hBD-32.js} +2 -2
  41. package/dist/cjs/index-D-dD-aC2.js +30 -0
  42. package/dist/cjs/index.cjs.js +8 -0
  43. package/dist/cjs/{insurance-state-Cyva9u6S.js → insurance-state-d2thhXUX.js} +2 -2
  44. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +7 -7
  45. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +8 -8
  46. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +1 -1
  47. package/dist/cjs/justifi-apple-pay.cjs.entry.js +782 -0
  48. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +16 -15
  49. package/dist/cjs/justifi-business-details.cjs.entry.js +10 -10
  50. package/dist/cjs/justifi-business-form.cjs.entry.js +13 -13
  51. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +1 -1
  52. package/dist/cjs/justifi-checkout-summary_7.cjs.entry.js +1421 -0
  53. package/dist/cjs/justifi-checkout.cjs.entry.js +26 -48
  54. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +7 -7
  55. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +13 -13
  56. package/dist/cjs/justifi-config-provider.cjs.entry.js +3 -3
  57. package/dist/cjs/justifi-details.cjs.entry.js +2 -2
  58. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +1 -1
  59. package/dist/cjs/justifi-dispute-management.cjs.entry.js +9 -9
  60. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +12 -12
  61. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +9 -9
  62. package/dist/cjs/justifi-order-terminals.cjs.entry.js +12 -12
  63. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +8 -8
  64. package/dist/cjs/justifi-payment-details.cjs.entry.js +11 -11
  65. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +3 -3
  66. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +9 -9
  67. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +12 -12
  68. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +5 -5
  69. package/dist/cjs/justifi-payments-list.cjs.entry.js +13 -13
  70. package/dist/cjs/justifi-payout-details.cjs.entry.js +10 -10
  71. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +12 -12
  72. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +5 -5
  73. package/dist/cjs/justifi-payouts-list.cjs.entry.js +14 -14
  74. package/dist/cjs/justifi-refund-payment.cjs.entry.js +13 -13
  75. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +1 -1
  76. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +17 -12
  77. package/dist/cjs/justifi-skeleton.cjs.entry.js +3 -3
  78. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +7 -7
  79. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +11 -11
  80. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +7 -7
  81. package/dist/cjs/justifi-terminals-list.cjs.entry.js +13 -13
  82. package/dist/cjs/loader.cjs.js +2 -2
  83. package/dist/cjs/{package-Cp_7Ls2E.js → package-Be2aoTf8.js} +1 -1
  84. package/dist/cjs/pagination-menu.cjs.entry.js +1 -1
  85. package/dist/cjs/payment-details-core.cjs.entry.js +7 -7
  86. package/dist/cjs/payment-method-option.cjs.entry.js +2 -2
  87. package/dist/cjs/{payment.service-1H0VC3LV.js → payment.service-aR96UW5e.js} +2 -2
  88. package/dist/cjs/payments-list-core.cjs.entry.js +11 -11
  89. package/dist/cjs/{payouts-list-params-state-BNbT1fuJ.js → payments-list-params-state-Cewmin_p.js} +1 -1
  90. package/dist/cjs/{payments-status-PB63klt3.js → payments-status-DXRh_ekP.js} +2 -2
  91. package/dist/cjs/{payments-table-quF0NnsS.js → payments-table-BE8u0-i0.js} +3 -3
  92. package/dist/cjs/payout-details-core.cjs.entry.js +8 -8
  93. package/dist/cjs/{payout.service-CIZFU-hV.js → payout.service-6Cl_yXXQ.js} +2 -2
  94. package/dist/cjs/payouts-list-core.cjs.entry.js +11 -11
  95. package/dist/cjs/{checkouts-list-params-state-BNbT1fuJ.js → payouts-list-params-state-Cewmin_p.js} +1 -1
  96. package/dist/cjs/{payouts-status-Bk1JFzbP.js → payouts-status-DxTQZv3i.js} +2 -2
  97. package/dist/cjs/{payouts-table-D_CCTR_k.js → payouts-table-BbydhJUr.js} +3 -3
  98. package/dist/cjs/{skeleton-x-GSs3xk.js → skeleton-C7DQRD6r.js} +1 -1
  99. package/dist/cjs/{spinner-Kb1BFvnL.js → spinner-jmeA44Ee.js} +1 -1
  100. package/dist/cjs/{styled-host-CqQYxX-w.js → styled-host-BfVJlAsJ.js} +1 -1
  101. package/dist/cjs/{table-BJVUhh3s.js → table-Ccdrt0v_.js} +2 -2
  102. package/dist/cjs/table-filters-menu.cjs.entry.js +2 -2
  103. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +10 -10
  104. package/dist/cjs/{terminal-orders-list-params-state-BNbT1fuJ.js → terminal-orders-list-params-state-Cewmin_p.js} +1 -1
  105. package/dist/cjs/{terminal-orders-table-0O5jtzYj.js → terminal-orders-table-B4HjERrK.js} +5 -5
  106. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +1 -1
  107. package/dist/cjs/{terminal.service-DUlyMTrX.js → terminal.service-D1FAYZzd.js} +2 -2
  108. package/dist/cjs/terminals-list-core.cjs.entry.js +10 -10
  109. package/dist/cjs/terminals-list-params-state-Cewmin_p.js +22 -0
  110. package/dist/cjs/{terminals-table-C2BNRUS5.js → terminals-table-C79Xc4FI.js} +3 -3
  111. package/dist/cjs/{utils-Df-pajL7.js → utils-Bzyj4qWe.js} +1 -1
  112. package/dist/cjs/{utils-BaGF9XIe.js → utils-ChCUZgUy.js} +6 -0
  113. package/dist/cjs/webcomponents.cjs.js +3 -3
  114. package/dist/collection/api/ApplePay.js +119 -0
  115. package/dist/collection/api/Payment.js +5 -2
  116. package/dist/collection/api/services/apple-pay.service.js +293 -0
  117. package/dist/collection/api/services/plaid.service.js +20 -0
  118. package/dist/collection/assets/plaid-icon.svg +1 -0
  119. package/dist/collection/collection-manifest.json +3 -1
  120. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +6 -3
  121. package/dist/collection/components/checkout/card-form/card-form.js +6 -3
  122. package/dist/collection/components/checkout/checkout.js +17 -39
  123. package/dist/collection/components/checkout/save-new-payment-method.js +1 -1
  124. package/dist/collection/components/insurance/season-interruption/season-interruption-insurance.js +4 -0
  125. package/dist/collection/components/modular-checkout/ModularCheckout.js +28 -0
  126. package/dist/collection/components/modular-checkout/modular-checkout.js +228 -125
  127. package/dist/collection/components/modular-checkout/sub-components/apple-pay-skeleton.js +10 -0
  128. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +509 -0
  129. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.js +885 -0
  130. package/dist/collection/components/modular-checkout/sub-components/plaid-payment-method.test.js +124 -0
  131. package/dist/collection/components/modular-checkout/sub-components/saved-payment-methods.js +7 -5
  132. package/dist/collection/components/modular-checkout/sub-components/sezzle-payment-method.js +25 -8
  133. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +63 -34
  134. package/dist/collection/index.js +1 -0
  135. package/dist/collection/store/checkout.store.js +46 -2
  136. package/dist/collection/ui-components/apple-pay-button.js +146 -0
  137. package/dist/collection/ui-components/form/form-control-radio.js +5 -5
  138. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +4 -4
  139. package/dist/collection/utils/check-pkg-version.js +6 -0
  140. package/dist/collection/utils/utils.js +5 -0
  141. package/dist/docs.json +1037 -212
  142. package/dist/esm/{Api-N_veT2p6.js → Api-DAWuvzbl.js} +2 -2
  143. package/dist/esm/{Refund-Di6J0oN2.js → Refund-CVh70dXA.js} +7 -4
  144. package/dist/esm/additional-questions-details_5.entry.js +4 -4
  145. package/dist/esm/{badge-D_mzXSCQ.js → badge-DSYSJcRy.js} +2 -2
  146. package/dist/esm/bank-account-document-form-inputs_4.entry.js +8 -8
  147. package/dist/esm/bank-account-form.entry.js +10 -7
  148. package/dist/esm/business-details-core.entry.js +5 -5
  149. package/dist/esm/{business.service-Bdvhdc_d.js → business.service-cQrH5BqF.js} +2 -2
  150. package/dist/esm/{button-CeR8qVS3.js → button-CpllL0At.js} +2 -2
  151. package/dist/esm/card-form.entry.js +10 -7
  152. package/dist/esm/{check-pkg-version-Bb69ihTN.js → check-pkg-version-CAnDiqiu.js} +9 -3
  153. package/dist/esm/{checkout.service-XgGFa7H8.js → checkout.service-Bbgi1I6V.js} +2 -2
  154. package/dist/esm/checkout.store-CCdFOPCK.js +83 -0
  155. package/dist/esm/checkouts-list-core.entry.js +11 -11
  156. package/dist/esm/{checkouts-list-params-state-SMXQIZTt.js → checkouts-list-params-state-D8tzsGR_.js} +1 -1
  157. package/dist/esm/{checkouts-table-CFZYoYjn.js → checkouts-table-Ddf2I-Ul.js} +4 -4
  158. package/dist/esm/{config-state-BrllxiM0.js → config-state-DZeVYerv.js} +1 -1
  159. package/dist/esm/custom-popper_2.entry.js +2 -2
  160. package/dist/esm/{dispute.service-CKPcmwhH.js → dispute.service-CrZsNDW8.js} +2 -2
  161. package/dist/esm/form-alert_5.entry.js +2 -2
  162. package/dist/esm/form-control-checkbox.entry.js +4 -4
  163. package/dist/esm/form-control-date.entry.js +3 -3
  164. package/dist/esm/{form-control-error-text-D3ZwkOv-.js → form-control-error-text-R7U07nTg.js} +2 -2
  165. package/dist/esm/form-control-file-v2_2.entry.js +3 -3
  166. package/dist/esm/{form-control-help-text-C39ZW65w.js → form-control-help-text-CRLH-2f7.js} +2 -2
  167. package/dist/esm/form-control-help-text.entry.js +1 -1
  168. package/dist/esm/form-control-monetary-provisioning.entry.js +4 -4
  169. package/dist/esm/form-control-monetary.entry.js +5 -5
  170. package/dist/esm/form-control-number-masked_2.entry.js +3 -3
  171. package/dist/esm/form-control-number.entry.js +4 -4
  172. package/dist/esm/form-control-radio.entry.js +4 -4
  173. package/dist/esm/form-control-select_2.entry.js +3 -3
  174. package/dist/esm/{get-payment-details-Dt-dr16k.js → get-payment-details-0VzpMNY9.js} +2 -2
  175. package/dist/esm/{get-subaccounts-BsoVLANw.js → get-subaccounts-9UMbyFiT.js} +3 -3
  176. package/dist/esm/gross-payment-chart-core.entry.js +5 -5
  177. package/dist/esm/{header-1-E-hEi3wF.js → header-1-3M9If0gM.js} +2 -2
  178. package/dist/esm/{header-3-Dm7M85kz.js → header-3-CWa41YWq.js} +2 -2
  179. package/dist/esm/hidden-input_2.entry.js +5 -5
  180. package/dist/esm/{index-B9me4yN2.js → index-B_KxSZIF.js} +1 -1
  181. package/dist/esm/{index-kpoIU4v_.js → index-Bn7inNWG.js} +2 -2
  182. package/dist/esm/index-CbL73B6U.js +30 -0
  183. package/dist/esm/index.js +1 -1
  184. package/dist/esm/{insurance-state-CB4l8sOv.js → insurance-state-CTalqbNa.js} +3 -3
  185. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +8 -8
  186. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +9 -9
  187. package/dist/esm/justifi-additional-statement_8.entry.js +2 -2
  188. package/dist/esm/justifi-apple-pay.entry.js +780 -0
  189. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +17 -16
  190. package/dist/esm/justifi-business-details.entry.js +11 -11
  191. package/dist/esm/justifi-business-form.entry.js +14 -14
  192. package/dist/esm/justifi-business-representative-form-inputs.entry.js +2 -2
  193. package/dist/esm/justifi-checkout-summary_7.entry.js +1413 -0
  194. package/dist/esm/justifi-checkout.entry.js +26 -48
  195. package/dist/esm/justifi-checkouts-list-filters.entry.js +8 -8
  196. package/dist/esm/justifi-checkouts-list.entry.js +14 -14
  197. package/dist/esm/justifi-config-provider.entry.js +3 -3
  198. package/dist/esm/justifi-details.entry.js +3 -3
  199. package/dist/esm/justifi-dispute-management-core.entry.js +1 -1
  200. package/dist/esm/justifi-dispute-management.entry.js +9 -9
  201. package/dist/esm/justifi-dispute-notification_3.entry.js +13 -13
  202. package/dist/esm/justifi-gross-payment-chart.entry.js +10 -10
  203. package/dist/esm/justifi-order-terminals.entry.js +13 -13
  204. package/dist/esm/justifi-owner-form_3.entry.js +9 -9
  205. package/dist/esm/justifi-payment-details.entry.js +12 -12
  206. package/dist/esm/justifi-payment-provisioning-core.entry.js +4 -4
  207. package/dist/esm/justifi-payment-provisioning.entry.js +9 -9
  208. package/dist/esm/justifi-payment-transactions-list.entry.js +13 -13
  209. package/dist/esm/justifi-payments-list-filters.entry.js +6 -6
  210. package/dist/esm/justifi-payments-list.entry.js +14 -14
  211. package/dist/esm/justifi-payout-details.entry.js +11 -11
  212. package/dist/esm/justifi-payout-transactions-list.entry.js +13 -13
  213. package/dist/esm/justifi-payouts-list-filters.entry.js +6 -6
  214. package/dist/esm/justifi-payouts-list.entry.js +15 -15
  215. package/dist/esm/justifi-refund-payment.entry.js +14 -14
  216. package/dist/esm/justifi-saved-payment-method.entry.js +2 -2
  217. package/dist/esm/justifi-season-interruption-insurance.entry.js +18 -13
  218. package/dist/esm/justifi-skeleton.entry.js +4 -4
  219. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +8 -8
  220. package/dist/esm/justifi-terminal-orders-list.entry.js +12 -12
  221. package/dist/esm/justifi-terminals-list-filters.entry.js +8 -8
  222. package/dist/esm/justifi-terminals-list.entry.js +14 -14
  223. package/dist/esm/loader.js +3 -3
  224. package/dist/esm/{package-O3LY2Da6.js → package-CnWtPu8L.js} +1 -1
  225. package/dist/esm/pagination-menu.entry.js +2 -2
  226. package/dist/esm/{parts-CfF8KKwx.js → parts-RvUQ__Pq.js} +1 -1
  227. package/dist/esm/payment-details-core.entry.js +8 -8
  228. package/dist/esm/payment-method-option.entry.js +3 -3
  229. package/dist/esm/{payment.service-BWO84KlP.js → payment.service-TxyxCg0E.js} +2 -2
  230. package/dist/esm/payments-list-core.entry.js +12 -12
  231. package/dist/esm/{payments-list-params-state-SMXQIZTt.js → payments-list-params-state-D8tzsGR_.js} +1 -1
  232. package/dist/esm/{payments-status-XoZrlbiZ.js → payments-status-5orNU2Rd.js} +2 -2
  233. package/dist/esm/{payments-table-Dh4P9mTb.js → payments-table-gkJV5GNK.js} +4 -4
  234. package/dist/esm/payout-details-core.entry.js +9 -9
  235. package/dist/esm/{payout.service-Cld6TS5W.js → payout.service-BOwZ4wWh.js} +2 -2
  236. package/dist/esm/payouts-list-core.entry.js +12 -12
  237. package/dist/esm/{payouts-list-params-state-SMXQIZTt.js → payouts-list-params-state-D8tzsGR_.js} +1 -1
  238. package/dist/esm/{payouts-status-Qm2jZG1-.js → payouts-status-CZPwa2AE.js} +2 -2
  239. package/dist/esm/{payouts-table-DMVAZp-r.js → payouts-table-0PtktGRd.js} +4 -4
  240. package/dist/esm/{skeleton-DrHwsgs_.js → skeleton-qMb0_Cjy.js} +2 -2
  241. package/dist/esm/{spinner-XBq6mVJW.js → spinner-DUzyWLhj.js} +2 -2
  242. package/dist/esm/{styled-host-B_XBaM7z.js → styled-host-CTAGIN84.js} +1 -1
  243. package/dist/esm/{table-qqt2Ew5y.js → table-Br3n9Xu-.js} +3 -3
  244. package/dist/esm/table-filters-menu.entry.js +3 -3
  245. package/dist/esm/terminal-orders-list-core.entry.js +11 -11
  246. package/dist/esm/{terminal-orders-list-params-state-SMXQIZTt.js → terminal-orders-list-params-state-D8tzsGR_.js} +1 -1
  247. package/dist/esm/{terminal-orders-table-BN4Co4T8.js → terminal-orders-table-DTBSIMlJ.js} +6 -6
  248. package/dist/esm/terminal-quantity-selector.entry.js +2 -2
  249. package/dist/esm/{terminal.service-DmYCUQcA.js → terminal.service-E6dZlM43.js} +2 -2
  250. package/dist/esm/terminals-list-core.entry.js +11 -11
  251. package/dist/esm/terminals-list-params-state-D8tzsGR_.js +16 -0
  252. package/dist/esm/{terminals-table-C8LczeG_.js → terminals-table-TGUKTi7I.js} +4 -4
  253. package/dist/esm/{utils-lb8p1Exq.js → utils-BscIVFn8.js} +6 -1
  254. package/dist/esm/{utils-kWaZhFAd.js → utils-Dg6gMUTv.js} +2 -2
  255. package/dist/esm/webcomponents.js +4 -4
  256. package/dist/module/Analytics.js +6 -0
  257. package/dist/module/ModularCheckout.js +30 -0
  258. package/dist/module/Refund.js +5 -2
  259. package/dist/module/bank-account-form.js +5 -2
  260. package/dist/module/card-form.js +5 -2
  261. package/dist/module/checkout.store.js +47 -2
  262. package/dist/module/form-control-radio2.js +3 -3
  263. package/dist/module/gross-payment-chart-core2.js +1 -1
  264. package/dist/module/index.js +1 -0
  265. package/dist/module/justifi-apple-pay.d.ts +11 -0
  266. package/dist/module/justifi-apple-pay.js +811 -0
  267. package/dist/module/justifi-checkout.js +63 -75
  268. package/dist/module/justifi-order-terminals.js +1 -1
  269. package/dist/module/justifi-plaid-payment-method.d.ts +11 -0
  270. package/dist/module/justifi-plaid-payment-method.js +6 -0
  271. package/dist/module/justifi-radio-list-item2.js +2 -2
  272. package/dist/module/justifi-season-interruption-insurance.js +5 -1
  273. package/dist/module/modular-checkout.js +179 -101
  274. package/dist/module/package.js +1 -1
  275. package/dist/module/plaid-payment-method.js +687 -0
  276. package/dist/module/save-new-payment-method.js +1 -1
  277. package/dist/module/saved-payment-methods.js +7 -5
  278. package/dist/module/sezzle-payment-method.js +14 -22
  279. package/dist/module/terminals-list-core2.js +1 -1
  280. package/dist/module/tokenize-payment-method.js +44 -34
  281. package/dist/module/utils2.js +6 -1
  282. package/dist/types/api/ApplePay.d.ts +196 -0
  283. package/dist/types/api/Checkout.d.ts +9 -14
  284. package/dist/types/api/Payment.d.ts +4 -3
  285. package/dist/types/api/services/apple-pay.service.d.ts +55 -0
  286. package/dist/types/api/services/plaid.service.d.ts +12 -0
  287. package/dist/types/components/checkout/bank-account-form/bank-account-form.d.ts +1 -0
  288. package/dist/types/components/checkout/card-form/card-form.d.ts +1 -0
  289. package/dist/types/components/checkout/checkout.d.ts +6 -7
  290. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +31 -0
  291. package/dist/types/components/modular-checkout/modular-checkout.d.ts +13 -4
  292. package/dist/types/components/modular-checkout/sub-components/apple-pay-skeleton.d.ts +6 -0
  293. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +39 -0
  294. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.d.ts +80 -0
  295. package/dist/types/components/modular-checkout/sub-components/plaid-payment-method.test.d.ts +1 -0
  296. package/dist/types/components/modular-checkout/sub-components/saved-payment-methods.d.ts +1 -1
  297. package/dist/types/components/modular-checkout/sub-components/sezzle-payment-method.d.ts +1 -1
  298. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +7 -6
  299. package/dist/types/components.d.ts +172 -11
  300. package/dist/types/index.d.ts +2 -0
  301. package/dist/types/store/checkout.store.d.ts +14 -3
  302. package/dist/types/ui-components/apple-pay-button.d.ts +17 -0
  303. package/dist/types/ui-components/form/form-control-radio.d.ts +1 -1
  304. package/dist/types/ui-components/shadow-dom-components/justifi-radio-list-item.d.ts +1 -1
  305. package/dist/types/utils/utils.d.ts +1 -0
  306. package/dist/webcomponents/index.esm.js +1 -0
  307. package/dist/webcomponents/p-0803d130.entry.js +1 -0
  308. package/dist/webcomponents/{p-Dvxpy_P1.js → p-0Om7jLBs.js} +1 -1
  309. package/dist/webcomponents/{p-0932f6a9.entry.js → p-117b7f47.entry.js} +1 -1
  310. package/dist/webcomponents/p-17093105.entry.js +1 -0
  311. package/dist/webcomponents/{p-f01953ea.entry.js → p-1a08b47f.entry.js} +1 -1
  312. package/dist/webcomponents/p-1bcb3852.entry.js +1 -0
  313. package/dist/webcomponents/{p-ae4297dd.entry.js → p-1eb2b847.entry.js} +1 -1
  314. package/dist/webcomponents/{p-dd257e60.entry.js → p-2f7aa249.entry.js} +1 -1
  315. package/dist/webcomponents/{p-28c7bef7.entry.js → p-2fa34c82.entry.js} +4 -4
  316. package/dist/webcomponents/{p-08ea8974.entry.js → p-33311d41.entry.js} +1 -1
  317. package/dist/webcomponents/p-336c31b3.entry.js +1 -0
  318. package/dist/webcomponents/{p-22be0859.entry.js → p-3f33c940.entry.js} +1 -1
  319. package/dist/webcomponents/{p-f3a757b2.entry.js → p-442f86e8.entry.js} +1 -1
  320. package/dist/webcomponents/{p-a8205044.entry.js → p-44450a94.entry.js} +1 -1
  321. package/dist/webcomponents/{p-cebe360b.entry.js → p-464e7a8e.entry.js} +1 -1
  322. package/dist/webcomponents/{p-ba8ae31f.entry.js → p-50392803.entry.js} +1 -1
  323. package/dist/webcomponents/p-52cbd667.entry.js +1 -0
  324. package/dist/webcomponents/{p-ded22005.entry.js → p-54ca3070.entry.js} +1 -1
  325. package/dist/webcomponents/{p-77515be6.entry.js → p-5ad0f438.entry.js} +1 -1
  326. package/dist/webcomponents/{p-6e18d13f.entry.js → p-613421d4.entry.js} +1 -1
  327. package/dist/webcomponents/{p-9b75aced.entry.js → p-62d12566.entry.js} +1 -1
  328. package/dist/webcomponents/p-65ed60bf.entry.js +1 -0
  329. package/dist/webcomponents/p-6cf30a24.entry.js +1 -0
  330. package/dist/webcomponents/{p-48bccf3b.entry.js → p-70f51444.entry.js} +1 -1
  331. package/dist/webcomponents/{p-a4172773.entry.js → p-729dbd8f.entry.js} +1 -1
  332. package/dist/webcomponents/p-77948b46.entry.js +1 -0
  333. package/dist/webcomponents/{p-1d53f0b8.entry.js → p-7bcfaff4.entry.js} +1 -1
  334. package/dist/webcomponents/{p-b0bfa20f.entry.js → p-7cf87637.entry.js} +1 -1
  335. package/dist/webcomponents/{p-dfd7c212.entry.js → p-7dd74e6f.entry.js} +1 -1
  336. package/dist/webcomponents/{p-I8XpD1TX.js → p-7s1gsXM5.js} +1 -1
  337. package/dist/webcomponents/{p-3d85d046.entry.js → p-80331983.entry.js} +1 -1
  338. package/dist/webcomponents/{p-d0e24727.entry.js → p-85f20746.entry.js} +1 -1
  339. package/dist/webcomponents/{p-79055216.entry.js → p-8687e5d6.entry.js} +1 -1
  340. package/dist/webcomponents/p-89ecd650.entry.js +1 -0
  341. package/dist/webcomponents/p-8a6718b6.entry.js +1 -0
  342. package/dist/webcomponents/p-8d6b81ba.entry.js +1 -0
  343. package/dist/webcomponents/{p-a7d5e434.entry.js → p-8d743490.entry.js} +1 -1
  344. package/dist/webcomponents/{p-8f0339de.entry.js → p-8f7396b1.entry.js} +1 -1
  345. package/dist/webcomponents/{p-15777cfe.entry.js → p-8ff839a4.entry.js} +1 -1
  346. package/dist/webcomponents/{p-57143978.entry.js → p-95cbb655.entry.js} +1 -1
  347. package/dist/webcomponents/{p-ae5a3c2a.entry.js → p-98cffba9.entry.js} +1 -1
  348. package/dist/webcomponents/{p-4ba144ac.entry.js → p-9a2c044f.entry.js} +1 -1
  349. package/dist/webcomponents/{p-904a95e5.entry.js → p-9be67b19.entry.js} +1 -1
  350. package/dist/webcomponents/{p-df199396.entry.js → p-9e8021a1.entry.js} +1 -1
  351. package/dist/webcomponents/{p-131d799c.entry.js → p-9fc0ea58.entry.js} +1 -1
  352. package/dist/webcomponents/p-9fc567d8.entry.js +1 -0
  353. package/dist/webcomponents/{p-424f491c.entry.js → p-9fcff84c.entry.js} +1 -1
  354. package/dist/webcomponents/p-B71k50jz.js +1 -0
  355. package/dist/webcomponents/p-BF4U0yVj.js +1 -0
  356. package/dist/webcomponents/{p-zdIeCUeh.js → p-BHf9IqGw.js} +1 -1
  357. package/dist/webcomponents/p-BQ2TIFoY.js +1 -0
  358. package/dist/webcomponents/p-BSt6p1oq.js +1 -0
  359. package/dist/webcomponents/p-BY1mRAvj.js +1 -0
  360. package/dist/webcomponents/{p-YND5pTuF.js → p-Bb-6bNcq.js} +1 -1
  361. package/dist/webcomponents/p-BbZwa5UI.js +1 -0
  362. package/dist/webcomponents/p-BdKWuCys.js +1 -0
  363. package/dist/webcomponents/p-BfM6X7lF.js +1 -0
  364. package/dist/webcomponents/{p-BbYVgLcf.js → p-BjVfIXWC.js} +1 -1
  365. package/dist/webcomponents/{p-kpoIU4v_.js → p-Bn7inNWG.js} +1 -1
  366. package/dist/webcomponents/{p-BisQ61nK.js → p-BsGE9UDv.js} +1 -1
  367. package/dist/webcomponents/{p-BeszVz87.js → p-C5id7s_l.js} +1 -1
  368. package/dist/webcomponents/{p-CsNubTqD.js → p-CAJnQLZF.js} +1 -1
  369. package/dist/webcomponents/{p-Bz164TKZ.js → p-CB0mCq1M.js} +1 -1
  370. package/dist/webcomponents/p-CaAVuW6B.js +1 -0
  371. package/dist/webcomponents/p-Cb0FhuyU.js +1 -0
  372. package/dist/webcomponents/p-CbL73B6U.js +1 -0
  373. package/dist/webcomponents/p-CnWtPu8L.js +1 -0
  374. package/dist/webcomponents/p-CpaS1Lex.js +1 -0
  375. package/dist/webcomponents/p-DD0Mvpeu.js +1 -0
  376. package/dist/webcomponents/p-DDUmOl3v.js +1 -0
  377. package/dist/webcomponents/p-DIDloHpm.js +1 -0
  378. package/dist/webcomponents/p-DIjoBk44.js +1 -0
  379. package/dist/webcomponents/{p-UD2JhYS2.js → p-DK2sRMlx.js} +1 -1
  380. package/dist/webcomponents/{p-DO3INvI2.js → p-DNo0OPOP.js} +1 -1
  381. package/dist/webcomponents/{p-BTkXk7ol.js → p-DRXvcLy9.js} +1 -1
  382. package/dist/webcomponents/{p-BNz6wy4f.js → p-DZYcH7jA.js} +1 -1
  383. package/dist/webcomponents/p-Da3idOSV.js +1 -0
  384. package/dist/webcomponents/p-Dgflaz6J.js +1 -0
  385. package/dist/webcomponents/{p-9y5MOK55.js → p-DhGNCW2f.js} +1 -1
  386. package/dist/webcomponents/p-DsZZxRXY.js +1 -0
  387. package/dist/webcomponents/{p-CRFzwZW6.js → p-DxqCFDtF.js} +1 -1
  388. package/dist/webcomponents/p-ED_TzwCp.js +1 -0
  389. package/dist/webcomponents/p-JyHlIFWl.js +1 -0
  390. package/dist/webcomponents/{p-CfF8KKwx.js → p-RvUQ__Pq.js} +1 -1
  391. package/dist/webcomponents/{p-DWUnL_zj.js → p-Wh1V0gvF.js} +1 -1
  392. package/dist/webcomponents/{p-c3a2c619.entry.js → p-a55f07af.entry.js} +1 -1
  393. package/dist/webcomponents/{p-40ba49e4.entry.js → p-aa6194ef.entry.js} +1 -1
  394. package/dist/webcomponents/{p-d77908ca.entry.js → p-ab6a5dc9.entry.js} +1 -1
  395. package/dist/webcomponents/{p-463ae23a.entry.js → p-abbf14b5.entry.js} +1 -1
  396. package/dist/webcomponents/{p-283cd78b.entry.js → p-af9c4174.entry.js} +1 -1
  397. package/dist/webcomponents/{p-f47095cd.entry.js → p-b7d2f2eb.entry.js} +1 -1
  398. package/dist/webcomponents/p-bbc4b4cb.entry.js +1 -0
  399. package/dist/webcomponents/{p-36d72e2d.entry.js → p-c599e526.entry.js} +1 -1
  400. package/dist/webcomponents/{p-5e10aa65.entry.js → p-d46dbb83.entry.js} +1 -1
  401. package/dist/webcomponents/{p-6849bf8e.entry.js → p-d62cd269.entry.js} +1 -1
  402. package/dist/webcomponents/{p-ff3377e7.entry.js → p-d9dd7d24.entry.js} +1 -1
  403. package/dist/webcomponents/p-dd7352da.entry.js +1 -0
  404. package/dist/webcomponents/{p-7c51805a.entry.js → p-e8a67dc7.entry.js} +1 -1
  405. package/dist/webcomponents/p-eP3fmhta.js +1 -0
  406. package/dist/webcomponents/p-eb2d9e5b.entry.js +1 -0
  407. package/dist/webcomponents/{p-1f8cd44e.entry.js → p-eddaca4e.entry.js} +1 -1
  408. package/dist/webcomponents/{p-9106fd74.entry.js → p-ef32fe0e.entry.js} +1 -1
  409. package/dist/webcomponents/{p-c5b48e8d.entry.js → p-f1cba43c.entry.js} +1 -1
  410. package/dist/webcomponents/{p-e830a580.entry.js → p-f1f0b405.entry.js} +1 -1
  411. package/dist/webcomponents/p-f499a8de.entry.js +1 -0
  412. package/dist/webcomponents/{p-828a61b9.entry.js → p-f4d0cdf0.entry.js} +1 -1
  413. package/dist/webcomponents/{p-818f51fd.entry.js → p-f680e617.entry.js} +1 -1
  414. package/dist/webcomponents/{p-bea4309d.entry.js → p-f7c4222f.entry.js} +1 -1
  415. package/dist/webcomponents/p-fa1884b4.entry.js +1 -0
  416. package/dist/webcomponents/p-sw5RO19U.js +1 -0
  417. package/dist/webcomponents/p-z-5r0gWn.js +1 -0
  418. package/dist/webcomponents/webcomponents.esm.js +1 -1
  419. package/package.json +2 -2
  420. package/dist/cjs/checkout.store-CV_fuGQw.js +0 -39
  421. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +0 -698
  422. package/dist/cjs/terminals-list-params-state-BNbT1fuJ.js +0 -22
  423. package/dist/esm/checkout.store-B60siz2l.js +0 -36
  424. package/dist/esm/justifi-checkout-summary_6.entry.js +0 -691
  425. package/dist/esm/terminals-list-params-state-SMXQIZTt.js +0 -16
  426. package/dist/webcomponents/p-09e768fe.entry.js +0 -1
  427. package/dist/webcomponents/p-0dcc83ac.entry.js +0 -1
  428. package/dist/webcomponents/p-1bdce018.entry.js +0 -1
  429. package/dist/webcomponents/p-2f31a4e5.entry.js +0 -1
  430. package/dist/webcomponents/p-3a4ca4df.entry.js +0 -1
  431. package/dist/webcomponents/p-466f33d7.entry.js +0 -1
  432. package/dist/webcomponents/p-57802e57.entry.js +0 -1
  433. package/dist/webcomponents/p-5rVtZ2GJ.js +0 -1
  434. package/dist/webcomponents/p-7322c86e.entry.js +0 -1
  435. package/dist/webcomponents/p-7WIgS5RM.js +0 -1
  436. package/dist/webcomponents/p-89e27079.entry.js +0 -1
  437. package/dist/webcomponents/p-BC8YDY7M.js +0 -1
  438. package/dist/webcomponents/p-BVD7g3cE.js +0 -1
  439. package/dist/webcomponents/p-Bb6FBEPP.js +0 -1
  440. package/dist/webcomponents/p-Bpcb3SsP.js +0 -1
  441. package/dist/webcomponents/p-Bt388eye.js +0 -1
  442. package/dist/webcomponents/p-BySyDTv5.js +0 -1
  443. package/dist/webcomponents/p-C1fMfnu0.js +0 -1
  444. package/dist/webcomponents/p-CCME-fyU.js +0 -1
  445. package/dist/webcomponents/p-CLwzqWk2.js +0 -1
  446. package/dist/webcomponents/p-CVQyw7ao.js +0 -1
  447. package/dist/webcomponents/p-C_CXv7AN.js +0 -1
  448. package/dist/webcomponents/p-CwZKT93w.js +0 -1
  449. package/dist/webcomponents/p-D599ZMGU.js +0 -1
  450. package/dist/webcomponents/p-DD74a16D.js +0 -1
  451. package/dist/webcomponents/p-DaDsBt65.js +0 -1
  452. package/dist/webcomponents/p-JgbsbAhz.js +0 -1
  453. package/dist/webcomponents/p-O3LY2Da6.js +0 -1
  454. package/dist/webcomponents/p-WEguiGt1.js +0 -1
  455. package/dist/webcomponents/p-be06d86a.entry.js +0 -1
  456. package/dist/webcomponents/p-dd689b5e.entry.js +0 -1
  457. package/dist/webcomponents/p-dd6d6ddb.entry.js +0 -1
  458. package/dist/webcomponents/p-e859ece8.entry.js +0 -1
  459. package/dist/webcomponents/p-eaea7cc1.entry.js +0 -1
  460. package/dist/webcomponents/p-fa33df9f.entry.js +0 -1
  461. package/dist/webcomponents/p-ff869ded.entry.js +0 -1
  462. package/dist/webcomponents/p-pska2q1M.js +0 -1
  463. package/dist/webcomponents/p-qMrd7_Gp.js +0 -1
  464. package/dist/webcomponents/p-vRhNRfmB.js +0 -1
  465. package/dist/webcomponents/p-zrUQD0Wr.js +0 -1
@@ -1,14 +1,44 @@
1
- import { h, Host } from "@stencil/core";
2
- import { checkoutStore, onChange } from "../../store/checkout.store";
1
+ import { h, Host, } from "@stencil/core";
2
+ import { checkoutStore, onAnyChange, getAvailablePaymentMethodTypes } from "../../store/checkout.store";
3
3
  import JustifiAnalytics from "../../api/Analytics";
4
4
  import { checkPkgVersion } from "../../utils/check-pkg-version";
5
- import { ComponentErrorCodes, ComponentErrorMessages, ComponentErrorSeverity, ICheckoutStatus } from "../../api";
6
- import { makeCheckoutComplete, makeGetCheckout } from "../../actions/checkout/checkout-actions";
5
+ import { ComponentErrorCodes, ComponentErrorMessages, ComponentErrorSeverity, ICheckoutStatus, PaymentMethodTypes, } from "../../api";
6
+ import { makeCheckoutComplete, makeGetCheckout, } from "../../actions/checkout/checkout-actions";
7
7
  import { CheckoutService } from "../../api/services/checkout.service";
8
8
  import { insuranceValues, insuranceValuesOn, hasInsuranceValueChanged } from "../insurance/insurance-state";
9
+ import { PAYMENT_MODE } from "./ModularCheckout";
9
10
  export class ModularCheckout {
10
11
  constructor() {
11
12
  this.savePaymentMethod = false;
13
+ this.handleApplePayCompleted = (event) => {
14
+ const { success, token, paymentMethodId, error } = event.detail;
15
+ if (success && token) {
16
+ checkoutStore.paymentToken = paymentMethodId;
17
+ checkoutStore.selectedPaymentMethod = { type: PaymentMethodTypes.applePay };
18
+ this.submitCheckout();
19
+ }
20
+ else {
21
+ console.error("Apple Pay completed but failed:", error);
22
+ this.errorEvent.emit({
23
+ message: (error === null || error === void 0 ? void 0 : error.message) || "Apple Pay payment failed",
24
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
25
+ severity: ComponentErrorSeverity.ERROR,
26
+ });
27
+ }
28
+ };
29
+ this.handleApplePayError = (event) => {
30
+ const { error } = event.detail;
31
+ console.error("Apple Pay error:", error);
32
+ this.errorEvent.emit({
33
+ message: error || "Apple Pay error occurred",
34
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
35
+ severity: ComponentErrorSeverity.ERROR,
36
+ });
37
+ };
38
+ this.handleApplePayCancelled = () => {
39
+ checkoutStore.paymentToken = undefined;
40
+ checkoutStore.selectedPaymentMethod = undefined;
41
+ };
12
42
  }
13
43
  savePaymentMethodChanged(newValue) {
14
44
  checkoutStore.savePaymentMethod = newValue;
@@ -16,39 +46,33 @@ export class ModularCheckout {
16
46
  connectedCallback() {
17
47
  this.observer = new MutationObserver(() => {
18
48
  this.queryFormRefs();
49
+ this.setupApplePayListeners(); // set up again listeners when DOM changes
19
50
  });
20
51
  this.observer.observe(this.hostEl, {
21
52
  childList: true,
22
- subtree: true
53
+ subtree: true,
23
54
  });
24
55
  checkoutStore.checkoutId = this.checkoutId;
25
56
  const config = {
26
57
  authToken: this.authToken,
27
58
  checkoutId: this.checkoutId,
28
- service: new CheckoutService()
59
+ service: new CheckoutService(),
29
60
  };
30
61
  this.getCheckout = makeGetCheckout(config);
31
62
  this.completeCheckout = makeCheckoutComplete(config);
32
- onChange('selectedPaymentMethod', (newValue) => {
33
- this.paymentMethodChangedEvent.emit(newValue);
63
+ // Emit checkout-changed whenever any store key changes
64
+ onAnyChange(() => {
65
+ this.emitCheckoutChanged();
34
66
  });
35
67
  }
36
68
  componentWillLoad() {
37
- if (!this.authToken || !this.checkoutId) {
38
- this.errorEvent.emit({
39
- message: ComponentErrorMessages.NOT_AUTHENTICATED,
40
- errorCode: ComponentErrorCodes.NOT_AUTHENTICATED,
41
- severity: ComponentErrorSeverity.ERROR,
42
- });
43
- return;
44
- }
45
69
  this.analytics = new JustifiAnalytics(this);
46
70
  checkPkgVersion();
47
71
  checkoutStore.authToken = this.authToken;
48
72
  checkoutStore.savePaymentMethod = this.savePaymentMethod;
49
73
  this.fetchCheckout();
50
74
  // Refresh the checkout data when insurance values actually change (not on initial load)
51
- insuranceValuesOn('set', (key) => {
75
+ insuranceValuesOn("set", (key) => {
52
76
  const value = insuranceValues[key];
53
77
  if (value !== undefined && hasInsuranceValueChanged(key, value)) {
54
78
  this.fetchCheckout();
@@ -57,15 +81,26 @@ export class ModularCheckout {
57
81
  }
58
82
  componentDidLoad() {
59
83
  this.queryFormRefs();
84
+ this.setupApplePayListeners();
60
85
  }
61
86
  disconnectedCallback() {
62
87
  var _a;
63
88
  (_a = this.observer) === null || _a === void 0 ? void 0 : _a.disconnect();
89
+ this.removeApplePayListeners();
64
90
  }
65
91
  fetchCheckout() {
92
+ if (!this.authToken || !this.checkoutId) {
93
+ this.errorEvent.emit({
94
+ message: ComponentErrorMessages.NOT_AUTHENTICATED,
95
+ errorCode: ComponentErrorCodes.NOT_AUTHENTICATED,
96
+ severity: ComponentErrorSeverity.ERROR,
97
+ });
98
+ return;
99
+ }
66
100
  if (this.getCheckout) {
67
101
  this.getCheckout({
68
102
  onSuccess: ({ checkout }) => {
103
+ this.updateStore(checkout);
69
104
  if (checkout.status === ICheckoutStatus.completed) {
70
105
  this.errorEvent.emit({
71
106
  message: ComponentErrorMessages.CHECKOUT_ALREADY_COMPLETED,
@@ -82,7 +117,6 @@ export class ModularCheckout {
82
117
  });
83
118
  return;
84
119
  }
85
- this.updateStore(checkout);
86
120
  },
87
121
  onError: (error) => {
88
122
  this.errorEvent.emit({
@@ -90,12 +124,12 @@ export class ModularCheckout {
90
124
  errorCode: ComponentErrorCodes.FETCH_ERROR,
91
125
  severity: ComponentErrorSeverity.ERROR,
92
126
  });
93
- }
127
+ },
94
128
  });
95
129
  }
96
130
  }
97
131
  updateStore(checkout) {
98
- var _a, _b, _c, _d;
132
+ var _a, _b, _c, _d, _e;
99
133
  checkoutStore.accountId = checkout.account_id;
100
134
  checkoutStore.paymentMethods = checkout.payment_methods;
101
135
  checkoutStore.paymentMethodGroupId = checkout.payment_method_group_id;
@@ -103,119 +137,165 @@ export class ModularCheckout {
103
137
  checkoutStore.totalAmount = checkout.total_amount;
104
138
  checkoutStore.paymentAmount = checkout.payment_amount;
105
139
  checkoutStore.bnplEnabled = checkout.payment_settings.bnpl_payments;
106
- checkoutStore.bnplProviderClientId = (_a = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _a === void 0 ? void 0 : _a.provider_client_id;
107
- checkoutStore.bnplProviderMode = (_b = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _b === void 0 ? void 0 : _b.provider_mode;
108
- checkoutStore.bnplProviderApiVersion = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_api_version;
109
- checkoutStore.bnplProviderCheckoutUrl = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_checkout_url;
140
+ checkoutStore.insuranceEnabled = checkout.payment_settings.insurance_payments;
141
+ checkoutStore.bankAccountVerification = (_a = checkout.payment_settings) === null || _a === void 0 ? void 0 : _a.bank_account_verification;
142
+ checkoutStore.bnplProviderClientId = (_b = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _b === void 0 ? void 0 : _b.provider_client_id;
143
+ checkoutStore.bnplProviderMode = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_mode;
144
+ checkoutStore.bnplProviderApiVersion = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_api_version;
145
+ checkoutStore.bnplProviderCheckoutUrl =
146
+ (_e = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _e === void 0 ? void 0 : _e.provider_checkout_url;
147
+ }
148
+ emitCheckoutChanged() {
149
+ const detail = {
150
+ availablePaymentMethodTypes: getAvailablePaymentMethodTypes(),
151
+ selectedPaymentMethod: checkoutStore.selectedPaymentMethod,
152
+ savedPaymentMethods: checkoutStore.paymentMethods,
153
+ };
154
+ this.checkoutChangedEvent.emit(detail);
110
155
  }
111
156
  queryFormRefs() {
112
- this.paymentMethodFormRef = this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form');
113
- this.billingFormRef = this.hostEl.querySelector('justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full');
157
+ this.billingFormRef = this.hostEl.querySelector("justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full");
158
+ this.applePayRef = this.hostEl.querySelector("justifi-apple-pay");
159
+ this.paymentMethodFormRef =
160
+ this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form, justifi-tokenize-payment-method');
114
161
  this.insuranceFormRef = this.hostEl.querySelector('justifi-season-interruption-insurance');
115
- this.sezzlePaymentMethodRef = this.hostEl.querySelector('justifi-sezzle-payment-method');
162
+ }
163
+ setupApplePayListeners() {
164
+ if (this.applePayRef) {
165
+ this.applePayRef.addEventListener("applePayCompleted", this.handleApplePayCompleted);
166
+ this.applePayRef.addEventListener("applePayError", this.handleApplePayError);
167
+ this.applePayRef.addEventListener("applePayCancelled", this.handleApplePayCancelled);
168
+ }
169
+ }
170
+ removeApplePayListeners() {
171
+ if (this.applePayRef) {
172
+ this.applePayRef.removeEventListener("applePayCompleted", this.handleApplePayCompleted);
173
+ this.applePayRef.removeEventListener("applePayError", this.handleApplePayError);
174
+ this.applePayRef.removeEventListener("applePayCancelled", this.handleApplePayCancelled);
175
+ }
116
176
  }
117
177
  async tokenizePaymentMethod(tokenizeArgs) {
118
178
  var _a, _b, _c;
119
- const billingInfoValues = (_b = await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues())) !== null && _b !== void 0 ? _b : {};
179
+ const billingInfoValues = (_b = (await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues()))) !== null && _b !== void 0 ? _b : {};
120
180
  const combinedBillingInfo = Object.assign(Object.assign({}, tokenizeArgs), billingInfoValues);
121
181
  const paymentMethodMetadata = Object.assign({ accountId: checkoutStore.accountId, payment_method_group_id: undefined }, combinedBillingInfo);
122
182
  if (checkoutStore.savePaymentMethod) {
123
- paymentMethodMetadata.payment_method_group_id = checkoutStore.paymentMethodGroupId;
183
+ paymentMethodMetadata.payment_method_group_id =
184
+ checkoutStore.paymentMethodGroupId;
124
185
  }
125
- return (_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
186
+ const tokenizeResult = await ((_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
126
187
  clientId: this.authToken,
127
188
  paymentMethodMetadata,
128
189
  account: checkoutStore.accountId,
129
- });
130
- }
131
- async getPaymentMethod(submitCheckoutArgs) {
132
- // If we have a payment token from the store (set by tokenize-payment-method), use it
133
- if (checkoutStore.paymentToken) {
134
- return checkoutStore.paymentToken;
190
+ }));
191
+ if (tokenizeResult.error) {
192
+ return tokenizeResult;
135
193
  }
136
- // Fallback to the original tokenization logic for backward compatibility
137
- if (!this.paymentMethodFormRef) {
138
- return checkoutStore.selectedPaymentMethod;
139
- }
140
- const { error, id: token } = await this.tokenizePaymentMethod(submitCheckoutArgs);
141
- if (error) {
142
- this.errorEvent.emit({
143
- errorCode: error.code,
144
- message: error.message,
145
- severity: ComponentErrorSeverity.ERROR,
146
- });
147
- return undefined;
148
- }
149
- return token;
194
+ checkoutStore.paymentToken = tokenizeResult.id;
195
+ return tokenizeResult.id;
196
+ }
197
+ // set the selected payment method to the checkout store from outside the component
198
+ async setSelectedPaymentMethod(paymentMethod) {
199
+ checkoutStore.selectedPaymentMethod = paymentMethod;
150
200
  }
201
+ // getAvailablePaymentMethods removed in favor of checkout-changed event
202
+ // if validation fails, the error will be emitted by the component
151
203
  async validate() {
152
- var _a, _b;
153
- console.log('billing information form', this.billingFormRef);
154
- console.log('payment method form', this.paymentMethodFormRef);
155
- console.log('insurance form', this.insuranceFormRef);
156
- console.log('sezzle payment method', this.sezzlePaymentMethodRef);
157
- const promises = [
158
- (_a = this.paymentMethodFormRef) === null || _a === void 0 ? void 0 : _a.validate(),
159
- (_b = this.billingFormRef) === null || _b === void 0 ? void 0 : _b.validate()
160
- ];
161
- if (this.insuranceFormRef) {
204
+ const promises = [];
205
+ if (checkoutStore.insuranceEnabled && this.insuranceFormRef) {
162
206
  promises.push(this.insuranceFormRef.validate());
163
207
  }
164
- const validationResults = await Promise.all(promises);
165
- return validationResults.every(result => (result === null || result === void 0 ? void 0 : result.isValid) !== false);
166
- }
167
- async submitCheckout(submitCheckoutArgs) {
168
- var _a;
169
- const isValid = await this.validate();
170
- if (!isValid) {
171
- this.errorEvent.emit({
172
- message: 'Please fill in all required fields.',
173
- errorCode: ComponentErrorCodes.VALIDATION_ERROR,
174
- severity: ComponentErrorSeverity.ERROR,
175
- });
176
- return;
208
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card && checkoutStore.selectedPaymentMethod.id === undefined;
209
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount && checkoutStore.selectedPaymentMethod.id === undefined;
210
+ // For new card/bank account, validate payment method + billing.
211
+ if (isNewCard ||
212
+ isNewBankAccount) {
213
+ if (this.paymentMethodFormRef)
214
+ promises.push(this.paymentMethodFormRef.validate());
215
+ if (this.billingFormRef)
216
+ promises.push(this.billingFormRef.validate());
177
217
  }
178
- let payment;
179
- if (checkoutStore.selectedPaymentMethod === 'sezzle') {
180
- const insuranceValidation = this.insuranceFormRef ? await this.insuranceFormRef.validate() : { isValid: true };
181
- const sezzleResult = await this.sezzlePaymentMethodRef.resolvePaymentMethod(insuranceValidation);
182
- if (sezzleResult.error) {
218
+ if (promises.length === 0)
219
+ return true;
220
+ try {
221
+ const results = await Promise.all(promises);
222
+ // Normalize different validator return shapes:
223
+ // - boolean -> use it directly
224
+ // - object -> look for isValid; treat missing isValid as falsey only if explicitly false
225
+ const resultsAreValid = results.every(r => typeof r === 'boolean' ? r : (r === null || r === void 0 ? void 0 : r.isValid) !== false);
226
+ if (!resultsAreValid) {
183
227
  this.errorEvent.emit({
184
- message: sezzleResult.error.message,
185
- errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
228
+ message: 'Validation error',
229
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
186
230
  severity: ComponentErrorSeverity.ERROR,
187
231
  });
188
- return;
189
- }
190
- else if (((_a = sezzleResult.bnpl) === null || _a === void 0 ? void 0 : _a.status) === 'success') {
191
- payment = {
192
- payment_mode: 'bnpl',
193
- payment_token: undefined,
194
- };
232
+ return false;
195
233
  }
234
+ return true;
196
235
  }
197
- else {
198
- const paymentMethod = await this.getPaymentMethod(submitCheckoutArgs);
199
- if (!paymentMethod) {
236
+ catch (_a) {
237
+ // If any validator throws/rejects, consider the whole validation failed.
238
+ return false;
239
+ }
240
+ }
241
+ async submitCheckout(submitCheckoutArgs) {
242
+ const isValid = await this.validate();
243
+ const isNewCard = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.card &&
244
+ checkoutStore.selectedPaymentMethod.id === undefined;
245
+ const isNewBankAccount = checkoutStore.selectedPaymentMethod.type === PaymentMethodTypes.bankAccount &&
246
+ checkoutStore.selectedPaymentMethod.id === undefined;
247
+ const shouldTokenize = isNewCard || isNewBankAccount;
248
+ if (shouldTokenize) {
249
+ const tokenizeResult = await this.tokenizePaymentMethod(submitCheckoutArgs);
250
+ if (tokenizeResult === null || tokenizeResult === void 0 ? void 0 : tokenizeResult.error) {
200
251
  this.errorEvent.emit({
201
- message: 'Payment method tokenization failed.',
252
+ message: tokenizeResult.error.message,
202
253
  errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
203
254
  severity: ComponentErrorSeverity.ERROR,
204
255
  });
205
256
  return;
206
257
  }
207
- ;
208
- payment = {
209
- payment_mode: 'ecom',
210
- payment_token: paymentMethod,
211
- };
212
258
  }
259
+ if (!isValid) {
260
+ this.errorEvent.emit({
261
+ message: "Please fill in all required fields.",
262
+ errorCode: ComponentErrorCodes.VALIDATION_ERROR,
263
+ severity: ComponentErrorSeverity.ERROR,
264
+ });
265
+ return;
266
+ }
267
+ if (!checkoutStore.paymentToken) {
268
+ this.errorEvent.emit({
269
+ message: 'Payment token not found.',
270
+ errorCode: ComponentErrorCodes.TOKENIZE_ERROR,
271
+ severity: ComponentErrorSeverity.ERROR,
272
+ });
273
+ }
274
+ let payment;
275
+ const mapTypeToPaymentMode = (type) => {
276
+ switch (type) {
277
+ case PaymentMethodTypes.card:
278
+ case PaymentMethodTypes.bankAccount:
279
+ case PaymentMethodTypes.plaid:
280
+ return PAYMENT_MODE.ECOM;
281
+ case PaymentMethodTypes.sezzle:
282
+ return PAYMENT_MODE.BNPL;
283
+ case PaymentMethodTypes.applePay:
284
+ return PAYMENT_MODE.APPLE_PAY;
285
+ default:
286
+ return undefined;
287
+ }
288
+ };
289
+ payment = {
290
+ payment_mode: mapTypeToPaymentMode(checkoutStore.selectedPaymentMethod.type),
291
+ payment_token: checkoutStore.paymentToken,
292
+ };
213
293
  this.completeCheckout({
214
294
  payment,
215
295
  onSuccess: ({ checkout }) => {
216
296
  this.submitEvent.emit({
217
297
  checkout,
218
- message: 'Checkout completed successfully',
298
+ message: "Checkout completed successfully",
219
299
  });
220
300
  },
221
301
  onError: (error) => {
@@ -227,11 +307,8 @@ export class ModularCheckout {
227
307
  },
228
308
  });
229
309
  }
230
- async setSelectedPaymentMethod(paymentMethodId) {
231
- checkoutStore.selectedPaymentMethod = paymentMethodId;
232
- }
233
310
  render() {
234
- return (h(Host, { key: 'd454d321b1a7a6e3b4097c94fbb05e02ce3e36a9' }));
311
+ return h(Host, { key: '4df5d1aa50fbeee7da93f8e19e45f6907b6ae2c7' });
235
312
  }
236
313
  static get is() { return "justifi-modular-checkout"; }
237
314
  static get properties() {
@@ -328,8 +405,8 @@ export class ModularCheckout {
328
405
  "references": {}
329
406
  }
330
407
  }, {
331
- "method": "paymentMethodChangedEvent",
332
- "name": "payment-method-changed",
408
+ "method": "checkoutChangedEvent",
409
+ "name": "checkout-changed",
333
410
  "bubbles": true,
334
411
  "cancelable": true,
335
412
  "composed": true,
@@ -338,69 +415,95 @@ export class ModularCheckout {
338
415
  "text": ""
339
416
  },
340
417
  "complexType": {
341
- "original": "string",
342
- "resolved": "string",
343
- "references": {}
418
+ "original": "CheckoutChangedEventDetail",
419
+ "resolved": "CheckoutChangedEventDetail",
420
+ "references": {
421
+ "CheckoutChangedEventDetail": {
422
+ "location": "import",
423
+ "path": "./ModularCheckout",
424
+ "id": "src/components/modular-checkout/ModularCheckout.ts::CheckoutChangedEventDetail"
425
+ }
426
+ }
344
427
  }
345
428
  }];
346
429
  }
347
430
  static get methods() {
348
431
  return {
349
- "validate": {
432
+ "setSelectedPaymentMethod": {
350
433
  "complexType": {
351
- "signature": "() => Promise<boolean>",
352
- "parameters": [],
434
+ "signature": "(paymentMethod: ICheckoutPaymentMethod | { type: PaymentMethodTypes; }) => Promise<void>",
435
+ "parameters": [{
436
+ "name": "paymentMethod",
437
+ "type": "ICheckoutPaymentMethod | { type: PaymentMethodTypes; }",
438
+ "docs": ""
439
+ }],
353
440
  "references": {
354
441
  "Promise": {
355
442
  "location": "global",
356
443
  "id": "global::Promise"
444
+ },
445
+ "ICheckoutPaymentMethod": {
446
+ "location": "import",
447
+ "path": "../../api",
448
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
449
+ },
450
+ "PaymentMethodTypes": {
451
+ "location": "import",
452
+ "path": "../../api",
453
+ "id": "src/api/index.ts::PaymentMethodTypes"
357
454
  }
358
455
  },
359
- "return": "Promise<boolean>"
456
+ "return": "Promise<void>"
360
457
  },
361
458
  "docs": {
362
459
  "text": "",
363
460
  "tags": []
364
461
  }
365
462
  },
366
- "submitCheckout": {
463
+ "validate": {
367
464
  "complexType": {
368
- "signature": "(submitCheckoutArgs?: BillingFormFields) => Promise<void>",
369
- "parameters": [{
370
- "name": "submitCheckoutArgs",
371
- "type": "BillingFormFields",
372
- "docs": ""
373
- }],
465
+ "signature": "() => Promise<boolean>",
466
+ "parameters": [],
374
467
  "references": {
375
468
  "Promise": {
376
469
  "location": "global",
377
470
  "id": "global::Promise"
378
471
  },
379
- "BillingFormFields": {
472
+ "ICheckoutPaymentMethod": {
380
473
  "location": "import",
381
- "path": "../../components",
382
- "id": "src/components.d.ts::BillingFormFields"
474
+ "path": "../../api",
475
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
383
476
  }
384
477
  },
385
- "return": "Promise<void>"
478
+ "return": "Promise<boolean>"
386
479
  },
387
480
  "docs": {
388
481
  "text": "",
389
482
  "tags": []
390
483
  }
391
484
  },
392
- "setSelectedPaymentMethod": {
485
+ "submitCheckout": {
393
486
  "complexType": {
394
- "signature": "(paymentMethodId: string) => Promise<void>",
487
+ "signature": "(submitCheckoutArgs?: BillingFormFields) => Promise<void>",
395
488
  "parameters": [{
396
- "name": "paymentMethodId",
397
- "type": "string",
489
+ "name": "submitCheckoutArgs",
490
+ "type": "BillingFormFields",
398
491
  "docs": ""
399
492
  }],
400
493
  "references": {
401
494
  "Promise": {
402
495
  "location": "global",
403
496
  "id": "global::Promise"
497
+ },
498
+ "BillingFormFields": {
499
+ "location": "import",
500
+ "path": "../../components",
501
+ "id": "src/components.d.ts::BillingFormFields"
502
+ },
503
+ "ICheckoutPaymentMethod": {
504
+ "location": "import",
505
+ "path": "../../api",
506
+ "id": "src/api/index.ts::ICheckoutPaymentMethod"
404
507
  }
405
508
  },
406
509
  "return": "Promise<void>"
@@ -0,0 +1,10 @@
1
+ import { h } from "@stencil/core";
2
+ import { Skeleton } from "../../../ui-components";
3
+ const ApplePaySkeleton = (props) => {
4
+ const { isReady } = props;
5
+ if (isReady) {
6
+ return null;
7
+ }
8
+ return (h("div", { class: 'container-fluid p-0' }, h("div", { class: 'row mb-3' }, h("div", { class: 'col-12 align-content-center' }, h(Skeleton, { height: '44px', width: '100%', styles: { borderRadius: "8px" } })))));
9
+ };
10
+ export default ApplePaySkeleton;