@justifi/webcomponents 6.5.0 → 6.5.1-rc.1

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 (545) hide show
  1. package/dist/cjs/{Refund-Blquw3jZ.js → GooglePay-HXBAmTgL.js} +415 -0
  2. package/dist/cjs/bank-account-document-form-inputs_6.cjs.entry.js +8 -7
  3. package/dist/cjs/bank-account-form.cjs.entry.js +2 -2
  4. package/dist/cjs/{business.service-DrBmfEbR.js → business.service-DMzf08nC.js} +1 -1
  5. package/dist/cjs/card-form.cjs.entry.js +2 -2
  6. package/dist/cjs/{check-pkg-version-D06Nzj0h.js → check-pkg-version-DNFRhNcW.js} +2 -2
  7. package/dist/cjs/{checkout.service-BEU6CI0t.js → checkout.service-CHNHEsrp.js} +1 -1
  8. package/dist/cjs/checkouts-list-core.cjs.entry.js +3 -2
  9. package/dist/cjs/custom-popper.cjs.entry.js +2 -2
  10. package/dist/cjs/{dispute.service-c0CZxPpe.js → dispute.service-B63kcFkU.js} +1 -1
  11. package/dist/cjs/form-alert_5.cjs.entry.js +6 -6
  12. package/dist/cjs/form-control-checkbox.cjs.entry.js +2 -2
  13. package/dist/cjs/form-control-date.cjs.entry.js +2 -2
  14. package/dist/cjs/form-control-file-v2_2.cjs.entry.js +3 -3
  15. package/dist/cjs/form-control-monetary-provisioning.cjs.entry.js +2 -2
  16. package/dist/cjs/form-control-monetary.cjs.entry.js +2 -2
  17. package/dist/cjs/form-control-number-masked_3.cjs.entry.js +4 -4
  18. package/dist/cjs/form-control-number.cjs.entry.js +2 -2
  19. package/dist/cjs/form-control-radio.cjs.entry.js +2 -2
  20. package/dist/cjs/form-control-select_3.cjs.entry.js +4 -4
  21. package/dist/cjs/{get-payment-details-D8UQRtX1.js → get-payment-details-BN139jp0.js} +2 -2
  22. package/dist/cjs/{get-subaccounts-fKcKqvrx.js → get-subaccounts-IgHJX5J4.js} +2 -2
  23. package/dist/cjs/gross-payment-chart-core.cjs.entry.js +1 -1
  24. package/dist/cjs/hidden-input_2.cjs.entry.js +5 -5
  25. package/dist/cjs/{index-C2ITzalN.js → index-CajjbB9t.js} +1 -0
  26. package/dist/cjs/index.cjs.js +1 -1
  27. package/dist/cjs/internal-tokenize-payment-method_7.cjs.entry.js +23 -24
  28. package/dist/cjs/justifi-additional-questions-form-step-core_6.cjs.entry.js +6 -5
  29. package/dist/cjs/justifi-additional-questions-form-step_9.cjs.entry.js +12 -11
  30. package/dist/cjs/justifi-additional-statement_8.cjs.entry.js +8 -8
  31. package/dist/cjs/{justifi-apple-pay_7.cjs.entry.js → justifi-apple-pay_8.cjs.entry.js} +903 -253
  32. package/dist/cjs/justifi-bank-account-billing-form-simple_3.cjs.entry.js +2 -2
  33. package/dist/cjs/justifi-business-details.cjs.entry.js +5 -4
  34. package/dist/cjs/justifi-business-form.cjs.entry.js +5 -4
  35. package/dist/cjs/justifi-business-representative-form-inputs.cjs.entry.js +2 -2
  36. package/dist/cjs/justifi-checkout.cjs.entry.js +14 -15
  37. package/dist/cjs/justifi-checkouts-list-filters.cjs.entry.js +10 -9
  38. package/dist/cjs/justifi-checkouts-list.cjs.entry.js +8 -7
  39. package/dist/cjs/justifi-details.cjs.entry.js +1 -1
  40. package/dist/cjs/justifi-dispute-management-core.cjs.entry.js +1 -1
  41. package/dist/cjs/justifi-dispute-management.cjs.entry.js +6 -5
  42. package/dist/cjs/justifi-dispute-notification_3.cjs.entry.js +9 -8
  43. package/dist/cjs/justifi-gross-payment-chart.cjs.entry.js +4 -3
  44. package/dist/cjs/justifi-order-terminals.cjs.entry.js +10 -9
  45. package/dist/cjs/justifi-owner-form_3.cjs.entry.js +7 -6
  46. package/dist/cjs/justifi-payment-details.cjs.entry.js +6 -5
  47. package/dist/cjs/justifi-payment-provisioning-core.cjs.entry.js +1 -1
  48. package/dist/cjs/justifi-payment-provisioning.cjs.entry.js +6 -5
  49. package/dist/cjs/justifi-payment-transactions-list.cjs.entry.js +7 -6
  50. package/dist/cjs/justifi-payments-list-filters.cjs.entry.js +2 -2
  51. package/dist/cjs/justifi-payments-list.cjs.entry.js +7 -6
  52. package/dist/cjs/justifi-payout-details.cjs.entry.js +6 -5
  53. package/dist/cjs/justifi-payout-transactions-list.cjs.entry.js +7 -6
  54. package/dist/cjs/justifi-payouts-list-filters.cjs.entry.js +2 -2
  55. package/dist/cjs/justifi-payouts-list.cjs.entry.js +8 -7
  56. package/dist/cjs/justifi-refund-payment.cjs.entry.js +10 -9
  57. package/dist/cjs/justifi-saved-payment-method.cjs.entry.js +1 -1
  58. package/dist/cjs/justifi-season-interruption-insurance.cjs.entry.js +7 -8
  59. package/dist/cjs/justifi-skeleton.cjs.entry.js +1 -1
  60. package/dist/cjs/justifi-terminal-orders-list-filters.cjs.entry.js +12 -11
  61. package/dist/cjs/justifi-terminal-orders-list.cjs.entry.js +7 -6
  62. package/dist/cjs/justifi-terminals-list-filters.cjs.entry.js +8 -7
  63. package/dist/cjs/justifi-terminals-list.cjs.entry.js +8 -7
  64. package/dist/cjs/justifi-tokenize-payment-method.cjs.entry.js +1 -1
  65. package/dist/cjs/loader.cjs.js +1 -1
  66. package/dist/cjs/{package-gCv25hzn.js → package-Z2EW-l1q.js} +1 -1
  67. package/dist/cjs/pagination-menu.cjs.entry.js +3 -3
  68. package/dist/cjs/payment-details-core.cjs.entry.js +11 -10
  69. package/dist/cjs/payment-method-option.cjs.entry.js +1 -1
  70. package/dist/cjs/{payment.service-DXbR13Kq.js → payment.service-eOZc1Qay.js} +1 -1
  71. package/dist/cjs/payments-list-core.cjs.entry.js +3 -2
  72. package/dist/cjs/payout-details-core.cjs.entry.js +3 -3
  73. package/dist/cjs/{payout.service-D0U6kzXJ.js → payout.service-QVl5N-UV.js} +1 -1
  74. package/dist/cjs/payouts-list-core.cjs.entry.js +3 -2
  75. package/dist/cjs/table-filters-menu.cjs.entry.js +1 -1
  76. package/dist/cjs/terminal-orders-list-core.cjs.entry.js +4 -3
  77. package/dist/cjs/{terminal-orders-table-BByfBAEK.js → terminal-orders-table-g2fwrh2P.js} +3 -3
  78. package/dist/cjs/terminal-quantity-selector.cjs.entry.js +1 -1
  79. package/dist/cjs/{terminal.service-BqXeiERV.js → terminal.service-BuSFyt0j.js} +1 -1
  80. package/dist/cjs/terminals-list-core.cjs.entry.js +3 -2
  81. package/dist/cjs/webcomponents.cjs.js +1 -1
  82. package/dist/collection/api/GooglePay.js +181 -0
  83. package/dist/collection/api/index.js +2 -0
  84. package/dist/collection/api/services/google-pay.service.js +240 -0
  85. package/dist/collection/collection-manifest.json +2 -1
  86. package/dist/collection/components/business-forms/business-form/additional-questions/additional-questions.js +7 -6
  87. package/dist/collection/components/business-forms/business-form/business-core-info/business-core-info.js +2 -2
  88. package/dist/collection/components/business-forms/business-form/business-representative/business-representative.js +8 -7
  89. package/dist/collection/components/business-forms/business-form/legal-address-form/legal-address-form.js +7 -6
  90. package/dist/collection/components/business-forms/owner-form/identity-address/identity-address-form.js +1 -1
  91. package/dist/collection/components/business-forms/owner-form/owner-form-core.js +1 -1
  92. package/dist/collection/components/business-forms/owner-form/owner-form-inputs.js +8 -7
  93. package/dist/collection/components/business-forms/owner-form/owner-form.js +1 -1
  94. package/dist/collection/components/business-forms/payment-provisioning/additional-questions/business-additional-questions-form-step.js +1 -1
  95. package/dist/collection/components/business-forms/payment-provisioning/bank-account/bank-account-document-inputs.js +1 -1
  96. package/dist/collection/components/business-forms/payment-provisioning/bank-account/bank-account-form-inputs-canada.js +1 -1
  97. package/dist/collection/components/business-forms/payment-provisioning/bank-account/bank-account-form-inputs.js +1 -1
  98. package/dist/collection/components/business-forms/payment-provisioning/bank-account/bank-account-read-only-value.js +1 -1
  99. package/dist/collection/components/business-forms/payment-provisioning/bank-account/business-bank-account-form-step.js +1 -1
  100. package/dist/collection/components/business-forms/payment-provisioning/business-core-info/business-core-info-form-step.js +1 -1
  101. package/dist/collection/components/business-forms/payment-provisioning/business-owners/business-owners-form-step.js +1 -1
  102. package/dist/collection/components/business-forms/payment-provisioning/business-representative/business-representative-form-inputs.js +2 -2
  103. package/dist/collection/components/business-forms/payment-provisioning/business-representative/business-representative-form-step.js +1 -1
  104. package/dist/collection/components/business-forms/payment-provisioning/form-address-fields/form-address-fields.js +1 -1
  105. package/dist/collection/components/business-forms/payment-provisioning/form-control-monetary-provisioning.js +2 -2
  106. package/dist/collection/components/business-forms/payment-provisioning/legal-address-form/legal-address-form-step.js +1 -1
  107. package/dist/collection/components/business-forms/payment-provisioning/payment-provisioning-core.js +1 -1
  108. package/dist/collection/components/business-forms/payment-provisioning/payment-provisioning-form-buttons.js +1 -1
  109. package/dist/collection/components/business-forms/payment-provisioning/payment-provisioning-form-steps.js +1 -1
  110. package/dist/collection/components/business-forms/payment-provisioning/payment-provisioning.js +1 -1
  111. package/dist/collection/components/business-forms/payment-provisioning/terms-and-conditions/business-terms-conditions-form-step.js +1 -1
  112. package/dist/collection/components/checkout/bank-account-form/bank-account-form.js +2 -2
  113. package/dist/collection/components/checkout/card-form/card-form.js +2 -2
  114. package/dist/collection/components/checkout/checkout.js +2 -2
  115. package/dist/collection/components/checkout/save-new-payment-method.js +1 -1
  116. package/dist/collection/components/checkout/saved-payment-method.js +1 -1
  117. package/dist/collection/components/checkouts-list/checkouts-list-core.js +1 -1
  118. package/dist/collection/components/checkouts-list/checkouts-list-filters.js +1 -1
  119. package/dist/collection/components/checkouts-list/checkouts-list.js +1 -1
  120. package/dist/collection/components/dispute-management/dispute-management-core.js +1 -1
  121. package/dist/collection/components/dispute-management/dispute-management.js +1 -1
  122. package/dist/collection/components/dispute-management/dispute-notification.js +2 -2
  123. package/dist/collection/components/dispute-management/dispute-response/additional-statement.js +1 -1
  124. package/dist/collection/components/dispute-management/dispute-response/cancellation-policy.js +1 -1
  125. package/dist/collection/components/dispute-management/dispute-response/customer-details.js +1 -1
  126. package/dist/collection/components/dispute-management/dispute-response/dispute-response-core.js +1 -1
  127. package/dist/collection/components/dispute-management/dispute-response/dispute-response.js +1 -1
  128. package/dist/collection/components/dispute-management/dispute-response/duplicate-charge.js +1 -1
  129. package/dist/collection/components/dispute-management/dispute-response/electronic-evidence.js +1 -1
  130. package/dist/collection/components/dispute-management/dispute-response/product-or-service.js +1 -1
  131. package/dist/collection/components/dispute-management/dispute-response/refund-policy.js +1 -1
  132. package/dist/collection/components/dispute-management/dispute-response/shipping-details.js +1 -1
  133. package/dist/collection/components/filters/table-filters-menu.js +1 -1
  134. package/dist/collection/components/gross-payment-chart/gross-payment-chart-core.js +1 -1
  135. package/dist/collection/components/modular-checkout/ModularCheckout.js +1 -0
  136. package/dist/collection/components/modular-checkout/modular-checkout.js +46 -9
  137. package/dist/collection/components/modular-checkout/sub-components/bank-account-billing-form-simple.js +1 -1
  138. package/dist/collection/components/modular-checkout/sub-components/bank-account.js +2 -2
  139. package/dist/collection/components/modular-checkout/sub-components/card-billing-form-simple.js +1 -1
  140. package/dist/collection/components/modular-checkout/sub-components/card-form.js +2 -2
  141. package/dist/collection/components/modular-checkout/sub-components/google-pay-skeleton.js +10 -0
  142. package/dist/collection/components/modular-checkout/sub-components/google-pay.js +609 -0
  143. package/dist/collection/components/modular-checkout/sub-components/payment-method-option.js +1 -1
  144. package/dist/collection/components/modular-checkout/sub-components/summary.js +1 -1
  145. package/dist/collection/components/order-terminals/order-terminals.js +1 -1
  146. package/dist/collection/components/order-terminals/terminal-quantity-selector/terminal-quantity-selector.js +1 -1
  147. package/dist/collection/components/payment-details/payment-details-core.js +8 -8
  148. package/dist/collection/components/payment-transactions-list/payment-transactions-list.js +1 -1
  149. package/dist/collection/components/payments-list/payments-list-core.js +1 -1
  150. package/dist/collection/components/payments-list/payments-list-filters.js +2 -2
  151. package/dist/collection/components/payments-list/payments-list.js +1 -1
  152. package/dist/collection/components/payout-details/payout-details-core.js +3 -3
  153. package/dist/collection/components/payout-transactions-list/payout-transactions-list.js +1 -1
  154. package/dist/collection/components/payouts-list/payouts-list-core.js +1 -1
  155. package/dist/collection/components/payouts-list/payouts-list-filters.js +2 -2
  156. package/dist/collection/components/payouts-list/payouts-list.js +1 -1
  157. package/dist/collection/components/terminal-orders-list/terminal-orders-list-core.js +1 -1
  158. package/dist/collection/components/terminal-orders-list/terminal-orders-list-filters.js +2 -2
  159. package/dist/collection/components/terminal-orders-list/terminal-orders-list.js +1 -1
  160. package/dist/collection/components/terminals-list/terminals-list-core.js +1 -1
  161. package/dist/collection/components/terminals-list/terminals-list-filters.js +1 -1
  162. package/dist/collection/components/terminals-list/terminals-list.js +1 -1
  163. package/dist/collection/components/tokenize-payment-method/internal-tokenize-payment-method.js +3 -4
  164. package/dist/collection/components/tokenize-payment-method/tokenize-payment-method.js +5 -10
  165. package/dist/collection/store/checkout.store.js +4 -0
  166. package/dist/collection/ui-components/custom-popper/custom-popper.js +2 -2
  167. package/dist/collection/ui-components/details/details.js +1 -1
  168. package/dist/collection/ui-components/form/form-control-checkbox.js +2 -2
  169. package/dist/collection/ui-components/form/form-control-date.js +2 -2
  170. package/dist/collection/ui-components/form/form-control-file-v2.js +1 -1
  171. package/dist/collection/ui-components/form/form-control-file.js +2 -2
  172. package/dist/collection/ui-components/form/form-control-monetary.js +2 -2
  173. package/dist/collection/ui-components/form/form-control-number-masked.js +2 -2
  174. package/dist/collection/ui-components/form/form-control-number.js +2 -2
  175. package/dist/collection/ui-components/form/form-control-radio.js +2 -2
  176. package/dist/collection/ui-components/form/form-control-select.js +2 -2
  177. package/dist/collection/ui-components/form/form-control-text.js +2 -2
  178. package/dist/collection/ui-components/form/form-control-textarea.js +2 -2
  179. package/dist/collection/ui-components/form/hidden-input.js +1 -1
  180. package/dist/collection/ui-components/form/iframe-input.js +3 -3
  181. package/dist/collection/ui-components/google-pay-button.js +255 -0
  182. package/dist/collection/ui-components/pagination-menu/pagination-menu.js +3 -3
  183. package/dist/collection/ui-components/shadow-dom-components/justifi-button.js +1 -1
  184. package/dist/collection/ui-components/shadow-dom-components/justifi-header.js +1 -1
  185. package/dist/collection/ui-components/shadow-dom-components/justifi-radio-list-item.js +1 -1
  186. package/dist/collection/ui-components/shadow-dom-components/justifi-skeleton.js +1 -1
  187. package/dist/docs.json +567 -119
  188. package/dist/esm/{Refund-BugCdfRo.js → GooglePay-9bPcqGZ9.js} +405 -1
  189. package/dist/esm/bank-account-document-form-inputs_6.entry.js +8 -7
  190. package/dist/esm/bank-account-form.entry.js +2 -2
  191. package/dist/esm/{business.service-pWcc3kfX.js → business.service-2j91Emgq.js} +1 -1
  192. package/dist/esm/card-form.entry.js +2 -2
  193. package/dist/esm/{check-pkg-version-AQP98jzk.js → check-pkg-version-B8HjTYV7.js} +2 -2
  194. package/dist/esm/{checkout.service-B4xSV2-X.js → checkout.service-D-dEMyXF.js} +1 -1
  195. package/dist/esm/checkouts-list-core.entry.js +3 -2
  196. package/dist/esm/custom-popper.entry.js +2 -2
  197. package/dist/esm/{dispute.service-3Kbbh1J9.js → dispute.service-DPumDIuV.js} +1 -1
  198. package/dist/esm/form-alert_5.entry.js +6 -6
  199. package/dist/esm/form-control-checkbox.entry.js +2 -2
  200. package/dist/esm/form-control-date.entry.js +2 -2
  201. package/dist/esm/form-control-file-v2_2.entry.js +3 -3
  202. package/dist/esm/form-control-monetary-provisioning.entry.js +2 -2
  203. package/dist/esm/form-control-monetary.entry.js +2 -2
  204. package/dist/esm/form-control-number-masked_3.entry.js +4 -4
  205. package/dist/esm/form-control-number.entry.js +2 -2
  206. package/dist/esm/form-control-radio.entry.js +2 -2
  207. package/dist/esm/form-control-select_3.entry.js +4 -4
  208. package/dist/esm/{get-payment-details-CakzKvOr.js → get-payment-details-CD_K6FQ3.js} +1 -1
  209. package/dist/esm/{get-subaccounts-Cw1Adtmo.js → get-subaccounts-D1eF6c0B.js} +1 -1
  210. package/dist/esm/gross-payment-chart-core.entry.js +1 -1
  211. package/dist/esm/hidden-input_2.entry.js +5 -5
  212. package/dist/esm/{index-DCIW8z1f.js → index-DkoufM1t.js} +1 -0
  213. package/dist/esm/index.js +1 -1
  214. package/dist/esm/internal-tokenize-payment-method_7.entry.js +12 -13
  215. package/dist/esm/justifi-additional-questions-form-step-core_6.entry.js +2 -1
  216. package/dist/esm/justifi-additional-questions-form-step_9.entry.js +12 -11
  217. package/dist/esm/justifi-additional-statement_8.entry.js +8 -8
  218. package/dist/esm/{justifi-apple-pay_7.entry.js → justifi-apple-pay_8.entry.js} +786 -137
  219. package/dist/esm/justifi-bank-account-billing-form-simple_3.entry.js +2 -2
  220. package/dist/esm/justifi-business-details.entry.js +5 -4
  221. package/dist/esm/justifi-business-form.entry.js +5 -4
  222. package/dist/esm/justifi-business-representative-form-inputs.entry.js +2 -2
  223. package/dist/esm/justifi-checkout.entry.js +7 -8
  224. package/dist/esm/justifi-checkouts-list-filters.entry.js +3 -2
  225. package/dist/esm/justifi-checkouts-list.entry.js +7 -6
  226. package/dist/esm/justifi-details.entry.js +1 -1
  227. package/dist/esm/justifi-dispute-management-core.entry.js +1 -1
  228. package/dist/esm/justifi-dispute-management.entry.js +6 -5
  229. package/dist/esm/justifi-dispute-notification_3.entry.js +9 -8
  230. package/dist/esm/justifi-gross-payment-chart.entry.js +4 -3
  231. package/dist/esm/justifi-order-terminals.entry.js +7 -6
  232. package/dist/esm/justifi-owner-form_3.entry.js +7 -6
  233. package/dist/esm/justifi-payment-details.entry.js +6 -5
  234. package/dist/esm/justifi-payment-provisioning-core.entry.js +1 -1
  235. package/dist/esm/justifi-payment-provisioning.entry.js +6 -5
  236. package/dist/esm/justifi-payment-transactions-list.entry.js +6 -5
  237. package/dist/esm/justifi-payments-list-filters.entry.js +2 -2
  238. package/dist/esm/justifi-payments-list.entry.js +6 -5
  239. package/dist/esm/justifi-payout-details.entry.js +5 -4
  240. package/dist/esm/justifi-payout-transactions-list.entry.js +6 -5
  241. package/dist/esm/justifi-payouts-list-filters.entry.js +2 -2
  242. package/dist/esm/justifi-payouts-list.entry.js +7 -6
  243. package/dist/esm/justifi-refund-payment.entry.js +6 -5
  244. package/dist/esm/justifi-saved-payment-method.entry.js +1 -1
  245. package/dist/esm/justifi-season-interruption-insurance.entry.js +4 -5
  246. package/dist/esm/justifi-skeleton.entry.js +1 -1
  247. package/dist/esm/justifi-terminal-orders-list-filters.entry.js +4 -3
  248. package/dist/esm/justifi-terminal-orders-list.entry.js +6 -5
  249. package/dist/esm/justifi-terminals-list-filters.entry.js +3 -2
  250. package/dist/esm/justifi-terminals-list.entry.js +7 -6
  251. package/dist/esm/justifi-tokenize-payment-method.entry.js +1 -1
  252. package/dist/esm/loader.js +1 -1
  253. package/dist/esm/{package-DQf0KCJj.js → package-BGHeOtXW.js} +1 -1
  254. package/dist/esm/pagination-menu.entry.js +3 -3
  255. package/dist/esm/payment-details-core.entry.js +10 -9
  256. package/dist/esm/payment-method-option.entry.js +1 -1
  257. package/dist/esm/{payment.service-nExZY_sU.js → payment.service-BreQSu6J.js} +1 -1
  258. package/dist/esm/payments-list-core.entry.js +3 -2
  259. package/dist/esm/payout-details-core.entry.js +3 -3
  260. package/dist/esm/{payout.service-B9-JQqU6.js → payout.service-DuqRe6oq.js} +1 -1
  261. package/dist/esm/payouts-list-core.entry.js +3 -2
  262. package/dist/esm/table-filters-menu.entry.js +1 -1
  263. package/dist/esm/terminal-orders-list-core.entry.js +4 -3
  264. package/dist/esm/{terminal-orders-table-DsrpmD9F.js → terminal-orders-table-DSo5x2D7.js} +1 -1
  265. package/dist/esm/terminal-quantity-selector.entry.js +1 -1
  266. package/dist/esm/{terminal.service-DvFiKAKV.js → terminal.service-CkzrYIA_.js} +1 -1
  267. package/dist/esm/terminals-list-core.entry.js +3 -2
  268. package/dist/esm/webcomponents.js +1 -1
  269. package/dist/module/Analytics.js +2 -0
  270. package/dist/module/ApplePay.js +121 -0
  271. package/dist/module/GooglePay.js +184 -0
  272. package/dist/module/ModularCheckout.js +1 -0
  273. package/dist/module/additional-questions.js +2 -2
  274. package/dist/module/additional-statement.js +1 -1
  275. package/dist/module/apple-pay.js +1 -120
  276. package/dist/module/bank-account-billing-form-simple.js +1 -1
  277. package/dist/module/bank-account-document-inputs.js +3 -1
  278. package/dist/module/bank-account-form-inputs-canada2.js +1 -1
  279. package/dist/module/bank-account-form-inputs2.js +1 -1
  280. package/dist/module/bank-account-form.js +2 -2
  281. package/dist/module/bank-account-read-only-value2.js +1 -1
  282. package/dist/module/bank-account.js +2 -2
  283. package/dist/module/business-additional-questions-form-step.js +1 -1
  284. package/dist/module/business-bank-account-form-step-core.js +2 -0
  285. package/dist/module/business-bank-account-form-step.js +3 -1
  286. package/dist/module/business-core-info-form-step.js +1 -1
  287. package/dist/module/business-core-info.js +2 -2
  288. package/dist/module/business-owners-form-step.js +1 -1
  289. package/dist/module/business-representative-form-inputs.js +2 -2
  290. package/dist/module/business-representative-form-step.js +1 -1
  291. package/dist/module/business-representative.js +3 -3
  292. package/dist/module/business-terms-conditions-form-step.js +3 -1
  293. package/dist/module/business.service.js +2 -0
  294. package/dist/module/cancellation-policy.js +1 -1
  295. package/dist/module/card-billing-form-simple.js +1 -1
  296. package/dist/module/card-form.js +2 -2
  297. package/dist/module/card-form2.js +2 -2
  298. package/dist/module/checkout.service.js +2 -0
  299. package/dist/module/checkout.store.js +4 -0
  300. package/dist/module/checkouts-list-core2.js +3 -1
  301. package/dist/module/custom-popper2.js +2 -2
  302. package/dist/module/customer-details.js +1 -1
  303. package/dist/module/details.js +1 -1
  304. package/dist/module/dispute-management-core.js +1 -1
  305. package/dist/module/dispute-notification.js +2 -2
  306. package/dist/module/dispute-response-actions.js +2 -0
  307. package/dist/module/dispute-response-core.js +1 -1
  308. package/dist/module/dispute-response.js +1 -1
  309. package/dist/module/duplicate-charge.js +1 -1
  310. package/dist/module/electronic-evidence.js +1 -1
  311. package/dist/module/form-address-fields.js +1 -1
  312. package/dist/module/form-control-checkbox2.js +2 -2
  313. package/dist/module/form-control-date2.js +2 -2
  314. package/dist/module/form-control-file-v22.js +1 -1
  315. package/dist/module/form-control-file2.js +2 -2
  316. package/dist/module/form-control-monetary-provisioning2.js +2 -2
  317. package/dist/module/form-control-monetary2.js +2 -2
  318. package/dist/module/form-control-number-masked2.js +2 -2
  319. package/dist/module/form-control-number.js +2 -2
  320. package/dist/module/form-control-radio2.js +2 -2
  321. package/dist/module/form-control-select2.js +2 -2
  322. package/dist/module/form-control-text2.js +2 -2
  323. package/dist/module/form-control-textarea2.js +2 -2
  324. package/dist/module/get-payment-details.js +2 -0
  325. package/dist/module/get-subaccounts.js +2 -0
  326. package/dist/module/google-pay.js +785 -0
  327. package/dist/module/gross-payment-chart-core2.js +1 -1
  328. package/dist/module/hidden-input2.js +1 -1
  329. package/dist/module/identity-address-form.js +1 -1
  330. package/dist/module/iframe-input2.js +3 -3
  331. package/dist/module/internal-tokenize-payment-method2.js +3 -1
  332. package/dist/module/justifi-business-form.js +2 -0
  333. package/dist/module/justifi-button2.js +1 -1
  334. package/dist/module/justifi-checkout.js +46 -40
  335. package/dist/module/justifi-checkouts-list-filters.js +3 -1
  336. package/dist/module/justifi-checkouts-list.js +3 -1
  337. package/dist/module/justifi-dispute-management.js +1 -1
  338. package/dist/module/justifi-google-pay.d.ts +11 -0
  339. package/dist/module/justifi-google-pay.js +6 -0
  340. package/dist/module/justifi-gross-payment-chart.js +2 -0
  341. package/dist/module/justifi-header2.js +1 -1
  342. package/dist/module/justifi-order-terminals.js +3 -1
  343. package/dist/module/justifi-payment-provisioning.js +3 -1
  344. package/dist/module/justifi-payment-transactions-list.js +3 -1
  345. package/dist/module/justifi-payments-list-filters.js +2 -2
  346. package/dist/module/justifi-payments-list.js +3 -1
  347. package/dist/module/justifi-payout-details.js +2 -0
  348. package/dist/module/justifi-payout-transactions-list.js +3 -1
  349. package/dist/module/justifi-payouts-list-filters.js +2 -2
  350. package/dist/module/justifi-payouts-list.js +3 -1
  351. package/dist/module/justifi-radio-list-item2.js +1 -1
  352. package/dist/module/justifi-refund-payment.js +2 -0
  353. package/dist/module/justifi-saved-payment-method.js +1 -1
  354. package/dist/module/justifi-season-interruption-insurance.js +2 -0
  355. package/dist/module/justifi-skeleton.js +1 -1
  356. package/dist/module/justifi-terminal-orders-list-filters.js +4 -2
  357. package/dist/module/justifi-terminal-orders-list.js +3 -1
  358. package/dist/module/justifi-terminals-list-filters.js +3 -1
  359. package/dist/module/justifi-terminals-list.js +3 -1
  360. package/dist/module/justifi-tokenize-payment-method.js +1 -1
  361. package/dist/module/legal-address-form-step.js +1 -1
  362. package/dist/module/legal-address-form.js +2 -2
  363. package/dist/module/modular-checkout.js +46 -6
  364. package/dist/module/owner-form-core2.js +1 -1
  365. package/dist/module/owner-form-inputs2.js +3 -3
  366. package/dist/module/owner-form.js +1 -1
  367. package/dist/module/package.js +1 -1
  368. package/dist/module/pagination-menu2.js +3 -3
  369. package/dist/module/payment-details-core2.js +10 -8
  370. package/dist/module/payment-method-option.js +1 -1
  371. package/dist/module/payment-provisioning-core.js +1 -1
  372. package/dist/module/payment-provisioning-form-buttons.js +1 -1
  373. package/dist/module/payment-provisioning-form-steps.js +1 -1
  374. package/dist/module/payment.service.js +2 -0
  375. package/dist/module/payments-list-core2.js +3 -1
  376. package/dist/module/payout-details-core2.js +3 -3
  377. package/dist/module/payout.service.js +2 -0
  378. package/dist/module/payouts-list-core2.js +3 -1
  379. package/dist/module/plaid.service.js +2 -0
  380. package/dist/module/product-or-service.js +1 -1
  381. package/dist/module/refund-policy.js +1 -1
  382. package/dist/module/save-new-payment-method.js +1 -1
  383. package/dist/module/shipping-details.js +1 -1
  384. package/dist/module/summary.js +1 -1
  385. package/dist/module/table-filters-menu2.js +1 -1
  386. package/dist/module/terminal-orders-list-core2.js +3 -1
  387. package/dist/module/terminal-quantity-selector2.js +1 -1
  388. package/dist/module/terminal.service.js +2 -0
  389. package/dist/module/terminals-list-core2.js +3 -1
  390. package/dist/types/api/Checkout.d.ts +2 -0
  391. package/dist/types/api/GooglePay.d.ts +271 -0
  392. package/dist/types/api/index.d.ts +2 -0
  393. package/dist/types/api/services/google-pay.service.d.ts +60 -0
  394. package/dist/types/components/business-forms/schemas/business-form-schema.d.ts +3 -3
  395. package/dist/types/components/checkout/checkout.d.ts +1 -0
  396. package/dist/types/components/modular-checkout/ModularCheckout.d.ts +2 -1
  397. package/dist/types/components/modular-checkout/modular-checkout.d.ts +5 -0
  398. package/dist/types/components/modular-checkout/sub-components/google-pay-skeleton.d.ts +6 -0
  399. package/dist/types/components/modular-checkout/sub-components/google-pay.d.ts +59 -0
  400. package/dist/types/components/tokenize-payment-method/tokenize-payment-method.d.ts +1 -1
  401. package/dist/types/components.d.ts +160 -22
  402. package/dist/types/store/checkout.store.d.ts +1 -0
  403. package/dist/types/ui-components/google-pay-button.d.ts +18 -0
  404. package/dist/webcomponents/index.esm.js +1 -1
  405. package/dist/webcomponents/{p-aec9185f.entry.js → p-03c8c754.entry.js} +1 -1
  406. package/dist/webcomponents/p-0772719b.entry.js +1 -0
  407. package/dist/webcomponents/p-0b64560d.entry.js +1 -0
  408. package/dist/webcomponents/p-0ca05626.entry.js +1 -0
  409. package/dist/webcomponents/p-136b29e3.entry.js +1 -0
  410. package/dist/webcomponents/p-13b55ca1.entry.js +1 -0
  411. package/dist/webcomponents/p-13bdb5ed.entry.js +1 -0
  412. package/dist/webcomponents/p-13ee296a.entry.js +1 -0
  413. package/dist/webcomponents/p-16812327.entry.js +1 -0
  414. package/dist/webcomponents/p-1989a253.entry.js +1 -0
  415. package/dist/webcomponents/{p-1193a1ac.entry.js → p-19dabeab.entry.js} +1 -1
  416. package/dist/webcomponents/p-1f196690.entry.js +1 -0
  417. package/dist/webcomponents/{p-800660f2.entry.js → p-270bf699.entry.js} +1 -1
  418. package/dist/webcomponents/p-2da4e6ca.entry.js +1 -0
  419. package/dist/webcomponents/p-2eb123a3.entry.js +1 -0
  420. package/dist/webcomponents/p-38e1ef4b.entry.js +1 -0
  421. package/dist/webcomponents/p-3ae12b98.entry.js +1 -0
  422. package/dist/webcomponents/{p-58ae4f9e.entry.js → p-3bacf834.entry.js} +1 -1
  423. package/dist/webcomponents/p-3c006a15.entry.js +1 -0
  424. package/dist/webcomponents/p-3d69b6b1.entry.js +1 -0
  425. package/dist/webcomponents/p-404b3f02.entry.js +1 -0
  426. package/dist/webcomponents/p-48cf806b.entry.js +1 -0
  427. package/dist/webcomponents/{p-e2e6c201.entry.js → p-48d1bc83.entry.js} +1 -1
  428. package/dist/webcomponents/p-499dc735.entry.js +1 -0
  429. package/dist/webcomponents/{p-af48a6bb.entry.js → p-4e71de94.entry.js} +1 -1
  430. package/dist/webcomponents/p-4f102cfd.entry.js +1 -0
  431. package/dist/webcomponents/p-7dbd0618.entry.js +1 -0
  432. package/dist/webcomponents/{p-1edec396.entry.js → p-86111a0a.entry.js} +1 -1
  433. package/dist/webcomponents/p-8b6b7e20.entry.js +1 -0
  434. package/dist/webcomponents/p-8fcd277c.entry.js +1 -0
  435. package/dist/webcomponents/p-90d1c943.entry.js +1 -0
  436. package/dist/webcomponents/p-914b590d.entry.js +1 -0
  437. package/dist/webcomponents/p-9a795f44.entry.js +1 -0
  438. package/dist/webcomponents/p-BGHeOtXW.js +1 -0
  439. package/dist/webcomponents/{p-CPtsjcdm.js → p-BKM7YeAB.js} +1 -1
  440. package/dist/webcomponents/p-BN1PYSFf.js +1 -0
  441. package/dist/webcomponents/p-BRbk6oSh.js +1 -0
  442. package/dist/webcomponents/{p-CFevTCAJ.js → p-BVwVhXcQ.js} +1 -1
  443. package/dist/webcomponents/p-BxtmTjqW.js +1 -0
  444. package/dist/webcomponents/p-CQrwlULd.js +1 -0
  445. package/dist/webcomponents/{p-B4ZUYyNh.js → p-CVhnuewz.js} +1 -1
  446. package/dist/webcomponents/{p-D_IJC4HG.js → p-Cmb6PRFh.js} +1 -1
  447. package/dist/webcomponents/p-DkoufM1t.js +1 -0
  448. package/dist/webcomponents/{p-BCPutgAi.js → p-Dy5btfGV.js} +1 -1
  449. package/dist/webcomponents/{p-LeyS3YJV.js → p-MdHYTSKO.js} +1 -1
  450. package/dist/webcomponents/p-a020c889.entry.js +1 -0
  451. package/dist/webcomponents/{p-0082f428.entry.js → p-a22d1078.entry.js} +1 -1
  452. package/dist/webcomponents/p-a6e816f6.entry.js +1 -0
  453. package/dist/webcomponents/p-a9f75a9e.entry.js +1 -0
  454. package/dist/webcomponents/{p-8681f258.entry.js → p-aaed4997.entry.js} +1 -1
  455. package/dist/webcomponents/p-ad9307c1.entry.js +1 -0
  456. package/dist/webcomponents/p-adddbcb7.entry.js +1 -0
  457. package/dist/webcomponents/p-af55fc0d.entry.js +1 -0
  458. package/dist/webcomponents/p-b3f8d5d4.entry.js +1 -0
  459. package/dist/webcomponents/p-b9d64d6b.entry.js +1 -0
  460. package/dist/webcomponents/p-ba0762f9.entry.js +1 -0
  461. package/dist/webcomponents/p-c14bc83f.entry.js +1 -0
  462. package/dist/webcomponents/p-c16dbe20.entry.js +1 -0
  463. package/dist/webcomponents/p-c249483e.entry.js +1 -0
  464. package/dist/webcomponents/p-c4044170.entry.js +1 -0
  465. package/dist/webcomponents/p-c41191e7.entry.js +1 -0
  466. package/dist/webcomponents/p-c621e7af.entry.js +1 -0
  467. package/dist/webcomponents/p-c88babbe.entry.js +1 -0
  468. package/dist/webcomponents/{p-f6ea74db.entry.js → p-cee402a5.entry.js} +1 -1
  469. package/dist/webcomponents/p-d2935214.entry.js +1 -0
  470. package/dist/webcomponents/p-dd0d0f96.entry.js +1 -0
  471. package/dist/webcomponents/p-def8124c.entry.js +1 -0
  472. package/dist/webcomponents/{p-2769f945.entry.js → p-e6507b93.entry.js} +1 -1
  473. package/dist/webcomponents/{p-ed55d333.entry.js → p-e7e5fee9.entry.js} +1 -1
  474. package/dist/webcomponents/p-ea18fcd9.entry.js +1 -0
  475. package/dist/webcomponents/p-ed9de6ed.entry.js +1 -0
  476. package/dist/webcomponents/p-ee122560.entry.js +1 -0
  477. package/dist/webcomponents/{p-4e23116c.entry.js → p-f2650bfc.entry.js} +1 -1
  478. package/dist/webcomponents/p-f4cb581f.entry.js +1 -0
  479. package/dist/webcomponents/p-f528da70.entry.js +1 -0
  480. package/dist/webcomponents/{p-9f70ce93.entry.js → p-fe862786.entry.js} +1 -1
  481. package/dist/webcomponents/p-fe8f8a7f.entry.js +1 -0
  482. package/dist/webcomponents/{p-C8QOezo8.js → p-t8p0WAW4.js} +1 -1
  483. package/dist/webcomponents/webcomponents.esm.js +1 -1
  484. package/package.json +13 -13
  485. package/LICENSE +0 -21
  486. package/dist/cjs/checkout.store-BA6h-dp2.js +0 -107
  487. package/dist/esm/checkout.store-CaS_htQd.js +0 -101
  488. package/dist/webcomponents/p-159d8ae7.entry.js +0 -1
  489. package/dist/webcomponents/p-20a8b0c0.entry.js +0 -1
  490. package/dist/webcomponents/p-22f74666.entry.js +0 -1
  491. package/dist/webcomponents/p-25b382b8.entry.js +0 -1
  492. package/dist/webcomponents/p-30f61f44.entry.js +0 -1
  493. package/dist/webcomponents/p-3437ce38.entry.js +0 -1
  494. package/dist/webcomponents/p-34aa9298.entry.js +0 -1
  495. package/dist/webcomponents/p-36720116.entry.js +0 -1
  496. package/dist/webcomponents/p-39706e38.entry.js +0 -1
  497. package/dist/webcomponents/p-3c38cec5.entry.js +0 -1
  498. package/dist/webcomponents/p-42d756b8.entry.js +0 -1
  499. package/dist/webcomponents/p-44a94dac.entry.js +0 -1
  500. package/dist/webcomponents/p-45936490.entry.js +0 -1
  501. package/dist/webcomponents/p-4761e0aa.entry.js +0 -1
  502. package/dist/webcomponents/p-4baabba0.entry.js +0 -1
  503. package/dist/webcomponents/p-4dcbc0af.entry.js +0 -1
  504. package/dist/webcomponents/p-54ff9b59.entry.js +0 -1
  505. package/dist/webcomponents/p-5c8c88c6.entry.js +0 -1
  506. package/dist/webcomponents/p-66688508.entry.js +0 -1
  507. package/dist/webcomponents/p-7218c312.entry.js +0 -1
  508. package/dist/webcomponents/p-77b76007.entry.js +0 -1
  509. package/dist/webcomponents/p-77bd4fb0.entry.js +0 -1
  510. package/dist/webcomponents/p-79d77eb9.entry.js +0 -1
  511. package/dist/webcomponents/p-7ee0bae1.entry.js +0 -1
  512. package/dist/webcomponents/p-80f5b2c8.entry.js +0 -1
  513. package/dist/webcomponents/p-84e2bd93.entry.js +0 -1
  514. package/dist/webcomponents/p-89518b26.entry.js +0 -1
  515. package/dist/webcomponents/p-8b944d09.entry.js +0 -1
  516. package/dist/webcomponents/p-942c8949.entry.js +0 -1
  517. package/dist/webcomponents/p-98b8028e.entry.js +0 -1
  518. package/dist/webcomponents/p-9e1f4231.entry.js +0 -1
  519. package/dist/webcomponents/p-BojLBYsY.js +0 -1
  520. package/dist/webcomponents/p-BpaE8q5f.js +0 -1
  521. package/dist/webcomponents/p-Ch9cTPyq.js +0 -1
  522. package/dist/webcomponents/p-DCIW8z1f.js +0 -1
  523. package/dist/webcomponents/p-DQf0KCJj.js +0 -1
  524. package/dist/webcomponents/p-DU8dqq9U.js +0 -1
  525. package/dist/webcomponents/p-MQxr_LMC.js +0 -1
  526. package/dist/webcomponents/p-a4540205.entry.js +0 -1
  527. package/dist/webcomponents/p-a655b996.entry.js +0 -1
  528. package/dist/webcomponents/p-ad5e488a.entry.js +0 -1
  529. package/dist/webcomponents/p-af236d05.entry.js +0 -1
  530. package/dist/webcomponents/p-af4e501d.entry.js +0 -1
  531. package/dist/webcomponents/p-b0e80802.entry.js +0 -1
  532. package/dist/webcomponents/p-b4d8a3f6.entry.js +0 -1
  533. package/dist/webcomponents/p-bf8cf72d.entry.js +0 -1
  534. package/dist/webcomponents/p-c3b71a1f.entry.js +0 -1
  535. package/dist/webcomponents/p-d2d69454.entry.js +0 -1
  536. package/dist/webcomponents/p-da26e869.entry.js +0 -1
  537. package/dist/webcomponents/p-daa534f1.entry.js +0 -1
  538. package/dist/webcomponents/p-dc0d3484.entry.js +0 -1
  539. package/dist/webcomponents/p-e91af879.entry.js +0 -1
  540. package/dist/webcomponents/p-eb56ba9b.entry.js +0 -1
  541. package/dist/webcomponents/p-ed006dd6.entry.js +0 -1
  542. package/dist/webcomponents/p-edcb84bf.entry.js +0 -1
  543. package/dist/webcomponents/p-efb2a58a.entry.js +0 -1
  544. package/dist/webcomponents/p-f91b79fb.entry.js +0 -1
  545. package/dist/webcomponents/p-fab28b02.entry.js +0 -1
