@internetarchive/donation-form 1.0.2 → 1.0.3-alpha-webdev7960.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 (210) hide show
  1. package/LICENSE +661 -661
  2. package/README.md +115 -115
  3. package/dist/demo/braintree-endpoint-manager.js.map +1 -1
  4. package/dist/demo/demo-analytics-handler.js.map +1 -1
  5. package/dist/demo/submit-form-with.js.map +1 -1
  6. package/dist/index.js.map +1 -1
  7. package/dist/src/braintree-manager/braintree-interfaces.js.map +1 -1
  8. package/dist/src/braintree-manager/braintree-manager.js.map +1 -1
  9. package/dist/src/braintree-manager/payment-clients.js.map +1 -1
  10. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.js.map +1 -1
  11. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.js.map +1 -1
  12. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.js.map +1 -1
  13. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.js.map +1 -1
  14. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.js.map +1 -1
  15. package/dist/src/braintree-manager/payment-providers/apple-pay/apple-pay.js.map +1 -1
  16. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card-interface.js.map +1 -1
  17. package/dist/src/braintree-manager/payment-providers/credit-card/credit-card.js.map +1 -1
  18. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.js.map +1 -1
  19. package/dist/src/braintree-manager/payment-providers/credit-card/hosted-field-container.js.map +1 -1
  20. package/dist/src/braintree-manager/payment-providers/google-pay-interface.js.map +1 -1
  21. package/dist/src/braintree-manager/payment-providers/google-pay.js.map +1 -1
  22. package/dist/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.js.map +1 -1
  23. package/dist/src/braintree-manager/payment-providers/paypal/paypal-interface.js.map +1 -1
  24. package/dist/src/braintree-manager/payment-providers/paypal/paypal.js.map +1 -1
  25. package/dist/src/braintree-manager/payment-providers/venmo-interface.js.map +1 -1
  26. package/dist/src/braintree-manager/payment-providers/venmo.js.map +1 -1
  27. package/dist/src/braintree-manager/payment-providers-interface.js.map +1 -1
  28. package/dist/src/braintree-manager/payment-providers.js.map +1 -1
  29. package/dist/src/donation-form-controller.js +123 -123
  30. package/dist/src/donation-form-controller.js.map +1 -1
  31. package/dist/src/donation-form-error.js.map +1 -1
  32. package/dist/src/donation-form.js +107 -107
  33. package/dist/src/donation-form.js.map +1 -1
  34. package/dist/src/form-elements/badged-input.js +47 -47
  35. package/dist/src/form-elements/badged-input.js.map +1 -1
  36. package/dist/src/form-elements/contact-form/autocomplete-field-options.js.map +1 -1
  37. package/dist/src/form-elements/contact-form/contact-form.js +157 -157
  38. package/dist/src/form-elements/contact-form/contact-form.js.map +1 -1
  39. package/dist/src/form-elements/contact-form/countries.js.map +1 -1
  40. package/dist/src/form-elements/header/donation-form-header.js +14 -14
  41. package/dist/src/form-elements/header/donation-form-header.js.map +1 -1
  42. package/dist/src/form-elements/header/donation-summary.js +15 -15
  43. package/dist/src/form-elements/header/donation-summary.js.map +1 -1
  44. package/dist/src/form-elements/payment-selector.js +164 -164
  45. package/dist/src/form-elements/payment-selector.js.map +1 -1
  46. package/dist/src/form-elements/total-amount.js +16 -16
  47. package/dist/src/form-elements/total-amount.js.map +1 -1
  48. package/dist/src/modals/confirm-donation-modal-content.js +51 -51
  49. package/dist/src/modals/confirm-donation-modal-content.js.map +1 -1
  50. package/dist/src/modals/error-modal-content.js +22 -22
  51. package/dist/src/modals/error-modal-content.js.map +1 -1
  52. package/dist/src/modals/upsell-modal-content.js +182 -182
  53. package/dist/src/modals/upsell-modal-content.js.map +1 -1
  54. package/dist/src/payment-flow-handlers/donation-flow-modal-manager.js +20 -20
  55. package/dist/src/payment-flow-handlers/donation-flow-modal-manager.js.map +1 -1
  56. package/dist/src/payment-flow-handlers/handlers/applepay-flow-handler.js.map +1 -1
  57. package/dist/src/payment-flow-handlers/handlers/creditcard-flow-handler.js.map +1 -1
  58. package/dist/src/payment-flow-handlers/handlers/googlepay-flow-handler.js.map +1 -1
  59. package/dist/src/payment-flow-handlers/handlers/paypal-flow-handler.js.map +1 -1
  60. package/dist/src/payment-flow-handlers/handlers/venmo-flow-handler.js.map +1 -1
  61. package/dist/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.js.map +1 -1
  62. package/dist/src/payment-flow-handlers/payment-flow-handlers.js.map +1 -1
  63. package/dist/src/recaptcha-manager/recaptcha-manager.js.map +1 -1
  64. package/dist/src/util/promisedSleep.js.map +1 -1
  65. package/dist/test/helpers/fillInContactForm.js.map +1 -1
  66. package/dist/test/mocks/flow-handlers/individual-handlers/mock-applepay-flow-handler.js.map +1 -1
  67. package/dist/test/mocks/flow-handlers/individual-handlers/mock-creditcard-flow-handler.js.map +1 -1
  68. package/dist/test/mocks/flow-handlers/individual-handlers/mock-googlepay-flow-handler.js.map +1 -1
  69. package/dist/test/mocks/flow-handlers/individual-handlers/mock-paypal-flow-handler.js.map +1 -1
  70. package/dist/test/mocks/flow-handlers/individual-handlers/mock-venmo-flow-handler.js.map +1 -1
  71. package/dist/test/mocks/flow-handlers/mock-payment-flow-handlers.js.map +1 -1
  72. package/dist/test/mocks/mock-braintree-manager.js.map +1 -1
  73. package/dist/test/mocks/mock-donation-info.js.map +1 -1
  74. package/dist/test/mocks/mock-endpoint-manager.js.map +1 -1
  75. package/dist/test/mocks/mock-hosted-fields-config.js.map +1 -1
  76. package/dist/test/mocks/mock-hosted-fields-container.js.map +1 -1
  77. package/dist/test/mocks/mock-lazy-loader.js.map +1 -1
  78. package/dist/test/mocks/mock-modal-manager.js.map +1 -1
  79. package/dist/test/mocks/mock-payment-clients.js.map +1 -1
  80. package/dist/test/mocks/mock-paypal-button-renderer.js.map +1 -1
  81. package/dist/test/mocks/mock-recaptcha-manager.js.map +1 -1
  82. package/dist/test/mocks/models/mock-billing-info.js.map +1 -1
  83. package/dist/test/mocks/models/mock-custom-fields.js.map +1 -1
  84. package/dist/test/mocks/models/mock-customer-info.js.map +1 -1
  85. package/dist/test/mocks/models/mock-donation-request.js.map +1 -1
  86. package/dist/test/mocks/models/mock-success-response.js.map +1 -1
  87. package/dist/test/mocks/payment-clients/mock-applepay-client.js.map +1 -1
  88. package/dist/test/mocks/payment-clients/mock-applepay-payment.js.map +1 -1
  89. package/dist/test/mocks/payment-clients/mock-applepay-paymentauthorizedevent.js.map +1 -1
  90. package/dist/test/mocks/payment-clients/mock-applepay-session.js.map +1 -1
  91. package/dist/test/mocks/payment-clients/mock-applepay-sessionmanager.js.map +1 -1
  92. package/dist/test/mocks/payment-clients/mock-applepay-validatemerchantevent.js.map +1 -1
  93. package/dist/test/mocks/payment-clients/mock-braintree-client.js.map +1 -1
  94. package/dist/test/mocks/payment-clients/mock-data-collector.js.map +1 -1
  95. package/dist/test/mocks/payment-clients/mock-googlepay-client.js.map +1 -1
  96. package/dist/test/mocks/payment-clients/mock-googlepay-library.js.map +1 -1
  97. package/dist/test/mocks/payment-clients/mock-grecaptcha.js.map +1 -1
  98. package/dist/test/mocks/payment-clients/mock-hostedfields-client.js.map +1 -1
  99. package/dist/test/mocks/payment-clients/mock-hostedfieldstateobject-generator.js.map +1 -1
  100. package/dist/test/mocks/payment-clients/mock-hostedfieldtokenizepayload.js.map +1 -1
  101. package/dist/test/mocks/payment-clients/mock-paypal-client.js.map +1 -1
  102. package/dist/test/mocks/payment-clients/mock-paypal-library.js.map +1 -1
  103. package/dist/test/mocks/payment-clients/mock-venmo-client.js.map +1 -1
  104. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-datasource-delegate.js.map +1 -1
  105. package/dist/test/mocks/payment-providers/individual-providers/mock-applepay-handler.js.map +1 -1
  106. package/dist/test/mocks/payment-providers/individual-providers/mock-creditcard-handler.js.map +1 -1
  107. package/dist/test/mocks/payment-providers/individual-providers/mock-googlepay-handler.js.map +1 -1
  108. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource-delegate.js.map +1 -1
  109. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-button-datasource.js.map +1 -1
  110. package/dist/test/mocks/payment-providers/individual-providers/mock-paypal-handler.js.map +1 -1
  111. package/dist/test/mocks/payment-providers/individual-providers/mock-venmo-handler.js.map +1 -1
  112. package/dist/test/mocks/payment-providers/mock-payment-providers.js.map +1 -1
  113. package/dist/test/tests/braintree-manager.test.js.map +1 -1
  114. package/dist/test/tests/donation-form-controller.test.js +39 -39
  115. package/dist/test/tests/donation-form-controller.test.js.map +1 -1
  116. package/dist/test/tests/donation-form.test.js +4 -4
  117. package/dist/test/tests/donation-form.test.js.map +1 -1
  118. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js +14 -14
  119. package/dist/test/tests/flow-handlers/donation-flow-modal-manager.test.js.map +1 -1
  120. package/dist/test/tests/form-elements/donation-summary.test.js.map +1 -1
  121. package/dist/test/tests/form-elements/payment-selector.test.js.map +1 -1
  122. package/dist/test/tests/modals/error-modal-content.test.js +2 -2
  123. package/dist/test/tests/modals/error-modal-content.test.js.map +1 -1
  124. package/dist/test/tests/modals/upsell-modal-content.test.js +31 -31
  125. package/dist/test/tests/modals/upsell-modal-content.test.js.map +1 -1
  126. package/dist/test/tests/models/donation-payment-info.test.js.map +1 -1
  127. package/dist/test/tests/payment-clients.test.js.map +1 -1
  128. package/dist/test/tests/payment-providers/applepay-sessiondatasource.test.js.map +1 -1
  129. package/dist/test/tests/payment-providers/applepay-sessionmanager.test.js.map +1 -1
  130. package/dist/test/tests/payment-providers/applepay.test.js.map +1 -1
  131. package/dist/test/tests/payment-providers/creditcard.test.js.map +1 -1
  132. package/dist/test/tests/payment-providers/googlepay.test.js.map +1 -1
  133. package/dist/test/tests/payment-providers/payment-providers.test.js.map +1 -1
  134. package/dist/test/tests/payment-providers/paypal-button-datasource.test.js.map +1 -1
  135. package/dist/test/tests/payment-providers/paypal.test.js.map +1 -1
  136. package/dist/test/tests/payment-providers/venmo.test.js.map +1 -1
  137. package/dist/test/tests/recaptcha-manager.test.js.map +1 -1
  138. package/package.json +107 -107
  139. package/src/@types/analytics-handler/index.d.ts +8 -8
  140. package/src/@types/braintree-web/LICENSE +21 -21
  141. package/src/@types/braintree-web/index.d.ts +93 -93
  142. package/src/@types/braintree-web/modules/american-express.d.ts +50 -50
  143. package/src/@types/braintree-web/modules/apple-pay.d.ts +213 -213
  144. package/src/@types/braintree-web/modules/client.d.ts +103 -103
  145. package/src/@types/braintree-web/modules/core.d.ts +34 -34
  146. package/src/@types/braintree-web/modules/data-collector.d.ts +13 -13
  147. package/src/@types/braintree-web/modules/google-payment.d.ts +269 -269
  148. package/src/@types/braintree-web/modules/hosted-fields.d.ts +366 -366
  149. package/src/@types/braintree-web/modules/paypal-checkout.d.ts +262 -262
  150. package/src/@types/braintree-web/modules/paypal.d.ts +177 -177
  151. package/src/@types/braintree-web/modules/three-d-secure.d.ts +141 -141
  152. package/src/@types/braintree-web/modules/unionpay.d.ts +224 -224
  153. package/src/@types/braintree-web/modules/us-bank-account.d.ts +81 -81
  154. package/src/@types/braintree-web/modules/venmo.d.ts +110 -110
  155. package/src/@types/braintree-web/package.json +64 -64
  156. package/src/@types/paypal-checkout-components/LICENSE +21 -21
  157. package/src/@types/paypal-checkout-components/index.d.ts +67 -67
  158. package/src/@types/paypal-checkout-components/modules/button.d.ts +50 -50
  159. package/src/@types/paypal-checkout-components/modules/callback-data.d.ts +244 -244
  160. package/src/@types/paypal-checkout-components/modules/configuration.d.ts +114 -114
  161. package/src/@types/paypal-checkout-components/package.json +58 -58
  162. package/src/braintree-manager/braintree-interfaces.ts +172 -172
  163. package/src/braintree-manager/braintree-manager.ts +281 -281
  164. package/src/braintree-manager/payment-clients.ts +146 -146
  165. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-interface.ts +13 -13
  166. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-delegate.ts +8 -8
  167. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource-interface.ts +10 -10
  168. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-datasource.ts +119 -119
  169. package/src/braintree-manager/payment-providers/apple-pay/apple-pay-session-manager.ts +21 -21
  170. package/src/braintree-manager/payment-providers/apple-pay/apple-pay.ts +97 -97
  171. package/src/braintree-manager/payment-providers/credit-card/credit-card-interface.ts +21 -21
  172. package/src/braintree-manager/payment-providers/credit-card/credit-card.ts +130 -130
  173. package/src/braintree-manager/payment-providers/credit-card/hosted-field-configuration.ts +19 -19
  174. package/src/braintree-manager/payment-providers/credit-card/hosted-field-container.ts +85 -85
  175. package/src/braintree-manager/payment-providers/google-pay-interface.ts +8 -8
  176. package/src/braintree-manager/payment-providers/google-pay.ts +59 -59
  177. package/src/braintree-manager/payment-providers/paypal/paypal-button-datasource.ts +218 -218
  178. package/src/braintree-manager/payment-providers/paypal/paypal-interface.ts +13 -13
  179. package/src/braintree-manager/payment-providers/paypal/paypal.ts +78 -78
  180. package/src/braintree-manager/payment-providers/venmo-interface.ts +8 -8
  181. package/src/braintree-manager/payment-providers/venmo.ts +67 -67
  182. package/src/braintree-manager/payment-providers-interface.ts +25 -25
  183. package/src/braintree-manager/payment-providers.ts +147 -147
  184. package/src/donation-form-controller.ts +623 -623
  185. package/src/donation-form-error.ts +6 -6
  186. package/src/donation-form.ts +576 -576
  187. package/src/form-elements/badged-input.ts +109 -109
  188. package/src/form-elements/contact-form/autocomplete-field-options.ts +63 -63
  189. package/src/form-elements/contact-form/contact-form.ts +434 -434
  190. package/src/form-elements/contact-form/countries.ts +252 -252
  191. package/src/form-elements/header/donation-form-header.ts +98 -98
  192. package/src/form-elements/header/donation-summary.ts +61 -61
  193. package/src/form-elements/payment-selector.ts +365 -365
  194. package/src/form-elements/total-amount.ts +46 -46
  195. package/src/modals/confirm-donation-modal-content.ts +168 -168
  196. package/src/modals/error-modal-content.ts +48 -48
  197. package/src/modals/upsell-modal-content.ts +284 -284
  198. package/src/payment-flow-handlers/donation-flow-modal-manager.ts +439 -439
  199. package/src/payment-flow-handlers/handlers/applepay-flow-handler.ts +109 -109
  200. package/src/payment-flow-handlers/handlers/creditcard-flow-handler.ts +232 -232
  201. package/src/payment-flow-handlers/handlers/googlepay-flow-handler.ts +111 -111
  202. package/src/payment-flow-handlers/handlers/paypal-flow-handler.ts +331 -331
  203. package/src/payment-flow-handlers/handlers/venmo-flow-handler.ts +119 -119
  204. package/src/payment-flow-handlers/handlers/venmo-restoration-state-handler.ts +127 -127
  205. package/src/payment-flow-handlers/payment-flow-handlers.ts +218 -218
  206. package/src/recaptcha-manager/recaptcha-manager.ts +123 -123
  207. package/src/util/promisedSleep.ts +3 -3
  208. package/dist/demo/app-root.d.ts +0 -0
  209. package/dist/demo/app-root.js +0 -2
  210. package/dist/demo/app-root.js.map +0 -1
