@justifi/webcomponents 4.4.0 → 4.5.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 (487) hide show
  1. package/dist/cjs/{Api-7303478d.js → Api-d2df6e84.js} +16 -4
  2. package/dist/cjs/Api-d2df6e84.js.map +1 -0
  3. package/dist/cjs/Payout-4906a445.js +116 -0
  4. package/dist/cjs/Payout-4906a445.js.map +1 -0
  5. package/dist/cjs/{business-form-schema-63b311b2.js → business-form-schema-725ec6f5.js} +40 -22
  6. package/dist/cjs/business-form-schema-725ec6f5.js.map +1 -0
  7. package/dist/cjs/form-control-datepart_2.cjs.entry.js +107 -0
  8. package/dist/cjs/form-control-datepart_2.cjs.entry.js.map +1 -0
  9. package/dist/cjs/form-control-monetary.cjs.entry.js +65 -0
  10. package/dist/cjs/form-control-monetary.cjs.entry.js.map +1 -0
  11. package/dist/cjs/{form-control-select_2.cjs.entry.js → form-control-number_3.cjs.entry.js} +99 -12
  12. package/dist/cjs/form-control-number_3.cjs.entry.js.map +1 -0
  13. package/dist/cjs/form-control-select.cjs.entry.js +47 -0
  14. package/dist/cjs/form-control-select.cjs.entry.js.map +1 -0
  15. package/dist/cjs/{index-83b2ec02.js → index-3533152c.js} +10 -6
  16. package/dist/cjs/index-3533152c.js.map +1 -0
  17. package/dist/cjs/index-5a880722.js +3233 -0
  18. package/dist/cjs/index-5a880722.js.map +1 -0
  19. package/dist/cjs/{index.esm-7e12ce07.js → index.esm-84a0a7a8.js} +1 -19
  20. package/dist/cjs/index.esm-84a0a7a8.js.map +1 -0
  21. package/dist/cjs/justifi-additional-questions_5.cjs.entry.js +396 -0
  22. package/dist/cjs/justifi-additional-questions_5.cjs.entry.js.map +1 -0
  23. package/dist/cjs/justifi-bank-account-form.cjs.entry.js +3 -1
  24. package/dist/cjs/justifi-bank-account-form.cjs.entry.js.map +1 -1
  25. package/dist/cjs/justifi-billing-form_2.cjs.entry.js +2 -2
  26. package/dist/cjs/justifi-business-form.cjs.entry.js +98 -16
  27. package/dist/cjs/justifi-business-form.cjs.entry.js.map +1 -1
  28. package/dist/cjs/justifi-business-list.cjs.entry.js +189 -0
  29. package/dist/cjs/justifi-business-list.cjs.entry.js.map +1 -0
  30. package/dist/cjs/justifi-card-form.cjs.entry.js +3 -1
  31. package/dist/cjs/justifi-card-form.cjs.entry.js.map +1 -1
  32. package/dist/cjs/justifi-details.cjs.entry.js +30 -0
  33. package/dist/cjs/justifi-details.cjs.entry.js.map +1 -0
  34. package/dist/cjs/justifi-payment-details.cjs.entry.js +63 -0
  35. package/dist/cjs/justifi-payment-details.cjs.entry.js.map +1 -0
  36. package/dist/cjs/justifi-payment-form.cjs.entry.js +6 -5
  37. package/dist/cjs/justifi-payment-form.cjs.entry.js.map +1 -1
  38. package/dist/cjs/justifi-payment-method-form.cjs.entry.js +1487 -19
  39. package/dist/cjs/justifi-payment-method-form.cjs.entry.js.map +1 -1
  40. package/dist/cjs/justifi-payments-list.cjs.entry.js +49 -47
  41. package/dist/cjs/justifi-payments-list.cjs.entry.js.map +1 -1
  42. package/dist/cjs/justifi-payout-details.cjs.entry.js +61 -0
  43. package/dist/cjs/justifi-payout-details.cjs.entry.js.map +1 -0
  44. package/dist/cjs/justifi-payouts-list.cjs.entry.js +64 -54
  45. package/dist/cjs/justifi-payouts-list.cjs.entry.js.map +1 -1
  46. package/dist/cjs/justifi-proceeds-list.cjs.entry.js +156 -0
  47. package/dist/cjs/justifi-proceeds-list.cjs.entry.js.map +1 -0
  48. package/dist/cjs/justifi-table.cjs.entry.js +68 -0
  49. package/dist/cjs/justifi-table.cjs.entry.js.map +1 -0
  50. package/dist/cjs/loader.cjs.js +2 -2
  51. package/dist/cjs/select-input_2.cjs.entry.js +1 -1
  52. package/dist/cjs/table-utils-617126e5.js +13 -0
  53. package/dist/cjs/table-utils-617126e5.js.map +1 -0
  54. package/dist/cjs/{utils-4ee7e080.js → utils-0fd61dbd.js} +43 -104
  55. package/dist/cjs/utils-0fd61dbd.js.map +1 -0
  56. package/dist/cjs/utils-d95b09c2.js +35 -0
  57. package/dist/cjs/utils-d95b09c2.js.map +1 -0
  58. package/dist/cjs/webcomponents.cjs.js +3 -3
  59. package/dist/cjs/webcomponents.cjs.js.map +1 -1
  60. package/dist/collection/api/Api.js +15 -3
  61. package/dist/collection/api/Api.js.map +1 -1
  62. package/dist/collection/api/Business.js +50 -0
  63. package/dist/collection/api/Business.js.map +1 -0
  64. package/dist/collection/api/Payment.js.map +1 -1
  65. package/dist/collection/api/Payout.js +9 -0
  66. package/dist/collection/api/Payout.js.map +1 -1
  67. package/dist/collection/api/Proceed.js +42 -0
  68. package/dist/collection/api/Proceed.js.map +1 -0
  69. package/dist/collection/api/shared.js +2 -0
  70. package/dist/collection/api/shared.js.map +1 -0
  71. package/dist/collection/collection-manifest.json +13 -1
  72. package/dist/collection/components/bank-account-form/bank-account-form.js +6 -1
  73. package/dist/collection/components/bank-account-form/bank-account-form.js.map +1 -1
  74. package/dist/collection/components/bank-account-form/bank-account-form.stories.js +8 -0
  75. package/dist/collection/components/bank-account-form/bank-account-form.stories.js.map +1 -1
  76. package/dist/collection/components/business-form/additional-questions/additional-questions.js +59 -0
  77. package/dist/collection/components/business-form/additional-questions/additional-questions.js.map +1 -0
  78. package/dist/collection/components/business-form/business-address/business-address-form.js +1 -1
  79. package/dist/collection/components/business-form/business-address/business-address-form.js.map +1 -1
  80. package/dist/collection/components/business-form/business-address/test/business-address.spec.js +22 -18
  81. package/dist/collection/components/business-form/business-address/test/business-address.spec.js.map +1 -1
  82. package/dist/collection/components/business-form/business-form-schema.js +48 -37
  83. package/dist/collection/components/business-form/business-form-schema.js.map +1 -1
  84. package/dist/collection/components/business-form/business-form.css +5283 -43
  85. package/dist/collection/components/business-form/business-form.js +83 -6
  86. package/dist/collection/components/business-form/business-form.js.map +1 -1
  87. package/dist/collection/components/business-form/{businessForm.stories.js → business-form.stories.js} +8 -8
  88. package/dist/collection/components/business-form/business-form.stories.js.map +1 -0
  89. package/dist/collection/components/business-form/business-generic-info/business-generic-info.js +10 -17
  90. package/dist/collection/components/business-form/business-generic-info/business-generic-info.js.map +1 -1
  91. package/dist/collection/components/business-form/business-owners/business-owners.css +5283 -0
  92. package/dist/collection/components/business-form/business-owners/business-owners.js +48 -37
  93. package/dist/collection/components/business-form/business-owners/business-owners.js.map +1 -1
  94. package/dist/collection/components/business-form/business-representative/business-representative.js +12 -17
  95. package/dist/collection/components/business-form/business-representative/business-representative.js.map +1 -1
  96. package/dist/collection/components/business-form/test/business-form.spec.js +44 -0
  97. package/dist/collection/components/business-form/test/business-form.spec.js.map +1 -0
  98. package/dist/collection/components/business-list/business-list.css +576 -0
  99. package/dist/collection/components/business-list/business-list.js +209 -0
  100. package/dist/collection/components/business-list/business-list.js.map +1 -0
  101. package/dist/collection/components/business-list/business-list.stories.js +68 -0
  102. package/dist/collection/components/business-list/business-list.stories.js.map +1 -0
  103. package/dist/collection/components/business-list/example.js +12 -0
  104. package/dist/collection/components/card-form/card-form.js +6 -1
  105. package/dist/collection/components/card-form/card-form.js.map +1 -1
  106. package/dist/collection/components/card-form/card-form.stories.js +8 -0
  107. package/dist/collection/components/card-form/card-form.stories.js.map +1 -1
  108. package/dist/collection/components/details/details.css +7983 -0
  109. package/dist/collection/components/details/details.js +66 -0
  110. package/dist/collection/components/details/details.js.map +1 -0
  111. package/dist/collection/components/details/utils.js +10 -0
  112. package/dist/collection/components/details/utils.js.map +1 -0
  113. package/dist/collection/components/form/form-control-datepart.js +233 -0
  114. package/dist/collection/components/form/form-control-datepart.js.map +1 -0
  115. package/dist/collection/components/form/form-control-monetary.js +186 -0
  116. package/dist/collection/components/form/form-control-monetary.js.map +1 -0
  117. package/dist/collection/components/form/form-control-number-masked.js +217 -0
  118. package/dist/collection/components/form/form-control-number-masked.js.map +1 -0
  119. package/dist/collection/components/form/form-control-number.css +1818 -0
  120. package/dist/collection/components/form/form-control-number.js +194 -0
  121. package/dist/collection/components/form/form-control-number.js.map +1 -0
  122. package/dist/collection/components/form/form-control-select.css +6 -0
  123. package/dist/collection/components/form/form-control-select.js +36 -4
  124. package/dist/collection/components/form/form-control-select.js.map +1 -1
  125. package/dist/collection/components/form/form-control-text.css +7 -0
  126. package/dist/collection/components/form/form-control-text.js +45 -3
  127. package/dist/collection/components/form/form-control-text.js.map +1 -1
  128. package/dist/collection/components/form/form.js +16 -8
  129. package/dist/collection/components/form/form.js.map +1 -1
  130. package/dist/collection/components/legal-address-form/legal-address-form-schema.js +11 -0
  131. package/dist/collection/components/legal-address-form/legal-address-form-schema.js.map +1 -0
  132. package/dist/collection/components/legal-address-form/legal-address-form.css +2489 -0
  133. package/dist/collection/components/legal-address-form/legal-address-form.js +90 -0
  134. package/dist/collection/components/legal-address-form/legal-address-form.js.map +1 -0
  135. package/dist/collection/components/payment-details/example.js +12 -0
  136. package/dist/collection/components/payment-details/payment-details.css +7983 -0
  137. package/dist/collection/components/payment-details/payment-details.js +129 -0
  138. package/dist/collection/components/payment-details/payment-details.js.map +1 -0
  139. package/dist/collection/components/payment-details/payment-details.stories.js +47 -0
  140. package/dist/collection/components/payment-details/payment-details.stories.js.map +1 -0
  141. package/dist/collection/components/payment-method-form/payment-method-form.css +5 -0
  142. package/dist/collection/components/payment-method-form/payment-method-form.js +25 -35
  143. package/dist/collection/components/payment-method-form/payment-method-form.js.map +1 -1
  144. package/dist/collection/components/payment-method-form/test/payment-method-form.spec.js +7 -7
  145. package/dist/collection/components/payment-method-form/test/payment-method-form.spec.js.map +1 -1
  146. package/dist/collection/components/payments-list/payments-list.css +0 -7380
  147. package/dist/collection/components/payments-list/payments-list.js +69 -43
  148. package/dist/collection/components/payments-list/payments-list.js.map +1 -1
  149. package/dist/collection/components/payments-list/payments-list.stories.js +10 -10
  150. package/dist/collection/components/payments-list/payments-list.stories.js.map +1 -1
  151. package/dist/collection/components/payments-list/test/payments-list.spec.js +3 -54
  152. package/dist/collection/components/payments-list/test/payments-list.spec.js.map +1 -1
  153. package/dist/collection/components/payout-details/example.js +12 -0
  154. package/dist/collection/components/payout-details/payout-details.css +7983 -0
  155. package/dist/collection/components/payout-details/payout-details.js +126 -0
  156. package/dist/collection/components/payout-details/payout-details.js.map +1 -0
  157. package/dist/collection/components/payout-details/payout-details.stories.js +47 -0
  158. package/dist/collection/components/payout-details/payout-details.stories.js.map +1 -0
  159. package/dist/collection/components/payouts-list/example.js +12 -0
  160. package/dist/collection/components/payouts-list/payouts-list.css +0 -7407
  161. package/dist/collection/components/payouts-list/payouts-list.js +82 -48
  162. package/dist/collection/components/payouts-list/payouts-list.js.map +1 -1
  163. package/dist/collection/components/payouts-list/payouts-list.stories.js +10 -10
  164. package/dist/collection/components/payouts-list/payouts-list.stories.js.map +1 -1
  165. package/dist/collection/components/proceeds-list/example.js +12 -0
  166. package/dist/collection/components/proceeds-list/proceeds-list.css +576 -0
  167. package/dist/collection/components/proceeds-list/proceeds-list.js +207 -0
  168. package/dist/collection/components/proceeds-list/proceeds-list.js.map +1 -0
  169. package/dist/collection/components/proceeds-list/proceeds-list.stories.js +69 -0
  170. package/dist/collection/components/proceeds-list/proceeds-list.stories.js.map +1 -0
  171. package/dist/collection/components/table/table-utils.js +8 -0
  172. package/dist/collection/components/table/table-utils.js.map +1 -0
  173. package/dist/collection/components/table/table.css +8077 -0
  174. package/dist/collection/components/table/table.js +215 -0
  175. package/dist/collection/components/table/table.js.map +1 -0
  176. package/dist/collection/components/table/test/table.spec.js +59 -0
  177. package/dist/collection/components/table/test/table.spec.js.map +1 -0
  178. package/dist/collection/utils/country-options.js +202 -0
  179. package/dist/collection/utils/country-options.js.map +1 -0
  180. package/dist/collection/utils/phone-masks.js +4 -0
  181. package/dist/collection/utils/phone-masks.js.map +1 -0
  182. package/dist/collection/utils/utils.js +40 -0
  183. package/dist/collection/utils/utils.js.map +1 -1
  184. package/dist/components/Api.js +15 -3
  185. package/dist/components/Api.js.map +1 -1
  186. package/dist/components/Payout.js +113 -0
  187. package/dist/components/Payout.js.map +1 -0
  188. package/dist/components/additional-questions.js +51 -0
  189. package/dist/components/additional-questions.js.map +1 -0
  190. package/dist/components/business-address-form.js +8 -2
  191. package/dist/components/business-address-form.js.map +1 -1
  192. package/dist/components/business-generic-info.js +61 -35
  193. package/dist/components/business-generic-info.js.map +1 -1
  194. package/dist/components/business-owners.js +52 -36
  195. package/dist/components/business-owners.js.map +1 -1
  196. package/dist/components/business-representative.js +31 -15
  197. package/dist/components/business-representative.js.map +1 -1
  198. package/dist/components/details.js +66 -0
  199. package/dist/components/details.js.map +1 -0
  200. package/dist/components/form-control-datepart.d.ts +11 -0
  201. package/dist/components/form-control-datepart.js +8 -0
  202. package/dist/components/form-control-datepart.js.map +1 -0
  203. package/dist/components/form-control-datepart2.js +97 -0
  204. package/dist/components/form-control-datepart2.js.map +1 -0
  205. package/dist/components/form-control-monetary.d.ts +11 -0
  206. package/dist/components/form-control-monetary.js +8 -0
  207. package/dist/components/form-control-monetary.js.map +1 -0
  208. package/dist/components/form-control-monetary2.js +82 -0
  209. package/dist/components/form-control-monetary2.js.map +1 -0
  210. package/dist/components/form-control-number-masked.d.ts +11 -0
  211. package/dist/components/form-control-number-masked.js +8 -0
  212. package/dist/components/form-control-number-masked.js.map +1 -0
  213. package/dist/components/form-control-number-masked2.js +81 -0
  214. package/dist/components/form-control-number-masked2.js.map +1 -0
  215. package/dist/components/form-control-number.d.ts +11 -0
  216. package/dist/components/form-control-number.js +8 -0
  217. package/dist/components/form-control-number.js.map +1 -0
  218. package/dist/components/form-control-number2.js +70 -0
  219. package/dist/components/form-control-number2.js.map +1 -0
  220. package/dist/components/form-control-select.js +2 -2
  221. package/dist/components/form-control-select2.js +20 -7
  222. package/dist/components/form-control-select2.js.map +1 -1
  223. package/dist/components/form-control-text2.js +23 -4
  224. package/dist/components/form-control-text2.js.map +1 -1
  225. package/dist/components/index.d.ts +6 -0
  226. package/dist/components/index.esm.js +1 -18
  227. package/dist/components/index.esm.js.map +1 -1
  228. package/dist/components/index.js +1 -1
  229. package/dist/components/index2.js +3231 -0
  230. package/dist/components/index2.js.map +1 -0
  231. package/dist/components/justifi-additional-questions.d.ts +11 -0
  232. package/dist/components/justifi-additional-questions.js +8 -0
  233. package/dist/components/justifi-additional-questions.js.map +1 -0
  234. package/dist/components/justifi-bank-account-form.js +2 -0
  235. package/dist/components/justifi-bank-account-form.js.map +1 -1
  236. package/dist/components/justifi-business-form.js +146 -28
  237. package/dist/components/justifi-business-form.js.map +1 -1
  238. package/dist/components/justifi-business-generic-info.js +1 -1
  239. package/dist/components/justifi-business-list.d.ts +11 -0
  240. package/dist/components/justifi-business-list.js +215 -0
  241. package/dist/components/justifi-business-list.js.map +1 -0
  242. package/dist/components/justifi-card-form.js +2 -0
  243. package/dist/components/justifi-card-form.js.map +1 -1
  244. package/dist/components/justifi-details.d.ts +11 -0
  245. package/dist/components/justifi-details.js +8 -0
  246. package/dist/components/justifi-details.js.map +1 -0
  247. package/dist/components/justifi-legal-address-form.d.ts +11 -0
  248. package/dist/components/justifi-legal-address-form.js +8 -0
  249. package/dist/components/justifi-legal-address-form.js.map +1 -0
  250. package/dist/components/justifi-payment-details.d.ts +11 -0
  251. package/dist/components/justifi-payment-details.js +88 -0
  252. package/dist/components/justifi-payment-details.js.map +1 -0
  253. package/dist/components/justifi-payment-form.js +2 -1
  254. package/dist/components/justifi-payment-form.js.map +1 -1
  255. package/dist/components/justifi-payments-list.js +52 -45
  256. package/dist/components/justifi-payments-list.js.map +1 -1
  257. package/dist/components/justifi-payout-details.d.ts +11 -0
  258. package/dist/components/justifi-payout-details.js +86 -0
  259. package/dist/components/justifi-payout-details.js.map +1 -0
  260. package/dist/components/justifi-payouts-list.js +65 -50
  261. package/dist/components/justifi-payouts-list.js.map +1 -1
  262. package/dist/components/justifi-proceeds-list.d.ts +11 -0
  263. package/dist/components/justifi-proceeds-list.js +182 -0
  264. package/dist/components/justifi-proceeds-list.js.map +1 -0
  265. package/dist/components/justifi-table.d.ts +11 -0
  266. package/dist/components/justifi-table.js +8 -0
  267. package/dist/components/justifi-table.js.map +1 -0
  268. package/dist/components/legal-address-form.js +271 -0
  269. package/dist/components/legal-address-form.js.map +1 -0
  270. package/dist/components/payment-method-form.js +1488 -21
  271. package/dist/components/payment-method-form.js.map +1 -1
  272. package/dist/components/phone-masks.js +7 -0
  273. package/dist/components/phone-masks.js.map +1 -0
  274. package/dist/components/table.js +94 -0
  275. package/dist/components/table.js.map +1 -0
  276. package/dist/components/utils.js +41 -102
  277. package/dist/components/utils.js.map +1 -1
  278. package/dist/esm/{Api-436dfa09.js → Api-a95f17ac.js} +16 -4
  279. package/dist/esm/Api-a95f17ac.js.map +1 -0
  280. package/dist/esm/Payout-9a1f2859.js +113 -0
  281. package/dist/esm/Payout-9a1f2859.js.map +1 -0
  282. package/dist/esm/{business-form-schema-30c48693.js → business-form-schema-5885d3d6.js} +40 -22
  283. package/dist/esm/business-form-schema-5885d3d6.js.map +1 -0
  284. package/dist/esm/form-control-datepart_2.entry.js +102 -0
  285. package/dist/esm/form-control-datepart_2.entry.js.map +1 -0
  286. package/dist/esm/form-control-monetary.entry.js +61 -0
  287. package/dist/esm/form-control-monetary.entry.js.map +1 -0
  288. package/dist/esm/{form-control-select_2.entry.js → form-control-number_3.entry.js} +98 -12
  289. package/dist/esm/form-control-number_3.entry.js.map +1 -0
  290. package/dist/esm/form-control-select.entry.js +43 -0
  291. package/dist/esm/form-control-select.entry.js.map +1 -0
  292. package/dist/esm/index-5ed53c20.js +3231 -0
  293. package/dist/esm/index-5ed53c20.js.map +1 -0
  294. package/dist/esm/{index-c8f391de.js → index-fe877d03.js} +10 -7
  295. package/dist/esm/index-fe877d03.js.map +1 -0
  296. package/dist/esm/{index.esm-be2cd327.js → index.esm-89fe6af9.js} +2 -19
  297. package/dist/esm/index.esm-89fe6af9.js.map +1 -0
  298. package/dist/esm/justifi-additional-questions_5.entry.js +388 -0
  299. package/dist/esm/justifi-additional-questions_5.entry.js.map +1 -0
  300. package/dist/esm/justifi-bank-account-form.entry.js +3 -1
  301. package/dist/esm/justifi-bank-account-form.entry.js.map +1 -1
  302. package/dist/esm/justifi-billing-form_2.entry.js +2 -2
  303. package/dist/esm/justifi-business-form.entry.js +98 -16
  304. package/dist/esm/justifi-business-form.entry.js.map +1 -1
  305. package/dist/esm/justifi-business-list.entry.js +185 -0
  306. package/dist/esm/justifi-business-list.entry.js.map +1 -0
  307. package/dist/esm/justifi-card-form.entry.js +3 -1
  308. package/dist/esm/justifi-card-form.entry.js.map +1 -1
  309. package/dist/esm/justifi-details.entry.js +26 -0
  310. package/dist/esm/justifi-details.entry.js.map +1 -0
  311. package/dist/esm/justifi-payment-details.entry.js +59 -0
  312. package/dist/esm/justifi-payment-details.entry.js.map +1 -0
  313. package/dist/esm/justifi-payment-form.entry.js +3 -2
  314. package/dist/esm/justifi-payment-form.entry.js.map +1 -1
  315. package/dist/esm/justifi-payment-method-form.entry.js +1487 -19
  316. package/dist/esm/justifi-payment-method-form.entry.js.map +1 -1
  317. package/dist/esm/justifi-payments-list.entry.js +47 -45
  318. package/dist/esm/justifi-payments-list.entry.js.map +1 -1
  319. package/dist/esm/justifi-payout-details.entry.js +57 -0
  320. package/dist/esm/justifi-payout-details.entry.js.map +1 -0
  321. package/dist/esm/justifi-payouts-list.entry.js +60 -50
  322. package/dist/esm/justifi-payouts-list.entry.js.map +1 -1
  323. package/dist/esm/justifi-proceeds-list.entry.js +152 -0
  324. package/dist/esm/justifi-proceeds-list.entry.js.map +1 -0
  325. package/dist/esm/justifi-table.entry.js +64 -0
  326. package/dist/esm/justifi-table.entry.js.map +1 -0
  327. package/dist/esm/loader.js +3 -3
  328. package/dist/esm/select-input_2.entry.js +1 -1
  329. package/dist/esm/table-utils-6cdcaa8c.js +11 -0
  330. package/dist/esm/table-utils-6cdcaa8c.js.map +1 -0
  331. package/dist/esm/utils-1e7d6279.js +28 -0
  332. package/dist/esm/utils-1e7d6279.js.map +1 -0
  333. package/dist/esm/{utils-e7782126.js → utils-ad0bbe03.js} +42 -103
  334. package/dist/esm/utils-ad0bbe03.js.map +1 -0
  335. package/dist/esm/webcomponents.js +4 -4
  336. package/dist/esm/webcomponents.js.map +1 -1
  337. package/dist/types/api/Api.d.ts +1 -1
  338. package/dist/types/api/Business.d.ts +133 -0
  339. package/dist/types/api/Payment.d.ts +1 -0
  340. package/dist/types/api/Payout.d.ts +10 -12
  341. package/dist/types/api/Proceed.d.ts +60 -0
  342. package/dist/types/api/shared.d.ts +11 -0
  343. package/dist/types/components/bank-account-form/bank-account-form.stories.d.ts +6 -0
  344. package/dist/types/components/business-form/additional-questions/additional-questions.d.ts +15 -0
  345. package/dist/types/components/business-form/business-form-schema.d.ts +47 -21
  346. package/dist/types/components/business-form/business-form.d.ts +7 -2
  347. package/dist/types/components/business-form/business-generic-info/business-generic-info.d.ts +1 -2
  348. package/dist/types/components/business-form/business-owners/business-owners.d.ts +3 -2
  349. package/dist/types/components/business-form/business-representative/business-representative.d.ts +1 -2
  350. package/dist/types/components/business-list/business-list.d.ts +35 -0
  351. package/dist/types/components/business-list/business-list.stories.d.ts +9 -0
  352. package/dist/types/components/card-form/card-form.stories.d.ts +6 -0
  353. package/dist/types/components/details/details.d.ts +7 -0
  354. package/dist/types/components/details/utils.d.ts +19 -0
  355. package/dist/types/components/form/form-control-datepart.d.ts +19 -0
  356. package/dist/types/components/form/form-control-monetary.d.ts +17 -0
  357. package/dist/types/components/form/form-control-number-masked.d.ts +19 -0
  358. package/dist/types/components/form/form-control-number.d.ts +18 -0
  359. package/dist/types/components/form/form-control-select.d.ts +6 -1
  360. package/dist/types/components/form/form-control-text.d.ts +6 -0
  361. package/dist/types/components/form/form.d.ts +5 -4
  362. package/dist/types/components/legal-address-form/legal-address-form-schema.d.ts +17 -0
  363. package/dist/types/components/legal-address-form/legal-address-form.d.ts +16 -0
  364. package/dist/types/components/payment-details/payment-details.d.ts +28 -0
  365. package/dist/types/components/payment-details/payment-details.stories.d.ts +8 -0
  366. package/dist/types/components/payment-method-form/payment-method-form.d.ts +1 -3
  367. package/dist/types/components/payments-list/payments-list.d.ts +6 -14
  368. package/dist/types/components/payments-list/payments-list.stories.d.ts +1 -8
  369. package/dist/types/components/payout-details/payout-details.d.ts +28 -0
  370. package/dist/types/components/payout-details/payout-details.stories.d.ts +8 -0
  371. package/dist/types/components/payouts-list/payouts-list.d.ts +7 -15
  372. package/dist/types/components/payouts-list/payouts-list.stories.d.ts +1 -8
  373. package/dist/types/components/proceeds-list/proceeds-list.d.ts +37 -0
  374. package/dist/types/components/proceeds-list/proceeds-list.stories.d.ts +9 -0
  375. package/dist/types/components/table/table-utils.d.ts +14 -0
  376. package/dist/types/components/table/table.d.ts +28 -0
  377. package/dist/types/components.d.ts +637 -12
  378. package/dist/types/stencil-public-runtime.d.ts +2 -0
  379. package/dist/types/utils/country-options.d.ts +5 -0
  380. package/dist/types/utils/phone-masks.d.ts +3 -0
  381. package/dist/types/utils/utils.d.ts +2 -0
  382. package/dist/webcomponents/{p-1953797f.entry.js → p-1beaaba3.entry.js} +2 -2
  383. package/dist/webcomponents/{p-33d69eb5.entry.js → p-2b6f5e35.entry.js} +2 -2
  384. package/dist/webcomponents/p-2b6f5e35.entry.js.map +1 -0
  385. package/dist/webcomponents/p-2c2cde2d.js +2 -0
  386. package/dist/webcomponents/p-2c2cde2d.js.map +1 -0
  387. package/dist/webcomponents/p-2e66512d.entry.js +2 -0
  388. package/dist/webcomponents/p-2e66512d.entry.js.map +1 -0
  389. package/dist/webcomponents/p-640bfa9f.entry.js +2 -0
  390. package/dist/webcomponents/p-640bfa9f.entry.js.map +1 -0
  391. package/dist/webcomponents/p-641883b2.entry.js +2 -0
  392. package/dist/webcomponents/p-641883b2.entry.js.map +1 -0
  393. package/dist/webcomponents/p-6d549d84.entry.js +2 -0
  394. package/dist/webcomponents/p-6d549d84.entry.js.map +1 -0
  395. package/dist/webcomponents/p-75292cca.entry.js +2 -0
  396. package/dist/webcomponents/p-75292cca.entry.js.map +1 -0
  397. package/dist/webcomponents/p-7d6c309d.entry.js +2 -0
  398. package/dist/webcomponents/p-7d6c309d.entry.js.map +1 -0
  399. package/dist/webcomponents/p-8f421dc6.js +2 -0
  400. package/dist/webcomponents/p-8f421dc6.js.map +1 -0
  401. package/dist/webcomponents/p-9346ae33.js +2 -0
  402. package/dist/webcomponents/p-9346ae33.js.map +1 -0
  403. package/dist/webcomponents/p-a2aae7c9.entry.js +2 -0
  404. package/dist/webcomponents/p-a2aae7c9.entry.js.map +1 -0
  405. package/dist/webcomponents/{p-23e9c7d4.entry.js → p-a922b908.entry.js} +2 -2
  406. package/dist/webcomponents/p-ab0756ff.js +2 -0
  407. package/dist/webcomponents/p-ab0756ff.js.map +1 -0
  408. package/dist/webcomponents/{p-0fd4aae2.js → p-c46241ba.js} +2 -2
  409. package/dist/webcomponents/p-c46241ba.js.map +1 -0
  410. package/dist/webcomponents/p-ccb0e1c5.js +2 -0
  411. package/dist/webcomponents/p-ccb0e1c5.js.map +1 -0
  412. package/dist/webcomponents/{p-d5cadc78.entry.js → p-cd0eca25.entry.js} +2 -2
  413. package/dist/webcomponents/{p-d5cadc78.entry.js.map → p-cd0eca25.entry.js.map} +1 -1
  414. package/dist/webcomponents/{p-7041a637.entry.js → p-d92116e6.entry.js} +2 -2
  415. package/dist/webcomponents/{p-7041a637.entry.js.map → p-d92116e6.entry.js.map} +1 -1
  416. package/dist/webcomponents/p-da4e6389.entry.js +2 -0
  417. package/dist/webcomponents/p-da4e6389.entry.js.map +1 -0
  418. package/dist/webcomponents/p-db9945b1.entry.js +2 -0
  419. package/dist/webcomponents/p-db9945b1.entry.js.map +1 -0
  420. package/dist/webcomponents/p-e1f6c8ec.entry.js +2 -0
  421. package/dist/webcomponents/p-e1f6c8ec.entry.js.map +1 -0
  422. package/dist/webcomponents/p-e6695628.js +2 -0
  423. package/dist/webcomponents/p-e6695628.js.map +1 -0
  424. package/dist/webcomponents/p-e70b2a21.js +3 -0
  425. package/dist/webcomponents/p-e70b2a21.js.map +1 -0
  426. package/dist/webcomponents/p-ee32a236.entry.js +2 -0
  427. package/dist/webcomponents/p-ee32a236.entry.js.map +1 -0
  428. package/dist/webcomponents/p-f6cc37a6.entry.js +2 -0
  429. package/dist/webcomponents/{p-309a886f.entry.js.map → p-f6cc37a6.entry.js.map} +1 -1
  430. package/dist/webcomponents/p-f72c3084.entry.js +2 -0
  431. package/dist/webcomponents/p-f72c3084.entry.js.map +1 -0
  432. package/dist/webcomponents/p-f8067330.entry.js +2 -0
  433. package/dist/webcomponents/p-f8067330.entry.js.map +1 -0
  434. package/dist/webcomponents/p-f9e127a5.js +2 -0
  435. package/dist/webcomponents/p-f9e127a5.js.map +1 -0
  436. package/dist/webcomponents/p-fe2ec58b.entry.js +2 -0
  437. package/dist/webcomponents/p-fe2ec58b.entry.js.map +1 -0
  438. package/dist/webcomponents/webcomponents.esm.js +1 -1
  439. package/dist/webcomponents/webcomponents.esm.js.map +1 -1
  440. package/package.json +8 -5
  441. package/dist/cjs/Api-7303478d.js.map +0 -1
  442. package/dist/cjs/business-form-schema-63b311b2.js.map +0 -1
  443. package/dist/cjs/form-control-select_2.cjs.entry.js.map +0 -1
  444. package/dist/cjs/index-83b2ec02.js.map +0 -1
  445. package/dist/cjs/index.esm-7e12ce07.js.map +0 -1
  446. package/dist/cjs/justifi-business-address-form.cjs.entry.js +0 -37
  447. package/dist/cjs/justifi-business-address-form.cjs.entry.js.map +0 -1
  448. package/dist/cjs/justifi-business-generic-info_3.cjs.entry.js +0 -148
  449. package/dist/cjs/justifi-business-generic-info_3.cjs.entry.js.map +0 -1
  450. package/dist/cjs/utils-4ee7e080.js.map +0 -1
  451. package/dist/collection/components/business-form/businessForm.stories.js.map +0 -1
  452. package/dist/esm/Api-436dfa09.js.map +0 -1
  453. package/dist/esm/business-form-schema-30c48693.js.map +0 -1
  454. package/dist/esm/form-control-select_2.entry.js.map +0 -1
  455. package/dist/esm/index-c8f391de.js.map +0 -1
  456. package/dist/esm/index.esm-be2cd327.js.map +0 -1
  457. package/dist/esm/justifi-business-address-form.entry.js +0 -33
  458. package/dist/esm/justifi-business-address-form.entry.js.map +0 -1
  459. package/dist/esm/justifi-business-generic-info_3.entry.js +0 -142
  460. package/dist/esm/justifi-business-generic-info_3.entry.js.map +0 -1
  461. package/dist/esm/utils-e7782126.js.map +0 -1
  462. package/dist/webcomponents/p-0fd4aae2.js.map +0 -1
  463. package/dist/webcomponents/p-1a1f2196.js +0 -2
  464. package/dist/webcomponents/p-1a1f2196.js.map +0 -1
  465. package/dist/webcomponents/p-309a886f.entry.js +0 -2
  466. package/dist/webcomponents/p-33d69eb5.entry.js.map +0 -1
  467. package/dist/webcomponents/p-3a80a2ec.entry.js +0 -2
  468. package/dist/webcomponents/p-3a80a2ec.entry.js.map +0 -1
  469. package/dist/webcomponents/p-45fea6a8.entry.js +0 -2
  470. package/dist/webcomponents/p-45fea6a8.entry.js.map +0 -1
  471. package/dist/webcomponents/p-79456add.js +0 -2
  472. package/dist/webcomponents/p-79456add.js.map +0 -1
  473. package/dist/webcomponents/p-af080b21.js +0 -2
  474. package/dist/webcomponents/p-af080b21.js.map +0 -1
  475. package/dist/webcomponents/p-bc969904.js +0 -3
  476. package/dist/webcomponents/p-bc969904.js.map +0 -1
  477. package/dist/webcomponents/p-cd097ce9.entry.js +0 -2
  478. package/dist/webcomponents/p-cd097ce9.entry.js.map +0 -1
  479. package/dist/webcomponents/p-d5bc9f22.entry.js +0 -2
  480. package/dist/webcomponents/p-d5bc9f22.entry.js.map +0 -1
  481. package/dist/webcomponents/p-dd1ebc0b.entry.js +0 -2
  482. package/dist/webcomponents/p-dd1ebc0b.entry.js.map +0 -1
  483. package/dist/webcomponents/p-e05e0c6b.entry.js +0 -2
  484. package/dist/webcomponents/p-e05e0c6b.entry.js.map +0 -1
  485. /package/dist/types/components/business-form/{businessForm.stories.d.ts → business-form.stories.d.ts} +0 -0
  486. /package/dist/webcomponents/{p-1953797f.entry.js.map → p-1beaaba3.entry.js.map} +0 -0
  487. /package/dist/webcomponents/{p-23e9c7d4.entry.js.map → p-a922b908.entry.js.map} +0 -0
