@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
@@ -2,7 +2,1478 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-83b2ec02.js');
5
+ const index = require('./index-3533152c.js');
6
+
7
+ function createCommonjsModule(fn, basedir, module) {
8
+ return module = {
9
+ path: basedir,
10
+ exports: {},
11
+ require: function (path, base) {
12
+ return commonjsRequire();
13
+ }
14
+ }, fn(module, module.exports), module.exports;
15
+ }
16
+
17
+ function commonjsRequire () {
18
+ throw new Error('Dynamic requires are not currently supported by @rollup/plugin-commonjs');
19
+ }
20
+
21
+ var iframeResizer = createCommonjsModule(function (module) {
22
+ (function (undefined$1) {
23
+ if (typeof window === 'undefined') return // don't run for server side render
24
+
25
+ var count = 0,
26
+ logEnabled = false,
27
+ hiddenCheckEnabled = false,
28
+ msgHeader = 'message',
29
+ msgHeaderLen = msgHeader.length,
30
+ msgId = '[iFrameSizer]', // Must match iframe msg ID
31
+ msgIdLen = msgId.length,
32
+ pagePosition = null,
33
+ requestAnimationFrame = window.requestAnimationFrame,
34
+ resetRequiredMethods = Object.freeze({
35
+ max: 1,
36
+ scroll: 1,
37
+ bodyScroll: 1,
38
+ documentElementScroll: 1
39
+ }),
40
+ settings = {},
41
+ timer = null,
42
+ defaults = Object.freeze({
43
+ autoResize: true,
44
+ bodyBackground: null,
45
+ bodyMargin: null,
46
+ bodyMarginV1: 8,
47
+ bodyPadding: null,
48
+ checkOrigin: true,
49
+ inPageLinks: false,
50
+ enablePublicMethods: true,
51
+ heightCalculationMethod: 'bodyOffset',
52
+ id: 'iFrameResizer',
53
+ interval: 32,
54
+ log: false,
55
+ maxHeight: Infinity,
56
+ maxWidth: Infinity,
57
+ minHeight: 0,
58
+ minWidth: 0,
59
+ mouseEvents: true,
60
+ resizeFrom: 'parent',
61
+ scrolling: false,
62
+ sizeHeight: true,
63
+ sizeWidth: false,
64
+ warningTimeout: 5000,
65
+ tolerance: 0,
66
+ widthCalculationMethod: 'scroll',
67
+ onClose: function () {
68
+ return true
69
+ },
70
+ onClosed: function () {},
71
+ onInit: function () {},
72
+ onMessage: function () {
73
+ warn('onMessage function not defined');
74
+ },
75
+ onMouseEnter: function () {},
76
+ onMouseLeave: function () {},
77
+ onResized: function () {},
78
+ onScroll: function () {
79
+ return true
80
+ }
81
+ });
82
+
83
+ function getMutationObserver() {
84
+ return (
85
+ window.MutationObserver ||
86
+ window.WebKitMutationObserver ||
87
+ window.MozMutationObserver
88
+ )
89
+ }
90
+
91
+ function addEventListener(el, evt, func) {
92
+ el.addEventListener(evt, func, false);
93
+ }
94
+
95
+ function removeEventListener(el, evt, func) {
96
+ el.removeEventListener(evt, func, false);
97
+ }
98
+
99
+ function setupRequestAnimationFrame() {
100
+ var vendors = ['moz', 'webkit', 'o', 'ms'];
101
+ var x;
102
+
103
+ // Remove vendor prefixing if prefixed and break early if not
104
+ for (x = 0; x < vendors.length && !requestAnimationFrame; x += 1) {
105
+ requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];
106
+ }
107
+
108
+ if (requestAnimationFrame) {
109
+ // Firefox extension content-scripts have a globalThis object that is not the same as window.
110
+ // Binding `requestAnimationFrame` to window allows the function to work and prevents errors
111
+ // being thrown when run in that context, and should be a no-op in every other context.
112
+ requestAnimationFrame = requestAnimationFrame.bind(window);
113
+ } else {
114
+ log('setup', 'RequestAnimationFrame not supported');
115
+ }
116
+ }
117
+
118
+ function getMyID(iframeId) {
119
+ var retStr = 'Host page: ' + iframeId;
120
+
121
+ if (window.top !== window.self) {
122
+ retStr =
123
+ window.parentIFrame && window.parentIFrame.getId
124
+ ? window.parentIFrame.getId() + ': ' + iframeId
125
+ : 'Nested host page: ' + iframeId;
126
+ }
127
+
128
+ return retStr
129
+ }
130
+
131
+ function formatLogHeader(iframeId) {
132
+ return msgId + '[' + getMyID(iframeId) + ']'
133
+ }
134
+
135
+ function isLogEnabled(iframeId) {
136
+ return settings[iframeId] ? settings[iframeId].log : logEnabled
137
+ }
138
+
139
+ function log(iframeId, msg) {
140
+ output('log', iframeId, msg, isLogEnabled(iframeId));
141
+ }
142
+
143
+ function info(iframeId, msg) {
144
+ output('info', iframeId, msg, isLogEnabled(iframeId));
145
+ }
146
+
147
+ function warn(iframeId, msg) {
148
+ output('warn', iframeId, msg, true);
149
+ }
150
+
151
+ function output(type, iframeId, msg, enabled) {
152
+ if (true === enabled && 'object' === typeof window.console) {
153
+ // eslint-disable-next-line no-console
154
+ console[type](formatLogHeader(iframeId), msg);
155
+ }
156
+ }
157
+
158
+ function iFrameListener(event) {
159
+ function resizeIFrame() {
160
+ function resize() {
161
+ setSize(messageData);
162
+ setPagePosition(iframeId);
163
+ on('onResized', messageData);
164
+ }
165
+
166
+ ensureInRange('Height');
167
+ ensureInRange('Width');
168
+
169
+ syncResize(resize, messageData, 'init');
170
+ }
171
+
172
+ function processMsg() {
173
+ var data = msg.slice(msgIdLen).split(':');
174
+ var height = data[1] ? parseInt(data[1], 10) : 0;
175
+ var iframe = settings[data[0]] && settings[data[0]].iframe;
176
+ var compStyle = getComputedStyle(iframe);
177
+
178
+ return {
179
+ iframe: iframe,
180
+ id: data[0],
181
+ height: height + getPaddingEnds(compStyle) + getBorderEnds(compStyle),
182
+ width: data[2],
183
+ type: data[3]
184
+ }
185
+ }
186
+
187
+ function getPaddingEnds(compStyle) {
188
+ if (compStyle.boxSizing !== 'border-box') {
189
+ return 0
190
+ }
191
+ var top = compStyle.paddingTop ? parseInt(compStyle.paddingTop, 10) : 0;
192
+ var bot = compStyle.paddingBottom
193
+ ? parseInt(compStyle.paddingBottom, 10)
194
+ : 0;
195
+ return top + bot
196
+ }
197
+
198
+ function getBorderEnds(compStyle) {
199
+ if (compStyle.boxSizing !== 'border-box') {
200
+ return 0
201
+ }
202
+ var top = compStyle.borderTopWidth
203
+ ? parseInt(compStyle.borderTopWidth, 10)
204
+ : 0;
205
+ var bot = compStyle.borderBottomWidth
206
+ ? parseInt(compStyle.borderBottomWidth, 10)
207
+ : 0;
208
+ return top + bot
209
+ }
210
+
211
+ function ensureInRange(Dimension) {
212
+ var max = Number(settings[iframeId]['max' + Dimension]),
213
+ min = Number(settings[iframeId]['min' + Dimension]),
214
+ dimension = Dimension.toLowerCase(),
215
+ size = Number(messageData[dimension]);
216
+
217
+ log(iframeId, 'Checking ' + dimension + ' is in range ' + min + '-' + max);
218
+
219
+ if (size < min) {
220
+ size = min;
221
+ log(iframeId, 'Set ' + dimension + ' to min value');
222
+ }
223
+
224
+ if (size > max) {
225
+ size = max;
226
+ log(iframeId, 'Set ' + dimension + ' to max value');
227
+ }
228
+
229
+ messageData[dimension] = '' + size;
230
+ }
231
+
232
+ function isMessageFromIFrame() {
233
+ function checkAllowedOrigin() {
234
+ function checkList() {
235
+ var i = 0,
236
+ retCode = false;
237
+
238
+ log(
239
+ iframeId,
240
+ 'Checking connection is from allowed list of origins: ' +
241
+ checkOrigin
242
+ );
243
+
244
+ for (; i < checkOrigin.length; i++) {
245
+ if (checkOrigin[i] === origin) {
246
+ retCode = true;
247
+ break
248
+ }
249
+ }
250
+ return retCode
251
+ }
252
+
253
+ function checkSingle() {
254
+ var remoteHost = settings[iframeId] && settings[iframeId].remoteHost;
255
+ log(iframeId, 'Checking connection is from: ' + remoteHost);
256
+ return origin === remoteHost
257
+ }
258
+
259
+ return checkOrigin.constructor === Array ? checkList() : checkSingle()
260
+ }
261
+
262
+ var origin = event.origin,
263
+ checkOrigin = settings[iframeId] && settings[iframeId].checkOrigin;
264
+
265
+ if (checkOrigin && '' + origin !== 'null' && !checkAllowedOrigin()) {
266
+ throw new Error(
267
+ 'Unexpected message received from: ' +
268
+ origin +
269
+ ' for ' +
270
+ messageData.iframe.id +
271
+ '. Message was: ' +
272
+ event.data +
273
+ '. This error can be disabled by setting the checkOrigin: false option or by providing of array of trusted domains.'
274
+ )
275
+ }
276
+
277
+ return true
278
+ }
279
+
280
+ function isMessageForUs() {
281
+ return (
282
+ msgId === ('' + msg).slice(0, msgIdLen) &&
283
+ msg.slice(msgIdLen).split(':')[0] in settings
284
+ ) // ''+Protects against non-string msg
285
+ }
286
+
287
+ function isMessageFromMetaParent() {
288
+ // Test if this message is from a parent above us. This is an ugly test, however, updating
289
+ // the message format would break backwards compatibility.
290
+ var retCode = messageData.type in { true: 1, false: 1, undefined: 1 };
291
+
292
+ if (retCode) {
293
+ log(iframeId, 'Ignoring init message from meta parent page');
294
+ }
295
+
296
+ return retCode
297
+ }
298
+
299
+ function getMsgBody(offset) {
300
+ return msg.slice(msg.indexOf(':') + msgHeaderLen + offset)
301
+ }
302
+
303
+ function forwardMsgFromIFrame(msgBody) {
304
+ log(
305
+ iframeId,
306
+ 'onMessage passed: {iframe: ' +
307
+ messageData.iframe.id +
308
+ ', message: ' +
309
+ msgBody +
310
+ '}'
311
+ );
312
+
313
+ on('onMessage', {
314
+ iframe: messageData.iframe,
315
+ message: JSON.parse(msgBody)
316
+ });
317
+
318
+ log(iframeId, '--');
319
+ }
320
+
321
+ function getPageInfo() {
322
+ var bodyPosition = document.body.getBoundingClientRect(),
323
+ iFramePosition = messageData.iframe.getBoundingClientRect();
324
+
325
+ return JSON.stringify({
326
+ iframeHeight: iFramePosition.height,
327
+ iframeWidth: iFramePosition.width,
328
+ clientHeight: Math.max(
329
+ document.documentElement.clientHeight,
330
+ window.innerHeight || 0
331
+ ),
332
+ clientWidth: Math.max(
333
+ document.documentElement.clientWidth,
334
+ window.innerWidth || 0
335
+ ),
336
+ offsetTop: parseInt(iFramePosition.top - bodyPosition.top, 10),
337
+ offsetLeft: parseInt(iFramePosition.left - bodyPosition.left, 10),
338
+ scrollTop: window.pageYOffset,
339
+ scrollLeft: window.pageXOffset,
340
+ documentHeight: document.documentElement.clientHeight,
341
+ documentWidth: document.documentElement.clientWidth,
342
+ windowHeight: window.innerHeight,
343
+ windowWidth: window.innerWidth
344
+ })
345
+ }
346
+
347
+ function sendPageInfoToIframe(iframe, iframeId) {
348
+ function debouncedTrigger() {
349
+ trigger('Send Page Info', 'pageInfo:' + getPageInfo(), iframe, iframeId);
350
+ }
351
+ debounceFrameEvents(debouncedTrigger, 32, iframeId);
352
+ }
353
+
354
+ function startPageInfoMonitor() {
355
+ function setListener(type, func) {
356
+ function sendPageInfo() {
357
+ if (settings[id]) {
358
+ sendPageInfoToIframe(settings[id].iframe, id);
359
+ } else {
360
+ stop();
361
+ }
362
+ }
363
+ ['scroll', 'resize'].forEach(function (evt) {
364
+ log(id, type + evt + ' listener for sendPageInfo');
365
+ func(window, evt, sendPageInfo);
366
+ });
367
+ }
368
+
369
+ function stop() {
370
+ setListener('Remove ', removeEventListener);
371
+ }
372
+
373
+ function start() {
374
+ setListener('Add ', addEventListener);
375
+ }
376
+
377
+ var id = iframeId; // Create locally scoped copy of iFrame ID
378
+
379
+ start();
380
+
381
+ if (settings[id]) {
382
+ settings[id].stopPageInfo = stop;
383
+ }
384
+ }
385
+
386
+ function stopPageInfoMonitor() {
387
+ if (settings[iframeId] && settings[iframeId].stopPageInfo) {
388
+ settings[iframeId].stopPageInfo();
389
+ delete settings[iframeId].stopPageInfo;
390
+ }
391
+ }
392
+
393
+ function checkIFrameExists() {
394
+ var retBool = true;
395
+
396
+ if (null === messageData.iframe) {
397
+ warn(iframeId, 'IFrame (' + messageData.id + ') not found');
398
+ retBool = false;
399
+ }
400
+ return retBool
401
+ }
402
+
403
+ function getElementPosition(target) {
404
+ var iFramePosition = target.getBoundingClientRect();
405
+
406
+ getPagePosition(iframeId);
407
+
408
+ return {
409
+ x: Math.floor(Number(iFramePosition.left) + Number(pagePosition.x)),
410
+ y: Math.floor(Number(iFramePosition.top) + Number(pagePosition.y))
411
+ }
412
+ }
413
+
414
+ function scrollRequestFromChild(addOffset) {
415
+ /* istanbul ignore next */ // Not testable in Karma
416
+ function reposition() {
417
+ pagePosition = newPosition;
418
+ scrollTo();
419
+ log(iframeId, '--');
420
+ }
421
+
422
+ function calcOffset() {
423
+ return {
424
+ x: Number(messageData.width) + offset.x,
425
+ y: Number(messageData.height) + offset.y
426
+ }
427
+ }
428
+
429
+ function scrollParent() {
430
+ if (window.parentIFrame) {
431
+ window.parentIFrame['scrollTo' + (addOffset ? 'Offset' : '')](
432
+ newPosition.x,
433
+ newPosition.y
434
+ );
435
+ } else {
436
+ warn(
437
+ iframeId,
438
+ 'Unable to scroll to requested position, window.parentIFrame not found'
439
+ );
440
+ }
441
+ }
442
+
443
+ var offset = addOffset
444
+ ? getElementPosition(messageData.iframe)
445
+ : { x: 0, y: 0 },
446
+ newPosition = calcOffset();
447
+
448
+ log(
449
+ iframeId,
450
+ 'Reposition requested from iFrame (offset x:' +
451
+ offset.x +
452
+ ' y:' +
453
+ offset.y +
454
+ ')'
455
+ );
456
+
457
+ if (window.top === window.self) {
458
+ reposition();
459
+ } else {
460
+ scrollParent();
461
+ }
462
+ }
463
+
464
+ function scrollTo() {
465
+ if (false === on('onScroll', pagePosition)) {
466
+ unsetPagePosition();
467
+ } else {
468
+ setPagePosition(iframeId);
469
+ }
470
+ }
471
+
472
+ function findTarget(location) {
473
+ function jumpToTarget() {
474
+ var jumpPosition = getElementPosition(target);
475
+
476
+ log(
477
+ iframeId,
478
+ 'Moving to in page link (#' +
479
+ hash +
480
+ ') at x: ' +
481
+ jumpPosition.x +
482
+ ' y: ' +
483
+ jumpPosition.y
484
+ );
485
+ pagePosition = {
486
+ x: jumpPosition.x,
487
+ y: jumpPosition.y
488
+ };
489
+
490
+ scrollTo();
491
+ log(iframeId, '--');
492
+ }
493
+
494
+ function jumpToParent() {
495
+ if (window.parentIFrame) {
496
+ window.parentIFrame.moveToAnchor(hash);
497
+ } else {
498
+ log(
499
+ iframeId,
500
+ 'In page link #' +
501
+ hash +
502
+ ' not found and window.parentIFrame not found'
503
+ );
504
+ }
505
+ }
506
+
507
+ var hash = location.split('#')[1] || '',
508
+ hashData = decodeURIComponent(hash),
509
+ target =
510
+ document.getElementById(hashData) ||
511
+ document.getElementsByName(hashData)[0];
512
+
513
+ if (target) {
514
+ jumpToTarget();
515
+ } else if (window.top === window.self) {
516
+ log(iframeId, 'In page link #' + hash + ' not found');
517
+ } else {
518
+ jumpToParent();
519
+ }
520
+ }
521
+
522
+ function onMouse(event) {
523
+ var mousePos = {};
524
+
525
+ if (Number(messageData.width) === 0 && Number(messageData.height) === 0) {
526
+ var data = getMsgBody(9).split(':');
527
+ mousePos = {
528
+ x: data[1],
529
+ y: data[0]
530
+ };
531
+ } else {
532
+ mousePos = {
533
+ x: messageData.width,
534
+ y: messageData.height
535
+ };
536
+ }
537
+
538
+ on(event, {
539
+ iframe: messageData.iframe,
540
+ screenX: Number(mousePos.x),
541
+ screenY: Number(mousePos.y),
542
+ type: messageData.type
543
+ });
544
+ }
545
+
546
+ function on(funcName, val) {
547
+ return chkEvent(iframeId, funcName, val)
548
+ }
549
+
550
+ function actionMsg() {
551
+ if (settings[iframeId] && settings[iframeId].firstRun) firstRun();
552
+
553
+ switch (messageData.type) {
554
+ case 'close': {
555
+ closeIFrame(messageData.iframe);
556
+ break
557
+ }
558
+
559
+ case 'message': {
560
+ forwardMsgFromIFrame(getMsgBody(6));
561
+ break
562
+ }
563
+
564
+ case 'mouseenter': {
565
+ onMouse('onMouseEnter');
566
+ break
567
+ }
568
+
569
+ case 'mouseleave': {
570
+ onMouse('onMouseLeave');
571
+ break
572
+ }
573
+
574
+ case 'autoResize': {
575
+ settings[iframeId].autoResize = JSON.parse(getMsgBody(9));
576
+ break
577
+ }
578
+
579
+ case 'scrollTo': {
580
+ scrollRequestFromChild(false);
581
+ break
582
+ }
583
+
584
+ case 'scrollToOffset': {
585
+ scrollRequestFromChild(true);
586
+ break
587
+ }
588
+
589
+ case 'pageInfo': {
590
+ sendPageInfoToIframe(
591
+ settings[iframeId] && settings[iframeId].iframe,
592
+ iframeId
593
+ );
594
+ startPageInfoMonitor();
595
+ break
596
+ }
597
+
598
+ case 'pageInfoStop': {
599
+ stopPageInfoMonitor();
600
+ break
601
+ }
602
+
603
+ case 'inPageLink': {
604
+ findTarget(getMsgBody(9));
605
+ break
606
+ }
607
+
608
+ case 'reset': {
609
+ resetIFrame(messageData);
610
+ break
611
+ }
612
+
613
+ case 'init': {
614
+ resizeIFrame();
615
+ on('onInit', messageData.iframe);
616
+ break
617
+ }
618
+
619
+ default: {
620
+ if (
621
+ Number(messageData.width) === 0 &&
622
+ Number(messageData.height) === 0
623
+ ) {
624
+ warn(
625
+ 'Unsupported message received (' +
626
+ messageData.type +
627
+ '), this is likely due to the iframe containing a later ' +
628
+ 'version of iframe-resizer than the parent page'
629
+ );
630
+ } else {
631
+ resizeIFrame();
632
+ }
633
+ }
634
+ }
635
+ }
636
+
637
+ function hasSettings(iframeId) {
638
+ var retBool = true;
639
+
640
+ if (!settings[iframeId]) {
641
+ retBool = false;
642
+ warn(
643
+ messageData.type +
644
+ ' No settings for ' +
645
+ iframeId +
646
+ '. Message was: ' +
647
+ msg
648
+ );
649
+ }
650
+
651
+ return retBool
652
+ }
653
+
654
+ function iFrameReadyMsgReceived() {
655
+ // eslint-disable-next-line no-restricted-syntax, guard-for-in
656
+ for (var iframeId in settings) {
657
+ trigger(
658
+ 'iFrame requested init',
659
+ createOutgoingMsg(iframeId),
660
+ settings[iframeId].iframe,
661
+ iframeId
662
+ );
663
+ }
664
+ }
665
+
666
+ function firstRun() {
667
+ if (settings[iframeId]) {
668
+ settings[iframeId].firstRun = false;
669
+ }
670
+ }
671
+
672
+ var msg = event.data,
673
+ messageData = {},
674
+ iframeId = null;
675
+
676
+ if ('[iFrameResizerChild]Ready' === msg) {
677
+ iFrameReadyMsgReceived();
678
+ } else if (isMessageForUs()) {
679
+ messageData = processMsg();
680
+ iframeId = messageData.id;
681
+ if (settings[iframeId]) {
682
+ settings[iframeId].loaded = true;
683
+ }
684
+
685
+ if (!isMessageFromMetaParent() && hasSettings(iframeId)) {
686
+ log(iframeId, 'Received: ' + msg);
687
+
688
+ if (checkIFrameExists() && isMessageFromIFrame()) {
689
+ actionMsg();
690
+ }
691
+ }
692
+ } else {
693
+ info(iframeId, 'Ignored: ' + msg);
694
+ }
695
+ }
696
+
697
+ function chkEvent(iframeId, funcName, val) {
698
+ var func = null,
699
+ retVal = null;
700
+
701
+ if (settings[iframeId]) {
702
+ func = settings[iframeId][funcName];
703
+
704
+ if ('function' === typeof func) {
705
+ retVal = func(val);
706
+ } else {
707
+ throw new TypeError(
708
+ funcName + ' on iFrame[' + iframeId + '] is not a function'
709
+ )
710
+ }
711
+ }
712
+
713
+ return retVal
714
+ }
715
+
716
+ function removeIframeListeners(iframe) {
717
+ var iframeId = iframe.id;
718
+ delete settings[iframeId];
719
+ }
720
+
721
+ function closeIFrame(iframe) {
722
+ var iframeId = iframe.id;
723
+ if (chkEvent(iframeId, 'onClose', iframeId) === false) {
724
+ log(iframeId, 'Close iframe cancelled by onClose event');
725
+ return
726
+ }
727
+ log(iframeId, 'Removing iFrame: ' + iframeId);
728
+
729
+ try {
730
+ // Catch race condition error with React
731
+ if (iframe.parentNode) {
732
+ iframe.parentNode.removeChild(iframe);
733
+ }
734
+ } catch (error) {
735
+ warn(error);
736
+ }
737
+
738
+ chkEvent(iframeId, 'onClosed', iframeId);
739
+ log(iframeId, '--');
740
+ removeIframeListeners(iframe);
741
+ }
742
+
743
+ function getPagePosition(iframeId) {
744
+ if (null === pagePosition) {
745
+ pagePosition = {
746
+ x:
747
+ window.pageXOffset === undefined$1
748
+ ? document.documentElement.scrollLeft
749
+ : window.pageXOffset,
750
+ y:
751
+ window.pageYOffset === undefined$1
752
+ ? document.documentElement.scrollTop
753
+ : window.pageYOffset
754
+ };
755
+ log(
756
+ iframeId,
757
+ 'Get page position: ' + pagePosition.x + ',' + pagePosition.y
758
+ );
759
+ }
760
+ }
761
+
762
+ function setPagePosition(iframeId) {
763
+ if (null !== pagePosition) {
764
+ window.scrollTo(pagePosition.x, pagePosition.y);
765
+ log(
766
+ iframeId,
767
+ 'Set page position: ' + pagePosition.x + ',' + pagePosition.y
768
+ );
769
+ unsetPagePosition();
770
+ }
771
+ }
772
+
773
+ function unsetPagePosition() {
774
+ pagePosition = null;
775
+ }
776
+
777
+ function resetIFrame(messageData) {
778
+ function reset() {
779
+ setSize(messageData);
780
+ trigger('reset', 'reset', messageData.iframe, messageData.id);
781
+ }
782
+
783
+ log(
784
+ messageData.id,
785
+ 'Size reset requested by ' +
786
+ ('init' === messageData.type ? 'host page' : 'iFrame')
787
+ );
788
+ getPagePosition(messageData.id);
789
+ syncResize(reset, messageData, 'reset');
790
+ }
791
+
792
+ function setSize(messageData) {
793
+ function setDimension(dimension) {
794
+ if (!messageData.id) {
795
+ log('undefined', 'messageData id not set');
796
+ return
797
+ }
798
+ messageData.iframe.style[dimension] = messageData[dimension] + 'px';
799
+ log(
800
+ messageData.id,
801
+ 'IFrame (' +
802
+ iframeId +
803
+ ') ' +
804
+ dimension +
805
+ ' set to ' +
806
+ messageData[dimension] +
807
+ 'px'
808
+ );
809
+ }
810
+
811
+ function chkZero(dimension) {
812
+ // FireFox sets dimension of hidden iFrames to zero.
813
+ // So if we detect that set up an event to check for
814
+ // when iFrame becomes visible.
815
+
816
+ /* istanbul ignore next */ // Not testable in PhantomJS
817
+ if (!hiddenCheckEnabled && '0' === messageData[dimension]) {
818
+ hiddenCheckEnabled = true;
819
+ log(iframeId, 'Hidden iFrame detected, creating visibility listener');
820
+ fixHiddenIFrames();
821
+ }
822
+ }
823
+
824
+ function processDimension(dimension) {
825
+ setDimension(dimension);
826
+ chkZero(dimension);
827
+ }
828
+
829
+ var iframeId = messageData.iframe.id;
830
+
831
+ if (settings[iframeId]) {
832
+ if (settings[iframeId].sizeHeight) {
833
+ processDimension('height');
834
+ }
835
+ if (settings[iframeId].sizeWidth) {
836
+ processDimension('width');
837
+ }
838
+ }
839
+ }
840
+
841
+ function syncResize(func, messageData, doNotSync) {
842
+ /* istanbul ignore if */ // Not testable in PhantomJS
843
+ if (
844
+ doNotSync !== messageData.type &&
845
+ requestAnimationFrame &&
846
+ // including check for jasmine because had trouble getting spy to work in unit test using requestAnimationFrame
847
+ !window.jasmine
848
+ ) {
849
+ log(messageData.id, 'Requesting animation frame');
850
+ requestAnimationFrame(func);
851
+ } else {
852
+ func();
853
+ }
854
+ }
855
+
856
+ function trigger(calleeMsg, msg, iframe, id, noResponseWarning) {
857
+ function postMessageToIFrame() {
858
+ var target = settings[id] && settings[id].targetOrigin;
859
+ log(
860
+ id,
861
+ '[' +
862
+ calleeMsg +
863
+ '] Sending msg to iframe[' +
864
+ id +
865
+ '] (' +
866
+ msg +
867
+ ') targetOrigin: ' +
868
+ target
869
+ );
870
+ iframe.contentWindow.postMessage(msgId + msg, target);
871
+ }
872
+
873
+ function iFrameNotFound() {
874
+ warn(id, '[' + calleeMsg + '] IFrame(' + id + ') not found');
875
+ }
876
+
877
+ function chkAndSend() {
878
+ if (
879
+ iframe &&
880
+ 'contentWindow' in iframe &&
881
+ null !== iframe.contentWindow
882
+ ) {
883
+ // Null test for PhantomJS
884
+ postMessageToIFrame();
885
+ } else {
886
+ iFrameNotFound();
887
+ }
888
+ }
889
+
890
+ function warnOnNoResponse() {
891
+ function warning() {
892
+ if (settings[id] && !settings[id].loaded && !errorShown) {
893
+ errorShown = true;
894
+ warn(
895
+ id,
896
+ 'IFrame has not responded within ' +
897
+ settings[id].warningTimeout / 1000 +
898
+ ' seconds. Check iFrameResizer.contentWindow.js has been loaded in iFrame. This message can be ignored if everything is working, or you can set the warningTimeout option to a higher value or zero to suppress this warning.'
899
+ );
900
+ }
901
+ }
902
+
903
+ if (
904
+ !!noResponseWarning &&
905
+ settings[id] &&
906
+ !!settings[id].warningTimeout
907
+ ) {
908
+ settings[id].msgTimeout = setTimeout(
909
+ warning,
910
+ settings[id].warningTimeout
911
+ );
912
+ }
913
+ }
914
+
915
+ var errorShown = false;
916
+
917
+ id = id || iframe.id;
918
+
919
+ if (settings[id]) {
920
+ chkAndSend();
921
+ warnOnNoResponse();
922
+ }
923
+ }
924
+
925
+ function createOutgoingMsg(iframeId) {
926
+ return (
927
+ iframeId +
928
+ ':' +
929
+ settings[iframeId].bodyMarginV1 +
930
+ ':' +
931
+ settings[iframeId].sizeWidth +
932
+ ':' +
933
+ settings[iframeId].log +
934
+ ':' +
935
+ settings[iframeId].interval +
936
+ ':' +
937
+ settings[iframeId].enablePublicMethods +
938
+ ':' +
939
+ settings[iframeId].autoResize +
940
+ ':' +
941
+ settings[iframeId].bodyMargin +
942
+ ':' +
943
+ settings[iframeId].heightCalculationMethod +
944
+ ':' +
945
+ settings[iframeId].bodyBackground +
946
+ ':' +
947
+ settings[iframeId].bodyPadding +
948
+ ':' +
949
+ settings[iframeId].tolerance +
950
+ ':' +
951
+ settings[iframeId].inPageLinks +
952
+ ':' +
953
+ settings[iframeId].resizeFrom +
954
+ ':' +
955
+ settings[iframeId].widthCalculationMethod +
956
+ ':' +
957
+ settings[iframeId].mouseEvents
958
+ )
959
+ }
960
+
961
+ function isNumber(value) {
962
+ return typeof value === 'number'
963
+ }
964
+
965
+ function setupIFrame(iframe, options) {
966
+ function setLimits() {
967
+ function addStyle(style) {
968
+ var styleValue = settings[iframeId][style];
969
+ if (Infinity !== styleValue && 0 !== styleValue) {
970
+ iframe.style[style] = isNumber(styleValue)
971
+ ? styleValue + 'px'
972
+ : styleValue;
973
+ log(iframeId, 'Set ' + style + ' = ' + iframe.style[style]);
974
+ }
975
+ }
976
+
977
+ function chkMinMax(dimension) {
978
+ if (
979
+ settings[iframeId]['min' + dimension] >
980
+ settings[iframeId]['max' + dimension]
981
+ ) {
982
+ throw new Error(
983
+ 'Value for min' +
984
+ dimension +
985
+ ' can not be greater than max' +
986
+ dimension
987
+ )
988
+ }
989
+ }
990
+
991
+ chkMinMax('Height');
992
+ chkMinMax('Width');
993
+
994
+ addStyle('maxHeight');
995
+ addStyle('minHeight');
996
+ addStyle('maxWidth');
997
+ addStyle('minWidth');
998
+ }
999
+
1000
+ function newId() {
1001
+ var id = (options && options.id) || defaults.id + count++;
1002
+ if (null !== document.getElementById(id)) {
1003
+ id += count++;
1004
+ }
1005
+ return id
1006
+ }
1007
+
1008
+ function ensureHasId(iframeId) {
1009
+ if (typeof iframeId !== 'string') {
1010
+ throw new TypeError('Invaild id for iFrame. Expected String')
1011
+ }
1012
+
1013
+ if ('' === iframeId) {
1014
+ // eslint-disable-next-line no-multi-assign
1015
+ iframe.id = iframeId = newId();
1016
+ logEnabled = (options || {}).log;
1017
+ log(
1018
+ iframeId,
1019
+ 'Added missing iframe ID: ' + iframeId + ' (' + iframe.src + ')'
1020
+ );
1021
+ }
1022
+
1023
+ return iframeId
1024
+ }
1025
+
1026
+ function setScrolling() {
1027
+ log(
1028
+ iframeId,
1029
+ 'IFrame scrolling ' +
1030
+ (settings[iframeId] && settings[iframeId].scrolling
1031
+ ? 'enabled'
1032
+ : 'disabled') +
1033
+ ' for ' +
1034
+ iframeId
1035
+ );
1036
+ iframe.style.overflow =
1037
+ false === (settings[iframeId] && settings[iframeId].scrolling)
1038
+ ? 'hidden'
1039
+ : 'auto';
1040
+ switch (settings[iframeId] && settings[iframeId].scrolling) {
1041
+ case 'omit': {
1042
+ break
1043
+ }
1044
+
1045
+ case true: {
1046
+ iframe.scrolling = 'yes';
1047
+ break
1048
+ }
1049
+
1050
+ case false: {
1051
+ iframe.scrolling = 'no';
1052
+ break
1053
+ }
1054
+
1055
+ default: {
1056
+ iframe.scrolling = settings[iframeId]
1057
+ ? settings[iframeId].scrolling
1058
+ : 'no';
1059
+ }
1060
+ }
1061
+ }
1062
+
1063
+ // The V1 iFrame script expects an int, where as in V2 expects a CSS
1064
+ // string value such as '1px 3em', so if we have an int for V2, set V1=V2
1065
+ // and then convert V2 to a string PX value.
1066
+ function setupBodyMarginValues() {
1067
+ if (
1068
+ 'number' ===
1069
+ typeof (settings[iframeId] && settings[iframeId].bodyMargin) ||
1070
+ '0' === (settings[iframeId] && settings[iframeId].bodyMargin)
1071
+ ) {
1072
+ settings[iframeId].bodyMarginV1 = settings[iframeId].bodyMargin;
1073
+ settings[iframeId].bodyMargin =
1074
+ '' + settings[iframeId].bodyMargin + 'px';
1075
+ }
1076
+ }
1077
+
1078
+ function checkReset() {
1079
+ // Reduce scope of firstRun to function, because IE8's JS execution
1080
+ // context stack is borked and this value gets externally
1081
+ // changed midway through running this function!!!
1082
+ var firstRun = settings[iframeId] && settings[iframeId].firstRun,
1083
+ resetRequertMethod =
1084
+ settings[iframeId] &&
1085
+ settings[iframeId].heightCalculationMethod in resetRequiredMethods;
1086
+
1087
+ if (!firstRun && resetRequertMethod) {
1088
+ resetIFrame({ iframe: iframe, height: 0, width: 0, type: 'init' });
1089
+ }
1090
+ }
1091
+
1092
+ function setupIFrameObject() {
1093
+ if (settings[iframeId]) {
1094
+ settings[iframeId].iframe.iFrameResizer = {
1095
+ close: closeIFrame.bind(null, settings[iframeId].iframe),
1096
+
1097
+ removeListeners: removeIframeListeners.bind(
1098
+ null,
1099
+ settings[iframeId].iframe
1100
+ ),
1101
+
1102
+ resize: trigger.bind(
1103
+ null,
1104
+ 'Window resize',
1105
+ 'resize',
1106
+ settings[iframeId].iframe
1107
+ ),
1108
+
1109
+ moveToAnchor: function (anchor) {
1110
+ trigger(
1111
+ 'Move to anchor',
1112
+ 'moveToAnchor:' + anchor,
1113
+ settings[iframeId].iframe,
1114
+ iframeId
1115
+ );
1116
+ },
1117
+
1118
+ sendMessage: function (message) {
1119
+ message = JSON.stringify(message);
1120
+ trigger(
1121
+ 'Send Message',
1122
+ 'message:' + message,
1123
+ settings[iframeId].iframe,
1124
+ iframeId
1125
+ );
1126
+ }
1127
+ };
1128
+ }
1129
+ }
1130
+
1131
+ // We have to call trigger twice, as we can not be sure if all
1132
+ // iframes have completed loading when this code runs. The
1133
+ // event listener also catches the page changing in the iFrame.
1134
+ function init(msg) {
1135
+ function iFrameLoaded() {
1136
+ trigger('iFrame.onload', msg, iframe, undefined$1, true);
1137
+ checkReset();
1138
+ }
1139
+
1140
+ function createDestroyObserver(MutationObserver) {
1141
+ if (!iframe.parentNode) {
1142
+ return
1143
+ }
1144
+
1145
+ var destroyObserver = new MutationObserver(function (mutations) {
1146
+ mutations.forEach(function (mutation) {
1147
+ var removedNodes = Array.prototype.slice.call(mutation.removedNodes); // Transform NodeList into an Array
1148
+ removedNodes.forEach(function (removedNode) {
1149
+ if (removedNode === iframe) {
1150
+ closeIFrame(iframe);
1151
+ }
1152
+ });
1153
+ });
1154
+ });
1155
+ destroyObserver.observe(iframe.parentNode, {
1156
+ childList: true
1157
+ });
1158
+ }
1159
+
1160
+ var MutationObserver = getMutationObserver();
1161
+ if (MutationObserver) {
1162
+ createDestroyObserver(MutationObserver);
1163
+ }
1164
+
1165
+ addEventListener(iframe, 'load', iFrameLoaded);
1166
+ trigger('init', msg, iframe, undefined$1, true);
1167
+ }
1168
+
1169
+ function checkOptions(options) {
1170
+ if ('object' !== typeof options) {
1171
+ throw new TypeError('Options is not an object')
1172
+ }
1173
+ }
1174
+
1175
+ function copyOptions(options) {
1176
+ // eslint-disable-next-line no-restricted-syntax
1177
+ for (var option in defaults) {
1178
+ if (Object.prototype.hasOwnProperty.call(defaults, option)) {
1179
+ settings[iframeId][option] = Object.prototype.hasOwnProperty.call(
1180
+ options,
1181
+ option
1182
+ )
1183
+ ? options[option]
1184
+ : defaults[option];
1185
+ }
1186
+ }
1187
+ }
1188
+
1189
+ function getTargetOrigin(remoteHost) {
1190
+ return '' === remoteHost ||
1191
+ null !== remoteHost.match(/^(about:blank|javascript:|file:\/\/)/)
1192
+ ? '*'
1193
+ : remoteHost
1194
+ }
1195
+
1196
+ function depricate(key) {
1197
+ var splitName = key.split('Callback');
1198
+
1199
+ if (splitName.length === 2) {
1200
+ var name =
1201
+ 'on' + splitName[0].charAt(0).toUpperCase() + splitName[0].slice(1);
1202
+ this[name] = this[key];
1203
+ delete this[key];
1204
+ warn(
1205
+ iframeId,
1206
+ "Deprecated: '" +
1207
+ key +
1208
+ "' has been renamed '" +
1209
+ name +
1210
+ "'. The old method will be removed in the next major version."
1211
+ );
1212
+ }
1213
+ }
1214
+
1215
+ function processOptions(options) {
1216
+ options = options || {};
1217
+
1218
+ settings[iframeId] = Object.create(null); // Protect against prototype attacks
1219
+ settings[iframeId].iframe = iframe;
1220
+ settings[iframeId].firstRun = true;
1221
+ settings[iframeId].remoteHost =
1222
+ iframe.src && iframe.src.split('/').slice(0, 3).join('/');
1223
+
1224
+ checkOptions(options);
1225
+ Object.keys(options).forEach(depricate, options);
1226
+ copyOptions(options);
1227
+
1228
+ if (settings[iframeId]) {
1229
+ settings[iframeId].targetOrigin =
1230
+ true === settings[iframeId].checkOrigin
1231
+ ? getTargetOrigin(settings[iframeId].remoteHost)
1232
+ : '*';
1233
+ }
1234
+ }
1235
+
1236
+ function beenHere() {
1237
+ return iframeId in settings && 'iFrameResizer' in iframe
1238
+ }
1239
+
1240
+ var iframeId = ensureHasId(iframe.id);
1241
+
1242
+ if (beenHere()) {
1243
+ warn(iframeId, 'Ignored iFrame, already setup.');
1244
+ } else {
1245
+ processOptions(options);
1246
+ setScrolling();
1247
+ setLimits();
1248
+ setupBodyMarginValues();
1249
+ init(createOutgoingMsg(iframeId));
1250
+ setupIFrameObject();
1251
+ }
1252
+ }
1253
+
1254
+ function debouce(fn, time) {
1255
+ if (null === timer) {
1256
+ timer = setTimeout(function () {
1257
+ timer = null;
1258
+ fn();
1259
+ }, time);
1260
+ }
1261
+ }
1262
+
1263
+ var frameTimer = {};
1264
+ function debounceFrameEvents(fn, time, frameId) {
1265
+ if (!frameTimer[frameId]) {
1266
+ frameTimer[frameId] = setTimeout(function () {
1267
+ frameTimer[frameId] = null;
1268
+ fn();
1269
+ }, time);
1270
+ }
1271
+ }
1272
+
1273
+ // Not testable in PhantomJS
1274
+ /* istanbul ignore next */
1275
+
1276
+ function fixHiddenIFrames() {
1277
+ function checkIFrames() {
1278
+ function checkIFrame(settingId) {
1279
+ function chkDimension(dimension) {
1280
+ return (
1281
+ '0px' ===
1282
+ (settings[settingId] && settings[settingId].iframe.style[dimension])
1283
+ )
1284
+ }
1285
+
1286
+ function isVisible(el) {
1287
+ return null !== el.offsetParent
1288
+ }
1289
+
1290
+ if (
1291
+ settings[settingId] &&
1292
+ isVisible(settings[settingId].iframe) &&
1293
+ (chkDimension('height') || chkDimension('width'))
1294
+ ) {
1295
+ trigger(
1296
+ 'Visibility change',
1297
+ 'resize',
1298
+ settings[settingId].iframe,
1299
+ settingId
1300
+ );
1301
+ }
1302
+ }
1303
+
1304
+ Object.keys(settings).forEach(function (key) {
1305
+ checkIFrame(key);
1306
+ });
1307
+ }
1308
+
1309
+ function mutationObserved(mutations) {
1310
+ log(
1311
+ 'window',
1312
+ 'Mutation observed: ' + mutations[0].target + ' ' + mutations[0].type
1313
+ );
1314
+ debouce(checkIFrames, 16);
1315
+ }
1316
+
1317
+ function createMutationObserver() {
1318
+ var target = document.querySelector('body'),
1319
+ config = {
1320
+ attributes: true,
1321
+ attributeOldValue: false,
1322
+ characterData: true,
1323
+ characterDataOldValue: false,
1324
+ childList: true,
1325
+ subtree: true
1326
+ },
1327
+ observer = new MutationObserver(mutationObserved);
1328
+
1329
+ observer.observe(target, config);
1330
+ }
1331
+
1332
+ var MutationObserver = getMutationObserver();
1333
+ if (MutationObserver) {
1334
+ createMutationObserver();
1335
+ }
1336
+ }
1337
+
1338
+ function resizeIFrames(event) {
1339
+ function resize() {
1340
+ sendTriggerMsg('Window ' + event, 'resize');
1341
+ }
1342
+
1343
+ log('window', 'Trigger event: ' + event);
1344
+ debouce(resize, 16);
1345
+ }
1346
+
1347
+ // Not testable in PhantomJS
1348
+ /* istanbul ignore next */
1349
+ function tabVisible() {
1350
+ function resize() {
1351
+ sendTriggerMsg('Tab Visible', 'resize');
1352
+ }
1353
+
1354
+ if ('hidden' !== document.visibilityState) {
1355
+ log('document', 'Trigger event: Visibility change');
1356
+ debouce(resize, 16);
1357
+ }
1358
+ }
1359
+
1360
+ function sendTriggerMsg(eventName, event) {
1361
+ function isIFrameResizeEnabled(iframeId) {
1362
+ return (
1363
+ settings[iframeId] &&
1364
+ 'parent' === settings[iframeId].resizeFrom &&
1365
+ settings[iframeId].autoResize &&
1366
+ !settings[iframeId].firstRun
1367
+ )
1368
+ }
1369
+
1370
+ Object.keys(settings).forEach(function (iframeId) {
1371
+ if (isIFrameResizeEnabled(iframeId)) {
1372
+ trigger(eventName, event, settings[iframeId].iframe, iframeId);
1373
+ }
1374
+ });
1375
+ }
1376
+
1377
+ function setupEventListeners() {
1378
+ addEventListener(window, 'message', iFrameListener);
1379
+
1380
+ addEventListener(window, 'resize', function () {
1381
+ resizeIFrames('resize');
1382
+ });
1383
+
1384
+ addEventListener(document, 'visibilitychange', tabVisible);
1385
+
1386
+ addEventListener(document, '-webkit-visibilitychange', tabVisible);
1387
+ }
1388
+
1389
+ function factory() {
1390
+ function init(options, element) {
1391
+ function chkType() {
1392
+ if (!element.tagName) {
1393
+ throw new TypeError('Object is not a valid DOM element')
1394
+ } else if ('IFRAME' !== element.tagName.toUpperCase()) {
1395
+ throw new TypeError(
1396
+ 'Expected <IFRAME> tag, found <' + element.tagName + '>'
1397
+ )
1398
+ }
1399
+ }
1400
+
1401
+ if (element) {
1402
+ chkType();
1403
+ setupIFrame(element, options);
1404
+ iFrames.push(element);
1405
+ }
1406
+ }
1407
+
1408
+ function warnDeprecatedOptions(options) {
1409
+ if (options && options.enablePublicMethods) {
1410
+ warn(
1411
+ 'enablePublicMethods option has been removed, public methods are now always available in the iFrame'
1412
+ );
1413
+ }
1414
+ }
1415
+
1416
+ var iFrames;
1417
+
1418
+ setupRequestAnimationFrame();
1419
+ setupEventListeners();
1420
+
1421
+ return function iFrameResizeF(options, target) {
1422
+ iFrames = []; // Only return iFrames past in on this call
1423
+
1424
+ warnDeprecatedOptions(options);
1425
+
1426
+ switch (typeof target) {
1427
+ case 'undefined':
1428
+ case 'string': {
1429
+ Array.prototype.forEach.call(
1430
+ document.querySelectorAll(target || 'iframe'),
1431
+ init.bind(undefined$1, options)
1432
+ );
1433
+ break
1434
+ }
1435
+
1436
+ case 'object': {
1437
+ init(options, target);
1438
+ break
1439
+ }
1440
+
1441
+ default: {
1442
+ throw new TypeError('Unexpected data type (' + typeof target + ')')
1443
+ }
1444
+ }
1445
+
1446
+ return iFrames
1447
+ }
1448
+ }
1449
+
1450
+ function createJQueryPublicMethod($) {
1451
+ if (!$.fn) {
1452
+ info('', 'Unable to bind to jQuery, it is not fully loaded.');
1453
+ } else if (!$.fn.iFrameResize) {
1454
+ $.fn.iFrameResize = function $iFrameResizeF(options) {
1455
+ function init(index, element) {
1456
+ setupIFrame(element, options);
1457
+ }
1458
+
1459
+ return this.filter('iframe').each(init).end()
1460
+ };
1461
+ }
1462
+ }
1463
+
1464
+ if (window.jQuery !== undefined$1) {
1465
+ createJQueryPublicMethod(window.jQuery);
1466
+ }
1467
+
1468
+ if (typeof undefined$1 === 'function' && undefined$1.amd) {
1469
+ undefined$1([], factory);
1470
+ } else {
1471
+ // Node for browserfy
1472
+ module.exports = factory();
1473
+ }
1474
+ window.iFrameResize = window.iFrameResize || factory();
1475
+ })();
1476
+ });
6
1477
 