@@ -2,149 +2,28 @@
2
2
 
3
3
  var index = require('./index-BhI7cJcE.js');
4
4
  var Api = require('./Api-BeSnjEuW.js');
5
+ var GooglePay$1 = require('./GooglePay-HXBAmTgL.js');
5
6
  var styledHost = require('./styled-host-D5g7INLE.js');
6
7
  require('./event-types-YOY5TKUN.js');
7
8
  var skeleton = require('./skeleton-BF3HGL9X.js');
8
- var checkout_store = require('./checkout.store-BA6h-dp2.js');
9
9
  var parts = require('./parts-Pb06tUMp.js');
10
10
  var utils = require('./utils-Bab-tddY.js');
11
+ var index$1 = require('./index-CajjbB9t.js');
11
12
  var header1 = require('./header-1-CBO8uDuZ.js');
12
13
  var insuranceState = require('./insurance-state-BMHITXoD.js');
13
14
  var header3 = require('./header-3-CPWtI1t0.js');
14
- var checkPkgVersion = require('./check-pkg-version-D06Nzj0h.js');
15
+ var checkPkgVersion = require('./check-pkg-version-DNFRhNcW.js');
15
16
  require('./config-state-CYoBVAca.js');
16
17
  require('./dinero-BwNN_k7x.js');
