@justifi/webcomponents 4.0.2 → 4.0.6

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 (265) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/cjs/Api-11362403.js +111 -0
  3. package/dist/cjs/Api-11362403.js.map +1 -0
  4. package/dist/cjs/Payment-ac4dea02.js +2 -0
  5. package/dist/cjs/Payment-ac4dea02.js.map +1 -0
  6. package/dist/cjs/{index-051b6dd0.js → index-34312a38.js} +185 -21
  7. package/dist/cjs/index-34312a38.js.map +1 -0
  8. package/dist/cjs/index.cjs.js +2 -0
  9. package/dist/cjs/index.cjs.js.map +1 -0
  10. package/dist/cjs/{index.esm-8df4906e.js → index.esm-bcf90c56.js} +2 -244
  11. package/dist/cjs/index.esm-bcf90c56.js.map +1 -0
  12. package/dist/cjs/justifi-bank-account-form.cjs.entry.js +3 -1
  13. package/dist/cjs/justifi-bank-account-form.cjs.entry.js.map +1 -0
  14. package/dist/cjs/justifi-billing-form_2.cjs.entry.js +8 -5
  15. package/dist/cjs/justifi-billing-form_2.cjs.entry.js.map +1 -0
  16. package/dist/cjs/justifi-business-address.cjs.entry.js +7 -4
  17. package/dist/cjs/justifi-business-address.cjs.entry.js.map +1 -0
  18. package/dist/cjs/justifi-business-info.cjs.entry.js +174 -0
  19. package/dist/cjs/justifi-business-info.cjs.entry.js.map +1 -0
  20. package/dist/cjs/justifi-card-form.cjs.entry.js +3 -1
  21. package/dist/cjs/justifi-card-form.cjs.entry.js.map +1 -0
  22. package/dist/cjs/justifi-payment-form.cjs.entry.js +10 -4
  23. package/dist/cjs/justifi-payment-form.cjs.entry.js.map +1 -0
  24. package/dist/cjs/justifi-payment-method-form.cjs.entry.js +12 -7
  25. package/dist/cjs/justifi-payment-method-form.cjs.entry.js.map +1 -0
  26. package/dist/cjs/justifi-payments-list.cjs.entry.js +5 -108
  27. package/dist/cjs/justifi-payments-list.cjs.entry.js.map +1 -0
  28. package/dist/cjs/loader.cjs.js +6 -3
  29. package/dist/cjs/loader.cjs.js.map +1 -0
  30. package/dist/cjs/select-input_2.cjs.entry.js +5 -3
  31. package/dist/cjs/select-input_2.cjs.entry.js.map +1 -0
  32. package/dist/cjs/state-options-efeaa587.js +248 -0
  33. package/dist/cjs/state-options-efeaa587.js.map +1 -0
  34. package/dist/cjs/webcomponents.cjs.js +12 -3
  35. package/dist/cjs/webcomponents.cjs.js.map +1 -0
  36. package/dist/collection/api/Api.js +2 -1
  37. package/dist/collection/api/Api.js.map +1 -0
  38. package/dist/collection/api/Pagination.js +1 -0
  39. package/dist/collection/api/Pagination.js.map +1 -0
  40. package/dist/collection/api/Payment.js +1 -0
  41. package/dist/collection/api/Payment.js.map +1 -0
  42. package/dist/collection/api/index.js +1 -0
  43. package/dist/collection/api/index.js.map +1 -0
  44. package/dist/collection/api/mockData/MockPayments.js +1 -0
  45. package/dist/collection/api/mockData/MockPayments.js.map +1 -0
  46. package/dist/collection/collection-manifest.json +4 -3
  47. package/dist/collection/components/bank-account-form/bank-account-form.js +1 -0
  48. package/dist/collection/components/bank-account-form/bank-account-form.js.map +1 -0
  49. package/dist/collection/components/bank-account-form/bank-account-form.stories.js +1 -0
  50. package/dist/collection/components/bank-account-form/bank-account-form.stories.js.map +1 -0
  51. package/dist/collection/components/bank-account-form/test/bank-account-form.e2e.js +14 -0
  52. package/dist/collection/components/bank-account-form/test/bank-account-form.e2e.js.map +1 -0
  53. package/dist/collection/components/bank-account-form/test/bank-account-form.spec.js +48 -0
  54. package/dist/collection/components/bank-account-form/test/bank-account-form.spec.js.map +1 -0
  55. package/dist/collection/components/billing-form/billing-form-schema.js +1 -0
  56. package/dist/collection/components/billing-form/billing-form-schema.js.map +1 -0
  57. package/dist/collection/components/billing-form/billing-form.css +337 -0
  58. package/dist/collection/components/billing-form/billing-form.js +1 -0
  59. package/dist/collection/components/billing-form/billing-form.js.map +1 -0
  60. package/dist/collection/components/billing-form/billing-form.stories.js +1 -0
  61. package/dist/collection/components/billing-form/billing-form.stories.js.map +1 -0
  62. package/dist/collection/components/billing-form/state-options.js +1 -0
  63. package/dist/collection/components/billing-form/state-options.js.map +1 -0
  64. package/dist/collection/components/billing-form/test/billing-form.spec.js +31 -0
  65. package/dist/collection/components/billing-form/test/billing-form.spec.js.map +1 -0
  66. package/dist/collection/components/business-address/business-address-schema.js +1 -0
  67. package/dist/collection/components/business-address/business-address-schema.js.map +1 -0
  68. package/dist/collection/components/business-address/business-address.css +337 -0
  69. package/dist/collection/components/business-address/business-address.js +1 -0
  70. package/dist/collection/components/business-address/business-address.js.map +1 -0
  71. package/dist/collection/components/business-address/test/business-address.e2e.js +10 -0
  72. package/dist/collection/components/business-address/test/business-address.e2e.js.map +1 -0
  73. package/dist/collection/components/business-address/test/business-address.spec.js +18 -0
  74. package/dist/collection/components/business-address/test/business-address.spec.js.map +1 -0
  75. package/dist/collection/components/business-info/business-info-schema.js +94 -0
  76. package/dist/collection/components/business-info/business-info-schema.js.map +1 -0
  77. package/dist/collection/components/business-info/business-info.css +2274 -0
  78. package/dist/collection/components/business-info/business-info.js +168 -0
  79. package/dist/collection/components/business-info/business-info.js.map +1 -0
  80. package/dist/collection/components/card-form/card-form.js +1 -0
  81. package/dist/collection/components/card-form/card-form.js.map +1 -0
  82. package/dist/collection/components/card-form/card-form.stories.js +1 -0
  83. package/dist/collection/components/card-form/card-form.stories.js.map +1 -0
  84. package/dist/collection/components/card-form/test/card-form.e2e.js +14 -0
  85. package/dist/collection/components/card-form/test/card-form.e2e.js.map +1 -0
  86. package/dist/collection/components/card-form/test/card-form.spec.js +56 -0
  87. package/dist/collection/components/card-form/test/card-form.spec.js.map +1 -0
  88. package/dist/collection/components/payment-form/payment-form.css +412 -0
  89. package/dist/collection/components/payment-form/payment-form.js +8 -2
  90. package/dist/collection/components/payment-form/payment-form.js.map +1 -0
  91. package/dist/collection/components/payment-form/payment-form.stories.js +1 -0
  92. package/dist/collection/components/payment-form/payment-form.stories.js.map +1 -0
  93. package/dist/collection/components/payment-form/payment-method-selector.css +337 -0
  94. package/dist/collection/components/payment-form/payment-method-selector.js +1 -0
  95. package/dist/collection/components/payment-form/payment-method-selector.js.map +1 -0
  96. package/dist/collection/components/payment-form/test/payment-form.e2e.js +23 -0
  97. package/dist/collection/components/payment-form/test/payment-form.e2e.js.map +1 -0
  98. package/dist/collection/components/payment-form/test/payment-form.spec.js +182 -0
  99. package/dist/collection/components/payment-form/test/payment-form.spec.js.map +1 -0
  100. package/dist/collection/components/payment-form/tokenize.js +1 -0
  101. package/dist/collection/components/payment-form/tokenize.js.map +1 -0
  102. package/dist/collection/components/payment-method-form/get-computed-theme.js +1 -0
  103. package/dist/collection/components/payment-method-form/get-computed-theme.js.map +1 -0
  104. package/dist/collection/components/payment-method-form/message-event-types.js +1 -0
  105. package/dist/collection/components/payment-method-form/message-event-types.js.map +1 -0
  106. package/dist/collection/components/payment-method-form/payment-method-form.js +2 -2
  107. package/dist/collection/components/payment-method-form/payment-method-form.js.map +1 -0
  108. package/dist/collection/components/payment-method-form/payment-method-responses.js +1 -0
  109. package/dist/collection/components/payment-method-form/payment-method-responses.js.map +1 -0
  110. package/dist/collection/components/payment-method-form/test/payment-method-form.e2e.js +22 -0
  111. package/dist/collection/components/payment-method-form/test/payment-method-form.e2e.js.map +1 -0
  112. package/dist/collection/components/payment-method-form/test/payment-method-form.spec.js +83 -0
  113. package/dist/collection/components/payment-method-form/test/payment-method-form.spec.js.map +1 -0
  114. package/dist/collection/components/payment-method-form/theme.js +1 -0
  115. package/dist/collection/components/payment-method-form/theme.js.map +1 -0
  116. package/dist/collection/components/payments-list/payments-list.js +1 -0
  117. package/dist/collection/components/payments-list/payments-list.js.map +1 -0
  118. package/dist/collection/components/payments-list/test/payments-list.spec.js +21 -0
  119. package/dist/collection/components/payments-list/test/payments-list.spec.js.map +1 -0
  120. package/dist/collection/components/select-input/select-input.css +337 -0
  121. package/dist/collection/components/select-input/select-input.js +1 -0
  122. package/dist/collection/components/select-input/select-input.js.map +1 -0
  123. package/dist/collection/components/select-input/test/select-input.spec.js +36 -0
  124. package/dist/collection/components/select-input/test/select-input.spec.js.map +1 -0
  125. package/dist/collection/components/text-input/test/text-input.spec.js +19 -0
  126. package/dist/collection/components/text-input/test/text-input.spec.js.map +1 -0
  127. package/dist/collection/components/text-input/text-input.css +337 -0
  128. package/dist/collection/components/text-input/text-input.js +1 -0
  129. package/dist/collection/components/text-input/text-input.js.map +1 -0
  130. package/dist/collection/index.js +1 -0
  131. package/dist/collection/index.js.map +1 -0
  132. package/dist/collection/utils/utils.js +1 -0
  133. package/dist/collection/utils/utils.js.map +1 -0
  134. package/dist/components/Api.js +109 -0
  135. package/dist/components/Api.js.map +1 -0
  136. package/dist/components/Payment.js +2 -0
  137. package/dist/components/Payment.js.map +1 -0
  138. package/dist/components/billing-form.js +6 -3
  139. package/dist/components/billing-form.js.map +1 -0
  140. package/dist/components/index.d.ts +9 -13
  141. package/dist/{esm/index.esm-c6a89005.js → components/index.esm.js} +3 -244
  142. package/dist/components/index.esm.js.map +1 -0
  143. package/dist/components/index.js +3 -11
  144. package/dist/components/index.js.map +1 -0
  145. package/dist/components/justifi-bank-account-form.js +3 -1
  146. package/dist/components/justifi-bank-account-form.js.map +1 -0
  147. package/dist/components/justifi-billing-form.js +2 -0
  148. package/dist/components/justifi-billing-form.js.map +1 -0
  149. package/dist/components/justifi-business-address.js +6 -3
  150. package/dist/components/justifi-business-address.js.map +1 -0
  151. package/dist/components/justifi-business-info.d.ts +11 -0
  152. package/dist/components/justifi-business-info.js +207 -0
  153. package/dist/components/justifi-business-info.js.map +1 -0
  154. package/dist/components/justifi-card-form.js +3 -1
  155. package/dist/components/justifi-card-form.js.map +1 -0
  156. package/dist/components/justifi-payment-form.js +11 -4
  157. package/dist/components/justifi-payment-form.js.map +1 -0
  158. package/dist/components/justifi-payment-method-form.js +2 -0
  159. package/dist/components/justifi-payment-method-form.js.map +1 -0
  160. package/dist/components/justifi-payment-method-selector.js +2 -0
  161. package/dist/components/justifi-payment-method-selector.js.map +1 -0
  162. package/dist/components/justifi-payments-list.js +4 -107
  163. package/dist/components/justifi-payments-list.js.map +1 -0
  164. package/dist/components/payment-method-form.js +12 -7
  165. package/dist/components/payment-method-form.js.map +1 -0
  166. package/dist/components/payment-method-selector.js +4 -2
  167. package/dist/components/payment-method-selector.js.map +1 -0
  168. package/dist/components/select-input.js +2 -0
  169. package/dist/components/select-input.js.map +1 -0
  170. package/dist/components/select-input2.js +4 -2
  171. package/dist/components/select-input2.js.map +1 -0
  172. package/dist/components/state-options.js +3 -1845
  173. package/dist/components/state-options.js.map +1 -0
  174. package/dist/components/text-input.js +2 -0
  175. package/dist/components/text-input.js.map +1 -0
  176. package/dist/components/text-input2.js +4 -2
  177. package/dist/components/text-input2.js.map +1 -0
  178. package/dist/esm/Api-a07f0057.js +109 -0
  179. package/dist/esm/Api-a07f0057.js.map +1 -0
  180. package/dist/esm/Payment-c86e1e84.js +2 -0
  181. package/dist/esm/Payment-c86e1e84.js.map +1 -0
  182. package/dist/esm/{index-605b421a.js → index-044f93fc.js} +185 -22
  183. package/dist/esm/index-044f93fc.js.map +1 -0
  184. package/dist/esm/index.esm-5624a5ed.js +1847 -0
  185. package/dist/esm/index.esm-5624a5ed.js.map +1 -0
  186. package/dist/esm/index.js +2 -0
  187. package/dist/esm/index.js.map +1 -0
  188. package/dist/esm/justifi-bank-account-form.entry.js +3 -1
  189. package/dist/esm/justifi-bank-account-form.entry.js.map +1 -0
  190. package/dist/esm/justifi-billing-form_2.entry.js +7 -4
  191. package/dist/esm/justifi-billing-form_2.entry.js.map +1 -0
  192. package/dist/esm/justifi-business-address.entry.js +6 -3
  193. package/dist/esm/justifi-business-address.entry.js.map +1 -0
  194. package/dist/esm/justifi-business-info.entry.js +170 -0
  195. package/dist/esm/justifi-business-info.entry.js.map +1 -0
  196. package/dist/esm/justifi-card-form.entry.js +3 -1
  197. package/dist/esm/justifi-card-form.entry.js.map +1 -0
  198. package/dist/esm/justifi-payment-form.entry.js +10 -4
  199. package/dist/esm/justifi-payment-form.entry.js.map +1 -0
  200. package/dist/esm/justifi-payment-method-form.entry.js +12 -7
  201. package/dist/esm/justifi-payment-method-form.entry.js.map +1 -0
  202. package/dist/esm/justifi-payments-list.entry.js +4 -107
  203. package/dist/esm/justifi-payments-list.entry.js.map +1 -0
  204. package/dist/esm/loader.js +6 -3
  205. package/dist/esm/loader.js.map +1 -0
  206. package/dist/esm/polyfills/css-shim.js +1 -1
  207. package/dist/esm/select-input_2.entry.js +5 -3
  208. package/dist/esm/select-input_2.entry.js.map +1 -0
  209. package/dist/esm/state-options-188acc34.js +246 -0
  210. package/dist/esm/state-options-188acc34.js.map +1 -0
  211. package/dist/esm/webcomponents.js +9 -3
  212. package/dist/esm/webcomponents.js.map +1 -0
  213. package/dist/types/api/Api.d.ts +1 -1
  214. package/dist/types/api/Payment.d.ts +1 -1
  215. package/dist/types/components/business-info/business-info-schema.d.ts +42 -0
  216. package/dist/types/components/business-info/business-info.d.ts +20 -0
  217. package/dist/types/components/payment-form/payment-form.d.ts +1 -0
  218. package/dist/types/components/payment-method-form/payment-method-responses.d.ts +1 -1
  219. package/dist/types/components.d.ts +63 -0
  220. package/dist/types/stencil-public-runtime.d.ts +72 -15
  221. package/dist/webcomponents/index.esm.js +2 -0
  222. package/dist/webcomponents/index.esm.js.map +1 -0
  223. package/dist/webcomponents/p-0ea23153.js +2 -0
  224. package/dist/webcomponents/p-0ea23153.js.map +1 -0
  225. package/dist/webcomponents/p-16b4e90a.entry.js +2 -0
  226. package/dist/webcomponents/p-16b4e90a.entry.js.map +1 -0
  227. package/dist/webcomponents/p-1ca0646b.js +2 -1
  228. package/dist/webcomponents/p-1ca0646b.js.map +1 -0
  229. package/dist/webcomponents/p-1f151d49.js +2 -0
  230. package/dist/webcomponents/p-1f151d49.js.map +1 -0
  231. package/dist/webcomponents/p-1f23b391.entry.js +2 -0
  232. package/dist/webcomponents/p-1f23b391.entry.js.map +1 -0
  233. package/dist/webcomponents/p-255b1284.entry.js +2 -0
  234. package/dist/webcomponents/p-255b1284.entry.js.map +1 -0
  235. package/dist/webcomponents/p-3aa91155.js +3 -0
  236. package/dist/webcomponents/p-3aa91155.js.map +1 -0
  237. package/dist/webcomponents/p-90c0d9e1.entry.js +2 -0
  238. package/dist/webcomponents/p-90c0d9e1.entry.js.map +1 -0
  239. package/dist/webcomponents/p-c903cc5a.entry.js +2 -0
  240. package/dist/webcomponents/p-c903cc5a.entry.js.map +1 -0
  241. package/dist/webcomponents/p-d87b0711.entry.js +2 -0
  242. package/dist/webcomponents/p-d87b0711.entry.js.map +1 -0
  243. package/dist/webcomponents/p-dbf7100f.entry.js +2 -0
  244. package/dist/webcomponents/p-dbf7100f.entry.js.map +1 -0
  245. package/dist/webcomponents/p-e0054bc3.js +2 -0
  246. package/dist/webcomponents/p-e0054bc3.js.map +1 -0
  247. package/dist/webcomponents/p-f30d1567.entry.js +2 -0
  248. package/dist/webcomponents/p-f30d1567.entry.js.map +1 -0
  249. package/dist/webcomponents/p-f66f024e.entry.js +2 -0
  250. package/dist/webcomponents/p-f66f024e.entry.js.map +1 -0
  251. package/dist/webcomponents/webcomponents.css +1 -1
  252. package/dist/webcomponents/webcomponents.esm.js +2 -1
  253. package/dist/webcomponents/webcomponents.esm.js.map +1 -0
  254. package/loader/index.d.ts +9 -0
  255. package/package.json +8 -4
  256. package/dist/webcomponents/p-039e3540.entry.js +0 -1
  257. package/dist/webcomponents/p-11e5bef9.entry.js +0 -1
  258. package/dist/webcomponents/p-20732337.js +0 -1
  259. package/dist/webcomponents/p-24409e8e.entry.js +0 -1
  260. package/dist/webcomponents/p-4a406704.js +0 -2
  261. package/dist/webcomponents/p-5774e36e.entry.js +0 -1
  262. package/dist/webcomponents/p-5b5e8351.entry.js +0 -1
  263. package/dist/webcomponents/p-7747c086.entry.js +0 -1
  264. package/dist/webcomponents/p-b061da77.entry.js +0 -1
  265. package/dist/webcomponents/p-bc35e124.entry.js +0 -1
