@watermarkinsights/ripple 5.10.0-14 → 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 (432) 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-69d4c258.js → cjs/global-705d39bd.js} +3 -8
  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 +6 -7
  9. package/dist/cjs/priv-chart-popover.cjs.entry.js +6 -7
  10. package/dist/cjs/priv-navigator-button.cjs.entry.js +4 -5
  11. package/dist/cjs/priv-navigator-item.cjs.entry.js +4 -5
  12. package/dist/cjs/priv-option-list.cjs.entry.js +5 -6
  13. package/dist/cjs/ripple.cjs.js +12 -13
  14. package/dist/cjs/wm-action-menu_2.cjs.entry.js +8 -10
  15. package/dist/cjs/wm-button.cjs.entry.js +5 -6
  16. package/dist/cjs/wm-chart-slice.cjs.entry.js +1 -1
  17. package/dist/cjs/wm-chart.cjs.entry.js +7 -8
  18. package/dist/cjs/wm-date-range.cjs.entry.js +9 -10
  19. package/dist/cjs/wm-datepicker.cjs.entry.js +9 -10
  20. package/dist/cjs/wm-file-list.cjs.entry.js +4 -5
  21. package/dist/cjs/wm-file.cjs.entry.js +5 -6
  22. package/dist/cjs/wm-input.cjs.entry.js +6 -7
  23. package/dist/cjs/wm-line-chart.cjs.entry.js +15 -16
  24. package/dist/cjs/wm-modal-pss_3.cjs.entry.js +13 -16
  25. package/dist/cjs/wm-modal_3.cjs.entry.js +13 -16
  26. package/dist/cjs/wm-navigation_3.cjs.entry.js +13 -16
  27. package/dist/cjs/wm-navigator.cjs.entry.js +4 -5
  28. package/dist/cjs/wm-nested-select.cjs.entry.js +8 -9
  29. package/dist/cjs/wm-optgroup.cjs.entry.js +5 -6
  30. package/dist/cjs/wm-option_2.cjs.entry.js +10 -12
  31. package/dist/cjs/wm-pagination.cjs.entry.js +5 -6
  32. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +9 -11
  33. package/dist/cjs/wm-search.cjs.entry.js +7 -8
  34. package/dist/cjs/wm-snackbar.cjs.entry.js +7 -8
  35. package/dist/cjs/wm-tab-item_3.cjs.entry.js +11 -14
  36. package/dist/cjs/wm-tag-input.cjs.entry.js +8 -9
  37. package/dist/cjs/wm-tag-option.cjs.entry.js +2 -2
  38. package/dist/cjs/wm-textarea.cjs.entry.js +6 -7
  39. package/dist/cjs/wm-timepicker.cjs.entry.js +6 -7
  40. package/dist/cjs/wm-toggletip.cjs.entry.js +6 -7
  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.css +5 -5
  47. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.e2e.js +81 -0
  48. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +2 -2
  49. package/dist/collection/components/charts/screenshots.e2e.js +96 -0
  50. package/dist/collection/components/charts/wm-chart/wm-chart.css +5 -5
  51. package/dist/collection/components/charts/wm-chart/wm-chart.e2e.js +213 -0
  52. package/dist/collection/components/charts/wm-chart/wm-chart.js +1 -1
  53. package/dist/collection/components/charts/wm-chart/wm-chart.spec.js +37 -0
  54. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.css +5 -5
  55. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.e2e.js +176 -0
  56. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +9 -9
  57. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.spec.js +163 -0
  58. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.css +5 -5
  59. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +1 -1
  60. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.css +5 -5
  61. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.e2e.js +69 -0
  62. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +1 -1
  63. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.spec.js +79 -0
  64. package/dist/collection/components/datepickers/datepicker.css +5 -5
  65. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.css +5 -5
  66. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +2 -2
  67. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.spec.js +89 -0
  68. package/dist/collection/components/datepickers/wm-date-range.e2e.js +443 -0
  69. package/dist/collection/components/datepickers/wm-date-range.js +13 -17
  70. package/dist/collection/components/datepickers/wm-date-range.spec.js +22 -0
  71. package/dist/collection/components/datepickers/wm-datepicker.e2e.js +382 -0
  72. package/dist/collection/components/datepickers/wm-datepicker.js +13 -17
  73. package/dist/collection/components/datepickers/wm-datepicker.spec.js +21 -0
  74. package/dist/collection/components/selects/priv-option-list/priv-option-list.css +5 -5
  75. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +5 -7
  76. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.css +5 -5
  77. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +3 -3
  78. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.css +5 -5
  79. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +1 -1
  80. package/dist/collection/components/selects/wm-option/wm-option.css +5 -5
  81. package/dist/collection/components/selects/wm-option/wm-option.e2e.js +22 -0
  82. package/dist/collection/components/selects/wm-option/wm-option.js +1 -1
  83. package/dist/collection/components/selects/wm-option/wm-option.spec.js +63 -0
  84. package/dist/collection/components/selects/wm-select/wm-select.css +5 -5
  85. package/dist/collection/components/selects/wm-select/wm-select.e2e.js +521 -0
  86. package/dist/collection/components/selects/wm-select/wm-select.js +2 -2
  87. package/dist/collection/components/selects/wm-select/wm-select.spec.js +271 -0
  88. package/dist/collection/components/wm-action-menu/wm-action-menu.css +5 -5
  89. package/dist/collection/components/wm-action-menu/wm-action-menu.e2e.js +200 -0
  90. package/dist/collection/components/wm-action-menu/wm-action-menu.js +1 -1
  91. package/dist/collection/components/wm-action-menu/wm-action-menu.spec.js +48 -0
  92. package/dist/collection/components/wm-button/wm-button.css +5 -5
  93. package/dist/collection/components/wm-button/wm-button.e2e.js +55 -0
  94. package/dist/collection/components/wm-button/wm-button.js +1 -1
  95. package/dist/collection/components/wm-button/wm-button.spec.js +74 -0
  96. package/dist/collection/components/wm-file/wm-file.css +5 -5
  97. package/dist/collection/components/wm-file/wm-file.js +1 -1
  98. package/dist/collection/components/wm-file/wm-file.spec.js +194 -0
  99. package/dist/collection/components/wm-file-list/wm-file-list.css +5 -5
  100. package/dist/collection/components/wm-file-list/wm-file-list.js +1 -1
  101. package/dist/collection/components/wm-file-list/wm-file-list.spec.js +69 -0
  102. package/dist/collection/components/wm-input/wm-input.css +5 -5
  103. package/dist/collection/components/wm-input/wm-input.e2e.js +32 -0
  104. package/dist/collection/components/wm-input/wm-input.js +1 -1
  105. package/dist/collection/components/wm-input/wm-input.spec.js +173 -0
  106. package/dist/collection/components/wm-menuitem/wm-menuitem.css +5 -5
  107. package/dist/collection/components/wm-menuitem/wm-menuitem.e2e.js +23 -0
  108. package/dist/collection/components/wm-menuitem/wm-menuitem.js +1 -1
  109. package/dist/collection/components/wm-menuitem/wm-menuitem.spec.js +54 -0
  110. package/dist/collection/components/wm-modal/wm-modal-footer.css +5 -5
  111. package/dist/collection/components/wm-modal/wm-modal-footer.js +1 -1
  112. package/dist/collection/components/wm-modal/wm-modal-footer.spec.js +11 -0
  113. package/dist/collection/components/wm-modal/wm-modal-header.css +5 -5
  114. package/dist/collection/components/wm-modal/wm-modal-header.js +1 -1
  115. package/dist/collection/components/wm-modal/wm-modal-header.spec.js +8 -0
  116. package/dist/collection/components/wm-modal/wm-modal.css +5 -5
  117. package/dist/collection/components/wm-modal/wm-modal.e2e.js +104 -0
  118. package/dist/collection/components/wm-modal/wm-modal.js +2 -2
  119. package/dist/collection/components/wm-modal/wm-modal.spec.js +30 -0
  120. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.css +5 -5
  121. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +1 -1
  122. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.css +5 -5
  123. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +1 -1
  124. package/dist/collection/components/wm-modal-pss/wm-modal-pss.css +5 -5
  125. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +2 -2
  126. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.css +5 -5
  127. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +1 -1
  128. package/dist/collection/components/wm-navigation/wm-navigation-item.css +5 -5
  129. package/dist/collection/components/wm-navigation/wm-navigation-item.js +1 -1
  130. package/dist/collection/components/wm-navigation/wm-navigation.css +5 -5
  131. package/dist/collection/components/wm-navigation/wm-navigation.e2e.js +102 -0
  132. package/dist/collection/components/wm-navigation/wm-navigation.js +2 -2
  133. package/dist/collection/components/wm-navigation/wm-navigation.spec.js +91 -0
  134. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +5 -5
  135. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.e2e.js +50 -0
  136. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +1 -1
  137. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +5 -5
  138. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +2 -2
  139. package/dist/collection/components/wm-navigator/wm-navigator.css +5 -5
  140. package/dist/collection/components/wm-navigator/wm-navigator.e2e.js +209 -0
  141. package/dist/collection/components/wm-navigator/wm-navigator.spec.js +177 -0
  142. package/dist/collection/components/wm-pagination/wm-pagination.css +5 -5
  143. package/dist/collection/components/wm-pagination/wm-pagination.e2e.js +312 -0
  144. package/dist/collection/components/wm-pagination/wm-pagination.js +1 -1
  145. package/dist/collection/components/wm-search/wm-search.css +5 -5
  146. package/dist/collection/components/wm-search/wm-search.e2e.js +76 -0
  147. package/dist/collection/components/wm-search/wm-search.js +4 -5
  148. package/dist/collection/components/wm-search/wm-search.spec.js +71 -0
  149. package/dist/collection/components/wm-snackbar/wm-snackbar.css +5 -5
  150. package/dist/collection/components/wm-snackbar/wm-snackbar.e2e.js +112 -0
  151. package/dist/collection/components/wm-snackbar/wm-snackbar.js +2 -2
  152. package/dist/collection/components/wm-snackbar/wm-snackbar.spec.js +9 -0
  153. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +5 -5
  154. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +1 -1
  155. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +5 -5
  156. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +1 -1
  157. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +5 -5
  158. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +1 -1
  159. package/dist/collection/components/wm-tabs/wm-tabs.e2e.js +91 -0
  160. package/dist/collection/components/wm-tabs/wm-tabs.spec.js +12 -0
  161. package/dist/collection/components/wm-tag-input/wm-tag-input.css +5 -5
  162. package/dist/collection/components/wm-tag-input/wm-tag-input.e2e.js +204 -0
  163. package/dist/collection/components/wm-tag-input/wm-tag-input.js +3 -3
  164. package/dist/collection/components/wm-tag-input/wm-tag-input.spec.js +195 -0
  165. package/dist/collection/components/wm-textarea/wm-textarea.css +5 -5
  166. package/dist/collection/components/wm-textarea/wm-textarea.e2e.js +41 -0
  167. package/dist/collection/components/wm-textarea/wm-textarea.js +1 -1
  168. package/dist/collection/components/wm-textarea/wm-textarea.spec.js +79 -0
  169. package/dist/collection/components/wm-timepicker/wm-timepicker.css +5 -5
  170. package/dist/collection/components/wm-timepicker/wm-timepicker.e2e.js +163 -0
  171. package/dist/collection/components/wm-timepicker/wm-timepicker.js +8 -11
  172. package/dist/collection/components/wm-timepicker/wm-timepicker.spec.js +147 -0
  173. package/dist/collection/components/wm-toggletip/wm-toggletip.css +5 -5
  174. package/dist/collection/components/wm-toggletip/wm-toggletip.e2e.js +69 -0
  175. package/dist/collection/components/wm-toggletip/wm-toggletip.js +2 -2
  176. package/dist/collection/components/wm-toggletip/wm-toggletip.spec.js +21 -0
  177. package/dist/collection/components/wm-uploader/wm-uploader.css +154 -13
  178. package/dist/collection/components/wm-uploader/wm-uploader.e2e.js +70 -0
  179. package/dist/collection/components/wm-uploader/wm-uploader.js +154 -11
  180. package/dist/collection/components/wm-uploader/wm-uploader.spec.js +234 -0
  181. package/dist/collection/global/functions.spec.js +126 -0
  182. package/dist/collection/global/global.js +1 -1
  183. package/dist/collection/global/intl.js +10 -14
  184. package/dist/collection/lang/lang.spec.js +20 -0
  185. package/dist/collection/lang/missing.js +43 -43
  186. package/dist/collection/lang/piglatin.js +93 -93
  187. package/dist/esm/{chartFunctions-21d5a3d3.js → chartFunctions-5555bab0.js} +3 -3
  188. package/dist/esm/{functions-f39e6177.js → functions-8800c690.js} +8 -105
  189. package/dist/{cjs/app-globals-385434e8.js → esm/global-a377e5a4.js} +2 -11
  190. package/dist/esm/index-558b5a82.js +2618 -0
  191. package/dist/esm/{intl-dda73e98.js → intl-82ebfb79.js} +11 -15
  192. package/dist/esm/loader.js +5 -6
  193. package/dist/esm/polyfills/core-js.js +0 -0
  194. package/dist/esm/polyfills/dom.js +0 -0
  195. package/dist/esm/polyfills/es5-html-element.js +0 -0
  196. package/dist/esm/polyfills/index.js +0 -0
  197. package/dist/esm/polyfills/system.js +0 -0
  198. package/dist/esm/priv-calendar.entry.js +6 -7
  199. package/dist/esm/priv-chart-popover.entry.js +6 -7
  200. package/dist/esm/priv-navigator-button.entry.js +4 -5
  201. package/dist/esm/priv-navigator-item.entry.js +4 -5
  202. package/dist/esm/priv-option-list.entry.js +5 -6
  203. package/dist/esm/ripple.js +13 -14
  204. package/dist/esm/wm-action-menu_2.entry.js +8 -10
  205. package/dist/esm/wm-button.entry.js +5 -6
  206. package/dist/esm/wm-chart-slice.entry.js +1 -1
  207. package/dist/esm/wm-chart.entry.js +7 -8
  208. package/dist/esm/wm-date-range.entry.js +9 -10
  209. package/dist/esm/wm-datepicker.entry.js +9 -10
  210. package/dist/esm/wm-file-list.entry.js +4 -5
  211. package/dist/esm/wm-file.entry.js +5 -6
  212. package/dist/esm/wm-input.entry.js +6 -7
  213. package/dist/esm/wm-line-chart.entry.js +15 -16
  214. package/dist/esm/wm-modal-pss_3.entry.js +13 -16
  215. package/dist/esm/wm-modal_3.entry.js +13 -16
  216. package/dist/esm/wm-navigation_3.entry.js +13 -16
  217. package/dist/esm/wm-navigator.entry.js +4 -5
  218. package/dist/esm/wm-nested-select.entry.js +8 -9
  219. package/dist/esm/wm-optgroup.entry.js +5 -6
  220. package/dist/esm/wm-option_2.entry.js +10 -12
  221. package/dist/esm/wm-pagination.entry.js +5 -6
  222. package/dist/esm/wm-progress-indicator_3.entry.js +9 -11
  223. package/dist/esm/wm-search.entry.js +7 -8
  224. package/dist/esm/wm-snackbar.entry.js +7 -8
  225. package/dist/esm/wm-tab-item_3.entry.js +11 -14
  226. package/dist/esm/wm-tag-input.entry.js +8 -9
  227. package/dist/esm/wm-tag-option.entry.js +2 -2
  228. package/dist/esm/wm-textarea.entry.js +6 -7
  229. package/dist/esm/wm-timepicker.entry.js +6 -7
  230. package/dist/esm/wm-toggletip.entry.js +6 -7
  231. package/dist/esm/wm-uploader.entry.js +98 -17
  232. package/dist/esm/wm-wrapper.entry.js +1 -1
  233. package/dist/esm-es5/{chartFunctions-21d5a3d3.js → chartFunctions-5555bab0.js} +1 -1
  234. package/dist/esm-es5/functions-8800c690.js +1 -0
  235. package/dist/esm-es5/global-a377e5a4.js +1 -0
  236. package/dist/esm-es5/index-558b5a82.js +1 -0
  237. package/dist/esm-es5/{intl-dda73e98.js → intl-82ebfb79.js} +1 -1
  238. package/dist/esm-es5/loader.js +1 -1
  239. package/dist/esm-es5/priv-calendar.entry.js +1 -1
  240. package/dist/esm-es5/priv-chart-popover.entry.js +1 -1
  241. package/dist/esm-es5/priv-navigator-button.entry.js +1 -1
  242. package/dist/esm-es5/priv-navigator-item.entry.js +1 -1
  243. package/dist/esm-es5/priv-option-list.entry.js +1 -1
  244. package/dist/esm-es5/ripple.js +1 -1
  245. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -1
  246. package/dist/esm-es5/wm-button.entry.js +1 -1
  247. package/dist/esm-es5/wm-chart-slice.entry.js +1 -1
  248. package/dist/esm-es5/wm-chart.entry.js +1 -1
  249. package/dist/esm-es5/wm-date-range.entry.js +1 -1
  250. package/dist/esm-es5/wm-datepicker.entry.js +1 -1
  251. package/dist/esm-es5/wm-file-list.entry.js +1 -1
  252. package/dist/esm-es5/wm-file.entry.js +1 -1
  253. package/dist/esm-es5/wm-input.entry.js +1 -1
  254. package/dist/esm-es5/wm-line-chart.entry.js +1 -1
  255. package/dist/esm-es5/wm-modal-pss_3.entry.js +1 -1
  256. package/dist/esm-es5/wm-modal_3.entry.js +1 -1
  257. package/dist/esm-es5/wm-navigation_3.entry.js +1 -1
  258. package/dist/esm-es5/wm-navigator.entry.js +1 -1
  259. package/dist/esm-es5/wm-nested-select.entry.js +1 -1
  260. package/dist/esm-es5/wm-optgroup.entry.js +1 -1
  261. package/dist/esm-es5/wm-option_2.entry.js +1 -1
  262. package/dist/esm-es5/wm-pagination.entry.js +1 -1
  263. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -1
  264. package/dist/esm-es5/wm-search.entry.js +1 -1
  265. package/dist/esm-es5/wm-snackbar.entry.js +1 -1
  266. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -1
  267. package/dist/esm-es5/wm-tag-input.entry.js +1 -1
  268. package/dist/esm-es5/wm-tag-option.entry.js +1 -1
  269. package/dist/esm-es5/wm-textarea.entry.js +1 -1
  270. package/dist/esm-es5/wm-timepicker.entry.js +1 -1
  271. package/dist/esm-es5/wm-toggletip.entry.js +1 -1
  272. package/dist/esm-es5/wm-uploader.entry.js +1 -1
  273. package/dist/esm-es5/wm-wrapper.entry.js +1 -1
  274. package/dist/loader/cdn.js +2 -1
  275. package/dist/loader/index.cjs.js +2 -1
  276. package/dist/loader/index.d.ts +0 -3
  277. package/dist/loader/index.es2017.js +2 -1
  278. package/dist/loader/index.js +2 -1
  279. package/dist/ripple/p-04502e9c.entry.js +1 -0
  280. package/dist/ripple/p-0aa8c50e.entry.js +1 -0
  281. package/dist/ripple/p-0b4b0741.system.entry.js +1 -0
  282. package/dist/ripple/p-0bffcc33.entry.js +1 -0
  283. package/dist/ripple/p-0d082f95.entry.js +1 -0
  284. package/dist/ripple/p-0eddc626.entry.js +1 -0
  285. package/dist/ripple/p-0fc6dab9.system.entry.js +1 -0
  286. package/dist/ripple/{p-73ce9af7.js → p-11d66b54.js} +1 -1
  287. package/dist/ripple/p-1887c39d.entry.js +1 -0
  288. package/dist/ripple/p-1a4d00a9.system.entry.js +1 -0
  289. package/dist/ripple/p-1bb48113.system.entry.js +1 -0
  290. package/dist/ripple/p-1f695ead.system.entry.js +1 -0
  291. package/dist/ripple/p-21a4a455.system.entry.js +1 -0
  292. package/dist/ripple/p-221a7c22.entry.js +1 -0
  293. package/dist/ripple/{p-37b044c7.system.js → p-2ce69098.system.js} +1 -1
  294. package/dist/ripple/{p-823d7b4e.system.entry.js → p-32bf3f5b.system.entry.js} +1 -1
  295. package/dist/ripple/p-34014c8d.system.entry.js +1 -0
  296. package/dist/ripple/p-34218322.system.entry.js +1 -0
  297. package/dist/ripple/p-3bdb760a.entry.js +1 -0
  298. package/dist/ripple/p-3c3c6b29.system.entry.js +1 -0
  299. package/dist/ripple/p-3fb7444d.system.entry.js +1 -0
  300. package/dist/ripple/p-40129c5d.js +1 -0
  301. package/dist/ripple/{p-c34c9cbb.system.entry.js → p-4743176d.system.entry.js} +1 -1
  302. package/dist/ripple/{p-13b1d775.entry.js → p-48e09589.entry.js} +1 -1
  303. package/dist/ripple/p-4abcb864.entry.js +1 -0
  304. package/dist/ripple/p-4edb481f.system.entry.js +1 -0
  305. package/dist/ripple/p-50501e07.entry.js +1 -0
  306. package/dist/ripple/p-51718b06.system.entry.js +1 -0
  307. package/dist/ripple/{p-44526834.entry.js → p-53975533.entry.js} +1 -1
  308. package/dist/ripple/p-568c595f.js +2 -0
  309. package/dist/ripple/{p-f41ab9ea.js → p-599dd035.js} +1 -1
  310. package/dist/ripple/{p-61769bc6.entry.js → p-5a2b1e2b.system.entry.js} +1 -1
  311. package/dist/ripple/p-5f78dd11.entry.js +1 -0
  312. package/dist/ripple/p-5fe90111.entry.js +1 -0
  313. package/dist/ripple/{p-043901ab.system.entry.js → p-65d26233.system.entry.js} +1 -1
  314. package/dist/ripple/{p-470ee72d.system.entry.js → p-68f39a1f.system.entry.js} +1 -1
  315. package/dist/ripple/p-6a7fd013.system.entry.js +1 -0
  316. package/dist/ripple/p-6b859ff2.entry.js +1 -0
  317. package/dist/ripple/p-72bf2c06.system.entry.js +1 -0
  318. package/dist/ripple/p-76a9ae45.system.js +1 -0
  319. package/dist/ripple/{p-b0dddc8b.system.js → p-7a647f51.system.js} +1 -1
  320. package/dist/ripple/p-7cf74ee6.system.js +1 -0
  321. package/dist/ripple/p-7f0ca371.system.entry.js +1 -0
  322. package/dist/ripple/p-7f7c5da2.system.entry.js +1 -0
  323. package/dist/ripple/p-88ae8914.system.entry.js +1 -0
  324. package/dist/ripple/p-88c968e7.system.entry.js +1 -0
  325. package/dist/ripple/{p-cd0cc88d.entry.js → p-88ebddd7.entry.js} +1 -1
  326. package/dist/ripple/p-8d7ecab9.entry.js +1 -0
  327. package/dist/ripple/p-8fcebe03.entry.js +1 -0
  328. package/dist/ripple/p-919fd2b6.entry.js +1 -0
  329. package/dist/ripple/p-950dc6c4.system.entry.js +1 -0
  330. package/dist/ripple/p-9f2a0e0a.entry.js +1 -0
  331. package/dist/ripple/p-9f38f65d.system.entry.js +1 -0
  332. package/dist/ripple/p-a0e84979.entry.js +1 -0
  333. package/dist/ripple/p-ab8d78cc.system.js +2 -0
  334. package/dist/ripple/{p-2d3c8179.system.entry.js → p-ac625334.system.entry.js} +1 -1
  335. package/dist/ripple/p-b0512477.system.entry.js +1 -0
  336. package/dist/ripple/p-b0ada8f7.system.entry.js +1 -0
  337. package/dist/ripple/p-b1fe3bbc.system.entry.js +1 -0
  338. package/dist/ripple/p-b72aa60b.entry.js +1 -0
  339. package/dist/ripple/{p-76d248e6.entry.js → p-b976c84b.entry.js} +1 -1
  340. package/dist/ripple/p-bc566798.entry.js +1 -0
  341. package/dist/ripple/p-c0f370f9.system.entry.js +1 -0
  342. package/dist/ripple/p-c6c43720.entry.js +1 -0
  343. package/dist/ripple/p-ce191133.entry.js +1 -0
  344. package/dist/ripple/{p-4de2ab7e.system.entry.js → p-d168b8bc.entry.js} +1 -1
  345. package/dist/ripple/p-d8bc3fd7.system.entry.js +1 -0
  346. package/dist/ripple/p-dadb480d.system.entry.js +1 -0
  347. package/dist/ripple/p-dcbed420.entry.js +1 -0
  348. package/dist/ripple/{p-f03dd608.system.entry.js → p-df387590.entry.js} +1 -1
  349. package/dist/ripple/p-e49d3992.entry.js +1 -0
  350. package/dist/ripple/p-e5b62488.entry.js +1 -0
  351. package/dist/ripple/{p-86520ba3.system.entry.js → p-e5c8a584.entry.js} +1 -1
  352. package/dist/ripple/p-eca78c2b.js +1 -0
  353. package/dist/ripple/p-edd87140.system.js +1 -0
  354. package/dist/ripple/p-ef980041.system.entry.js +1 -0
  355. package/dist/ripple/p-f623828b.entry.js +1 -0
  356. package/dist/ripple/p-f94b8117.system.entry.js +1 -0
  357. package/dist/ripple/p-fef994ea.entry.js +1 -0
  358. package/dist/ripple/ripple.css +1 -1
  359. package/dist/ripple/ripple.esm.js +1 -1
  360. package/dist/ripple/ripple.js +1 -1
  361. package/dist/types/components/wm-uploader/wm-uploader.d.ts +16 -2
  362. package/dist/types/components.d.ts +10 -6
  363. package/dist/types/global/intl.d.ts +2 -2
  364. package/dist/types/stencil-public-runtime.d.ts +10 -3
  365. package/package.json +1 -1
  366. package/dist/cjs/index-788526f5.js +0 -1859
  367. package/dist/esm/index-130e07bb.js +0 -1828
  368. package/dist/esm-es5/app-globals-69d4c258.js +0 -1
  369. package/dist/esm-es5/functions-f39e6177.js +0 -1
  370. package/dist/esm-es5/index-130e07bb.js +0 -1
  371. package/dist/ripple/p-01621baa.system.entry.js +0 -1
  372. package/dist/ripple/p-066e22a8.entry.js +0 -1
  373. package/dist/ripple/p-0b9cfafd.entry.js +0 -1
  374. package/dist/ripple/p-1b022b07.entry.js +0 -1
  375. package/dist/ripple/p-1b3c81cd.system.entry.js +0 -1
  376. package/dist/ripple/p-1dbc5def.system.entry.js +0 -1
  377. package/dist/ripple/p-1e9e2b61.entry.js +0 -1
  378. package/dist/ripple/p-23d2a65e.system.entry.js +0 -1
  379. package/dist/ripple/p-2a825f9b.system.entry.js +0 -1
  380. package/dist/ripple/p-382d18ef.entry.js +0 -1
  381. package/dist/ripple/p-3bf21b98.entry.js +0 -1
  382. package/dist/ripple/p-3d1bb82e.system.entry.js +0 -1
  383. package/dist/ripple/p-3de00415.entry.js +0 -1
  384. package/dist/ripple/p-3f486eed.system.js +0 -1
  385. package/dist/ripple/p-446adb62.entry.js +0 -1
  386. package/dist/ripple/p-457b0368.entry.js +0 -1
  387. package/dist/ripple/p-45bb1cca.entry.js +0 -1
  388. package/dist/ripple/p-4a88d7f0.system.entry.js +0 -1
  389. package/dist/ripple/p-4b41b2b2.system.entry.js +0 -1
  390. package/dist/ripple/p-54bf5f8f.system.entry.js +0 -1
  391. package/dist/ripple/p-55175883.system.entry.js +0 -1
  392. package/dist/ripple/p-585d7d8b.entry.js +0 -1
  393. package/dist/ripple/p-5d7bb3db.system.entry.js +0 -1
  394. package/dist/ripple/p-60bfae00.system.entry.js +0 -1
  395. package/dist/ripple/p-6182809b.system.entry.js +0 -1
  396. package/dist/ripple/p-69111fc9.entry.js +0 -1
  397. package/dist/ripple/p-6e674694.entry.js +0 -1
  398. package/dist/ripple/p-7936661f.entry.js +0 -1
  399. package/dist/ripple/p-7d2bdfa7.system.entry.js +0 -1
  400. package/dist/ripple/p-7e8ce599.entry.js +0 -1
  401. package/dist/ripple/p-834d3b6e.system.entry.js +0 -1
  402. package/dist/ripple/p-84bbdb6c.system.entry.js +0 -1
  403. package/dist/ripple/p-86aa69a1.system.entry.js +0 -1
  404. package/dist/ripple/p-89419541.system.entry.js +0 -1
  405. package/dist/ripple/p-89a2db02.js +0 -1
  406. package/dist/ripple/p-8c5e08b0.entry.js +0 -1
  407. package/dist/ripple/p-8ee66c9b.entry.js +0 -1
  408. package/dist/ripple/p-8f6688d1.entry.js +0 -1
  409. package/dist/ripple/p-8fd93b85.system.js +0 -1
  410. package/dist/ripple/p-916ac4da.system.entry.js +0 -1
  411. package/dist/ripple/p-9bc259e7.system.entry.js +0 -1
  412. package/dist/ripple/p-9d50b702.entry.js +0 -1
  413. package/dist/ripple/p-a377f8ca.system.entry.js +0 -1
  414. package/dist/ripple/p-a388c103.system.entry.js +0 -1
  415. package/dist/ripple/p-a80168b0.entry.js +0 -1
  416. package/dist/ripple/p-aabde755.entry.js +0 -1
  417. package/dist/ripple/p-b0268240.js +0 -1
  418. package/dist/ripple/p-b25b3606.system.js +0 -1
  419. package/dist/ripple/p-b6427999.system.entry.js +0 -1
  420. package/dist/ripple/p-c1031d35.system.entry.js +0 -1
  421. package/dist/ripple/p-c679e48c.system.entry.js +0 -1
  422. package/dist/ripple/p-c92ef4d6.entry.js +0 -1
  423. package/dist/ripple/p-cef8a45b.system.js +0 -2
  424. package/dist/ripple/p-d52910b9.entry.js +0 -1
  425. package/dist/ripple/p-d9da0502.js +0 -2
  426. package/dist/ripple/p-da765ca3.entry.js +0 -1
  427. package/dist/ripple/p-dad57469.entry.js +0 -1
  428. package/dist/ripple/p-e06014b0.entry.js +0 -1
  429. package/dist/ripple/p-e69169a2.system.entry.js +0 -1
  430. package/dist/ripple/p-eeccd224.entry.js +0 -1
  431. package/dist/ripple/p-eee1dcec.entry.js +0 -1
  432. package/dist/ripple/p-fdfca672.entry.js +0 -1