17
18
  var ComponentError = require('./ComponentError-D4OLnOkg.js');
18
- var Refund = require('./Refund-Blquw3jZ.js');
19
19
  require('./Pagination-Dediz133.js');
20
20
  require('./Business-DWHy_-z9.js');
21
21
  require('./Dispute-CruQTF6_.js');
22
22
  var utils$1 = require('./utils-DvUQQLmR.js');
23
- var checkout_service = require('./checkout.service-BEU6CI0t.js');
24
- var index$1 = require('./index-C2ITzalN.js');
23
+ var checkout_service = require('./checkout.service-CHNHEsrp.js');
25
24
  var paymentMethodOptionUtils = require('./payment-method-option-utils-WYHIHy-l.js');
26
25
  require('./index-mmd0OhmD.js');
27
- require('./package-gCv25hzn.js');
28
-
29
- var ApplePaySessionStatus;
30
- (function (ApplePaySessionStatus) {
31
- ApplePaySessionStatus["STATUS_SUCCESS"] = "STATUS_SUCCESS";
32
- ApplePaySessionStatus["STATUS_FAILURE"] = "STATUS_FAILURE";
33
- })(ApplePaySessionStatus || (ApplePaySessionStatus = {}));
34
- var ApplePayButtonType;
35
- (function (ApplePayButtonType) {
36
- ApplePayButtonType["PLAIN"] = "plain";
37
- ApplePayButtonType["BUY"] = "buy";
38
- ApplePayButtonType["SET_UP"] = "set-up";
39
- ApplePayButtonType["DONATE"] = "donate";
40
- ApplePayButtonType["CHECK_OUT"] = "check-out";
41
- ApplePayButtonType["BOOK"] = "book";
42
- ApplePayButtonType["SUBSCRIBE"] = "subscribe";
43
- })(ApplePayButtonType || (ApplePayButtonType = {}));
44
- var ApplePayButtonStyle;
45
- (function (ApplePayButtonStyle) {
46
- ApplePayButtonStyle["BLACK"] = "black";
47
- ApplePayButtonStyle["WHITE"] = "white";
48
- ApplePayButtonStyle["WHITE_OUTLINE"] = "white-outline";
49
- })(ApplePayButtonStyle || (ApplePayButtonStyle = {}));
50
- var ApplePayMerchantCapability;
51
- (function (ApplePayMerchantCapability) {
52
- ApplePayMerchantCapability["SUPPORTS_3DS"] = "supports3DS";
53
- ApplePayMerchantCapability["SUPPORTS_EMV"] = "supportsEMV";
54
- ApplePayMerchantCapability["SUPPORTS_CREDIT"] = "supportsCredit";
55
- ApplePayMerchantCapability["SUPPORTS_DEBIT"] = "supportsDebit";
56
- })(ApplePayMerchantCapability || (ApplePayMerchantCapability = {}));
57
- class ApplePayConfig {
58
- constructor(data) {
59
- this.merchantIdentifier = data.merchantIdentifier;
60
- this.displayName = data.displayName;
61
- this.initiative = data.initiative;
62
- this.initiativeContext = data.initiativeContext;
63
- this.buttonType = data.buttonType || ApplePayButtonType.PLAIN;
64
- this.buttonStyle = data.buttonStyle || ApplePayButtonStyle.BLACK;
65
- this.buttonLocale = data.buttonLocale || 'en-US';
66
- }
67
- get isValid() {
68
- return !!(this.merchantIdentifier &&
69
- this.displayName &&
70
- this.initiative &&
71
- this.initiativeContext);
72
- }
73
- }
74
- class ApplePayPaymentRequest {
75
- constructor(data) {
76
- this.countryCode = data.countryCode;
77
- this.currencyCode = data.currencyCode;
78
- this.merchantCapabilities = data.merchantCapabilities;
79
- this.supportedNetworks = data.supportedNetworks;
80
- this.total = data.total;
81
- this.lineItems = data.lineItems;
82
- this.shippingMethods = data.shippingMethods;
83
- this.applicationData = data.applicationData;
84
- this.supportedCountries = data.supportedCountries;
85
- }
86
- get isValid() {
87
- var _a, _b, _c, _d;
88
- return !!(this.countryCode &&
89
- this.currencyCode &&
90
- ((_a = this.merchantCapabilities) === null || _a === void 0 ? void 0 : _a.length) &&
91
- ((_b = this.supportedNetworks) === null || _b === void 0 ? void 0 : _b.length) &&
92
- ((_c = this.total) === null || _c === void 0 ? void 0 : _c.label) &&
93
- ((_d = this.total) === null || _d === void 0 ? void 0 : _d.amount));
94
- }
95
- }
96
- class ApplePayHelpers {
97
- static isApplePaySupported() {
98
- var _a;
99
- return (typeof window !== 'undefined' &&
100
- 'ApplePaySession' in window &&
101
- ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.supportsVersion(3)));
102
- }
103
- static canMakePayments() {
104
- var _a;
105
- if (!this.isApplePaySupported()) {
106
- return false;
107
- }
108
- return ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.canMakePayments()) || false;
109
- }
110
- static async canMakePaymentsWithActiveCard(merchantIdentifier) {
111
- var _a;
112
- if (!this.isApplePaySupported()) {
113
- return false;
114
- }
115
- try {
116
- return ((await ((_a = window.ApplePaySession) === null || _a === void 0 ? void 0 : _a.canMakePaymentsWithActiveCard(merchantIdentifier))) || false);
117
- }
118
- catch (error) {
119
- console.error('Error checking Apple Pay active card:', error);
120
- return false;
121
- }
122
- }
123
- static formatAmount(amount) {
124
- return (amount / 100).toFixed(2);
125
- }
126
- static parseAmount(amount) {
127
- return Math.round(parseFloat(amount) * 100);
128
- }
129
- static createLineItem(label, amount, type = 'final') {
130
- return {
131
- label,
132
- amount: this.formatAmount(amount),
133
- type,
134
- };
135
- }
136
- static getDefaultSupportedNetworks() {
137
- return ['amex', 'discover', 'masterCard', 'visa'];
138
- }
139
- static getDefaultMerchantCapabilities() {
140
- return [
141
- ApplePayMerchantCapability.SUPPORTS_3DS,
142
- ApplePayMerchantCapability.SUPPORTS_EMV,
143
- ApplePayMerchantCapability.SUPPORTS_CREDIT,
144
- ApplePayMerchantCapability.SUPPORTS_DEBIT,
145
- ];
146
- }
147
- }
26
+ require('./package-Z2EW-l1q.js');
148
27
 