7
1478
  const MessageEventType = {
8
1479
  card: {
@@ -22,7 +1493,7 @@ const MessageEventType = {
22
1493
  };
23
1494
 
24
1495
  const name = "@justifi/webcomponents";
25
- const version = "4.4.0";
1496
+ const version = "4.5.1";
26
1497
  const description = "JustiFi Web Components";
27
1498
  const main = "dist/index.cjs.js";
28
1499
  const module$1 = "dist/components/index.js";
@@ -46,13 +1517,13 @@ const scripts = {
46
1517
  "build:dev": "NODE_ENV=dev stencil build --docs",
47
1518
  "build:staging": "NODE_ENV=staging stencil build --docs",
48
1519
  "build:prod": "NODE_ENV=prod stencil build --docs",
49
- start: "NODE_ENV=dev concurrently --restart-tries 3 -c \"bgBlue.bold,bgMagenta.bold,bgGreen.bold\" \"npm run start-stencil\" \"npm run storybook\"",
50
- "start-stencil": "stencil build --watch --serve --no-open",
1520
+ start: "concurrently --restart-tries 3 -c \"bgBlue.bold,bgMagenta.bold,bgGreen.bold\" \"npm run start-stencil\" \"npm run storybook\"",
1521
+ "start-stencil": "NODE_ENV=dev stencil build --watch --serve --no-open",
51
1522
  test: "stencil test --spec",
52
1523
  "test:watch": "stencil test --spec --watchAll",
53
1524
  "test:e2e": "stencil test --e2e",
54
1525
  generate: "stencil generate",
55
- storybook: "storybook dev -p 6006 --quiet",
1526
+ storybook: "NODE_ENV=dev storybook dev -p 6006 --quiet",
56
1527
  "build-storybook": "storybook build -o ../docs"
57
1528
  };
58
1529
  const dependencies = {
@@ -60,6 +1531,8 @@ const dependencies = {
60
1531
  bootstrap: "^5.2.3",
61
1532
  "date-fns": "^2.29.3",
62
1533
  "dinero.js": "^1.9.1",
1534
+ "iframe-resizer": "^4.3.7",
1535
+ imask: "^7.1.3",
63
1536
  rxjs: "^7.8.1",
64
1537
  "ts-dedent": "^2.2.0",
65
1538
  uuid: "^9.0.0",
@@ -74,6 +1547,7 @@ const devDependencies = {
74
1547
  "@stencil/react-output-target": "^0.5.3",
75
1548
  "@stencil/sass": "^3.0.1",
76
1549
  "@stencil/store": "^2.0.8",
1550
+ "@stencil/vue-output-target": "^0.8.6",
77
1551
  "@storybook/addon-actions": "^7.0.4",
78
1552
  "@storybook/addon-essentials": "^7.0.4",
79
1553
  "@storybook/addon-interactions": "^7.0.4",
@@ -169,7 +1643,7 @@ const getComputedTheme = () => {
169
1643
  return computedTheme;
170
1644
  };
171
1645
 
172
- const paymentMethodFormCss = ":host{display:block}justifi-payment-method-form iframe{border:none;width:100%}";
1646
+ const paymentMethodFormCss = ":host{display:block}justifi-payment-method-form iframe{border:none;width:100%}iframe{width:1px;min-width:100%}";
173
1647
 
174
1648
  const PaymentMethodForm = class {
175
1649
  constructor(hostRef) {
@@ -181,7 +1655,6 @@ const PaymentMethodForm = class {
181
1655
  this.paymentMethodFormValidationMode = undefined;
182
1656
  this.iframeOrigin = undefined;
183
1657
  this.singleLine = undefined;
184
- this.height = 55;
185
1658
  }
186
1659
  connectedCallback() {
187
1660
  window.addEventListener('message', this.dispatchMessageEvent.bind(this));
@@ -189,10 +1662,6 @@ const PaymentMethodForm = class {
189
1662
  disconnectedCallback() {
190
1663
  window.removeEventListener('message', this.dispatchMessageEvent.bind(this));
191
1664
  }
192
- componentShouldUpdate() {
193
- this.sendStyleOverrides();
194
- this.resize();
195
- }
196
1665
  sendStyleOverrides() {
197
1666
  if (this.computedTheme) {
198
1667
  this.postMessage(MessageEventType[this.paymentMethodFormType].styleOverrides, { styleOverrides: this.computedTheme });
@@ -205,14 +1674,14 @@ const PaymentMethodForm = class {
205
1674
  if (messageType === MessageEventType[this.paymentMethodFormType].ready) {
206
1675
  this.paymentMethodFormReady.emit(messageData);
207
1676
  }
208
- if (messageType === MessageEventType[this.paymentMethodFormType].resize) {
209
- this.height = messageData.height;
210
- }
211
1677
  }
212
1678
  postMessage(eventType, payload) {
213
1679
  var _a, _b;
214
1680
  (_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 || "" || '*');
215
1681
  }
1682
+ async resize() {
1683
+ this.postMessage(MessageEventType[this.paymentMethodFormType].resize);
1684
+ }
216
1685
  async postMessageWithResponseListener(eventType, payload) {
217
1686
  return new Promise(resolve => {
218
1687
  const responseListener = (event) => {
@@ -238,9 +1707,6 @@ const PaymentMethodForm = class {
238
1707
  async validate() {
239
1708
  return this.postMessageWithResponseListener(MessageEventType[this.paymentMethodFormType].validate);
240
1709
  }
241
- async resize() {
242
- this.postMessage(MessageEventType[this.paymentMethodFormType].resize);
243
- }
244
1710
  composeQueryParams(values) {
245
1711
  const queryParams = values.map(value => {
246
1712
  if (value === values[0]) {
@@ -265,9 +1731,11 @@ const PaymentMethodForm = class {
265
1731
  return iframeSrc.concat(this.composeQueryParams(paramsList));
266
1732
  }
267
1733
  render() {
268
- return (index.h(index.Host, null, index.h("iframe", { id: `justifi-payment-method-form-${this.paymentMethodFormType}`, src: this.getIframeSrc(), ref: el => (this.iframeElement = el), height: this.height, onLoad: () => {
1734
+ return (index.h(index.Host, null, index.h("iframe", { id: `justifi-payment-method-form-${this.paymentMethodFormType}`, src: this.getIframeSrc(), ref: el => {
1735
+ this.iframeElement = el;
1736
+ }, onLoad: () => {
1737
+ iframeResizer({ log: true }, this.iframeElement);
269
1738
  this.sendStyleOverrides();
270
- this.resize();
271
1739
  } })));
272
1740
  }
273
1741
  };