@@ -1,262 +1,262 @@
1
- import { callback } from './core';
2
- import { Client } from './client';
3
-
4
- export interface PayPalCheckoutCreatePaymentOptions {
5
- flow: paypal.FlowType;
6
- intent?: paypal.Intent;
7
- offerCredit?: boolean;
8
- amount?: string | number;
9
- currency?: string;
10
- displayName?: string;
11
- locale?: string;
12
- vaultInitiatedCheckoutPaymentMethodToken?: string;
13
- shippingOptions?: paypal.ShippingOption[];
14
- enableShippingAddress?: boolean;
15
- shippingAddressOverride?: paypal.Address;
16
- shippingAddressEditable?: boolean;
17
- billingAgreementDescription?: string;
18
- landingPageType?: string;
19
- lineItems?: paypal.LineItem[];
20
- }
21
-
22
- export interface PayPalCheckoutTokenizationOptions {
23
- payerId: string;
24
- paymentId?: string;
25
- billingToken?: string;
26
- vault?: boolean;
27
- }
28
-
29
- export interface PayPalCheckout {
30
- /**
31
- * @description There are two ways to integrate the PayPal Checkout component.
32
- * See the [PayPal Checkout constructor documentation](PayPalCheckout.html#PayPalCheckout) for more information and examples.
33
- * @example
34
- * braintree.client.create({
35
- * authorization: 'authorization'
36
- * }).then(function (clientInstance) {
37
- * return braintree.paypalCheckout.create({
38
- * client: clientInstance
39
- * });
40
- * }).then(function (paypalCheckoutInstance) {
41
- * // set up checkout.js
42
- * }).catch(function (err) {
43
- * console.error('Error!', err);
44
- * });
45
- */
46
- create(options: {
47
- client?: Client;
48
- authorization?: string;
49
- merchantAccountId?: string;
50
- }): Promise<PayPalCheckout>;
51
- create(
52
- options: { client?: Client; authorization?: string; merchantAccountId?: string },
53
- callback?: callback,
54
- ): void;
55
-
56
- /**
57
- * @description The current version of the SDK, i.e. `3.0.2`.
58
- */
59
- VERSION: string;
60
-
61
- /**
62
- * Creates a PayPal payment ID or billing token using the given options. This is meant to be passed to PayPal's checkout.js library.
63
- * When a {@link callback} is defined, the function returns undefined and invokes the callback with the id to be used with the checkout.js
64
- * library. Otherwise, it returns a Promise that resolves with the id.
65
- * `authorize` - Submits the transaction for authorization but not settlement.
66
- * `order` - Validates the transaction without an authorization (i.e. without holding funds).
67
- * Useful for authorizing and capturing funds up to 90 days after the order has been placed. Only available for Checkout flow.
68
- * `capture` - Payment will be immediately submitted for settlement upon creating a transaction.
69
- * `sale` can be used as an alias for this value.
70
- * Supported locales are:
71
- * `da_DK`,
72
- * `de_DE`,
73
- * `en_AU`,
74
- * `en_GB`,
75
- * `en_US`,
76
- * `es_ES`,
77
- * `fr_CA`,
78
- * `fr_FR`,
79
- * `id_ID`,
80
- * `it_IT`,
81
- * `ja_JP`,
82
- * `ko_KR`,
83
- * `nl_NL`,
84
- * `no_NO`,
85
- * `pl_PL`,
86
- * `pt_BR`,
87
- * `pt_PT`,
88
- * `ru_RU`,
89
- * `sv_SE`,
90
- * `th_TH`,
91
- * `zh_CN`,
92
- * `zh_HK`,
93
- * and `zh_TW`.
94
- * * * `login` - A PayPal account login page is used.
95
- * * `billing` - A non-PayPal account landing page is used.
96
- * // this paypal object is created by checkout.js
97
- * // see https://github.com/paypal/paypal-checkout
98
- * paypal.Buttons({
99
- * createOrder: function () {
100
- * // when createPayment resolves, it is automatically passed to checkout.js
101
- * return paypalCheckoutInstance.createPayment({
102
- * flow: 'checkout',
103
- * amount: '10.00',
104
- * currency: 'USD',
105
- * intent: 'capture' // this value must either be `capture` or match the intent passed into the PayPal SDK intent query parameter
106
- * });
107
- * },
108
- * // Add other options, e.g. onApproved, onCancel, onError
109
- * }).render('#paypal-button');
110
- *
111
- * @example
112
- * // shippingOptions are passed to createPayment. You can review the result from onAuthorize to determine which shipping option id was selected.
113
- * ```javascript
114
- * braintree.client.create({
115
- * authorization: 'authorization'
116
- * }).then(function (clientInstance) {
117
- * return braintree.paypalCheckout.create({
118
- * client: clientInstance
119
- * });
120
- * }).then(function (paypalCheckoutInstance) {
121
- * return paypal.Button.render({
122
- * env: 'production'
123
- *
124
- * payment: function () {
125
- * return paypalCheckoutInstance.createPayment({
126
- * flow: 'checkout',
127
- * amount: '10.00',
128
- * currency: 'USD',
129
- * shippingOptions: [
130
- * {
131
- * id: 'UUID-9',
132
- * type: 'PICKUP',
133
- * label: 'Store Location Five',
134
- * selected: true,
135
- * amount: {
136
- * value: '1.00',
137
- * currency: 'USD'
138
- * }
139
- * },
140
- * {
141
- * id: 'shipping-speed-fast',
142
- * type: 'SHIPPING',
143
- * label: 'Fast Shipping',
144
- * selected: false,
145
- * amount: {
146
- * value: '1.00',
147
- * currency: 'USD'
148
- * }
149
- * },
150
- * {
151
- * id: 'shipping-speed-slow',
152
- * type: 'SHIPPING',
153
- * label: 'Slow Shipping',
154
- * selected: false,
155
- * amount: {
156
- * value: '1.00',
157
- * currency: 'USD'
158
- * }
159
- * }
160
- * ]
161
- * });
162
- * },
163
- *
164
- * onAuthorize: function (data, actions) {
165
- * return paypalCheckoutInstance.tokenizePayment(data).then(function (payload) {
166
- * // Submit payload.nonce to your server
167
- * });
168
- * }
169
- * }, '#paypal-button');
170
- * }).catch(function (err) {
171
- * console.error('Error!', err);
172
- * });
173
- * ```
174
- *
175
- */
176
- createPayment(options: PayPalCheckoutCreatePaymentOptions, callback?: callback): Promise<string>;
177
-
178
- /**
179
- * Tokenizes the authorize data from PayPal's checkout.js library when completing a buyer approval flow.
180
- * When a {@link callback} is defined, invokes the callback with {@link PayPalCheckout~tokenizePayload|tokenizePayload} and returns undefined.
181
- * Otherwise, returns a Promise that resolves with a {@link PayPalCheckout~tokenizePayload|tokenizePayload}.
182
- * @example <caption>Opt out of auto-vaulting behavior</caption>
183
- * // create the paypalCheckoutInstance with a client token generated with a customer id
184
- * paypal.Buttons({
185
- * createBillingAgreement: function () {
186
- * return paypalCheckoutInstance.createPayment({
187
- * flow: 'vault'
188
- * // your other createPayment options here
189
- * });
190
- * },
191
- * onApproved: function (data) {
192
- * data.vault = false;
193
- *
194
- * return paypalCheckoutInstance.tokenizePayment(data);
195
- * },
196
- * // Add other options, e.g. onCancel, onError
197
- * }).render('#paypal-button');
198
- *
199
- */
200
- tokenizePayment(
201
- tokenizeOptions: PayPalCheckoutTokenizationOptions,
202
- ): Promise<paypal.TokenizePayload>;
203
- tokenizePayment(tokenizeOptions: PayPalCheckoutTokenizationOptions, callback?: callback): void;
204
-
205
- /**
206
- * Resolves with the PayPal client id to be used when loading the PayPal SDK. * @example
207
- * paypalCheckoutInstance.getClientId().then(function (id) {
208
- * var script = document.createElement('script');
209
- *
210
- * script.src = 'https://www.paypal.com/sdk/js?client-id=' + id;
211
- * script.onload = function () {
212
- * // setup the PayPal SDK
213
- * };
214
- *
215
- * document.body.appendChild(script);
216
- * });
217
- */
218
- getClientId(): Promise<string>;
219
- getClientId(callback: (id: string) => void): void;
220
-
221
- /**
222
- * Initializes the PayPal checkout flow with a payment method nonce that represents a vaulted PayPal account.
223
- * When a {@link callback} is defined, the function returns undefined and invokes the callback with the id to be used with the checkout.js library.
224
- * Otherwise, it returns a Promise that resolves with the id.
225
- * `flow` cannot be set (will always be `'checkout'`)
226
- * `amount`, `currency`, and `vaultInitiatedCheckoutPaymentMethodToken` are required instead of optional
227
- * * Additional configuration is available (listed below)
228
- * @example
229
- * paypalCheckoutInstance.startVaultInitiatedCheckout({
230
- * vaultInitiatedCheckoutPaymentMethodToken: 'nonce-that-represents-a-vaulted-paypal-account',
231
- * amount: '10.00',
232
- * currency: 'USD'
233
- * }).then(function (payload) {
234
- * // send payload.nonce to your server
235
- * }).catch(function (err) {
236
- * if (err.code === 'PAYPAL_POPUP_CLOSED') {
237
- * // indicates that customer canceled by
238
- * // manually closing the PayPal popup
239
- * }
240
- *
241
- * // handle other errors
242
- * });
243
- *
244
- */
245
- startVaultInitiatedCheckout(options: { optOutOfModalBackdrop: boolean }): Promise<void>;
246
- startVaultInitiatedCheckout(
247
- options: { optOutOfModalBackdrop: boolean },
248
- callback: callback,
249
- ): void;
250
-
251
- /**
252
- * Cleanly tear down anything set up by {@link module:braintree-web/paypal-checkout.create|create}.
253
- * @example
254
- * paypalCheckoutInstance.teardown();
255
- * @example <caption>With callback</caption>
256
- * paypalCheckoutInstance.teardown(function () {
257
- * // teardown is complete
258
- * });
259
- */
260
- teardown(callback: () => void): void;
261
- teardown(): Promise<void>;
262
- }
1
+ import { callback } from './core';
2
+ import { Client } from './client';
3
+
4
+ export interface PayPalCheckoutCreatePaymentOptions {
5
+ flow: paypal.FlowType;
6
+ intent?: paypal.Intent;
7
+ offerCredit?: boolean;
8
+ amount?: string | number;
9
+ currency?: string;
10
+ displayName?: string;
11
+ locale?: string;
12
+ vaultInitiatedCheckoutPaymentMethodToken?: string;
13
+ shippingOptions?: paypal.ShippingOption[];
14
+ enableShippingAddress?: boolean;
15
+ shippingAddressOverride?: paypal.Address;
16
+ shippingAddressEditable?: boolean;
17
+ billingAgreementDescription?: string;
18
+ landingPageType?: string;
19
+ lineItems?: paypal.LineItem[];
20
+ }
21
+
22
+ export interface PayPalCheckoutTokenizationOptions {
23
+ payerId: string;
24
+ paymentId?: string;
25
+ billingToken?: string;
26
+ vault?: boolean;
27
+ }
28
+
29
+ export interface PayPalCheckout {
30
+ /**
31
+ * @description There are two ways to integrate the PayPal Checkout component.
32
+ * See the [PayPal Checkout constructor documentation](PayPalCheckout.html#PayPalCheckout) for more information and examples.
33
+ * @example
34
+ * braintree.client.create({
35
+ * authorization: 'authorization'
36
+ * }).then(function (clientInstance) {
37
+ * return braintree.paypalCheckout.create({
38
+ * client: clientInstance
39
+ * });
40
+ * }).then(function (paypalCheckoutInstance) {
41
+ * // set up checkout.js
42
+ * }).catch(function (err) {
43
+ * console.error('Error!', err);
44
+ * });
45
+ */
46
+ create(options: {
47
+ client?: Client;
48
+ authorization?: string;
49
+ merchantAccountId?: string;
50
+ }): Promise<PayPalCheckout>;
51
+ create(
52
+ options: { client?: Client; authorization?: string; merchantAccountId?: string },
53
+ callback?: callback,
54
+ ): void;
55
+
56
+ /**
57
+ * @description The current version of the SDK, i.e. `3.0.2`.
58
+ */
59
+ VERSION: string;
60
+
61
+ /**
62
+ * Creates a PayPal payment ID or billing token using the given options. This is meant to be passed to PayPal's checkout.js library.
63
+ * When a {@link callback} is defined, the function returns undefined and invokes the callback with the id to be used with the checkout.js
64
+ * library. Otherwise, it returns a Promise that resolves with the id.
65
+ * `authorize` - Submits the transaction for authorization but not settlement.
66
+ * `order` - Validates the transaction without an authorization (i.e. without holding funds).
67
+ * Useful for authorizing and capturing funds up to 90 days after the order has been placed. Only available for Checkout flow.
68
+ * `capture` - Payment will be immediately submitted for settlement upon creating a transaction.
69
+ * `sale` can be used as an alias for this value.
70
+ * Supported locales are:
71
+ * `da_DK`,
72
+ * `de_DE`,
73
+ * `en_AU`,
74
+ * `en_GB`,
75
+ * `en_US`,
76
+ * `es_ES`,
77
+ * `fr_CA`,
78
+ * `fr_FR`,
79
+ * `id_ID`,
80
+ * `it_IT`,
81
+ * `ja_JP`,
82
+ * `ko_KR`,
83
+ * `nl_NL`,
84
+ * `no_NO`,
85
+ * `pl_PL`,
86
+ * `pt_BR`,
87
+ * `pt_PT`,
88
+ * `ru_RU`,
89
+ * `sv_SE`,
90
+ * `th_TH`,
91
+ * `zh_CN`,
92
+ * `zh_HK`,
93
+ * and `zh_TW`.
94
+ * * * `login` - A PayPal account login page is used.
95
+ * * `billing` - A non-PayPal account landing page is used.
96
+ * // this paypal object is created by checkout.js
97
+ * // see https://github.com/paypal/paypal-checkout
98
+ * paypal.Buttons({
99
+ * createOrder: function () {
100
+ * // when createPayment resolves, it is automatically passed to checkout.js
101
+ * return paypalCheckoutInstance.createPayment({
102
+ * flow: 'checkout',
103
+ * amount: '10.00',
104
+ * currency: 'USD',
105
+ * intent: 'capture' // this value must either be `capture` or match the intent passed into the PayPal SDK intent query parameter
106
+ * });
107
+ * },
108
+ * // Add other options, e.g. onApproved, onCancel, onError
109
+ * }).render('#paypal-button');
110
+ *
111
+ * @example
112
+ * // shippingOptions are passed to createPayment. You can review the result from onAuthorize to determine which shipping option id was selected.
113
+ * ```javascript
114
+ * braintree.client.create({
115
+ * authorization: 'authorization'
116
+ * }).then(function (clientInstance) {
117
+ * return braintree.paypalCheckout.create({
118
+ * client: clientInstance
119
+ * });
120
+ * }).then(function (paypalCheckoutInstance) {
121
+ * return paypal.Button.render({
122
+ * env: 'production'
123
+ *
124
+ * payment: function () {
125
+ * return paypalCheckoutInstance.createPayment({
126
+ * flow: 'checkout',
127
+ * amount: '10.00',
128
+ * currency: 'USD',
129
+ * shippingOptions: [
130
+ * {
131
+ * id: 'UUID-9',
132
+ * type: 'PICKUP',
133
+ * label: 'Store Location Five',
134
+ * selected: true,
135
+ * amount: {
136
+ * value: '1.00',
137
+ * currency: 'USD'
138
+ * }
139
+ * },
140
+ * {
141
+ * id: 'shipping-speed-fast',
142
+ * type: 'SHIPPING',
143
+ * label: 'Fast Shipping',
144
+ * selected: false,
145
+ * amount: {
146
+ * value: '1.00',
147
+ * currency: 'USD'
148
+ * }
149
+ * },
150
+ * {
151
+ * id: 'shipping-speed-slow',
152
+ * type: 'SHIPPING',
153
+ * label: 'Slow Shipping',
154
+ * selected: false,
155
+ * amount: {
156
+ * value: '1.00',
157
+ * currency: 'USD'
158
+ * }
159
+ * }
160
+ * ]
161
+ * });
162
+ * },
163
+ *
164
+ * onAuthorize: function (data, actions) {
165
+ * return paypalCheckoutInstance.tokenizePayment(data).then(function (payload) {
166
+ * // Submit payload.nonce to your server
167
+ * });
168
+ * }
169
+ * }, '#paypal-button');
170
+ * }).catch(function (err) {
171
+ * console.error('Error!', err);
172
+ * });
173
+ * ```
174
+ *
175
+ */
176
+ createPayment(options: PayPalCheckoutCreatePaymentOptions, callback?: callback): Promise<string>;
177
+
178
+ /**
179
+ * Tokenizes the authorize data from PayPal's checkout.js library when completing a buyer approval flow.
180
+ * When a {@link callback} is defined, invokes the callback with {@link PayPalCheckout~tokenizePayload|tokenizePayload} and returns undefined.
181
+ * Otherwise, returns a Promise that resolves with a {@link PayPalCheckout~tokenizePayload|tokenizePayload}.
182
+ * @example <caption>Opt out of auto-vaulting behavior</caption>
183
+ * // create the paypalCheckoutInstance with a client token generated with a customer id
184
+ * paypal.Buttons({
185
+ * createBillingAgreement: function () {
186
+ * return paypalCheckoutInstance.createPayment({
187
+ * flow: 'vault'
188
+ * // your other createPayment options here
189
+ * });
190
+ * },
191
+ * onApproved: function (data) {
192
+ * data.vault = false;
193
+ *
194
+ * return paypalCheckoutInstance.tokenizePayment(data);
195
+ * },
196
+ * // Add other options, e.g. onCancel, onError
197
+ * }).render('#paypal-button');
198
+ *
199
+ */
200
+ tokenizePayment(
201
+ tokenizeOptions: PayPalCheckoutTokenizationOptions,
202
+ ): Promise<paypal.TokenizePayload>;
203
+ tokenizePayment(tokenizeOptions: PayPalCheckoutTokenizationOptions, callback?: callback): void;
204
+
205
+ /**
206
+ * Resolves with the PayPal client id to be used when loading the PayPal SDK. * @example
207
+ * paypalCheckoutInstance.getClientId().then(function (id) {
208
+ * var script = document.createElement('script');
209
+ *
210
+ * script.src = 'https://www.paypal.com/sdk/js?client-id=' + id;
211
+ * script.onload = function () {
212
+ * // setup the PayPal SDK
213
+ * };
214
+ *
215
+ * document.body.appendChild(script);
216
+ * });
217
+ */
218
+ getClientId(): Promise<string>;
219
+ getClientId(callback: (id: string) => void): void;
220
+
221
+ /**
222
+ * Initializes the PayPal checkout flow with a payment method nonce that represents a vaulted PayPal account.
223
+ * When a {@link callback} is defined, the function returns undefined and invokes the callback with the id to be used with the checkout.js library.
224
+ * Otherwise, it returns a Promise that resolves with the id.
225
+ * `flow` cannot be set (will always be `'checkout'`)
226
+ * `amount`, `currency`, and `vaultInitiatedCheckoutPaymentMethodToken` are required instead of optional
227
+ * * Additional configuration is available (listed below)
228
+ * @example
229
+ * paypalCheckoutInstance.startVaultInitiatedCheckout({
230
+ * vaultInitiatedCheckoutPaymentMethodToken: 'nonce-that-represents-a-vaulted-paypal-account',
231
+ * amount: '10.00',
232
+ * currency: 'USD'
233
+ * }).then(function (payload) {
234
+ * // send payload.nonce to your server
235
+ * }).catch(function (err) {
236
+ * if (err.code === 'PAYPAL_POPUP_CLOSED') {
237
+ * // indicates that customer canceled by
238
+ * // manually closing the PayPal popup
239
+ * }
240
+ *
241
+ * // handle other errors
242
+ * });
243
+ *
244
+ */
245
+ startVaultInitiatedCheckout(options: { optOutOfModalBackdrop: boolean }): Promise<void>;
246
+ startVaultInitiatedCheckout(
247
+ options: { optOutOfModalBackdrop: boolean },
248
+ callback: callback,
249
+ ): void;
250
+
251
+ /**
252
+ * Cleanly tear down anything set up by {@link module:braintree-web/paypal-checkout.create|create}.
253
+ * @example
254
+ * paypalCheckoutInstance.teardown();
255
+ * @example <caption>With callback</caption>
256
+ * paypalCheckoutInstance.teardown(function () {
257
+ * // teardown is complete
258
+ * });
259
+ */
260
+ teardown(callback: () => void): void;
261
+ teardown(): Promise<void>;
262
+ }