@watermarkinsights/ripple 5.10.0-15 → 5.10.0-16

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 (363) hide show
  1. package/README.md +3 -3
  2. package/dist/cjs/{chartFunctions-a3a08880.js → chartFunctions-c4046c7a.js} +3 -3
  3. package/dist/cjs/{functions-5ac8a62f.js → functions-e24249e6.js} +7 -104
  4. package/dist/{esm/app-globals-bd78f8aa.js → cjs/global-705d39bd.js} +2 -7
  5. package/dist/cjs/index-e86c28b6.js +2649 -0
  6. package/dist/cjs/{intl-57d1cfd1.js → intl-790f6c37.js} +11 -15
  7. package/dist/cjs/loader.cjs.js +4 -5
  8. package/dist/cjs/priv-calendar.cjs.entry.js +5 -6
  9. package/dist/cjs/priv-chart-popover.cjs.entry.js +5 -6
  10. package/dist/cjs/priv-navigator-button.cjs.entry.js +3 -4
  11. package/dist/cjs/priv-navigator-item.cjs.entry.js +3 -4
  12. package/dist/cjs/priv-option-list.cjs.entry.js +4 -5
  13. package/dist/cjs/ripple.cjs.js +12 -13
  14. package/dist/cjs/wm-action-menu_2.cjs.entry.js +6 -8
  15. package/dist/cjs/wm-button.cjs.entry.js +4 -5
  16. package/dist/cjs/wm-chart-slice.cjs.entry.js +1 -1
  17. package/dist/cjs/wm-chart.cjs.entry.js +6 -7
  18. package/dist/cjs/wm-date-range.cjs.entry.js +8 -9
  19. package/dist/cjs/wm-datepicker.cjs.entry.js +8 -9
  20. package/dist/cjs/wm-file-list.cjs.entry.js +3 -4
  21. package/dist/cjs/wm-file.cjs.entry.js +4 -5
  22. package/dist/cjs/wm-input.cjs.entry.js +5 -6
  23. package/dist/cjs/wm-line-chart.cjs.entry.js +14 -15
  24. package/dist/cjs/wm-modal-pss_3.cjs.entry.js +10 -13
  25. package/dist/cjs/wm-modal_3.cjs.entry.js +10 -13
  26. package/dist/cjs/wm-navigation_3.cjs.entry.js +10 -13
  27. package/dist/cjs/wm-navigator.cjs.entry.js +3 -4
  28. package/dist/cjs/wm-nested-select.cjs.entry.js +7 -8
  29. package/dist/cjs/wm-optgroup.cjs.entry.js +4 -5
  30. package/dist/cjs/wm-option_2.cjs.entry.js +8 -10
  31. package/dist/cjs/wm-pagination.cjs.entry.js +4 -5
  32. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +7 -9
  33. package/dist/cjs/wm-search.cjs.entry.js +6 -7
  34. package/dist/cjs/wm-snackbar.cjs.entry.js +6 -7
  35. package/dist/cjs/wm-tab-item_3.cjs.entry.js +8 -11
  36. package/dist/cjs/wm-tag-input.cjs.entry.js +7 -8
  37. package/dist/cjs/wm-tag-option.cjs.entry.js +2 -2
  38. package/dist/cjs/wm-textarea.cjs.entry.js +5 -6
  39. package/dist/cjs/wm-timepicker.cjs.entry.js +5 -6
  40. package/dist/cjs/wm-toggletip.cjs.entry.js +5 -6
  41. package/dist/cjs/wm-uploader.cjs.entry.js +98 -17
  42. package/dist/cjs/wm-wrapper.cjs.entry.js +1 -1
  43. package/dist/collection/collection-manifest.json +2 -2
  44. package/dist/collection/components/charts/chartFunctions.js +1 -1
  45. package/dist/collection/components/charts/chartFunctions.spec.js +16 -0
  46. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.e2e.js +81 -0
  47. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +2 -2
  48. package/dist/collection/components/charts/screenshots.e2e.js +96 -0
  49. package/dist/collection/components/charts/wm-chart/wm-chart.e2e.js +213 -0
  50. package/dist/collection/components/charts/wm-chart/wm-chart.js +1 -1
  51. package/dist/collection/components/charts/wm-chart/wm-chart.spec.js +37 -0
  52. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.e2e.js +176 -0
  53. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +9 -9
  54. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.spec.js +163 -0
  55. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +1 -1
  56. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.e2e.js +69 -0
  57. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +1 -1
  58. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.spec.js +79 -0
  59. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +2 -2
  60. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.spec.js +89 -0
  61. package/dist/collection/components/datepickers/wm-date-range.e2e.js +443 -0
  62. package/dist/collection/components/datepickers/wm-date-range.js +13 -17
  63. package/dist/collection/components/datepickers/wm-date-range.spec.js +22 -0
  64. package/dist/collection/components/datepickers/wm-datepicker.e2e.js +382 -0
  65. package/dist/collection/components/datepickers/wm-datepicker.js +13 -17
  66. package/dist/collection/components/datepickers/wm-datepicker.spec.js +21 -0
  67. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +5 -7
  68. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +3 -3
  69. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +1 -1
  70. package/dist/collection/components/selects/wm-option/wm-option.e2e.js +22 -0
  71. package/dist/collection/components/selects/wm-option/wm-option.js +1 -1
  72. package/dist/collection/components/selects/wm-option/wm-option.spec.js +63 -0
  73. package/dist/collection/components/selects/wm-select/wm-select.e2e.js +521 -0
  74. package/dist/collection/components/selects/wm-select/wm-select.js +2 -2
  75. package/dist/collection/components/selects/wm-select/wm-select.spec.js +271 -0
  76. package/dist/collection/components/wm-action-menu/wm-action-menu.e2e.js +200 -0
  77. package/dist/collection/components/wm-action-menu/wm-action-menu.js +1 -1
  78. package/dist/collection/components/wm-action-menu/wm-action-menu.spec.js +48 -0
  79. package/dist/collection/components/wm-button/wm-button.e2e.js +55 -0
  80. package/dist/collection/components/wm-button/wm-button.js +1 -1
  81. package/dist/collection/components/wm-button/wm-button.spec.js +74 -0
  82. package/dist/collection/components/wm-file/wm-file.js +1 -1
  83. package/dist/collection/components/wm-file/wm-file.spec.js +194 -0
  84. package/dist/collection/components/wm-file-list/wm-file-list.js +1 -1
  85. package/dist/collection/components/wm-file-list/wm-file-list.spec.js +69 -0
  86. package/dist/collection/components/wm-input/wm-input.e2e.js +32 -0
  87. package/dist/collection/components/wm-input/wm-input.js +1 -1
  88. package/dist/collection/components/wm-input/wm-input.spec.js +173 -0
  89. package/dist/collection/components/wm-menuitem/wm-menuitem.e2e.js +23 -0
  90. package/dist/collection/components/wm-menuitem/wm-menuitem.js +1 -1
  91. package/dist/collection/components/wm-menuitem/wm-menuitem.spec.js +54 -0
  92. package/dist/collection/components/wm-modal/wm-modal-footer.js +1 -1
  93. package/dist/collection/components/wm-modal/wm-modal-footer.spec.js +11 -0
  94. package/dist/collection/components/wm-modal/wm-modal-header.js +1 -1
  95. package/dist/collection/components/wm-modal/wm-modal-header.spec.js +8 -0
  96. package/dist/collection/components/wm-modal/wm-modal.e2e.js +104 -0
  97. package/dist/collection/components/wm-modal/wm-modal.js +2 -2
  98. package/dist/collection/components/wm-modal/wm-modal.spec.js +30 -0
  99. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +1 -1
  100. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +1 -1
  101. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +2 -2
  102. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +1 -1
  103. package/dist/collection/components/wm-navigation/wm-navigation-item.js +1 -1
  104. package/dist/collection/components/wm-navigation/wm-navigation.e2e.js +102 -0
  105. package/dist/collection/components/wm-navigation/wm-navigation.js +2 -2
  106. package/dist/collection/components/wm-navigation/wm-navigation.spec.js +91 -0
  107. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.e2e.js +50 -0
  108. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +1 -1
  109. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +2 -2
  110. package/dist/collection/components/wm-navigator/wm-navigator.e2e.js +209 -0
  111. package/dist/collection/components/wm-navigator/wm-navigator.spec.js +177 -0
  112. package/dist/collection/components/wm-pagination/wm-pagination.e2e.js +312 -0
  113. package/dist/collection/components/wm-pagination/wm-pagination.js +1 -1
  114. package/dist/collection/components/wm-search/wm-search.e2e.js +76 -0
  115. package/dist/collection/components/wm-search/wm-search.js +4 -5
  116. package/dist/collection/components/wm-search/wm-search.spec.js +71 -0
  117. package/dist/collection/components/wm-snackbar/wm-snackbar.e2e.js +112 -0
  118. package/dist/collection/components/wm-snackbar/wm-snackbar.js +2 -2
  119. package/dist/collection/components/wm-snackbar/wm-snackbar.spec.js +9 -0
  120. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +1 -1
  121. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +1 -1
  122. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +1 -1
  123. package/dist/collection/components/wm-tabs/wm-tabs.e2e.js +91 -0
  124. package/dist/collection/components/wm-tabs/wm-tabs.spec.js +12 -0
  125. package/dist/collection/components/wm-tag-input/wm-tag-input.e2e.js +204 -0
  126. package/dist/collection/components/wm-tag-input/wm-tag-input.js +3 -3
  127. package/dist/collection/components/wm-tag-input/wm-tag-input.spec.js +195 -0
  128. package/dist/collection/components/wm-textarea/wm-textarea.e2e.js +41 -0
  129. package/dist/collection/components/wm-textarea/wm-textarea.js +1 -1
  130. package/dist/collection/components/wm-textarea/wm-textarea.spec.js +79 -0
  131. package/dist/collection/components/wm-timepicker/wm-timepicker.e2e.js +163 -0
  132. package/dist/collection/components/wm-timepicker/wm-timepicker.js +8 -11
  133. package/dist/collection/components/wm-timepicker/wm-timepicker.spec.js +147 -0
  134. package/dist/collection/components/wm-toggletip/wm-toggletip.e2e.js +69 -0
  135. package/dist/collection/components/wm-toggletip/wm-toggletip.js +2 -2
  136. package/dist/collection/components/wm-toggletip/wm-toggletip.spec.js +21 -0
  137. package/dist/collection/components/wm-uploader/wm-uploader.css +149 -8
  138. package/dist/collection/components/wm-uploader/wm-uploader.e2e.js +70 -0
  139. package/dist/collection/components/wm-uploader/wm-uploader.js +154 -11
  140. package/dist/collection/components/wm-uploader/wm-uploader.spec.js +234 -0
  141. package/dist/collection/global/functions.spec.js +126 -0
  142. package/dist/collection/global/intl.js +10 -14
  143. package/dist/collection/lang/lang.spec.js +20 -0
  144. package/dist/collection/lang/missing.js +43 -43
  145. package/dist/collection/lang/piglatin.js +93 -93
  146. package/dist/esm/{chartFunctions-21d5a3d3.js → chartFunctions-5555bab0.js} +3 -3
  147. package/dist/esm/{functions-f39e6177.js → functions-8800c690.js} +8 -105
  148. package/dist/{cjs/app-globals-d1951045.js → esm/global-a377e5a4.js} +1 -10
  149. package/dist/esm/index-558b5a82.js +2618 -0
  150. package/dist/esm/{intl-dda73e98.js → intl-82ebfb79.js} +11 -15
  151. package/dist/esm/loader.js +5 -6
  152. package/dist/esm/polyfills/core-js.js +0 -0
  153. package/dist/esm/polyfills/dom.js +0 -0
  154. package/dist/esm/polyfills/es5-html-element.js +0 -0
  155. package/dist/esm/polyfills/index.js +0 -0
  156. package/dist/esm/polyfills/system.js +0 -0
  157. package/dist/esm/priv-calendar.entry.js +5 -6
  158. package/dist/esm/priv-chart-popover.entry.js +5 -6
  159. package/dist/esm/priv-navigator-button.entry.js +3 -4
  160. package/dist/esm/priv-navigator-item.entry.js +3 -4
  161. package/dist/esm/priv-option-list.entry.js +4 -5
  162. package/dist/esm/ripple.js +13 -14
  163. package/dist/esm/wm-action-menu_2.entry.js +6 -8
  164. package/dist/esm/wm-button.entry.js +4 -5
  165. package/dist/esm/wm-chart-slice.entry.js +1 -1
  166. package/dist/esm/wm-chart.entry.js +6 -7
  167. package/dist/esm/wm-date-range.entry.js +8 -9
  168. package/dist/esm/wm-datepicker.entry.js +8 -9
  169. package/dist/esm/wm-file-list.entry.js +3 -4
  170. package/dist/esm/wm-file.entry.js +4 -5
  171. package/dist/esm/wm-input.entry.js +5 -6
  172. package/dist/esm/wm-line-chart.entry.js +14 -15
  173. package/dist/esm/wm-modal-pss_3.entry.js +10 -13
  174. package/dist/esm/wm-modal_3.entry.js +10 -13
  175. package/dist/esm/wm-navigation_3.entry.js +10 -13
  176. package/dist/esm/wm-navigator.entry.js +3 -4
  177. package/dist/esm/wm-nested-select.entry.js +7 -8
  178. package/dist/esm/wm-optgroup.entry.js +4 -5
  179. package/dist/esm/wm-option_2.entry.js +8 -10
  180. package/dist/esm/wm-pagination.entry.js +4 -5
  181. package/dist/esm/wm-progress-indicator_3.entry.js +7 -9
  182. package/dist/esm/wm-search.entry.js +6 -7
  183. package/dist/esm/wm-snackbar.entry.js +6 -7
  184. package/dist/esm/wm-tab-item_3.entry.js +8 -11
  185. package/dist/esm/wm-tag-input.entry.js +7 -8
  186. package/dist/esm/wm-tag-option.entry.js +2 -2
  187. package/dist/esm/wm-textarea.entry.js +5 -6
  188. package/dist/esm/wm-timepicker.entry.js +5 -6
  189. package/dist/esm/wm-toggletip.entry.js +5 -6
  190. package/dist/esm/wm-uploader.entry.js +98 -17
  191. package/dist/esm/wm-wrapper.entry.js +1 -1
  192. package/dist/esm-es5/{chartFunctions-21d5a3d3.js → chartFunctions-5555bab0.js} +1 -1
  193. package/dist/esm-es5/functions-8800c690.js +1 -0
  194. package/dist/esm-es5/global-a377e5a4.js +1 -0
  195. package/dist/esm-es5/index-558b5a82.js +1 -0
  196. package/dist/esm-es5/{intl-dda73e98.js → intl-82ebfb79.js} +1 -1
  197. package/dist/esm-es5/loader.js +1 -1
  198. package/dist/esm-es5/priv-calendar.entry.js +1 -1
  199. package/dist/esm-es5/priv-chart-popover.entry.js +1 -1
  200. package/dist/esm-es5/priv-navigator-button.entry.js +1 -1
  201. package/dist/esm-es5/priv-navigator-item.entry.js +1 -1
  202. package/dist/esm-es5/priv-option-list.entry.js +1 -1
  203. package/dist/esm-es5/ripple.js +1 -1
  204. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -1
  205. package/dist/esm-es5/wm-button.entry.js +1 -1
  206. package/dist/esm-es5/wm-chart-slice.entry.js +1 -1
  207. package/dist/esm-es5/wm-chart.entry.js +1 -1
  208. package/dist/esm-es5/wm-date-range.entry.js +1 -1
  209. package/dist/esm-es5/wm-datepicker.entry.js +1 -1
  210. package/dist/esm-es5/wm-file-list.entry.js +1 -1
  211. package/dist/esm-es5/wm-file.entry.js +1 -1
  212. package/dist/esm-es5/wm-input.entry.js +1 -1
  213. package/dist/esm-es5/wm-line-chart.entry.js +1 -1
  214. package/dist/esm-es5/wm-modal-pss_3.entry.js +1 -1
  215. package/dist/esm-es5/wm-modal_3.entry.js +1 -1
  216. package/dist/esm-es5/wm-navigation_3.entry.js +1 -1
  217. package/dist/esm-es5/wm-navigator.entry.js +1 -1
  218. package/dist/esm-es5/wm-nested-select.entry.js +1 -1
  219. package/dist/esm-es5/wm-optgroup.entry.js +1 -1
  220. package/dist/esm-es5/wm-option_2.entry.js +1 -1
  221. package/dist/esm-es5/wm-pagination.entry.js +1 -1
  222. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -1
  223. package/dist/esm-es5/wm-search.entry.js +1 -1
  224. package/dist/esm-es5/wm-snackbar.entry.js +1 -1
  225. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -1
  226. package/dist/esm-es5/wm-tag-input.entry.js +1 -1
  227. package/dist/esm-es5/wm-tag-option.entry.js +1 -1
  228. package/dist/esm-es5/wm-textarea.entry.js +1 -1
  229. package/dist/esm-es5/wm-timepicker.entry.js +1 -1
  230. package/dist/esm-es5/wm-toggletip.entry.js +1 -1
  231. package/dist/esm-es5/wm-uploader.entry.js +1 -1
  232. package/dist/esm-es5/wm-wrapper.entry.js +1 -1
  233. package/dist/loader/cdn.js +2 -1
  234. package/dist/loader/index.cjs.js +2 -1
  235. package/dist/loader/index.d.ts +0 -3
  236. package/dist/loader/index.es2017.js +2 -1
  237. package/dist/loader/index.js +2 -1
  238. package/dist/ripple/{p-b9f4ee75.entry.js → p-04502e9c.entry.js} +1 -1
  239. package/dist/ripple/p-0aa8c50e.entry.js +1 -0
  240. package/dist/ripple/{p-07087139.system.entry.js → p-0b4b0741.system.entry.js} +1 -1
  241. package/dist/ripple/p-0bffcc33.entry.js +1 -0
  242. package/dist/ripple/{p-0bffed17.entry.js → p-0d082f95.entry.js} +1 -1
  243. package/dist/ripple/{p-0e1d1d0e.entry.js → p-0eddc626.entry.js} +1 -1
  244. package/dist/ripple/{p-ade89f97.system.entry.js → p-0fc6dab9.system.entry.js} +1 -1
  245. package/dist/ripple/{p-73ce9af7.js → p-11d66b54.js} +1 -1
  246. package/dist/ripple/p-1887c39d.entry.js +1 -0
  247. package/dist/ripple/p-1a4d00a9.system.entry.js +1 -0
  248. package/dist/ripple/{p-97c524e5.system.entry.js → p-1bb48113.system.entry.js} +1 -1
  249. package/dist/ripple/{p-1b91dc76.system.entry.js → p-1f695ead.system.entry.js} +1 -1
  250. package/dist/ripple/{p-36bb61c1.system.entry.js → p-21a4a455.system.entry.js} +1 -1
  251. package/dist/ripple/p-221a7c22.entry.js +1 -0
  252. package/dist/ripple/{p-37b044c7.system.js → p-2ce69098.system.js} +1 -1
  253. package/dist/ripple/{p-823d7b4e.system.entry.js → p-32bf3f5b.system.entry.js} +1 -1
  254. package/dist/ripple/{p-069ec9d0.system.entry.js → p-34014c8d.system.entry.js} +1 -1
  255. package/dist/ripple/{p-b8912fba.system.entry.js → p-34218322.system.entry.js} +1 -1
  256. package/dist/ripple/p-3bdb760a.entry.js +1 -0
  257. package/dist/ripple/{p-044cbd11.system.entry.js → p-3c3c6b29.system.entry.js} +1 -1
  258. package/dist/ripple/{p-7a9ad0df.system.entry.js → p-3fb7444d.system.entry.js} +1 -1
  259. package/dist/ripple/p-40129c5d.js +1 -0
  260. package/dist/ripple/{p-c34c9cbb.system.entry.js → p-4743176d.system.entry.js} +1 -1
  261. package/dist/ripple/{p-13b1d775.entry.js → p-48e09589.entry.js} +1 -1
  262. package/dist/ripple/p-4abcb864.entry.js +1 -0
  263. package/dist/ripple/{p-342e6ba1.system.entry.js → p-4edb481f.system.entry.js} +1 -1
  264. package/dist/ripple/p-50501e07.entry.js +1 -0
  265. package/dist/ripple/p-51718b06.system.entry.js +1 -0
  266. package/dist/ripple/p-53975533.entry.js +1 -0
  267. package/dist/ripple/p-568c595f.js +2 -0
  268. package/dist/ripple/{p-f41ab9ea.js → p-599dd035.js} +1 -1
  269. package/dist/ripple/{p-a38a1bd7.system.entry.js → p-5a2b1e2b.system.entry.js} +1 -1
  270. package/dist/ripple/p-5f78dd11.entry.js +1 -0
  271. package/dist/ripple/p-5fe90111.entry.js +1 -0
  272. package/dist/ripple/{p-043901ab.system.entry.js → p-65d26233.system.entry.js} +1 -1
  273. package/dist/ripple/{p-cc17206d.system.entry.js → p-68f39a1f.system.entry.js} +1 -1
  274. package/dist/ripple/{p-3818fb5b.system.entry.js → p-6a7fd013.system.entry.js} +1 -1
  275. package/dist/ripple/p-6b859ff2.entry.js +1 -0
  276. package/dist/ripple/p-72bf2c06.system.entry.js +1 -0
  277. package/dist/ripple/p-76a9ae45.system.js +1 -0
  278. package/dist/ripple/{p-b0dddc8b.system.js → p-7a647f51.system.js} +1 -1
  279. package/dist/ripple/p-7cf74ee6.system.js +1 -0
  280. package/dist/ripple/{p-aae83494.system.entry.js → p-7f0ca371.system.entry.js} +1 -1
  281. package/dist/ripple/{p-f1abfaa1.entry.js → p-7f7c5da2.system.entry.js} +1 -1
  282. package/dist/ripple/{p-d3ffe48c.system.entry.js → p-88ae8914.system.entry.js} +1 -1
  283. package/dist/ripple/{p-1c9e0cae.system.entry.js → p-88c968e7.system.entry.js} +1 -1
  284. package/dist/ripple/{p-cd0cc88d.entry.js → p-88ebddd7.entry.js} +1 -1
  285. package/dist/ripple/p-8d7ecab9.entry.js +1 -0
  286. package/dist/ripple/p-8fcebe03.entry.js +1 -0
  287. package/dist/ripple/p-919fd2b6.entry.js +1 -0
  288. package/dist/ripple/{p-8270cd9e.system.entry.js → p-950dc6c4.system.entry.js} +1 -1
  289. package/dist/ripple/p-9f2a0e0a.entry.js +1 -0
  290. package/dist/ripple/{p-0c9e1261.system.entry.js → p-9f38f65d.system.entry.js} +1 -1
  291. package/dist/ripple/{p-a96fd05a.entry.js → p-a0e84979.entry.js} +1 -1
  292. package/dist/ripple/p-ab8d78cc.system.js +2 -0
  293. package/dist/ripple/{p-8b983e94.system.entry.js → p-ac625334.system.entry.js} +1 -1
  294. package/dist/ripple/{p-44b7ac3f.system.entry.js → p-b0512477.system.entry.js} +1 -1
  295. package/dist/ripple/{p-7125475c.system.entry.js → p-b0ada8f7.system.entry.js} +1 -1
  296. package/dist/ripple/p-b1fe3bbc.system.entry.js +1 -0
  297. package/dist/ripple/{p-93f75c0c.entry.js → p-b72aa60b.entry.js} +1 -1
  298. package/dist/ripple/{p-76d248e6.entry.js → p-b976c84b.entry.js} +1 -1
  299. package/dist/ripple/p-bc566798.entry.js +1 -0
  300. package/dist/ripple/{p-581dd537.system.entry.js → p-c0f370f9.system.entry.js} +1 -1
  301. package/dist/ripple/p-c6c43720.entry.js +1 -0
  302. package/dist/ripple/p-ce191133.entry.js +1 -0
  303. package/dist/ripple/{p-8acb1dc0.entry.js → p-d168b8bc.entry.js} +1 -1
  304. package/dist/ripple/{p-0d77c2f2.system.entry.js → p-d8bc3fd7.system.entry.js} +1 -1
  305. package/dist/ripple/{p-b02dfe01.system.entry.js → p-dadb480d.system.entry.js} +1 -1
  306. package/dist/ripple/p-dcbed420.entry.js +1 -0
  307. package/dist/ripple/p-df387590.entry.js +1 -0
  308. package/dist/ripple/{p-cf02b0a3.entry.js → p-e49d3992.entry.js} +1 -1
  309. package/dist/ripple/p-e5b62488.entry.js +1 -0
  310. package/dist/ripple/p-e5c8a584.entry.js +1 -0
  311. package/dist/ripple/p-eca78c2b.js +1 -0
  312. package/dist/ripple/p-edd87140.system.js +1 -0
  313. package/dist/ripple/{p-3bec88da.system.entry.js → p-ef980041.system.entry.js} +1 -1
  314. package/dist/ripple/p-f623828b.entry.js +1 -0
  315. package/dist/ripple/{p-e540946d.system.entry.js → p-f94b8117.system.entry.js} +1 -1
  316. package/dist/ripple/p-fef994ea.entry.js +1 -0
  317. package/dist/ripple/ripple.esm.js +1 -1
  318. package/dist/ripple/ripple.js +1 -1
  319. package/dist/types/components/wm-uploader/wm-uploader.d.ts +16 -2
  320. package/dist/types/components.d.ts +10 -6
  321. package/dist/types/global/intl.d.ts +2 -2
  322. package/dist/types/stencil-public-runtime.d.ts +10 -3
  323. package/package.json +1 -1
  324. package/dist/cjs/index-788526f5.js +0 -1859
  325. package/dist/esm/index-130e07bb.js +0 -1828
  326. package/dist/esm-es5/app-globals-bd78f8aa.js +0 -1
  327. package/dist/esm-es5/functions-f39e6177.js +0 -1
  328. package/dist/esm-es5/index-130e07bb.js +0 -1
  329. package/dist/ripple/p-0ced76f3.system.js +0 -1
  330. package/dist/ripple/p-1827f482.entry.js +0 -1
  331. package/dist/ripple/p-1b808f54.entry.js +0 -1
  332. package/dist/ripple/p-25017466.entry.js +0 -1
  333. package/dist/ripple/p-2bbe2a08.entry.js +0 -1
  334. package/dist/ripple/p-2e1f1f9e.entry.js +0 -1
  335. package/dist/ripple/p-342ba395.entry.js +0 -1
  336. package/dist/ripple/p-362f606c.system.entry.js +0 -1
  337. package/dist/ripple/p-36f666de.entry.js +0 -1
  338. package/dist/ripple/p-37438529.entry.js +0 -1
  339. package/dist/ripple/p-3d203b92.system.entry.js +0 -1
  340. package/dist/ripple/p-3ed77883.entry.js +0 -1
  341. package/dist/ripple/p-3f486eed.system.js +0 -1
  342. package/dist/ripple/p-585d603f.entry.js +0 -1
  343. package/dist/ripple/p-5f247e4a.entry.js +0 -1
  344. package/dist/ripple/p-65d2c6b7.entry.js +0 -1
  345. package/dist/ripple/p-6e159fdf.entry.js +0 -1
  346. package/dist/ripple/p-72935ed4.entry.js +0 -1
  347. package/dist/ripple/p-77016702.system.js +0 -1
  348. package/dist/ripple/p-78041e19.system.entry.js +0 -1
  349. package/dist/ripple/p-79b5df24.entry.js +0 -1
  350. package/dist/ripple/p-89a2db02.js +0 -1
  351. package/dist/ripple/p-8ad580c5.entry.js +0 -1
  352. package/dist/ripple/p-929e82f6.entry.js +0 -1
  353. package/dist/ripple/p-a866c01c.js +0 -1
  354. package/dist/ripple/p-aab342f1.entry.js +0 -1
  355. package/dist/ripple/p-b4134a44.entry.js +0 -1
  356. package/dist/ripple/p-c22b9ac6.entry.js +0 -1
  357. package/dist/ripple/p-cef8a45b.system.js +0 -2
  358. package/dist/ripple/p-d49cd886.entry.js +0 -1
  359. package/dist/ripple/p-d7ce58a3.entry.js +0 -1
  360. package/dist/ripple/p-d9da0502.js +0 -2
  361. package/dist/ripple/p-e3083b58.entry.js +0 -1
  362. package/dist/ripple/p-e4ef6c22.system.entry.js +0 -1
  363. package/dist/ripple/p-f4ed6ee8.system.entry.js +0 -1
