@internetarchive/donation-form 0.5.18-alpha.1 → 0.5.19

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 (420) hide show
  1. package/LICENSE +661 -661
  2. package/README.md +115 -115
  3. package/dist/demo/braintree-endpoint-manager.d.ts +9 -9
  4. package/dist/demo/braintree-endpoint-manager.js +45 -45
  5. package/dist/demo/braintree-endpoint-manager.js.map +1 -1
  6. package/dist/demo/demo-analytics-handler.d.ts +17 -17
  7. package/dist/demo/demo-analytics-handler.js +13 -13
  8. package/dist/demo/demo-analytics-handler.js.map +1 -1
  9. package/dist/demo/submit-form-with.d.ts +7 -7
  10. package/dist/demo/submit-form-with.js +21 -21
  11. package/dist/demo/submit-form-with.js.map +1 -1
  12. package/dist/index.d.ts +7 -7
  13. package/dist/index.js +7 -7
  14. package/dist/index.js.map +1 -1
  15. package/dist/src/braintree-manager/braintree-interfaces.d.ts +147 -147
  16. package/dist/src/braintree-manager/braintree-interfaces.js +5 -5
  17. package/dist/src/braintree-manager/braintree-interfaces.js.map +1 -1
  18. package/dist/src/braintree-manager/braintree-manager.d.ts +124 -124
  19. package/dist/src/braintree-manager/braintree-manager.js +149 -149
  20. package/dist/src/braintree-manager/braintree-manager.js.map +1 -1
  21. package/dist/src/braintree-manager/payment-clients.d.ts +47 -47
  22. package/dist/src/braintree-manager/payment-clients.js +116 -116
  23. package/dist/src/braintree-manager/payment-clients.js.map +1 -1
  24. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.d.ts +8 -8
  25. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.js.map +1 -1
  26. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.d.ts +6 -6
  27. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.js.map +1 -1
  28. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.d.ts +10 -10
  29. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.js.map +1 -1
  30. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.d.ts +21 -21
  31. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.js +99 -99
  32. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.js.map +1 -1
  33. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.d.ts +10 -10
  34. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.js +12 -12
  35. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.js.map +1 -1
  36. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay.d.ts +20 -20
  37. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay.js +71 -71
  38. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay.js.map +1 -1
  39. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card-interface.d.ts +16 -16
  40. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card-interface.js.map +1 -1
  41. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card.d.ts +29 -29
  42. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card.js +99 -99
  43. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card.js.map +1 -1
  44. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.d.ts +11 -11
  45. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.js +7 -7
  46. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.js.map +1 -1
  47. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-container.d.ts +34 -34
  48. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-container.js +52 -52
  49. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-container.js.map +1 -1
  50. package/dist/src/braintree-manager/payment-providers/google-pay-interface.d.ts +7 -7
  51. package/dist/src/braintree-manager/payment-providers/google-pay-interface.js.map +1 -1
  52. package/dist/src/braintree-manager/payment-providers/google-pay.d.ts +18 -18
  53. package/dist/src/braintree-manager/payment-providers/google-pay.js +40 -40
  54. package/dist/src/braintree-manager/payment-providers/google-pay.js.map +1 -1
  55. package/dist/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.d.ts +145 -145
  56. package/dist/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.js +60 -60
  57. package/dist/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.js.map +1 -1
  58. package/dist/src/braintree-manager/payment-providers/paypal/paypal-interface.d.ts +11 -11
  59. package/dist/src/braintree-manager/payment-providers/paypal/paypal-interface.js.map +1 -1
  60. package/dist/src/braintree-manager/payment-providers/paypal/paypal.d.ts +23 -23
  61. package/dist/src/braintree-manager/payment-providers/paypal/paypal.js +46 -46
  62. package/dist/src/braintree-manager/payment-providers/paypal/paypal.js.map +1 -1
  63. package/dist/src/braintree-manager/payment-providers/venmo-interface.d.ts +6 -6
  64. package/dist/src/braintree-manager/payment-providers/venmo-interface.js.map +1 -1
  65. package/dist/src/braintree-manager/payment-providers/venmo.d.ts +28 -28
  66. package/dist/src/braintree-manager/payment-providers/venmo.js +50 -50
  67. package/dist/src/braintree-manager/payment-providers/venmo.js.map +1 -1
  68. package/dist/src/braintree-manager/payment-providers-interface.d.ts +16 -16
  69. package/dist/src/braintree-manager/payment-providers-interface.js.map +1 -1
  70. package/dist/src/braintree-manager/payment-providers.d.ts +45 -45
  71. package/dist/src/braintree-manager/payment-providers.js +105 -105
  72. package/dist/src/braintree-manager/payment-providers.js.map +1 -1
  73. package/dist/src/donation-form-controller.d.ts +116 -116
  74. package/dist/src/donation-form-controller.js +562 -562
  75. package/dist/src/donation-form-controller.js.map +1 -1
  76. package/dist/src/donation-form-error.d.ts +3 -3
  77. package/dist/src/donation-form-error.js +6 -6
  78. package/dist/src/donation-form-error.js.map +1 -1
  79. package/dist/src/donation-form.d.ts +120 -120
  80. package/dist/src/donation-form.js +530 -530
  81. package/dist/src/donation-form.js.map +1 -1
  82. package/dist/src/form-elements/badged-input.d.ts +32 -32
  83. package/dist/src/form-elements/badged-input.js +124 -124
  84. package/dist/src/form-elements/badged-input.js.map +1 -1
  85. package/dist/src/form-elements/contact-form/autocomplete-field-options.d.ts +1 -1
  86. package/dist/src/form-elements/contact-form/autocomplete-field-options.js.map +1 -1
  87. package/dist/src/form-elements/contact-form/contact-form.d.ts +53 -53
  88. package/dist/src/form-elements/contact-form/contact-form.js +428 -428
  89. package/dist/src/form-elements/contact-form/contact-form.js.map +1 -1
  90. package/dist/src/form-elements/contact-form/countries.d.ts +3 -3
  91. package/dist/src/form-elements/contact-form/countries.js +252 -252
  92. package/dist/src/form-elements/contact-form/countries.js.map +1 -1
  93. package/dist/src/form-elements/header/donation-form-header.d.ts +27 -27
  94. package/dist/src/form-elements/header/donation-form-header.js +97 -97
  95. package/dist/src/form-elements/header/donation-form-header.js.map +1 -1
  96. package/dist/src/form-elements/header/donation-summary.d.ts +11 -11
  97. package/dist/src/form-elements/header/donation-summary.js +57 -57
  98. package/dist/src/form-elements/header/donation-summary.js.map +1 -1
  99. package/dist/src/form-elements/payment-selector.d.ts +25 -25
  100. package/dist/src/form-elements/payment-selector.js +286 -286
  101. package/dist/src/form-elements/payment-selector.js.map +1 -1
  102. package/dist/src/form-elements/total-amount.d.ts +8 -8
  103. package/dist/src/form-elements/total-amount.js +47 -47
  104. package/dist/src/form-elements/total-amount.js.map +1 -1
  105. package/dist/src/modals/confirm-donation-modal-content.d.ts +31 -31
  106. package/dist/src/modals/confirm-donation-modal-content.js +168 -168
  107. package/dist/src/modals/confirm-donation-modal-content.js.map +1 -1
  108. package/dist/src/modals/error-modal-content.d.ts +14 -14
  109. package/dist/src/modals/error-modal-content.js +49 -49
  110. package/dist/src/modals/error-modal-content.js.map +1 -1
  111. package/dist/src/modals/upsell-modal-content.d.ts +32 -32
  112. package/dist/src/modals/upsell-modal-content.js +294 -294
  113. package/dist/src/modals/upsell-modal-content.js.map +1 -1
  114. package/dist/src/payment-flow-handlers/donation-flow-modal-manager.d.ts +181 -181
  115. package/dist/src/payment-flow-handlers/donation-flow-modal-manager.js +252 -252
  116. package/dist/src/payment-flow-handlers/donation-flow-modal-manager.js.map +1 -1
  117. package/dist/src/payment-flow-handlers/handlers/applepay-flow-handler.d.ts +21 -21
  118. package/dist/src/payment-flow-handlers/handlers/applepay-flow-handler.js +76 -76
  119. package/dist/src/payment-flow-handlers/handlers/applepay-flow-handler.js.map +1 -1
  120. package/dist/src/payment-flow-handlers/handlers/creditcard-flow-handler.d.ts +70 -70
  121. package/dist/src/payment-flow-handlers/handlers/creditcard-flow-handler.js +140 -140
  122. package/dist/src/payment-flow-handlers/handlers/creditcard-flow-handler.js.map +1 -1
  123. package/dist/src/payment-flow-handlers/handlers/googlepay-flow-handler.d.ts +22 -22
  124. package/dist/src/payment-flow-handlers/handlers/googlepay-flow-handler.js +74 -74
  125. package/dist/src/payment-flow-handlers/handlers/googlepay-flow-handler.js.map +1 -1
  126. package/dist/src/payment-flow-handlers/handlers/paypal-flow-handler.d.ts +52 -52
  127. package/dist/src/payment-flow-handlers/handlers/paypal-flow-handler.js +239 -239
  128. package/dist/src/payment-flow-handlers/handlers/paypal-flow-handler.js.map +1 -1
  129. package/dist/src/payment-flow-handlers/handlers/venmo-flow-handler.d.ts +30 -30
  130. package/dist/src/payment-flow-handlers/handlers/venmo-flow-handler.js +89 -89
  131. package/dist/src/payment-flow-handlers/handlers/venmo-flow-handler.js.map +1 -1
  132. package/dist/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.d.ts +75 -75
  133. package/dist/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.js +94 -94
  134. package/dist/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.js.map +1 -1
  135. package/dist/src/payment-flow-handlers/payment-flow-handlers.d.ts +111 -111
  136. package/dist/src/payment-flow-handlers/payment-flow-handlers.js +107 -107
  137. package/dist/src/payment-flow-handlers/payment-flow-handlers.js.map +1 -1
  138. package/dist/src/recaptcha-manager/recaptcha-manager.d.ts +48 -48
  139. package/dist/src/recaptcha-manager/recaptcha-manager.js +88 -88
  140. package/dist/src/recaptcha-manager/recaptcha-manager.js.map +1 -1
  141. package/dist/src/util/promisedSleep.d.ts +1 -1
  142. package/dist/src/util/promisedSleep.js +3 -3
  143. package/dist/src/util/promisedSleep.js.map +1 -1
  144. package/dist/test/helpers/fillInContactForm.d.ts +2 -2
  145. package/dist/test/helpers/fillInContactForm.js +19 -19
  146. package/dist/test/helpers/fillInContactForm.js.map +1 -1
  147. package/dist/test/mocks/flow-handlers/individual-handlers/mock-applepay-flow-handler.d.ts +7 -7
  148. package/dist/test/mocks/flow-handlers/individual-handlers/mock-applepay-flow-handler.js +9 -9
  149. package/dist/test/mocks/flow-handlers/individual-handlers/mock-applepay-flow-handler.js.map +1 -1
  150. package/dist/test/mocks/flow-handlers/individual-handlers/mock-creditcard-flow-handler.d.ts +15 -15
  151. package/dist/test/mocks/flow-handlers/individual-handlers/mock-creditcard-flow-handler.js +32 -32
  152. package/dist/test/mocks/flow-handlers/individual-handlers/mock-creditcard-flow-handler.js.map +1 -1
  153. package/dist/test/mocks/flow-handlers/individual-handlers/mock-googlepay-flow-handler.d.ts +9 -9
  154. package/dist/test/mocks/flow-handlers/individual-handlers/mock-googlepay-flow-handler.js +15 -15
  155. package/dist/test/mocks/flow-handlers/individual-handlers/mock-googlepay-flow-handler.js.map +1 -1
  156. package/dist/test/mocks/flow-handlers/individual-handlers/mock-paypal-flow-handler.d.ts +15 -15
  157. package/dist/test/mocks/flow-handlers/individual-handlers/mock-paypal-flow-handler.js +30 -30
  158. package/dist/test/mocks/flow-handlers/individual-handlers/mock-paypal-flow-handler.js.map +1 -1
  159. package/dist/test/mocks/flow-handlers/individual-handlers/mock-venmo-flow-handler.d.ts +9 -9
  160. package/dist/test/mocks/flow-handlers/individual-handlers/mock-venmo-flow-handler.js +17 -17
  161. package/dist/test/mocks/flow-handlers/individual-handlers/mock-venmo-flow-handler.js.map +1 -1
  162. package/dist/test/mocks/flow-handlers/mock-payment-flow-handlers.d.ts +30 -30
  163. package/dist/test/mocks/flow-handlers/mock-payment-flow-handlers.js +29 -29
  164. package/dist/test/mocks/flow-handlers/mock-payment-flow-handlers.js.map +1 -1
  165. package/dist/test/mocks/mock-analytics-handler.d.ts +8 -0
  166. package/dist/test/mocks/mock-analytics-handler.js +10 -0
  167. package/dist/test/mocks/mock-analytics-handler.js.map +1 -0
  168. package/dist/test/mocks/mock-braintree-manager.d.ts +45 -45
  169. package/dist/test/mocks/mock-braintree-manager.js +71 -71
  170. package/dist/test/mocks/mock-braintree-manager.js.map +1 -1
  171. package/dist/test/mocks/mock-donation-info.d.ts +4 -4
  172. package/dist/test/mocks/mock-donation-info.js +10 -10
  173. package/dist/test/mocks/mock-donation-info.js.map +1 -1
  174. package/dist/test/mocks/mock-endpoint-manager.d.ts +12 -12
  175. package/dist/test/mocks/mock-endpoint-manager.js +19 -19
  176. package/dist/test/mocks/mock-endpoint-manager.js.map +1 -1
  177. package/dist/test/mocks/mock-hosted-fields-config.d.ts +4 -4
  178. package/dist/test/mocks/mock-hosted-fields-config.js +37 -37
  179. package/dist/test/mocks/mock-hosted-fields-config.js.map +1 -1
  180. package/dist/test/mocks/mock-hosted-fields-container.d.ts +13 -13
  181. package/dist/test/mocks/mock-hosted-fields-container.js +27 -27
  182. package/dist/test/mocks/mock-hosted-fields-container.js.map +1 -1
  183. package/dist/test/mocks/mock-lazy-loader.d.ts +15 -15
  184. package/dist/test/mocks/mock-lazy-loader.js +20 -20
  185. package/dist/test/mocks/mock-lazy-loader.js.map +1 -1
  186. package/dist/test/mocks/mock-modal-manager.d.ts +17 -17
  187. package/dist/test/mocks/mock-modal-manager.js +26 -26
  188. package/dist/test/mocks/mock-modal-manager.js.map +1 -1
  189. package/dist/test/mocks/mock-payment-clients.d.ts +29 -29
  190. package/dist/test/mocks/mock-payment-clients.js +78 -78
  191. package/dist/test/mocks/mock-payment-clients.js.map +1 -1
  192. package/dist/test/mocks/mock-paypal-button-renderer.d.ts +5 -5
  193. package/dist/test/mocks/mock-paypal-button-renderer.js +6 -6
  194. package/dist/test/mocks/mock-paypal-button-renderer.js.map +1 -1
  195. package/dist/test/mocks/mock-recaptcha-manager.d.ts +7 -7
  196. package/dist/test/mocks/mock-recaptcha-manager.js +14 -14
  197. package/dist/test/mocks/mock-recaptcha-manager.js.map +1 -1
  198. package/dist/test/mocks/models/mock-billing-info.d.ts +2 -2
  199. package/dist/test/mocks/models/mock-billing-info.js +9 -9
  200. package/dist/test/mocks/models/mock-billing-info.js.map +1 -1
  201. package/dist/test/mocks/models/mock-custom-fields.d.ts +2 -2
  202. package/dist/test/mocks/models/mock-custom-fields.js +7 -7
  203. package/dist/test/mocks/models/mock-custom-fields.js.map +1 -1
  204. package/dist/test/mocks/models/mock-customer-info.d.ts +2 -2
  205. package/dist/test/mocks/models/mock-customer-info.js +6 -6
  206. package/dist/test/mocks/models/mock-customer-info.js.map +1 -1
  207. package/dist/test/mocks/models/mock-donation-request.d.ts +2 -2
  208. package/dist/test/mocks/models/mock-donation-request.js +18 -18
  209. package/dist/test/mocks/models/mock-donation-request.js.map +1 -1
  210. package/dist/test/mocks/models/mock-success-response.d.ts +2 -2
  211. package/dist/test/mocks/models/mock-success-response.js +14 -14
  212. package/dist/test/mocks/models/mock-success-response.js.map +1 -1
  213. package/dist/test/mocks/payment-clients/mock-applepay-client.d.ts +21 -21
  214. package/dist/test/mocks/payment-clients/mock-applepay-client.js +72 -72
  215. package/dist/test/mocks/payment-clients/mock-applepay-client.js.map +1 -1
  216. package/dist/test/mocks/payment-clients/mock-applepay-payment.d.ts +6 -6
  217. package/dist/test/mocks/payment-clients/mock-applepay-payment.js +42 -42
  218. package/dist/test/mocks/payment-clients/mock-applepay-payment.js.map +1 -1
  219. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.d.ts +22 -22
  220. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.js +35 -35
  221. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.js.map +1 -1
  222. package/dist/test/mocks/payment-clients/mock-applepay-session.d.ts +30 -30
  223. package/dist/test/mocks/payment-clients/mock-applepay-session.js +52 -52
  224. package/dist/test/mocks/payment-clients/mock-applepay-session.js.map +1 -1
  225. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.d.ts +10 -10
  226. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.js +12 -12
  227. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.js.map +1 -1
  228. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.d.ts +22 -22
  229. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.js +34 -34
  230. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.js.map +1 -1
  231. package/dist/test/mocks/payment-clients/mock-braintree-client.d.ts +14 -14
  232. package/dist/test/mocks/payment-clients/mock-braintree-client.js +19 -19
  233. package/dist/test/mocks/payment-clients/mock-braintree-client.js.map +1 -1
  234. package/dist/test/mocks/payment-clients/mock-data-collector.d.ts +11 -11
  235. package/dist/test/mocks/payment-clients/mock-data-collector.js +17 -17
  236. package/dist/test/mocks/payment-clients/mock-data-collector.js.map +1 -1
  237. package/dist/test/mocks/payment-clients/mock-googlepay-client.d.ts +22 -22
  238. package/dist/test/mocks/payment-clients/mock-googlepay-client.js +42 -42
  239. package/dist/test/mocks/payment-clients/mock-googlepay-client.js.map +1 -1
  240. package/dist/test/mocks/payment-clients/mock-googlepay-library.d.ts +10 -10
  241. package/dist/test/mocks/payment-clients/mock-googlepay-library.js +22 -22
  242. package/dist/test/mocks/payment-clients/mock-googlepay-library.js.map +1 -1
  243. package/dist/test/mocks/payment-clients/mock-grecaptcha.d.ts +23 -23
  244. package/dist/test/mocks/payment-clients/mock-grecaptcha.js +62 -62
  245. package/dist/test/mocks/payment-clients/mock-grecaptcha.js.map +1 -1
  246. package/dist/test/mocks/payment-clients/mock-hostedfields-client.d.ts +33 -33
  247. package/dist/test/mocks/payment-clients/mock-hostedfields-client.js +54 -54
  248. package/dist/test/mocks/payment-clients/mock-hostedfields-client.js.map +1 -1
  249. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.d.ts +1 -1
  250. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.js +50 -50
  251. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.js.map +1 -1
  252. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.d.ts +1 -1
  253. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.js +13 -13
  254. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.js.map +1 -1
  255. package/dist/test/mocks/payment-clients/mock-paypal-client.d.ts +23 -23
  256. package/dist/test/mocks/payment-clients/mock-paypal-client.js +62 -62
  257. package/dist/test/mocks/payment-clients/mock-paypal-client.js.map +1 -1
  258. package/dist/test/mocks/payment-clients/mock-paypal-library.d.ts +4 -4
  259. package/dist/test/mocks/payment-clients/mock-paypal-library.js +9 -9
  260. package/dist/test/mocks/payment-clients/mock-paypal-library.js.map +1 -1
  261. package/dist/test/mocks/payment-clients/mock-venmo-client.d.ts +22 -22
  262. package/dist/test/mocks/payment-clients/mock-venmo-client.js +36 -36
  263. package/dist/test/mocks/payment-clients/mock-venmo-client.js.map +1 -1
  264. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.d.ts +10 -10
  265. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.js +14 -14
  266. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.js.map +1 -1
  267. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.d.ts +9 -9
  268. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.js +19 -19
  269. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.js.map +1 -1
  270. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.d.ts +18 -18
  271. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.js +41 -41
  272. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.js.map +1 -1
  273. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.d.ts +8 -8
  274. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.js +16 -16
  275. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.js.map +1 -1
  276. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.d.ts +28 -28
  277. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.js +52 -52
  278. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.js.map +1 -1
  279. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.d.ts +11 -11
  280. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.js +37 -37
  281. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.js.map +1 -1
  282. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.d.ts +12 -12
  283. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.js +15 -15
  284. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.js.map +1 -1
  285. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.d.ts +7 -7
  286. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.js +22 -22
  287. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.js.map +1 -1
  288. package/dist/test/mocks/payment-providers/mock-payment-providers.d.ts +21 -21
  289. package/dist/test/mocks/payment-providers/mock-payment-providers.js +45 -45
  290. package/dist/test/mocks/payment-providers/mock-payment-providers.js.map +1 -1
  291. package/dist/test/tests/braintree-manager.test.d.ts +1 -1
  292. package/dist/test/tests/braintree-manager.test.js +166 -166
  293. package/dist/test/tests/braintree-manager.test.js.map +1 -1
  294. package/dist/test/tests/donation-form-controller.test.d.ts +1 -1
  295. package/dist/test/tests/donation-form-controller.test.js +188 -188
  296. package/dist/test/tests/donation-form-controller.test.js.map +1 -1
  297. package/dist/test/tests/donation-form.test.d.ts +1 -1
  298. package/dist/test/tests/donation-form.test.js +109 -109
  299. package/dist/test/tests/donation-form.test.js.map +1 -1
  300. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.d.ts +1 -1
  301. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js +216 -216
  302. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js.map +1 -1
  303. package/dist/test/tests/form-elements/donation-summary.test.d.ts +1 -1
  304. package/dist/test/tests/form-elements/donation-summary.test.js +36 -36
  305. package/dist/test/tests/form-elements/donation-summary.test.js.map +1 -1
  306. package/dist/test/tests/form-elements/payment-selector.test.d.ts +1 -1
  307. package/dist/test/tests/form-elements/payment-selector.test.js +69 -69
  308. package/dist/test/tests/form-elements/payment-selector.test.js.map +1 -1
  309. package/dist/test/tests/modals/error-modal-content.test.d.ts +1 -1
  310. package/dist/test/tests/modals/error-modal-content.test.js +14 -14
  311. package/dist/test/tests/modals/error-modal-content.test.js.map +1 -1
  312. package/dist/test/tests/modals/upsell-modal-content.test.d.ts +1 -1
  313. package/dist/test/tests/modals/upsell-modal-content.test.js +163 -163
  314. package/dist/test/tests/modals/upsell-modal-content.test.js.map +1 -1
  315. package/dist/test/tests/models/donation-payment-info.test.d.ts +1 -1
  316. package/dist/test/tests/models/donation-payment-info.test.js +74 -74
  317. package/dist/test/tests/models/donation-payment-info.test.js.map +1 -1
  318. package/dist/test/tests/payment-clients.test.d.ts +1 -1
  319. package/dist/test/tests/payment-clients.test.js +130 -130
  320. package/dist/test/tests/payment-clients.test.js.map +1 -1
  321. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.d.ts +1 -1
  322. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.js +160 -160
  323. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.js.map +1 -1
  324. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.d.ts +1 -1
  325. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.js +36 -36
  326. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.js.map +1 -1
  327. package/dist/test/tests/payment-providers/applepay.test.d.ts +1 -1
  328. package/dist/test/tests/payment-providers/applepay.test.js +78 -78
  329. package/dist/test/tests/payment-providers/applepay.test.js.map +1 -1
  330. package/dist/test/tests/payment-providers/creditcard.test.d.ts +1 -1
  331. package/dist/test/tests/payment-providers/creditcard.test.js +190 -190
  332. package/dist/test/tests/payment-providers/creditcard.test.js.map +1 -1
  333. package/dist/test/tests/payment-providers/googlepay.test.d.ts +1 -1
  334. package/dist/test/tests/payment-providers/googlepay.test.js +48 -48
  335. package/dist/test/tests/payment-providers/googlepay.test.js.map +1 -1
  336. package/dist/test/tests/payment-providers/payment-providers.test.d.ts +1 -1
  337. package/dist/test/tests/payment-providers/payment-providers.test.js +38 -38
  338. package/dist/test/tests/payment-providers/payment-providers.test.js.map +1 -1
  339. package/dist/test/tests/payment-providers/paypal-button-datasource.test.d.ts +1 -1
  340. package/dist/test/tests/payment-providers/paypal-button-datasource.test.js +162 -162
  341. package/dist/test/tests/payment-providers/paypal-button-datasource.test.js.map +1 -1
  342. package/dist/test/tests/payment-providers/paypal.test.d.ts +1 -1
  343. package/dist/test/tests/payment-providers/paypal.test.js +38 -38
  344. package/dist/test/tests/payment-providers/paypal.test.js.map +1 -1
  345. package/dist/test/tests/payment-providers/venmo.test.d.ts +1 -1
  346. package/dist/test/tests/payment-providers/venmo.test.js +77 -77
  347. package/dist/test/tests/payment-providers/venmo.test.js.map +1 -1
  348. package/dist/test/tests/recaptcha-manager.test.d.ts +1 -1
  349. package/dist/test/tests/recaptcha-manager.test.js +70 -70
  350. package/dist/test/tests/recaptcha-manager.test.js.map +1 -1
  351. package/package.json +101 -101
  352. package/src/@types/analytics-handler/index.d.ts +8 -8
  353. package/src/@types/braintree-web/LICENSE +21 -21
  354. package/src/@types/braintree-web/index.d.ts +93 -93
  355. package/src/@types/braintree-web/modules/american-express.d.ts +50 -50
  356. package/src/@types/braintree-web/modules/apple-pay.d.ts +213 -213
  357. package/src/@types/braintree-web/modules/client.d.ts +103 -103
  358. package/src/@types/braintree-web/modules/core.d.ts +34 -34
  359. package/src/@types/braintree-web/modules/data-collector.d.ts +13 -13
  360. package/src/@types/braintree-web/modules/google-payment.d.ts +269 -269
  361. package/src/@types/braintree-web/modules/hosted-fields.d.ts +366 -366
  362. package/src/@types/braintree-web/modules/paypal-checkout.d.ts +262 -262
  363. package/src/@types/braintree-web/modules/paypal.d.ts +177 -177
  364. package/src/@types/braintree-web/modules/three-d-secure.d.ts +141 -141
  365. package/src/@types/braintree-web/modules/unionpay.d.ts +224 -224
  366. package/src/@types/braintree-web/modules/us-bank-account.d.ts +81 -81
  367. package/src/@types/braintree-web/modules/venmo.d.ts +110 -110
  368. package/src/@types/braintree-web/package.json +64 -64
  369. package/src/@types/paypal-checkout-components/LICENSE +21 -21
  370. package/src/@types/paypal-checkout-components/index.d.ts +67 -67
  371. package/src/@types/paypal-checkout-components/modules/button.d.ts +50 -50
  372. package/src/@types/paypal-checkout-components/modules/callback-data.d.ts +244 -244
  373. package/src/@types/paypal-checkout-components/modules/configuration.d.ts +114 -114
  374. package/src/@types/paypal-checkout-components/package.json +58 -58
  375. package/src/braintree-manager/braintree-interfaces.ts +172 -172
  376. package/src/braintree-manager/braintree-manager.ts +283 -283
  377. package/src/braintree-manager/payment-clients.ts +148 -148
  378. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.ts +13 -13
  379. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.ts +8 -8
  380. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.ts +10 -10
  381. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.ts +119 -119
  382. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.ts +21 -21
  383. package/src/braintree-manager/payment-providers/apple-pay/apple-pay.ts +98 -98
  384. package/src/braintree-manager/payment-providers/credit-card/credit-card-interface.ts +21 -21
  385. package/src/braintree-manager/payment-providers/credit-card/credit-card.ts +130 -130
  386. package/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.ts +19 -19
  387. package/src/braintree-manager/payment-providers/credit-card/hosted-field-container.ts +85 -85
  388. package/src/braintree-manager/payment-providers/google-pay-interface.ts +8 -8
  389. package/src/braintree-manager/payment-providers/google-pay.ts +59 -59
  390. package/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.ts +218 -218
  391. package/src/braintree-manager/payment-providers/paypal/paypal-interface.ts +13 -13
  392. package/src/braintree-manager/payment-providers/paypal/paypal.ts +78 -78
  393. package/src/braintree-manager/payment-providers/venmo-interface.ts +8 -8
  394. package/src/braintree-manager/payment-providers/venmo.ts +67 -67
  395. package/src/braintree-manager/payment-providers-interface.ts +25 -25
  396. package/src/braintree-manager/payment-providers.ts +147 -147
  397. package/src/donation-form-controller.ts +619 -619
  398. package/src/donation-form-error.ts +6 -6
  399. package/src/donation-form.ts +566 -566
  400. package/src/form-elements/badged-input.ts +113 -113
  401. package/src/form-elements/contact-form/autocomplete-field-options.ts +63 -63
  402. package/src/form-elements/contact-form/contact-form.ts +427 -427
  403. package/src/form-elements/contact-form/countries.ts +252 -252
  404. package/src/form-elements/header/donation-form-header.ts +100 -100
  405. package/src/form-elements/header/donation-summary.ts +61 -61
  406. package/src/form-elements/payment-selector.ts +293 -293
  407. package/src/form-elements/total-amount.ts +46 -46
  408. package/src/modals/confirm-donation-modal-content.ts +160 -160
  409. package/src/modals/error-modal-content.ts +48 -48
  410. package/src/modals/upsell-modal-content.ts +294 -294
  411. package/src/payment-flow-handlers/donation-flow-modal-manager.ts +450 -450
  412. package/src/payment-flow-handlers/handlers/applepay-flow-handler.ts +108 -108
  413. package/src/payment-flow-handlers/handlers/creditcard-flow-handler.ts +231 -231
  414. package/src/payment-flow-handlers/handlers/googlepay-flow-handler.ts +113 -113
  415. package/src/payment-flow-handlers/handlers/paypal-flow-handler.ts +332 -332
  416. package/src/payment-flow-handlers/handlers/venmo-flow-handler.ts +118 -118
  417. package/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.ts +127 -127
  418. package/src/payment-flow-handlers/payment-flow-handlers.ts +218 -218
  419. package/src/recaptcha-manager/recaptcha-manager.ts +123 -123
  420. package/src/util/promisedSleep.ts +3 -3