@@ -0,0 +1,129 @@
1
+ import { Host, h } from "@stencil/core";
2
+ import { Api } from "../../api";
3
+ import { MapPaymentStatusToBadge, formatCurrency, formatDate, formatTime } from "../../utils/utils";
4
+ import { DetailItem, EntityHeadInfo, EntityHeadInfoItem, ErrorState, LoadingState } from "../details/utils";
5
+ import { DetailSection } from "../details/utils";
6
+ /**
7
+ * @exportedPart detail-loading-spinner
8
+ * @exportedPart detail-loading-state
9
+ * @exportedPart detail-empty-state
10
+ * @exportedPart detail-head
11
+ * @exportedPart detail-title
12
+ * @exportedPart detail-method
13
+ * @exportedPart detail-info
14
+ * @exportedPart detail-info-item
15
+ * @exportedPart detail-info-item-title
16
+ * @exportedPart detail-info-item-data
17
+ * @exportedPart detail-metadata
18
+ * @exportedPart detail-metadata-title
19
+ * @exportedPart detail-method-title
20
+ * @exportedPart detail-method-data
21
+ */
22
+ export class PaymentDetails {
23
+ constructor() {
24
+ this.paymentId = undefined;
25
+ this.authToken = undefined;
26
+ this.payment = undefined;
27
+ this.loading = true;
28
+ this.errorMessage = undefined;
29
+ }
30
+ updateOnPropChange() {
31
+ this.fetchData();
32
+ }
33
+ connectedCallback() {
34
+ this.fetchData();
35
+ }
36
+ async fetchData() {
37
+ this.errorMessage = '';
38
+ if (!this.paymentId || !this.authToken) {
39
+ this.errorMessage = "Can not fetch any data without a PaymentID and an AuthToken";
40
+ this.loading = false;
41
+ return;
42
+ }
43
+ this.loading = true;
44
+ const endpoint = `payments/${this.paymentId}`;
45
+ const response = await Api(this.authToken).get(endpoint);
46
+ if (!response.error) {
47
+ this.payment = response.data;
48
+ }
49
+ else {
50
+ this.errorMessage = typeof response.error === 'string' ? response.error : response.error.message;
51
+ }
52
+ this.loading = false;
53
+ }
54
+ render() {
55
+ var _a;
56
+ return (h(Host, null, this.loading ? LoadingState :
57
+ !this.payment ? ErrorState(this.errorMessage) :
58
+ h("justifi-details", { "error-message": this.errorMessage, entity: {
59
+ metadata: this.payment.metadata
60
+ } }, h(EntityHeadInfo, { slot: "head-info", badge: h("span", { slot: 'badge', innerHTML: MapPaymentStatusToBadge((_a = this.payment) === null || _a === void 0 ? void 0 : _a.status) }), title: `${formatCurrency(this.payment.amount)} ${this.payment.currency.toUpperCase()}` }, h(EntityHeadInfoItem, { classes: "border-1 border-end", title: "Updated At", value: `${formatDate(this.payment.updated_at)} ${formatTime(this.payment.updated_at)}` }), h(EntityHeadInfoItem, { classes: "border-1 border-end", title: "Created At", value: `${formatDate(this.payment.created_at)} ${formatTime(this.payment.created_at)}` }), h(EntityHeadInfoItem, { title: "ID", value: this.payment.id })), h("div", { slot: 'detail-sections' }, h(DetailSection, { sectionTitle: "Details" }, h(DetailItem, { title: "Amount", value: formatCurrency(this.payment.amount) }), h(DetailItem, { title: "Fees", value: formatCurrency(this.payment.fee_amount) }), h(DetailItem, { title: "Refunded", value: formatCurrency(this.payment.amount_refunded) }), h(DetailItem, { title: "Net", value: formatCurrency(this.payment.balance) }), h(DetailItem, { title: "Status", value: MapPaymentStatusToBadge(this.payment.status) }), h(DetailItem, { title: "Payment ID", value: this.payment.id }), h(DetailItem, { title: "Processing Fees", value: formatCurrency(this.payment.fee_amount) }), h(DetailItem, { title: "Statement Descriptor", value: this.payment.statement_descriptor }), h(DetailItem, { title: "Description", value: this.payment.description })), h(DetailSection, { sectionTitle: "Payment Method" }, h(DetailItem, { title: "ID", value: this.payment.payment_method.card.id }), h(DetailItem, { title: "Payment Type", value: "Card" }), h(DetailItem, { title: "Last 4 Numbers", value: this.payment.payment_method.card.acct_last_four }), h(DetailItem, { title: "Brand", value: this.payment.payment_method.card.brand }), h(DetailItem, { title: "Cardholder", value: this.payment.payment_method.card.name }))))));
61
+ }
62
+ static get is() { return "justifi-payment-details"; }
63
+ static get encapsulation() { return "shadow"; }
64
+ static get originalStyleUrls() {
65
+ return {
66
+ "$": ["payment-details.scss"]
67
+ };
68
+ }
69
+ static get styleUrls() {
70
+ return {
71
+ "$": ["payment-details.css"]
72
+ };
73
+ }
74
+ static get properties() {
75
+ return {
76
+ "paymentId": {
77
+ "type": "string",
78
+ "mutable": false,
79
+ "complexType": {
80
+ "original": "string",
81
+ "resolved": "string",
82
+ "references": {}
83
+ },
84
+ "required": false,
85
+ "optional": false,
86
+ "docs": {
87
+ "tags": [],
88
+ "text": ""
89
+ },
90
+ "attribute": "payment-id",
91
+ "reflect": false
92
+ },
93
+ "authToken": {
94
+ "type": "string",
95
+ "mutable": false,
96
+ "complexType": {
97
+ "original": "string",
98
+ "resolved": "string",
99
+ "references": {}
100
+ },
101
+ "required": false,
102
+ "optional": false,
103
+ "docs": {
104
+ "tags": [],
105
+ "text": ""
106
+ },
107
+ "attribute": "auth-token",
108
+ "reflect": false
109
+ }
110
+ };
111
+ }
112
+ static get states() {
113
+ return {
114
+ "payment": {},
115
+ "loading": {},
116
+ "errorMessage": {}
117
+ };
118
+ }
119
+ static get watchers() {
120
+ return [{
121
+ "propName": "paymentId",
122
+ "methodName": "updateOnPropChange"
123
+ }, {
124
+ "propName": "authToken",
125
+ "methodName": "updateOnPropChange"
126
+ }];
127
+ }
128
+ }
129
+ //# sourceMappingURL=payment-details.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"payment-details.js","sourceRoot":"","sources":["../../../../src/components/payment-details/payment-details.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, Prop, State, Watch } from '@stencil/core';\nimport { Api, IApiResponseCollection, Payment } from '../../api';\nimport { MapPaymentStatusToBadge, formatCurrency, formatDate, formatTime } from '../../utils/utils';\nimport { DetailItem, EntityHeadInfo, EntityHeadInfoItem, ErrorState, LoadingState } from '../details/utils';\nimport { DetailSection } from '../details/utils';\n\n/**\n * @exportedPart detail-loading-spinner\n * @exportedPart detail-loading-state\n * @exportedPart detail-empty-state\n * @exportedPart detail-head\n * @exportedPart detail-title\n * @exportedPart detail-method\n * @exportedPart detail-info\n * @exportedPart detail-info-item\n * @exportedPart detail-info-item-title\n * @exportedPart detail-info-item-data\n * @exportedPart detail-metadata\n * @exportedPart detail-metadata-title\n * @exportedPart detail-method-title\n * @exportedPart detail-method-data\n*/\n@Component({\n tag: 'justifi-payment-details',\n styleUrl: 'payment-details.scss',\n shadow: true,\n})\n\nexport class PaymentDetails {\n @Prop() paymentId: string;\n @Prop() authToken: string;\n @State() payment: Payment;\n @State() loading: boolean = true;\n @State() errorMessage: string;\n\n @Watch('paymentId')\n @Watch('authToken')\n updateOnPropChange() {\n this.fetchData();\n }\n\n connectedCallback() {\n this.fetchData();\n }\n\n async fetchData(): Promise<void> {\n this.errorMessage = '';\n if (!this.paymentId || !this.authToken) {\n this.errorMessage = \"Can not fetch any data without a PaymentID and an AuthToken\";\n this.loading = false;\n return;\n }\n this.loading = true;\n const endpoint = `payments/${this.paymentId}`;\n\n const response: IApiResponseCollection<Payment> = await Api(this.authToken).get(endpoint);\n if (!response.error) {\n this.payment = response.data;\n } else {\n this.errorMessage = typeof response.error === 'string' ? response.error : response.error.message;\n }\n\n this.loading = false;\n }\n\n render() {\n return (\n <Host>\n {\n this.loading ? LoadingState :\n !this.payment ? ErrorState(this.errorMessage) :\n <justifi-details\n error-message={this.errorMessage}\n entity={{\n metadata: this.payment.metadata\n }}\n >\n <EntityHeadInfo slot=\"head-info\" badge={<span slot='badge' innerHTML={MapPaymentStatusToBadge(this.payment?.status)} />} title={`${formatCurrency(this.payment.amount)} ${this.payment.currency.toUpperCase()}`}>\n <EntityHeadInfoItem\n classes=\"border-1 border-end\"\n title=\"Updated At\"\n value={`${formatDate(this.payment.updated_at)} ${formatTime(this.payment.updated_at)}`}\n />\n <EntityHeadInfoItem\n classes=\"border-1 border-end\"\n title=\"Created At\"\n value={`${formatDate(this.payment.created_at)} ${formatTime(this.payment.created_at)}`}\n />\n <EntityHeadInfoItem title=\"ID\" value={this.payment.id} />\n </EntityHeadInfo>\n <div slot='detail-sections'>\n <DetailSection sectionTitle=\"Details\">\n <DetailItem title=\"Amount\" value={formatCurrency(this.payment.amount)} />\n <DetailItem title=\"Fees\" value={formatCurrency(this.payment.fee_amount)} />\n <DetailItem title=\"Refunded\" value={formatCurrency(this.payment.amount_refunded)} />\n <DetailItem title=\"Net\" value={formatCurrency(this.payment.balance)} />\n <DetailItem title=\"Status\" value={MapPaymentStatusToBadge(this.payment.status)} />\n <DetailItem title=\"Payment ID\" value={this.payment.id} />\n <DetailItem title=\"Processing Fees\" value={formatCurrency(this.payment.fee_amount)} />\n <DetailItem title=\"Statement Descriptor\" value={this.payment.statement_descriptor} />\n <DetailItem title=\"Description\" value={this.payment.description} />\n </DetailSection>\n <DetailSection sectionTitle=\"Payment Method\">\n <DetailItem title=\"ID\" value={this.payment.payment_method.card.id} />\n <DetailItem title=\"Payment Type\" value=\"Card\" />\n <DetailItem title=\"Last 4 Numbers\" value={this.payment.payment_method.card.acct_last_four} />\n <DetailItem title=\"Brand\" value={this.payment.payment_method.card.brand} />\n <DetailItem title=\"Cardholder\" value={this.payment.payment_method.card.name} />\n </DetailSection>\n </div>\n </justifi-details>\n }\n </Host>\n );\n }\n}\n"]}
@@ -0,0 +1,47 @@
1
+ export default {
2
+ title: 'dev/Components/PaymentDetails',
3
+ component: 'justifi-payment-details',
4
+ parameters: {},
5
+ };
6
+ class PaymentDetailsArgs {
7
+ constructor(args) {
8
+ this['auth-token'] = args['auth-token'] || '';
9
+ this['payment-id'] = args['payment-id'] || '';
10
+ }
11
+ }
12
+ const Template = (args) => {
13
+ return (`
14
+ <justifi-payment-details
15
+ data-testid="justifi-payment-details"
16
+ auth-token="${args['auth-token']}"
17
+ payment-id="${args['payment-id']}"
18
+ />
19
+ `);
20
+ };
21
+ export const Basic = Template.bind({});
22
+ Basic.args = new PaymentDetailsArgs({});
23
+ export const Styled = Template.bind({});
24
+ Styled.args = new PaymentDetailsArgs({});
25
+ Styled.decorators = [
26
+ (Story) => `
27
+ ${Story()}
28
+ <style>
29
+ justifi-payment-details::part(detail-head) {
30
+ background-color: rgba(100, 200, 250, 0.2);
31
+ border-left: 4px solid rgba(100, 200, 250, 1);
32
+ }
33
+ justifi-payment-details::part(detail-info-item-title),
34
+ justifi-payment-details::part(detail-method-item-title) {
35
+ border-radius: 3px;
36
+ background-color: rgba(0, 0, 0, 0.8);
37
+ text-align: center;
38
+ padding: 0 10px;
39
+ color: white !important;
40
+ }
41
+ justifi-payment-details::part(detail-metadata) {
42
+ background-color: rgba(100,100,100,0.2)
43
+ }
44
+ </style>
45
+ `
46
+ ];
47
+ //# sourceMappingURL=payment-details.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"payment-details.stories.js","sourceRoot":"","sources":["../../../../src/components/payment-details/payment-details.stories.ts"],"names":[],"mappings":"AAAA,eAAe;EACb,KAAK,EAAE,+BAA+B;EACtC,SAAS,EAAE,yBAAyB;EACpC,UAAU,EAAE,EAAE;CACf,CAAC;AAEF,MAAM,kBAAkB;EAItB,YAAY,IAAI;IACd,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC9C,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;EAChD,CAAC;CACF;AAED,MAAM,QAAQ,GAAG,CAAC,IAAwB,EAAE,EAAE;EAC5C,OAAO,CAAC;;;oBAGU,IAAI,CAAC,YAAY,CAAC;oBAClB,IAAI,CAAC,YAAY,CAAC;;GAEnC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACvC,KAAK,CAAC,IAAI,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;AAExC,MAAM,CAAC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACxC,MAAM,CAAC,IAAI,GAAG,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;AACzC,MAAM,CAAC,UAAU,GAAG;EAClB,CAAC,KAAK,EAAE,EAAE,CAAC;MACP,KAAK,EAAE;;;;;;;;;;;;;;;;;;GAkBV;CACF,CAAA","sourcesContent":["export default {\n title: 'dev/Components/PaymentDetails',\n component: 'justifi-payment-details',\n parameters: {},\n};\n\nclass PaymentDetailsArgs {\n 'auth-token': string;\n 'payment-id': string;\n\n constructor(args) {\n this['auth-token'] = args['auth-token'] || '';\n this['payment-id'] = args['payment-id'] || '';\n }\n}\n\nconst Template = (args: PaymentDetailsArgs) => {\n return (`\n <justifi-payment-details\n data-testid=\"justifi-payment-details\"\n auth-token=\"${args['auth-token']}\"\n payment-id=\"${args['payment-id']}\"\n />\n `);\n};\n\nexport const Basic = Template.bind({});\nBasic.args = new PaymentDetailsArgs({});\n\nexport const Styled = Template.bind({});\nStyled.args = new PaymentDetailsArgs({});\nStyled.decorators = [\n (Story) => `\n ${Story()}\n <style>\n justifi-payment-details::part(detail-head) {\n background-color: rgba(100, 200, 250, 0.2);\n border-left: 4px solid rgba(100, 200, 250, 1);\n }\n justifi-payment-details::part(detail-info-item-title),\n justifi-payment-details::part(detail-method-item-title) {\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.8);\n text-align: center;\n padding: 0 10px;\n color: white !important;\n }\n justifi-payment-details::part(detail-metadata) {\n background-color: rgba(100,100,100,0.2)\n }\n </style>\n `\n]\n"]}
@@ -6,3 +6,8 @@ justifi-payment-method-form iframe {
6
6
  border: none;
7
7
  width: 100%;
8
8
  }