@@ -706,7 +706,7 @@
706
706
  margin-left: 0.3125rem;
707
707
  margin-right: 0;
708
708
  }
709
- :host input:focus-visible + .wm-button {
709
+ :host input:focus-visible + label {
710
710
  outline: 3px solid var(--wmcolor-interactive-focus);
711
711
  outline-offset: 2px;
712
712
  }
@@ -715,6 +715,61 @@
715
715
  box-sizing: border-box;
716
716
  }
717
717
 
718
+ .upload-arrow {
719
+ display: inline-block;
720
+ width: 20px;
721
+ height: 20px;
722
+ }
723
+ .upload-arrow:before {
724
+ content: "";
725
+ display: inline-block;
726
+ background-color: var(--icon-fill, currentColor);
727
+ width: 100%;
728
+ height: 100%;
729
+ -webkit-mask-size: 100%;
730
+ mask-size: 100%;
731
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M14 11V14H2V11H0V14C0 15.1 0.9 16 2 16H14C15.1 16 16 15.1 16 14V11H14ZM3 5L4.41 6.41L7 3.83V12H9V3.83L11.59 6.41L13 5L8 0L3 5Z'/%3E%3C/svg%3E%0A");
732
+ mask-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M14 11V14H2V11H0V14C0 15.1 0.9 16 2 16H14C15.1 16 16 15.1 16 14V11H14ZM3 5L4.41 6.41L7 3.83V12H9V3.83L11.59 6.41L13 5L8 0L3 5Z'/%3E%3C/svg%3E%0A");
733
+ }
734
+
735
+ .drop-area {
736
+ position: absolute;
737
+ height: 100%;
738
+ width: 100%;
739
+ z-index: 100;
740
+ pointer-events: none;
741
+ }
742
+ .drop-area.listening {
743
+ pointer-events: unset;
744
+ }
745
+ .drop-area.listening .drop-overlay {
746
+ display: flex;
747
+ }
748
+ .drop-area.-page {
749
+ position: fixed;
750
+ top: 0;
751
+ left: 0;
752
+ z-index: 1000;
753
+ }
754
+ .drop-area .drop-overlay {
755
+ display: none;
756
+ flex-direction: column;
757
+ font-size: 1rem;
758
+ font-weight: 600;
759
+ gap: 0.75rem;
760
+ height: 100%;
761
+ width: 100%;
762
+ background-color: rgba(221, 241, 250, 0.6);
763
+ border: 3px solid var(--wmcolor-border-focus);
764
+ align-items: center;
765
+ justify-content: center;
766
+ }
767
+ .drop-area .drop-overlay .upload-arrow {
768
+ height: 2rem;
769
+ width: 2rem;
770
+ color: var(--wmcolor-interactive-positive);
771
+ }
772
+
718
773
  .wm-button.disabled {
719
774
  pointer-events: initial !important;
720
775
  }