149
28
  // Centralized error codes for Apple Pay service
150
29
  var ApplePayServiceErrorCode;
@@ -163,7 +42,7 @@ class ApplePayService {
163
42
  * Initialize Apple Pay configuration
164
43
  */
165
44
  initialize(applePayConfig) {
166
- this.applePayConfig = new ApplePayConfig(applePayConfig);
45
+ this.applePayConfig = new GooglePay$1.ApplePayConfig(applePayConfig);
167
46
  if (!this.applePayConfig.isValid) {
168
47
  throw new Error('Invalid Apple Pay configuration provided');
169
48
  }
@@ -214,7 +93,7 @@ class ApplePayService {
214
93
  * Check if Apple Pay is available on this device/browser
215
94
  */
216
95
  isAvailable() {
217
- return (ApplePayHelpers.isApplePaySupported() && ApplePayHelpers.canMakePayments());
96
+ return (GooglePay$1.ApplePayHelpers.isApplePaySupported() && GooglePay$1.ApplePayHelpers.canMakePayments());
218
97
  }
219
98
  /**
220
99
  * Check if the user has an active card for the merchant
@@ -223,7 +102,7 @@ class ApplePayService {
223
102
  if (!this.applePayConfig) {
224
103
  throw new Error('Apple Pay not initialized. Call initialize() first.');
225
104
  }
226
- return await ApplePayHelpers.canMakePaymentsWithActiveCard(this.applePayConfig.merchantIdentifier);
105
+ return await GooglePay$1.ApplePayHelpers.canMakePaymentsWithActiveCard(this.applePayConfig.merchantIdentifier);
227
106
  }
228
107
  /**
229
108
  * Start Apple Pay session
@@ -237,7 +116,7 @@ class ApplePayService {
237
116
  // if (!this.isAvailable()) {
238
117
  // throw new Error('Apple Pay is not available on this device/browser');
239
118
  // }
240
- const request = new ApplePayPaymentRequest(paymentRequest);
119
+ const request = new GooglePay$1.ApplePayPaymentRequest(paymentRequest);
241
120
  if (!request.isValid) {
242
121
  const missingFields = [];
243
122
  if (!request.countryCode)
@@ -348,13 +227,13 @@ class ApplePayService {
348
227
  const payment = event.payment;
349
228
  const paymentPayload = Object.assign(Object.assign({}, payment.token), { product_details: {
350
229
  name: this.currentPaymentRequest.total.label,
351
- price: ApplePayHelpers.parseAmount(this.currentPaymentRequest.total.amount),
230
+ price: GooglePay$1.ApplePayHelpers.parseAmount(this.currentPaymentRequest.total.amount),
352
231
  description: this.currentPaymentRequest.total.label,
353
232
  } });
354
233
  const paymentResult = await this.processPayment(authToken, accountId, paymentPayload);
355
234
  if (paymentResult.success) {
356
235
  this.currentSession.completePayment({
357
- status: ApplePaySessionStatus.STATUS_SUCCESS,
236
+ status: GooglePay$1.ApplePaySessionStatus.STATUS_SUCCESS,
358
237
  });
359
238
  resolve({
360
239
  success: true,
@@ -365,7 +244,7 @@ class ApplePayService {
365
244
  else {
366
245
  console.error('PSP reported payment failure:', paymentResult.data);
367
246
  this.currentSession.completePayment({
368
- status: ApplePaySessionStatus.STATUS_FAILURE,
247
+ status: GooglePay$1.ApplePaySessionStatus.STATUS_FAILURE,
369
248
  });
370
249
  reject({
371
250
  success: false,
@@ -383,7 +262,7 @@ class ApplePayService {
383
262
  console.error('Error stack:', error.stack);
384
263
  }
385
264
  this.currentSession.completePayment({
386
- status: ApplePaySessionStatus.STATUS_FAILURE,
265
+ status: GooglePay$1.ApplePaySessionStatus.STATUS_FAILURE,
387
266
  });
388
267
  reject({
389
268
  success: false,
@@ -415,7 +294,7 @@ class ApplePayService {
415
294
  };
416
295
  this.currentSession.onshippingmethodselected = () => {
417
296
  this.currentSession.completeShippingMethodSelection({
418
- status: ApplePaySessionStatus.STATUS_SUCCESS,
297
+ status: GooglePay$1.ApplePaySessionStatus.STATUS_SUCCESS,
419
298
  newTotal: this.currentPaymentRequest.total,
420
299
  newLineItems: this.currentPaymentRequest.lineItems || [],
421
300
  });
@@ -475,9 +354,9 @@ class ApplePayService {
475
354
  return {
476
355
  countryCode,
477
356
  currencyCode,
478
- merchantCapabilities: ApplePayHelpers.getDefaultMerchantCapabilities(),
479
- supportedNetworks: ApplePayHelpers.getDefaultSupportedNetworks(),
480
- total: ApplePayHelpers.createLineItem(label, amount),
357
+ merchantCapabilities: GooglePay$1.ApplePayHelpers.getDefaultMerchantCapabilities(),
358
+ supportedNetworks: GooglePay$1.ApplePayHelpers.getDefaultSupportedNetworks(),
359
+ total: GooglePay$1.ApplePayHelpers.createLineItem(label, amount),
481
360
  };
482
361
  }
483
362
  /**
@@ -496,30 +375,30 @@ const ApplePaySkeleton = (props) => {
496
375
  return (index.h("div", { class: 'container-fluid p-0' }, index.h("div", { class: 'row mb-3' }, index.h("div", { class: 'col-12 align-content-center' }, index.h(skeleton.Skeleton, { height: '44px', width: '100%', styles: { borderRadius: "8px" } })))));
497
376
  };
498
377
 
499
- const ProcessingSpinner = () => (index.h("div", { class: 'processing-overlay' }, index.h("div", { class: 'spinner' }), index.h("span", null, "Processing...")));
378
+ const ProcessingSpinner$1 = () => (index.h("div", { class: 'processing-overlay' }, index.h("div", { class: 'spinner' }), index.h("span", null, "Processing...")));
500
379
  const ApplePayButton = (props) => {
501
380
  const getApplePayButtonClass = () => {
502
381
  let classes = "apple-pay-button";
503
382
  switch (props.buttonStyle) {
504
- case ApplePayButtonStyle.WHITE:
383
+ case GooglePay$1.ApplePayButtonStyle.WHITE:
505
384
  classes += " apple-pay-button-white";
506
385
  break;
507
- case ApplePayButtonStyle.WHITE_OUTLINE:
386
+ case GooglePay$1.ApplePayButtonStyle.WHITE_OUTLINE:
508
387
  classes += " apple-pay-button-white-outline";
509
388
  break;
510
- case ApplePayButtonStyle.BLACK:
389
+ case GooglePay$1.ApplePayButtonStyle.BLACK:
511
390
  default:
512
391
  classes += " apple-pay-button-black";
513
392
  break;
514
393
  }
515
394
  switch (props.buttonType) {
516
- case ApplePayButtonType.BUY:
395
+ case GooglePay$1.ApplePayButtonType.BUY:
517
396
  classes += " apple-pay-button-type-buy";
518
397
  break;
519
- case ApplePayButtonType.DONATE:
398
+ case GooglePay$1.ApplePayButtonType.DONATE:
520
399
  classes += " apple-pay-button-type-donate";
521
400
  break;
522
- case ApplePayButtonType.PLAIN:
401
+ case GooglePay$1.ApplePayButtonType.PLAIN:
523
402
  default:
524
403
  classes += " apple-pay-button-type-plain";
525
404
  break;
@@ -540,7 +419,7 @@ const ApplePayButton = (props) => {
540
419
  return (index.h("div", { class: 'apple-pay-button-container' }, index.h("button", Object.assign({ class: getApplePayButtonClass(), style: {
541
420
  width: props.width,
542
421
  height: props.height,
543
- }, onClick: handleClick, disabled: props.disabled || props.isProcessing || !props.isAvailable, "aria-label": 'Pay with Apple Pay', type: 'button' }, props), props.isProcessing && ProcessingSpinner()), index.h("style", null, `
422
+ }, onClick: handleClick, disabled: props.disabled || props.isProcessing || !props.isAvailable, "aria-label": 'Pay with Apple Pay', type: 'button' }, props), props.isProcessing && ProcessingSpinner$1()), index.h("style", null, `
544
423
  .apple-pay-button-container {
545
424
  display: block;
546
425
  position: relative;
@@ -650,8 +529,8 @@ const ApplePay = class {
650
529
  this.merchantIdentifier = "merchant.com.staging-justifi.checkout-dev";
651
530
  this.merchantDisplayName = "JustiFi Checkout";
652
531
  this.initiativeContext = "dev-checkout.justifi-staging.com";
653
- this.buttonType = ApplePayButtonType.PLAIN;
654
- this.buttonStyle = ApplePayButtonStyle.BLACK;
532
+ this.buttonType = GooglePay$1.ApplePayButtonType.PLAIN;
533
+ this.buttonStyle = GooglePay$1.ApplePayButtonStyle.BLACK;
655
534
  this.disabled = false;
656
535
  this.showSkeleton = true;
657
536
  this.width = "100%";
@@ -673,16 +552,16 @@ const ApplePay = class {
673
552
  this.applePayStarted.emit();
674
553
  const paymentRequest = {
675
554
  countryCode: this.countryCode,
676
- currencyCode: checkout_store.checkoutStore.paymentCurrency,
555
+ currencyCode: GooglePay$1.checkoutStore.paymentCurrency,
677
556
  merchantCapabilities: [
678
- ApplePayMerchantCapability.SUPPORTS_3DS,
679
- ApplePayMerchantCapability.SUPPORTS_CREDIT,
680
- ApplePayMerchantCapability.SUPPORTS_DEBIT,
557
+ GooglePay$1.ApplePayMerchantCapability.SUPPORTS_3DS,
558
+ GooglePay$1.ApplePayMerchantCapability.SUPPORTS_CREDIT,
559
+ GooglePay$1.ApplePayMerchantCapability.SUPPORTS_DEBIT,
681
560
  ],
682
- supportedNetworks: ApplePayHelpers.getDefaultSupportedNetworks(),
683
- total: ApplePayHelpers.createLineItem(checkout_store.checkoutStore.paymentDescription, checkout_store.checkoutStore.paymentAmount),
561
+ supportedNetworks: GooglePay$1.ApplePayHelpers.getDefaultSupportedNetworks(),
562
+ total: GooglePay$1.ApplePayHelpers.createLineItem(GooglePay$1.checkoutStore.paymentDescription, GooglePay$1.checkoutStore.paymentAmount),
684
563
  };
685
- const result = await this.applePayService.startPaymentSession(paymentRequest, checkout_store.checkoutStore.authToken, checkout_store.checkoutStore.accountId);
564
+ const result = await this.applePayService.startPaymentSession(paymentRequest, GooglePay$1.checkoutStore.authToken, GooglePay$1.checkoutStore.accountId);
686
565
  if (result.success) {
687
566
  this.applePayCompleted.emit({
688
567
  success: true,
@@ -720,24 +599,24 @@ const ApplePay = class {
720
599
  this.isLoading = true;
721
600
  this.error = null;
722
601
  this.isConfigValid = true;
723
- const hasRequiredConfig = Boolean(checkout_store.checkoutStore.paymentAmount) &&
724
- Boolean(checkout_store.checkoutStore.paymentCurrency) &&
725
- Boolean(checkout_store.checkoutStore.authToken);
602
+ const hasRequiredConfig = Boolean(GooglePay$1.checkoutStore.paymentAmount) &&
603
+ Boolean(GooglePay$1.checkoutStore.paymentCurrency) &&
604
+ Boolean(GooglePay$1.checkoutStore.authToken);
726
605
  if (!hasRequiredConfig) {
727
606
  this.error = "Missing required Apple Pay configuration";
728
607
  this.isConfigValid = false;
729
608
  console.error("Apple Pay config error: missing required values", {
730
- paymentAmount: checkout_store.checkoutStore.paymentAmount,
731
- paymentCurrency: checkout_store.checkoutStore.paymentCurrency,
732
- hasAuthToken: Boolean(checkout_store.checkoutStore.authToken),
733
- accountId: checkout_store.checkoutStore.accountId,
609
+ paymentAmount: GooglePay$1.checkoutStore.paymentAmount,
610
+ paymentCurrency: GooglePay$1.checkoutStore.paymentCurrency,
611
+ hasAuthToken: Boolean(GooglePay$1.checkoutStore.authToken),
612
+ accountId: GooglePay$1.checkoutStore.accountId,
734
613
  });
735
614
  this.applePayError.emit({ error: this.error, code: ApplePay.ErrorCode.CONFIG_ERROR });
736
615
  this.isLoading = false;
737
616
  return;
738
617
  }
739
- this.isAvailable = ApplePayHelpers.isApplePaySupported();
740
- this.canMakePayments = ApplePayHelpers.canMakePayments();
618
+ this.isAvailable = GooglePay$1.ApplePayHelpers.isApplePaySupported();
619
+ this.canMakePayments = GooglePay$1.ApplePayHelpers.canMakePayments();
741
620
  if (!this.isAvailable) {
742
621
  this.error = "Apple Pay is not supported on this device";
743
622
  console.error(this.error);
@@ -786,7 +665,7 @@ const ApplePay = class {
786
665
  if (!this.isAvailable) {
787
666
  return [];
788
667
  }
789
- return ApplePayHelpers.getDefaultSupportedNetworks();
668
+ return GooglePay$1.ApplePayHelpers.getDefaultSupportedNetworks();
790
669
  }
791
670
  async abort() {
792
671
  this.applePayService.abortPaymentSession();
@@ -794,7 +673,7 @@ const ApplePay = class {
794
673
  this.applePayCancelled.emit();
795
674
  }
796
675
  render() {
797
- if (!checkout_store.checkoutStore.applePayEnabled) {
676
+ if (!GooglePay$1.checkoutStore.applePayEnabled) {
798
677
  // Render nothing when Apple Pay is disabled at the checkout settings level
799
678
  return null;
800
679
  }
@@ -802,7 +681,7 @@ const ApplePay = class {
802
681
  this.isAvailable &&
803
682
  this.canMakePayments &&
804
683
  this.isConfigValid;
805
- return (index.h(styledHost.StyledHost, null, checkout_store.checkoutStore.checkoutLoaded && (index.h("script", { async: true, src: 'https://applepay.cdn-apple.com/jsapi/1.latest/apple-pay-sdk.js', onLoad: () => {
684
+ return (index.h(styledHost.StyledHost, null, GooglePay$1.checkoutStore.checkoutLoaded && (index.h("script", { async: true, src: 'https://applepay.cdn-apple.com/jsapi/1.latest/apple-pay-sdk.js', onLoad: () => {
806
685
  this.initializeApplePay();
807
686
  } })), index.h("div", { class: 'apple-pay-container' }, index.h(ApplePaySkeleton, { isLoading: this.isLoading }), isReady && (index.h(ApplePayButton, { buttonType: this.buttonType, buttonStyle: this.buttonStyle, disabled: this.disabled, isProcessing: this.isProcessing, isAvailable: this.isAvailable, clickHandler: this.handleApplePayClick, width: this.width, height: this.height }))), index.h("style", null, `
808
687
  .apple-pay-container {
@@ -825,8 +704,740 @@ const Summary = class {
825
704
  index.registerInstance(this, hostRef);
826
705
  }
827
706
  render() {
828
- return (index.h(styledHost.StyledHost, { key: 'fd2c61dcafdc800d0064c19d29c6e007aed5adb5' }, index.h("section", { key: 'f2abef1233f3ccad3982d10c61ec5765e13e27a5' }, index.h("div", { key: '713d66ef6f7e2fc73135e765069baba6df976f52' }, index.h("div", { key: 'b8dd28f257948aa317366fe3ea6d2bc4911ef164', part: parts.text }, checkout_store.checkoutStore === null || checkout_store.checkoutStore === void 0 ? void 0 : checkout_store.checkoutStore.paymentDescription), index.h("div", { key: '675676b40de7dc27d07bfafc0eee77eb855a3d26' }, index.h("span", { key: 'cbd47994d9c3f1518741a298de3f5d62a0ad5313', part: parts.text }, "Total"), "\u00A0", index.h("span", { key: '614748853f666f1b072d4fa9b14ee15ef5717112', part: parts.text }, utils.formatCurrency(+(checkout_store.checkoutStore === null || checkout_store.checkoutStore === void 0 ? void 0 : checkout_store.checkoutStore.totalAmount))))))));
707
+ return (index.h(styledHost.StyledHost, { key: '3ebaf90f9085614d44043d9b5ba7de3f926bf6f1' }, index.h("section", { key: '888ea6f17ece8e78b7ddf9302be5b1b355cd54c6' }, index.h("div", { key: 'bb7db155a31ceb9e824c5290b8fb8d8713622bdd' }, index.h("div", { key: 'dc954f18e824dabfb09fc727aeb87685020e2d1e', part: parts.text }, GooglePay$1.checkoutStore === null || GooglePay$1.checkoutStore === void 0 ? void 0 : GooglePay$1.checkoutStore.paymentDescription), index.h("div", { key: 'e7f6b12c142655fc967bd6a37e00193b9f743f84' }, index.h("span", { key: '25996f66626d428385422d72f5e2bba1a8301628', part: parts.text }, "Total"), "\u00A0", index.h("span", { key: '958bd1242ac23e13e66b73563d2c6f73499d2574', part: parts.text }, utils.formatCurrency(+(GooglePay$1.checkoutStore === null || GooglePay$1.checkoutStore === void 0 ? void 0 : GooglePay$1.checkoutStore.totalAmount))))))));
708
+ }
709
+ };
710
+
711
+ const PROCESS_TOKEN_ENDPOINT = 'google_pay/process_token';
712
+ class GooglePayService {
713
+ constructor() {
714
+ this.api = Api.Api();
715
+ }
716
+ /**
717
+ * Initialize Google Pay configuration
718
+ */
719
+ initialize(googlePayConfig) {
720
+ this.googlePayConfig = new GooglePay$1.GooglePayConfig(googlePayConfig);
721
+ if (!this.googlePayConfig.isValid) {
722
+ throw new Error('Invalid Google Pay configuration provided');
723
+ }
724
+ // Create Google Pay client
725
+ this.googlePayClient = GooglePay$1.GooglePayHelpers.createGooglePayClient(this.googlePayConfig.environment);
726
+ if (!this.googlePayClient) {
727
+ throw new Error('Failed to create Google Pay client');
728
+ }
729
+ // No debug logs
730
+ }
731
+ /**
732
+ * Process Google Pay payment via API
733
+ */
734
+ async processPayment(authToken, accountId, payload) {
735
+ const endpoint = PROCESS_TOKEN_ENDPOINT;
736
+ try {
737
+ const result = await this.api.post({
738
+ endpoint,
739
+ authToken,
740
+ body: payload,
741
+ headers: {
742
+ 'sub-account': accountId,
743
+ },
744
+ });
745
+ return {
746
+ success: result.id && !!result.data.token,
747
+ data: result,
748
+ };
749
+ }
750
+ catch (_error) {
751
+ throw new Error('Google Pay payment processing failed');
752
+ }
753
+ }
754
+ /**
755
+ * Check if Google Pay is available on this device/browser
756
+ */
757
+ isAvailable() {
758
+ return GooglePay$1.GooglePayHelpers.isGooglePaySupported() && !!this.googlePayClient;
759
+ }
760
+ /**
761
+ * Check if the user can make payments with Google Pay
762
+ */
763
+ async canMakePayments() {
764
+ if (!this.googlePayClient || !this.googlePayConfig) {
765
+ return false;
766
+ }
767
+ try {
768
+ const baseRequest = GooglePay$1.GooglePayHelpers.createBasePaymentDataRequest();
769
+ const response = await this.googlePayClient.isReadyToPay(baseRequest);
770
+ return response.result;
771
+ }
772
+ catch (_error) {
773
+ return false;
774
+ }
775
+ }
776
+ /**
777
+ * Start Google Pay payment session
778
+ */
779
+ async startPaymentSession(paymentDataRequest, authToken, accountId) {
780
+ var _a;
781
+ if (!this.googlePayConfig || !this.googlePayClient) {
782
+ throw new Error('Google Pay not initialized. Call initialize() first.');
783
+ }
784
+ if (!this.isAvailable()) {
785
+ throw new Error('Google Pay is not available on this device/browser');
786
+ }
787
+ const request = new GooglePay$1.GooglePayPaymentDataRequest(paymentDataRequest);
788
+ if (!request.isValid) {
789
+ throw new Error('Invalid payment data request provided');
790
+ }
791
+ try {
792
+ const paymentData = await this.googlePayClient.loadPaymentData(request);
793
+ // Build top-level snake_case fields from Google Pay tokenizationData
794
+ const tokenizationData = (_a = paymentData === null || paymentData === void 0 ? void 0 : paymentData.paymentMethodData) === null || _a === void 0 ? void 0 : _a.tokenizationData;
795
+ const tokenObj = (() => {
796
+ if ((tokenizationData === null || tokenizationData === void 0 ? void 0 : tokenizationData.token) &&
797
+ typeof tokenizationData.token === 'string') {
798
+ try {
799
+ return JSON.parse(tokenizationData.token);
800
+ }
801
+ catch (_e) {
802
+ return tokenizationData;
803
+ }
804
+ }
805
+ return tokenizationData;
806
+ })();
807
+ const tokenProcessRequest = {
808
+ protocolVersion: tokenObj === null || tokenObj === void 0 ? void 0 : tokenObj.protocolVersion,
809
+ signature: tokenObj === null || tokenObj === void 0 ? void 0 : tokenObj.signature,
810
+ intermediateSigningKey: (tokenObj === null || tokenObj === void 0 ? void 0 : tokenObj.intermediateSigningKey)
811
+ ? {
812
+ signedKey: tokenObj.intermediateSigningKey.signedKey,
813
+ signatures: tokenObj.intermediateSigningKey.signatures,
814
+ }
815
+ : undefined,
816
+ signedMessage: tokenObj === null || tokenObj === void 0 ? void 0 : tokenObj.signedMessage,
817
+ };
818
+ const paymentResult = await this.processPayment(authToken, accountId, tokenProcessRequest);
819
+ if (paymentResult.success) {
820
+ return {
821
+ success: true,
822
+ paymentData: paymentData,
823
+ paymentMethodId: paymentResult.data.id,
824
+ };
825
+ }
826
+ else {
827
+ return {
828
+ success: false,
829
+ error: {
830
+ code: 'PAYMENT_PROCESSING_ERROR',
831
+ message: 'Payment processing failed',
832
+ },
833
+ };
834
+ }
835
+ }
836
+ catch (error) {
837
+ // Handle different types of errors
838
+ if (error && typeof error === 'object' && 'statusCode' in error) {
839
+ const googlePayError = error;
840
+ switch (googlePayError.statusCode) {
841
+ case 'CANCELED':
842
+ return {
843
+ success: false,
844
+ error: {
845
+ code: 'USER_CANCELLED',
846
+ message: 'User cancelled the Google Pay session',
847
+ },
848
+ };
849
+ case 'DEVELOPER_ERROR':
850
+ return {
851
+ success: false,
852
+ error: {
853
+ code: 'DEVELOPER_ERROR',
854
+ message: 'Google Pay configuration error',
855
+ },
856
+ };
857
+ default:
858
+ return {
859
+ success: false,
860
+ error: {
861
+ code: 'PAYMENT_ERROR',
862
+ message: googlePayError.statusMessage || 'Google Pay payment failed',
863
+ },
864
+ };
865
+ }
866
+ }
867
+ return {
868
+ success: false,
869
+ error: {
870
+ code: 'PAYMENT_ERROR',
871
+ message: error instanceof Error
872
+ ? error.message
873
+ : 'Google Pay payment failed',
874
+ },
875
+ };
876
+ }
877
+ }
878
+ /**
879
+ * Create Google Pay button element
880
+ */
881
+ createButton(options) {
882
+ if (!this.googlePayClient || !this.googlePayConfig) {
883
+ return null;
884
+ }
885
+ try {
886
+ return this.googlePayClient.createButton({
887
+ onClick: options.onClick,
888
+ buttonType: options.buttonType,
889
+ buttonSizeMode: options.buttonSizeMode,
890
+ buttonColor: options.buttonColor,
891
+ buttonLocale: options.buttonLocale,
892
+ });
893
+ }
894
+ catch (_error) {
895
+ return null;
896
+ }
897
+ }
898
+ /**
899
+ * Prefetch payment data for faster loading
900
+ */
901
+ prefetchPaymentData(paymentDataRequest) {
902
+ if (!this.googlePayClient) {
903
+ return;
904
+ }
905
+ const request = new GooglePay$1.GooglePayPaymentDataRequest(paymentDataRequest);
906
+ if (!request.isValid) {
907
+ return;
908
+ }
909
+ try {
910
+ this.googlePayClient.prefetchPaymentData(request);
911
+ }
912
+ catch (_error) { }
913
+ }
914
+ /**
915
+ * Create a basic payment data request
916
+ */
917
+ static createPaymentDataRequest(amount, label, countryCode = 'US', currencyCode = 'USD', merchantName) {
918
+ const request = {
919
+ apiVersion: 2,
920
+ apiVersionMinor: 0,
921
+ allowedPaymentMethods: [GooglePay$1.GooglePayHelpers.createPaymentMethodData()],
922
+ transactionInfo: {
923
+ countryCode,
924
+ currencyCode,
925
+ totalPriceStatus: 'FINAL',
926
+ totalPrice: GooglePay$1.GooglePayHelpers.formatAmount(amount),
927
+ totalPriceLabel: label,
928
+ },
929
+ merchantInfo: {
930
+ merchantName,
931
+ },
932
+ };
933
+ // No debug logs
934
+ return request;
935
+ }
936
+ /**
937
+ * Get current configuration
938
+ */
939
+ getGooglePayConfig() {
940
+ return this.googlePayConfig;
941
+ }
942
+ /**
943
+ * Get current Google Pay client
944
+ */
945
+ getGooglePayClient() {
946
+ return this.googlePayClient;
947
+ }
948
+ }
949
+
950
+ const GooglePaySkeleton = (props) => {
951
+ const { isLoading } = props;
952
+ if (!isLoading) {
953
+ return null;
954
+ }
955
+ return (index.h("div", { class: 'container-fluid p-0' }, index.h("div", { class: 'row mb-3' }, index.h("div", { class: 'col-12 align-content-center' }, index.h(skeleton.Skeleton, { height: '44px', width: '100%', styles: { borderRadius: "8px" } })))));
956
+ };
957
+
958
+ const ProcessingSpinner = () => (index.h("div", { class: 'processing-overlay' }, index.h("div", { class: 'spinner' }), index.h("span", null, "Processing...")));
959
+ const GooglePayButton = (props) => {
960
+ const getGooglePayButtonClass = () => {
961
+ let classes = "google-pay-button";
962
+ // Button style
963
+ switch (props.buttonStyle) {
964
+ case GooglePay$1.GooglePayButtonStyle.WHITE:
965
+ classes += " google-pay-button-white";
966
+ break;
967
+ case GooglePay$1.GooglePayButtonStyle.BLACK:
968
+ default:
969
+ classes += " google-pay-button-black";
970
+ break;
971
+ }
972
+ // Button type
973
+ switch (props.buttonType) {
974
+ case GooglePay$1.GooglePayButtonType.BUY:
975
+ classes += " google-pay-button-type-buy";
976
+ break;
977
+ case GooglePay$1.GooglePayButtonType.BOOK:
978
+ classes += " google-pay-button-type-book";
979
+ break;
980
+ case GooglePay$1.GooglePayButtonType.CHECKOUT:
981
+ classes += " google-pay-button-type-checkout";
982
+ break;
983
+ case GooglePay$1.GooglePayButtonType.DONATE:
984
+ classes += " google-pay-button-type-donate";
985
+ break;
986
+ case GooglePay$1.GooglePayButtonType.ORDER:
987
+ classes += " google-pay-button-type-order";
988
+ break;
989
+ case GooglePay$1.GooglePayButtonType.PAY:
990
+ classes += " google-pay-button-type-pay";
991
+ break;
992
+ case GooglePay$1.GooglePayButtonType.SUBSCRIBE:
993
+ classes += " google-pay-button-type-subscribe";
994
+ break;
995
+ case GooglePay$1.GooglePayButtonType.PLAIN:
996
+ default:
997
+ classes += " google-pay-button-type-plain";
998
+ break;
999
+ }
1000
+ // Size mode
1001
+ switch (props.buttonSizeMode) {
1002
+ case GooglePay$1.GooglePayButtonSizeMode.FILL:
1003
+ classes += " google-pay-button-fill";
1004
+ break;
1005
+ case GooglePay$1.GooglePayButtonSizeMode.STATIC:
1006
+ default:
1007
+ classes += " google-pay-button-static";
1008
+ break;
1009
+ }
1010
+ if (props.disabled || props.isProcessing || !props.isAvailable) {
1011
+ classes += " disabled";
1012
+ }
1013
+ return classes;
1014
+ };
1015
+ const getButtonStyles = () => {
1016
+ const styles = {};
1017
+ if (props.buttonSizeMode === GooglePay$1.GooglePayButtonSizeMode.FILL) {
1018
+ styles.width = '100%';
1019
+ styles.minWidth = '200px';
1020
+ }
1021
+ else {
1022
+ styles.width = props.width || '200px';
1023
+ }
1024
+ styles.height = props.height || '48px';
1025
+ return styles;
1026
+ };
1027
+ const handleClick = () => {
1028
+ if (!props.disabled &&
1029
+ !props.isProcessing &&
1030
+ props.isAvailable &&
1031
+ props.clickHandler) {
1032
+ props.clickHandler();
1033
+ }
1034
+ };
1035
+ return (index.h("div", { class: 'google-pay-button-container' }, index.h("button", Object.assign({ class: getGooglePayButtonClass(), style: getButtonStyles(), onClick: handleClick, disabled: props.disabled || props.isProcessing || !props.isAvailable, "aria-label": 'Pay with Google Pay', type: 'button' }, props), props.isProcessing && ProcessingSpinner(), index.h("div", { class: 'google-pay-button-content' }, index.h("svg", { class: 'google-g-logo', viewBox: '0 0 24 24', xmlns: 'http://www.w3.org/2000/svg' }, index.h("path", { d: 'M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z', fill: '#4285F4' }), index.h("path", { d: 'M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z', fill: '#34A853' }), index.h("path", { d: 'M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z', fill: '#FBBC05' }), index.h("path", { d: 'M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z', fill: '#EA4335' })), index.h("span", { class: 'pay-text' }, "Pay"))), index.h("style", null, `
1036
+ .google-pay-button-container {
1037
+ display: block;
1038
+ position: relative;
1039
+ }
1040
+
1041
+ .google-pay-button {
1042
+ display: flex;
1043
+ align-items: center;
1044
+ justify-content: center;
1045
+ border: none;
1046
+ border-radius: 4px;
1047
+ cursor: pointer;
1048
+ font-family: 'Google Sans', arial, sans-serif;
1049
+ font-size: 14px;
1050
+ font-weight: 500;
1051
+ letter-spacing: 0.25px;
1052
+ line-height: 16px;
1053
+ outline: none;
1054
+ padding: 0 20px;
1055
+ position: relative;
1056
+ transition: box-shadow 0.2s ease;
1057
+ min-width: 140px;
1058
+ min-height: 48px;
1059
+ }
1060
+
1061
+ /* Button styles */
1062
+ .google-pay-button.google-pay-button-black {
1063
+ background-color: #000;
1064
+ color: #fff;
1065
+ box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.12), 0 1px 3px 1px rgba(0, 0, 0, 0.15);
1066
+ }
1067
+
1068
+ .google-pay-button.google-pay-button-white {
1069
+ background-color: #fff;
1070
+ color: #3c4043;
1071
+ box-shadow: 0 1px 1px 0 rgba(60, 64, 67, 0.30), 0 1px 3px 1px rgba(60, 64, 67, 0.15);
1072
+ }
1073
+
1074
+ /* Button content */
1075
+ .google-pay-button-content {
1076
+ display: flex;
1077
+ align-items: center;
1078
+ justify-content: center;
1079
+ gap: 8px;
1080
+ white-space: nowrap;
1081
+ }
1082
+
1083
+ .google-g-logo {
1084
+ width: 20px;
1085
+ height: 20px;
1086
+ flex-shrink: 0;
1087
+ }
1088
+
1089
+ .pay-text {
1090
+ font-family: 'Google Sans', arial, sans-serif;
1091
+ font-size: 14px;
1092
+ font-weight: 500;
1093
+ margin-left: 8px;
1094
+ }
1095
+
1096
+ /* Button types - text content handled by ::before pseudo-element */
1097
+ .google-pay-button-type-buy .google-pay-button-content::before {
1098
+ content: 'Buy with';
1099
+ margin-right: 8px;
1100
+ }
1101
+
1102
+ .google-pay-button-type-book .google-pay-button-content::before {
1103
+ content: 'Book with';
1104
+ margin-right: 8px;
1105
+ }
1106
+
1107
+ .google-pay-button-type-checkout .google-pay-button-content::before {
1108
+ content: 'Checkout with';
1109
+ margin-right: 8px;
1110
+ }
1111
+
1112
+ .google-pay-button-type-donate .google-pay-button-content::before {
1113
+ content: 'Donate with';
1114
+ margin-right: 8px;
1115
+ }
1116
+
1117
+ .google-pay-button-type-order .google-pay-button-content::before {
1118
+ content: 'Order with';
1119
+ margin-right: 8px;
1120
+ }
1121
+
1122
+ .google-pay-button-type-pay .google-pay-button-content::before {
1123
+ content: 'Pay with';
1124
+ margin-right: 8px;
1125
+ }
1126
+
1127
+ .google-pay-button-type-subscribe .google-pay-button-content::before {
1128
+ content: 'Subscribe with';
1129
+ margin-right: 8px;
1130
+ }
1131
+
1132
+ /* Size modes */
1133
+ .google-pay-button.google-pay-button-fill {
1134
+ width: 100%;
1135
+ min-width: 200px;
1136
+ }
1137
+
1138
+ .google-pay-button.google-pay-button-static {
1139
+ width: auto;
1140
+ }
1141
+
1142
+ /* Hover and focus states */
1143
+ .google-pay-button:hover:not(.disabled) {
1144
+ box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.15), 0 1px 3px 1px rgba(0, 0, 0, 0.30);
1145
+ }
1146
+
1147
+ .google-pay-button:focus:not(.disabled) {
1148
+ box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.15), 0 1px 3px 1px rgba(0, 0, 0, 0.30);
1149
+ }
1150
+
1151
+ .google-pay-button:active:not(.disabled) {
1152
+ box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.15), 0 1px 3px 1px rgba(0, 0, 0, 0.30);
1153
+ transform: translateY(1px);
1154
+ }
1155
+
1156
+ /* Disabled state */
1157
+ .google-pay-button.disabled {
1158
+ opacity: 0.5;
1159
+ cursor: not-allowed;
1160
+ box-shadow: none;
1161
+ }
1162
+
1163
+ .google-pay-button.disabled:hover,
1164
+ .google-pay-button.disabled:focus,
1165
+ .google-pay-button.disabled:active {
1166
+ box-shadow: none;
1167
+ transform: none;
1168
+ }
1169
+
1170
+ /* Processing overlay */
1171
+ .processing-overlay {
1172
+ position: absolute;
1173
+ top: 0;
1174
+ left: 0;
1175
+ right: 0;
1176
+ bottom: 0;
1177
+ display: flex;
1178
+ align-items: center;
1179
+ justify-content: center;
1180
+ gap: 8px;
1181
+ background: rgba(0, 0, 0, 0.8);
1182
+ color: white;
1183
+ border-radius: 4px;
1184
+ font-size: 14px;
1185
+ font-weight: 500;
1186
+ }
1187
+
1188
+ .spinner {
1189
+ width: 16px;
1190
+ height: 16px;
1191
+ border: 2px solid rgba(255, 255, 255, 0.3);
1192
+ border-top: 2px solid #fff;
1193
+ border-radius: 50%;
1194
+ animation: spin 1s linear infinite;
1195
+ }
1196
+
1197
+ @keyframes spin {
1198
+ 0% { transform: rotate(0deg); }
1199
+ 100% { transform: rotate(360deg); }
1200
+ }
1201
+
1202
+ /* Responsive design */
1203
+ @media (max-width: 480px) {
1204
+ .google-pay-button {
1205
+ width: 100% !important;
1206
+ min-width: 200px;
1207
+ }
1208
+ }
1209
+ `)));
1210
+ };
1211
+
1212
+ const GooglePay = class {
1213
+ constructor(hostRef) {
1214
+ index.registerInstance(this, hostRef);
1215
+ this.googlePayCancelled = index.createEvent(this, "googlePayCancelled");
1216
+ this.googlePayCompleted = index.createEvent(this, "googlePayCompleted");
1217
+ this.googlePayStarted = index.createEvent(this, "googlePayStarted");
1218
+ this.unsubscribes = [];
1219
+ this.canMakePayments = false;
1220
+ this.error = null;
1221
+ this.isAvailable = false;
1222
+ this.isLoading = true;
1223
+ this.isProcessing = false;
1224
+ this.buttonSizeMode = GooglePay$1.GooglePayButtonSizeMode.FILL;
1225
+ this.buttonStyle = GooglePay$1.GooglePayButtonStyle.BLACK;
1226
+ this.buttonType = GooglePay$1.GooglePayButtonType.PLAIN;
1227
+ this.countryCode = "US";
1228
+ this.disabled = false;
1229
+ this.environment = GooglePay$1.GooglePayEnvironment.PRODUCTION;
1230
+ this.merchantId = "gateway:justifi";
1231
+ this.merchantName = "justifi";
1232
+ this.showSkeleton = true;
1233
+ this.handleGooglePayClick = async () => {
1234
+ var _a;
1235
+ if (this.isProcessing ||
1236
+ this.disabled ||
1237
+ !this.isAvailable ||
1238
+ !this.canMakePayments) {
1239
+ return;
1240
+ }
1241
+ try {
1242
+ this.isProcessing = true;
1243
+ this.error = null;
1244
+ this.googlePayStarted.emit();
1245
+ const paymentDataRequest = this.createPaymentDataRequest();
1246
+ const result = await this.googlePayService.startPaymentSession(paymentDataRequest, GooglePay$1.checkoutStore.authToken, GooglePay$1.checkoutStore.accountId);
1247
+ if (result.success) {
1248
+ this.googlePayCompleted.emit({
1249
+ success: true,
1250
+ paymentData: result.paymentData,
1251
+ paymentMethodId: result.paymentMethodId,
1252
+ });
1253
+ }
1254
+ else {
1255
+ this.googlePayCompleted.emit({
1256
+ success: false,
1257
+ error: result.error,
1258
+ });
1259
+ if (((_a = result.error) === null || _a === void 0 ? void 0 : _a.code) === "USER_CANCELLED") {
1260
+ this.googlePayCancelled.emit();
1261
+ }
1262
+ }
1263
+ }
1264
+ catch (error) {
1265
+ const errorMessage = error instanceof Error ? error.message : "Payment failed";
1266
+ this.error = errorMessage;
1267
+ this.googlePayCompleted.emit({
1268
+ success: false,
1269
+ error: errorMessage,
1270
+ });
1271
+ }
1272
+ finally {
1273
+ this.isProcessing = false;
1274
+ }
1275
+ };
1276
+ }
1277
+ watchConfigChange() {
1278
+ this.initializeGooglePay();
1279
+ }
1280
+ componentWillLoad() {
1281
+ this.googlePayService = new GooglePayService();
1282
+ }
1283
+ componentDidLoad() {
1284
+ const unsub = GooglePay$1.onChange("paymentAmount", () => {
1285
+ this.prefetchPaymentData();
1286
+ });
1287
+ if (typeof unsub === 'function')
1288
+ this.unsubscribes.push(unsub);
1289
+ const unsubCurrency = GooglePay$1.onChange("paymentCurrency", () => {
1290
+ this.prefetchPaymentData();
1291
+ });
1292
+ if (typeof unsubCurrency === 'function')
1293
+ this.unsubscribes.push(unsubCurrency);
1294
+ const unsubDesc = GooglePay$1.onChange("paymentDescription", () => {
1295
+ this.prefetchPaymentData();
1296
+ });
1297
+ if (typeof unsubDesc === 'function')
1298
+ this.unsubscribes.push(unsubDesc);
1299
+ }
1300
+ disconnectedCallback() {
1301
+ this.unsubscribes.forEach((fn) => {
1302
+ try {
1303
+ fn();
1304
+ }
1305
+ catch (_a) { }
1306
+ });
1307
+ this.unsubscribes = [];
1308
+ }
1309
+ /**
1310
+ * Returns supported authentication methods when Google Pay is available.
1311
+ */
1312
+ async getSupportedAuthMethods() {
1313
+ if (!this.isAvailable) {
1314
+ return [];
1315
+ }
1316
+ return GooglePay$1.GooglePayHelpers.getDefaultAuthMethods();
1317
+ }
1318
+ /**
1319
+ * Returns supported card networks when Google Pay is available.
1320
+ */
1321
+ async getSupportedNetworks() {
1322
+ if (!this.isAvailable) {
1323
+ return [];
1324
+ }
1325
+ return GooglePay$1.GooglePayHelpers.getDefaultSupportedNetworks();
1326
+ }
1327
+ /**
1328
+ * Select Google Pay in the modular checkout parent.
1329
+ */
1330
+ async handleSelectionClick() {
1331
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.GOOGLE_PAY };
1332
+ }
1333
+ /**
1334
+ * Returns whether Google Pay is both available and can make payments.
1335
+ */
1336
+ async isSupported() {
1337
+ return this.isAvailable && this.canMakePayments;
1338
+ }
1339
+ /**
1340
+ * Prefetch payment data for faster load times of the Google Pay sheet.
1341
+ */
1342
+ async prefetchPaymentData() {
1343
+ if (!this.isAvailable || !this.canMakePayments) {
1344
+ return;
1345
+ }
1346
+ const paymentDataRequest = this.createPaymentDataRequest();
1347
+ this.googlePayService.prefetchPaymentData(paymentDataRequest);
1348
+ }
1349
+ async initializeGooglePay() {
1350
+ try {
1351
+ this.isLoading = true;
1352
+ this.error = null;
1353
+ if (!GooglePay$1.checkoutStore.paymentAmount) {
1354
+ this.error = "Missing required Google Pay configuration";
1355
+ this.isLoading = false;
1356
+ return;
1357
+ }
1358
+ const googlePayConfig = {
1359
+ environment: this.environment,
1360
+ merchantId: this.merchantId,
1361
+ merchantName: this.merchantName,
1362
+ buttonType: this.buttonType,
1363
+ buttonStyle: this.buttonStyle,
1364
+ buttonSizeMode: this.buttonSizeMode,
1365
+ };
1366
+ this.googlePayService.initialize(googlePayConfig);
1367
+ this.isAvailable = this.googlePayService.isAvailable();
1368
+ if (!this.isAvailable) {
1369
+ this.error = "Google Pay is not supported on this device";
1370
+ this.isLoading = false;
1371
+ return;
1372
+ }
1373
+ this.canMakePayments = await this.googlePayService.canMakePayments();
1374
+ if (!this.canMakePayments) {
1375
+ this.error = "Google Pay is not available for payments";
1376
+ this.isLoading = false;
1377
+ return;
1378
+ }
1379
+ const paymentDataRequest = this.createPaymentDataRequest();
1380
+ this.googlePayService.prefetchPaymentData(paymentDataRequest);
1381
+ }
1382
+ catch (error) {
1383
+ this.error =
1384
+ error instanceof Error
1385
+ ? error.message
1386
+ : "Failed to initialize Google Pay";
1387
+ }
1388
+ finally {
1389
+ this.isLoading = false;
1390
+ }
1391
+ }
1392
+ createPaymentDataRequest() {
1393
+ return GooglePayService.createPaymentDataRequest(GooglePay$1.checkoutStore.paymentAmount, GooglePay$1.checkoutStore.paymentDescription, this.countryCode, GooglePay$1.checkoutStore.paymentCurrency, this.merchantName);
1394
+ }
1395
+ render() {
1396
+ const showError = !this.isLoading && !!this.error;
1397
+ const showDeviceUnavailable = !this.isLoading && !this.error && !this.isAvailable;
1398
+ const showPaymentsUnavailable = !this.isLoading && !this.error && this.isAvailable && !this.canMakePayments;
1399
+ const showButton = !this.isLoading && !this.error && this.isAvailable && this.canMakePayments;
1400
+ return (index.h(styledHost.StyledHost, { key: 'd85684b123cdba175d68a2e216f9150780ac7cf9' }, GooglePay$1.checkoutStore.checkoutLoaded && (index.h("script", { key: 'b78bb8980d670e5b66cb907f89cee6ff2238205c', async: true, src: 'https://pay.google.com/gp/p/js/pay.js', onLoad: () => {
1401
+ this.initializeGooglePay();
1402
+ } })), index.h("div", { key: 'e405efb3a164be9e1d9db5beeb3c01471b647aaf', class: 'google-pay-container' }, index.h(GooglePaySkeleton, { key: 'c17dbb3e305678a1da10e3741ff0b610c549be6e', isLoading: this.isLoading }), showError && (index.h("div", { key: '726895b7c76f3edbbbb1930a317d826b8f8f11fd', class: 'google-pay-error', role: 'alert', "data-testid": 'gp-error' }, index.h("span", { key: '23342ca70b6b5bf28f846ca519cc4fbfb065fc67', class: 'error-icon' }, "\u26A0\uFE0F"), index.h("span", { key: '008315696bc7b7f78f69cfc80160dacabf1205b5', class: 'error-message' }, this.error))), showDeviceUnavailable && (index.h("div", { key: '2e87b4a9e5d0c0201333b79b9c190ca14932391b', class: 'google-pay-unavailable', "data-testid": 'gp-device-unavailable' }, index.h("span", { key: '6db13fc44661500a964422d18550cb31e275f076', class: 'unavailable-message' }, "Google Pay is not available on this device"))), showPaymentsUnavailable && (index.h("div", { key: 'c2ca09e36652800092cc6bcbe4a351b0d604bae2', class: 'google-pay-unavailable', "data-testid": 'gp-payments-unavailable' }, index.h("span", { key: 'a5e75ccbb269249327192b927a0df879d90aefe5', class: 'unavailable-message' }, "Google Pay is not available for payments"))), showButton && (index.h(GooglePayButton, { key: 'a2af46b3970620491e5c005e2b57f7a6d6f06e2c', "data-testid": 'gp-button', buttonType: this.buttonType, buttonStyle: this.buttonStyle, buttonSizeMode: this.buttonSizeMode, disabled: this.disabled, isProcessing: this.isProcessing, isAvailable: this.isAvailable, clickHandler: this.handleGooglePayClick }))), index.h("style", { key: '9890ac44c4f047484396e0b4ae0d04a31489e61f' }, `
1403
+ .google-pay-container {
1404
+ width: 100%;
1405
+ }
1406
+
1407
+ .google-pay-error {
1408
+ display: flex;
1409
+ align-items: center;
1410
+ gap: 8px;
1411
+ padding: 12px;
1412
+ background: #fef2f2;
1413
+ border: 1px solid #fecaca;
1414
+ border-radius: 8px;
1415
+ color: #dc2626;
1416
+ font-size: 14px;
1417
+ }
1418
+
1419
+ .google-pay-unavailable {
1420
+ display: flex;
1421
+ align-items: center;
1422
+ justify-content: center;
1423
+ padding: 12px;
1424
+ background: #f9fafb;
1425
+ border: 1px solid #e5e7eb;
1426
+ border-radius: 8px;
1427
+ color: #6b7280;
1428
+ font-size: 14px;
1429
+ }
1430
+
1431
+ .error-icon {
1432
+ font-size: 16px;
1433
+ }
1434
+
1435
+ `)));
829
1436
  }
1437
+ static get watchers() { return {
1438
+ "merchantId": ["watchConfigChange"],
1439
+ "environment": ["watchConfigChange"]
1440
+ }; }
830
1441
  };
831
1442
 
832
1443
  const Header = class {
@@ -841,7 +1452,7 @@ const Header = class {
841
1452
  }
842
1453
  render() {
843
1454
  const HeaderComponent = this.levels[this.level];
844
- return (index.h(styledHost.StyledHost, { key: 'd4871da09451d40b27220a207ee72317ed9b1b9f' }, index.h(HeaderComponent, { key: 'f7de159fa6395ef4024f48b868369f8d10edf64e', text: this.text, class: this.class })));
1455
+ return (index.h(styledHost.StyledHost, { key: '73104ea086f8a9948e69f86451adf19e0f39fb32' }, index.h(HeaderComponent, { key: 'a8582109634299a24e2a9b3c7181c6bba511fde7', text: this.text, class: this.class })));
845
1456
  }
846
1457
  };
847
1458
 
@@ -927,11 +1538,30 @@ const ModularCheckout = class {
927
1538
  this.submitEvent = index.createEvent(this, "submit-event");
928
1539
  this.checkoutChangedEvent = index.createEvent(this, "checkout-changed");
929
1540
  this.plaidService = new PlaidService();
1541
+ this.handleGooglePayCompleted = (event) => {
1542
+ const { success, paymentMethodId, error } = event.detail || {};
1543
+ if (success && paymentMethodId) {
1544
+ GooglePay$1.checkoutStore.paymentToken = paymentMethodId;
1545
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.GOOGLE_PAY };
1546
+ this.submitCheckout();
1547
+ }
1548
+ else {
1549
+ this.errorEvent.emit({
1550
+ message: (error && error.message) || "Google Pay payment failed",
1551
+ errorCode: ComponentError.ComponentErrorCodes.TOKENIZE_ERROR,
1552
+ severity: ComponentError.ComponentErrorSeverity.ERROR,
1553
+ });
1554
+ }
1555
+ };
1556
+ this.handleGooglePayCancelled = () => {
1557
+ GooglePay$1.checkoutStore.paymentToken = undefined;
1558
+ GooglePay$1.checkoutStore.selectedPaymentMethod = undefined;
1559
+ };
930
1560
  this.handleApplePayCompleted = (event) => {
931
1561
  const { success, token, paymentMethodId, error } = event.detail;
932
1562
  if (success && token) {
933
- checkout_store.checkoutStore.paymentToken = paymentMethodId;
934
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.APPLE_PAY };
1563
+ GooglePay$1.checkoutStore.paymentToken = paymentMethodId;
1564
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.APPLE_PAY };
935
1565
  this.submitCheckout();
936
1566
  }