@@ -1,19 +1,28 @@
1
1
  'use strict';
2
2
 
3
- const index = require('./index-051b6dd0.js');
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-34312a38.js');
4
6
 
5
7
  /*
6
- Stencil Client Patch Browser v2.20.0 | MIT Licensed | https://stenciljs.com
8
+ Stencil Client Patch Browser v3.3.0 | MIT Licensed | https://stenciljs.com
7
9
  */
8
10
  const patchBrowser = () => {
9
11
  const importMeta = (typeof document === 'undefined' ? new (require('u' + 'rl').URL)('file:' + __filename).href : (document.currentScript && document.currentScript.src || new URL('webcomponents.cjs.js', document.baseURI).href));
10
12
  const opts = {};
13
+ // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.
11
14
  if (importMeta !== '') {
12
15
  opts.resourcesUrl = new URL('.', importMeta).href;
16
+ // TODO(STENCIL-661): Remove code related to the dynamic import shim
17
+ // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.
13
18
  }
14
19
  return index.promiseResolve(opts);
15
20
  };
16
21
 
17
22
  patchBrowser().then(options => {
18
- return index.bootstrapLazy([["justifi-payment-form.cjs",[[1,"justifi-payment-form",{"bankAccount":[4,"bank-account"],"card":[4],"email":[1],"iframeOrigin":[1,"iframe-origin"],"clientId":[1,"client-id"],"accountId":[1,"account-id"],"submitButtonText":[1,"submit-button-text"],"submitButtonEnabled":[32],"selectedPaymentMethodType":[32],"allowedPaymentMethodTypes":[32],"fillBillingForm":[64],"enableSubmitButton":[64]},[[0,"paymentMethodSelected","paymentMethodSelectedHandler"]]]]],["justifi-business-address.cjs",[[1,"justifi-business-address",{"businessAddress":[32],"businessAddressErrors":[32],"submit":[64]},[[0,"fieldReceivedInput","setFormValue"]]]]],["justifi-payment-method-form.cjs",[[0,"justifi-payment-method-form",{"paymentMethodFormType":[1,"payment-method-form-type"],"paymentMethodFormValidationMode":[1025,"payment-method-form-validation-mode"],"iframeOrigin":[1,"iframe-origin"],"singleLine":[4,"single-line"],"height":[32],"tokenize":[64],"validate":[64]}]]],["justifi-bank-account-form.cjs",[[0,"justifi-bank-account-form",{"validationMode":[1025,"validation-mode"],"iframeOrigin":[1025,"iframe-origin"],"internalStyleOverrides":[32],"tokenize":[64],"validate":[64]},[[0,"paymentMethodFormReady","readyHandler"],[0,"paymentMethodFormTokenize","tokenizeHandler"],[0,"paymentMethodFormValidate","validateHandler"]]]]],["justifi-card-form.cjs",[[0,"justifi-card-form",{"validationMode":[1025,"validation-mode"],"iframeOrigin":[1025,"iframe-origin"],"singleLine":[4,"single-line"],"internalStyleOverrides":[32],"tokenize":[64],"validate":[64]},[[0,"paymentMethodFormReady","readyHandler"],[0,"paymentMethodFormTokenize","tokenizeHandler"],[0,"paymentMethodFormValidate","validateHandler"]]]]],["justifi-payments-list.cjs",[[1,"justifi-payments-list",{"accountId":[1,"account-id"],"auth":[16],"payments":[32]}]]],["select-input_2.cjs",[[1,"select-input",{"name":[1],"label":[1],"defaultValue":[1,"default-value"],"error":[1],"options":[16],"internalValue":[32]}],[1,"text-input",{"name":[1],"label":[1],"defaultValue":[1,"default-value"],"error":[1],"internalValue":[32]}]]],["justifi-billing-form_2.cjs",[[1,"justifi-billing-form",{"legend":[1],"billingFields":[32],"billingFieldsErrors":[32],"fill":[64],"validate":[64],"getValues":[64]},[[0,"fieldReceivedInput","setFormValue"]]],[1,"justifi-payment-method-selector",{"paymentMethodTypes":[16],"selectedPaymentMethodType":[1,"selected-payment-method-type"]}]]]], options);
23
+ return index.bootstrapLazy([["justifi-payment-form.cjs",[[1,"justifi-payment-form",{"bankAccount":[4,"bank-account"],"card":[4],"email":[1],"iframeOrigin":[1,"iframe-origin"],"clientId":[1,"client-id"],"accountId":[1,"account-id"],"submitButtonText":[1,"submit-button-text"],"submitButtonEnabled":[32],"isLoading":[32],"selectedPaymentMethodType":[32],"allowedPaymentMethodTypes":[32],"fillBillingForm":[64],"enableSubmitButton":[64]},[[0,"paymentMethodSelected","paymentMethodSelectedHandler"]]]]],["justifi-business-address.cjs",[[1,"justifi-business-address",{"businessAddress":[32],"businessAddressErrors":[32],"submit":[64]},[[0,"fieldReceivedInput","setFormValue"]]]]],["justifi-business-info.cjs",[[1,"justifi-business-info",{"authToken":[1,"auth-token"],"businessId":[1,"business-id"],"businessInfoPrefillData":[32],"businessInfo":[32],"businessInfoFieldsErrors":[32],"submit":[64]},[[0,"fieldReceivedInput","setFormValue"]]]]],["justifi-payment-method-form.cjs",[[0,"justifi-payment-method-form",{"paymentMethodFormType":[1,"payment-method-form-type"],"paymentMethodFormValidationMode":[1025,"payment-method-form-validation-mode"],"iframeOrigin":[1,"iframe-origin"],"singleLine":[4,"single-line"],"height":[32],"tokenize":[64],"validate":[64]}]]],["justifi-bank-account-form.cjs",[[0,"justifi-bank-account-form",{"validationMode":[1025,"validation-mode"],"iframeOrigin":[1025,"iframe-origin"],"internalStyleOverrides":[32],"tokenize":[64],"validate":[64]},[[0,"paymentMethodFormReady","readyHandler"],[0,"paymentMethodFormTokenize","tokenizeHandler"],[0,"paymentMethodFormValidate","validateHandler"]]]]],["justifi-card-form.cjs",[[0,"justifi-card-form",{"validationMode":[1025,"validation-mode"],"iframeOrigin":[1025,"iframe-origin"],"singleLine":[4,"single-line"],"internalStyleOverrides":[32],"tokenize":[64],"validate":[64]},[[0,"paymentMethodFormReady","readyHandler"],[0,"paymentMethodFormTokenize","tokenizeHandler"],[0,"paymentMethodFormValidate","validateHandler"]]]]],["justifi-payments-list.cjs",[[1,"justifi-payments-list",{"accountId":[1,"account-id"],"auth":[16],"payments":[32]}]]],["select-input_2.cjs",[[1,"select-input",{"name":[1],"label":[1],"defaultValue":[1,"default-value"],"error":[1],"options":[16],"internalValue":[32]}],[1,"text-input",{"name":[1],"label":[1],"defaultValue":[1,"default-value"],"error":[1],"internalValue":[32]}]]],["justifi-billing-form_2.cjs",[[1,"justifi-billing-form",{"legend":[1],"billingFields":[32],"billingFieldsErrors":[32],"fill":[64],"validate":[64],"getValues":[64]},[[0,"fieldReceivedInput","setFormValue"]]],[1,"justifi-payment-method-selector",{"paymentMethodTypes":[16],"selectedPaymentMethodType":[1,"selected-payment-method-type"]}]]]], options);
19
24
  });
