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

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 (360) hide show
  1. package/dist/cjs/bank-account-document-form-inputs_4.cjs.entry.js +2 -2
  2. package/dist/cjs/{check-pkg-version-BfmeLSXP.js → check-pkg-version-BNVGE27p.js} +1 -1
  3. package/dist/cjs/{checkout.store-Cn3Jj5gi.js → checkout.store-CV_fuGQw.js} +0 -1
  4. package/dist/cjs/custom-popper_2.cjs.entry.js +2 -2
  5. package/dist/cjs/form-control-checkbox.cjs.entry.js +2 -2
  6. package/dist/cjs/form-control-date.cjs.entry.js +2 -2
  7. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +3 -3
  8. package/dist/cjs/form-control-monetary.cjs.entry.js +2 -2
  9. package/dist/cjs/form-control-number-masked_2.cjs.entry.js +2 -2
  10. package/dist/cjs/form-control-number.cjs.entry.js +2 -2
  11. package/dist/cjs/form-control-radio.cjs.entry.js +2 -2
  12. package/dist/cjs/form-control-select_2.cjs.entry.js +2 -2
  13. package/dist/cjs/hidden-input_2.cjs.entry.js +5 -5
  14. package/dist/cjs/justifi-bank-account-billing-form-simple_9.cjs.entry.js +8 -8
  15. package/dist/cjs/justifi-business-details.cjs.entry.js +2 -2
  16. package/dist/cjs/justifi-business-form.cjs.entry.js +2 -2
  17. package/dist/cjs/justifi-checkout-summary_6.cjs.entry.js +12 -99
  18. package/dist/cjs/justifi-checkout.cjs.entry.js +3 -3
  19. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +2 -2
  20. package/dist/cjs/justifi-dispute-management.cjs.entry.js +2 -2
  21. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +2 -2
  22. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +2 -2
  23. package/dist/cjs/justifi-order-terminals.cjs.entry.js +3 -3
  24. package/dist/cjs/justifi-payment-details.cjs.entry.js +2 -2
  25. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +2 -2
  26. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +3 -3
  27. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +2 -2
  28. package/dist/cjs/justifi-payments-list.cjs.entry.js +3 -3
  29. package/dist/cjs/justifi-payout-details.cjs.entry.js +2 -2
  30. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +3 -3
  31. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +2 -2
  32. package/dist/cjs/justifi-payouts-list.cjs.entry.js +3 -3
  33. package/dist/cjs/justifi-refund-payment.cjs.entry.js +2 -2
  34. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +3 -3
  35. package/dist/cjs/justifi-skeleton.cjs.entry.js +1 -1
  36. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +2 -2
  37. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +3 -3
  38. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +1 -1
  39. package/dist/cjs/justifi-terminals-list.cjs.entry.js +3 -3
  40. package/dist/cjs/loader.cjs.js +1 -1
  41. package/dist/cjs/{package-CuNDvHTB.js → package-BKILqyp3.js} +1 -1
  42. package/dist/cjs/payment-details-core.cjs.entry.js +8 -8
  43. package/dist/cjs/payment-method-option.cjs.entry.js +1 -1
  44. package/dist/cjs/payments-list-core.cjs.entry.js +1 -1
  45. package/dist/cjs/payout-details-core.cjs.entry.js +3 -3
  46. package/dist/cjs/payouts-list-core.cjs.entry.js +1 -1
  47. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +1 -1
  48. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +1 -1
  49. package/dist/cjs/terminals-list-core.cjs.entry.js +1 -1
  50. package/dist/cjs/webcomponents.cjs.js +1 -1
  51. package/dist/collection/collection-manifest.json +0 -1
  52. package/dist/collection/components/modular-checkout/modular-checkout.js +5 -92
  53. package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
  54. package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
  55. package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
  56. package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
  57. package/dist/collection/components/order-terminals/order-terminals.js +1 -1
  58. package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
  59. package/dist/collection/components/payment-details/payment-details-core.js +8 -8
  60. package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
  61. package/dist/collection/components/payments-list/payments-list-core.js +1 -1
  62. package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
  63. package/dist/collection/components/payments-list/payments-list.js +1 -1
  64. package/dist/collection/components/payout-details/payout-details-core.js +3 -3
  65. package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
  66. package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
  67. package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
  68. package/dist/collection/components/payouts-list/payouts-list.js +1 -1
  69. package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
  70. package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
  71. package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
  72. package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
  73. package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
  74. package/dist/collection/components/terminals-list/terminals-list.js +1 -1
  75. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +2 -2
  76. package/dist/collection/store/checkout.store.js +0 -1
  77. package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
  78. package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
  79. package/dist/collection/ui-components/form/form-control-date.js +2 -2
  80. package/dist/collection/ui-components/form/form-control-file-v2.js +1 -1
  81. package/dist/collection/ui-components/form/form-control-file.js +2 -2
  82. package/dist/collection/ui-components/form/form-control-monetary.js +2 -2
  83. package/dist/collection/ui-components/form/form-control-number-masked.js +2 -2
  84. package/dist/collection/ui-components/form/form-control-number.js +2 -2
  85. package/dist/collection/ui-components/form/form-control-radio.js +2 -2
  86. package/dist/collection/ui-components/form/form-control-text.js +2 -2
  87. package/dist/collection/ui-components/form/form-control-textarea.js +2 -2
  88. package/dist/collection/ui-components/form/hidden-input.js +1 -1
  89. package/dist/collection/ui-components/form/iframe-input.js +3 -3
  90. package/dist/collection/ui-components/shadow-dom-components/justifi-button.js +1 -1
  91. package/dist/collection/ui-components/shadow-dom-components/justifi-header.js +1 -1
  92. package/dist/collection/ui-components/shadow-dom-components/justifi-skeleton.js +1 -1
  93. package/dist/docs.json +1 -463
  94. package/dist/esm/additional-questions-details_5.entry.js +2 -2
  95. package/dist/esm/{badge-D4ZXPFjL.js → badge-D_mzXSCQ.js} +1 -1
  96. package/dist/esm/bank-account-document-form-inputs_4.entry.js +5 -5
  97. package/dist/esm/bank-account-form.entry.js +2 -2
  98. package/dist/esm/business-details-core.entry.js +3 -3
  99. package/dist/esm/{button-C0wLsDP3.js → button-CeR8qVS3.js} +1 -1
  100. package/dist/esm/card-form.entry.js +2 -2
  101. package/dist/esm/{check-pkg-version-BuYkk-jV.js → check-pkg-version-CaWUVat7.js} +1 -1
  102. package/dist/esm/{checkout.store-OAv_iY1u.js → checkout.store-B60siz2l.js} +0 -1
  103. package/dist/esm/checkouts-list-core.entry.js +5 -5
  104. package/dist/esm/{checkouts-table-DjGKtqoc.js → checkouts-table-CFZYoYjn.js} +2 -2
  105. package/dist/esm/custom-popper_2.entry.js +3 -3
  106. package/dist/esm/form-alert_5.entry.js +1 -1
  107. package/dist/esm/form-control-checkbox.entry.js +5 -5
  108. package/dist/esm/form-control-date.entry.js +4 -4
  109. package/dist/esm/{form-control-error-text-Bzfs_rxk.js → form-control-error-text-D3ZwkOv-.js} +1 -1
  110. package/dist/esm/form-control-file-v2_2.entry.js +5 -5
  111. package/dist/esm/{form-control-help-text-ueLctOBN.js → form-control-help-text-C39ZW65w.js} +1 -1
  112. package/dist/esm/form-control-monetary-provisioning.entry.js +3 -3
  113. package/dist/esm/form-control-monetary.entry.js +5 -5
  114. package/dist/esm/form-control-number-masked_2.entry.js +4 -4
  115. package/dist/esm/form-control-number.entry.js +5 -5
  116. package/dist/esm/form-control-radio.entry.js +3 -3
  117. package/dist/esm/form-control-select_2.entry.js +4 -4
  118. package/dist/esm/gross-payment-chart-core.entry.js +3 -3
  119. package/dist/esm/{header-1-BMKEv9y6.js → header-1-E-hEi3wF.js} +1 -1
  120. package/dist/esm/{header-3-C3t3m27b.js → header-3-Dm7M85kz.js} +1 -1
  121. package/dist/esm/hidden-input_2.entry.js +7 -7
  122. package/dist/esm/{insurance-state-d4hjThzE.js → insurance-state-CB4l8sOv.js} +1 -1
  123. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +3 -3
  124. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +2 -2
  125. package/dist/esm/justifi-additional-statement_8.entry.js +1 -1
  126. package/dist/esm/justifi-bank-account-billing-form-simple_9.entry.js +12 -12
  127. package/dist/esm/justifi-business-details.entry.js +4 -4
  128. package/dist/esm/justifi-business-form.entry.js +6 -6
  129. package/dist/esm/justifi-business-representative-form-inputs.entry.js +1 -1
  130. package/dist/esm/justifi-checkout-summary_6.entry.js +16 -103
  131. package/dist/esm/justifi-checkout.entry.js +4 -4
  132. package/dist/esm/justifi-checkouts-list-filters.entry.js +1 -1
  133. package/dist/esm/justifi-checkouts-list.entry.js +5 -5
  134. package/dist/esm/justifi-details.entry.js +2 -2
  135. package/dist/esm/justifi-dispute-management.entry.js +2 -2
  136. package/dist/esm/justifi-dispute-notification_3.entry.js +5 -5
  137. package/dist/esm/justifi-gross-payment-chart.entry.js +4 -4
  138. package/dist/esm/justifi-order-terminals.entry.js +5 -5
  139. package/dist/esm/justifi-owner-form_3.entry.js +2 -2
  140. package/dist/esm/justifi-payment-details.entry.js +4 -4
  141. package/dist/esm/justifi-payment-provisioning-core.entry.js +2 -2
  142. package/dist/esm/justifi-payment-provisioning.entry.js +2 -2
  143. package/dist/esm/justifi-payment-transactions-list.entry.js +6 -6
  144. package/dist/esm/justifi-payments-list-filters.entry.js +3 -3
  145. package/dist/esm/justifi-payments-list.entry.js +7 -7
  146. package/dist/esm/justifi-payout-details.entry.js +4 -4
  147. package/dist/esm/justifi-payout-transactions-list.entry.js +6 -6
  148. package/dist/esm/justifi-payouts-list-filters.entry.js +3 -3
  149. package/dist/esm/justifi-payouts-list.entry.js +7 -7
  150. package/dist/esm/justifi-refund-payment.entry.js +5 -5
  151. package/dist/esm/justifi-saved-payment-method.entry.js +1 -1
  152. package/dist/esm/justifi-season-interruption-insurance.entry.js +6 -6
  153. package/dist/esm/justifi-skeleton.entry.js +3 -3
  154. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +3 -3
  155. package/dist/esm/justifi-terminal-orders-list.entry.js +6 -6
  156. package/dist/esm/justifi-terminals-list-filters.entry.js +2 -2
  157. package/dist/esm/justifi-terminals-list.entry.js +6 -6
  158. package/dist/esm/loader.js +1 -1
  159. package/dist/esm/{package-C60pS6qh.js → package-BF-uL8B4.js} +1 -1
  160. package/dist/esm/pagination-menu.entry.js +1 -1
  161. package/dist/esm/{parts-RvUQ__Pq.js → parts-CfF8KKwx.js} +1 -1
  162. package/dist/esm/payment-details-core.entry.js +13 -13
  163. package/dist/esm/payment-method-option.entry.js +2 -2
  164. package/dist/esm/payments-list-core.entry.js +7 -7
  165. package/dist/esm/{payments-status-1yRdTNeS.js → payments-status-XoZrlbiZ.js} +1 -1
  166. package/dist/esm/{payments-table-8RADYkma.js → payments-table-Dh4P9mTb.js} +2 -2
  167. package/dist/esm/payout-details-core.entry.js +9 -9
  168. package/dist/esm/payouts-list-core.entry.js +7 -7
  169. package/dist/esm/{payouts-status-BqsQVtBp.js → payouts-status-Qm2jZG1-.js} +1 -1
  170. package/dist/esm/{payouts-table-DPw7yIx8.js → payouts-table-DMVAZp-r.js} +2 -2
  171. package/dist/esm/{skeleton-BmTjpTYa.js → skeleton-DrHwsgs_.js} +1 -1
  172. package/dist/esm/{spinner-YGDOI-CS.js → spinner-XBq6mVJW.js} +1 -1
  173. package/dist/esm/table-filters-menu.entry.js +2 -2
  174. package/dist/esm/{table-ybHxxc9f.js → table-qqt2Ew5y.js} +2 -2
  175. package/dist/esm/terminal-orders-list-core.entry.js +6 -6
  176. package/dist/esm/{terminal-orders-table-D-xP5WuM.js → terminal-orders-table-BN4Co4T8.js} +2 -2
  177. package/dist/esm/terminal-quantity-selector.entry.js +2 -2
  178. package/dist/esm/terminals-list-core.entry.js +6 -6
  179. package/dist/esm/{terminals-table-DVAPCgEr.js → terminals-table-C8LczeG_.js} +2 -2
  180. package/dist/esm/{utils-DG5aMFmf.js → utils-kWaZhFAd.js} +1 -1
  181. package/dist/esm/webcomponents.js +1 -1
  182. package/dist/module/bank-account.js +2 -2
  183. package/dist/module/card-form2.js +2 -2
  184. package/dist/module/checkout.store.js +0 -1
  185. package/dist/module/custom-popper2.js +2 -2
  186. package/dist/module/form-control-checkbox2.js +2 -2
  187. package/dist/module/form-control-date2.js +2 -2
  188. package/dist/module/form-control-file-v22.js +1 -1
  189. package/dist/module/form-control-file2.js +2 -2
  190. package/dist/module/form-control-monetary2.js +2 -2
  191. package/dist/module/form-control-number-masked2.js +2 -2
  192. package/dist/module/form-control-number.js +2 -2
  193. package/dist/module/form-control-radio2.js +2 -2
  194. package/dist/module/form-control-text2.js +2 -2
  195. package/dist/module/form-control-textarea2.js +2 -2
  196. package/dist/module/hidden-input2.js +1 -1
  197. package/dist/module/iframe-input2.js +3 -3
  198. package/dist/module/justifi-button2.js +1 -1
  199. package/dist/module/justifi-header2.js +1 -1
  200. package/dist/module/justifi-order-terminals.js +1 -1
  201. package/dist/module/justifi-payment-transactions-list.js +1 -1
  202. package/dist/module/justifi-payments-list-filters.js +2 -2
  203. package/dist/module/justifi-payments-list.js +1 -1
  204. package/dist/module/justifi-payout-transactions-list.js +1 -1
  205. package/dist/module/justifi-payouts-list-filters.js +2 -2
  206. package/dist/module/justifi-payouts-list.js +1 -1
  207. package/dist/module/justifi-skeleton.js +1 -1
  208. package/dist/module/justifi-terminal-orders-list-filters.js +2 -2
  209. package/dist/module/justifi-terminal-orders-list.js +1 -1
  210. package/dist/module/justifi-terminals-list-filters.js +1 -1
  211. package/dist/module/justifi-terminals-list.js +1 -1
  212. package/dist/module/modular-checkout.js +5 -92
  213. package/dist/module/package.js +1 -1
  214. package/dist/module/payment-details-core2.js +8 -8
  215. package/dist/module/payment-method-option.js +1 -1
  216. package/dist/module/payments-list-core2.js +1 -1
  217. package/dist/module/payout-details-core2.js +3 -3
  218. package/dist/module/payouts-list-core2.js +1 -1
  219. package/dist/module/summary.js +1 -1
  220. package/dist/module/terminal-orders-list-core2.js +1 -1
  221. package/dist/module/terminal-quantity-selector2.js +1 -1
  222. package/dist/module/terminals-list-core2.js +1 -1
  223. package/dist/module/tokenize-payment-method.js +2 -2
  224. package/dist/types/components/modular-checkout/modular-checkout.d.ts +0 -8
  225. package/dist/types/components.d.ts +0 -120
  226. package/dist/types/store/checkout.store.d.ts +0 -1
  227. package/dist/webcomponents/{p-dc245644.entry.js → p-0b790fa4.entry.js} +4 -4
  228. package/dist/webcomponents/{p-0e64cd09.entry.js → p-0cab7d5d.entry.js} +1 -1
  229. package/dist/webcomponents/{p-cbfc8269.entry.js → p-0e287092.entry.js} +1 -1
  230. package/dist/webcomponents/{p-59e8f027.entry.js → p-145bb9c4.entry.js} +1 -1
  231. package/dist/webcomponents/{p-cabaf013.entry.js → p-14d66df2.entry.js} +1 -1
  232. package/dist/webcomponents/{p-a406bf1a.entry.js → p-15777cfe.entry.js} +1 -1
  233. package/dist/webcomponents/p-1975406a.entry.js +1 -0
  234. package/dist/webcomponents/{p-387bcdee.entry.js → p-1ffbf771.entry.js} +1 -1
  235. package/dist/webcomponents/{p-7b9fa1fb.entry.js → p-29b6f15a.entry.js} +1 -1
  236. package/dist/webcomponents/p-2a59547b.entry.js +1 -0
  237. package/dist/webcomponents/p-2da63719.entry.js +1 -0
  238. package/dist/webcomponents/{p-fbaf62a5.entry.js → p-35bbfbf8.entry.js} +1 -1
  239. package/dist/webcomponents/{p-b04cc606.entry.js → p-3d85d046.entry.js} +1 -1
  240. package/dist/webcomponents/{p-ea1b161a.entry.js → p-413236be.entry.js} +1 -1
  241. package/dist/webcomponents/{p-0aee6da6.entry.js → p-43d693a3.entry.js} +1 -1
  242. package/dist/webcomponents/{p-03c7cee8.entry.js → p-48bccf3b.entry.js} +1 -1
  243. package/dist/webcomponents/p-4ae2a0b9.entry.js +1 -0
  244. package/dist/webcomponents/p-4b795b77.entry.js +1 -0
  245. package/dist/webcomponents/{p-2169c3d1.entry.js → p-518a9519.entry.js} +1 -1
  246. package/dist/webcomponents/{p-a1a8f6bd.entry.js → p-53c81d62.entry.js} +1 -1
  247. package/dist/webcomponents/p-5477c449.entry.js +1 -0
  248. package/dist/webcomponents/p-56980ef3.entry.js +1 -0
  249. package/dist/webcomponents/{p-a9d2dd5e.entry.js → p-57143978.entry.js} +1 -1
  250. package/dist/webcomponents/p-614fcef6.entry.js +1 -0
  251. package/dist/webcomponents/{p-5ad70aae.entry.js → p-6e18d13f.entry.js} +1 -1
  252. package/dist/webcomponents/p-70ff3b10.entry.js +1 -0
  253. package/dist/webcomponents/{p-0aa78c58.entry.js → p-724b0361.entry.js} +1 -1
  254. package/dist/webcomponents/{p-08a5cc2f.entry.js → p-738e0511.entry.js} +1 -1
  255. package/dist/webcomponents/p-739d6f13.entry.js +1 -0
  256. package/dist/webcomponents/{p-76a95d07.entry.js → p-79055216.entry.js} +1 -1
  257. package/dist/webcomponents/{p-42994618.entry.js → p-7b9008f1.entry.js} +1 -1
  258. package/dist/webcomponents/{p-281e36be.entry.js → p-84ce3bae.entry.js} +1 -1
  259. package/dist/webcomponents/p-8a5e168d.entry.js +1 -0
  260. package/dist/webcomponents/{p-cf16498f.entry.js → p-8f31a0c5.entry.js} +1 -1
  261. package/dist/webcomponents/{p-e8a198fa.entry.js → p-904a95e5.entry.js} +1 -1
  262. package/dist/webcomponents/{p-4cf9168d.entry.js → p-98579723.entry.js} +1 -1
  263. package/dist/webcomponents/{p-c7e5245a.entry.js → p-9c5b0b94.entry.js} +1 -1
  264. package/dist/webcomponents/p-9ccd19f5.entry.js +1 -0
  265. package/dist/webcomponents/{p-1246b999.entry.js → p-9f289c31.entry.js} +1 -1
  266. package/dist/webcomponents/p-BC8YDY7M.js +1 -0
  267. package/dist/webcomponents/p-BF-uL8B4.js +1 -0
  268. package/dist/webcomponents/{p-BUadwxkh.js → p-BTkXk7ol.js} +1 -1
  269. package/dist/webcomponents/p-BbYVgLcf.js +1 -0
  270. package/dist/webcomponents/{p-CP_tg-uH.js → p-BeszVz87.js} +1 -1
  271. package/dist/webcomponents/{p-wyEq9Pa1.js → p-BisQ61nK.js} +1 -1
  272. package/dist/webcomponents/{p-HAk7yBNq.js → p-Bz164TKZ.js} +1 -1
  273. package/dist/webcomponents/p-C1fMfnu0.js +1 -0
  274. package/dist/webcomponents/{p-BXKEChoo.js → p-CCME-fyU.js} +1 -1
  275. package/dist/webcomponents/p-C_CXv7AN.js +1 -0
  276. package/dist/webcomponents/{p-RvUQ__Pq.js → p-CfF8KKwx.js} +1 -1
  277. package/dist/webcomponents/{p-DBsw4qpn.js → p-CsNubTqD.js} +1 -1
  278. package/dist/webcomponents/p-CwZKT93w.js +1 -0
  279. package/dist/webcomponents/p-D599ZMGU.js +1 -0
  280. package/dist/webcomponents/{p-DuXN7Akd.js → p-DO3INvI2.js} +1 -1
  281. package/dist/webcomponents/{p-D9Sv4eV5.js → p-DWOKxG7j.js} +1 -1
  282. package/dist/webcomponents/{p-BhdBpAn9.js → p-Dvxpy_P1.js} +1 -1
  283. package/dist/webcomponents/{p-D48iERjQ.js → p-JgbsbAhz.js} +1 -1
  284. package/dist/webcomponents/{p-nWGo6sHu.js → p-YND5pTuF.js} +1 -1
  285. package/dist/webcomponents/{p-bfc38bc2.entry.js → p-a0573ecc.entry.js} +1 -1
  286. package/dist/webcomponents/p-a33ea645.entry.js +1 -0
  287. package/dist/webcomponents/{p-4c994761.entry.js → p-a8205044.entry.js} +1 -1
  288. package/dist/webcomponents/{p-c6860f60.entry.js → p-b0bfa20f.entry.js} +1 -1
  289. package/dist/webcomponents/{p-1202181b.entry.js → p-b93377a7.entry.js} +1 -1
  290. package/dist/webcomponents/p-ba018d57.entry.js +1 -0
  291. package/dist/webcomponents/{p-d014a155.entry.js → p-bafe873d.entry.js} +1 -1
  292. package/dist/webcomponents/p-be06d86a.entry.js +1 -0
  293. package/dist/webcomponents/{p-4a79c737.entry.js → p-befda39d.entry.js} +1 -1
  294. package/dist/webcomponents/{p-afc83e27.entry.js → p-c5b48e8d.entry.js} +1 -1
  295. package/dist/webcomponents/{p-92efb3f2.entry.js → p-c5dabaf4.entry.js} +1 -1
  296. package/dist/webcomponents/p-cea8e40e.entry.js +1 -0
  297. package/dist/webcomponents/p-d075bd72.entry.js +1 -0
  298. package/dist/webcomponents/{p-1a83d9f2.entry.js → p-d7720819.entry.js} +1 -1
  299. package/dist/webcomponents/p-df4f2af9.entry.js +1 -0
  300. package/dist/webcomponents/p-e1ba5735.entry.js +1 -0
  301. package/dist/webcomponents/{p-e6ca1872.entry.js → p-e2267656.entry.js} +1 -1
  302. package/dist/webcomponents/p-e4e30e84.entry.js +1 -0
  303. package/dist/webcomponents/{p-55b7bdba.entry.js → p-e81c5d79.entry.js} +1 -1
  304. package/dist/webcomponents/p-f200cbda.entry.js +1 -0
  305. package/dist/webcomponents/p-f4645aef.entry.js +1 -0
  306. package/dist/webcomponents/{p-a70bc148.entry.js → p-f4f3cae8.entry.js} +1 -1
  307. package/dist/webcomponents/p-f7345d66.entry.js +1 -0
  308. package/dist/webcomponents/{p-1b892b3a.entry.js → p-f7e62bfa.entry.js} +1 -1
  309. package/dist/webcomponents/{p-32cc081a.entry.js → p-fd39af50.entry.js} +1 -1
  310. package/dist/webcomponents/{p-C0AHrswP.js → p-qMrd7_Gp.js} +1 -1
  311. package/dist/webcomponents/{p-DKRXPZKS.js → p-vRhNRfmB.js} +1 -1
  312. package/dist/webcomponents/p-zrUQD0Wr.js +1 -0
  313. package/dist/webcomponents/webcomponents.esm.js +1 -1
  314. package/package.json +1 -1
  315. package/dist/cjs/justifi-apple-pay.cjs.entry.js +0 -830
  316. package/dist/collection/api/ApplePay.js +0 -119
  317. package/dist/collection/api/services/apple-pay.service.js +0 -329
  318. package/dist/collection/components/modular-checkout/sub-components/apple-pay-skeleton.js +0 -10
  319. package/dist/collection/components/modular-checkout/sub-components/apple-pay.js +0 -554
  320. package/dist/collection/ui-components/apple-pay-button.js +0 -146
  321. package/dist/esm/justifi-apple-pay.entry.js +0 -828
  322. package/dist/module/justifi-apple-pay.d.ts +0 -11
  323. package/dist/module/justifi-apple-pay.js +0 -871
  324. package/dist/types/api/ApplePay.d.ts +0 -196
  325. package/dist/types/api/services/apple-pay.service.d.ts +0 -65
  326. package/dist/types/components/modular-checkout/sub-components/apple-pay-skeleton.d.ts +0 -6
  327. package/dist/types/components/modular-checkout/sub-components/apple-pay.d.ts +0 -38
  328. package/dist/types/ui-components/apple-pay-button.d.ts +0 -17
  329. package/dist/webcomponents/p-12c312a0.entry.js +0 -1
  330. package/dist/webcomponents/p-1c0c1d7b.entry.js +0 -1
  331. package/dist/webcomponents/p-1e206c92.entry.js +0 -1
  332. package/dist/webcomponents/p-2988e82c.entry.js +0 -1
  333. package/dist/webcomponents/p-2a0a907d.entry.js +0 -1
  334. package/dist/webcomponents/p-41416b5f.entry.js +0 -1
  335. package/dist/webcomponents/p-5510b57c.entry.js +0 -1
  336. package/dist/webcomponents/p-5a5f07be.entry.js +0 -1
  337. package/dist/webcomponents/p-5acd6add.entry.js +0 -1
  338. package/dist/webcomponents/p-5afbfafb.entry.js +0 -1
  339. package/dist/webcomponents/p-6974a44c.entry.js +0 -1
  340. package/dist/webcomponents/p-6f2b41f5.entry.js +0 -1
  341. package/dist/webcomponents/p-6f9755cc.entry.js +0 -1
  342. package/dist/webcomponents/p-7288473f.entry.js +0 -1
  343. package/dist/webcomponents/p-98939b74.entry.js +0 -1
  344. package/dist/webcomponents/p-BZzESzqz.js +0 -1
  345. package/dist/webcomponents/p-BmFoKOM3.js +0 -1
  346. package/dist/webcomponents/p-BtOB_CaO.js +0 -1
  347. package/dist/webcomponents/p-C60pS6qh.js +0 -1
  348. package/dist/webcomponents/p-D7eeJWA-.js +0 -1
  349. package/dist/webcomponents/p-DOd8HaWV.js +0 -1
  350. package/dist/webcomponents/p-DcE8SQPv.js +0 -1
  351. package/dist/webcomponents/p-Drz6LnIw.js +0 -1
  352. package/dist/webcomponents/p-b41d2b8f.entry.js +0 -1
  353. package/dist/webcomponents/p-b8f63e28.entry.js +0 -1
  354. package/dist/webcomponents/p-ba84c3bd.entry.js +0 -1
  355. package/dist/webcomponents/p-c62e23c1.entry.js +0 -1
  356. package/dist/webcomponents/p-eff0b0e9.entry.js +0 -1
  357. package/dist/webcomponents/p-f3be7b2b.entry.js +0 -1
  358. package/dist/webcomponents/p-f787bc18.entry.js +0 -1
  359. package/dist/webcomponents/p-fb1904d2.entry.js +0 -1
  360. package/dist/webcomponents/p-fcb6e870.entry.js +0 -1