@@ -790,14 +845,74 @@
790
845
  margin-bottom: 0.5rem;
791
846
  }
792
847
 
793
- .info-wrapper {
794
- position: relative;
848
+ .button-wrapper {
849
+ display: flex;
850
+ width: fit-content;
851
+ gap: 1rem;
852
+ }
853
+
854
+ .-drop label {
855
+ height: 6.25rem;
856
+ border-radius: 8px;
857
+ border: 2px dashed var(--wmcolor-border-dark);
858
+ background: var(--wmcolor-background);
859
+ min-width: 21.375rem;
860
+ display: flex;
861
+ flex-direction: column;
862
+ justify-content: center;
863
+ align-items: center;
864
+ gap: 0.25rem;
865
+ transition: border ease-out 200ms, background-color ease-out 200ms;
866
+ }
867
+ .-drop label:hover:not(:has(.disabled)) {
868
+ cursor: pointer;
869
+ }
870
+ .-drop label:hover:not(:has(.disabled)) .wm-button {
871
+ text-decoration: underline;
872
+ }
873
+ .-drop .prompt {
795
874
  display: flex;
796
875
  align-items: center;
876
+ gap: 0.5rem;
877
+ }
878
+ .-drop .prompt .upload-arrow {
879
+ width: 1rem;
880
+ height: 1rem;
881
+ color: var(--wmcolor-interactive);
797
882
  }
798
- .info-wrapper .info {
883
+ .-drop .prompt .wm-button {
884
+ font-weight: 700;
799
885
  font-size: 0.875rem;
800
- margin-left: 1rem;
886
+ transition: none;
887
+ width: fit-content;
888
+ }
889
+
890
+ .-drop:has(.disabled) label {
891
+ background: var(--wmcolor-interactive-background-disabled);
892
+ border-color: var(--wmcolor-border);
893
+ }
894
+ .-drop:has(.disabled) .upload-arrow {
895
+ color: var(--wmcolor-button-text-textonly-disabled);
896
+ }
897
+
898
+ :host(.dragging) *:not(.drop-area, .drop-overlay) {
899
+ pointer-events: none;
900
+ }
901
+ :host(.dragging) .-drop label {
902
+ background-color: var(--wmcolor-interactive-background-highlight);
903
+ border: 2px solid var(--wmcolor-border-focus);
904
+ pointer-events: none;
905
+ }
906
+ :host(.dragging) .-drop label .wm-button {
907
+ color: var(--wmcolor-text);
908
+ font-size: 1rem;
909
+ font-weight: 600;
910
+ }
911
+ :host(.dragging) .-drop label .upload-arrow {
912
+ color: var(--wmcolor-interactive-positive);
913
+ }
914
+ :host(.dragging) .-drop label #file-count {
915
+ display: none;
801
916
  }
802
917
 
803
918
  .accepted-types {
@@ -805,17 +920,43 @@
805
920
  }
806
921
 
807
922
  .notif-wrapper {
808
- position: relative;
809
923
  display: flex;
810
- flex-direction: row;
924
+ flex-direction: column;
925
+ position: relative;
811
926
  margin-bottom: 0.75rem;
927
+ gap: 0.5rem;
812
928
  }
813
929
 
814
930
  .requirements {
931
+ font-size: 0.875rem;
932
+ }
933
+ .requirements summary {
934
+ width: fit-content;
935
+ list-style-position: outside;
936
+ margin-inline-start: 1rem;
937
+ font-weight: 700;
938
+ color: var(--wmcolor-button-text-textonly);
939
+ }
940
+ .requirements summary:focus-visible {
941
+ outline: 3px solid var(--wmcolor-interactive-focus);
942
+ outline-offset: 2px;
943
+ }
944
+ .requirements summary::marker {
945
+ font-size: 0.75rem;
946
+ }
947
+ .requirements .requirements-wrapper {
815
948
  display: flex;
816
949
  flex-direction: column;
950
+ gap: 0.25rem;
951
+ margin-top: 0.25rem;
952
+ margin-inline-start: 1rem;
953
+ }
954
+
955
+ #file-count {
956
+ display: block;
957
+ flex-shrink: 0;
817
958
  font-size: 0.875rem;
818
- margin-left: 1rem;
959
+ font-style: italic;
819
960
  }