@@ -504,7 +504,7 @@
504
504
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M15,14C12.33,14 7,15.33 7,18V20H23V18C23,15.33 17.67,14 15,14M6,10V7H4V10H1V12H4V15H6V12H9V10M15,12A4,4 0 0,0 19,8A4,4 0 0,0 15,4A4,4 0 0,0 11,8A4,4 0 0,0 15,12Z'/%3E%3C/svg%3E%0A");
505
505
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M15,14C12.33,14 7,15.33 7,18V20H23V18C23,15.33 17.67,14 15,14M6,10V7H4V10H1V12H4V15H6V12H9V10M15,12A4,4 0 0,0 19,8A4,4 0 0,0 15,4A4,4 0 0,0 11,8A4,4 0 0,0 15,12Z'/%3E%3C/svg%3E%0A");
506
506
  }
507
- .svg-icon.svg-add-tag:before {
507
+ .svg-icon.svg-add-outline:before {
508
508
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2M13,7H11V11H7V13H11V17H13V13H17V11H13V7Z'/%3E%3C/svg%3E%0A");
509
509
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2M13,7H11V11H7V13H11V17H13V13H17V11H13V7Z'/%3E%3C/svg%3E%0A");
510
510
  }
@@ -520,10 +520,6 @@
520
520
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M19.8 22.6L17.15 20H6.5Q4.2 20 2.6 18.4T1 14.5Q1 12.58 2.19 11.08 3.38 9.57 5.25 9.15 5.33 8.95 5.4 8.76 5.5 8.57 5.55 8.35L1.4 4.2L2.8 2.8L21.2 21.2M6.5 18H15.15L7.1 9.95Q7.05 10.23 7.03 10.5 7 10.73 7 11H6.5Q5.05 11 4.03 12.03 3 13.05 3 14.5 3 15.95 4.03 17 5.05 18 6.5 18M11.13 14M21.6 18.75L20.15 17.35Q20.58 17 20.79 16.54 21 16.08 21 15.5 21 14.45 20.27 13.73 19.55 13 18.5 13H17V11Q17 8.93 15.54 7.46 14.08 6 12 6 11.33 6 10.7 6.16 10.07 6.33 9.5 6.68L8.05 5.23Q8.93 4.63 9.91 4.31 10.9 4 12 4 14.93 4 16.96 6.04 19 8.07 19 11 20.73 11.2 21.86 12.5 23 13.78 23 15.5 23 16.5 22.63 17.31 22.25 18.15 21.6 18.75M14.83 12.03Z'/%3E%3C/svg%3E%0A");
521
521
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M19.8 22.6L17.15 20H6.5Q4.2 20 2.6 18.4T1 14.5Q1 12.58 2.19 11.08 3.38 9.57 5.25 9.15 5.33 8.95 5.4 8.76 5.5 8.57 5.55 8.35L1.4 4.2L2.8 2.8L21.2 21.2M6.5 18H15.15L7.1 9.95Q7.05 10.23 7.03 10.5 7 10.73 7 11H6.5Q5.05 11 4.03 12.03 3 13.05 3 14.5 3 15.95 4.03 17 5.05 18 6.5 18M11.13 14M21.6 18.75L20.15 17.35Q20.58 17 20.79 16.54 21 16.08 21 15.5 21 14.45 20.27 13.73 19.55 13 18.5 13H17V11Q17 8.93 15.54 7.46 14.08 6 12 6 11.33 6 10.7 6.16 10.07 6.33 9.5 6.68L8.05 5.23Q8.93 4.63 9.91 4.31 10.9 4 12 4 14.93 4 16.96 6.04 19 8.07 19 11 20.73 11.2 21.86 12.5 23 13.78 23 15.5 23 16.5 22.63 17.31 22.25 18.15 21.6 18.75M14.83 12.03Z'/%3E%3C/svg%3E%0A");
522
522
  }