25
+
26
+ exports.setNonce = index.setNonce;
27
+
28
+ //# sourceMappingURL=webcomponents.cjs.js.map
@@ -0,0 +1 @@
1
+ {"file":"webcomponents.cjs.js","mappings":";;;;;;AAAA;AACA;AACA;AAiBA,MAAM,YAAY,GAAG,MAAM;AAkC3B,IAAI,MAAM,UAAU,GAAG,+MAAe,CAAC;AACvC,IAAI,MAAM,IAAI,GAAiE,EAAE,CAAC;AAgBlF;AACA,IAAI,IAAuB,UAAU,KAAK,EAAE,EAAE;AAC9C,QAAQ,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC;AAC1D;AACA;AACA,KAaK;AACL,IAAI,OAAOA,oBAAc,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;;ACtFD,YAAY,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI;AAE/B,EAAE,OAAOC,mBAAa,CAAC,4BAA4B,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC,CAAC;;;;","names":["promiseResolve","bootstrapLazy"],"sources":["./node_modules/@stencil/core/internal/client/patch-browser.js","@lazy-browser-entrypoint?app-data=conditional"],"sourcesContent":["/*\n Stencil Client Patch Browser v3.3.0 | MIT Licensed | https://stenciljs.com\n */\nimport { BUILD, NAMESPACE } from '@stencil/core/internal/app-data';\nimport { consoleDevInfo, plt, win, doc, promiseResolve, H } from '@stencil/core';\n/**\n * Helper method for querying a `meta` tag that contains a nonce value\n * out of a DOM's head.\n *\n * @param doc The DOM containing the `head` to query against\n * @returns The content of the meta tag representing the nonce value, or `undefined` if no tag\n * exists or the tag has no content.\n */\nfunction queryNonceMetaTagContent(doc) {\n var _a, _b, _c;\n return (_c = (_b = (_a = doc.head) === null || _a === void 0 ? void 0 : _a.querySelector('meta[name=\"csp-nonce\"]')) === null || _b === void 0 ? void 0 : _b.getAttribute('content')) !== null && _c !== void 0 ? _c : undefined;\n}\n// TODO(STENCIL-661): Remove code related to the dynamic import shim\nconst getDynamicImportFunction = (namespace) => `__sc_import_${namespace.replace(/\\s|-/g, '_')}`;\nconst patchBrowser = () => {\n // NOTE!! This fn cannot use async/await!\n if (BUILD.isDev && !BUILD.isTesting) {\n consoleDevInfo('Running in development mode.');\n }\n // TODO(STENCIL-659): Remove code implementing the CSS variable shim\n if (BUILD.cssVarShim) {\n // shim css vars\n // TODO(STENCIL-659): Remove code implementing the CSS variable shim\n plt.$cssShim$ = win.__cssshim;\n }\n if (BUILD.cloneNodeFix) {\n // opted-in to polyfill cloneNode() for slot polyfilled components\n patchCloneNodeFix(H.prototype);\n }\n if (BUILD.profile && !performance.mark) {\n // not all browsers support performance.mark/measure (Safari 10)\n // because the mark/measure APIs are designed to write entries to a buffer in the browser that does not exist,\n // simply stub the implementations out.\n // TODO(STENCIL-323): Remove this patch when support for older browsers is removed (breaking)\n // @ts-ignore\n performance.mark = performance.measure = () => {\n /*noop*/\n };\n performance.getEntriesByName = () => [];\n }\n // @ts-ignore\n const scriptElm = \n // TODO(STENCIL-661): Remove code related to the dynamic import shim\n // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.\n BUILD.scriptDataOpts || BUILD.safari10 || BUILD.dynamicImportShim\n ? Array.from(doc.querySelectorAll('script')).find((s) => new RegExp(`\\/${NAMESPACE}(\\\\.esm)?\\\\.js($|\\\\?|#)`).test(s.src) ||\n s.getAttribute('data-stencil-namespace') === NAMESPACE)\n : null;\n const importMeta = import.meta.url;\n const opts = BUILD.scriptDataOpts ? (scriptElm || {})['data-opts'] || {} : {};\n // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.\n if (BUILD.safari10 && 'onbeforeload' in scriptElm && !history.scrollRestoration /* IS_ESM_BUILD */) {\n // Safari < v11 support: This IF is true if it's Safari below v11.\n // This fn cannot use async/await since Safari didn't support it until v11,\n // however, Safari 10 did support modules. Safari 10 also didn't support \"nomodule\",\n // so both the ESM file and nomodule file would get downloaded. Only Safari\n // has 'onbeforeload' in the script, and \"history.scrollRestoration\" was added\n // to Safari in v11. Return a noop then() so the async/await ESM code doesn't continue.\n // IS_ESM_BUILD is replaced at build time so this check doesn't happen in systemjs builds.\n return {\n then() {\n /* promise noop */\n },\n };\n }\n // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.\n if (!BUILD.safari10 && importMeta !== '') {\n opts.resourcesUrl = new URL('.', importMeta).href;\n // TODO(STENCIL-661): Remove code related to the dynamic import shim\n // TODO(STENCIL-663): Remove code related to deprecated `safari10` field.\n }\n else if (BUILD.dynamicImportShim || BUILD.safari10) {\n opts.resourcesUrl = new URL('.', new URL(scriptElm.getAttribute('data-resources-url') || scriptElm.src, win.location.href)).href;\n // TODO(STENCIL-661): Remove code related to the dynamic import shim\n if (BUILD.dynamicImportShim) {\n patchDynamicImport(opts.resourcesUrl, scriptElm);\n }\n // TODO(STENCIL-661): Remove code related to the dynamic import shim\n if (BUILD.dynamicImportShim && !win.customElements) {\n // module support, but no custom elements support (Old Edge)\n // @ts-ignore\n return import(/* webpackChunkName: \"polyfills-dom\" */ './dom.js').then(() => opts);\n }\n }\n return promiseResolve(opts);\n};\n// TODO(STENCIL-661): Remove code related to the dynamic import shim\nconst patchDynamicImport = (base, orgScriptElm) => {\n const importFunctionName = getDynamicImportFunction(NAMESPACE);\n try {\n // test if this browser supports dynamic imports\n // There is a caching issue in V8, that breaks using import() in Function\n // By generating a random string, we can workaround it\n // Check https://bugs.chromium.org/p/chromium/issues/detail?id=990810 for more info\n win[importFunctionName] = new Function('w', `return import(w);//${Math.random()}`);\n }\n catch (e) {\n // this shim is specifically for browsers that do support \"esm\" imports\n // however, they do NOT support \"dynamic\" imports\n // basically this code is for old Edge, v18 and below\n const moduleMap = new Map();\n win[importFunctionName] = (src) => {\n var _a;\n const url = new URL(src, base).href;\n let mod = moduleMap.get(url);\n if (!mod) {\n const script = doc.createElement('script');\n script.type = 'module';\n script.crossOrigin = orgScriptElm.crossOrigin;\n script.src = URL.createObjectURL(new Blob([`import * as m from '${url}'; window.${importFunctionName}.m = m;`], {\n type: 'application/javascript',\n }));\n // Apply CSP nonce to the script tag if it exists\n const nonce = (_a = plt.$nonce$) !== null && _a !== void 0 ? _a : queryNonceMetaTagContent(doc);\n if (nonce != null) {\n script.setAttribute('nonce', nonce);\n }\n mod = new Promise((resolve) => {\n script.onload = () => {\n resolve(win[importFunctionName].m);\n script.remove();\n };\n });\n moduleMap.set(url, mod);\n doc.head.appendChild(script);\n }\n return mod;\n };\n }\n};\nconst patchCloneNodeFix = (HTMLElementPrototype) => {\n const nativeCloneNodeFn = HTMLElementPrototype.cloneNode;\n HTMLElementPrototype.cloneNode = function (deep) {\n if (this.nodeName === 'TEMPLATE') {\n return nativeCloneNodeFn.call(this, deep);\n }\n const clonedNode = nativeCloneNodeFn.call(this, false);\n const srcChildNodes = this.childNodes;\n if (deep) {\n for (let i = 0; i < srcChildNodes.length; i++) {\n // Node.ATTRIBUTE_NODE === 2, and checking because IE11\n if (srcChildNodes[i].nodeType !== 2) {\n clonedNode.appendChild(srcChildNodes[i].cloneNode(true));\n }\n }\n }\n return clonedNode;\n };\n};\nexport { patchBrowser };\n","export { setNonce } from '@stencil/core';\nimport { bootstrapLazy } from '@stencil/core';\nimport { patchBrowser } from '@stencil/core/internal/client/patch-browser';\nimport { globalScripts } from '@stencil/core/internal/app-globals';\npatchBrowser().then(options => {\n globalScripts();\n return bootstrapLazy([/*!__STENCIL_LAZY_DATA__*/], options);\n});\n"],"version":3}
@@ -1,6 +1,6 @@
1
1
  import { v4 as uuidv4 } from 'uuid';