820
961
 
821
962
  .notif,
@@ -0,0 +1,70 @@
1
+ import { newE2EPage } from "@stencil/core/testing";
2
+ import { AxePuppeteer } from "@axe-core/puppeteer";
3
+ describe("wm-uploader", () => {
4
+ let page, input, label;
5
+ beforeEach(async () => {
6
+ page = await newE2EPage();
7
+ await page.setContent(`<html lang='en'><head><title>Page</title></head><body><main><h1>Title</h1>
8
+ <wm-uploader button-text="Upload new document">
9
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="2020-01-28T22:29:10.397Z"></wm-file>
10
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2019-02-14T12:21:05.397Z"></wm-file>
11
+ </wm-uploader>
12
+ </main></body></html>`);
13
+ input = await page.find("wm-uploader >>> input[type='file']");
14
+ label = await page.find("wm-uploader >>> label");
15
+ await page.waitForChanges();
16
+ });
17
+ it("passes Axe checks", async () => {
18
+ const results = await new AxePuppeteer(page).analyze();
19
+ expect(results.violations.length).toBe(0);
20
+ });
21
+ it("renders the component", async () => {
22
+ expect(input).not.toBeNull();
23
+ expect(label).not.toBeNull();
24
+ });
25
+ it("focuses previous file when deleting with the keyboard", async () => {
26
+ page = await newE2EPage();
27
+ await page.setContent(`<html lang='en'><head><title>Page</title></head><body><main><h1>Title</h1>
28
+ <wm-uploader button-text="Upload new document">
29
+ <wm-file id="file1" name="First file" type="pdf" file-actions="preview delete"></wm-file>
30
+ <wm-file id="file2" name="Second file" type="pdf" file-actions="delete"></wm-file>
31
+ </wm-uploader>
32
+ </main></body></html>`);
33
+ await page.waitForChanges();
34
+ let fileEls = await page.findAll("wm-file");
35
+ let secondFileEl = fileEls[1];
36
+ // inital check of file count
37
+ expect(fileEls.length).toBe(2);
38
+ // user must be tabbing for these changes to occur
39
+ await page.keyboard.press("Tab");
40
+ await page.keyboard.press("Tab");
41
+ await page.keyboard.press("Tab");
42
+ await page.keyboard.press("Tab");
43
+ await page.keyboard.press("Enter");
44
+ await page.waitForChanges();
45
+ // check focused element is last file, delete button
46
+ let activeElId = await page.evaluate(() => document.activeElement.id);
47
+ expect(activeElId).toBe("file2");
48
+ let activeElButtonType = await page.evaluate(() => document.activeElement.shadowRoot.activeElement.classList[0]);
49
+ expect(activeElButtonType).toBe("delete-button");
50
+ let mockFileDeleteEvent = new CustomEvent("wmFileDelete");
51
+ //@ts-ignore
52
+ mockFileDeleteEvent.target = secondFileEl;
53
+ secondFileEl.dispatchEvent(mockFileDeleteEvent);
54
+ await page.evaluate(() => { var _a; return (_a = document.getElementById("file2")) === null || _a === void 0 ? void 0 : _a.remove(); });
55
+ await page.waitForChanges();
56
+ // confirm file has been removed
57
+ fileEls = await page.findAll("wm-file");
58
+ expect(fileEls.length).toBe(1);
59
+ // check focused element is last file, delete button
60
+ activeElId = await page.evaluate(() => document.activeElement.id);
61
+ expect(activeElId).toBe("file1");
62
+ activeElButtonType = await page.evaluate(() => document.activeElement.shadowRoot.activeElement.classList[0]);
63
+ expect(activeElButtonType).toBe("delete-button");
64
+ });
65
+ // it("disables the button dynamically", async () => {
66
+ // disabled when maxed out
67
+ // disabled while a file is uploading
68
+ // not disabled after upload
69
+ // });
70
+ });
@@ -1,11 +1,14 @@
1
1
  import { h, Host, forceUpdate, } from "@stencil/core";