523
- .svg-icon.svg-apps:before {
524
- -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M16,20H20V16H16M16,14H20V10H16M10,8H14V4H10M16,8H20V4H16M10,14H14V10H10M4,14H8V10H4M4,20H8V16H4M10,20H14V16H10M4,8H8V4H4V8Z'/%3E%3C/svg%3E%0A");
525
- mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M16,20H20V16H16M16,14H20V10H16M10,8H14V4H10M16,8H20V4H16M10,14H14V10H10M4,14H8V10H4M4,20H8V16H4M10,20H14V16H10M4,8H8V4H4V8Z'/%3E%3C/svg%3E%0A");
526
- }
527
523
  .svg-icon.svg-attach:before {
528
524
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M16.5,6V17.5A4,4 0 0,1 12.5,21.5A4,4 0 0,1 8.5,17.5V5A2.5,2.5 0 0,1 11,2.5A2.5,2.5 0 0,1 13.5,5V15.5A1,1 0 0,1 12.5,16.5A1,1 0 0,1 11.5,15.5V6H10V15.5A2.5,2.5 0 0,0 12.5,18A2.5,2.5 0 0,0 15,15.5V5A4,4 0 0,0 11,1A4,4 0 0,0 7,5V17.5A5.5,5.5 0 0,0 12.5,23A5.5,5.5 0 0,0 18,17.5V6H16.5Z'/%3E%3C/svg%3E%0A");
529
525
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M16.5,6V17.5A4,4 0 0,1 12.5,21.5A4,4 0 0,1 8.5,17.5V5A2.5,2.5 0 0,1 11,2.5A2.5,2.5 0 0,1 13.5,5V15.5A1,1 0 0,1 12.5,16.5A1,1 0 0,1 11.5,15.5V6H10V15.5A2.5,2.5 0 0,0 12.5,18A2.5,2.5 0 0,0 15,15.5V5A4,4 0 0,0 11,1A4,4 0 0,0 7,5V17.5A5.5,5.5 0 0,0 12.5,23A5.5,5.5 0 0,0 18,17.5V6H16.5Z'/%3E%3C/svg%3E%0A");
@@ -648,6 +644,10 @@
648
644
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2C6.47,2 2,6.47 2,12C2,17.53 6.47,22 12,22C17.53,22 22,17.53 22,12C22,6.47 17.53,2 12,2M14.59,8L12,10.59L9.41,8L8,9.41L10.59,12L8,14.59L9.41,16L12,13.41L14.59,16L16,14.59L13.41,12L16,9.41L14.59,8Z'/%3E%3C/svg%3E%0A");
649
645
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2C6.47,2 2,6.47 2,12C2,17.53 6.47,22 12,22C17.53,22 22,17.53 22,12C22,6.47 17.53,2 12,2M14.59,8L12,10.59L9.41,8L8,9.41L10.59,12L8,14.59L9.41,16L12,13.41L14.59,16L16,14.59L13.41,12L16,9.41L14.59,8Z'/%3E%3C/svg%3E%0A");
650
646
  }