2
2
  const Api = (authToken) => {
3
- const apiOrigin = 'http://localhost:3000';
3
+ const apiOrigin = 'https://justifi.ai';
4
4
  async function getAuthorizationHeader() {
5
5
  return {
6
6
  'Authorization': `Bearer ${authToken}`,
@@ -40,3 +40,4 @@ function handleError(requestUrl) {
40
40
  console.error(`Error fetching from ${requestUrl}`);
41
41
  }
42
42
  export default Api;
43
+ //# sourceMappingURL=Api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Api.js","sourceRoot":"","sources":["../../../src/api/Api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAwBpC,MAAM,GAAG,GAAG,CAAC,SAAiB,EAAE,EAAE;EAChC,MAAM,SAAS,GAAG,oBAAoB,CAAC;EAEvC,KAAK,UAAU,sBAAsB;IACnC,OAAO;MACL,eAAe,EAAE,UAAU,SAAS,EAAE;MACtC,iBAAiB,EAAE,MAAM,EAAE;MAC3B,cAAc,EAAE,kBAAkB;KACnC,CAAC;EACJ,CAAC;EAED,KAAK,UAAU,WAAW,CAAC,QAAgB,EAAE,MAAc,EAAE,MAAY,EAAE,IAAU,EAAE,MAAoB;IACzG,MAAM,GAAG,GAAG,GAAG,SAAS,OAAO,QAAQ,EAAE,CAAC;IAC1C,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,IAAI,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;IAC1E,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,UAAU,EAAE;MACvC,MAAM,EAAE,MAAM;MACd,OAAO,EAAE,MAAM,sBAAsB,EAAE;MACvC,IAAI,EAAE,IAAI;MACV,MAAM,EAAE,MAAM;KACf,CAAC,CAAC;IAEH,IAAI,QAAQ,EAAE;MACZ,OAAO,QAAQ,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;KACvD;IACD,WAAW,CAAC,UAAU,CAAC,CAAC;EAC1B,CAAC;EAED,KAAK,UAAU,GAAG,CAAC,QAAgB,EAAE,MAAY,EAAE,MAAoB;IACrE,OAAO,WAAW,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;EAC5D,CAAC;EAED,KAAK,UAAU,IAAI,CAAC,QAAgB,EAAE,IAAU,EAAE,MAAY,EAAE,MAAoB;IAClF,OAAO,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;EAC7D,CAAC;EAED,KAAK,UAAU,KAAK,CAAC,QAAgB,EAAE,IAAU,EAAE,MAAY,EAAE,MAAoB;IACnF,OAAO,WAAW,CAAC,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;EAC9D,CAAC;EAED,KAAK,UAAU,OAAO,CAAC,QAAgB,EAAE,MAAY,EAAE,MAAoB;IACzE,OAAO,WAAW,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;EAC/D,CAAC;EAED,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;AACvC,CAAC,CAAC;AAEF,SAAS,WAAW,CAAC,UAAkB;EACrC,OAAO,CAAC,KAAK,CAAC,uBAAuB,UAAU,EAAE,CAAC,CAAC;AACrD,CAAC;AAED,eAAe,GAAG,CAAC","sourcesContent":["import { v4 as uuidv4 } from 'uuid';\nimport { IPagination } from './Pagination';\n\nexport interface IApiResponse<T> {\n data: T;\n error?: IErrorObject | IServerError;\n page_info?: IPagination;\n errors?: string[];\n id: number;\n type: string;\n}\n\nexport type IServerError = string;\n\nexport interface IErrorObject {\n message: string;\n code: string;\n param?: string;\n}\n\nexport interface IApiResponseCollection<T> extends IApiResponse<T> {\n page_info: IPagination;\n}\n\nconst Api = (authToken: string) => {\n const apiOrigin = 'https://justifi.ai';\n\n async function getAuthorizationHeader() {\n return {\n 'Authorization': `Bearer ${authToken}`,\n 'Idempotency-Key': uuidv4(),\n 'Content-Type': 'application/json',\n };\n }\n\n async function makeRequest(endpoint: string, method: string, params?: any, body?: any, signal?: AbortSignal) {\n const url = `${apiOrigin}/v1/${endpoint}`;\n const requestUrl = params ? `${url}?${new URLSearchParams(params)}` : url;\n const response = await fetch(requestUrl, {\n method: method,\n headers: await getAuthorizationHeader(),\n body: body,\n signal: signal,\n });\n\n if (response) {\n return response.status === 204 ? {} : response.json();\n }\n handleError(requestUrl);\n }\n\n async function get(endpoint: string, params?: any, signal?: AbortSignal) {\n return makeRequest(endpoint, 'GET', params, null, signal);\n }\n\n async function post(endpoint: string, body?: any, params?: any, signal?: AbortSignal) {\n return makeRequest(endpoint, 'POST', params, body, signal);\n }\n\n async function patch(endpoint: string, body?: any, params?: any, signal?: AbortSignal) {\n return makeRequest(endpoint, 'PATCH', params, body, signal);\n }\n\n async function destroy(endpoint: string, params?: any, signal?: AbortSignal) {\n return makeRequest(endpoint, 'DELETE', params, null, signal);\n }\n\n return { get, post, patch, destroy };\n};\n\nfunction handleError(requestUrl: string): void {\n console.error(`Error fetching from ${requestUrl}`);\n}\n\nexport default Api;\n"]}
@@ -6,3 +6,4 @@ export class Pagination {
6
6
  this.end_cursor = (pagination === null || pagination === void 0 ? void 0 : pagination.end_cursor) || '';
7
7
  }
8
8
  }
9
+ //# sourceMappingURL=Pagination.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pagination.js","sourceRoot":"","sources":["../../../src/api/Pagination.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,UAAU;EAMrB,YAAY,UAAwB;IAClC,IAAI,CAAC,YAAY,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,YAAY,KAAI,KAAK,CAAC;IACtD,IAAI,CAAC,QAAQ,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,KAAI,KAAK,CAAC;IAC9C,IAAI,CAAC,YAAY,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,YAAY,KAAI,EAAE,CAAC;IACnD,IAAI,CAAC,UAAU,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,UAAU,KAAI,EAAE,CAAC;EACjD,CAAC;CACF","sourcesContent":["export interface IPagination {\n has_previous: boolean;\n has_next: boolean;\n start_cursor: string;\n end_cursor: string;\n}\n\nexport class Pagination implements IPagination {\n public has_previous: boolean;\n public has_next: boolean;\n public start_cursor: string;\n public end_cursor: string;\n\n constructor(pagination?: IPagination) {\n this.has_previous = pagination?.has_previous || false;\n this.has_next = pagination?.has_next || false;\n this.start_cursor = pagination?.start_cursor || '';\n this.end_cursor = pagination?.end_cursor || '';\n }\n}\n"]}
@@ -65,3 +65,4 @@ export class Payment {
65
65
  }
66
66
  }
67
67
  }