@@ -1,830 +0,0 @@
1
- 'use strict';
2
-
3
- var index = require('./index-dm_GlYlb.js');
4
- var configState = require('./config-state-5xZf-jax.js');
5
- var styledHost = require('./styled-host-CqQYxX-w.js');
6
- require('./event-types-YOY5TKUN.js');
7
- var skeleton = require('./skeleton-x-GSs3xk.js');
8
- var checkout_store = require('./checkout.store-Cn3Jj5gi.js');
9
- require('./index-Yd9aLenr.js');
10
- require('./parts-9jMf1erK.js');
11
-
12
- var ApplePaySessionStatus;
13
- (function (ApplePaySessionStatus) {
14
- ApplePaySessionStatus["STATUS_SUCCESS"] = "STATUS_SUCCESS";
15
- ApplePaySessionStatus["STATUS_FAILURE"] = "STATUS_FAILURE";
16
- })(ApplePaySessionStatus || (ApplePaySessionStatus = {}));
17
- var ApplePayButtonType;
18
- (function (ApplePayButtonType) {
19
- ApplePayButtonType["PLAIN"] = "plain";
20
- ApplePayButtonType["BUY"] = "buy";
21
- ApplePayButtonType["SET_UP"] = "set-up";
22
- ApplePayButtonType["DONATE"] = "donate";
23
- ApplePayButtonType["CHECK_OUT"] = "check-out";
24
- ApplePayButtonType["BOOK"] = "book";
25
- ApplePayButtonType["SUBSCRIBE"] = "subscribe";
26
- })(ApplePayButtonType || (ApplePayButtonType = {}));
27
- var ApplePayButtonStyle;
28
- (function (ApplePayButtonStyle) {
29
- ApplePayButtonStyle["BLACK"] = "black";
30
- ApplePayButtonStyle["WHITE"] = "white";
31
- ApplePayButtonStyle["WHITE_OUTLINE"] = "white-outline";
32
- })(ApplePayButtonStyle || (ApplePayButtonStyle = {}));
33
- var ApplePayMerchantCapability;
34
- (function (ApplePayMerchantCapability) {
35
- ApplePayMerchantCapability["SUPPORTS_3DS"] = "supports3DS";
36
- ApplePayMerchantCapability["SUPPORTS_EMV"] = "supportsEMV";
37
- ApplePayMerchantCapability["SUPPORTS_CREDIT"] = "supportsCredit";
38
- ApplePayMerchantCapability["SUPPORTS_DEBIT"] = "supportsDebit";
39
- })(ApplePayMerchantCapability || (ApplePayMerchantCapability = {}));
40
- class ApplePayConfig {
41
- constructor(data) {
42
- this.merchantIdentifier = data.merchantIdentifier;
43
- this.displayName = data.displayName;
44
- this.initiative = data.initiative;
45
- this.initiativeContext = data.initiativeContext;
46
- this.buttonType = data.buttonType || ApplePayButtonType.PLAIN;
47
- this.buttonStyle = data.buttonStyle || ApplePayButtonStyle.BLACK;
48
- this.buttonLocale = data.buttonLocale || 'en-US';
49
- }
50
- get isValid() {
51
- return !!(this.merchantIdentifier &&
52
- this.displayName &&
53
- this.initiative &&
54
- this.initiativeContext);
55
- }
56
- }
57
- class ApplePayPaymentRequest {
58
- constructor(data) {
59
- this.countryCode = data.countryCode;
60
- this.currencyCode = data.currencyCode;
61
- this.merchantCapabilities = data.merchantCapabilities;
62
- this.supportedNetworks = data.supportedNetworks;
63
- this.total = data.total;
64
- this.lineItems = data.lineItems;
65
- this.shippingMethods = data.shippingMethods;
66
- this.applicationData = data.applicationData;
67
- this.supportedCountries = data.supportedCountries;
68
- }
69
- get isValid() {
70
- var _a, _b, _c, _d;
71
- return !!(this.countryCode &&
72
- this.currencyCode &&
73
- ((_a = this.merchantCapabilities) === null || _a === void 0 ? void 0 : _a.length) &&
74
- ((_b = this.supportedNetworks) === null || _b === void 0 ? void 0 : _b.length) &&
75
- ((_c = this.total) === null || _c === void 0 ? void 0 : _c.label) &&
76
- ((_d = this.total) === null || _d === void 0 ? void 0 : _d.amount));
77
- }
78
- }
79
- class ApplePayHelpers {
80
- static isApplePaySupported() {
81
- var _a;
82
- return (typeof window !== 'undefined' &&
83
- 'ApplePaySession' in window &&
84
- ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.supportsVersion(3)));
85
- }
86
- static canMakePayments() {
87
- var _a;
88
- if (!this.isApplePaySupported()) {
89
- return false;
90
- }
91
- return ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.canMakePayments()) || false;
92
- }
93
- static async canMakePaymentsWithActiveCard(merchantIdentifier) {
94
- var _a;
95
- if (!this.isApplePaySupported()) {
96
- return false;
97
- }
98
- try {
99
- return ((await ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.canMakePaymentsWithActiveCard(merchantIdentifier))) || false);
100
- }
101
- catch (error) {
102
- console.error('Error checking Apple Pay active card:', error);
103
- return false;
104
- }
105
- }
106
- static formatAmount(amount) {
107
- return (amount / 100).toFixed(2);
108
- }
109
- static parseAmount(amount) {
110
- return Math.round(parseFloat(amount) * 100);
111
- }
112
- static createLineItem(label, amount, type = 'final') {
113
- return {
114
- label,
115
- amount: this.formatAmount(amount),
116
- type,
117
- };
118
- }
119
- static getDefaultSupportedNetworks() {
120
- return ['amex', 'discover', 'masterCard', 'visa'];
121
- }
122
- static getDefaultMerchantCapabilities() {
123
- return [
124
- ApplePayMerchantCapability.SUPPORTS_3DS,
125
- ApplePayMerchantCapability.SUPPORTS_EMV,
126
- ApplePayMerchantCapability.SUPPORTS_CREDIT,
127
- ApplePayMerchantCapability.SUPPORTS_DEBIT,
128
- ];
129
- }
130
- }
131
-
132
- class ApplePayService {
133
- constructor() {
134
- this.apiBaseUrl = configState.configState.apiOrigin;
135
- }
136
- /**
137
- * Set custom API base URL
138
- */
139
- setApiBaseUrl(url) {
140
- this.apiBaseUrl = url;
141
- }
142
- /**
143
- * Set authentication token
144
- */
145
- setAuthToken(authToken) {
146
- this.authToken = authToken;
147
- }
148
- setAccountId(accountId) {
149
- this.accountId = accountId;
150
- }
151
- /**
152
- * Initialize Apple Pay configuration
153
- */
154
- initialize(applePayConfig) {
155
- this.applePayConfig = new ApplePayConfig(applePayConfig);
156
- if (!this.applePayConfig.isValid) {
157
- throw new Error('Invalid Apple Pay configuration provided');
158
- }
159
- }
160
- /**
161
- * Validate merchant with Apple Pay servers via API
162
- */
163
- async validateMerchant(authToken) {
164
- const endpoint = `${this.apiBaseUrl}/v1/apple_pay/merchant_session`;
165
- console.log('=== MERCHANT VALIDATION REQUEST ===');
166
- console.log('Endpoint:', endpoint);
167
- console.log('Auth token present:', !!authToken);
168
- console.log('Account ID:', this.accountId);
169
- const response = await fetch(endpoint, {
170
- method: 'POST',
171
- headers: {
172
- 'Content-Type': 'application/json',
173
- Accept: 'application/json',
174
- Authorization: `Bearer ${authToken}`,
175
- 'Sub-Account': this.accountId,
176
- },
177
- });
178
- console.log('Response status:', response.status);
179
- if (!response.ok) {
180
- const errorData = await response.text();
181
- console.error('Backend validation failed - Raw response:', errorData);
182
- try {
183
- const jsonError = JSON.parse(errorData);
184
- console.error('Backend validation failed - Parsed error:', jsonError);
185
- }
186
- catch (parseError) {
187
- console.error('Could not parse error response as JSON:', parseError);
188
- }
189
- throw new Error(`Merchant validation failed: ${response.status}`);
190
- }
191
- const merchantSession = await response.json();
192
- console.log('Merchant session received:', merchantSession);
193
- return merchantSession;
194
- }
195
- /**
196
- * Process Apple Pay payment via API (fixed to match original logic)
197
- */
198
- async processPayment(authToken, payload) {
199
- const endpoint = `${this.apiBaseUrl}/v1/apple_pay/process_token`;
200
- const body = payload;
201
- const response = await fetch(endpoint, {
202
- method: 'POST',
203
- headers: {
204
- 'Content-Type': 'application/json',
205
- Accept: 'application/json',
206
- Authorization: `Bearer ${authToken}`,
207
- 'Sub-Account': this.accountId,
208
- },
209
- body: JSON.stringify(body),
210
- });
211
- const result = await response.json();
212
- return {
213
- success: result.id && !!result.data.token,
214
- data: result,
215
- };
216
- }
217
- /**
218
- * Check if Apple Pay is available on this device/browser
219
- */
220
- isAvailable() {
221
- return (ApplePayHelpers.isApplePaySupported() && ApplePayHelpers.canMakePayments());
222
- }
223
- /**
224
- * Check if the user has an active card for the merchant
225
- */
226
- async canMakePaymentsWithActiveCard() {
227
- if (!this.applePayConfig) {
228
- throw new Error('Apple Pay not initialized. Call initialize() first.');
229
- }
230
- return await ApplePayHelpers.canMakePaymentsWithActiveCard(this.applePayConfig.merchantIdentifier);
231
- }
232
- /**
233
- * Start Apple Pay session
234
- */
235
- async startPaymentSession(paymentRequest) {
236
- if (!this.applePayConfig) {
237
- throw new Error('Apple Pay not initialized. Call initialize() first.');
238
- }
239
- // if (!this.isAvailable()) {
240
- // throw new Error('Apple Pay is not available on this device/browser');
241
- // }
242
- const request = new ApplePayPaymentRequest(paymentRequest);
243
- if (!request.isValid) {
244
- throw new Error('Invalid payment request provided');
245
- }
246
- this.currentPaymentRequest = request;
247
- return new Promise((resolve, reject) => {
248
- try {
249
- this.currentSession = new window.ApplePaySession(3, request);
250
- this.setupSessionEventHandlers(resolve, reject);
251
- this.currentSession.begin();
252
- }
253
- catch (error) {
254
- reject({
255
- success: false,
256
- error: {
257
- code: 'SESSION_ERROR',
258
- message: error instanceof Error
259
- ? error.message
260
- : 'Failed to start Apple Pay session',
261
- },
262
- });
263
- }
264
- });
265
- }
266
- /**
267
- * Abort current Apple Pay session
268
- */
269
- abortPaymentSession() {
270
- if (this.currentSession) {
271
- this.currentSession.abort();
272
- this.currentSession = undefined;
273
- this.currentPaymentRequest = undefined;
274
- }
275
- }
276
- /**
277
- * Setup Apple Pay session event handlers
278
- */
279
- setupSessionEventHandlers(resolve, reject) {
280
- if (!this.currentSession ||
281
- !this.applePayConfig ||
282
- !this.currentPaymentRequest) {
283
- return;
284
- }
285
- this.currentSession.onvalidatemerchant = async () => {
286
- try {
287
- if (!this.authToken) {
288
- throw new Error('Authentication token not set. Call setAuthToken() first.');
289
- }
290
- const merchantSession = await this.validateMerchant(this.authToken);
291
- try {
292
- this.currentSession.completeMerchantValidation(merchantSession);
293
- }
294
- catch (completionError) {
295
- console.error('Error calling completeMerchantValidation:', completionError);
296
- throw completionError;
297
- }
298
- }
299
- catch (error) {
300
- console.error('=== MERCHANT VALIDATION ERROR ===');
301
- console.error('Error during merchant validation:', error);
302
- console.error('Error stack:', error.stack);
303
- this.currentSession.abort();
304
- reject({
305
- success: false,
306
- error: {
307
- code: 'MERCHANT_VALIDATION_ERROR',
308
- message: error instanceof Error
309
- ? error.message
310
- : 'Merchant validation failed',
311
- },
312
- });
313
- }
314
- };
315
- this.currentSession.onpaymentauthorized = async (event) => {
316
- try {
317
- const payment = event.payment;
318
- const paymentPayload = Object.assign(Object.assign({}, payment.token), { product_details: {
319
- name: this.currentPaymentRequest.total.label,
320
- price: ApplePayHelpers.parseAmount(this.currentPaymentRequest.total.amount),
321
- description: this.currentPaymentRequest.total.label,
322
- } });
323
- if (!this.authToken) {
324
- throw new Error('Authentication token not set. Call setAuthToken() first.');
325
- }
326
- const paymentResult = await this.processPayment(this.authToken, paymentPayload);
327
- if (paymentResult.success) {
328
- this.currentSession.completePayment({
329
- status: ApplePaySessionStatus.STATUS_SUCCESS,
330
- });
331
- resolve({
332
- success: true,
333
- token: payment.token,
334
- });
335
- }
336
- else {
337
- console.error('PSP reported payment failure:', paymentResult.data);
338
- this.currentSession.completePayment({
339
- status: ApplePaySessionStatus.STATUS_FAILURE,
340
- });
341
- reject({
342
- success: false,
343
- error: {
344
- code: 'PAYMENT_PROCESSING_ERROR',
345
- message: 'Payment processing failed',
346
- },
347
- });
348
- }
349
- }
350
- catch (error) {
351
- console.error('=== PAYMENT PROCESSING ERROR ===');
352
- console.error('Error processing payment:', error);
353
- console.error('Error stack:', error.stack);
354
- this.currentSession.completePayment({
355
- status: ApplePaySessionStatus.STATUS_FAILURE,
356
- });
357
- reject({
358
- success: false,
359
- error: {
360
- code: 'PAYMENT_PROCESSING_ERROR',
361
- message: error instanceof Error
362
- ? error.message
363
- : 'Payment processing failed',
364
- },
365
- });
366
- }
367
- finally {
368
- this.currentSession = undefined;
369
- this.currentPaymentRequest = undefined;
370
- }
371
- };
372
- this.currentSession.onpaymentmethodselected = () => {
373
- const paymentUpdate = {
374
- newTotal: this.currentPaymentRequest.total,
375
- newLineItems: this.currentPaymentRequest.lineItems || [],
376
- };
377
- try {
378
- this.currentSession.completePaymentMethodSelection(paymentUpdate);
379
- }
380
- catch (error) {
381
- console.error('Error completing payment method selection:', error);
382
- this.currentSession.abort();
383
- }
384
- };
385
- this.currentSession.onshippingmethodselected = () => {
386
- this.currentSession.completeShippingMethodSelection({
387
- status: ApplePaySessionStatus.STATUS_SUCCESS,
388
- newTotal: this.currentPaymentRequest.total,
389
- newLineItems: this.currentPaymentRequest.lineItems || [],
390
- });
391
- };
392
- this.currentSession.oncancel = (event) => {
393
- if (event.sessionError) {
394
- console.error(event.sessionError);
395
- switch (event.sessionError.code) {
396
- case 'unknown':
397
- console.error('Unknown error - likely merchant validation issue');
398
- console.error('This usually means:');
399
- console.error('1. Merchant certificate is invalid or expired');
400
- console.error('2. Merchant identifier mismatch');
401
- console.error('3. Backend validation endpoint issues');
402
- break;
403
- case 'invalidMerchantSession':
404
- console.error('Invalid merchant session provided');
405
- console.error('Check that the merchant session from backend is valid');
406
- break;
407
- case 'userCancel':
408
- console.error('User cancelled the payment');
409
- break;
410
- default:
411
- console.error('Other error code:', event.sessionError.code);
412
- }
413
- }
414
- this.currentSession = undefined;
415
- this.currentPaymentRequest = undefined;
416
- reject({
417
- success: false,
418
- error: {
419
- code: 'USER_CANCELLED',
420
- message: 'User cancelled the Apple Pay session',
421
- },
422
- });
423
- };
424
- if ('onerror' in this.currentSession) {
425
- this.currentSession.onerror = (error) => {
426
- console.error('=== APPLE PAY SESSION ERROR ===');
427
- console.error('Session error:', error);
428
- this.currentSession = undefined;
429
- this.currentPaymentRequest = undefined;
430
- reject({
431
- success: false,
432
- error: {
433
- code: 'SESSION_ERROR',
434
- message: 'Apple Pay session error occurred',
435
- },
436
- });
437
- };
438
- }
439
- }
440
- /**
441
- * Create a basic payment request
442
- */
443
- static createPaymentRequest(amount, label, countryCode = 'US', currencyCode = 'USD') {
444
- return {
445
- countryCode,
446
- currencyCode,
447
- merchantCapabilities: ApplePayHelpers.getDefaultMerchantCapabilities(),
448
- supportedNetworks: ApplePayHelpers.getDefaultSupportedNetworks(),
449
- total: ApplePayHelpers.createLineItem(label, amount),
450
- };
451
- }
452
- /**
453
- * Get current configuration
454
- */
455
- getApplePayConfig() {
456
- return this.applePayConfig;
457
- }
458
- }
459
-
460
- const ApplePaySkeleton = (props) => {
461
- const { isReady } = props;
462
- if (isReady) {
463
- return null;
464
- }
465
- return (index.h("div", { class: 'container-fluid p-0' },
466
- index.h("div", { class: 'row mb-3' },
467
- index.h("div", { class: 'col-12 align-content-center' },
468
- index.h(skeleton.Skeleton, { height: '44px', width: '100%', styles: { borderRadius: "8px" } })))));
469
- };
470
-
471
- const ProcessingSpinner = () => (index.h("div", { class: 'processing-overlay' },
472
- index.h("div", { class: 'spinner' }),
473
- index.h("span", null, "Processing...")));
474
- const ApplePayButton = (props) => {
475
- const getApplePayButtonClass = () => {
476
- let classes = "apple-pay-button";
477
- switch (props.buttonStyle) {
478
- case ApplePayButtonStyle.WHITE:
479
- classes += " apple-pay-button-white";
480
- break;
481
- case ApplePayButtonStyle.WHITE_OUTLINE:
482
- classes += " apple-pay-button-white-outline";
483
- break;
484
- case ApplePayButtonStyle.BLACK:
485
- default:
486
- classes += " apple-pay-button-black";
487
- break;
488
- }
489
- switch (props.buttonType) {
490
- case ApplePayButtonType.BUY:
491
- classes += " apple-pay-button-type-buy";
492
- break;
493
- case ApplePayButtonType.DONATE:
494
- classes += " apple-pay-button-type-donate";
495
- break;
496
- case ApplePayButtonType.PLAIN:
497
- default:
498
- classes += " apple-pay-button-type-plain";
499
- break;
500
- }
501
- if (props.disabled || props.isProcessing || !props.isAvailable) {
502
- classes += " disabled";
503
- }
504
- return classes;
505
- };
506
- const getButtonStyles = () => {
507
- return {
508
- width: props.width || "200px",
509
- height: props.height || "48px",
510
- };
511
- };
512
- const handleClick = () => {
513
- if (!props.disabled &&
514
- !props.isProcessing &&
515
- props.isAvailable &&
516
- props.clickHandler) {
517
- props.clickHandler();
518
- }
519
- };
520
- return (index.h("div", { class: 'apple-pay-button-container' },
521
- index.h("button", Object.assign({ class: getApplePayButtonClass(), style: getButtonStyles(), onClick: handleClick, disabled: props.disabled || props.isProcessing || !props.isAvailable, "aria-label": 'Pay with Apple Pay', type: 'button' }, props), props.isProcessing && ProcessingSpinner()),
522
- index.h("style", null, `
523
- .apple-pay-button-container {
524
- display: inline-block;
525
- position: relative;
526
- }
527
-
528
- /* Apple Pay CSS classes - these are the official Apple Pay button styles */
529
- .apple-pay-button {
530
- display: inline-block;
531
- -webkit-appearance: -apple-pay-button;
532
- -apple-pay-button-type: plain; /* default */
533
- -apple-pay-button-style: black; /* default */
534
- border-radius: 8px;
535
- cursor: pointer;
536
- border: none;
537
- outline: none;
538
- transition: opacity 0.2s ease;
539
- position: relative;
540
- }
541
-
542
- /* Button styles */
543
- .apple-pay-button.apple-pay-button-black {
544
- -apple-pay-button-style: black;
545
- }
546
-
547
- .apple-pay-button.apple-pay-button-white {
548
- -apple-pay-button-style: white;
549
- }
550
-
551
- .apple-pay-button.apple-pay-button-white-outline {
552
- -apple-pay-button-style: white-outline;
553
- }
554
-
555
- /* Button types */
556
- .apple-pay-button.apple-pay-button-type-plain {
557
- -apple-pay-button-type: plain;
558
- }
559
-
560
- .apple-pay-button.apple-pay-button-type-buy {
561
- -apple-pay-button-type: buy;
562
- }
563
-
564
- .apple-pay-button.apple-pay-button-type-donate {
565
- -apple-pay-button-type: donate;
566
- }
567
-
568
- /* Hover and disabled states */
569
- .apple-pay-button:hover:not(.disabled) {
570
- opacity: 0.9;
571
- }
572
-
573
- .apple-pay-button.disabled {
574
- opacity: 0.5;
575
- cursor: not-allowed;
576
- }
577
-
578
- /* Processing overlay */
579
- .processing-overlay {
580
- position: absolute;
581
- top: 0;
582
- left: 0;
583
- right: 0;
584
- bottom: 0;
585
- display: flex;
586
- align-items: center;
587
- justify-content: center;
588
- gap: 8px;
589
- background: rgba(0, 0, 0, 0.8);
590
- color: white;
591
- border-radius: 8px;
592
- font-size: 14px;
593
- font-weight: 500;
594
- }
595
-
596
- .spinner {
597
- width: 16px;
598
- height: 16px;
599
- border: 2px solid rgba(255, 255, 255, 0.3);
600
- border-top: 2px solid #fff;
601
- border-radius: 50%;
602
- animation: spin 1s linear infinite;
603
- }
604
-
605
- @keyframes spin {
606
- 0% { transform: rotate(0deg); }
607
- 100% { transform: rotate(360deg); }
608
- }
609
-
610
- /* Responsive design */
611
- @media (max-width: 480px) {
612
- .apple-pay-button {
613
- width: 100% !important;
614
- min-width: 200px;
615
- }
616
- }
617
- `)));
618
- };
619
-
620
- const ApplePay = class {
621
- constructor(hostRef) {
622
- index.registerInstance(this, hostRef);
623
- this.applePayStarted = index.createEvent(this, "applePayStarted");
624
- this.applePayCompleted = index.createEvent(this, "applePayCompleted");
625
- this.applePayCancelled = index.createEvent(this, "applePayCancelled");
626
- this.applePayError = index.createEvent(this, "applePayError");
627
- this.countryCode = "US";
628
- this.merchantIdentifier = "merchant.com.staging-justifi.checkout-dev";
629
- this.merchantDisplayName = "JustiFi Checkout";
630
- this.initiativeContext = "dev-checkout.justifi-staging.com";
631
- this.apiBaseUrl = configState.configState.apiOrigin;
632
- this.buttonType = ApplePayButtonType.PLAIN;
633
- this.buttonStyle = ApplePayButtonStyle.BLACK;
634
- this.disabled = false;
635
- this.showSkeleton = true;
636
- this.isLoading = true;
637
- this.isProcessing = false;
638
- this.isAvailable = false;
639
- this.canMakePayments = false;
640
- this.error = null;
641
- this.handleApplePayClick = async () => {
642
- var _a;
643
- if (this.isProcessing || this.disabled || !this.isAvailable) {
644
- return;
645
- }
646
- try {
647
- this.isProcessing = true;
648
- this.error = null;
649
- this.applePayStarted.emit();
650
- const paymentRequest = {
651
- countryCode: this.countryCode,
652
- currencyCode: checkout_store.checkoutStore.paymentCurrency,
653
- merchantCapabilities: ApplePayHelpers.getDefaultMerchantCapabilities(),
654
- supportedNetworks: ApplePayHelpers.getDefaultSupportedNetworks(),
655
- total: ApplePayHelpers.createLineItem(checkout_store.checkoutStore.paymentDescription, checkout_store.checkoutStore.paymentAmount),
656
- };
657
- const result = await this.applePayService.startPaymentSession(paymentRequest);
658
- if (result.success) {
659
- this.applePayCompleted.emit({
660
- success: true,
661
- token: result.token,
662
- });
663
- }
664
- else {
665
- this.applePayCompleted.emit({
666
- success: false,
667
- error: result.error,
668
- });
669
- this.applePayError.emit({
670
- error: ((_a = result.error) === null || _a === void 0 ? void 0 : _a.message) || "Payment failed",
671
- });
672
- }
673
- }
674
- catch (error) {
675
- console.error("Apple Pay payment error:", error);
676
- const errorMessage = error instanceof Error ? error.message : "Payment failed";
677
- this.error = errorMessage;
678
- this.applePayError.emit({ error: errorMessage });
679
- this.applePayCompleted.emit({
680
- success: false,
681
- error: errorMessage,
682
- });
683
- }
684
- finally {
685
- this.isProcessing = false;
686
- }
687
- };
688
- }
689
- componentWillLoad() {
690
- this.applePayService = new ApplePayService();
691
- this.applePayService.setApiBaseUrl(this.apiBaseUrl);
692
- this.applePayService.setAuthToken(checkout_store.checkoutStore.authToken);
693
- this.applePayService.setAccountId(checkout_store.checkoutStore.accountId);
694
- this.initializeApplePay();
695
- }
696
- componentDidLoad() {
697
- checkout_store.onChange('paymentAmount', () => {
698
- this.initializeApplePay();
699
- });
700
- checkout_store.onChange('authToken', () => {
701
- if (this.applePayService) {
702
- this.applePayService.setAuthToken(checkout_store.checkoutStore.authToken);
703
- }
704
- });
705
- }
706
- watchPropsChange() {
707
- this.initializeApplePay();
708
- }
709
- async initializeApplePay() {
710
- console.log('Initializing Apple Pay');
711
- try {
712
- if (this.applePayService) {
713
- this.applePayService.setApiBaseUrl(this.apiBaseUrl);
714
- this.applePayService.setAuthToken(checkout_store.checkoutStore.authToken);
715
- }
716
- this.isLoading = true;
717
- this.error = null;
718
- if (!checkout_store.checkoutStore.paymentAmount) {
719
- this.error = "Missing required Apple Pay configuration";
720
- this.isLoading = false;
721
- return;
722
- }
723
- this.isAvailable = true; // ApplePayHelpers.isApplePaySupported();
724
- this.canMakePayments = true; // ApplePayHelpers.canMakePayments();
725
- if (!this.isAvailable) {
726
- this.error = "Apple Pay is not supported on this device";
727
- this.isLoading = false;
728
- return;
729
- }
730
- if (!this.canMakePayments) {
731
- this.error = "Apple Pay is not available";
732
- this.isLoading = false;
733
- return;
734
- }
735
- const applePayConfig = {
736
- merchantIdentifier: this.merchantIdentifier,
737
- displayName: this.merchantDisplayName,
738
- initiative: "web",
739
- initiativeContext: this.initiativeContext,
740
- buttonType: this.buttonType,
741
- buttonStyle: this.buttonStyle,
742
- };
743
- console.log('=== APPLE PAY CONFIG ===');
744
- console.log('Config:', applePayConfig);
745
- console.log('Auth token present:', !!checkout_store.checkoutStore.authToken);
746
- console.log('Account ID:', checkout_store.checkoutStore.accountId);
747
- this.applePayService.setAccountId(checkout_store.checkoutStore.accountId);
748
- this.applePayService.initialize(applePayConfig);
749
- const hasActiveCard = await this.applePayService.canMakePaymentsWithActiveCard();
750
- if (!hasActiveCard) {
751
- console.warn("No Apple Pay cards available, but continuing...");
752
- }
753
- }
754
- catch (error) {
755
- console.error("Apple Pay initialization error:", error);
756
- this.error =
757
- error instanceof Error
758
- ? error.message
759
- : "Failed to initialize Apple Pay";
760
- }
761
- finally {
762
- this.isLoading = false;
763
- }
764
- }
765
- async isSupported() {
766
- return this.isAvailable && this.canMakePayments;
767
- }
768
- async getPaymentMethods() {
769
- if (!this.isAvailable) {
770
- return [];
771
- }
772
- return ApplePayHelpers.getDefaultSupportedNetworks();
773
- }
774
- async abort() {
775
- this.applePayService.abortPaymentSession();
776
- this.isProcessing = false;
777
- this.applePayCancelled.emit();
778
- }
779
- render() {
780
- const isReady = !this.isLoading &&
781
- this.isAvailable &&
782
- this.canMakePayments &&
783
- !this.error;
784
- return (index.h(styledHost.StyledHost, { key: '45f2eaf52c3a2b2641a9cf6b22861de0a2a628a6' }, index.h("script", { key: '42a858aefc0e5ff23d5cf322ebca4408d7ac745f', async: true, src: "https://applepay.cdn-apple.com/jsapi/1.latest/apple-pay-sdk.js" }), index.h("div", { key: '87ff666f7a898051253e18a1c14a9fca0373b1a8', class: 'apple-pay-container' }, index.h(ApplePaySkeleton, { key: '3b4a24e3e8f4a4fdde1b134b61d7cbe422b40fd9', isReady: isReady }), !this.isLoading && this.error && (index.h("div", { key: 'a6f58df266b99e385eb38f7d8104906966b337af', class: 'apple-pay-error', role: 'alert' }, index.h("span", { key: 'c97d5489a323df55a97a5d3395fd4e14363ba32b', class: 'error-icon' }, "\u26A0\uFE0F"), index.h("span", { key: 'd6447983dcf879d061d1b4d6d06300e9df3430d4', class: 'error-message' }, this.error))), !this.isLoading && !this.error && !this.isAvailable && (index.h("div", { key: 'd58714c3a66403876a1b92f7de5a2981a71baaa4', class: 'apple-pay-unavailable' }, index.h("span", { key: '7d01800c0044a6b1cce70d76da8c4b37e9d592c8', class: 'unavailable-message' }, "Apple Pay is not available on this device"))), !this.isLoading &&
785
- !this.error &&
786
- this.isAvailable &&
787
- this.canMakePayments && (index.h(ApplePayButton, { key: '6e950987ae3c2d7c5168028f48a6400bd97a0692', buttonType: this.buttonType, buttonStyle: this.buttonStyle, disabled: this.disabled, isProcessing: this.isProcessing, isAvailable: this.isAvailable, clickHandler: this.handleApplePayClick }))), index.h("style", { key: '2358f7ee9df1d9d270754801b00be2c807c2a10c' }, `
788
- .apple-pay-container {
789
- width: 100%;
790
- }
791
-
792
- .apple-pay-error {
793
- display: flex;
794
- align-items: center;
795
- gap: 8px;
796
- padding: 12px;
797
- background: #fef2f2;
798
- border: 1px solid #fecaca;
799
- border-radius: 8px;
800
- color: #dc2626;
801
- font-size: 14px;
802
- }
803
-
804
- .apple-pay-unavailable {
805
- display: flex;
806
- align-items: center;
807
- justify-content: center;
808
- padding: 12px;
809
- background: #f9fafb;
810
- border: 1px solid #e5e7eb;
811
- border-radius: 8px;
812
- color: #6b7280;
813
- font-size: 14px;
814
- }
815
-
816
- .error-icon {
817
- font-size: 16px;
818
- }
819
- `)));
820
- }
821
- static get watchers() { return {
822
- "merchantIdentifier": ["watchPropsChange"],
823
- "apiBaseUrl": ["watchPropsChange"],
824
- "buttonType": ["watchPropsChange"],
825
- "buttonStyle": ["watchPropsChange"],
826
- "disabled": ["watchPropsChange"]
827
- }; }
828
- };
829
-
830
- exports.justifi_apple_pay = ApplePay;