647
+ .svg-icon.svg-reset:before {
648
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,5V1L7,6L12,11V7A6,6 0 0,1 18,13A6,6 0 0,1 12,19A6,6 0 0,1 6,13H4A8,8 0 0,0 12,21A8,8 0 0,0 20,13A8,8 0 0,0 12,5Z'/%3E%3C/svg%3E%0A");
649
+ mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M12,5V1L7,6L12,11V7A6,6 0 0,1 18,13A6,6 0 0,1 12,19A6,6 0 0,1 6,13H4A8,8 0 0,0 12,21A8,8 0 0,0 20,13A8,8 0 0,0 12,5Z'/%3E%3C/svg%3E%0A");
650
+ }
651
651
  .svg-icon.svg-restore:before {
652
652
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M13.5,8H12V13L16.28,15.54L17,14.33L13.5,12.25V8M13,3A9,9 0 0,0 4,12H1L4.96,16.03L9,12H6A7,7 0 0,1 13,5A7,7 0 0,1 20,12A7,7 0 0,1 13,19C11.07,19 9.32,18.21 8.06,16.94L6.64,18.36C8.27,20 10.5,21 13,21A9,9 0 0,0 22,12A9,9 0 0,0 13,3'/%3E%3C/svg%3E%0A");
653
653
  mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath style='fill: var(--icon-fill, currentColor)' d='M13.5,8H12V13L16.28,15.54L17,14.33L13.5,12.25V8M13,3A9,9 0 0,0 4,12H1L4.96,16.03L9,12H6A7,7 0 0,1 13,5A7,7 0 0,1 20,12A7,7 0 0,1 13,19C11.07,19 9.32,18.21 8.06,16.94L6.64,18.36C8.27,20 10.5,21 13,21A9,9 0 0,0 22,12A9,9 0 0,0 13,3'/%3E%3C/svg%3E%0A");
@@ -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
  }