68
+ //# sourceMappingURL=Payment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Payment.js","sourceRoot":"","sources":["../../../src/api/Payment.ts"],"names":[],"mappings":"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","sourcesContent":["export enum CaptureStrategy {\n automatic = 'automatic',\n manual = 'manual',\n}\n\nexport enum PaymentMethodTypes {\n card = 'card',\n bankAccount = 'bankAccount',\n}\n\nexport enum PaymentStatuses {\n pending = 'pending',\n authorized = 'authorized',\n succeeded = 'succeeded',\n failed = 'failed',\n disputed = 'disputed',\n fully_refunded = 'fully_refunded',\n partially_refunded = 'partially_refunded',\n}\n\nexport enum PaymentDisputedStatuses {\n // if a dispute is 'won', we don't show a dispute status, just general status\n lost = 'lost',\n open = 'open',\n}\n\nexport interface IPaymentMethod {\n card?: ICard;\n}\n\nexport type CardBrand = 'american_express' | 'diners_club' | 'discover' | 'jcb' | 'mastercard' | 'china_unionpay' | 'visa' | 'unknown';\n\nexport interface ICard {\n id: string;\n acct_last_four: string;\n name: string;\n brand: CardBrand;\n token: string;\n created_at: string;\n updated_at: string;\n}\n\nexport interface IDispute {\n amount_cents: number;\n created_at: string;\n currency: string;\n gateway_ref_id: string;\n id: string;\n payment_id: string;\n reason: null;\n status: string;\n updated_at: string;\n}\n\nexport interface IPayment {\n id: string;\n account_id: string;\n amount: number;\n amount_disputed: number;\n amount_refundable: number;\n amount_refunded: number;\n balance: number;\n captured: boolean;\n capture_strategy: CaptureStrategy;\n currency: 'usd';\n description: string;\n disputed: boolean;\n disputes: IDispute[];\n error_code: string | null;\n error_description: string | null;\n fee_amount: number;\n is_test: boolean;\n metadata: Object | null;\n payment_method: IPaymentMethod;\n payment_intent_id: string | null;\n refunded: boolean;\n status: PaymentStatuses;\n created_at: string;\n updated_at: string;\n}\n\nexport class Payment implements IPayment {\n public id: string;\n public account_id: string;\n public amount: number;\n public amount_disputed: number;\n public amount_refundable: number;\n public amount_refunded: number;\n public balance: number;\n public captured: boolean;\n public capture_strategy: CaptureStrategy;\n public currency: 'usd';\n public description: string;\n public disputed: boolean;\n public disputes: IDispute[];\n public error_code: string | null;\n public error_description: string | null;\n public fee_amount: number;\n public is_test: boolean;\n public metadata: Object | null;\n public payment_method: IPaymentMethod;\n public payment_intent_id: string | null;\n public refunded: boolean;\n public status: PaymentStatuses;\n public created_at: string;\n public updated_at: string;\n\n constructor(payment: IPayment) {\n this.id = payment.id;\n this.account_id = payment.account_id;\n this.amount = payment.amount;\n this.amount_disputed = payment.amount_disputed;\n this.amount_refundable = payment.amount_refundable;\n this.amount_refunded = payment.amount_refunded;\n this.balance = payment.balance;\n this.captured = payment.captured;\n this.capture_strategy = payment.capture_strategy;\n this.currency = payment.currency;\n this.description = payment.description;\n this.disputed = payment.disputed;\n this.disputes = payment.disputes;\n this.error_code = payment.error_code;\n this.error_description = payment.error_description;\n this.fee_amount = payment.fee_amount;\n this.is_test = payment.is_test;\n this.metadata = payment.metadata;\n this.payment_method = payment.payment_method;\n this.payment_intent_id = payment.payment_intent_id;\n this.refunded = payment.refunded;\n this.status = payment.status;\n this.created_at = payment.created_at;\n this.updated_at = payment.updated_at;\n }\n\n get disputedStatus(): PaymentDisputedStatuses | null {\n const lost = this.disputes.some(dispute => dispute.status === PaymentDisputedStatuses.lost);\n // if a dispute is 'won', we don't show a dispute status, just general status\n if (!this.disputed) {\n return null;\n } else if (lost) {\n return PaymentDisputedStatuses.lost;\n } else {\n return PaymentDisputedStatuses.open;\n }\n }\n}\n"]}
@@ -2,3 +2,4 @@ export { default as Api } from './Api';
2
2
  export * from './Api';
3
3
  export * from './Pagination';
4
4
  export * from './Payment';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,GAAG,EAAE,MAAM,OAAO,CAAC;AACvC,cAAc,OAAO,CAAC;AACtB,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC","sourcesContent":["export { default as Api } from './Api';\nexport * from './Api';\nexport * from './Pagination';\nexport * from './Payment';\n"]}
@@ -216,3 +216,4 @@ const mockPayments = [
216
216
  }),
217
217
  ];
218
218
  export default mockPayments;
