@internetarchive/donation-form 0.5.17-a3 → 0.5.18-alpha.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 (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-braintree-manager.d.ts +45 -45
  166. package/dist/test/mocks/mock-braintree-manager.js +71 -71
  167. package/dist/test/mocks/mock-braintree-manager.js.map +1 -1
  168. package/dist/test/mocks/mock-donation-info.d.ts +4 -4
  169. package/dist/test/mocks/mock-donation-info.js +10 -10
  170. package/dist/test/mocks/mock-donation-info.js.map +1 -1
  171. package/dist/test/mocks/mock-endpoint-manager.d.ts +12 -12
  172. package/dist/test/mocks/mock-endpoint-manager.js +19 -19
  173. package/dist/test/mocks/mock-endpoint-manager.js.map +1 -1
  174. package/dist/test/mocks/mock-hosted-fields-config.d.ts +4 -4
  175. package/dist/test/mocks/mock-hosted-fields-config.js +37 -37
  176. package/dist/test/mocks/mock-hosted-fields-config.js.map +1 -1
  177. package/dist/test/mocks/mock-hosted-fields-container.d.ts +13 -13
  178. package/dist/test/mocks/mock-hosted-fields-container.js +27 -27
  179. package/dist/test/mocks/mock-hosted-fields-container.js.map +1 -1
  180. package/dist/test/mocks/mock-lazy-loader.d.ts +15 -15
  181. package/dist/test/mocks/mock-lazy-loader.js +20 -20
  182. package/dist/test/mocks/mock-lazy-loader.js.map +1 -1
  183. package/dist/test/mocks/mock-modal-manager.d.ts +17 -17
  184. package/dist/test/mocks/mock-modal-manager.js +26 -26
  185. package/dist/test/mocks/mock-modal-manager.js.map +1 -1
  186. package/dist/test/mocks/mock-payment-clients.d.ts +29 -29
  187. package/dist/test/mocks/mock-payment-clients.js +78 -78
  188. package/dist/test/mocks/mock-payment-clients.js.map +1 -1
  189. package/dist/test/mocks/mock-paypal-button-renderer.d.ts +5 -5
  190. package/dist/test/mocks/mock-paypal-button-renderer.js +6 -6
  191. package/dist/test/mocks/mock-paypal-button-renderer.js.map +1 -1
  192. package/dist/test/mocks/mock-recaptcha-manager.d.ts +7 -7
  193. package/dist/test/mocks/mock-recaptcha-manager.js +14 -14
  194. package/dist/test/mocks/mock-recaptcha-manager.js.map +1 -1
  195. package/dist/test/mocks/models/mock-billing-info.d.ts +2 -2
  196. package/dist/test/mocks/models/mock-billing-info.js +9 -9
  197. package/dist/test/mocks/models/mock-billing-info.js.map +1 -1
  198. package/dist/test/mocks/models/mock-custom-fields.d.ts +2 -2
  199. package/dist/test/mocks/models/mock-custom-fields.js +7 -7
  200. package/dist/test/mocks/models/mock-custom-fields.js.map +1 -1
  201. package/dist/test/mocks/models/mock-customer-info.d.ts +2 -2
  202. package/dist/test/mocks/models/mock-customer-info.js +6 -6
  203. package/dist/test/mocks/models/mock-customer-info.js.map +1 -1
  204. package/dist/test/mocks/models/mock-donation-request.d.ts +2 -2
  205. package/dist/test/mocks/models/mock-donation-request.js +18 -18
  206. package/dist/test/mocks/models/mock-donation-request.js.map +1 -1
  207. package/dist/test/mocks/models/mock-success-response.d.ts +2 -2
  208. package/dist/test/mocks/models/mock-success-response.js +14 -14
  209. package/dist/test/mocks/models/mock-success-response.js.map +1 -1
  210. package/dist/test/mocks/payment-clients/mock-applepay-client.d.ts +21 -21
  211. package/dist/test/mocks/payment-clients/mock-applepay-client.js +72 -72
  212. package/dist/test/mocks/payment-clients/mock-applepay-client.js.map +1 -1
  213. package/dist/test/mocks/payment-clients/mock-applepay-payment.d.ts +6 -6
  214. package/dist/test/mocks/payment-clients/mock-applepay-payment.js +42 -42
  215. package/dist/test/mocks/payment-clients/mock-applepay-payment.js.map +1 -1
  216. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.d.ts +22 -22
  217. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.js +35 -35
  218. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.js.map +1 -1
  219. package/dist/test/mocks/payment-clients/mock-applepay-session.d.ts +30 -30
  220. package/dist/test/mocks/payment-clients/mock-applepay-session.js +52 -52
  221. package/dist/test/mocks/payment-clients/mock-applepay-session.js.map +1 -1
  222. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.d.ts +10 -10
  223. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.js +12 -12
  224. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.js.map +1 -1
  225. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.d.ts +22 -22
  226. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.js +34 -34
  227. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.js.map +1 -1
  228. package/dist/test/mocks/payment-clients/mock-braintree-client.d.ts +14 -14
  229. package/dist/test/mocks/payment-clients/mock-braintree-client.js +19 -19
  230. package/dist/test/mocks/payment-clients/mock-braintree-client.js.map +1 -1
  231. package/dist/test/mocks/payment-clients/mock-data-collector.d.ts +11 -11
  232. package/dist/test/mocks/payment-clients/mock-data-collector.js +17 -17
  233. package/dist/test/mocks/payment-clients/mock-data-collector.js.map +1 -1
  234. package/dist/test/mocks/payment-clients/mock-googlepay-client.d.ts +22 -22
  235. package/dist/test/mocks/payment-clients/mock-googlepay-client.js +42 -42
  236. package/dist/test/mocks/payment-clients/mock-googlepay-client.js.map +1 -1
  237. package/dist/test/mocks/payment-clients/mock-googlepay-library.d.ts +10 -10
  238. package/dist/test/mocks/payment-clients/mock-googlepay-library.js +22 -22
  239. package/dist/test/mocks/payment-clients/mock-googlepay-library.js.map +1 -1
  240. package/dist/test/mocks/payment-clients/mock-grecaptcha.d.ts +23 -23
  241. package/dist/test/mocks/payment-clients/mock-grecaptcha.js +62 -62
  242. package/dist/test/mocks/payment-clients/mock-grecaptcha.js.map +1 -1
  243. package/dist/test/mocks/payment-clients/mock-hostedfields-client.d.ts +33 -33
  244. package/dist/test/mocks/payment-clients/mock-hostedfields-client.js +54 -54
  245. package/dist/test/mocks/payment-clients/mock-hostedfields-client.js.map +1 -1
  246. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.d.ts +1 -1
  247. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.js +50 -50
  248. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.js.map +1 -1
  249. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.d.ts +1 -1
  250. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.js +13 -13
  251. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.js.map +1 -1
  252. package/dist/test/mocks/payment-clients/mock-paypal-client.d.ts +23 -23
  253. package/dist/test/mocks/payment-clients/mock-paypal-client.js +62 -62
  254. package/dist/test/mocks/payment-clients/mock-paypal-client.js.map +1 -1
  255. package/dist/test/mocks/payment-clients/mock-paypal-library.d.ts +4 -4
  256. package/dist/test/mocks/payment-clients/mock-paypal-library.js +9 -9
  257. package/dist/test/mocks/payment-clients/mock-paypal-library.js.map +1 -1
  258. package/dist/test/mocks/payment-clients/mock-venmo-client.d.ts +22 -22
  259. package/dist/test/mocks/payment-clients/mock-venmo-client.js +36 -36
  260. package/dist/test/mocks/payment-clients/mock-venmo-client.js.map +1 -1
  261. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.d.ts +10 -10
  262. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.js +14 -14
  263. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.js.map +1 -1
  264. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.d.ts +9 -9
  265. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.js +19 -19
  266. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.js.map +1 -1
  267. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.d.ts +18 -18
  268. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.js +41 -41
  269. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.js.map +1 -1
  270. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.d.ts +8 -8
  271. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.js +16 -16
  272. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.js.map +1 -1
  273. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.d.ts +28 -28
  274. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.js +52 -52
  275. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.js.map +1 -1
  276. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.d.ts +11 -11
  277. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.js +37 -37
  278. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.js.map +1 -1
  279. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.d.ts +12 -12
  280. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.js +15 -15
  281. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.js.map +1 -1
  282. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.d.ts +7 -7
  283. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.js +22 -22
  284. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.js.map +1 -1
  285. package/dist/test/mocks/payment-providers/mock-payment-providers.d.ts +21 -21
  286. package/dist/test/mocks/payment-providers/mock-payment-providers.js +45 -45
  287. package/dist/test/mocks/payment-providers/mock-payment-providers.js.map +1 -1
  288. package/dist/test/tests/braintree-manager.test.d.ts +1 -1
  289. package/dist/test/tests/braintree-manager.test.js +166 -166
  290. package/dist/test/tests/braintree-manager.test.js.map +1 -1
  291. package/dist/test/tests/donation-form-controller.test.d.ts +1 -1
  292. package/dist/test/tests/donation-form-controller.test.js +188 -199
  293. package/dist/test/tests/donation-form-controller.test.js.map +1 -1
  294. package/dist/test/tests/donation-form.test.d.ts +1 -1
  295. package/dist/test/tests/donation-form.test.js +109 -109
  296. package/dist/test/tests/donation-form.test.js.map +1 -1
  297. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.d.ts +1 -1
  298. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js +216 -216
  299. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js.map +1 -1
  300. package/dist/test/tests/form-elements/donation-summary.test.d.ts +1 -1
  301. package/dist/test/tests/form-elements/donation-summary.test.js +36 -36
  302. package/dist/test/tests/form-elements/donation-summary.test.js.map +1 -1
  303. package/dist/test/tests/form-elements/payment-selector.test.d.ts +1 -1
  304. package/dist/test/tests/form-elements/payment-selector.test.js +69 -69
  305. package/dist/test/tests/form-elements/payment-selector.test.js.map +1 -1
  306. package/dist/test/tests/modals/error-modal-content.test.d.ts +1 -1
  307. package/dist/test/tests/modals/error-modal-content.test.js +14 -14
  308. package/dist/test/tests/modals/error-modal-content.test.js.map +1 -1
  309. package/dist/test/tests/modals/upsell-modal-content.test.d.ts +1 -1
  310. package/dist/test/tests/modals/upsell-modal-content.test.js +163 -163
  311. package/dist/test/tests/modals/upsell-modal-content.test.js.map +1 -1
  312. package/dist/test/tests/models/donation-payment-info.test.d.ts +1 -1
  313. package/dist/test/tests/models/donation-payment-info.test.js +74 -74
  314. package/dist/test/tests/models/donation-payment-info.test.js.map +1 -1
  315. package/dist/test/tests/payment-clients.test.d.ts +1 -1
  316. package/dist/test/tests/payment-clients.test.js +130 -130
  317. package/dist/test/tests/payment-clients.test.js.map +1 -1
  318. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.d.ts +1 -1
  319. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.js +160 -160
  320. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.js.map +1 -1
  321. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.d.ts +1 -1
  322. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.js +36 -36
  323. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.js.map +1 -1
  324. package/dist/test/tests/payment-providers/applepay.test.d.ts +1 -1
  325. package/dist/test/tests/payment-providers/applepay.test.js +78 -78
  326. package/dist/test/tests/payment-providers/applepay.test.js.map +1 -1
  327. package/dist/test/tests/payment-providers/creditcard.test.d.ts +1 -1
  328. package/dist/test/tests/payment-providers/creditcard.test.js +190 -190
  329. package/dist/test/tests/payment-providers/creditcard.test.js.map +1 -1
  330. package/dist/test/tests/payment-providers/googlepay.test.d.ts +1 -1
  331. package/dist/test/tests/payment-providers/googlepay.test.js +48 -48
  332. package/dist/test/tests/payment-providers/googlepay.test.js.map +1 -1
  333. package/dist/test/tests/payment-providers/payment-providers.test.d.ts +1 -1
  334. package/dist/test/tests/payment-providers/payment-providers.test.js +38 -38
  335. package/dist/test/tests/payment-providers/payment-providers.test.js.map +1 -1
  336. package/dist/test/tests/payment-providers/paypal-button-datasource.test.d.ts +1 -1
  337. package/dist/test/tests/payment-providers/paypal-button-datasource.test.js +162 -162
  338. package/dist/test/tests/payment-providers/paypal-button-datasource.test.js.map +1 -1
  339. package/dist/test/tests/payment-providers/paypal.test.d.ts +1 -1
  340. package/dist/test/tests/payment-providers/paypal.test.js +38 -38
  341. package/dist/test/tests/payment-providers/paypal.test.js.map +1 -1
  342. package/dist/test/tests/payment-providers/venmo.test.d.ts +1 -1
  343. package/dist/test/tests/payment-providers/venmo.test.js +77 -77
  344. package/dist/test/tests/payment-providers/venmo.test.js.map +1 -1
  345. package/dist/test/tests/recaptcha-manager.test.d.ts +1 -1
  346. package/dist/test/tests/recaptcha-manager.test.js +70 -70
  347. package/dist/test/tests/recaptcha-manager.test.js.map +1 -1
  348. package/package.json +101 -101
  349. package/src/@types/analytics-handler/index.d.ts +8 -8
  350. package/src/@types/braintree-web/LICENSE +21 -21
  351. package/src/@types/braintree-web/index.d.ts +93 -93
  352. package/src/@types/braintree-web/modules/american-express.d.ts +50 -50
  353. package/src/@types/braintree-web/modules/apple-pay.d.ts +213 -213
  354. package/src/@types/braintree-web/modules/client.d.ts +103 -103
  355. package/src/@types/braintree-web/modules/core.d.ts +34 -34
  356. package/src/@types/braintree-web/modules/data-collector.d.ts +13 -13
  357. package/src/@types/braintree-web/modules/google-payment.d.ts +269 -269
  358. package/src/@types/braintree-web/modules/hosted-fields.d.ts +366 -366
  359. package/src/@types/braintree-web/modules/paypal-checkout.d.ts +262 -262
  360. package/src/@types/braintree-web/modules/paypal.d.ts +177 -177
  361. package/src/@types/braintree-web/modules/three-d-secure.d.ts +141 -141
  362. package/src/@types/braintree-web/modules/unionpay.d.ts +224 -224
  363. package/src/@types/braintree-web/modules/us-bank-account.d.ts +81 -81
  364. package/src/@types/braintree-web/modules/venmo.d.ts +110 -110
  365. package/src/@types/braintree-web/package.json +64 -64
  366. package/src/@types/paypal-checkout-components/LICENSE +21 -21
  367. package/src/@types/paypal-checkout-components/index.d.ts +67 -67
  368. package/src/@types/paypal-checkout-components/modules/button.d.ts +50 -50
  369. package/src/@types/paypal-checkout-components/modules/callback-data.d.ts +244 -244
  370. package/src/@types/paypal-checkout-components/modules/configuration.d.ts +114 -114
  371. package/src/@types/paypal-checkout-components/package.json +58 -58
  372. package/src/braintree-manager/braintree-interfaces.ts +172 -172
  373. package/src/braintree-manager/braintree-manager.ts +283 -283
  374. package/src/braintree-manager/payment-clients.ts +148 -148
  375. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.ts +13 -13
  376. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.ts +8 -8
  377. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.ts +10 -10
  378. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.ts +119 -119
  379. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.ts +21 -21
  380. package/src/braintree-manager/payment-providers/apple-pay/apple-pay.ts +98 -98
  381. package/src/braintree-manager/payment-providers/credit-card/credit-card-interface.ts +21 -21
  382. package/src/braintree-manager/payment-providers/credit-card/credit-card.ts +130 -130
  383. package/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.ts +19 -19
  384. package/src/braintree-manager/payment-providers/credit-card/hosted-field-container.ts +85 -85
  385. package/src/braintree-manager/payment-providers/google-pay-interface.ts +8 -8
  386. package/src/braintree-manager/payment-providers/google-pay.ts +59 -59
  387. package/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.ts +218 -218
  388. package/src/braintree-manager/payment-providers/paypal/paypal-interface.ts +13 -13
  389. package/src/braintree-manager/payment-providers/paypal/paypal.ts +78 -78
  390. package/src/braintree-manager/payment-providers/venmo-interface.ts +8 -8
  391. package/src/braintree-manager/payment-providers/venmo.ts +67 -67
  392. package/src/braintree-manager/payment-providers-interface.ts +25 -25
  393. package/src/braintree-manager/payment-providers.ts +147 -147
  394. package/src/donation-form-controller.ts +619 -619
  395. package/src/donation-form-error.ts +6 -6
  396. package/src/donation-form.ts +566 -566
  397. package/src/form-elements/badged-input.ts +113 -113
  398. package/src/form-elements/contact-form/autocomplete-field-options.ts +63 -63
  399. package/src/form-elements/contact-form/contact-form.ts +427 -427
  400. package/src/form-elements/contact-form/countries.ts +252 -252
  401. package/src/form-elements/header/donation-form-header.ts +100 -100
  402. package/src/form-elements/header/donation-summary.ts +61 -61
  403. package/src/form-elements/payment-selector.ts +293 -293
  404. package/src/form-elements/total-amount.ts +46 -46
  405. package/src/modals/confirm-donation-modal-content.ts +160 -160
  406. package/src/modals/error-modal-content.ts +48 -48
  407. package/src/modals/upsell-modal-content.ts +294 -294
  408. package/src/payment-flow-handlers/donation-flow-modal-manager.ts +450 -450
  409. package/src/payment-flow-handlers/handlers/applepay-flow-handler.ts +108 -108
  410. package/src/payment-flow-handlers/handlers/creditcard-flow-handler.ts +231 -231
  411. package/src/payment-flow-handlers/handlers/googlepay-flow-handler.ts +113 -113
  412. package/src/payment-flow-handlers/handlers/paypal-flow-handler.ts +332 -332
  413. package/src/payment-flow-handlers/handlers/venmo-flow-handler.ts +118 -118
  414. package/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.ts +127 -127
  415. package/src/payment-flow-handlers/payment-flow-handlers.ts +218 -218
  416. package/src/recaptcha-manager/recaptcha-manager.ts +123 -123
  417. package/src/util/promisedSleep.ts +3 -3
  418. package/dist/test/mocks/mock-analytics-handler.d.ts +0 -8
  419. package/dist/test/mocks/mock-analytics-handler.js +0 -10
  420. package/dist/test/mocks/mock-analytics-handler.js.map +0 -1
@@ -1,70 +1,70 @@
1
- import { __awaiter } from "tslib";
2
- import { html, fixture, expect, elementUpdated, oneEvent } from '@open-wc/testing';
3
- import '../../../src/form-elements/payment-selector';
4
- import { MockPaymentProviders } from '../../mocks/payment-providers/mock-payment-providers';
5
- import { promisedSleep } from '../../../src/util/promisedSleep';
6
- describe('Payment Selector', () => {
7
- it('shows Venmo if it is available', () => __awaiter(void 0, void 0, void 0, function* () {
8
- var _a;
9
- const el = (yield fixture(html `
10
- <payment-selector></payment-selector>
11
- `));
12
- const paymentProviders = new MockPaymentProviders();
13
- el.paymentProviders = paymentProviders;
14
- yield elementUpdated(el);
15
- yield promisedSleep(250);
16
- const venmoButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.venmo.provider-button');
17
- expect(venmoButton === null || venmoButton === void 0 ? void 0 : venmoButton.classList.contains('available')).to.be.true;
18
- }));
19
- it('can show PayPal when called', () => __awaiter(void 0, void 0, void 0, function* () {
20
- var _b;
21
- const el = (yield fixture(html `
22
- <payment-selector></payment-selector>
23
- `));
24
- el.showPaypalButton();
25
- yield elementUpdated(el);
26
- const paypalButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.paypal-container.provider-button');
27
- expect(paypalButton === null || paypalButton === void 0 ? void 0 : paypalButton.classList.contains('available')).to.be.true;
28
- }));
29
- it('emits paypalBlockerSelected event when paypal is selected in an error state', () => __awaiter(void 0, void 0, void 0, function* () {
30
- var _c;
31
- const el = (yield fixture(html `
32
- <payment-selector></payment-selector>
33
- `));
34
- const paypalBlocker = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.paypal-local-button');
35
- const clickEvent = new MouseEvent('click');
36
- setTimeout(() => {
37
- paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
38
- });
39
- const response = yield oneEvent(el, 'paypalBlockerSelected');
40
- expect(response).to.exist;
41
- }));
42
- it('emits applePaySelected event with original click event when ApplePay is selected', () => __awaiter(void 0, void 0, void 0, function* () {
43
- var _d;
44
- const el = (yield fixture(html `
45
- <payment-selector></payment-selector>
46
- `));
47
- const paypalBlocker = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.applepay.provider-button');
48
- const clickEvent = new MouseEvent('click');
49
- setTimeout(() => {
50
- paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
51
- });
52
- const response = yield oneEvent(el, 'applePaySelected');
53
- const event = response.detail.originalEvent;
54
- expect(event).to.equal(clickEvent);
55
- }));
56
- it('emits googlePaySelected when GooglePay is selected', () => __awaiter(void 0, void 0, void 0, function* () {
57
- var _e;
58
- const el = (yield fixture(html `
59
- <payment-selector></payment-selector>
60
- `));
61
- const paypalBlocker = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('.googlepay.provider-button');
62
- const clickEvent = new MouseEvent('click');
63
- setTimeout(() => {
64
- paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
65
- });
66
- const response = yield oneEvent(el, 'googlePaySelected');
67
- expect(response).to.exist;
68
- }));
69
- });
1
+ import { __awaiter } from "tslib";
2
+ import { html, fixture, expect, elementUpdated, oneEvent } from '@open-wc/testing';
3
+ import '../../../src/form-elements/payment-selector';
4
+ import { MockPaymentProviders } from '../../mocks/payment-providers/mock-payment-providers';
5
+ import { promisedSleep } from '../../../src/util/promisedSleep';
6
+ describe('Payment Selector', () => {
7
+ it('shows Venmo if it is available', () => __awaiter(void 0, void 0, void 0, function* () {
8
+ var _a;
9
+ const el = (yield fixture(html `
10
+ <payment-selector></payment-selector>
11
+ `));
12
+ const paymentProviders = new MockPaymentProviders();
13
+ el.paymentProviders = paymentProviders;
14
+ yield elementUpdated(el);
15
+ yield promisedSleep(250);
16
+ const venmoButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.venmo.provider-button');
17
+ expect(venmoButton === null || venmoButton === void 0 ? void 0 : venmoButton.classList.contains('available')).to.be.true;
18
+ }));
19
+ it('can show PayPal when called', () => __awaiter(void 0, void 0, void 0, function* () {
20
+ var _b;
21
+ const el = (yield fixture(html `
22
+ <payment-selector></payment-selector>
23
+ `));
24
+ el.showPaypalButton();
25
+ yield elementUpdated(el);
26
+ const paypalButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.paypal-container.provider-button');
27
+ expect(paypalButton === null || paypalButton === void 0 ? void 0 : paypalButton.classList.contains('available')).to.be.true;
28
+ }));
29
+ it('emits paypalBlockerSelected event when paypal is selected in an error state', () => __awaiter(void 0, void 0, void 0, function* () {
30
+ var _c;
31
+ const el = (yield fixture(html `
32
+ <payment-selector></payment-selector>
33
+ `));
34
+ const paypalBlocker = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.paypal-local-button');
35
+ const clickEvent = new MouseEvent('click');
36
+ setTimeout(() => {
37
+ paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
38
+ });
39
+ const response = yield oneEvent(el, 'paypalBlockerSelected');
40
+ expect(response).to.exist;
41
+ }));
42
+ it('emits applePaySelected event with original click event when ApplePay is selected', () => __awaiter(void 0, void 0, void 0, function* () {
43
+ var _d;
44
+ const el = (yield fixture(html `
45
+ <payment-selector></payment-selector>
46
+ `));
47
+ const paypalBlocker = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.applepay.provider-button');
48
+ const clickEvent = new MouseEvent('click');
49
+ setTimeout(() => {
50
+ paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
51
+ });
52
+ const response = yield oneEvent(el, 'applePaySelected');
53
+ const event = response.detail.originalEvent;
54
+ expect(event).to.equal(clickEvent);
55
+ }));
56
+ it('emits googlePaySelected when GooglePay is selected', () => __awaiter(void 0, void 0, void 0, function* () {
57
+ var _e;
58
+ const el = (yield fixture(html `
59
+ <payment-selector></payment-selector>
60
+ `));
61
+ const paypalBlocker = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('.googlepay.provider-button');
62
+ const clickEvent = new MouseEvent('click');
63
+ setTimeout(() => {
64
+ paypalBlocker === null || paypalBlocker === void 0 ? void 0 : paypalBlocker.dispatchEvent(clickEvent);
65
+ });
66
+ const response = yield oneEvent(el, 'googlePaySelected');
67
+ expect(response).to.exist;
68
+ }));
69
+ });
70
70
  //# sourceMappingURL=payment-selector.test.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"payment-selector.test.js","sourceRoot":"","sources":["../../../../test/tests/form-elements/payment-selector.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, fixture, expect, elementUpdated, oneEvent } from '@open-wc/testing';\nimport { PaymentSelector } from '../../../src/form-elements/payment-selector';\nimport '../../../src/form-elements/payment-selector';\nimport { MockPaymentProviders } from '../../mocks/payment-providers/mock-payment-providers';\nimport { promisedSleep } from '../../../src/util/promisedSleep';\n\ndescribe('Payment Selector', () => {\n it('shows Venmo if it is available', async () => {\n const el = (await fixture(html`\n <payment-selector></payment-selector>\n `)) as PaymentSelector;\n\n const paymentProviders = new MockPaymentProviders();\n el.paymentProviders = paymentProviders;\n await elementUpdated(el);\n await promisedSleep(250);\n\n const venmoButton = el.shadowRoot?.querySelector('.venmo.provider-button');\n expect(venmoButton?.classList.contains('available')).to.be.true;\n });\n\n it('can show PayPal when called', async () => {\n const el = (await fixture(html`\n <payment-selector></payment-selector>\n `)) as PaymentSelector;\n el.showPaypalButton();\n await elementUpdated(el);\n const paypalButton = el.shadowRoot?.querySelector('.paypal-container.provider-button');\n expect(paypalButton?.classList.contains('available')).to.be.true;\n });\n\n it('emits paypalBlockerSelected event when paypal is selected in an error state', async () => {\n const el = (await fixture(html`\n <payment-selector></payment-selector>\n `)) as PaymentSelector;\n const paypalBlocker = el.shadowRoot?.querySelector('.paypal-local-button');\n const clickEvent = new MouseEvent('click');\n setTimeout(() => {\n paypalBlocker?.dispatchEvent(clickEvent);\n });\n const response = await oneEvent(el, 'paypalBlockerSelected');\n expect(response).to.exist;\n });\n\n it('emits applePaySelected event with original click event when ApplePay is selected', async () => {\n const el = (await fixture(html`\n <payment-selector></payment-selector>\n `)) as PaymentSelector;\n const paypalBlocker = el.shadowRoot?.querySelector('.applepay.provider-button');\n const clickEvent = new MouseEvent('click');\n setTimeout(() => {\n paypalBlocker?.dispatchEvent(clickEvent);\n });\n const response = await oneEvent(el, 'applePaySelected');\n const event = response.detail.originalEvent;\n expect(event).to.equal(clickEvent);\n });\n\n it('emits googlePaySelected when GooglePay is selected', async () => {\n const el = (await fixture(html`\n <payment-selector></payment-selector>\n `)) as PaymentSelector;\n const paypalBlocker = el.shadowRoot?.querySelector('.googlepay.provider-button');\n const clickEvent = new MouseEvent('click');\n setTimeout(() => {\n paypalBlocker?.dispatchEvent(clickEvent);\n });\n const response = await oneEvent(el, 'googlePaySelected');\n expect(response).to.exist;\n });\n});\n"]}
1
+ {"version":3,"file":"payment-selector.test.js","sourceRoot":"","sources":["../../../../test/tests/form-elements/payment-selector.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, fixture, expect, elementUpdated, oneEvent } from '@open-wc/testing';\r\nimport { PaymentSelector } from '../../../src/form-elements/payment-selector';\r\nimport '../../../src/form-elements/payment-selector';\r\nimport { MockPaymentProviders } from '../../mocks/payment-providers/mock-payment-providers';\r\nimport { promisedSleep } from '../../../src/util/promisedSleep';\r\n\r\ndescribe('Payment Selector', () => {\r\n it('shows Venmo if it is available', async () => {\r\n const el = (await fixture(html`\r\n <payment-selector></payment-selector>\r\n `)) as PaymentSelector;\r\n\r\n const paymentProviders = new MockPaymentProviders();\r\n el.paymentProviders = paymentProviders;\r\n await elementUpdated(el);\r\n await promisedSleep(250);\r\n\r\n const venmoButton = el.shadowRoot?.querySelector('.venmo.provider-button');\r\n expect(venmoButton?.classList.contains('available')).to.be.true;\r\n });\r\n\r\n it('can show PayPal when called', async () => {\r\n const el = (await fixture(html`\r\n <payment-selector></payment-selector>\r\n `)) as PaymentSelector;\r\n el.showPaypalButton();\r\n await elementUpdated(el);\r\n const paypalButton = el.shadowRoot?.querySelector('.paypal-container.provider-button');\r\n expect(paypalButton?.classList.contains('available')).to.be.true;\r\n });\r\n\r\n it('emits paypalBlockerSelected event when paypal is selected in an error state', async () => {\r\n const el = (await fixture(html`\r\n <payment-selector></payment-selector>\r\n `)) as PaymentSelector;\r\n const paypalBlocker = el.shadowRoot?.querySelector('.paypal-local-button');\r\n const clickEvent = new MouseEvent('click');\r\n setTimeout(() => {\r\n paypalBlocker?.dispatchEvent(clickEvent);\r\n });\r\n const response = await oneEvent(el, 'paypalBlockerSelected');\r\n expect(response).to.exist;\r\n });\r\n\r\n it('emits applePaySelected event with original click event when ApplePay is selected', async () => {\r\n const el = (await fixture(html`\r\n <payment-selector></payment-selector>\r\n `)) as PaymentSelector;\r\n const paypalBlocker = el.shadowRoot?.querySelector('.applepay.provider-button');\r\n const clickEvent = new MouseEvent('click');\r\n setTimeout(() => {\r\n paypalBlocker?.dispatchEvent(clickEvent);\r\n });\r\n const response = await oneEvent(el, 'applePaySelected');\r\n const event = response.detail.originalEvent;\r\n expect(event).to.equal(clickEvent);\r\n });\r\n\r\n it('emits googlePaySelected when GooglePay is selected', async () => {\r\n const el = (await fixture(html`\r\n <payment-selector></payment-selector>\r\n `)) as PaymentSelector;\r\n const paypalBlocker = el.shadowRoot?.querySelector('.googlepay.provider-button');\r\n const clickEvent = new MouseEvent('click');\r\n setTimeout(() => {\r\n paypalBlocker?.dispatchEvent(clickEvent);\r\n });\r\n const response = await oneEvent(el, 'googlePaySelected');\r\n expect(response).to.exist;\r\n });\r\n});\r\n"]}
@@ -1 +1 @@
1
- import '../../../src/modals/error-modal-content';
1
+ import '../../../src/modals/error-modal-content';
@@ -1,15 +1,15 @@
1
- import { __awaiter } from "tslib";
2
- import { html, fixture, expect } from '@open-wc/testing';
3
- import '../../../src/modals/error-modal-content';
4
- describe('Error Modal Content', () => {
5
- it('renders a "Questions" link', () => __awaiter(void 0, void 0, void 0, function* () {
6
- var _a;
7
- const el = yield fixture(html `
8
- <donation-form-error-modal-content></donation-form-error-modal-content>
9
- `);
10
- const questionsLink = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.container a');
11
- expect(questionsLink).to.exist;
12
- expect(questionsLink === null || questionsLink === void 0 ? void 0 : questionsLink.innerHTML).to.contain('Questions?');
13
- }));
14
- });
1
+ import { __awaiter } from "tslib";
2
+ import { html, fixture, expect } from '@open-wc/testing';
3
+ import '../../../src/modals/error-modal-content';
4
+ describe('Error Modal Content', () => {
5
+ it('renders a "Questions" link', () => __awaiter(void 0, void 0, void 0, function* () {
6
+ var _a;
7
+ const el = yield fixture(html `
8
+ <donation-form-error-modal-content></donation-form-error-modal-content>
9
+ `);
10
+ const questionsLink = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.container a');
11
+ expect(questionsLink).to.exist;
12
+ expect(questionsLink === null || questionsLink === void 0 ? void 0 : questionsLink.innerHTML).to.contain('Questions?');
13
+ }));
14
+ });
15
15
  //# sourceMappingURL=error-modal-content.test.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"error-modal-content.test.js","sourceRoot":"","sources":["../../../../test/tests/modals/error-modal-content.test.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,yCAAyC,CAAC;AAEjD,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,4BAA4B,EAAE,GAAS,EAAE;;QAC1C,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,IAAI,CAAA;;KAE5B,CAAC,CAAC;QAEH,MAAM,aAAa,SAAG,EAAE,CAAC,UAAU,0CAAE,aAAa,CAAC,cAAc,CAAC,CAAC;QACnE,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC;QAC/B,MAAM,CAAC,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,SAAS,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC5D,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { html, fixture, expect } from '@open-wc/testing';\nimport '../../../src/modals/error-modal-content';\n\ndescribe('Error Modal Content', () => {\n it('renders a \"Questions\" link', async () => {\n const el = await fixture(html`\n <donation-form-error-modal-content></donation-form-error-modal-content>\n `);\n\n const questionsLink = el.shadowRoot?.querySelector('.container a');\n expect(questionsLink).to.exist;\n expect(questionsLink?.innerHTML).to.contain('Questions?');\n });\n});\n"]}
1
+ {"version":3,"file":"error-modal-content.test.js","sourceRoot":"","sources":["../../../../test/tests/modals/error-modal-content.test.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,yCAAyC,CAAC;AAEjD,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,4BAA4B,EAAE,GAAS,EAAE;;QAC1C,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,IAAI,CAAA;;KAE5B,CAAC,CAAC;QAEH,MAAM,aAAa,SAAG,EAAE,CAAC,UAAU,0CAAE,aAAa,CAAC,cAAc,CAAC,CAAC;QACnE,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC;QAC/B,MAAM,CAAC,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,SAAS,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC5D,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { html, fixture, expect } from '@open-wc/testing';\r\nimport '../../../src/modals/error-modal-content';\r\n\r\ndescribe('Error Modal Content', () => {\r\n it('renders a \"Questions\" link', async () => {\r\n const el = await fixture(html`\r\n <donation-form-error-modal-content></donation-form-error-modal-content>\r\n `);\r\n\r\n const questionsLink = el.shadowRoot?.querySelector('.container a');\r\n expect(questionsLink).to.exist;\r\n expect(questionsLink?.innerHTML).to.contain('Questions?');\r\n });\r\n});\r\n"]}
@@ -1 +1 @@
1
- import '../../../src/modals/upsell-modal-content';
1
+ import '../../../src/modals/upsell-modal-content';
@@ -1,164 +1,164 @@
1
- import { __awaiter } from "tslib";
2
- import { html, fixture, expect, oneEvent } from '@open-wc/testing';
3
- import { UpsellModalCTAMode } from '../../../src/modals/upsell-modal-content';
4
- import '../../../src/modals/upsell-modal-content';
5
- import { html as lit2html } from 'lit';
6
- describe('Upsell Modal Content', () => {
7
- describe('UI Actions', () => {
8
- it('shows a no button', () => __awaiter(void 0, void 0, void 0, function* () {
9
- var _a;
10
- const el = (yield fixture(html `
11
- <upsell-modal-content></upsell-modal-content>
12
- `));
13
- const noButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#no-button');
14
- expect(noButton).to.exist;
15
- }));
16
- it('shows the proper yes button for non-paypal types', () => __awaiter(void 0, void 0, void 0, function* () {
17
- var _b, _c;
18
- const el = (yield fixture(html `
19
- <upsell-modal-content .yesButtonMode=${UpsellModalCTAMode.YesButton}></upsell-modal-content>
20
- `));
21
- const yesButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#yes-button');
22
- expect(yesButton).to.exist;
23
- const payPalSlot = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.paypal-upsell-slot-container');
24
- expect(payPalSlot).to.not.exist;
25
- }));
26
- it('shows the paypal upsell slot for paypal upsells', () => __awaiter(void 0, void 0, void 0, function* () {
27
- var _d, _e;
28
- const el = (yield fixture(html `
29
- <upsell-modal-content
30
- .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}
31
- ></upsell-modal-content>
32
- `));
33
- const payPalSlot = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.paypal-upsell-slot-container');
34
- expect(payPalSlot).to.exist;
35
- const yesButton = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('#yes-button');
36
- expect(yesButton).to.not.exist;
37
- }));
38
- });
39
- describe('Events Emitted', () => {
40
- it('emits a `yesSelected` event with the amount when yes is selected', () => __awaiter(void 0, void 0, void 0, function* () {
41
- var _a;
42
- const el = (yield fixture(html `
43
- <upsell-modal-content
44
- .amount=${7.5}
45
- .yesButtonMode=${UpsellModalCTAMode.YesButton}
46
- ></upsell-modal-content>
47
- `));
48
- const yesButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#yes-button');
49
- const clickEvent = new MouseEvent('click');
50
- setTimeout(() => {
51
- yesButton === null || yesButton === void 0 ? void 0 : yesButton.dispatchEvent(clickEvent);
52
- });
53
- const response = yield oneEvent(el, 'yesSelected');
54
- expect(response).to.exist;
55
- expect(response.detail.amount).to.equal(7.5);
56
- }));
57
- it('emits a `noThanksSelected` event when no thanks is selected', () => __awaiter(void 0, void 0, void 0, function* () {
58
- var _b;
59
- const el = (yield fixture(html `
60
- <upsell-modal-content></upsell-modal-content>
61
- `));
62
- const noButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#no-button');
63
- const clickEvent = new MouseEvent('click');
64
- setTimeout(() => {
65
- noButton === null || noButton === void 0 ? void 0 : noButton.dispatchEvent(clickEvent);
66
- });
67
- const response = yield oneEvent(el, 'noThanksSelected');
68
- expect(response).to.exist;
69
- }));
70
- });
71
- describe('Amount Changer', () => {
72
- it('emits an `amountChanged` event with the amount if change successful', () => __awaiter(void 0, void 0, void 0, function* () {
73
- var _a;
74
- const el = (yield fixture(html `
75
- <upsell-modal-content></upsell-modal-content>
76
- `));
77
- const amountInput = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#amount-input');
78
- amountInput.value = '3.50';
79
- const inputEvent = new Event('input');
80
- setTimeout(() => {
81
- amountInput.dispatchEvent(inputEvent);
82
- });
83
- const response = yield oneEvent(el, 'amountChanged');
84
- expect(response).to.exist;
85
- expect(response.detail.amount).to.equal(3.5);
86
- }));
87
- it('nothing happens if the input is empty', () => __awaiter(void 0, void 0, void 0, function* () {
88
- var _b;
89
- const el = (yield fixture(html `
90
- <upsell-modal-content></upsell-modal-content>
91
- `));
92
- const amountInput = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#amount-input');
93
- amountInput.value = '';
94
- const inputEvent = new Event('input');
95
- expect(el.error).to.be.undefined;
96
- amountInput.dispatchEvent(inputEvent);
97
- yield el.updateComplete;
98
- expect(el.error).to.be.undefined;
99
- }));
100
- it('shows an error if the amount isNaN', () => __awaiter(void 0, void 0, void 0, function* () {
101
- var _c, _d;
102
- const el = (yield fixture(html `
103
- <upsell-modal-content></upsell-modal-content>
104
- `));
105
- const amountInput = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('#amount-input');
106
- amountInput.value = 'a';
107
- const inputEvent = new Event('input');
108
- const errorDiv = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.error');
109
- expect(el.error).to.be.undefined;
110
- amountInput.dispatchEvent(inputEvent);
111
- yield el.updateComplete;
112
- expect(el.error).to.not.be.undefined;
113
- expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('Please enter a valid amount.');
114
- }));
115
- it('shows an error if the amount is too low', () => __awaiter(void 0, void 0, void 0, function* () {
116
- var _e, _f;
117
- const el = (yield fixture(html `
118
- <upsell-modal-content></upsell-modal-content>
119
- `));
120
- const amountInput = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('#amount-input');
121
- amountInput.value = '0.99';
122
- const inputEvent = new Event('input');
123
- const errorDiv = (_f = el.shadowRoot) === null || _f === void 0 ? void 0 : _f.querySelector('.error');
124
- expect(el.error).to.be.undefined;
125
- amountInput.dispatchEvent(inputEvent);
126
- yield el.updateComplete;
127
- expect(el.error).to.not.be.undefined;
128
- expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('The minimum donation amount is $1');
129
- }));
130
- it('shows an error if the amount is too high', () => __awaiter(void 0, void 0, void 0, function* () {
131
- var _g, _h;
132
- const el = (yield fixture(html `
133
- <upsell-modal-content></upsell-modal-content>
134
- `));
135
- const amountInput = (_g = el.shadowRoot) === null || _g === void 0 ? void 0 : _g.querySelector('#amount-input');
136
- amountInput.value = '10000';
137
- const inputEvent = new Event('input');
138
- const errorDiv = (_h = el.shadowRoot) === null || _h === void 0 ? void 0 : _h.querySelector('.error');
139
- expect(el.error).to.be.undefined;
140
- amountInput.dispatchEvent(inputEvent);
141
- yield el.updateComplete;
142
- expect(el.error).to.not.be.undefined;
143
- expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('To make a donation of $10,000 or more');
144
- }));
145
- it('shows the paypal blocker if there is an error', () => __awaiter(void 0, void 0, void 0, function* () {
146
- var _j;
147
- const el = (yield fixture(html `
148
- <upsell-modal-content
149
- .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}
150
- ></upsell-modal-content>
151
- `));
152
- const paypalBlocker = (_j = el.shadowRoot) === null || _j === void 0 ? void 0 : _j.querySelector('.paypal-upsell-slot-blocker');
153
- expect(el.error).to.be.undefined;
154
- expect(paypalBlocker.classList.contains('hidden')).to.be.true;
155
- el.error = lit2html `
156
- Some error
157
- `;
158
- yield el.updateComplete;
159
- expect(el.error).to.not.be.undefined;
160
- expect(paypalBlocker.classList.contains('hidden')).to.be.false;
161
- }));
162
- });
163
- });
1
+ import { __awaiter } from "tslib";
2
+ import { html, fixture, expect, oneEvent } from '@open-wc/testing';
3
+ import { UpsellModalCTAMode } from '../../../src/modals/upsell-modal-content';
4
+ import '../../../src/modals/upsell-modal-content';
5
+ import { html as lit2html } from 'lit';
6
+ describe('Upsell Modal Content', () => {
7
+ describe('UI Actions', () => {
8
+ it('shows a no button', () => __awaiter(void 0, void 0, void 0, function* () {
9
+ var _a;
10
+ const el = (yield fixture(html `
11
+ <upsell-modal-content></upsell-modal-content>
12
+ `));
13
+ const noButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#no-button');
14
+ expect(noButton).to.exist;
15
+ }));
16
+ it('shows the proper yes button for non-paypal types', () => __awaiter(void 0, void 0, void 0, function* () {
17
+ var _b, _c;
18
+ const el = (yield fixture(html `
19
+ <upsell-modal-content .yesButtonMode=${UpsellModalCTAMode.YesButton}></upsell-modal-content>
20
+ `));
21
+ const yesButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#yes-button');
22
+ expect(yesButton).to.exist;
23
+ const payPalSlot = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.paypal-upsell-slot-container');
24
+ expect(payPalSlot).to.not.exist;
25
+ }));
26
+ it('shows the paypal upsell slot for paypal upsells', () => __awaiter(void 0, void 0, void 0, function* () {
27
+ var _d, _e;
28
+ const el = (yield fixture(html `
29
+ <upsell-modal-content
30
+ .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}
31
+ ></upsell-modal-content>
32
+ `));
33
+ const payPalSlot = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.paypal-upsell-slot-container');
34
+ expect(payPalSlot).to.exist;
35
+ const yesButton = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('#yes-button');
36
+ expect(yesButton).to.not.exist;
37
+ }));
38
+ });
39
+ describe('Events Emitted', () => {
40
+ it('emits a `yesSelected` event with the amount when yes is selected', () => __awaiter(void 0, void 0, void 0, function* () {
41
+ var _a;
42
+ const el = (yield fixture(html `
43
+ <upsell-modal-content
44
+ .amount=${7.5}
45
+ .yesButtonMode=${UpsellModalCTAMode.YesButton}
46
+ ></upsell-modal-content>
47
+ `));
48
+ const yesButton = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#yes-button');
49
+ const clickEvent = new MouseEvent('click');
50
+ setTimeout(() => {
51
+ yesButton === null || yesButton === void 0 ? void 0 : yesButton.dispatchEvent(clickEvent);
52
+ });
53
+ const response = yield oneEvent(el, 'yesSelected');
54
+ expect(response).to.exist;
55
+ expect(response.detail.amount).to.equal(7.5);
56
+ }));
57
+ it('emits a `noThanksSelected` event when no thanks is selected', () => __awaiter(void 0, void 0, void 0, function* () {
58
+ var _b;
59
+ const el = (yield fixture(html `
60
+ <upsell-modal-content></upsell-modal-content>
61
+ `));
62
+ const noButton = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#no-button');
63
+ const clickEvent = new MouseEvent('click');
64
+ setTimeout(() => {
65
+ noButton === null || noButton === void 0 ? void 0 : noButton.dispatchEvent(clickEvent);
66
+ });
67
+ const response = yield oneEvent(el, 'noThanksSelected');
68
+ expect(response).to.exist;
69
+ }));
70
+ });
71
+ describe('Amount Changer', () => {
72
+ it('emits an `amountChanged` event with the amount if change successful', () => __awaiter(void 0, void 0, void 0, function* () {
73
+ var _a;
74
+ const el = (yield fixture(html `
75
+ <upsell-modal-content></upsell-modal-content>
76
+ `));
77
+ const amountInput = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#amount-input');
78
+ amountInput.value = '3.50';
79
+ const inputEvent = new Event('input');
80
+ setTimeout(() => {
81
+ amountInput.dispatchEvent(inputEvent);
82
+ });
83
+ const response = yield oneEvent(el, 'amountChanged');
84
+ expect(response).to.exist;
85
+ expect(response.detail.amount).to.equal(3.5);
86
+ }));
87
+ it('nothing happens if the input is empty', () => __awaiter(void 0, void 0, void 0, function* () {
88
+ var _b;
89
+ const el = (yield fixture(html `
90
+ <upsell-modal-content></upsell-modal-content>
91
+ `));
92
+ const amountInput = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('#amount-input');
93
+ amountInput.value = '';
94
+ const inputEvent = new Event('input');
95
+ expect(el.error).to.be.undefined;
96
+ amountInput.dispatchEvent(inputEvent);
97
+ yield el.updateComplete;
98
+ expect(el.error).to.be.undefined;
99
+ }));
100
+ it('shows an error if the amount isNaN', () => __awaiter(void 0, void 0, void 0, function* () {
101
+ var _c, _d;
102
+ const el = (yield fixture(html `
103
+ <upsell-modal-content></upsell-modal-content>
104
+ `));
105
+ const amountInput = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('#amount-input');
106
+ amountInput.value = 'a';
107
+ const inputEvent = new Event('input');
108
+ const errorDiv = (_d = el.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.error');
109
+ expect(el.error).to.be.undefined;
110
+ amountInput.dispatchEvent(inputEvent);
111
+ yield el.updateComplete;
112
+ expect(el.error).to.not.be.undefined;
113
+ expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('Please enter a valid amount.');
114
+ }));
115
+ it('shows an error if the amount is too low', () => __awaiter(void 0, void 0, void 0, function* () {
116
+ var _e, _f;
117
+ const el = (yield fixture(html `
118
+ <upsell-modal-content></upsell-modal-content>
119
+ `));
120
+ const amountInput = (_e = el.shadowRoot) === null || _e === void 0 ? void 0 : _e.querySelector('#amount-input');
121
+ amountInput.value = '0.99';
122
+ const inputEvent = new Event('input');
123
+ const errorDiv = (_f = el.shadowRoot) === null || _f === void 0 ? void 0 : _f.querySelector('.error');
124
+ expect(el.error).to.be.undefined;
125
+ amountInput.dispatchEvent(inputEvent);
126
+ yield el.updateComplete;
127
+ expect(el.error).to.not.be.undefined;
128
+ expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('The minimum donation amount is $1');
129
+ }));
130
+ it('shows an error if the amount is too high', () => __awaiter(void 0, void 0, void 0, function* () {
131
+ var _g, _h;
132
+ const el = (yield fixture(html `
133
+ <upsell-modal-content></upsell-modal-content>
134
+ `));
135
+ const amountInput = (_g = el.shadowRoot) === null || _g === void 0 ? void 0 : _g.querySelector('#amount-input');
136
+ amountInput.value = '10000';
137
+ const inputEvent = new Event('input');
138
+ const errorDiv = (_h = el.shadowRoot) === null || _h === void 0 ? void 0 : _h.querySelector('.error');
139
+ expect(el.error).to.be.undefined;
140
+ amountInput.dispatchEvent(inputEvent);
141
+ yield el.updateComplete;
142
+ expect(el.error).to.not.be.undefined;
143
+ expect(errorDiv === null || errorDiv === void 0 ? void 0 : errorDiv.innerHTML).to.contain('To make a donation of $10,000 or more');
144
+ }));
145
+ it('shows the paypal blocker if there is an error', () => __awaiter(void 0, void 0, void 0, function* () {
146
+ var _j;
147
+ const el = (yield fixture(html `
148
+ <upsell-modal-content
149
+ .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}
150
+ ></upsell-modal-content>
151
+ `));
152
+ const paypalBlocker = (_j = el.shadowRoot) === null || _j === void 0 ? void 0 : _j.querySelector('.paypal-upsell-slot-blocker');
153
+ expect(el.error).to.be.undefined;
154
+ expect(paypalBlocker.classList.contains('hidden')).to.be.true;
155
+ el.error = lit2html `
156
+ Some error
157
+ `;
158
+ yield el.updateComplete;
159
+ expect(el.error).to.not.be.undefined;
160
+ expect(paypalBlocker.classList.contains('hidden')).to.be.false;
161
+ }));
162
+ });
163
+ });
164
164
  //# sourceMappingURL=upsell-modal-content.test.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"upsell-modal-content.test.js","sourceRoot":"","sources":["../../../../test/tests/modals/upsell-modal-content.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, fixture, expect, oneEvent } from '@open-wc/testing';\nimport { UpsellModalContent, UpsellModalCTAMode } from '../../../src/modals/upsell-modal-content';\nimport '../../../src/modals/upsell-modal-content';\nimport { html as lit2html } from 'lit';\n\ndescribe('Upsell Modal Content', () => {\n describe('UI Actions', () => {\n it('shows a no button', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const noButton = el.shadowRoot?.querySelector('#no-button');\n expect(noButton).to.exist;\n });\n\n it('shows the proper yes button for non-paypal types', async () => {\n const el = (await fixture(html`\n <upsell-modal-content .yesButtonMode=${UpsellModalCTAMode.YesButton}></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\n expect(yesButton).to.exist;\n const payPalSlot = el.shadowRoot?.querySelector('.paypal-upsell-slot-container');\n expect(payPalSlot).to.not.exist;\n });\n\n it('shows the paypal upsell slot for paypal upsells', async () => {\n const el = (await fixture(html`\n <upsell-modal-content\n .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}\n ></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const payPalSlot = el.shadowRoot?.querySelector('.paypal-upsell-slot-container');\n expect(payPalSlot).to.exist;\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\n expect(yesButton).to.not.exist;\n });\n });\n\n describe('Events Emitted', () => {\n it('emits a `yesSelected` event with the amount when yes is selected', async () => {\n const el = (await fixture(html`\n <upsell-modal-content\n .amount=${7.5}\n .yesButtonMode=${UpsellModalCTAMode.YesButton}\n ></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\n const clickEvent = new MouseEvent('click');\n setTimeout(() => {\n yesButton?.dispatchEvent(clickEvent);\n });\n const response = await oneEvent(el, 'yesSelected');\n expect(response).to.exist;\n expect(response.detail.amount).to.equal(7.5);\n });\n\n it('emits a `noThanksSelected` event when no thanks is selected', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const noButton = el.shadowRoot?.querySelector('#no-button');\n const clickEvent = new MouseEvent('click');\n setTimeout(() => {\n noButton?.dispatchEvent(clickEvent);\n });\n const response = await oneEvent(el, 'noThanksSelected');\n expect(response).to.exist;\n });\n });\n\n describe('Amount Changer', () => {\n it('emits an `amountChanged` event with the amount if change successful', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\n amountInput.value = '3.50';\n const inputEvent = new Event('input');\n setTimeout(() => {\n amountInput.dispatchEvent(inputEvent);\n });\n const response = await oneEvent(el, 'amountChanged');\n expect(response).to.exist;\n expect(response.detail.amount).to.equal(3.5);\n });\n\n it('nothing happens if the input is empty', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\n amountInput.value = '';\n const inputEvent = new Event('input');\n expect(el.error).to.be.undefined;\n amountInput.dispatchEvent(inputEvent);\n await el.updateComplete;\n expect(el.error).to.be.undefined;\n });\n\n it('shows an error if the amount isNaN', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\n amountInput.value = 'a';\n const inputEvent = new Event('input');\n const errorDiv = el.shadowRoot?.querySelector('.error');\n expect(el.error).to.be.undefined;\n amountInput.dispatchEvent(inputEvent);\n await el.updateComplete;\n expect(el.error).to.not.be.undefined;\n expect(errorDiv?.innerHTML).to.contain('Please enter a valid amount.');\n });\n\n it('shows an error if the amount is too low', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\n amountInput.value = '0.99';\n const inputEvent = new Event('input');\n const errorDiv = el.shadowRoot?.querySelector('.error');\n expect(el.error).to.be.undefined;\n amountInput.dispatchEvent(inputEvent);\n await el.updateComplete;\n expect(el.error).to.not.be.undefined;\n expect(errorDiv?.innerHTML).to.contain('The minimum donation amount is $1');\n });\n\n it('shows an error if the amount is too high', async () => {\n const el = (await fixture(html`\n <upsell-modal-content></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\n amountInput.value = '10000';\n const inputEvent = new Event('input');\n const errorDiv = el.shadowRoot?.querySelector('.error');\n expect(el.error).to.be.undefined;\n amountInput.dispatchEvent(inputEvent);\n await el.updateComplete;\n expect(el.error).to.not.be.undefined;\n expect(errorDiv?.innerHTML).to.contain('To make a donation of $10,000 or more');\n });\n\n it('shows the paypal blocker if there is an error', async () => {\n const el = (await fixture(html`\n <upsell-modal-content\n .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}\n ></upsell-modal-content>\n `)) as UpsellModalContent;\n\n const paypalBlocker = el.shadowRoot?.querySelector(\n '.paypal-upsell-slot-blocker',\n ) as HTMLDivElement;\n expect(el.error).to.be.undefined;\n expect(paypalBlocker.classList.contains('hidden')).to.be.true;\n el.error = lit2html`\n Some error\n `;\n await el.updateComplete;\n expect(el.error).to.not.be.undefined;\n expect(paypalBlocker.classList.contains('hidden')).to.be.false;\n });\n });\n});\n"]}
1
+ {"version":3,"file":"upsell-modal-content.test.js","sourceRoot":"","sources":["../../../../test/tests/modals/upsell-modal-content.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, fixture, expect, oneEvent } from '@open-wc/testing';\r\nimport { UpsellModalContent, UpsellModalCTAMode } from '../../../src/modals/upsell-modal-content';\r\nimport '../../../src/modals/upsell-modal-content';\r\nimport { html as lit2html } from 'lit';\r\n\r\ndescribe('Upsell Modal Content', () => {\r\n describe('UI Actions', () => {\r\n it('shows a no button', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const noButton = el.shadowRoot?.querySelector('#no-button');\r\n expect(noButton).to.exist;\r\n });\r\n\r\n it('shows the proper yes button for non-paypal types', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content .yesButtonMode=${UpsellModalCTAMode.YesButton}></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\r\n expect(yesButton).to.exist;\r\n const payPalSlot = el.shadowRoot?.querySelector('.paypal-upsell-slot-container');\r\n expect(payPalSlot).to.not.exist;\r\n });\r\n\r\n it('shows the paypal upsell slot for paypal upsells', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content\r\n .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}\r\n ></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const payPalSlot = el.shadowRoot?.querySelector('.paypal-upsell-slot-container');\r\n expect(payPalSlot).to.exist;\r\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\r\n expect(yesButton).to.not.exist;\r\n });\r\n });\r\n\r\n describe('Events Emitted', () => {\r\n it('emits a `yesSelected` event with the amount when yes is selected', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content\r\n .amount=${7.5}\r\n .yesButtonMode=${UpsellModalCTAMode.YesButton}\r\n ></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const yesButton = el.shadowRoot?.querySelector('#yes-button');\r\n const clickEvent = new MouseEvent('click');\r\n setTimeout(() => {\r\n yesButton?.dispatchEvent(clickEvent);\r\n });\r\n const response = await oneEvent(el, 'yesSelected');\r\n expect(response).to.exist;\r\n expect(response.detail.amount).to.equal(7.5);\r\n });\r\n\r\n it('emits a `noThanksSelected` event when no thanks is selected', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const noButton = el.shadowRoot?.querySelector('#no-button');\r\n const clickEvent = new MouseEvent('click');\r\n setTimeout(() => {\r\n noButton?.dispatchEvent(clickEvent);\r\n });\r\n const response = await oneEvent(el, 'noThanksSelected');\r\n expect(response).to.exist;\r\n });\r\n });\r\n\r\n describe('Amount Changer', () => {\r\n it('emits an `amountChanged` event with the amount if change successful', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\r\n amountInput.value = '3.50';\r\n const inputEvent = new Event('input');\r\n setTimeout(() => {\r\n amountInput.dispatchEvent(inputEvent);\r\n });\r\n const response = await oneEvent(el, 'amountChanged');\r\n expect(response).to.exist;\r\n expect(response.detail.amount).to.equal(3.5);\r\n });\r\n\r\n it('nothing happens if the input is empty', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\r\n amountInput.value = '';\r\n const inputEvent = new Event('input');\r\n expect(el.error).to.be.undefined;\r\n amountInput.dispatchEvent(inputEvent);\r\n await el.updateComplete;\r\n expect(el.error).to.be.undefined;\r\n });\r\n\r\n it('shows an error if the amount isNaN', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\r\n amountInput.value = 'a';\r\n const inputEvent = new Event('input');\r\n const errorDiv = el.shadowRoot?.querySelector('.error');\r\n expect(el.error).to.be.undefined;\r\n amountInput.dispatchEvent(inputEvent);\r\n await el.updateComplete;\r\n expect(el.error).to.not.be.undefined;\r\n expect(errorDiv?.innerHTML).to.contain('Please enter a valid amount.');\r\n });\r\n\r\n it('shows an error if the amount is too low', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\r\n amountInput.value = '0.99';\r\n const inputEvent = new Event('input');\r\n const errorDiv = el.shadowRoot?.querySelector('.error');\r\n expect(el.error).to.be.undefined;\r\n amountInput.dispatchEvent(inputEvent);\r\n await el.updateComplete;\r\n expect(el.error).to.not.be.undefined;\r\n expect(errorDiv?.innerHTML).to.contain('The minimum donation amount is $1');\r\n });\r\n\r\n it('shows an error if the amount is too high', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const amountInput = el.shadowRoot?.querySelector('#amount-input') as HTMLInputElement;\r\n amountInput.value = '10000';\r\n const inputEvent = new Event('input');\r\n const errorDiv = el.shadowRoot?.querySelector('.error');\r\n expect(el.error).to.be.undefined;\r\n amountInput.dispatchEvent(inputEvent);\r\n await el.updateComplete;\r\n expect(el.error).to.not.be.undefined;\r\n expect(errorDiv?.innerHTML).to.contain('To make a donation of $10,000 or more');\r\n });\r\n\r\n it('shows the paypal blocker if there is an error', async () => {\r\n const el = (await fixture(html`\r\n <upsell-modal-content\r\n .yesButtonMode=${UpsellModalCTAMode.PayPalUpsellSlot}\r\n ></upsell-modal-content>\r\n `)) as UpsellModalContent;\r\n\r\n const paypalBlocker = el.shadowRoot?.querySelector(\r\n '.paypal-upsell-slot-blocker',\r\n ) as HTMLDivElement;\r\n expect(el.error).to.be.undefined;\r\n expect(paypalBlocker.classList.contains('hidden')).to.be.true;\r\n el.error = lit2html`\r\n Some error\r\n `;\r\n await el.updateComplete;\r\n expect(el.error).to.not.be.undefined;\r\n expect(paypalBlocker.classList.contains('hidden')).to.be.false;\r\n });\r\n });\r\n});\r\n"]}