@@ -1,287 +1,287 @@
1
- import { __awaiter, __decorate } from "tslib";
2
- import { LitElement, html, css } from 'lit';
3
- import { customElement, property } from 'lit/decorators.js';
4
- import applePayButtonImage from '@internetarchive/icon-applepay';
5
- import googlePayButtonImage from '@internetarchive/icon-googlepay';
6
- import paypalButtonImage from '@internetarchive/icon-paypal';
7
- import venmoButtonImage from '@internetarchive/icon-venmo';
8
- var PaymentButtonMode;
9
- (function (PaymentButtonMode) {
10
- PaymentButtonMode["Loading"] = "loading";
11
- PaymentButtonMode["Available"] = "available";
12
- PaymentButtonMode["Unavailable"] = "unavailable";
13
- })(PaymentButtonMode || (PaymentButtonMode = {}));
14
- let PaymentSelector = class PaymentSelector extends LitElement {
15
- constructor() {
16
- super(...arguments);
17
- this.donationInfoValid = true;
18
- this.applePayMode = PaymentButtonMode.Loading;
19
- this.googlePayMode = PaymentButtonMode.Loading;
20
- this.venmoMode = PaymentButtonMode.Loading;
21
- this.payPalMode = PaymentButtonMode.Loading;
22
- }
23
- /** @inheritdoc */
24
- render() {
25
- return html `
26
- <div
27
- class="payment-container ${this.donationInfoValid
28
- ? 'donation-info-valid'
29
- : 'donation-info-invalid'}
30
- "
31
- >
32
- <div class="payment-provider-container">
33
- <button
34
- class="applepay provider-button ${this.applePayMode}"
35
- @click=${this.applePaySelected}
36
- tabindex="0"
37
- >
38
- <div class="payment-image">${applePayButtonImage}</div>
39
- </button>
40
-
41
- <button
42
- class="googlepay provider-button ${this.googlePayMode}"
43
- @click=${this.googlePaySelected}
44
- tabindex="0"
45
- >
46
- <div class="payment-image">${googlePayButtonImage}</div>
47
- </button>
48
-
49
- <button
50
- class="venmo provider-button ${this.venmoMode}"
51
- @click=${this.venmoSelected}
52
- tabindex="0"
53
- >
54
- <div class="payment-image">${venmoButtonImage}</div>
55
- </button>
56
-
57
- <div class="paypal-container provider-button ${this.payPalMode}" tabindex="0">
58
- <div class="payment-image">
59
- <div class="paypal-local-button" @click=${this.localPaypalButtonClicked}>
60
- ${paypalButtonImage}
61
- </div>
62
- <slot name="paypal-button"></slot>
63
- </div>
64
- </div>
65
- </div>
66
-
67
- <div class="credit-card-container">
68
- <button
69
- @click=${this.creditCardSelected}
70
- class="button-style credit-card-button"
71
- tabindex="0"
72
- >
73
- <div class="cc-title">Credit Card</div>
74
- <div class="cc-background"></div>
75
- </button>
76
- </div>
77
- </div>
78
- `;
79
- }
80
- /** @inheritdoc */
81
- firstUpdated() {
82
- this.dispatchEvent(new Event('firstUpdated'));
83
- }
84
- /** @inheritdoc */
85
- updated(changed) {
86
- if (changed.has('paymentProviders')) {
87
- this.setButtonVisibility();
88
- }
89
- }
90
- showPaypalButton() {
91
- this.payPalMode = PaymentButtonMode.Available;
92
- }
93
- setButtonVisibility() {
94
- var _a, _b, _c;
95
- return __awaiter(this, void 0, void 0, function* () {
96
- (_a = this.paymentProviders) === null || _a === void 0 ? void 0 : _a.venmoHandler.get().then(handler => {
97
- if (!handler) {
98
- this.venmoMode = PaymentButtonMode.Unavailable;
99
- return;
100
- }
101
- handler
102
- .isBrowserSupported()
103
- .then(supported => {
104
- this.venmoMode = supported
105
- ? PaymentButtonMode.Available
106
- : PaymentButtonMode.Unavailable;
107
- })
108
- .catch(reason => {
109
- console.error('error loading venmo', reason);
110
- this.venmoMode = PaymentButtonMode.Unavailable;
111
- });
112
- }).catch(reason => {
113
- console.error('venmo unavailable', reason);
114
- this.venmoMode = PaymentButtonMode.Unavailable;
115
- });
116
- (_b = this.paymentProviders) === null || _b === void 0 ? void 0 : _b.applePayHandler.get().then(handler => {
117
- if (!handler) {
118
- console.error('applePayHandler unavailable');
119
- this.applePayMode = PaymentButtonMode.Unavailable;
120
- return;
121
- }
122
- handler
123
- .isAvailable()
124
- .then(supported => {
125
- this.applePayMode = supported
126
- ? PaymentButtonMode.Available
127
- : PaymentButtonMode.Unavailable;
128
- })
129
- .catch(reason => {
130
- console.error('error loading applepay', reason);
131
- this.applePayMode = PaymentButtonMode.Unavailable;
132
- });
133
- }).catch(reason => {
134
- console.error('apple pay unavailable', reason);
135
- this.applePayMode = PaymentButtonMode.Unavailable;
136
- });
137
- (_c = this.paymentProviders) === null || _c === void 0 ? void 0 : _c.googlePayHandler.get().then(handler => {
138
- if (!handler) {
139
- console.error('google pay handler unavailable');
140
- this.googlePayMode = PaymentButtonMode.Unavailable;
141
- return;
142
- }
143
- handler
144
- .isBrowserSupported()
145
- .then(supported => {
146
- this.googlePayMode = supported
147
- ? PaymentButtonMode.Available
148
- : PaymentButtonMode.Unavailable;
149
- })
150
- .catch(reason => {
151
- console.error('error loading googlepay', reason);
152
- this.googlePayMode = PaymentButtonMode.Unavailable;
153
- });
154
- }).catch(reason => {
155
- console.error('google pay unavailable', reason);
156
- this.googlePayMode = PaymentButtonMode.Unavailable;
157
- });
158
- });
159
- }
160
- googlePaySelected() {
161
- this.dispatchEvent(new Event('googlePaySelected'));
162
- }
163
- applePaySelected(e) {
164
- const event = new CustomEvent('applePaySelected', { detail: { originalEvent: e } });
165
- this.dispatchEvent(event);
166
- }
167
- venmoSelected() {
168
- this.dispatchEvent(new Event('venmoSelected'));
169
- }
170
- creditCardSelected() {
171
- this.dispatchEvent(new Event('creditCardSelected'));
172
- }
173
- localPaypalButtonClicked() {
174
- this.dispatchEvent(new Event('paypalBlockerSelected'));
175
- }
176
- /** @inheritdoc */
177
- static get styles() {
178
- const paymentButtonWidthCss = css `var(--paymentButtonWidth, 5rem)`;
179
- const paymentButtonHeightCss = css `var(--paymentButtonHeight, 3.2rem)`;
180
- const creditCardFontSizeCss = css `var(--creditCardFontSize, 1.8rem)`;
181
- return css `
182
- button {
183
- color: inherit;
184
- font-family: inherit;
185
- }
186
-
187
- .payment-container {
188
- width: 100%;
189
- }
190
-
191
- .payment-provider-container {
192
- display: grid;
193
- grid-template-columns: 1fr 1fr 1fr 1fr;
194
- grid-gap: 1rem;
195
- margin-bottom: 1rem;
196
- max-width: 23rem;
197
- }
198
-
199
- .provider-button {
200
- border: 0;
201
- padding: 0;
202
- background: none;
203
- cursor: pointer;
204
- width: ${paymentButtonWidthCss};
205
- height: ${paymentButtonHeightCss};
206
- }
207
-
208
- .provider-button.unavailable {
209
- display: none;
210
- }
211
-
212
- .provider-button.loading {
213
- border: 1px solid #ddd;
214
- border-radius: 2px;
215
- /* account for the borders that don't exist once the provider loads, otherwise the layout shifts */
216
- margin-bottom: -2px;
217
- }
218
-
219
- .provider-button.loading .payment-image {
220
- display: none;
221
- }
222
-
223
- .paypal-local-button {
224
- position: absolute;
225
- width: ${paymentButtonWidthCss};
226
- height: ${paymentButtonHeightCss};
227
- }
228
-
229
- .donation-info-valid .paypal-local-button {
230
- z-index: 0;
231
- }
232
-
233
- .donation-info-invalid .paypal-local-button {
234
- z-index: 250;
235
- }
236
-
237
- .credit-card-button {
238
- color: var(--ccButtonFontColor, #333);
239
- background-color: var(--ccButtonColor, white);
240
- border: 1px solid #333;
241
- border-radius: 4px;
242
- cursor: pointer;
243
- margin: 0;
244
- padding: 0.7rem 1rem;
245
- width: 100%;
246
- }
247
-
248
- .credit-card-button .cc-background {
249
- height: 2.4rem;
250
- width: 100%;
251
- background-repeat: no-repeat;
252
- background-image: url(https://archive.org/images/cc_logos.png);
253
- background-position: 50% 50%;
254
- background-size: contain;
255
- }
256
-
257
- .credit-card-button .cc-title {
258
- font-size: ${creditCardFontSizeCss};
259
- font-weight: 700;
260
- margin-bottom: 0.5rem;
261
- }
262
- `;
263
- }
264
- };
265
- __decorate([
266
- property({ type: Boolean })
267
- ], PaymentSelector.prototype, "donationInfoValid", void 0);
268
- __decorate([
269
- property({ type: Object })
270
- ], PaymentSelector.prototype, "paymentProviders", void 0);
271
- __decorate([
272
- property({ type: String })
273
- ], PaymentSelector.prototype, "applePayMode", void 0);
274
- __decorate([
275
- property({ type: String })
276
- ], PaymentSelector.prototype, "googlePayMode", void 0);
277
- __decorate([
278
- property({ type: String })
279
- ], PaymentSelector.prototype, "venmoMode", void 0);
280
- __decorate([
281
- property({ type: String })
282
- ], PaymentSelector.prototype, "payPalMode", void 0);
283
- PaymentSelector = __decorate([
284
- customElement('payment-selector')
285
- ], PaymentSelector);
286
- export { PaymentSelector };
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { LitElement, html, css } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import applePayButtonImage from '@internetarchive/icon-applepay';
5
+ import googlePayButtonImage from '@internetarchive/icon-googlepay';
6
+ import paypalButtonImage from '@internetarchive/icon-paypal';
7
+ import venmoButtonImage from '@internetarchive/icon-venmo';
8
+ var PaymentButtonMode;
9
+ (function (PaymentButtonMode) {
10
+ PaymentButtonMode["Loading"] = "loading";
11
+ PaymentButtonMode["Available"] = "available";
12
+ PaymentButtonMode["Unavailable"] = "unavailable";
13
+ })(PaymentButtonMode || (PaymentButtonMode = {}));
14
+ let PaymentSelector = class PaymentSelector extends LitElement {
15
+ constructor() {
16
+ super(...arguments);
17
+ this.donationInfoValid = true;
18
+ this.applePayMode = PaymentButtonMode.Loading;
19
+ this.googlePayMode = PaymentButtonMode.Loading;
20
+ this.venmoMode = PaymentButtonMode.Loading;
21
+ this.payPalMode = PaymentButtonMode.Loading;
22
+ }
23
+ /** @inheritdoc */
24
+ render() {
25
+ return html `
26
+ <div
27
+ class="payment-container ${this.donationInfoValid
28
+ ? 'donation-info-valid'
29
+ : 'donation-info-invalid'}
30
+ "
31
+ >
32
+ <div class="payment-provider-container">
33
+ <button
34
+ class="applepay provider-button ${this.applePayMode}"
35
+ @click=${this.applePaySelected}
36
+ tabindex="0"
37
+ >
38
+ <div class="payment-image">${applePayButtonImage}</div>
39
+ </button>
40
+
41
+ <button
42
+ class="googlepay provider-button ${this.googlePayMode}"
43
+ @click=${this.googlePaySelected}
44
+ tabindex="0"
45
+ >
46
+ <div class="payment-image">${googlePayButtonImage}</div>
47
+ </button>
48
+
49
+ <button
50
+ class="venmo provider-button ${this.venmoMode}"
51
+ @click=${this.venmoSelected}
52
+ tabindex="0"
53
+ >
54
+ <div class="payment-image">${venmoButtonImage}</div>
55
+ </button>
56
+
57
+ <div class="paypal-container provider-button ${this.payPalMode}" tabindex="0">
58
+ <div class="payment-image">
59
+ <div class="paypal-local-button" @click=${this.localPaypalButtonClicked}>
60
+ ${paypalButtonImage}
61
+ </div>
62
+ <slot name="paypal-button"></slot>
63
+ </div>
64
+ </div>
65
+ </div>
66
+
67
+ <div class="credit-card-container">
68
+ <button
69
+ @click=${this.creditCardSelected}
70
+ class="button-style credit-card-button"
71
+ tabindex="0"
72
+ >
73
+ <div class="cc-title">Credit Card</div>
74
+ <div class="cc-background"></div>
75
+ </button>
76
+ </div>
77
+ </div>
78
+ `;
79
+ }
80
+ /** @inheritdoc */
81
+ firstUpdated() {
82
+ this.dispatchEvent(new Event('firstUpdated'));
83
+ }
84
+ /** @inheritdoc */
85
+ updated(changed) {
86
+ if (changed.has('paymentProviders')) {
87
+ this.setButtonVisibility();
88
+ }
89
+ }
90
+ showPaypalButton() {
91
+ this.payPalMode = PaymentButtonMode.Available;
92
+ }
93
+ setButtonVisibility() {
94
+ var _a, _b, _c;
95
+ return __awaiter(this, void 0, void 0, function* () {
96
+ (_a = this.paymentProviders) === null || _a === void 0 ? void 0 : _a.venmoHandler.get().then(handler => {
97
+ if (!handler) {
98
+ this.venmoMode = PaymentButtonMode.Unavailable;
99
+ return;
100
+ }
101
+ handler
102
+ .isBrowserSupported()
103
+ .then(supported => {
104
+ this.venmoMode = supported
105
+ ? PaymentButtonMode.Available
106
+ : PaymentButtonMode.Unavailable;
107
+ })
108
+ .catch(reason => {
109
+ console.error('error loading venmo', reason);
110
+ this.venmoMode = PaymentButtonMode.Unavailable;
111
+ });
112
+ }).catch(reason => {
113
+ console.error('venmo unavailable', reason);
114
+ this.venmoMode = PaymentButtonMode.Unavailable;
115
+ });
116
+ (_b = this.paymentProviders) === null || _b === void 0 ? void 0 : _b.applePayHandler.get().then(handler => {
117
+ if (!handler) {
118
+ console.error('applePayHandler unavailable');
119
+ this.applePayMode = PaymentButtonMode.Unavailable;
120
+ return;
121
+ }
122
+ handler
123
+ .isAvailable()
124
+ .then(supported => {
125
+ this.applePayMode = supported
126
+ ? PaymentButtonMode.Available
127
+ : PaymentButtonMode.Unavailable;
128
+ })
129
+ .catch(reason => {
130
+ console.error('error loading applepay', reason);
131
+ this.applePayMode = PaymentButtonMode.Unavailable;
132
+ });
133
+ }).catch(reason => {
134
+ console.error('apple pay unavailable', reason);
135
+ this.applePayMode = PaymentButtonMode.Unavailable;
136
+ });
137
+ (_c = this.paymentProviders) === null || _c === void 0 ? void 0 : _c.googlePayHandler.get().then(handler => {
138
+ if (!handler) {
139
+ console.error('google pay handler unavailable');
140
+ this.googlePayMode = PaymentButtonMode.Unavailable;
141
+ return;
142
+ }
143
+ handler
144
+ .isBrowserSupported()
145
+ .then(supported => {
146
+ this.googlePayMode = supported
147
+ ? PaymentButtonMode.Available
148
+ : PaymentButtonMode.Unavailable;
149
+ })
150
+ .catch(reason => {
151
+ console.error('error loading googlepay', reason);
152
+ this.googlePayMode = PaymentButtonMode.Unavailable;
153
+ });
154
+ }).catch(reason => {
155
+ console.error('google pay unavailable', reason);
156
+ this.googlePayMode = PaymentButtonMode.Unavailable;
157
+ });
158
+ });
159
+ }
160
+ googlePaySelected() {
161
+ this.dispatchEvent(new Event('googlePaySelected'));
162
+ }
163
+ applePaySelected(e) {
164
+ const event = new CustomEvent('applePaySelected', { detail: { originalEvent: e } });
165
+ this.dispatchEvent(event);
166
+ }
167
+ venmoSelected() {
168
+ this.dispatchEvent(new Event('venmoSelected'));
169
+ }
170
+ creditCardSelected() {
171
+ this.dispatchEvent(new Event('creditCardSelected'));
172
+ }
173
+ localPaypalButtonClicked() {
174
+ this.dispatchEvent(new Event('paypalBlockerSelected'));
175
+ }
176
+ /** @inheritdoc */
177
+ static get styles() {
178
+ const paymentButtonWidthCss = css `var(--paymentButtonWidth, 5rem)`;
179
+ const paymentButtonHeightCss = css `var(--paymentButtonHeight, 3.2rem)`;
180
+ const creditCardFontSizeCss = css `var(--creditCardFontSize, 1.8rem)`;
181
+ return css `
182
+ button {
183
+ color: inherit;
184
+ font-family: inherit;
185
+ }
186
+
187
+ .payment-container {
188
+ width: 100%;
189
+ }
190
+
191
+ .payment-provider-container {
192
+ display: grid;
193
+ grid-template-columns: 1fr 1fr 1fr 1fr;
194
+ grid-gap: 1rem;
195
+ margin-bottom: 1rem;
196
+ max-width: 23rem;
197
+ }
198
+
199
+ .provider-button {
200
+ border: 0;
201
+ padding: 0;
202
+ background: none;
203
+ cursor: pointer;
204
+ width: ${paymentButtonWidthCss};
205
+ height: ${paymentButtonHeightCss};
206
+ }
207
+
208
+ .provider-button.unavailable {
209
+ display: none;
210
+ }
211
+
212
+ .provider-button.loading {
213
+ border: 1px solid #ddd;
214
+ border-radius: 2px;
215
+ /* account for the borders that don't exist once the provider loads, otherwise the layout shifts */
216
+ margin-bottom: -2px;
217
+ }
218
+
219
+ .provider-button.loading .payment-image {
220
+ display: none;
221
+ }
222
+
223
+ .paypal-local-button {
224
+ position: absolute;
225
+ width: ${paymentButtonWidthCss};
226
+ height: ${paymentButtonHeightCss};
227
+ }
228
+
229
+ .donation-info-valid .paypal-local-button {
230
+ z-index: 0;
231
+ }
232
+
233
+ .donation-info-invalid .paypal-local-button {
234
+ z-index: 250;
235
+ }
236
+
237
+ .credit-card-button {
238
+ color: var(--ccButtonFontColor, #333);
239
+ background-color: var(--ccButtonColor, white);
240
+ border: 1px solid #333;
241
+ border-radius: 4px;
242
+ cursor: pointer;
243
+ margin: 0;
244
+ padding: 0.7rem 1rem;
245
+ width: 100%;
246
+ }
247
+
248
+ .credit-card-button .cc-background {
249
+ height: 2.4rem;
250
+ width: 100%;
251
+ background-repeat: no-repeat;
252
+ background-image: url(https://archive.org/images/cc_logos.png);
253
+ background-position: 50% 50%;
254
+ background-size: contain;
255
+ }
256
+
257
+ .credit-card-button .cc-title {
258
+ font-size: ${creditCardFontSizeCss};
259
+ font-weight: 700;
260
+ margin-bottom: 0.5rem;
261
+ }
262
+ `;
263
+ }
264
+ };
265
+ __decorate([
266
+ property({ type: Boolean })
267
+ ], PaymentSelector.prototype, "donationInfoValid", void 0);
268
+ __decorate([
269
+ property({ type: Object })
270
+ ], PaymentSelector.prototype, "paymentProviders", void 0);
271
+ __decorate([
272
+ property({ type: String })
273
+ ], PaymentSelector.prototype, "applePayMode", void 0);
274
+ __decorate([
275
+ property({ type: String })
276
+ ], PaymentSelector.prototype, "googlePayMode", void 0);
277
+ __decorate([
278
+ property({ type: String })
279
+ ], PaymentSelector.prototype, "venmoMode", void 0);
280
+ __decorate([
281
+ property({ type: String })
282
+ ], PaymentSelector.prototype, "payPalMode", void 0);
283
+ PaymentSelector = __decorate([
284
+ customElement('payment-selector')
285
+ ], PaymentSelector);
286
+ export { PaymentSelector };
287
287
  //# sourceMappingURL=payment-selector.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"payment-selector.js","sourceRoot":"","sources":["../../../src/form-elements/payment-selector.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAA6C,MAAM,KAAK,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,mBAAmB,MAAM,gCAAgC,CAAC;AACjE,OAAO,oBAAoB,MAAM,iCAAiC,CAAC;AACnE,OAAO,iBAAiB,MAAM,8BAA8B,CAAC;AAC7D,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAG3D,IAAK,iBAIJ;AAJD,WAAK,iBAAiB;IACpB,wCAAmB,CAAA;IACnB,4CAAuB,CAAA;IACvB,gDAA2B,CAAA;AAC7B,CAAC,EAJI,iBAAiB,KAAjB,iBAAiB,QAIrB;AAGD,IAAa,eAAe,GAA5B,MAAa,eAAgB,SAAQ,UAAU;IAA/C;;QAC+B,sBAAiB,GAAG,IAAI,CAAC;QAIlB,iBAAY,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAE5D,kBAAa,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAE7D,cAAS,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAEzD,eAAU,GAAsB,iBAAiB,CAAC,OAAO,CAAC;IAyQhG,CAAC;IAvQC,kBAAkB;IAClB,MAAM;QACJ,OAAO,IAAI,CAAA;;mCAEoB,IAAI,CAAC,iBAAiB;YAC/C,CAAC,CAAC,qBAAqB;YACvB,CAAC,CAAC,uBAAuB;;;;;8CAKW,IAAI,CAAC,YAAY;qBAC1C,IAAI,CAAC,gBAAgB;;;yCAGD,mBAAmB;;;;+CAIb,IAAI,CAAC,aAAa;qBAC5C,IAAI,CAAC,iBAAiB;;;yCAGF,oBAAoB;;;;2CAIlB,IAAI,CAAC,SAAS;qBACpC,IAAI,CAAC,aAAa;;;yCAGE,gBAAgB;;;yDAGA,IAAI,CAAC,UAAU;;wDAEhB,IAAI,CAAC,wBAAwB;kBACnE,iBAAiB;;;;;;;;;qBASd,IAAI,CAAC,kBAAkB;;;;;;;;;KASvC,CAAC;IACJ,CAAC;IAED,kBAAkB;IAClB,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,OAAuB;QAC7B,IAAI,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,SAAS,CAAC;IAChD,CAAC;IAEa,mBAAmB;;;YAC/B,MAAA,IAAI,CAAC,gBAAgB,0CAAE,YAAY,CAChC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBAC/C,OAAO;iBACR;gBAED,OAAO;qBACJ,kBAAkB,EAAE;qBACpB,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,SAAS,GAAG,SAAS;wBACxB,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC;oBAC7C,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACjD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;gBAC3C,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACjD,CAAC,EAAE;YAEL,MAAA,IAAI,CAAC,gBAAgB,0CAAE,eAAe,CACnC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;oBAC7C,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBAClD,OAAO;iBACR;gBAED,OAAO;qBACJ,WAAW,EAAE;qBACb,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,YAAY,GAAG,SAAS;wBAC3B,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;oBAChD,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACpD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;gBAC/C,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACpD,CAAC,EAAE;YAEL,MAAA,IAAI,CAAC,gBAAgB,0CAAE,gBAAgB,CACpC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;oBAChD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBACnD,OAAO;iBACR;gBAED,OAAO;qBACJ,kBAAkB,EAAE;qBACpB,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,aAAa,GAAG,SAAS;wBAC5B,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAC;oBACjD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACrD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;gBAChD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACrD,CAAC,EAAE;;KACN;IAEO,iBAAiB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;IACrD,CAAC;IAEO,gBAAgB,CAAC,CAAQ;QAC/B,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QACpF,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC;IACjD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;IACtD,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,kBAAkB;IAClB,MAAM,KAAK,MAAM;QACf,MAAM,qBAAqB,GAAG,GAAG,CAAA,iCAAiC,CAAC;QACnE,MAAM,sBAAsB,GAAG,GAAG,CAAA,oCAAoC,CAAC;QACvE,MAAM,qBAAqB,GAAG,GAAG,CAAA,mCAAmC,CAAC;QAErE,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;iBAuBG,qBAAqB;kBACpB,sBAAsB;;;;;;;;;;;;;;;;;;;;iBAoBvB,qBAAqB;kBACpB,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAgCnB,qBAAqB;;;;KAIrC,CAAC;IACJ,CAAC;CACF,CAAA;AAnR8B;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;0DAA0B;AAE1B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;yDAA8C;AAE7C;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;qDAAqE;AAEpE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;sDAAsE;AAErE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAAkE;AAEjE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAmE;AAXnF,eAAe;IAD3B,aAAa,CAAC,kBAAkB,CAAC;GACrB,eAAe,CAoR3B;SApRY,eAAe","sourcesContent":["import { LitElement, html, css, CSSResult, TemplateResult, PropertyValues } from 'lit';\r\nimport { customElement, property } from 'lit/decorators.js';\r\n\r\nimport applePayButtonImage from '@internetarchive/icon-applepay';\r\nimport googlePayButtonImage from '@internetarchive/icon-googlepay';\r\nimport paypalButtonImage from '@internetarchive/icon-paypal';\r\nimport venmoButtonImage from '@internetarchive/icon-venmo';\r\nimport { PaymentProvidersInterface } from '../braintree-manager/payment-providers-interface';\r\n\r\nenum PaymentButtonMode {\r\n Loading = 'loading',\r\n Available = 'available',\r\n Unavailable = 'unavailable',\r\n}\r\n\r\n@customElement('payment-selector')\r\nexport class PaymentSelector extends LitElement {\r\n @property({ type: Boolean }) donationInfoValid = true;\r\n\r\n @property({ type: Object }) paymentProviders?: PaymentProvidersInterface;\r\n\r\n @property({ type: String }) private applePayMode: PaymentButtonMode = PaymentButtonMode.Loading;\r\n\r\n @property({ type: String }) private googlePayMode: PaymentButtonMode = PaymentButtonMode.Loading;\r\n\r\n @property({ type: String }) private venmoMode: PaymentButtonMode = PaymentButtonMode.Loading;\r\n\r\n @property({ type: String }) private payPalMode: PaymentButtonMode = PaymentButtonMode.Loading;\r\n\r\n /** @inheritdoc */\r\n render(): TemplateResult {\r\n return html`\r\n <div\r\n class=\"payment-container ${this.donationInfoValid\r\n ? 'donation-info-valid'\r\n : 'donation-info-invalid'}\r\n \"\r\n >\r\n <div class=\"payment-provider-container\">\r\n <button\r\n class=\"applepay provider-button ${this.applePayMode}\"\r\n @click=${this.applePaySelected}\r\n tabindex=\"0\"\r\n >\r\n <div class=\"payment-image\">${applePayButtonImage}</div>\r\n </button>\r\n\r\n <button\r\n class=\"googlepay provider-button ${this.googlePayMode}\"\r\n @click=${this.googlePaySelected}\r\n tabindex=\"0\"\r\n >\r\n <div class=\"payment-image\">${googlePayButtonImage}</div>\r\n </button>\r\n\r\n <button\r\n class=\"venmo provider-button ${this.venmoMode}\"\r\n @click=${this.venmoSelected}\r\n tabindex=\"0\"\r\n >\r\n <div class=\"payment-image\">${venmoButtonImage}</div>\r\n </button>\r\n\r\n <div class=\"paypal-container provider-button ${this.payPalMode}\" tabindex=\"0\">\r\n <div class=\"payment-image\">\r\n <div class=\"paypal-local-button\" @click=${this.localPaypalButtonClicked}>\r\n ${paypalButtonImage}\r\n </div>\r\n <slot name=\"paypal-button\"></slot>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"credit-card-container\">\r\n <button\r\n @click=${this.creditCardSelected}\r\n class=\"button-style credit-card-button\"\r\n tabindex=\"0\"\r\n >\r\n <div class=\"cc-title\">Credit Card</div>\r\n <div class=\"cc-background\"></div>\r\n </button>\r\n </div>\r\n </div>\r\n `;\r\n }\r\n\r\n /** @inheritdoc */\r\n firstUpdated(): void {\r\n this.dispatchEvent(new Event('firstUpdated'));\r\n }\r\n\r\n /** @inheritdoc */\r\n updated(changed: PropertyValues): void {\r\n if (changed.has('paymentProviders')) {\r\n this.setButtonVisibility();\r\n }\r\n }\r\n\r\n showPaypalButton(): void {\r\n this.payPalMode = PaymentButtonMode.Available;\r\n }\r\n\r\n private async setButtonVisibility(): Promise<void> {\r\n this.paymentProviders?.venmoHandler\r\n .get()\r\n .then(handler => {\r\n if (!handler) {\r\n this.venmoMode = PaymentButtonMode.Unavailable;\r\n return;\r\n }\r\n\r\n handler\r\n .isBrowserSupported()\r\n .then(supported => {\r\n this.venmoMode = supported\r\n ? PaymentButtonMode.Available\r\n : PaymentButtonMode.Unavailable;\r\n })\r\n .catch(reason => {\r\n console.error('error loading venmo', reason);\r\n this.venmoMode = PaymentButtonMode.Unavailable;\r\n });\r\n })\r\n .catch(reason => {\r\n console.error('venmo unavailable', reason);\r\n this.venmoMode = PaymentButtonMode.Unavailable;\r\n });\r\n\r\n this.paymentProviders?.applePayHandler\r\n .get()\r\n .then(handler => {\r\n if (!handler) {\r\n console.error('applePayHandler unavailable');\r\n this.applePayMode = PaymentButtonMode.Unavailable;\r\n return;\r\n }\r\n\r\n handler\r\n .isAvailable()\r\n .then(supported => {\r\n this.applePayMode = supported\r\n ? PaymentButtonMode.Available\r\n : PaymentButtonMode.Unavailable;\r\n })\r\n .catch(reason => {\r\n console.error('error loading applepay', reason);\r\n this.applePayMode = PaymentButtonMode.Unavailable;\r\n });\r\n })\r\n .catch(reason => {\r\n console.error('apple pay unavailable', reason);\r\n this.applePayMode = PaymentButtonMode.Unavailable;\r\n });\r\n\r\n this.paymentProviders?.googlePayHandler\r\n .get()\r\n .then(handler => {\r\n if (!handler) {\r\n console.error('google pay handler unavailable');\r\n this.googlePayMode = PaymentButtonMode.Unavailable;\r\n return;\r\n }\r\n\r\n handler\r\n .isBrowserSupported()\r\n .then(supported => {\r\n this.googlePayMode = supported\r\n ? PaymentButtonMode.Available\r\n : PaymentButtonMode.Unavailable;\r\n })\r\n .catch(reason => {\r\n console.error('error loading googlepay', reason);\r\n this.googlePayMode = PaymentButtonMode.Unavailable;\r\n });\r\n })\r\n .catch(reason => {\r\n console.error('google pay unavailable', reason);\r\n this.googlePayMode = PaymentButtonMode.Unavailable;\r\n });\r\n }\r\n\r\n private googlePaySelected(): void {\r\n this.dispatchEvent(new Event('googlePaySelected'));\r\n }\r\n\r\n private applePaySelected(e: Event): void {\r\n const event = new CustomEvent('applePaySelected', { detail: { originalEvent: e } });\r\n this.dispatchEvent(event);\r\n }\r\n\r\n private venmoSelected(): void {\r\n this.dispatchEvent(new Event('venmoSelected'));\r\n }\r\n\r\n private creditCardSelected(): void {\r\n this.dispatchEvent(new Event('creditCardSelected'));\r\n }\r\n\r\n private localPaypalButtonClicked(): void {\r\n this.dispatchEvent(new Event('paypalBlockerSelected'));\r\n }\r\n\r\n /** @inheritdoc */\r\n static get styles(): CSSResult {\r\n const paymentButtonWidthCss = css`var(--paymentButtonWidth, 5rem)`;\r\n const paymentButtonHeightCss = css`var(--paymentButtonHeight, 3.2rem)`;\r\n const creditCardFontSizeCss = css`var(--creditCardFontSize, 1.8rem)`;\r\n\r\n return css`\r\n button {\r\n color: inherit;\r\n font-family: inherit;\r\n }\r\n\r\n .payment-container {\r\n width: 100%;\r\n }\r\n\r\n .payment-provider-container {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr 1fr 1fr;\r\n grid-gap: 1rem;\r\n margin-bottom: 1rem;\r\n max-width: 23rem;\r\n }\r\n\r\n .provider-button {\r\n border: 0;\r\n padding: 0;\r\n background: none;\r\n cursor: pointer;\r\n width: ${paymentButtonWidthCss};\r\n height: ${paymentButtonHeightCss};\r\n }\r\n\r\n .provider-button.unavailable {\r\n display: none;\r\n }\r\n\r\n .provider-button.loading {\r\n border: 1px solid #ddd;\r\n border-radius: 2px;\r\n /* account for the borders that don't exist once the provider loads, otherwise the layout shifts */\r\n margin-bottom: -2px;\r\n }\r\n\r\n .provider-button.loading .payment-image {\r\n display: none;\r\n }\r\n\r\n .paypal-local-button {\r\n position: absolute;\r\n width: ${paymentButtonWidthCss};\r\n height: ${paymentButtonHeightCss};\r\n }\r\n\r\n .donation-info-valid .paypal-local-button {\r\n z-index: 0;\r\n }\r\n\r\n .donation-info-invalid .paypal-local-button {\r\n z-index: 250;\r\n }\r\n\r\n .credit-card-button {\r\n color: var(--ccButtonFontColor, #333);\r\n background-color: var(--ccButtonColor, white);\r\n border: 1px solid #333;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n margin: 0;\r\n padding: 0.7rem 1rem;\r\n width: 100%;\r\n }\r\n\r\n .credit-card-button .cc-background {\r\n height: 2.4rem;\r\n width: 100%;\r\n background-repeat: no-repeat;\r\n background-image: url(https://archive.org/images/cc_logos.png);\r\n background-position: 50% 50%;\r\n background-size: contain;\r\n }\r\n\r\n .credit-card-button .cc-title {\r\n font-size: ${creditCardFontSizeCss};\r\n font-weight: 700;\r\n margin-bottom: 0.5rem;\r\n }\r\n `;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"payment-selector.js","sourceRoot":"","sources":["../../../src/form-elements/payment-selector.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAA6C,MAAM,KAAK,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,mBAAmB,MAAM,gCAAgC,CAAC;AACjE,OAAO,oBAAoB,MAAM,iCAAiC,CAAC;AACnE,OAAO,iBAAiB,MAAM,8BAA8B,CAAC;AAC7D,OAAO,gBAAgB,MAAM,6BAA6B,CAAC;AAG3D,IAAK,iBAIJ;AAJD,WAAK,iBAAiB;IACpB,wCAAmB,CAAA;IACnB,4CAAuB,CAAA;IACvB,gDAA2B,CAAA;AAC7B,CAAC,EAJI,iBAAiB,KAAjB,iBAAiB,QAIrB;AAGD,IAAa,eAAe,GAA5B,MAAa,eAAgB,SAAQ,UAAU;IAA/C;;QAC+B,sBAAiB,GAAG,IAAI,CAAC;QAIlB,iBAAY,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAE5D,kBAAa,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAE7D,cAAS,GAAsB,iBAAiB,CAAC,OAAO,CAAC;QAEzD,eAAU,GAAsB,iBAAiB,CAAC,OAAO,CAAC;IAyQhG,CAAC;IAvQC,kBAAkB;IAClB,MAAM;QACJ,OAAO,IAAI,CAAA;;mCAEoB,IAAI,CAAC,iBAAiB;YAC/C,CAAC,CAAC,qBAAqB;YACvB,CAAC,CAAC,uBAAuB;;;;;8CAKW,IAAI,CAAC,YAAY;qBAC1C,IAAI,CAAC,gBAAgB;;;yCAGD,mBAAmB;;;;+CAIb,IAAI,CAAC,aAAa;qBAC5C,IAAI,CAAC,iBAAiB;;;yCAGF,oBAAoB;;;;2CAIlB,IAAI,CAAC,SAAS;qBACpC,IAAI,CAAC,aAAa;;;yCAGE,gBAAgB;;;yDAGA,IAAI,CAAC,UAAU;;wDAEhB,IAAI,CAAC,wBAAwB;kBACnE,iBAAiB;;;;;;;;;qBASd,IAAI,CAAC,kBAAkB;;;;;;;;;KASvC,CAAC;IACJ,CAAC;IAED,kBAAkB;IAClB,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;IAChD,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,OAAuB;QAC7B,IAAI,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,SAAS,CAAC;IAChD,CAAC;IAEa,mBAAmB;;;YAC/B,MAAA,IAAI,CAAC,gBAAgB,0CAAE,YAAY,CAChC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBAC/C,OAAO;iBACR;gBAED,OAAO;qBACJ,kBAAkB,EAAE;qBACpB,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,SAAS,GAAG,SAAS;wBACxB,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC;oBAC7C,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACjD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;gBAC3C,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACjD,CAAC,EAAE;YAEL,MAAA,IAAI,CAAC,gBAAgB,0CAAE,eAAe,CACnC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;oBAC7C,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBAClD,OAAO;iBACR;gBAED,OAAO;qBACJ,WAAW,EAAE;qBACb,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,YAAY,GAAG,SAAS;wBAC3B,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;oBAChD,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACpD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;gBAC/C,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACpD,CAAC,EAAE;YAEL,MAAA,IAAI,CAAC,gBAAgB,0CAAE,gBAAgB,CACpC,GAAG,GACH,IAAI,CAAC,OAAO,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;oBAChD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;oBACnD,OAAO;iBACR;gBAED,OAAO;qBACJ,kBAAkB,EAAE;qBACpB,IAAI,CAAC,SAAS,CAAC,EAAE;oBAChB,IAAI,CAAC,aAAa,GAAG,SAAS;wBAC5B,CAAC,CAAC,iBAAiB,CAAC,SAAS;wBAC7B,CAAC,CAAC,iBAAiB,CAAC,WAAW,CAAC;gBACpC,CAAC,CAAC;qBACD,KAAK,CAAC,MAAM,CAAC,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAC;oBACjD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;gBACrD,CAAC,CAAC,CAAC;YACP,CAAC,EACA,KAAK,CAAC,MAAM,CAAC,EAAE;gBACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;gBAChD,IAAI,CAAC,aAAa,GAAG,iBAAiB,CAAC,WAAW,CAAC;YACrD,CAAC,EAAE;;KACN;IAEO,iBAAiB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;IACrD,CAAC;IAEO,gBAAgB,CAAC,CAAQ;QAC/B,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QACpF,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC;IACjD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;IACtD,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,kBAAkB;IAClB,MAAM,KAAK,MAAM;QACf,MAAM,qBAAqB,GAAG,GAAG,CAAA,iCAAiC,CAAC;QACnE,MAAM,sBAAsB,GAAG,GAAG,CAAA,oCAAoC,CAAC;QACvE,MAAM,qBAAqB,GAAG,GAAG,CAAA,mCAAmC,CAAC;QAErE,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;iBAuBG,qBAAqB;kBACpB,sBAAsB;;;;;;;;;;;;;;;;;;;;iBAoBvB,qBAAqB;kBACpB,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAgCnB,qBAAqB;;;;KAIrC,CAAC;IACJ,CAAC;CACF,CAAA;AAnR8B;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;0DAA0B;AAE1B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;yDAA8C;AAE7C;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;qDAAqE;AAEpE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;sDAAsE;AAErE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAAkE;AAEjE;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAmE;AAXnF,eAAe;IAD3B,aAAa,CAAC,kBAAkB,CAAC;GACrB,eAAe,CAoR3B;SApRY,eAAe","sourcesContent":["import { LitElement, html, css, CSSResult, TemplateResult, PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport applePayButtonImage from '@internetarchive/icon-applepay';\nimport googlePayButtonImage from '@internetarchive/icon-googlepay';\nimport paypalButtonImage from '@internetarchive/icon-paypal';\nimport venmoButtonImage from '@internetarchive/icon-venmo';\nimport { PaymentProvidersInterface } from '../braintree-manager/payment-providers-interface';\n\nenum PaymentButtonMode {\n Loading = 'loading',\n Available = 'available',\n Unavailable = 'unavailable',\n}\n\n@customElement('payment-selector')\nexport class PaymentSelector extends LitElement {\n @property({ type: Boolean }) donationInfoValid = true;\n\n @property({ type: Object }) paymentProviders?: PaymentProvidersInterface;\n\n @property({ type: String }) private applePayMode: PaymentButtonMode = PaymentButtonMode.Loading;\n\n @property({ type: String }) private googlePayMode: PaymentButtonMode = PaymentButtonMode.Loading;\n\n @property({ type: String }) private venmoMode: PaymentButtonMode = PaymentButtonMode.Loading;\n\n @property({ type: String }) private payPalMode: PaymentButtonMode = PaymentButtonMode.Loading;\n\n /** @inheritdoc */\n render(): TemplateResult {\n return html`\n <div\n class=\"payment-container ${this.donationInfoValid\n ? 'donation-info-valid'\n : 'donation-info-invalid'}\n \"\n >\n <div class=\"payment-provider-container\">\n <button\n class=\"applepay provider-button ${this.applePayMode}\"\n @click=${this.applePaySelected}\n tabindex=\"0\"\n >\n <div class=\"payment-image\">${applePayButtonImage}</div>\n </button>\n\n <button\n class=\"googlepay provider-button ${this.googlePayMode}\"\n @click=${this.googlePaySelected}\n tabindex=\"0\"\n >\n <div class=\"payment-image\">${googlePayButtonImage}</div>\n </button>\n\n <button\n class=\"venmo provider-button ${this.venmoMode}\"\n @click=${this.venmoSelected}\n tabindex=\"0\"\n >\n <div class=\"payment-image\">${venmoButtonImage}</div>\n </button>\n\n <div class=\"paypal-container provider-button ${this.payPalMode}\" tabindex=\"0\">\n <div class=\"payment-image\">\n <div class=\"paypal-local-button\" @click=${this.localPaypalButtonClicked}>\n ${paypalButtonImage}\n </div>\n <slot name=\"paypal-button\"></slot>\n </div>\n </div>\n </div>\n\n <div class=\"credit-card-container\">\n <button\n @click=${this.creditCardSelected}\n class=\"button-style credit-card-button\"\n tabindex=\"0\"\n >\n <div class=\"cc-title\">Credit Card</div>\n <div class=\"cc-background\"></div>\n </button>\n </div>\n </div>\n `;\n }\n\n /** @inheritdoc */\n firstUpdated(): void {\n this.dispatchEvent(new Event('firstUpdated'));\n }\n\n /** @inheritdoc */\n updated(changed: PropertyValues): void {\n if (changed.has('paymentProviders')) {\n this.setButtonVisibility();\n }\n }\n\n showPaypalButton(): void {\n this.payPalMode = PaymentButtonMode.Available;\n }\n\n private async setButtonVisibility(): Promise<void> {\n this.paymentProviders?.venmoHandler\n .get()\n .then(handler => {\n if (!handler) {\n this.venmoMode = PaymentButtonMode.Unavailable;\n return;\n }\n\n handler\n .isBrowserSupported()\n .then(supported => {\n this.venmoMode = supported\n ? PaymentButtonMode.Available\n : PaymentButtonMode.Unavailable;\n })\n .catch(reason => {\n console.error('error loading venmo', reason);\n this.venmoMode = PaymentButtonMode.Unavailable;\n });\n })\n .catch(reason => {\n console.error('venmo unavailable', reason);\n this.venmoMode = PaymentButtonMode.Unavailable;\n });\n\n this.paymentProviders?.applePayHandler\n .get()\n .then(handler => {\n if (!handler) {\n console.error('applePayHandler unavailable');\n this.applePayMode = PaymentButtonMode.Unavailable;\n return;\n }\n\n handler\n .isAvailable()\n .then(supported => {\n this.applePayMode = supported\n ? PaymentButtonMode.Available\n : PaymentButtonMode.Unavailable;\n })\n .catch(reason => {\n console.error('error loading applepay', reason);\n this.applePayMode = PaymentButtonMode.Unavailable;\n });\n })\n .catch(reason => {\n console.error('apple pay unavailable', reason);\n this.applePayMode = PaymentButtonMode.Unavailable;\n });\n\n this.paymentProviders?.googlePayHandler\n .get()\n .then(handler => {\n if (!handler) {\n console.error('google pay handler unavailable');\n this.googlePayMode = PaymentButtonMode.Unavailable;\n return;\n }\n\n handler\n .isBrowserSupported()\n .then(supported => {\n this.googlePayMode = supported\n ? PaymentButtonMode.Available\n : PaymentButtonMode.Unavailable;\n })\n .catch(reason => {\n console.error('error loading googlepay', reason);\n this.googlePayMode = PaymentButtonMode.Unavailable;\n });\n })\n .catch(reason => {\n console.error('google pay unavailable', reason);\n this.googlePayMode = PaymentButtonMode.Unavailable;\n });\n }\n\n private googlePaySelected(): void {\n this.dispatchEvent(new Event('googlePaySelected'));\n }\n\n private applePaySelected(e: Event): void {\n const event = new CustomEvent('applePaySelected', { detail: { originalEvent: e } });\n this.dispatchEvent(event);\n }\n\n private venmoSelected(): void {\n this.dispatchEvent(new Event('venmoSelected'));\n }\n\n private creditCardSelected(): void {\n this.dispatchEvent(new Event('creditCardSelected'));\n }\n\n private localPaypalButtonClicked(): void {\n this.dispatchEvent(new Event('paypalBlockerSelected'));\n }\n\n /** @inheritdoc */\n static get styles(): CSSResult {\n const paymentButtonWidthCss = css`var(--paymentButtonWidth, 5rem)`;\n const paymentButtonHeightCss = css`var(--paymentButtonHeight, 3.2rem)`;\n const creditCardFontSizeCss = css`var(--creditCardFontSize, 1.8rem)`;\n\n return css`\n button {\n color: inherit;\n font-family: inherit;\n }\n\n .payment-container {\n width: 100%;\n }\n\n .payment-provider-container {\n display: grid;\n grid-template-columns: 1fr 1fr 1fr 1fr;\n grid-gap: 1rem;\n margin-bottom: 1rem;\n max-width: 23rem;\n }\n\n .provider-button {\n border: 0;\n padding: 0;\n background: none;\n cursor: pointer;\n width: ${paymentButtonWidthCss};\n height: ${paymentButtonHeightCss};\n }\n\n .provider-button.unavailable {\n display: none;\n }\n\n .provider-button.loading {\n border: 1px solid #ddd;\n border-radius: 2px;\n /* account for the borders that don't exist once the provider loads, otherwise the layout shifts */\n margin-bottom: -2px;\n }\n\n .provider-button.loading .payment-image {\n display: none;\n }\n\n .paypal-local-button {\n position: absolute;\n width: ${paymentButtonWidthCss};\n height: ${paymentButtonHeightCss};\n }\n\n .donation-info-valid .paypal-local-button {\n z-index: 0;\n }\n\n .donation-info-invalid .paypal-local-button {\n z-index: 250;\n }\n\n .credit-card-button {\n color: var(--ccButtonFontColor, #333);\n background-color: var(--ccButtonColor, white);\n border: 1px solid #333;\n border-radius: 4px;\n cursor: pointer;\n margin: 0;\n padding: 0.7rem 1rem;\n width: 100%;\n }\n\n .credit-card-button .cc-background {\n height: 2.4rem;\n width: 100%;\n background-repeat: no-repeat;\n background-image: url(https://archive.org/images/cc_logos.png);\n background-position: 50% 50%;\n background-size: contain;\n }\n\n .credit-card-button .cc-title {\n font-size: ${creditCardFontSizeCss};\n font-weight: 700;\n margin-bottom: 0.5rem;\n }\n `;\n }\n}\n"]}