937
1567
  else {
@@ -954,20 +1584,21 @@ const ModularCheckout = class {
954
1584
  });
955
1585
  };
956
1586
  this.handleApplePayCancelled = () => {
957
- checkout_store.checkoutStore.paymentToken = undefined;
958
- checkout_store.checkoutStore.selectedPaymentMethod = undefined;
1587
+ GooglePay$1.checkoutStore.paymentToken = undefined;
1588
+ GooglePay$1.checkoutStore.selectedPaymentMethod = undefined;
959
1589
  };
960
1590
  }
961
1591
  connectedCallback() {
962
1592
  this.observer = new MutationObserver(() => {
963
1593
  this.queryFormRefs();
964
1594
  this.setupApplePayListeners(); // set up again listeners when DOM changes
1595
+ this.setupGooglePayListeners();
965
1596
  });
966
1597
  this.observer.observe(this.hostEl, {
967
1598
  childList: true,
968
1599
  subtree: true,
969
1600
  });
970
- checkout_store.checkoutStore.checkoutId = this.checkoutId;
1601
+ GooglePay$1.checkoutStore.checkoutId = this.checkoutId;
971
1602
  const config = {
972
1603
  authToken: this.authToken,
973
1604
  checkoutId: this.checkoutId,
@@ -976,14 +1607,14 @@ const ModularCheckout = class {
976
1607
  this.getCheckout = makeGetCheckout(config);
977
1608
  this.completeCheckout = makeCheckoutComplete(config);
978
1609
  // Emit checkout-changed whenever any store key changes
979
- checkout_store.onAnyChange(() => {
1610
+ GooglePay$1.onAnyChange(() => {
980
1611
  this.emitCheckoutChanged();
981
1612
  });
982
1613
  }
983
1614
  componentWillLoad() {
984
1615
  this.analytics = new checkPkgVersion.JustifiAnalytics(this);
985
1616
  checkPkgVersion.checkPkgVersion();
986
- checkout_store.checkoutStore.authToken = this.authToken;
1617
+ GooglePay$1.checkoutStore.authToken = this.authToken;
987
1618
  this.fetchCheckout();
988
1619
  // Refresh the checkout data when insurance values actually change (not on initial load)
989
1620
  insuranceState.insuranceValuesOn("set", (key) => {
@@ -996,11 +1627,13 @@ const ModularCheckout = class {
996
1627
  componentDidLoad() {
997
1628
  this.queryFormRefs();
998
1629
  this.setupApplePayListeners();
1630
+ this.setupGooglePayListeners();
999
1631
  }
1000
1632
  disconnectedCallback() {
1001
1633
  var _a;
1002
1634
  (_a = this.observer) === null || _a === void 0 ? void 0 : _a.disconnect();
1003
1635
  this.removeApplePayListeners();
1636
+ this.removeGooglePayListeners();
1004
1637
  }
1005
1638
  fetchCheckout() {
1006
1639
  if (!this.authToken || !this.checkoutId) {
@@ -1015,7 +1648,7 @@ const ModularCheckout = class {
1015
1648
  this.getCheckout({
1016
1649
  onSuccess: ({ checkout }) => {
1017
1650
  this.updateStore(checkout);
1018
- if (checkout.status === Refund.ICheckoutStatus.completed) {
1651
+ if (checkout.status === GooglePay$1.ICheckoutStatus.completed) {
1019
1652
  this.errorEvent.emit({
1020
1653
  message: ComponentError.ComponentErrorMessages.CHECKOUT_ALREADY_COMPLETED,
1021
1654
  errorCode: ComponentError.ComponentErrorCodes.CHECKOUT_ALREADY_COMPLETED,
@@ -1023,7 +1656,7 @@ const ModularCheckout = class {
1023
1656
  });
1024
1657
  return;
1025
1658
  }
1026
- else if (checkout.status === Refund.ICheckoutStatus.expired) {
1659
+ else if (checkout.status === GooglePay$1.ICheckoutStatus.expired) {
1027
1660
  this.errorEvent.emit({
1028
1661
  message: ComponentError.ComponentErrorMessages.CHECKOUT_EXPIRED,
1029
1662
  errorCode: ComponentError.ComponentErrorCodes.CHECKOUT_EXPIRED,
@@ -1043,35 +1676,37 @@ const ModularCheckout = class {
1043
1676
  }
1044
1677
  }
1045
1678
  updateStore(checkout) {
1046
- var _a, _b, _c, _d, _e, _f;
1047
- checkout_store.checkoutStore.accountId = checkout.account_id;
1048
- checkout_store.checkoutStore.checkoutLoaded = true;
1049
- checkout_store.checkoutStore.paymentMethods = checkout.payment_methods.map((paymentMethod) => new index$1.PaymentMethod(paymentMethod));
1050
- checkout_store.checkoutStore.paymentMethodGroupId = checkout.payment_method_group_id;
1051
- checkout_store.checkoutStore.paymentDescription = checkout.payment_description;
1052
- checkout_store.checkoutStore.totalAmount = checkout.total_amount;
1053
- checkout_store.checkoutStore.paymentAmount = checkout.payment_amount;
1054
- checkout_store.checkoutStore.bnplEnabled = checkout.payment_settings.bnpl_payments;
1055
- checkout_store.checkoutStore.insuranceEnabled = checkout.payment_settings.insurance_payments;
1056
- checkout_store.checkoutStore.bankAccountVerification = (_a = checkout.payment_settings) === null || _a === void 0 ? void 0 : _a.bank_account_verification;
1057
- checkout_store.checkoutStore.applePayEnabled = (_b = checkout.payment_settings) === null || _b === void 0 ? void 0 : _b.apple_payments;
1058
- checkout_store.checkoutStore.bnplProviderClientId = (_c = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _c === void 0 ? void 0 : _c.provider_client_id;
1059
- checkout_store.checkoutStore.bnplProviderMode = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_mode;
1060
- checkout_store.checkoutStore.bnplProviderApiVersion = (_e = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _e === void 0 ? void 0 : _e.provider_api_version;
1061
- checkout_store.checkoutStore.bnplProviderCheckoutUrl =
1062
- (_f = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _f === void 0 ? void 0 : _f.provider_checkout_url;
1679
+ var _a, _b, _c, _d, _e, _f, _g;
1680
+ GooglePay$1.checkoutStore.accountId = checkout.account_id;
1681
+ GooglePay$1.checkoutStore.checkoutLoaded = true;
1682
+ GooglePay$1.checkoutStore.paymentMethods = checkout.payment_methods.map((paymentMethod) => new index$1.PaymentMethod(paymentMethod));
1683
+ GooglePay$1.checkoutStore.paymentMethodGroupId = checkout.payment_method_group_id;
1684
+ GooglePay$1.checkoutStore.paymentDescription = checkout.payment_description;
1685
+ GooglePay$1.checkoutStore.totalAmount = checkout.total_amount;
1686
+ GooglePay$1.checkoutStore.paymentAmount = checkout.payment_amount;
1687
+ GooglePay$1.checkoutStore.bnplEnabled = checkout.payment_settings.bnpl_payments;
1688
+ GooglePay$1.checkoutStore.insuranceEnabled = checkout.payment_settings.insurance_payments;
1689
+ GooglePay$1.checkoutStore.bankAccountVerification = (_a = checkout.payment_settings) === null || _a === void 0 ? void 0 : _a.bank_account_verification;
1690
+ GooglePay$1.checkoutStore.applePayEnabled = (_b = checkout.payment_settings) === null || _b === void 0 ? void 0 : _b.apple_payments;
1691
+ GooglePay$1.checkoutStore.googlePayEnabled = (_c = checkout.payment_settings) === null || _c === void 0 ? void 0 : _c.google_payments;
1692
+ GooglePay$1.checkoutStore.bnplProviderClientId = (_d = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _d === void 0 ? void 0 : _d.provider_client_id;
1693
+ GooglePay$1.checkoutStore.bnplProviderMode = (_e = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _e === void 0 ? void 0 : _e.provider_mode;
1694
+ GooglePay$1.checkoutStore.bnplProviderApiVersion = (_f = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _f === void 0 ? void 0 : _f.provider_api_version;
1695
+ GooglePay$1.checkoutStore.bnplProviderCheckoutUrl =
1696
+ (_g = checkout === null || checkout === void 0 ? void 0 : checkout.bnpl) === null || _g === void 0 ? void 0 : _g.provider_checkout_url;
1063
1697
  }
1064
1698
  emitCheckoutChanged() {
1065
1699
  const detail = {
1066
- availablePaymentMethodTypes: checkout_store.getAvailablePaymentMethodTypes(),
1067
- selectedPaymentMethod: checkout_store.checkoutStore.selectedPaymentMethod,
1068
- savedPaymentMethods: checkout_store.checkoutStore.paymentMethods,
1700
+ availablePaymentMethodTypes: GooglePay$1.getAvailablePaymentMethodTypes(),
1701
+ selectedPaymentMethod: GooglePay$1.checkoutStore.selectedPaymentMethod,
1702
+ savedPaymentMethods: GooglePay$1.checkoutStore.paymentMethods,
1069
1703
  };
1070
1704
  this.checkoutChangedEvent.emit(detail);
1071
1705
  }
1072
1706
  queryFormRefs() {
1073
1707
  this.billingFormRef = this.hostEl.querySelector("justifi-billing-form, justifi-bank-account-billing-form-simple, justifi-card-billing-form-simple, justifi-billing-form-full");
1074
1708
  this.applePayRef = this.hostEl.querySelector("justifi-apple-pay");
1709
+ this.googlePayRef = this.hostEl.querySelector("justifi-google-pay");
1075
1710
  this.paymentMethodFormRef =
1076
1711
  this.hostEl.querySelector('justifi-card-form, justifi-bank-account-form, justifi-tokenize-payment-method');
1077
1712
  this.insuranceFormRef = this.hostEl.querySelector('justifi-season-interruption-insurance');
@@ -1090,40 +1725,52 @@ const ModularCheckout = class {
1090
1725
  this.applePayRef.removeEventListener("applePayCancelled", this.handleApplePayCancelled);
1091
1726
  }
1092
1727
  }
1728
+ setupGooglePayListeners() {
1729
+ if (this.googlePayRef) {
1730
+ this.googlePayRef.addEventListener("googlePayCompleted", this.handleGooglePayCompleted);
1731
+ this.googlePayRef.addEventListener("googlePayCancelled", this.handleGooglePayCancelled);
1732
+ }
1733
+ }
1734
+ removeGooglePayListeners() {
1735
+ if (this.googlePayRef) {
1736
+ this.googlePayRef.removeEventListener("googlePayCompleted", this.handleGooglePayCompleted);
1737
+ this.googlePayRef.removeEventListener("googlePayCancelled", this.handleGooglePayCancelled);
1738
+ }
1739
+ }
1093
1740
  async tokenizePaymentMethod(tokenizeArgs) {
1094
1741
  var _a, _b, _c;
1095
1742
  const billingInfoValues = (_b = (await ((_a = this.billingFormRef) === null || _a === void 0 ? void 0 : _a.getValues()))) !== null && _b !== void 0 ? _b : {};
1096
1743
  const combinedBillingInfo = Object.assign(Object.assign({}, tokenizeArgs), billingInfoValues);
1097
- const paymentMethodMetadata = Object.assign({ accountId: checkout_store.checkoutStore.accountId, payment_method_group_id: undefined }, combinedBillingInfo);
1098
- if (checkout_store.checkoutStore.savePaymentMethod) {
1744
+ const paymentMethodMetadata = Object.assign({ accountId: GooglePay$1.checkoutStore.accountId, payment_method_group_id: undefined }, combinedBillingInfo);
1745
+ if (GooglePay$1.checkoutStore.savePaymentMethod) {
1099
1746
  paymentMethodMetadata.payment_method_group_id =
1100
- checkout_store.checkoutStore.paymentMethodGroupId;
1747
+ GooglePay$1.checkoutStore.paymentMethodGroupId;
1101
1748
  }
1102
1749
  const tokenizeResult = await ((_c = this.paymentMethodFormRef) === null || _c === void 0 ? void 0 : _c.tokenize({
1103
1750
  clientId: this.authToken,
1104
1751
  paymentMethodMetadata,
1105
- account: checkout_store.checkoutStore.accountId,
1752
+ account: GooglePay$1.checkoutStore.accountId,
1106
1753
  }));
1107
1754
  if (tokenizeResult.error) {
1108
1755
  return tokenizeResult;
1109
1756
  }
1110
- checkout_store.checkoutStore.paymentToken = tokenizeResult.id;
1757
+ GooglePay$1.checkoutStore.paymentToken = tokenizeResult.id;
1111
1758
  return tokenizeResult.id;
1112
1759
  }
1113
1760
  // set the selected payment method to the checkout store from outside the component
1114
1761
  async setSelectedPaymentMethod(paymentMethod) {
1115
- checkout_store.checkoutStore.selectedPaymentMethod = paymentMethod;
1116
- checkout_store.checkoutStore.paymentToken = paymentMethod.id || undefined;
1762
+ GooglePay$1.checkoutStore.selectedPaymentMethod = paymentMethod;
1763
+ GooglePay$1.checkoutStore.paymentToken = paymentMethod.id || undefined;
1117
1764
  }
1118
1765
  // if validation fails, the error will be emitted by the component
1119
1766
  async validate() {
1120
1767
  var _a, _b;
1121
1768
  const promises = [];
1122
- if (checkout_store.checkoutStore.insuranceEnabled && this.insuranceFormRef) {
1769
+ if (GooglePay$1.checkoutStore.insuranceEnabled && this.insuranceFormRef) {
1123
1770
  promises.push(this.insuranceFormRef.validate());
1124
1771
  }
1125
- const isNewCard = ((_a = checkout_store.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.NEW_CARD;
1126
- const isNewBankAccount = ((_b = checkout_store.checkoutStore.selectedPaymentMethod) === null || _b === void 0 ? void 0 : _b.type) === index$1.PAYMENT_METHODS.NEW_BANK_ACCOUNT;
1772
+ const isNewCard = ((_a = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.NEW_CARD;
1773
+ const isNewBankAccount = ((_b = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _b === void 0 ? void 0 : _b.type) === index$1.PAYMENT_METHODS.NEW_BANK_ACCOUNT;
1127
1774
  // For new card/bank account, validate payment method + billing.
1128
1775
  if (isNewCard || isNewBankAccount) {
1129
1776
  if (this.paymentMethodFormRef)
@@ -1157,7 +1804,7 @@ const ModularCheckout = class {
1157
1804
  async submitCheckout(submitCheckoutArgs) {
1158
1805
  var _a, _b, _c, _d, _e;
1159
1806
  const isValid = await this.validate();
1160
- if (!checkout_store.checkoutStore.selectedPaymentMethod) {
1807
+ if (!GooglePay$1.checkoutStore.selectedPaymentMethod) {
1161
1808
  this.errorEvent.emit({
1162
1809
  message: 'No payment method selected.',
1163
1810
  errorCode: ComponentError.ComponentErrorCodes.VALIDATION_ERROR,
@@ -1165,9 +1812,9 @@ const ModularCheckout = class {
1165
1812
  });
1166
1813
  return;
1167
1814
  }
1168
- const isNewCard = ((_a = checkout_store.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.NEW_CARD;
1169
- const isNewBankAccount = ((_b = checkout_store.checkoutStore.selectedPaymentMethod) === null || _b === void 0 ? void 0 : _b.type) === index$1.PAYMENT_METHODS.NEW_BANK_ACCOUNT;
1170
- const isPlaid = ((_c = checkout_store.checkoutStore.selectedPaymentMethod) === null || _c === void 0 ? void 0 : _c.type) === index$1.PAYMENT_METHODS.PLAID;
1815
+ const isNewCard = ((_a = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.NEW_CARD;
1816
+ const isNewBankAccount = ((_b = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _b === void 0 ? void 0 : _b.type) === index$1.PAYMENT_METHODS.NEW_BANK_ACCOUNT;
1817
+ const isPlaid = ((_c = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _c === void 0 ? void 0 : _c.type) === index$1.PAYMENT_METHODS.PLAID;
1171
1818
  const shouldTokenize = isNewCard || isNewBankAccount;
1172
1819
  if (shouldTokenize) {
1173
1820
  const tokenizeResult = await this.tokenizePaymentMethod(submitCheckoutArgs);
@@ -1181,9 +1828,9 @@ const ModularCheckout = class {
1181
1828
  }
1182
1829
  }
1183
1830
  // For Plaid, perform exchange at submit time using stored public token and link token id
1184
- if (isPlaid && !checkout_store.checkoutStore.paymentToken) {
1185
- const publicToken = checkout_store.checkoutStore.plaidPublicToken;
1186
- const linkTokenId = checkout_store.checkoutStore.plaidLinkTokenId;
1831
+ if (isPlaid && !GooglePay$1.checkoutStore.paymentToken) {
1832
+ const publicToken = GooglePay$1.checkoutStore.plaidPublicToken;
1833
+ const linkTokenId = GooglePay$1.checkoutStore.plaidLinkTokenId;
1187
1834
  if (!publicToken) {
1188
1835
  this.errorEvent.emit({
1189
1836
  message: 'Missing Plaid public token. Please connect your bank.',
@@ -1193,7 +1840,7 @@ const ModularCheckout = class {
1193
1840
  return;
1194
1841
  }
1195
1842
  try {
1196
- const response = await this.plaidService.tokenizeBankAccount(checkout_store.checkoutStore.authToken, checkout_store.checkoutStore.accountId, publicToken, linkTokenId || undefined, checkout_store.checkoutStore.savePaymentMethod ? checkout_store.checkoutStore.paymentMethodGroupId : undefined);
1843
+ const response = await this.plaidService.tokenizeBankAccount(GooglePay$1.checkoutStore.authToken, GooglePay$1.checkoutStore.accountId, publicToken, linkTokenId || undefined, GooglePay$1.checkoutStore.savePaymentMethod ? GooglePay$1.checkoutStore.paymentMethodGroupId : undefined);
1197
1844
  if (response === null || response === void 0 ? void 0 : response.error) {
1198
1845
  this.errorEvent.emit({
1199
1846
  message: typeof response.error === 'string' ? response.error : response.error.message || 'Failed to tokenize bank account',
@@ -1204,7 +1851,7 @@ const ModularCheckout = class {
1204
1851
  }
1205
1852
  const paymentMethod = response === null || response === void 0 ? void 0 : response.data;
1206
1853
  const token = ((_d = paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.bank_account) === null || _d === void 0 ? void 0 : _d.token) || (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.token) || (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id);
1207
- checkout_store.checkoutStore.paymentToken = token;
1854
+ GooglePay$1.checkoutStore.paymentToken = token;
1208
1855
  }
1209
1856
  catch (err) {
1210
1857
  this.errorEvent.emit({
@@ -1223,7 +1870,7 @@ const ModularCheckout = class {
1223
1870
  });
1224
1871
  return;
1225
1872
  }
1226
- if (!checkout_store.checkoutStore.paymentToken) {
1873
+ if (!GooglePay$1.checkoutStore.paymentToken) {
1227
1874
  this.errorEvent.emit({
1228
1875
  message: 'Payment token not found.',
1229
1876
  errorCode: ComponentError.ComponentErrorCodes.TOKENIZE_ERROR,
@@ -1244,16 +1891,18 @@ const ModularCheckout = class {
1244
1891
  return index$1.PAYMENT_MODE.BNPL;
1245
1892
  case index$1.PAYMENT_METHODS.APPLE_PAY:
1246
1893
  return index$1.PAYMENT_MODE.APPLE_PAY;
1894
+ case index$1.PAYMENT_METHODS.GOOGLE_PAY:
1895
+ return index$1.PAYMENT_MODE.GOOGLE_PAY;
1247
1896
  default:
1248
1897
  return undefined;
1249
1898
  }
1250
1899
  };
1251
1900
  payment = {
1252
- payment_mode: mapTypeToPaymentMode((_e = checkout_store.checkoutStore.selectedPaymentMethod) === null || _e === void 0 ? void 0 : _e.type),
1253
- payment_token: checkout_store.checkoutStore.paymentToken,
1901
+ payment_mode: mapTypeToPaymentMode((_e = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _e === void 0 ? void 0 : _e.type),
1902
+ payment_token: GooglePay$1.checkoutStore.paymentToken,
1254
1903
  };
1255
1904
  if (this.preCompleteHook) {
1256
- const state = checkout_store.getCheckoutState();
1905
+ const state = GooglePay$1.getCheckoutState();
1257
1906
  try {
1258
1907
  await new Promise((resolve, reject) => {
1259
1908
  this.preCompleteHook(state, () => resolve(), () => reject());
@@ -1281,7 +1930,7 @@ const ModularCheckout = class {
1281
1930
  });
1282
1931
  }
1283
1932
  render() {
1284
- return index.h(index.Host, { key: '56a003ca1e1ac4bdc1baa8f862cdb05b2d8af4b1' });
1933
+ return index.h(index.Host, { key: '43f4be87e218b23251f2ccac90e0c980bf157d68' });
1285
1934
  }
1286
1935
  get hostEl() { return index.getElement(this); }
1287
1936
  };
@@ -1360,7 +2009,7 @@ const PlaidPaymentMethod = class {
1360
2009
  this.hasLoggedDisabledWarning = false;
1361
2010
  this.waitForStoreAndInitialize = () => {
1362
2011
  // Check if store has necessary data
1363
- if (checkout_store.checkoutStore.authToken && checkout_store.checkoutStore.accountId && checkout_store.checkoutStore.checkoutId) {
2012
+ if (GooglePay$1.checkoutStore.authToken && GooglePay$1.checkoutStore.accountId && GooglePay$1.checkoutStore.checkoutId) {
1364
2013
  this.initializePlaidLink();
1365
2014
  }
1366
2015
  else {
@@ -1419,7 +2068,7 @@ const PlaidPaymentMethod = class {
1419
2068
  this.getLinkToken = async () => {
1420
2069
  var _a, _b, _c, _d, _e;
1421
2070
  try {
1422
- if (!checkout_store.checkoutStore.authToken || !checkout_store.checkoutStore.accountId) {
2071
+ if (!GooglePay$1.checkoutStore.authToken || !GooglePay$1.checkoutStore.accountId) {
1423
2072
  this.handleError({
1424
2073
  code: PlaidErrorCodes.PLAID_LINK_TOKEN_FAILED,
1425
2074
  message: 'Missing authentication. Please refresh the page and try again.',
@@ -1436,7 +2085,7 @@ const PlaidPaymentMethod = class {
1436
2085
  var _a;
1437
2086
  (_a = this.abortController) === null || _a === void 0 ? void 0 : _a.abort();
1438
2087
  }, 30000); // 30 second timeout
1439
- const response = await this.plaidService.getLinkToken(checkout_store.checkoutStore.authToken, checkout_store.checkoutStore.accountId, checkout_store.checkoutStore.checkoutId, this.abortController.signal);
2088
+ const response = await this.plaidService.getLinkToken(GooglePay$1.checkoutStore.authToken, GooglePay$1.checkoutStore.accountId, GooglePay$1.checkoutStore.checkoutId, this.abortController.signal);
1440
2089
  // Clear timeout
1441
2090
  if (this.timeoutId) {
1442
2091
  clearTimeout(this.timeoutId);
@@ -1453,7 +2102,7 @@ const PlaidPaymentMethod = class {
1453
2102
  // Try to capture link token id if present in envelope
1454
2103
  this.linkTokenId = (response === null || response === void 0 ? void 0 : response.id) || ((_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.id) || null;
1455
2104
  if (this.linkTokenId) {
1456
- checkout_store.checkoutStore.plaidLinkTokenId = this.linkTokenId;
2105
+ GooglePay$1.checkoutStore.plaidLinkTokenId = this.linkTokenId;
1457
2106
  }
1458
2107
  }
1459
2108
  catch (error) {
@@ -1526,7 +2175,7 @@ const PlaidPaymentMethod = class {
1526
2175
  // Ensure the component remains selected after successful authentication
1527
2176
  if (!this.isSelected) {
1528
2177
  this.isSelected = true;
1529
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
2178
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
1530
2179
  }
1531
2180
  // Emit success event for parent components
1532
2181
  this.plaidErrorRecovered.emit({
@@ -1535,7 +2184,7 @@ const PlaidPaymentMethod = class {
1535
2184
  severity: ComponentError.ComponentErrorSeverity.INFO
1536
2185
  });
1537
2186
  // Store public token in checkout store; exchange will be handled on submit
1538
- checkout_store.checkoutStore.plaidPublicToken = publicToken;
2187
+ GooglePay$1.checkoutStore.plaidPublicToken = publicToken;
1539
2188
  };
1540
2189
  // Exchange logic moved to Modular Checkout submit flow.
1541
2190
  this.handlePlaidExit = (err, _metadata) => {
@@ -1677,7 +2326,7 @@ const PlaidPaymentMethod = class {
1677
2326
  // Watch for store changes to sync component state
1678
2327
  this.syncWithStore = () => {
1679
2328
  var _a;
1680
- const shouldBeSelected = ((_a = checkout_store.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.PLAID;
2329
+ const shouldBeSelected = ((_a = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.PLAID;
1681
2330
  if (this.isSelected !== shouldBeSelected) {
1682
2331
  this.isSelected = shouldBeSelected;
1683
2332
  }
@@ -1686,8 +2335,8 @@ const PlaidPaymentMethod = class {
1686
2335
  onSelectionChange(newValue) {
1687
2336
  var _a;
1688
2337
  // Ensure store is updated when component selection changes
1689
- if (newValue && ((_a = checkout_store.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) !== index$1.PAYMENT_METHODS.PLAID) {
1690
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
2338
+ if (newValue && ((_a = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) !== index$1.PAYMENT_METHODS.PLAID) {
2339
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
1691
2340
  }
1692
2341
  // Auto-start Plaid flow when selected and ready
1693
2342
  if (newValue &&
@@ -1719,7 +2368,7 @@ const PlaidPaymentMethod = class {
1719
2368
  componentWillLoad() {
1720
2369
  var _a;
1721
2370
  // Initialize selection state based on store
1722
- this.isSelected = ((_a = checkout_store.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.PLAID;
2371
+ this.isSelected = ((_a = GooglePay$1.checkoutStore.selectedPaymentMethod) === null || _a === void 0 ? void 0 : _a.type) === index$1.PAYMENT_METHODS.PLAID;
1723
2372
  }
1724
2373
  async resolvePaymentMethod() {
1725
2374
  if (!this.publicToken) {
@@ -1736,13 +2385,13 @@ const PlaidPaymentMethod = class {
1736
2385
  // Returns a usable payment method token for checkout completion.
1737
2386
  // Will perform the backend exchange if the token is not yet present in the store.
1738
2387
  async getPaymentToken() {
1739
- return checkout_store.checkoutStore.paymentToken;
2388
+ return GooglePay$1.checkoutStore.paymentToken;
1740
2389
  }
1741
2390
  async handleSelectionClick() {
1742
2391
  // Update local selection state
1743
2392
  this.isSelected = true;
1744
2393
  // Update store selection
1745
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
2394
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
1746
2395
  // If there's an error, clear it and try to initialize again
1747
2396
  if (this.error) {
1748
2397
  this.clearError();
@@ -1758,7 +2407,7 @@ const PlaidPaymentMethod = class {
1758
2407
  async setSelected(selected) {
1759
2408
  this.isSelected = selected;
1760
2409
  if (selected) {
1761
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
2410
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.PLAID };
1762
2411
  }
1763
2412
  }
1764
2413
  // Method to check if component is currently selected
@@ -1807,7 +2456,7 @@ const PlaidPaymentMethod = class {
1807
2456
  }
1808
2457
  componentDidLoad() {
1809
2458
  // Set up store change listener to keep component in sync
1810
- const unsubscribe = checkout_store.onChange('selectedPaymentMethod', this.syncWithStore);
2459
+ const unsubscribe = GooglePay$1.onChange('selectedPaymentMethod', this.syncWithStore);
1811
2460
  // Store unsubscribe function for cleanup
1812
2461
  this.unsubscribeFromStore = unsubscribe;
1813
2462
  }
@@ -1826,7 +2475,7 @@ const PlaidPaymentMethod = class {
1826
2475
  }
1827
2476
  render() {
1828
2477
  // Only allow use if enabled in checkout settings
1829
- if (checkout_store.checkoutStore.bankAccountVerification !== true) {
2478
+ if (GooglePay$1.checkoutStore.bankAccountVerification !== true) {
1830
2479
  if (!this.hasLoggedDisabledWarning) {
1831
2480
  // Log once per component lifecycle
1832
2481
  console.warn('[PlaidPaymentMethod] bank_account_verification is disabled. Component will not render.');
@@ -1877,36 +2526,36 @@ const SavedPaymentMethods = class {
1877
2526
  index.registerInstance(this, hostRef);
1878
2527
  this.onPaymentMethodOptionClick = (paymentMethod) => (e) => {
1879
2528
  e.preventDefault();
1880
- checkout_store.checkoutStore.selectedPaymentMethod = { id: paymentMethod.id, type: paymentMethod.type };
1881
- checkout_store.checkoutStore.paymentToken = paymentMethod.id;
2529
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { id: paymentMethod.id, type: paymentMethod.type };
2530
+ GooglePay$1.checkoutStore.paymentToken = paymentMethod.id;
1882
2531
  };
1883
2532
  this.isAllowedPaymentMethod = (paymentMethodType) => {
1884
2533
  const isCard = paymentMethodType === index$1.PAYMENT_METHODS.SAVED_CARD;
1885
2534
  const isBankAccount = paymentMethodType === index$1.PAYMENT_METHODS.SAVED_BANK_ACCOUNT;
1886
- if (isCard && checkout_store.checkoutStore.disableCreditCard) {
2535
+ if (isCard && GooglePay$1.checkoutStore.disableCreditCard) {
1887
2536
  return false;
1888
2537
  }
1889
- if (isBankAccount && checkout_store.checkoutStore.disableBankAccount) {
2538
+ if (isBankAccount && GooglePay$1.checkoutStore.disableBankAccount) {
1890
2539
  return false;
1891
2540
  }
1892
2541
  return true;
1893
2542
  };
1894
2543
  }
1895
2544
  componentWillLoad() {
1896
- if (!checkout_store.checkoutStore.paymentMethods.length) {
2545
+ if (!GooglePay$1.checkoutStore.paymentMethods.length) {
1897
2546
  console.warn('No saved payment methods available.');
1898
2547
  }
1899
- if (checkout_store.checkoutStore.disablePaymentMethodGroup) {
2548
+ if (GooglePay$1.checkoutStore.disablePaymentMethodGroup) {
1900
2549
  console.warn('Payment method group is disabled.');
1901
2550
  }
1902
2551
  }
1903
2552
  render() {
1904
- if (checkout_store.checkoutStore.disablePaymentMethodGroup) {
2553
+ if (GooglePay$1.checkoutStore.disablePaymentMethodGroup) {
1905
2554
  return null;
1906
2555
  }
1907
- return (index.h(styledHost.StyledHost, null, index.h("div", { class: "saved-payment-methods" }, checkout_store.checkoutStore.paymentMethods.length ? checkout_store.checkoutStore.paymentMethods
2556
+ return (index.h(styledHost.StyledHost, null, index.h("div", { class: "saved-payment-methods" }, GooglePay$1.checkoutStore.paymentMethods.length ? GooglePay$1.checkoutStore.paymentMethods
1908
2557
  .filter((paymentMethod) => this.isAllowedPaymentMethod(paymentMethod.type))
1909
- .map((paymentMethod) => (index.h("div", { class: "radio-list-item p-3", part: parts.radioListItem, onClick: this.onPaymentMethodOptionClick(paymentMethod) }, index.h("form-control-radio", { name: "paymentMethodType", value: paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id, checked: checkout_store.checkoutStore.paymentToken === (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id), label: `${paymentMethodOptionUtils.CardBrandLabels[paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.brand] || ''} *${paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.acct_last_four}` })))) : null)));
2558
+ .map((paymentMethod) => (index.h("div", { class: "radio-list-item p-3", part: parts.radioListItem, onClick: this.onPaymentMethodOptionClick(paymentMethod) }, index.h("form-control-radio", { name: "paymentMethodType", value: paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id, checked: GooglePay$1.checkoutStore.paymentToken === (paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.id), label: `${paymentMethodOptionUtils.CardBrandLabels[paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.brand] || ''} *${paymentMethod === null || paymentMethod === void 0 ? void 0 : paymentMethod.acct_last_four}` })))) : null)));
1910
2559
  }
1911
2560
  };
1912
2561
 
@@ -1924,20 +2573,20 @@ const SezzlePaymentMethod = class {
1924
2573
  this.initializeSezzleCheckout = () => {
1925
2574
  let resolveSezzlePromise;
1926
2575
  this.sezzlePromise = new Promise((resolve) => { resolveSezzlePromise = resolve; });
1927
- const amount = Number(checkout_store.checkoutStore.paymentAmount);
2576
+ const amount = Number(GooglePay$1.checkoutStore.paymentAmount);
1928
2577
  const Checkout = window.Checkout;
1929
2578
  const checkout = new Checkout({
1930
2579
  mode: 'popup',
1931
- publicKey: checkout_store.checkoutStore.bnplProviderClientId,
1932
- apiMode: checkout_store.checkoutStore.bnplProviderMode,
1933
- apiVersion: checkout_store.checkoutStore.bnplProviderApiVersion,
2580
+ publicKey: GooglePay$1.checkoutStore.bnplProviderClientId,
2581
+ apiMode: GooglePay$1.checkoutStore.bnplProviderMode,
2582
+ apiVersion: GooglePay$1.checkoutStore.bnplProviderApiVersion,
1934
2583
  });
1935
2584
  checkout.sezzleButtonElement = this.sezzleButtonRef;
1936
2585
  checkout.init({
1937
2586
  onClick: function (event) {
1938
2587
  event.preventDefault();
1939
2588
  checkout.startCheckout({
1940
- checkout_url: checkout_store.checkoutStore.bnplProviderCheckoutUrl,
2589
+ checkout_url: GooglePay$1.checkoutStore.bnplProviderCheckoutUrl,
1941
2590
  });
1942
2591
  },
1943
2592
  onComplete: (event) => resolveSezzlePromise({ bnpl: event.data }),
@@ -1964,12 +2613,12 @@ const SezzlePaymentMethod = class {
1964
2613
  return this.sezzlePromise;
1965
2614
  }
1966
2615
  async handleSelectionClick() {
1967
- checkout_store.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.SEZZLE };
2616
+ GooglePay$1.checkoutStore.selectedPaymentMethod = { type: index$1.PAYMENT_METHODS.SEZZLE };
1968
2617
  this.paymentMethodOptionSelected.emit(this.paymentMethodOptionId);
1969
2618
  }
1970
2619
  render() {
1971
2620
  var _a, _b;
1972
- if (!checkout_store.checkoutStore.bnplEnabled) {
2621
+ if (!GooglePay$1.checkoutStore.bnplEnabled) {
1973
2622
  console.warn('justifi-sezzle-payment-method: BNPL is not enabled for this account.');
1974
2623
  return null;
1975
2624
  }
@@ -1979,6 +2628,7 @@ const SezzlePaymentMethod = class {
1979
2628
 
1980
2629
  exports.justifi_apple_pay = ApplePay;
1981
2630
  exports.justifi_checkout_summary = Summary;
2631
+ exports.justifi_google_pay = GooglePay;
1982
2632
  exports.justifi_header = Header;
1983
2633
  exports.justifi_modular_checkout = ModularCheckout;
1984
2634
  exports.justifi_plaid_payment_method = PlaidPaymentMethod;