219
+ //# sourceMappingURL=MockPayments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MockPayments.js","sourceRoot":"","sources":["../../../../src/api/mockData/MockPayments.ts"],"names":[],"mappings":"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","sourcesContent":["import { CaptureStrategy, Payment, PaymentStatuses } from '../Payment';\n\nconst mockPayments = [\n // payment 0: succeeded\n new Payment({\n account_id: 'acc_5wEk41rFZVPsqK5xQ7K0eG',\n amount: 363393,\n amount_disputed: 0,\n amount_refundable: 363393,\n amount_refunded: 0,\n balance: 363368,\n capture_strategy: CaptureStrategy.automatic,\n captured: true,\n created_at: '2022-01-10T15:29:58.940Z',\n currency: 'usd',\n description: 'Successful Payment',\n disputed: false,\n disputes: [],\n error_code: null,\n error_description: null,\n fee_amount: 25,\n id: 'py_6vbEiTROeuEoA1Hs1s2exQ',\n is_test: false,\n metadata: {\n city: 'Vienna',\n state: 'Nevada',\n customer_id: 234,\n customer_first_name: 'Elvis',\n customer_last_name: 'Presley',\n source: 'app',\n items: [\n {\n name: 'Pullover',\n amount: 4500,\n },\n {\n name: 'Jeans',\n amount: 5567,\n },\n ],\n },\n payment_intent_id: null,\n payment_method: {\n card: {\n acct_last_four: '6449',\n brand: 'mastercard',\n created_at: '2022-01-13T14:19:11.803Z',\n id: 'pm_7f66GJQoSofG3s9nOHPgaq',\n name: 'Nick Name',\n token: 'fake-token',\n updated_at: '2022-01-13T14:19:11.803Z',\n },\n },\n refunded: false,\n status: PaymentStatuses.succeeded,\n updated_at: '2022-01-10T15:29:58.940Z',\n }),\n // payment 1: fully refunded\n new Payment({\n account_id: 'acc_5wEk41rFZVPsqK5xQ7K0eG',\n amount: 3393,\n amount_disputed: 0,\n amount_refundable: 0,\n amount_refunded: 3393,\n balance: 0,\n capture_strategy: CaptureStrategy.automatic,\n captured: true,\n created_at: '2021-01-10T15:29:58.940Z',\n currency: 'usd',\n description: 'Fully Refunded Payment',\n disputed: false,\n disputes: [],\n error_code: null,\n error_description: null,\n fee_amount: 25,\n id: 'py_22cEiTROeuEoA1Hs1s24ls3',\n is_test: false,\n metadata: null,\n payment_intent_id: null,\n payment_method: {\n card: {\n acct_last_four: '1213',\n brand: 'visa',\n created_at: '2021-01-13T14:19:11.803Z',\n id: 'pm_7f66GJQoSofG3s9nOHPgaq',\n name: 'Good Customer',\n token: 'fake-token',\n updated_at: '2021-01-13T14:19:11.803Z',\n },\n },\n refunded: true,\n status: PaymentStatuses.fully_refunded,\n updated_at: '2021-01-10T15:29:58.940Z',\n }),\n // payment 2: partially refunded\n new Payment({\n account_id: 'acc_5wEk41rFZVPsqK5xQ7K0eG',\n amount: 3393,\n amount_disputed: 0,\n amount_refundable: 3300,\n amount_refunded: 193,\n balance: 3275,\n capture_strategy: CaptureStrategy.automatic,\n captured: true,\n created_at: '2021-11-10T15:29:58.940Z',\n currency: 'usd',\n description: 'Partially Refunded Payment',\n disputed: false,\n disputes: [],\n error_code: null,\n error_description: null,\n fee_amount: 25,\n id: 'py_8reEiTROeuEoA1Hs1s24zue',\n is_test: false,\n metadata: null,\n payment_intent_id: null,\n payment_method: {\n card: {\n acct_last_four: '9780',\n brand: 'american_express',\n created_at: '2021-11-13T14:19:11.803Z',\n id: 'pm_7f66GJQoSofG3s9nOHPgaq',\n name: 'Sal Gleason',\n token: 'fake-token',\n updated_at: '2021-11-13T14:19:11.803Z',\n },\n },\n refunded: true,\n status: PaymentStatuses.partially_refunded,\n updated_at: '2022-01-10T15:29:58.940Z',\n }),\n // payment 3: disputed\n new Payment({\n account_id: 'acc_5wEk41rFZVPsqK5xQ7K0eG',\n amount: 403393,\n amount_disputed: 403393,\n amount_refundable: 0,\n amount_refunded: 0,\n balance: 0,\n capture_strategy: CaptureStrategy.automatic,\n captured: true,\n created_at: '2021-09-10T15:29:58.940Z',\n currency: 'usd',\n description: 'Rustic Marble Pants',\n disputed: true,\n disputes: [\n {\n amount_cents: 10000,\n created_at: '2021-09-10T16:34:47.940Z',\n currency: 'usd',\n gateway_ref_id: 'dp_4f67775b-d6e0-4c4a-afb0-6ecf2d0df1a8',\n id: 'ed5dfa9d-b29d-4658-b76d-fff0c592171f',\n payment_id: '41ebfb2a-f8c8-4cee-9eca-cb7d86e863bc',\n reason: null,\n status: 'needs_response',\n updated_at: '2021-09-10T16:34:47.940Z',\n },\n ],\n error_code: null,\n error_description: null,\n fee_amount: 35,\n id: 'py_123EiTROeuEoA1Hs1s24r4w',\n is_test: false,\n metadata: null,\n payment_intent_id: null,\n payment_method: {\n card: {\n acct_last_four: '1554',\n brand: 'discover',\n created_at: '2021-09-13T14:19:11.803Z',\n id: 'pm_7f66GJQoSofG3s9nOHPgaq',\n name: 'Sal Gleason',\n token: 'fake-token',\n updated_at: '2021-09-13T14:19:11.803Z',\n },\n },\n refunded: false,\n status: PaymentStatuses.disputed,\n updated_at: '2021-09-10T15:29:58.940Z',\n }),\n // payment 4: failed\n new Payment({\n account_id: 'acc_5wEk41rFZVPsqK5xQ7K0eG',\n amount: 24170,\n amount_disputed: 0,\n amount_refundable: 0,\n amount_refunded: 0,\n balance: 0,\n capture_strategy: CaptureStrategy.automatic,\n captured: false,\n created_at: '2022-01-18T12:54:44.822Z',\n currency: 'usd',\n description: 'Failed Payment',\n disputed: false,\n disputes: [],\n error_code: 'card_declined',\n error_description: 'Your card has insufficient funds.',\n fee_amount: 25,\n id: 'py_6eZAJjYBFZU6LLNzxUDgx9',\n is_test: true,\n metadata: null,\n payment_intent_id: null,\n payment_method: {\n card: {\n acct_last_four: '8774',\n brand: 'diners_club',\n created_at: '2022-01-18T15:07:15.975Z',\n id: 'pm_5uyevnE6o1yl55nRgPWXXL',\n name: 'Minnie Bernhard',\n token: 'fake-token',\n updated_at: '2022-01-18T15:07:15.975Z',\n },\n },\n refunded: false,\n status: PaymentStatuses.failed,\n updated_at: '2022-01-18T12:54:44.822Z',\n }),\n];\n\nexport default mockPayments;\n"]}
@@ -1,20 +1,21 @@
1
1
  {
2
2
  "entries": [
3
3
  "./components/bank-account-form/bank-account-form.js",
4
+ "./components/payment-method-form/payment-method-form.js",
4
5
  "./components/billing-form/billing-form.js",
5
6
  "./components/business-address/business-address.js",
7
+ "./components/business-info/business-info.js",
6
8
  "./components/card-form/card-form.js",
7
9
  "./components/payment-form/payment-form.js",
8
10
  "./components/payment-form/payment-method-selector.js",
9
- "./components/payment-method-form/payment-method-form.js",
10
11
  "./components/payments-list/payments-list.js",
11
12
  "./components/select-input/select-input.js",
12
13
  "./components/text-input/text-input.js"
13
14
  ],
14
15
  "compiler": {
15
16
  "name": "@stencil/core",
16
- "version": "2.20.0",
17
- "typescriptVersion": "4.8.4"
17
+ "version": "3.3.0",
18
+ "typescriptVersion": "5.0.4"
18
19
  },
19
20
  "collections": [],
20
21
  "bundles": []
@@ -211,3 +211,4 @@ export class BankAccountForm {
211
211
  }];
212
212
  }
213
213
  }
214
+ //# sourceMappingURL=bank-account-form.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank-account-form.js","sourceRoot":"","sources":["../../../../src/components/bank-account-form/bank-account-form.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAgB,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAQ/F,MAAM,OAAO,eAAe;;;;;;EAgC1B,YAAY,CAAC,KAAkB;IAC7B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;EACxC,CAAC;EAGD,eAAe,CAAC,KAAoB;IAClC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;EAC3C,CAAC;EAGD,eAAe,CAAC,KAAoB;IAClC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;EAC3C,CAAC;EAID;;KAEG;EAEH,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAiE;IACjF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;MAClB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;KACzC;IACD,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,CAAC;EACzC,CAAC;EAED;;KAEG;EAEH,KAAK,CAAC,QAAQ;IACZ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;MAClB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;KACzC;IACD,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;EAClC,CAAC;EAED,MAAM;IACJ,OAAO,CACL,mCACE,GAAG,EAAE,EAAE,CAAC,EAAE;QACR,IAAI,EAAE,EAAE;UACN,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;SACpB;MACH,CAAC,mBACc,IAAI,CAAC,YAAY,8BACP,aAAa,+BACX,IAAI,CAAC,oBAAoB,kCACtB,IAAI,CAAC,uBAAuB,yCACrB,IAAI,CAAC,cAAc,IAAI,UAAU,GACtE,CACH,CAAC;EACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Event, Prop, h, EventEmitter, Listen, Method, State } from '@stencil/core';\nimport { CreatePaymentMethodResponse } from '../payment-method-form/payment-method-responses';\nimport { Theme } from '../payment-method-form/theme';\n\n@Component({\n tag: 'justifi-bank-account-form',\n shadow: false,\n})\nexport class BankAccountForm {\n /**\n * When to trigger validation of the form.\n */\n @Prop({ mutable: true }) validationMode: 'onChange' | 'onBlur' | 'onSubmit' | 'onTouched' | 'all';\n\n /**\n * URL for the rendered iFrame. End-users need not use this.\n */\n @Prop({ mutable: true }) iframeOrigin?: string;\n\n @State() internalStyleOverrides: Theme;\n\n /**\n * Triggered when iframe has loaded\n * @event justifi-bank-account-form#bankAccountFormReady\n */\n @Event() bankAccountFormReady: EventEmitter<any>;\n\n /**\n * Triggered when the tokenize method is called on the component\n * @event justifi-bank-account-form#bankAccountFormTokenize\n */\n @Event() bankAccountFormTokenize: EventEmitter<{ data: any }>;\n\n /**\n * Triggered when the validate method is called on the component\n * @event justifi-bank-account-form#bankAccountFormValidate\n */\n @Event() bankAccountFormValidate: EventEmitter<{ data: { isValid: boolean } }>;\n\n @Listen('paymentMethodFormReady')\n readyHandler(event: CustomEvent) {\n this.bankAccountFormReady.emit(event);\n }\n\n @Listen('paymentMethodFormTokenize')\n tokenizeHandler(event: { data: any }) {\n this.bankAccountFormTokenize.emit(event);\n }\n\n @Listen('paymentMethodFormValidate')\n validateHandler(event: { data: any }) {\n this.bankAccountFormValidate.emit(event);\n }\n\n private childRef?: HTMLJustifiPaymentMethodFormElement;\n\n /**\n * Makes a tokenization request to the iframe\n */\n @Method()\n async tokenize(...args: Parameters<HTMLJustifiPaymentMethodFormElement['tokenize']>): Promise<CreatePaymentMethodResponse> {\n if (!this.childRef) {\n throw new Error('Cannot call tokenize');\n }\n return this.childRef.tokenize(...args);\n }\n\n /**\n * Runs a validation on the form and shows errors if any\n */\n @Method()\n async validate() {\n if (!this.childRef) {\n throw new Error('Cannot call validate');\n }\n return this.childRef.validate();\n }\n\n render() {\n return (\n <justifi-payment-method-form\n ref={el => {\n if (el) {\n this.childRef = el;\n }\n }}\n iframe-origin={this.iframeOrigin}\n payment-method-form-type=\"bankAccount\"\n payment-method-form-ready={this.bankAccountFormReady}\n payment-method-form-tokenize={this.bankAccountFormTokenize}\n payment-method-form-validation-mode={this.validationMode || 'onSubmit'}\n />\n );\n }\n}\n"]}
@@ -118,3 +118,4 @@ export const Styled = Template.bind({});
118
118
  Styled.args = {
119
119
  'css-variables': CSSVars,
120
120
  };