9
+
10
+ iframe {
11
+ width: 1px;
12
+ min-width: 100%;
13
+ }
@@ -1,4 +1,5 @@
1
1
  import { Host, h } from "@stencil/core";
2
+ import iFrameResize from "iframe-resizer/js/iframeResizer";
2
3
  import { MessageEventType } from "./message-event-types";
3
4
  import packageJson from "../../../package.json";
4
5
  import getComputedTheme from "./get-computed-theme";
@@ -9,7 +10,6 @@ export class PaymentMethodForm {
9
10
  this.paymentMethodFormValidationMode = undefined;
10
11
  this.iframeOrigin = undefined;
11
12
  this.singleLine = undefined;
12
- this.height = 55;
13
13
  }
14
14
  connectedCallback() {
15
15
  window.addEventListener('message', this.dispatchMessageEvent.bind(this));
@@ -17,10 +17,6 @@ export class PaymentMethodForm {
17
17
  disconnectedCallback() {
18
18
  window.removeEventListener('message', this.dispatchMessageEvent.bind(this));
19
19
  }
20
- componentShouldUpdate() {
21
- this.sendStyleOverrides();
22
- this.resize();
23
- }
24
20
  sendStyleOverrides() {
25
21
  if (this.computedTheme) {
26
22
  this.postMessage(MessageEventType[this.paymentMethodFormType].styleOverrides, { styleOverrides: this.computedTheme });
@@ -33,14 +29,14 @@ export class PaymentMethodForm {
33
29
  if (messageType === MessageEventType[this.paymentMethodFormType].ready) {
34
30
  this.paymentMethodFormReady.emit(messageData);
35
31
  }
36
- if (messageType === MessageEventType[this.paymentMethodFormType].resize) {
37
- this.height = messageData.height;
38
- }
39
32
  }
40
33
  postMessage(eventType, payload) {
41
34
  var _a, _b;
42
35
  (_b = (_a = this.iframeElement) === null || _a === void 0 ? void 0 : _a.contentWindow) === null || _b === void 0 ? void 0 : _b.postMessage(Object.assign({ eventType: eventType }, payload), this.iframeOrigin || process.env.IFRAME_ORIGIN || '*');
43
36
  }
37
+ async resize() {
38
+ this.postMessage(MessageEventType[this.paymentMethodFormType].resize);
39
+ }
44
40
  async postMessageWithResponseListener(eventType, payload) {
45
41
  return new Promise(resolve => {
46
42
  const responseListener = (event) => {
@@ -66,9 +62,6 @@ export class PaymentMethodForm {
66
62
  async validate() {
67
63
  return this.postMessageWithResponseListener(MessageEventType[this.paymentMethodFormType].validate);
68
64
  }
69
- async resize() {
70
- this.postMessage(MessageEventType[this.paymentMethodFormType].resize);
71
- }
72
65
  composeQueryParams(values) {
73
66
  const queryParams = values.map(value => {
74
67
  if (value === values[0]) {
@@ -93,9 +86,11 @@ export class PaymentMethodForm {
93
86
  return iframeSrc.concat(this.composeQueryParams(paramsList));
94
87
  }
95
88
  render() {
96
- return (h(Host, null, h("iframe", { id: `justifi-payment-method-form-${this.paymentMethodFormType}`, src: this.getIframeSrc(), ref: el => (this.iframeElement = el), height: this.height, onLoad: () => {
89
+ return (h(Host, null, h("iframe", { id: `justifi-payment-method-form-${this.paymentMethodFormType}`, src: this.getIframeSrc(), ref: el => {
90
+ this.iframeElement = el;
91
+ }, onLoad: () => {
92
+ iFrameResize({ log: true }, this.iframeElement);
97
93
  this.sendStyleOverrides();
98
- this.resize();
99
94
  } })));
100
95
  }
101
96
  static get is() { return "justifi-payment-method-form"; }
@@ -181,11 +176,6 @@ export class PaymentMethodForm {
181
176
  }
182
177
  };
183
178
  }
184
- static get states() {
185
- return {
186
- "height": {}
187
- };
188
- }
189
179
  static get events() {
190
180
  return [{
191
181
  "method": "paymentMethodFormReady",
@@ -221,6 +211,23 @@ export class PaymentMethodForm {
221
211
  }
222
212
  static get methods() {
223
213
  return {
214
+ "resize": {
215
+ "complexType": {
216
+ "signature": "() => Promise<any>",
217
+ "parameters": [],
218
+ "references": {
219
+ "Promise": {
220
+ "location": "global",
221
+ "id": "global::Promise"
222
+ }
223
+ },
224
+ "return": "Promise<any>"
225
+ },
226
+ "docs": {
227
+ "text": "",
228
+ "tags": []
229
+ }
230
+ },
224
231
  "tokenize": {
225
232
  "complexType": {
226
233
  "signature": "(clientId: string, paymentMethodMetadata: any, account?: string) => Promise<CreatePaymentMethodResponse>",
@@ -268,23 +275,6 @@ export class PaymentMethodForm {
268
275
  "text": "",
269
276
  "tags": []
270
277
  }
271
- },
272
- "resize": {
273
- "complexType": {
274
- "signature": "() => Promise<any>",
275
- "parameters": [],
276
- "references": {
277
- "Promise": {
278
- "location": "global",
279
- "id": "global::Promise"
280
- }
281
- },
282
- "return": "Promise<any>"
283
- },
284
- "docs": {
285
- "text": "",
286
- "tags": []
287
- }
288
278
  }
289
279
  };
290
280
  }
@@ -1 +1 @@
1
- {"version":3,"file":"payment-method-form.js","sourceRoot":"","sources":["../../../../src/components/payment-method-form/payment-method-form.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Event, Host, Prop, h, EventEmitter, Method, State } from '@stencil/core';\nimport { MessageEventType } from './message-event-types';\nimport { Theme } from './theme';\nimport packageJson from '../../../package.json';\nimport getComputedTheme from './get-computed-theme';\nimport { CreatePaymentMethodResponse } from './payment-method-responses';\n\n@Component({\n tag: 'justifi-payment-method-form',\n styleUrl: 'payment-method-form.css',\n shadow: false,\n})\nexport class PaymentMethodForm {\n @Prop() paymentMethodFormType: 'card' | 'bankAccount';\n @Prop({\n mutable: true,\n })\n paymentMethodFormValidationMode: 'onChange' | 'onBlur' | 'onSubmit' | 'onTouched' | 'all';\n @Prop() iframeOrigin?: string;\n @Prop() singleLine: boolean;\n @Event({ bubbles: true }) paymentMethodFormReady: EventEmitter;\n @Event({ bubbles: true }) paymentMethodFormTokenize: EventEmitter<{ data: any }>;\n @State() height: number = 55;\n\n private computedTheme: Theme = getComputedTheme();\n\n iframeElement!: HTMLIFrameElement;\n\n connectedCallback() {\n window.addEventListener('message', this.dispatchMessageEvent.bind(this));\n }\n\n disconnectedCallback() {\n window.removeEventListener('message', this.dispatchMessageEvent.bind(this));\n }\n\n componentShouldUpdate() {\n this.sendStyleOverrides();\n this.resize();\n }\n\n sendStyleOverrides() {\n if (this.computedTheme) {\n this.postMessage(MessageEventType[this.paymentMethodFormType].styleOverrides, { styleOverrides: this.computedTheme });\n }\n }\n\n private dispatchMessageEvent(messageEvent: MessageEvent) {\n const messagePayload = messageEvent.data;\n const messageType = messagePayload.eventType;\n const messageData = messagePayload.data;\n\n if (messageType === MessageEventType[this.paymentMethodFormType].ready) {\n this.paymentMethodFormReady.emit(messageData);\n }\n\n if (messageType === MessageEventType[this.paymentMethodFormType].resize) {\n this.height = messageData.height;\n }\n }\n\n private postMessage(eventType: string, payload?: any) {\n this.iframeElement?.contentWindow?.postMessage({ eventType: eventType, ...payload }, this.iframeOrigin || process.env.IFRAME_ORIGIN || '*');\n }\n\n private async postMessageWithResponseListener(eventType: string, payload?: any): Promise<any> {\n return new Promise(resolve => {\n const responseListener = (event: MessageEvent) => {\n if (event.data.eventType !== eventType) return;\n window.removeEventListener('message', responseListener);\n resolve(event.data.data);\n };\n window.addEventListener('message', responseListener);\n this.postMessage(eventType, payload);\n });\n }\n\n @Method()\n async tokenize(clientId: string, paymentMethodMetadata: any, account?: string): Promise<CreatePaymentMethodResponse> {\n const eventType = MessageEventType[this.paymentMethodFormType].tokenize;\n const payload = {\n clientId: clientId,\n componentVersion: packageJson.version,\n paymentMethodMetadata: paymentMethodMetadata,\n account: account,\n };\n\n return this.postMessageWithResponseListener(eventType, payload);\n }\n\n @Method()\n async validate(): Promise<any> {\n return this.postMessageWithResponseListener(MessageEventType[this.paymentMethodFormType].validate);\n }\n\n @Method()\n async resize(): Promise<any> {\n this.postMessage(MessageEventType[this.paymentMethodFormType].resize);\n }\n\n private composeQueryParams(values: string[]) {\n const queryParams = values.map(value => {\n if (value === values[0]) {\n return (value = `?${value}`);\n } else {\n return (value = `&${value}`);\n }\n });\n return queryParams.join('');\n }\n\n private getIframeSrc() {\n const iframeOrigin = this.iframeOrigin || process.env.IFRAME_ORIGIN || 'https://js.justifi.ai/v2';\n let iframeSrc = `${iframeOrigin}/${this.paymentMethodFormType}`;\n let paramsList = [];\n if (this.paymentMethodFormValidationMode) {\n paramsList.push(`validationMode=${this.paymentMethodFormValidationMode}`);\n }\n if (this.singleLine) {\n paramsList.push(`singleLine=${this.singleLine}`);\n }\n\n return iframeSrc.concat(this.composeQueryParams(paramsList));\n }\n\n render() {\n return (\n <Host>\n <iframe\n id={`justifi-payment-method-form-${this.paymentMethodFormType}`}\n src={this.getIframeSrc()}\n ref={el => (this.iframeElement = el as HTMLIFrameElement)}\n height={this.height}\n onLoad={() => {\n this.sendStyleOverrides();\n this.resize();\n }}\n ></iframe>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"payment-method-form.js","sourceRoot":"","sources":["../../../../src/components/payment-method-form/payment-method-form.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Event, Host, Prop, h, EventEmitter, Method } from '@stencil/core';\nimport iFrameResize from 'iframe-resizer/js/iframeResizer';\nimport { MessageEventType } from './message-event-types';\nimport { Theme } from './theme';\nimport packageJson from '../../../package.json';\nimport getComputedTheme from './get-computed-theme';\nimport { CreatePaymentMethodResponse } from './payment-method-responses';\n\n@Component({\n tag: 'justifi-payment-method-form',\n styleUrl: 'payment-method-form.css',\n shadow: false,\n})\nexport class PaymentMethodForm {\n @Prop() paymentMethodFormType: 'card' | 'bankAccount';\n @Prop({\n mutable: true,\n })\n paymentMethodFormValidationMode: 'onChange' | 'onBlur' | 'onSubmit' | 'onTouched' | 'all';\n @Prop() iframeOrigin?: string;\n @Prop() singleLine: boolean;\n @Event({ bubbles: true }) paymentMethodFormReady: EventEmitter;\n @Event({ bubbles: true }) paymentMethodFormTokenize: EventEmitter<{ data: any }>;\n\n private computedTheme: Theme = getComputedTheme();\n\n iframeElement!: HTMLIFrameElement;\n\n connectedCallback() {\n window.addEventListener('message', this.dispatchMessageEvent.bind(this));\n }\n\n disconnectedCallback() {\n window.removeEventListener('message', this.dispatchMessageEvent.bind(this));\n }\n\n sendStyleOverrides() {\n if (this.computedTheme) {\n this.postMessage(MessageEventType[this.paymentMethodFormType].styleOverrides, { styleOverrides: this.computedTheme });\n }\n }\n\n private dispatchMessageEvent(messageEvent: MessageEvent) {\n const messagePayload = messageEvent.data;\n const messageType = messagePayload.eventType;\n const messageData = messagePayload.data;\n\n if (messageType === MessageEventType[this.paymentMethodFormType].ready) {\n this.paymentMethodFormReady.emit(messageData);\n }\n }\n\n private postMessage(eventType: string, payload?: any) {\n this.iframeElement?.contentWindow?.postMessage({ eventType: eventType, ...payload }, this.iframeOrigin || process.env.IFRAME_ORIGIN || '*');\n }\n\n @Method()\n async resize(): Promise<any> {\n this.postMessage(MessageEventType[this.paymentMethodFormType].resize);\n }\n\n private async postMessageWithResponseListener(eventType: string, payload?: any): Promise<any> {\n return new Promise(resolve => {\n const responseListener = (event: MessageEvent) => {\n if (event.data.eventType !== eventType) return;\n window.removeEventListener('message', responseListener);\n resolve(event.data.data);\n };\n window.addEventListener('message', responseListener);\n this.postMessage(eventType, payload);\n });\n }\n\n @Method()\n async tokenize(clientId: string, paymentMethodMetadata: any, account?: string): Promise<CreatePaymentMethodResponse> {\n const eventType = MessageEventType[this.paymentMethodFormType].tokenize;\n const payload = {\n clientId: clientId,\n componentVersion: packageJson.version,\n paymentMethodMetadata: paymentMethodMetadata,\n account: account,\n };\n\n return this.postMessageWithResponseListener(eventType, payload);\n }\n\n @Method()\n async validate(): Promise<any> {\n return this.postMessageWithResponseListener(MessageEventType[this.paymentMethodFormType].validate);\n }\n\n private composeQueryParams(values: string[]) {\n const queryParams = values.map(value => {\n if (value === values[0]) {\n return (value = `?${value}`);\n } else {\n return (value = `&${value}`);\n }\n });\n return queryParams.join('');\n }\n\n private getIframeSrc() {\n const iframeOrigin = this.iframeOrigin || process.env.IFRAME_ORIGIN || 'https://js.justifi.ai/v2';\n let iframeSrc = `${iframeOrigin}/${this.paymentMethodFormType}`;\n let paramsList = [];\n if (this.paymentMethodFormValidationMode) {\n paramsList.push(`validationMode=${this.paymentMethodFormValidationMode}`);\n }\n if (this.singleLine) {\n paramsList.push(`singleLine=${this.singleLine}`);\n }\n\n return iframeSrc.concat(this.composeQueryParams(paramsList));\n }\n\n render() {\n return (\n <Host>\n <iframe\n id={`justifi-payment-method-form-${this.paymentMethodFormType}`}\n src={this.getIframeSrc()}\n ref={el => {\n this.iframeElement = el as HTMLIFrameElement;\n }}\n onLoad={() => {\n iFrameResize({ log: true }, this.iframeElement);\n this.sendStyleOverrides();\n }}\n ></iframe>\n </Host>\n );\n }\n}\n"]}
@@ -9,7 +9,7 @@ describe('justifi-payment-method-form', () => {
9
9
  });
10
10
  expect(page.root).toEqualHtml(`
11
11
  <justifi-payment-method-form>
12
- <iframe height="55" id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
12
+ <iframe id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
13
13
  </justifi-payment-method-form>
14
14
  `);
15
15
  });
@@ -20,7 +20,7 @@ describe('justifi-payment-method-form', () => {
20
20
  });
21
21
  expect(page.root).toEqualHtml(`
22
22
  <justifi-payment-method-form>
23
- <iframe height="55" id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
23
+ <iframe id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
24
24
  </justifi-payment-method-form>
25
25
  `);
26
26
  });
@@ -31,7 +31,7 @@ describe('justifi-payment-method-form', () => {
31
31
  });
32
32
  expect(page.root).toEqualHtml(`
33
33
  <justifi-payment-method-form>
34
- <iframe height="55" id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount"></iframe>
34
+ <iframe id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount"></iframe>
35
35
  </justifi-payment-method-form>
36
36
  `);
37
37
  });
@@ -42,7 +42,7 @@ describe('justifi-payment-method-form', () => {
42
42
  });
43
43
  expect(page.root).toEqualHtml(`
44
44
  <justifi-payment-method-form>
45
- <iframe height="55" id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount?validationMode=onChange"></iframe>
45
+ <iframe id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount?validationMode=onChange"></iframe>
46
46
  </justifi-payment-method-form>
47
47
  `);
48
48
  });
@@ -53,7 +53,7 @@ describe('justifi-payment-method-form', () => {
53
53
  });
54
54
  expect(page.root).toEqualHtml(`
55
55
  <justifi-payment-method-form>
56
- <iframe height="55" id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount?validationMode=onBlur"></iframe>
56
+ <iframe id="justifi-payment-method-form-bankAccount" src="https://js.justifi.ai/v2/bankAccount?validationMode=onBlur"></iframe>
57
57
  </justifi-payment-method-form>
58
58
  `);
59
59
  });
@@ -64,7 +64,7 @@ describe('justifi-payment-method-form', () => {
64
64
  });
65
65
  expect(page.root).toEqualHtml(`
66
66
  <justifi-payment-method-form>
67
- <iframe height="55" id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
67
+ <iframe id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card"></iframe>
68
68
  </justifi-payment-method-form>
69
69
  `);
70
70
  });
@@ -75,7 +75,7 @@ describe('justifi-payment-method-form', () => {
75
75
  });
76
76
  expect(page.root).toEqualHtml(`
77
77
  <justifi-payment-method-form>
78
- <iframe height="55" id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card?singleLine=true"></iframe>
78
+ <iframe id="justifi-payment-method-form-card" src="https://js.justifi.ai/v2/card?singleLine=true"></iframe>
79
79
  </justifi-payment-method-form>
80
80
  `);
81
81
  });
@@ -1 +1 @@
1
- {"version":3,"file":"payment-method-form.spec.js","sourceRoot":"","sources":["../../../../../src/components/payment-method-form/test/payment-method-form.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["import { h } from '@stencil/core';\nimport { newSpecPage } from '@stencil/core/testing';\nimport { PaymentMethodForm } from '../payment-method-form';\n\ndescribe('justifi-payment-method-form', () => {\n it('renders an iframe', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe when paymentMethodFormType is card', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a bank iframe when paymentMethodFormType is bank', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with validationMode when paymentMethodFormType is card and paymentMethodFormValidationMode is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\" paymentMethodFormValidationMode=\"onChange\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount?validationMode=onChange\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with validationMode when paymentMethodFormType is card and paymentMethodFormValidationMode is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\" paymentMethodFormValidationMode=\"onBlur\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount?validationMode=onBlur\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with iframeOrigin when paymentMethodFormType is card and iframeOrigin is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\" iframeOrigin=\"https://js.justifi.ai/v2\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with singleLine when paymentMethodFormType is card and singleLine is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\" singleLine={true}></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe height=\"55\" id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card?singleLine=true\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n});\n"]}
1
+ {"version":3,"file":"payment-method-form.spec.js","sourceRoot":"","sources":["../../../../../src/components/payment-method-form/test/payment-method-form.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["import { h } from '@stencil/core';\nimport { newSpecPage } from '@stencil/core/testing';\nimport { PaymentMethodForm } from '../payment-method-form';\n\ndescribe('justifi-payment-method-form', () => {\n it('renders an iframe', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe when paymentMethodFormType is card', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a bank iframe when paymentMethodFormType is bank', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\"></justifi-payment-method-form>,\n });\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with validationMode when paymentMethodFormType is card and paymentMethodFormValidationMode is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\" paymentMethodFormValidationMode=\"onChange\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount?validationMode=onChange\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with validationMode when paymentMethodFormType is card and paymentMethodFormValidationMode is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"bankAccount\" paymentMethodFormValidationMode=\"onBlur\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-bankAccount\" src=\"https://js.justifi.ai/v2/bankAccount?validationMode=onBlur\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with iframeOrigin when paymentMethodFormType is card and iframeOrigin is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\" iframeOrigin=\"https://js.justifi.ai/v2\"></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n\n it('renders a card iframe with singleLine when paymentMethodFormType is card and singleLine is set', async () => {\n const page = await newSpecPage({\n components: [PaymentMethodForm],\n template: () => <justifi-payment-method-form paymentMethodFormType=\"card\" singleLine={true}></justifi-payment-method-form>,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payment-method-form>\n <iframe id=\"justifi-payment-method-form-card\" src=\"https://js.justifi.ai/v2/card?singleLine=true\"></iframe>\n </justifi-payment-method-form>\n `);\n });\n});\n"]}