2
2
  import { uploaderMessages } from "../../global/intl";
3
+ import { intl } from "../../global/functions";
3
4
  export class Uploader {
4
5
  constructor() {
5
6
  this.batchCount = 0; // used to calculate the aggregate upload progress
6
7
  this.prevUploadCount = 0; // comparison to determine whether or not to announce updated count
7
8
  this.fileIdToDelete = "";
8
9
  this.label = undefined;
10
+ this.uploaderType = "select";
11
+ this.dropArea = "component";
9
12
  this.buttonText = undefined;
10
13
  this.icon = undefined;
11
14
  this.fileTypes = "pdf txt log xml doc docx xls xlsx ppt pptx gif jpg jpeg png csv";
@@ -49,6 +52,27 @@ export class Uploader {
49
52
  storeDeletedId(ev) {
50
53
  this.fileIdToDelete = ev.target.id;
51
54
  }
55
+ handleDocumentDragEnter() {
56
+ if (this.uploaderType == "drop") {
57
+ this.dropAreaEl.classList.add("listening");
58
+ }
59
+ }
60
+ handleMouseOver() {
61
+ if (this.uploaderType == "drop") {
62
+ this.dropAreaEl.classList.remove("listening");
63
+ }
64
+ }
65
+ handleDocumentDragLeave(ev) {
66
+ if (this.uploaderType == "drop") {
67
+ if (ev.target == null || ev.target.nodeName == "HTML")
68
+ this.dropAreaEl.classList.remove("listening");
69
+ }
70
+ }
71
+ handleDocumentVisibilityChange() {
72
+ if (this.uploaderType == "drop") {
73
+ this.dropAreaEl.classList.remove("listening");
74
+ }
75
+ }
52
76
  announceError() {
53
77
  if (this.errorMessage) {
54
78
  setTimeout(() => this.announce(this.errorMessage, this.politeLiveRegionEl), 100);
@@ -155,15 +179,46 @@ export class Uploader {
155
179
  }
156
180
  }
157
181
  }
158
- handleUploadButtonChange(ev) {
159
- const inputEl = ev.target;
160
- if (inputEl.files) {
161
- const files = Array.from(inputEl.files);
182
+ handleUploadButtonChange() {
183
+ if (this.uploadButtonEl.files) {
184
+ const files = Array.from(this.uploadButtonEl.files);
162
185
  if (files.length > 0) {
163
186
  this.batchCount = files.length;
164
187
  this.wmUploaderFilesSelected.emit(files);
165
188
  }
166
- ev.target.value = ""; // reset to ensure that onChange is triggered when the same file is selected a second time
189
+ this.uploadButtonEl.value = ""; // reset to ensure that onChange is triggered when the same file is selected a second time
190
+ }
191
+ }
192
+ handleDragEnter(ev) {
193
+ if (this.uploaderType == "drop") {
194
+ ev.preventDefault();
195
+ this.el.classList.add("dragging");
196
+ }
197
+ }
198
+ handleDragOver(ev) {
199
+ if (this.uploaderType == "drop") {
200
+ ev.preventDefault();
201
+ }
202
+ }
203
+ handleDragLeave(ev) {
204
+ if (this.uploaderType == "drop") {
205
+ ev.preventDefault();
206
+ this.dropAreaEl.classList.remove("listening");
207
+ this.el.classList.remove("dragging");
208
+ }
209
+ }
210
+ handleDrop(ev) {
211
+ if (this.uploaderType == "drop") {
212
+ ev.preventDefault();
213
+ this.el.classList.remove("dragging");
214
+ this.dropAreaEl.classList.remove("listening");
215
+ if (ev.dataTransfer.files) {
216
+ const files = Array.from(ev.dataTransfer.files);
217
+ if (files.length > 0) {
218
+ this.batchCount = files.length;
219
+ this.wmUploaderFilesSelected.emit(files);
220
+ }
221
+ }
167
222
  }
168
223
  }
169
224
  announce(message, liveRegionEl) {
@@ -188,15 +243,40 @@ export class Uploader {
188
243
  return (h("span", { class: "mdi", "aria-hidden": "true" }, String.fromCodePoint(parseInt(`0x${this.icon}`))));
189
244
  }
190
245
  }
191
- renderUploadButton(classes) {
246
+ renderUploadButton() {
192
247
  let accessibleLabel = `${this.label && this.label !== this.buttonText ? `${this.label}, ` : ""}${this.buttonText}`;
193
- return (h("div", { class: "info-wrapper" }, h("input", { name: "input", id: "input", ref: (el) => (this.uploadButtonEl = el), class: "sr-only", "aria-label": accessibleLabel, "aria-required": this.requiredField ? "true" : null, "aria-describedby": `${this.errorMessage ? "error " : ""}file-count max-size accepted-types`, type: "file", multiple: true, onClick: (ev) => this.handleUploadButtonClick(ev), onChange: (ev) => this.handleUploadButtonChange(ev) }), h("label", { htmlFor: "input", class: `wm-button ${classes}` }, this.icon && this.renderIcon(), this.buttonText)));
248
+ return (h("div", { class: "button-wrapper" }, h("input", { name: "input", id: "input", ref: (el) => (this.uploadButtonEl = el), class: "sr-only", "aria-label": accessibleLabel, "aria-required": this.requiredField ? "true" : null, "aria-describedby": `${this.errorMessage ? "error " : ""}file-count max-size accepted-types`, type: "file", multiple: true, onClick: (ev) => this.handleUploadButtonClick(ev), onChange: () => this.handleUploadButtonChange() }), h("label", { htmlFor: "input", class: `wm-button -secondary ${this.isDisabled ? "disabled" : ""}` }, this.icon && this.renderIcon(), this.buttonText), this.uploaderType == "select" && this.renderFileCount()));
249
+ }
250
+ renderDropButton() {
251
+ let accessibleLabel = `${this.label && this.label !== this.buttonText ? `${this.label}, ` : ""}${uploaderMessages.dropInstructions}`;
252
+ return (h("div", { class: "button-wrapper -drop" }, h("input", { name: "input", id: "input", ref: (el) => (this.uploadButtonEl = el), class: "sr-only", "aria-label": accessibleLabel, "aria-required": this.requiredField ? "true" : null, "aria-describedby": `${this.errorMessage ? "error " : ""}file-count max-size accepted-types`, type: "file", multiple: true, onClick: (ev) => this.handleUploadButtonClick(ev), onChange: () => this.handleUploadButtonChange() }), h("label", { htmlFor: "input", class: `${this.isDisabled ? "disabled" : ""}` }, h("div", { class: "prompt" }, h("span", { class: "upload-arrow" }), h("span", { id: "drop-text", class: `wm-button -textonly ${this.isDisabled ? "disabled" : ""}` }, uploaderMessages.dropInstructions)), this.renderFileCount())));
194
253
  }
195
254
  renderHeader() {
196
- return (h("div", { class: "header" }, h("div", { class: "notif-wrapper" }, this.renderUploadButton(`-secondary ${this.isDisabled ? "disabled" : ""}`), this.renderRequirements()), h("div", { id: "accepted-types", class: "accepted-types" }, uploaderMessages.getAcceptedFileTypes(this.validTypes, this.fileTypes.split(" ").length)), this.notif && h("div", { class: "notif" }, this.notif), h("div", { id: "error" }, this.errorMessage)));
255
+ return (h("div", { class: "header" }, h("div", { class: "notif-wrapper" }, this.uploaderType == "select" ? this.renderUploadButton() : this.renderDropButton(), this.renderRequirements()), this.notif && h("div", { class: "notif" }, this.notif), h("div", { id: "error" }, this.errorMessage)));
256
+ }
257
+ renderFileCount() {
258
+ if (this.maxFiles) {
259
+ return h("div", { id: "file-count" }, uploaderMessages.getFileCount(this.uploadedFileEls.length, this.maxFiles));
260
+ }
197
261
  }
198
262
  renderRequirements() {
199
- return (h("div", { class: "requirements" }, this.maxFiles && (h("span", { id: "file-count" }, uploaderMessages.getFileCount(this.uploadedFileEls.length, this.maxFiles))), this.maxSize && h("span", { id: "max-size" }, uploaderMessages.getMaxSize(this.maxSize))));
263
+ const maxSizeMessage = intl.formatMessage({
264
+ id: "uploader.maxSize",
265
+ defaultMessage: "<b>Maximum File Size:</b> {maxSize}",
266
+ description: "An indicator of the maximum file size the uploader allows",
267
+ }, {
268
+ maxSize: this.maxSize,
269
+ b: (chunks) => h("span", { style: { "font-weight": "600" } }, chunks),
270
+ });
271
+ const acceptedTypesMessage = intl.formatMessage({
272
+ id: "uploader.acceptedFileTypes",
273
+ defaultMessage: "<b>Accepted File {amount, plural, =1 {Type} other {Types}}:</b> {fileTypes}",
274
+ }, {
275
+ fileTypes: this.validTypes,
276
+ amount: this.fileTypes.split(" ").length,
277
+ b: (chunks) => h("span", { style: { "font-weight": "600" } }, chunks),
278
+ });
279
+ return (h("details", { class: "requirements" }, h("summary", null, uploaderMessages.fileRequirements), h("div", { class: "requirements-wrapper" }, h("div", { id: "accepted-types", class: "accepted-types" }, acceptedTypesMessage), this.maxSize && h("span", { id: "max-size" }, maxSizeMessage))));
200
280
  }
201
281
  renderListContainer() {
202
282
  const hasNewlyUploadedFiles = this.fileEls.filter((file) => file.progress && file.progress === 100).length;
@@ -205,10 +285,13 @@ export class Uploader {
205
285
  renderLabel() {
206
286
  return (h("div", { class: `wrapper ${this.errorMessage ? "invalid" : ""}` }, h("div", { id: "label", class: `label` }, this.label, this.requiredField && (h("span", { class: "required", "aria-hidden": "true" }, "*")))));
207
287
  }
288
+ renderDropArea() {
289
+ return (h("div", { class: `drop-area -${this.dropArea}`, ref: (el) => (this.dropAreaEl = el), onDragEnter: (ev) => this.handleDragEnter(ev), onDragOver: (ev) => this.handleDragOver(ev), onDragLeave: (ev) => this.handleDragLeave(ev), onDrop: (ev) => this.handleDrop(ev) }, this.dropArea == "page" && (h("div", { class: "drop-overlay" }, h("span", { class: "upload-arrow" }), h("span", null, "Drop to Upload")))));
290
+ }
208
291
  render() {
209
- return (h(Host, { key: '46d82b5386359d17221f7b7376dbbafcdd245543' }, this.label && this.renderLabel(), this.renderHeader(), this.renderListContainer(), h("div", { key: 'b7f938f7da392db21554228ab4f104a2116ecb44', ref: (el) => (this.assertiveLiveRegionEl = el), class: "live-region sr-only", "aria-live": "assertive" // since it's directly linked to the action the user took, it should be read in priority. With polite, some messages get dismissed in favor of the page title
292
+ return (h(Host, null, this.uploaderType == "drop" && this.renderDropArea(), this.label && this.renderLabel(), this.renderHeader(), this.renderListContainer(), h("div", { ref: (el) => (this.assertiveLiveRegionEl = el), class: "live-region sr-only", "aria-live": "assertive" // since it's directly linked to the action the user took, it should be read in priority. With polite, some messages get dismissed in favor of the page title
210
293
  ,
211
- "aria-atomic": "true" }), h("div", { key: '1b0a6f5340262caed883ac70a38f76e80f6c0d5c', ref: (el) => (this.politeLiveRegionEl = el), class: "live-region sr-only", "aria-live": "polite", "aria-atomic": "true" })));
294
+ "aria-atomic": "true" }), h("div", { ref: (el) => (this.politeLiveRegionEl = el), class: "live-region sr-only", "aria-live": "polite", "aria-atomic": "true" })));
212
295
  }
213
296
  static get is() { return "wm-uploader"; }
214
297
  static get encapsulation() { return "shadow"; }
@@ -242,6 +325,42 @@ export class Uploader {
242
325
  "attribute": "label",
243
326
  "reflect": false
244
327
  },
328
+ "uploaderType": {
329
+ "type": "string",
330
+ "mutable": false,
331
+ "complexType": {
332
+ "original": "\"select\" | \"drop\"",
333
+ "resolved": "\"drop\" | \"select\"",
334
+ "references": {}
335
+ },
336
+ "required": false,
337
+ "optional": false,
338
+ "docs": {
339
+ "tags": [],
340
+ "text": ""
341
+ },
342
+ "attribute": "uploader-type",
343
+ "reflect": false,
344
+ "defaultValue": "\"select\""
345
+ },
346
+ "dropArea": {
347
+ "type": "string",
348
+ "mutable": false,
349
+ "complexType": {
350
+ "original": "\"component\" | \"page\"",
351
+ "resolved": "\"component\" | \"page\"",
352
+ "references": {}
353
+ },
354
+ "required": false,
355
+ "optional": false,
356
+ "docs": {
357
+ "tags": [],
358
+ "text": ""
359
+ },
360
+ "attribute": "drop-area",
361
+ "reflect": false,
362
+ "defaultValue": "\"component\""
363
+ },
245
364
  "buttonText": {
246
365
  "type": "string",
247
366
  "mutable": false,
@@ -444,6 +563,30 @@ export class Uploader {
444
563
  "target": undefined,
445
564
  "capture": false,
446
565
  "passive": false
566
+ }, {
567
+ "name": "dragenter",
568
+ "method": "handleDocumentDragEnter",
569
+ "target": "document",
570
+ "capture": false,
571
+ "passive": true
572
+ }, {
573
+ "name": "mouseover",
574
+ "method": "handleMouseOver",
575
+ "target": undefined,
576
+ "capture": false,
577
+ "passive": true
578
+ }, {
579
+ "name": "dragleave",
580
+ "method": "handleDocumentDragLeave",
581
+ "target": "document",
582
+ "capture": false,
583
+ "passive": true
584
+ }, {
585
+ "name": "visibilitychange",
586
+ "method": "handleDocumentVisibilityChange",
587
+ "target": "document",
588
+ "capture": false,
589
+ "passive": false
447
590
  }];
448
591
  }
449
592
  }