121
+ //# sourceMappingURL=bank-account-form.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank-account-form.stories.js","sourceRoot":"","sources":["../../../../src/components/bank-account-form/bank-account-form.stories.ts"],"names":[],"mappings":"AAAA,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC;AACrD,MAAM,OAAO,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+Bf,CAAC;AAEF,eAAe;EACb,KAAK,EAAE,4BAA4B;EACnC,SAAS,EAAE,2BAA2B;EACtC,QAAQ,EAAE;IACR,eAAe,EAAE;MACf,OAAO,EAAE,MAAM;MACf,KAAK,EAAE;QACL,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI;QAC7B,QAAQ,EAAE,OAAO;OAClB;KACF;IACD,eAAe,EAAE;MACf,OAAO,EAAE,MAAM;MACf,KAAK,EAAE;QACL,QAAQ,EAAE,OAAO;QACjB,YAAY,EAAE,OAAO;OACtB;KACF;GACF;EACD,UAAU,EAAE;IACV,KAAK,CAAC,EAAE,CAAC;QACL,KAAK,EAAE;gBACC,SAAS,EAAE;KACtB;GACF;CACF,CAAC;AAEF,MAAM,mBAAmB,GAAG,KAAK,EAAE,QAA2C,EAAE,EAAE;EAChF,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,CAAC;EACxC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACrB,CAAC,CAAC;AACF,MAAM,mBAAmB,GAAG,KAAK,EAAE,QAA2C,EAAE,iBAAsB,EAAE,EAAE;EACxG,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;EACjF,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;AAChC,CAAC,CAAC;AACF,MAAM,WAAW,GAAG,GAAG,EAAE;EACvB,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC;EAC1C,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,2BAA2B,CAAsC,CAAC;EAC1G,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;EAC5D,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;EAC5D,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;IAC1C,mBAAmB,CAAC,QAAQ,CAAC,CAAC;EAChC,CAAC,CAAC,CAAC;EACH,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;IAC1C,mBAAmB,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;EACpC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,SAAS,GAAG,GAAG,EAAE;EACrB,gBAAgB,CAAC,sBAAsB,EAAE,WAAW,CAAC,CAAC;AACxD,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG;;;;;;;;;;;;;;;CAenB,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,IAAS,EAAE,EAAE;EAC7B,OAAO;;;;UAIC,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE;;;;;2BAKV,IAAI,CAAC,iBAAiB,CAAC,IAAI,UAAU;yBACvC,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE;;;MAG9C,WAAW;GACd,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAEvC,MAAM,CAAC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACxC,MAAM,CAAC,IAAI,GAAG;EACZ,eAAe,EAAE,OAAO;CACzB,CAAC","sourcesContent":["const isDev = process.env.NODE_ENV === 'development';\nconst CSSVars = `\n--jfi-layout-padding: 0;\n--jfi-layout-form-control-spacing-x: .5rem;\n--jfi-layout-form-control-spacing-y: 1rem;\n--jfi-form-label-font-weight: 700;\n--jfi-form-label-font-family: sans-serif;\n--jfi-form-label-margin: 0 0 .5rem 0;\n--jfi-form-control-background-color: #F4F4F6;\n--jfi-form-control-background-color-hover: #EEEEF5;\n--jfi-form-control-border-color: rgba(0, 0, 0, 0.42);\n--jfi-form-control-border-color-hover: rgba(0, 0, 0, 0.62);\n--jfi-form-control-border-color-focus: #fccc32;\n--jfi-form-control-border-color-error: #C12727;\n--jfi-form-control-border-top-width: 0;\n--jfi-form-control-border-left-width: 0;\n--jfi-form-control-border-bottom-width: 1px;\n--jfi-form-control-border-right-width: 0;\n--jfi-form-control-border-radius: 4px 4px 0 0;\n--jfi-form-control-border-style: solid;\n--jfi-form-control-box-shadow-focus: none;\n--jfi-form-control-box-shadow-error-focus: none;\n--jfi-form-control-border-style: solid;\n--jfi-form-control-color: #212529;\n--jfi-form-control-font-size: 1rem;\n--jfi-form-control-font-weight: 400;\n--jfi-form-control-line-height: 2;\n--jfi-form-control-margin: 0;\n--jfi-form-control-padding: .5rem .875rem;\n--jfi-error-message-color: #C12727;\n--jfi-error-message-margin: .25rem 0 0 0;\n--jfi-error-message-font-size: .875rem;\n`;\n\nexport default {\n title: 'Components/BankAccountForm',\n component: 'justifi-bank-account-form',\n argTypes: {\n 'iframe-origin': {\n control: 'text',\n table: {\n disable: isDev ? false : true,\n category: 'props',\n },\n },\n 'css-variables': {\n control: 'text',\n table: {\n category: 'props',\n defaultValue: CSSVars,\n },\n },\n },\n decorators: [\n story => `\n ${story()}\n <script>${addEvents()}</script>\n `,\n ],\n};\n\nconst handleValidateClick = async (bankForm: HTMLJustifiBankAccountFormElement) => {\n const valid = await bankForm.validate();\n console.log(valid);\n};\nconst handleTokenizeClick = async (bankForm: HTMLJustifiBankAccountFormElement, paymentMethodData: any) => {\n const tokenizeResponse = await bankForm.tokenize('CLIENT_ID', paymentMethodData);\n console.log(tokenizeResponse);\n};\nconst handleReady = () => {\n console.log('bank account form is ready');\n const bankForm = document.querySelector('justifi-bank-account-form') as HTMLJustifiBankAccountFormElement;\n const validateBtn = document.querySelector('#validate-btn');\n const tokenizeBtn = document.querySelector('#tokenize-btn');\n validateBtn?.addEventListener('click', () => {\n handleValidateClick(bankForm);\n });\n tokenizeBtn?.addEventListener('click', () => {\n handleTokenizeClick(bankForm, {});\n });\n};\n\nconst addEvents = () => {\n addEventListener('bankAccountFormReady', handleReady);\n};\n\nconst FormButtons = `\n <style>\n .button-bar {\n display: flex;\n aligin-items: center;\n padding: 10px;\n }\n .button-bar button {\n margin-right: 10px;\n }\n </style>\n <div class=\"button-bar\">\n <button id=\"validate-btn\">Validate</button>\n <button id=\"tokenize-btn\">Tokenize</button>\n </div>\n`;\n\nconst Template = (args: any) => {\n return `\n <div>\n <style>\n :root {\n ${args['css-variables'] || ''}\n }\n </style>\n <justifi-bank-account-form\n data-testid=\"bank-account-form-iframe\"\n validation-mode='${args['validation-mode'] || 'onSubmit'}'\n iframe-origin='${args['iframe-origin'] || ''}'\n />\n </div>\n ${FormButtons}\n `;\n};\n\nexport const Basic = Template.bind({});\n\nexport const Styled = Template.bind({});\nStyled.args = {\n 'css-variables': CSSVars,\n};\n"]}
@@ -0,0 +1,14 @@
1
+ import { newE2EPage } from '@stencil/core/testing';
2
+ describe('justifi-bank-account-form', () => {
3
+ it('should emit "bankAccountFormReady" event when "paymentMethodFormReady" event is fired', async () => {
4
+ const page = await newE2EPage();
5
+ await page.setContent('<justifi-bank-account-form></justifi-bank-account-form>');
6
+ const bankAccountForm = await page.find('justifi-bank-account-form');
7
+ const readyEventSpy = await bankAccountForm.spyOnEvent('bankAccountFormReady');
8
+ const paymentFormElement = await page.find('justifi-payment-method-form');
9
+ paymentFormElement.triggerEvent('paymentMethodFormReady');
10
+ await page.waitForChanges();
11
+ expect(readyEventSpy).toHaveReceivedEventTimes(1);
12
+ });
13
+ });
14
+ //# sourceMappingURL=bank-account-form.e2e.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank-account-form.e2e.js","sourceRoot":"","sources":["../../../../../src/components/bank-account-form/test/bank-account-form.e2e.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAEnD,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;EACzC,EAAE,CAAC,uFAAuF,EAAE,KAAK,IAAI,EAAE;IACrG,MAAM,IAAI,GAAG,MAAM,UAAU,EAAE,CAAC;IAChC,MAAM,IAAI,CAAC,UAAU,CAAC,yDAAyD,CAAC,CAAC;IAEjF,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAErE,MAAM,aAAa,GAAG,MAAM,eAAe,CAAC,UAAU,CAAC,sBAAsB,CAAC,CAAC;IAE/E,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;IAC1E,kBAAkB,CAAC,YAAY,CAAC,wBAAwB,CAAC,CAAC;IAE1D,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;IAE5B,MAAM,CAAC,aAAa,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC;EACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newE2EPage } from '@stencil/core/testing';\n\ndescribe('justifi-bank-account-form', () => {\n it('should emit \"bankAccountFormReady\" event when \"paymentMethodFormReady\" event is fired', async () => {\n const page = await newE2EPage();\n await page.setContent('<justifi-bank-account-form></justifi-bank-account-form>');\n\n const bankAccountForm = await page.find('justifi-bank-account-form');\n\n const readyEventSpy = await bankAccountForm.spyOnEvent('bankAccountFormReady');\n\n const paymentFormElement = await page.find('justifi-payment-method-form');\n paymentFormElement.triggerEvent('paymentMethodFormReady');\n\n await page.waitForChanges();\n\n expect(readyEventSpy).toHaveReceivedEventTimes(1);\n });\n});\n"]}
@@ -0,0 +1,48 @@
1
+ import { newSpecPage } from '@stencil/core/testing';
2
+ import { BankAccountForm } from '../bank-account-form';
3
+ import { PaymentMethodForm } from '../../payment-method-form/payment-method-form';
4
+ describe('justifi-bank-account-form', () => {
5
+ it('should pass validationMode prop to justifi-payment-method-form', async () => {
6
+ const page = await newSpecPage({
7
+ components: [BankAccountForm],
8
+ html: '<justifi-bank-account-form validation-mode="onChange" />',
9
+ });
10
+ const paymentMethodForm = page.root.querySelector('justifi-payment-method-form');
11
+ expect(paymentMethodForm.getAttribute('payment-method-form-validation-mode')).toBe('onChange');
12
+ });
13
+ it('should pass iframeOrigin prop to justifi-payment-method-form', async () => {
14
+ const page = await newSpecPage({
15
+ components: [BankAccountForm],
16
+ html: '<justifi-bank-account-form iframe-origin="https://example.com" />',
17
+ });
18
+ const paymentMethodForm = page.root.querySelector('justifi-payment-method-form');
19
+ expect(paymentMethodForm.getAttribute('iframe-origin')).toBe('https://example.com');
20
+ });
21
+ it('should call the PaymentMethodForm validate method when invoked from the BankAccountForm component', async () => {
22
+ const page = await newSpecPage({
23
+ components: [BankAccountForm, PaymentMethodForm],
24
+ html: '<justifi-bank-account-form></justifi-bank-account-form>',
25
+ });
26
+ const component = page.rootInstance;
27
+ const validateMock = jest.fn();
28
+ component.childRef = { validate: validateMock };
29
+ await component.validate();
30
+ expect(validateMock).toHaveBeenCalled();
31
+ });
32
+ it('should call the PaymentMethodForm tokenize method with the right arguments when invoked from the BankAccountForm component', async () => {
33
+ const page = await newSpecPage({
34
+ components: [BankAccountForm, PaymentMethodForm],
35
+ html: '<justifi-bank-account-form></justifi-bank-account-form>',
36
+ });
37
+ const component = page.rootInstance;
38
+ const tokenizeMock = jest.fn();
39
+ component.childRef = { tokenize: tokenizeMock };
40
+ const clientId = 'clientId';
41
+ const paymentMethodMetadata = { paymentMethodType: 'bankAccount' };
42
+ const account = 'account';
43
+ const tokenizeArgs = [clientId, paymentMethodMetadata, account];
44
+ await component.tokenize(...tokenizeArgs);
45
+ expect(tokenizeMock).toHaveBeenCalledWith(...tokenizeArgs);
46
+ });
47
+ });
48
+ //# sourceMappingURL=bank-account-form.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bank-account-form.spec.js","sourceRoot":"","sources":["../../../../../src/components/bank-account-form/test/bank-account-form.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,+CAA+C,CAAC;AAElF,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;EACzC,EAAE,CAAC,gEAAgE,EAAE,KAAK,IAAI,EAAE;IAC9E,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,eAAe,CAAC;MAC7B,IAAI,EAAE,0DAA0D;KACjE,CAAC,CAAC;IACH,MAAM,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,6BAA6B,CAAC,CAAC;IACjF,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,qCAAqC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;EACjG,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;IAC5E,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,eAAe,CAAC;MAC7B,IAAI,EAAE,mEAAmE;KAC1E,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,6BAA6B,CAAC,CAAC;IACjF,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;EACtF,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,mGAAmG,EAAE,KAAK,IAAI,EAAE;IACjH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,eAAe,EAAE,iBAAiB,CAAC;MAChD,IAAI,EAAE,yDAAyD;KAChE,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC;IAEpC,MAAM,YAAY,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;IAC/B,SAAS,CAAC,QAAQ,GAAG,EAAE,QAAQ,EAAE,YAAY,EAAS,CAAC;IAEvD,MAAM,SAAS,CAAC,QAAQ,EAAE,CAAC;IAE3B,MAAM,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;EAC1C,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,4HAA4H,EAAE,KAAK,IAAI,EAAE;IAC1I,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,eAAe,EAAE,iBAAiB,CAAC;MAChD,IAAI,EAAE,yDAAyD;KAChE,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC;IAEpC,MAAM,YAAY,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;IAC/B,SAAS,CAAC,QAAQ,GAAG,EAAE,QAAQ,EAAE,YAAY,EAAS,CAAC;IAEvD,MAAM,QAAQ,GAAG,UAAU,CAAC;IAC5B,MAAM,qBAAqB,GAAG,EAAE,iBAAiB,EAAE,aAAa,EAAE,CAAC;IACnE,MAAM,OAAO,GAAG,SAAS,CAAC;IAC1B,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,qBAAqB,EAAE,OAAO,CAAC,CAAC;IAEhE,MAAM,SAAS,CAAC,QAAQ,CAAC,GAAG,YAAY,CAAC,CAAC;IAE1C,MAAM,CAAC,YAAY,CAAC,CAAC,oBAAoB,CAAC,GAAG,YAAY,CAAC,CAAC;EAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { BankAccountForm } from '../bank-account-form';\nimport { PaymentMethodForm } from '../../payment-method-form/payment-method-form';\n\ndescribe('justifi-bank-account-form', () => {\n it('should pass validationMode prop to justifi-payment-method-form', async () => {\n const page = await newSpecPage({\n components: [BankAccountForm],\n html: '<justifi-bank-account-form validation-mode=\"onChange\" />',\n });\n const paymentMethodForm = page.root.querySelector('justifi-payment-method-form');\n expect(paymentMethodForm.getAttribute('payment-method-form-validation-mode')).toBe('onChange');\n });\n\n it('should pass iframeOrigin prop to justifi-payment-method-form', async () => {\n const page = await newSpecPage({\n components: [BankAccountForm],\n html: '<justifi-bank-account-form iframe-origin=\"https://example.com\" />',\n });\n\n const paymentMethodForm = page.root.querySelector('justifi-payment-method-form');\n expect(paymentMethodForm.getAttribute('iframe-origin')).toBe('https://example.com');\n });\n\n it('should call the PaymentMethodForm validate method when invoked from the BankAccountForm component', async () => {\n const page = await newSpecPage({\n components: [BankAccountForm, PaymentMethodForm],\n html: '<justifi-bank-account-form></justifi-bank-account-form>',\n });\n\n const component = page.rootInstance;\n\n const validateMock = jest.fn();\n component.childRef = { validate: validateMock } as any;\n\n await component.validate();\n\n expect(validateMock).toHaveBeenCalled();\n });\n\n it('should call the PaymentMethodForm tokenize method with the right arguments when invoked from the BankAccountForm component', async () => {\n const page = await newSpecPage({\n components: [BankAccountForm, PaymentMethodForm],\n html: '<justifi-bank-account-form></justifi-bank-account-form>',\n });\n\n const component = page.rootInstance;\n\n const tokenizeMock = jest.fn();\n component.childRef = { tokenize: tokenizeMock } as any;\n\n const clientId = 'clientId';\n const paymentMethodMetadata = { paymentMethodType: 'bankAccount' };\n const account = 'account';\n const tokenizeArgs = [clientId, paymentMethodMetadata, account];\n\n await component.tokenize(...tokenizeArgs);\n\n expect(tokenizeMock).toHaveBeenCalledWith(...tokenizeArgs);\n });\n});\n"]}
@@ -9,3 +9,4 @@ const BillingFormSchema = object({
9
9
  address_postal_code: string().required('Enter ZIP').matches(RegExZip, 'Enter a valid ZIP').min(5, 'Enter a valid ZIP'),
10
10
  });
11
11
  export default BillingFormSchema;
12
+ //# sourceMappingURL=billing-form-schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"billing-form-schema.js","sourceRoot":"","sources":["../../../../src/components/billing-form/billing-form-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAErC,MAAM,CAAC,MAAM,QAAQ,GAAG,QAAQ,CAAC;AAWjC,MAAM,iBAAiB,GAAG,MAAM,CAAC;EAC/B,IAAI,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;EACrC,aAAa,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,sBAAsB,CAAC;EACxD,aAAa,EAAE,MAAM,EAAE;EACvB,YAAY,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC;EAC7C,aAAa,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC;EAChD,mBAAmB,EAAE,MAAM,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,mBAAmB,CAAC;CACvH,CAAC,CAAC;AAEH,eAAe,iBAAiB,CAAC","sourcesContent":["import { object, string } from 'yup';\n\nexport const RegExZip = /^\\d{5}/;\n\nexport interface BillingFormFields {\n name: string;\n address_line1: string;\n address_line2?: string;\n address_city: string;\n address_state: string;\n address_postal_code: string;\n}\n\nconst BillingFormSchema = object({\n name: string().required('Enter name'),\n address_line1: string().required('Enter street address'),\n address_line2: string(),\n address_city: string().required('Enter city'),\n address_state: string().required('Choose state'),\n address_postal_code: string().required('Enter ZIP').matches(RegExZip, 'Enter a valid ZIP').min(5, 'Enter a valid ZIP'),\n});\n\nexport default BillingFormSchema;\n"]}