@watermarkinsights/ripple 5.13.0 → 5.13.1-alpha.0

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 (476) hide show
  1. package/dist/cjs/app-globals-6l2OXl3R.js +92 -0
  2. package/dist/cjs/chartFunctions-uCzSt0yo.js +741 -0
  3. package/dist/cjs/functions-CqAwq8Fq.js +10526 -0
  4. package/dist/cjs/index-Cig4P4gJ.js +2086 -0
  5. package/dist/cjs/index.cjs.js +2 -0
  6. package/dist/cjs/interfaces-C7YbtGnk.js +37 -0
  7. package/dist/cjs/intl-BUs7ck9m.js +283 -0
  8. package/dist/cjs/loader.cjs.js +13 -0
  9. package/dist/cjs/priv-calendar.cjs.entry.js +568 -0
  10. package/dist/cjs/priv-chart-popover.cjs.entry.js +136 -0
  11. package/dist/cjs/priv-navigator-button_2.cjs.entry.js +54 -0
  12. package/dist/cjs/priv-option-list_2.cjs.entry.js +556 -0
  13. package/dist/cjs/ripple.cjs.js +25 -0
  14. package/dist/cjs/wm-action-menu_4.cjs.entry.js +701 -0
  15. package/dist/cjs/wm-chart-slice.cjs.entry.js +20 -0
  16. package/dist/cjs/wm-chart.cjs.entry.js +159 -0
  17. package/dist/cjs/wm-date-range.cjs.entry.js +479 -0
  18. package/dist/cjs/wm-datepicker.cjs.entry.js +249 -0
  19. package/dist/cjs/wm-file-list.cjs.entry.js +20 -0
  20. package/dist/cjs/wm-file.cjs.entry.js +184 -0
  21. package/dist/cjs/wm-flyout.cjs.entry.js +169 -0
  22. package/dist/cjs/wm-input.cjs.entry.js +113 -0
  23. package/dist/cjs/wm-line-chart.cjs.entry.js +451 -0
  24. package/dist/cjs/wm-modal-footer.cjs.entry.js +46 -0
  25. package/dist/cjs/wm-modal-header.cjs.entry.js +38 -0
  26. package/dist/cjs/wm-modal-pss-footer.cjs.entry.js +42 -0
  27. package/dist/cjs/wm-modal-pss-header.cjs.entry.js +41 -0
  28. package/dist/cjs/wm-modal-pss.cjs.entry.js +137 -0
  29. package/dist/cjs/wm-modal.cjs.entry.js +135 -0
  30. package/dist/cjs/wm-navigation-hamburger.cjs.entry.js +50 -0
  31. package/dist/{ripple/wm-tab-panel.entry.js → cjs/wm-navigation-item.cjs.entry.js} +12 -24
  32. package/dist/cjs/wm-navigation.cjs.entry.js +118 -0
  33. package/dist/cjs/wm-navigator.cjs.entry.js +329 -0
  34. package/dist/{ripple/wm-search.entry.js → cjs/wm-nested-select.cjs.entry.js} +273 -171
  35. package/dist/cjs/wm-optgroup.cjs.entry.js +70 -0
  36. package/dist/cjs/wm-pagination.cjs.entry.js +225 -0
  37. package/dist/cjs/wm-progress-indicator.cjs.entry.js +109 -0
  38. package/dist/cjs/wm-progress-monitor.cjs.entry.js +73 -0
  39. package/dist/cjs/wm-progress-slice.cjs.entry.js +15 -0
  40. package/dist/cjs/wm-search.cjs.entry.js +210 -0
  41. package/dist/cjs/wm-select.cjs.entry.js +251 -0
  42. package/dist/cjs/wm-tab-item.cjs.entry.js +65 -0
  43. package/dist/cjs/wm-tab-list.cjs.entry.js +177 -0
  44. package/dist/cjs/wm-tab-panel.cjs.entry.js +34 -0
  45. package/dist/cjs/wm-tag-input.cjs.entry.js +879 -0
  46. package/dist/cjs/wm-tag-option.cjs.entry.js +37 -0
  47. package/dist/cjs/wm-textarea.cjs.entry.js +81 -0
  48. package/dist/cjs/wm-timepicker.cjs.entry.js +302 -0
  49. package/dist/cjs/wm-toggletip.cjs.entry.js +178 -0
  50. package/dist/cjs/wm-uploader.cjs.entry.js +315 -0
  51. package/dist/cjs/wm-wrapper.cjs.entry.js +19 -0
  52. package/dist/collection/collection-manifest.json +59 -0
  53. package/dist/collection/components/charts/chartFunctions.js +675 -0
  54. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.css +922 -0
  55. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +261 -0
  56. package/dist/collection/components/charts/wm-chart/wm-chart-slice.js +128 -0
  57. package/dist/collection/components/charts/wm-chart/wm-chart.css +1288 -0
  58. package/dist/collection/components/charts/wm-chart/wm-chart.js +445 -0
  59. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.css +1080 -0
  60. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +742 -0
  61. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.css +1288 -0
  62. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +271 -0
  63. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.css +922 -0
  64. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +154 -0
  65. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-slice.js +124 -0
  66. package/dist/collection/components/datepickers/datepicker.css +1057 -0
  67. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.css +1292 -0
  68. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +849 -0
  69. package/dist/collection/components/datepickers/wm-date-range.js +869 -0
  70. package/dist/collection/components/datepickers/wm-datepicker.js +538 -0
  71. package/dist/collection/components/selects/priv-option-list/priv-option-list.css +931 -0
  72. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +791 -0
  73. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.css +1194 -0
  74. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +644 -0
  75. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.css +843 -0
  76. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +265 -0
  77. package/dist/collection/components/selects/wm-option/wm-option.css +944 -0
  78. package/dist/collection/components/selects/wm-option/wm-option.js +539 -0
  79. package/dist/collection/components/selects/wm-select/wm-select.css +1117 -0
  80. package/dist/collection/components/selects/wm-select/wm-select.js +606 -0
  81. package/dist/collection/components/wm-action-menu/wm-action-menu.css +904 -0
  82. package/dist/collection/components/wm-action-menu/wm-action-menu.js +444 -0
  83. package/dist/collection/components/wm-button/wm-button.css +1371 -0
  84. package/dist/collection/components/wm-button/wm-button.js +510 -0
  85. package/dist/collection/components/wm-file/wm-file.css +940 -0
  86. package/dist/collection/components/wm-file/wm-file.js +423 -0
  87. package/dist/collection/components/wm-file-list/wm-file-list.css +833 -0
  88. package/dist/collection/components/wm-file-list/wm-file-list.js +47 -0
  89. package/dist/collection/components/wm-flyout/wm-flyout.css +1027 -0
  90. package/dist/collection/components/wm-flyout/wm-flyout.js +460 -0
  91. package/dist/collection/components/wm-input/wm-input.css +1017 -0
  92. package/dist/collection/components/wm-input/wm-input.js +498 -0
  93. package/dist/collection/components/wm-menuitem/wm-menuitem.css +904 -0
  94. package/dist/collection/components/wm-menuitem/wm-menuitem.js +425 -0
  95. package/dist/collection/components/wm-modal/wm-modal-footer.css +858 -0
  96. package/dist/collection/components/wm-modal/wm-modal-footer.js +152 -0
  97. package/dist/collection/components/wm-modal/wm-modal-header.css +857 -0
  98. package/dist/collection/components/wm-modal/wm-modal-header.js +83 -0
  99. package/dist/collection/components/wm-modal/wm-modal.css +905 -0
  100. package/dist/collection/components/wm-modal/wm-modal.js +356 -0
  101. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.css +865 -0
  102. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +148 -0
  103. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.css +859 -0
  104. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +86 -0
  105. package/dist/collection/components/wm-modal-pss/wm-modal-pss.css +941 -0
  106. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +369 -0
  107. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.css +860 -0
  108. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +120 -0
  109. package/dist/collection/components/wm-navigation/wm-navigation-item.css +869 -0
  110. package/dist/collection/components/wm-navigation/wm-navigation-item.js +99 -0
  111. package/dist/collection/components/wm-navigation/wm-navigation.css +911 -0
  112. package/dist/collection/components/wm-navigation/wm-navigation.js +192 -0
  113. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +863 -0
  114. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +90 -0
  115. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +843 -0
  116. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +130 -0
  117. package/dist/collection/components/wm-navigator/wm-navigator.css +916 -0
  118. package/dist/collection/components/wm-navigator/wm-navigator.js +515 -0
  119. package/dist/collection/components/wm-pagination/wm-pagination.css +984 -0
  120. package/dist/collection/components/wm-pagination/wm-pagination.js +373 -0
  121. package/dist/collection/components/wm-search/wm-search.css +909 -0
  122. package/dist/collection/components/wm-search/wm-search.js +462 -0
  123. package/dist/collection/components/wm-snackbar/wm-snackbar.css +1091 -0
  124. package/dist/collection/components/wm-snackbar/wm-snackbar.js +279 -0
  125. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +882 -0
  126. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +187 -0
  127. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +854 -0
  128. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +276 -0
  129. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +838 -0
  130. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +97 -0
  131. package/dist/collection/components/wm-tag-input/wm-tag-input.css +1289 -0
  132. package/dist/collection/components/wm-tag-input/wm-tag-input.js +1245 -0
  133. package/dist/collection/components/wm-tag-input/wm-tag-option/wm-tag-option.js +251 -0
  134. package/dist/collection/components/wm-textarea/wm-textarea.css +993 -0
  135. package/dist/collection/components/wm-textarea/wm-textarea.js +331 -0
  136. package/dist/collection/components/wm-timepicker/wm-timepicker.css +1107 -0
  137. package/dist/collection/components/wm-timepicker/wm-timepicker.js +559 -0
  138. package/dist/collection/components/wm-toggletip/wm-toggletip.css +1165 -0
  139. package/dist/collection/components/wm-toggletip/wm-toggletip.js +295 -0
  140. package/dist/collection/components/wm-uploader/wm-uploader.css +1673 -0
  141. package/dist/collection/components/wm-uploader/wm-uploader.js +618 -0
  142. package/dist/collection/components/wm-wrapper/wm-wrapper.js +28 -0
  143. package/dist/collection/dev/action-menu.js +0 -0
  144. package/dist/collection/dev/button.js +0 -0
  145. package/dist/collection/dev/chart-small.js +56 -0
  146. package/dist/collection/dev/chart.js +18 -0
  147. package/dist/collection/dev/date-range.js +6 -0
  148. package/dist/collection/dev/datepicker.js +46 -0
  149. package/dist/collection/dev/file-list.js +16 -0
  150. package/dist/collection/dev/file.js +0 -0
  151. package/dist/collection/dev/flyout.js +194 -0
  152. package/dist/collection/dev/input.js +6 -0
  153. package/dist/collection/dev/line-chart.js +0 -0
  154. package/dist/collection/dev/modal.js +48 -0
  155. package/dist/collection/dev/navigation.js +13 -0
  156. package/dist/collection/dev/navigator.js +34 -0
  157. package/dist/collection/dev/nested-select.js +36 -0
  158. package/dist/collection/dev/pagination.js +7 -0
  159. package/dist/collection/dev/progress-monitor.js +0 -0
  160. package/dist/collection/dev/pss-modal.js +8 -0
  161. package/dist/collection/dev/scripts.js +49 -0
  162. package/dist/collection/dev/search.js +72 -0
  163. package/dist/collection/dev/select.js +57 -0
  164. package/dist/collection/dev/snackbar.js +60 -0
  165. package/dist/collection/dev/tabs.js +44 -0
  166. package/dist/collection/dev/tag-input.js +32 -0
  167. package/dist/collection/dev/textarea.js +28 -0
  168. package/dist/collection/dev/timepicker.js +32 -0
  169. package/dist/collection/dev/toggletip.js +9 -0
  170. package/dist/collection/dev/uploader.js +139 -0
  171. package/dist/collection/global/__mocks__/functions.js +6 -0
  172. package/dist/collection/global/functions.js +841 -0
  173. package/dist/{ripple/app-globals-B7cOtGhY.js → collection/global/global.js} +2 -84
  174. package/dist/{ripple/interfaces-CrANcZM9.js → collection/global/interfaces.js} +4 -6
  175. package/dist/collection/global/intl.js +274 -0
  176. package/dist/collection/global/services/__mocks__/http-service.js +130 -0
  177. package/dist/collection/global/services/http-service.js +50 -0
  178. package/dist/collection/lang/lang.js +5 -0
  179. package/dist/collection/lang/missing.js +43 -0
  180. package/dist/collection/lang/piglatin.js +101 -0
  181. package/dist/components/index.js +85 -0
  182. package/dist/components/p-BlQdbOh_.js +294 -0
  183. package/dist/components/p-BvE5BEYe.js +146 -0
  184. package/dist/components/p-BzGDMpdL.js +592 -0
  185. package/dist/{ripple/wm-modal-header.entry.js → components/p-CLem5EoD.js} +35 -29
  186. package/dist/components/p-COwzv5zO.js +34 -0
  187. package/dist/components/p-CWx2NF6K.js +231 -0
  188. package/dist/{ripple/wm-progress-monitor.entry.js → components/p-D9GMUh0-.js} +217 -57
  189. package/dist/{ripple/wm-option.entry.js → components/p-DCSxoWXP.js} +384 -134
  190. package/dist/components/p-DG_w4q3M.js +196 -0
  191. package/dist/{ripple/intl-7p27BJSM.js → components/p-DStPjkvu.js} +1 -1
  192. package/dist/components/p-DdlNyc6u.js +10485 -0
  193. package/dist/{ripple/wm-toggletip.entry.js → components/p-DvXS4oTB.js} +44 -171
  194. package/dist/components/p-HPnDWE3g.js +1686 -0
  195. package/dist/components/p-K9lgwbAO.js +724 -0
  196. package/dist/{ripple/wm-textarea.entry.js → components/p-e_A35rK5.js} +132 -57
  197. package/dist/components/priv-calendar.js +6 -0
  198. package/dist/components/priv-chart-popover.js +6 -0
  199. package/dist/components/priv-navigator-button.js +6 -0
  200. package/dist/components/priv-navigator-item.js +6 -0
  201. package/dist/components/priv-option-list.js +6 -0
  202. package/dist/components/wm-action-menu.js +6 -0
  203. package/dist/components/wm-button.js +6 -0
  204. package/dist/components/wm-chart-slice.js +41 -0
  205. package/dist/components/wm-chart.js +197 -0
  206. package/dist/components/wm-date-range.js +522 -0
  207. package/dist/components/wm-datepicker.js +287 -0
  208. package/dist/components/wm-file-list.js +38 -0
  209. package/dist/components/wm-file.js +228 -0
  210. package/dist/components/wm-flyout.js +208 -0
  211. package/dist/components/wm-input.js +152 -0
  212. package/dist/components/wm-line-chart.js +497 -0
  213. package/dist/components/wm-menuitem.js +6 -0
  214. package/dist/components/wm-modal-footer.js +73 -0
  215. package/dist/components/wm-modal-header.js +61 -0
  216. package/dist/components/wm-modal-pss-footer.js +69 -0
  217. package/dist/components/wm-modal-pss-header.js +64 -0
  218. package/dist/components/wm-modal-pss.js +162 -0
  219. package/dist/components/wm-modal.js +161 -0
  220. package/dist/components/wm-navigation-hamburger.js +70 -0
  221. package/dist/components/wm-navigation-item.js +40 -0
  222. package/dist/components/wm-navigation.js +144 -0
  223. package/dist/components/wm-navigator.js +369 -0
  224. package/dist/{ripple/wm-flyout.entry.js → components/wm-nested-select.js} +313 -137
  225. package/dist/components/wm-optgroup.js +107 -0
  226. package/dist/components/wm-option.js +6 -0
  227. package/dist/components/wm-pagination.js +251 -0
  228. package/dist/components/wm-progress-indicator.js +144 -0
  229. package/dist/components/wm-progress-monitor.js +93 -0
  230. package/dist/components/wm-progress-slice.js +37 -0
  231. package/dist/components/wm-search.js +250 -0
  232. package/dist/components/wm-select.js +6 -0
  233. package/dist/components/wm-snackbar.js +209 -0
  234. package/dist/components/wm-tab-item.js +85 -0
  235. package/dist/components/wm-tab-list.js +217 -0
  236. package/dist/components/wm-tab-panel.js +52 -0
  237. package/dist/components/wm-tag-input.js +919 -0
  238. package/dist/components/wm-tag-option.js +63 -0
  239. package/dist/components/wm-textarea.js +113 -0
  240. package/dist/components/wm-timepicker.js +333 -0
  241. package/dist/components/wm-toggletip.js +200 -0
  242. package/dist/components/wm-uploader.js +348 -0
  243. package/dist/components/wm-wrapper.js +34 -0
  244. package/dist/esm/app-globals-eAJzxs1b.js +90 -0
  245. package/dist/{ripple/chartFunctions-CmeM8Tyx.js → esm/chartFunctions-C4yzutWl.js} +3 -4
  246. package/dist/{ripple/functions-DVLl0rH_.js → esm/functions-CU95tthb.js} +144 -7767
  247. package/dist/esm/index-EopL5zo4.js +2075 -0
  248. package/dist/esm/index.js +1 -0
  249. package/dist/esm/interfaces-CyJHzEjr.js +34 -0
  250. package/dist/esm/intl-CN471tL5.js +277 -0
  251. package/dist/esm/loader.js +11 -0
  252. package/dist/esm/polyfills/core-js.js +11 -0
  253. package/dist/esm/polyfills/dom.js +79 -0
  254. package/dist/esm/polyfills/es5-html-element.js +1 -0
  255. package/dist/esm/polyfills/index.js +34 -0
  256. package/dist/esm/polyfills/system.js +6 -0
  257. package/dist/esm/priv-calendar.entry.js +566 -0
  258. package/dist/esm/priv-chart-popover.entry.js +134 -0
  259. package/dist/esm/priv-navigator-button_2.entry.js +51 -0
  260. package/dist/esm/priv-option-list_2.entry.js +553 -0
  261. package/dist/esm/ripple.js +21 -0
  262. package/dist/esm/wm-action-menu_4.entry.js +696 -0
  263. package/dist/{ripple → esm}/wm-chart-slice.entry.js +1 -1
  264. package/dist/esm/wm-chart.entry.js +157 -0
  265. package/dist/esm/wm-date-range.entry.js +477 -0
  266. package/dist/esm/wm-datepicker.entry.js +247 -0
  267. package/dist/esm/wm-file-list.entry.js +18 -0
  268. package/dist/{ripple/wm-chart.entry.js → esm/wm-file.entry.js} +161 -136
  269. package/dist/esm/wm-flyout.entry.js +167 -0
  270. package/dist/esm/wm-input.entry.js +111 -0
  271. package/dist/esm/wm-line-chart.entry.js +449 -0
  272. package/dist/{ripple/wm-modal.entry.js → esm/wm-modal-footer.entry.js} +28 -117
  273. package/dist/{ripple/wm-input.entry.js → esm/wm-modal-header.entry.js} +24 -99
  274. package/dist/{ripple/wm-menuitem.entry.js → esm/wm-modal-pss-footer.entry.js} +28 -113
  275. package/dist/{ripple/wm-optgroup.entry.js → esm/wm-modal-pss-header.entry.js} +28 -57
  276. package/dist/esm/wm-modal-pss.entry.js +135 -0
  277. package/dist/esm/wm-modal.entry.js +133 -0
  278. package/dist/esm/wm-navigation-hamburger.entry.js +48 -0
  279. package/dist/{ripple/wm-file-list.entry.js → esm/wm-navigation-item.entry.js} +7 -7
  280. package/dist/{ripple/wm-file.entry.js → esm/wm-navigation.entry.js} +91 -157
  281. package/dist/esm/wm-navigator.entry.js +327 -0
  282. package/dist/{ripple/wm-select.entry.js → esm/wm-nested-select.entry.js} +193 -134
  283. package/dist/esm/wm-optgroup.entry.js +68 -0
  284. package/dist/esm/wm-pagination.entry.js +223 -0
  285. package/dist/esm/wm-progress-indicator.entry.js +107 -0
  286. package/dist/esm/wm-progress-monitor.entry.js +71 -0
  287. package/dist/{ripple → esm}/wm-progress-slice.entry.js +1 -1
  288. package/dist/esm/wm-search.entry.js +208 -0
  289. package/dist/esm/wm-select.entry.js +249 -0
  290. package/dist/esm/wm-tab-item.entry.js +63 -0
  291. package/dist/esm/wm-tab-list.entry.js +175 -0
  292. package/dist/esm/wm-tab-panel.entry.js +32 -0
  293. package/dist/esm/wm-tag-input.entry.js +877 -0
  294. package/dist/{ripple → esm}/wm-tag-option.entry.js +2 -2
  295. package/dist/esm/wm-textarea.entry.js +79 -0
  296. package/dist/esm/wm-timepicker.entry.js +300 -0
  297. package/dist/esm/wm-toggletip.entry.js +176 -0
  298. package/dist/esm/wm-uploader.entry.js +313 -0
  299. package/dist/{ripple → esm}/wm-wrapper.entry.js +1 -1
  300. package/dist/esm-es5/app-globals-eAJzxs1b.js +1 -0
  301. package/dist/esm-es5/chartFunctions-C4yzutWl.js +1 -0
  302. package/dist/esm-es5/functions-CU95tthb.js +1 -0
  303. package/dist/esm-es5/index-EopL5zo4.js +1 -0
  304. package/dist/esm-es5/index.js +0 -0
  305. package/dist/esm-es5/interfaces-CyJHzEjr.js +1 -0
  306. package/dist/esm-es5/intl-CN471tL5.js +1 -0
  307. package/dist/esm-es5/loader.js +1 -0
  308. package/dist/esm-es5/priv-calendar.entry.js +1 -0
  309. package/dist/esm-es5/priv-chart-popover.entry.js +1 -0
  310. package/dist/esm-es5/priv-navigator-button_2.entry.js +1 -0
  311. package/dist/esm-es5/priv-option-list_2.entry.js +1 -0
  312. package/dist/esm-es5/ripple.js +1 -0
  313. package/dist/esm-es5/wm-action-menu_4.entry.js +1 -0
  314. package/dist/esm-es5/wm-chart-slice.entry.js +1 -0
  315. package/dist/esm-es5/wm-chart.entry.js +1 -0
  316. package/dist/esm-es5/wm-date-range.entry.js +1 -0
  317. package/dist/{ripple/wm-uploader.entry.js → esm-es5/wm-datepicker.entry.js} +1 -313
  318. package/dist/{ripple/wm-tab-item.entry.js → esm-es5/wm-file-list.entry.js} +1 -63
  319. package/dist/esm-es5/wm-file.entry.js +1 -0
  320. package/dist/esm-es5/wm-flyout.entry.js +1 -0
  321. package/dist/esm-es5/wm-input.entry.js +1 -0
  322. package/dist/esm-es5/wm-line-chart.entry.js +1 -0
  323. package/dist/{ripple/wm-navigation.entry.js → esm-es5/wm-modal-footer.entry.js} +1 -116
  324. package/dist/esm-es5/wm-modal-header.entry.js +1 -0
  325. package/dist/esm-es5/wm-modal-pss-footer.entry.js +1 -0
  326. package/dist/esm-es5/wm-modal-pss-header.entry.js +1 -0
  327. package/dist/esm-es5/wm-modal-pss.entry.js +1 -0
  328. package/dist/esm-es5/wm-modal.entry.js +1 -0
  329. package/dist/esm-es5/wm-navigation-hamburger.entry.js +1 -0
  330. package/dist/esm-es5/wm-navigation-item.entry.js +1 -0
  331. package/dist/esm-es5/wm-navigation.entry.js +1 -0
  332. package/dist/esm-es5/wm-navigator.entry.js +1 -0
  333. package/dist/esm-es5/wm-nested-select.entry.js +1 -0
  334. package/dist/esm-es5/wm-optgroup.entry.js +1 -0
  335. package/dist/esm-es5/wm-pagination.entry.js +1 -0
  336. package/dist/{ripple/wm-modal-footer.entry.js → esm-es5/wm-progress-indicator.entry.js} +1 -44
  337. package/dist/esm-es5/wm-progress-monitor.entry.js +1 -0
  338. package/dist/esm-es5/wm-progress-slice.entry.js +1 -0
  339. package/dist/esm-es5/wm-search.entry.js +1 -0
  340. package/dist/esm-es5/wm-select.entry.js +1 -0
  341. package/dist/esm-es5/wm-tab-item.entry.js +1 -0
  342. package/dist/esm-es5/wm-tab-list.entry.js +1 -0
  343. package/dist/esm-es5/wm-tab-panel.entry.js +1 -0
  344. package/dist/esm-es5/wm-tag-input.entry.js +1 -0
  345. package/dist/esm-es5/wm-tag-option.entry.js +1 -0
  346. package/dist/esm-es5/wm-textarea.entry.js +1 -0
  347. package/dist/esm-es5/wm-timepicker.entry.js +1 -0
  348. package/dist/esm-es5/wm-toggletip.entry.js +1 -0
  349. package/dist/esm-es5/wm-uploader.entry.js +1 -0
  350. package/dist/esm-es5/wm-wrapper.entry.js +1 -0
  351. package/dist/index.cjs.js +1 -0
  352. package/dist/index.js +1 -0
  353. package/dist/loader/cdn.js +2 -0
  354. package/dist/loader/index.cjs.js +2 -0
  355. package/dist/loader/index.d.ts +24 -0
  356. package/dist/loader/index.es2017.js +2 -0
  357. package/dist/loader/index.js +3 -0
  358. package/dist/ripple/index.esm.js +0 -1
  359. package/dist/ripple/p-007883c7.entry.js +1 -0
  360. package/dist/ripple/p-01456c1a.system.entry.js +1 -0
  361. package/dist/ripple/p-0b716fc3.system.entry.js +1 -0
  362. package/dist/ripple/p-11c9e7ee.system.entry.js +1 -0
  363. package/dist/ripple/p-176778bc.system.entry.js +1 -0
  364. package/dist/ripple/p-1f7e1851.entry.js +1 -0
  365. package/dist/ripple/p-28e8965b.system.entry.js +1 -0
  366. package/dist/ripple/p-29302f19.entry.js +1 -0
  367. package/dist/ripple/p-2bd007af.system.entry.js +1 -0
  368. package/dist/ripple/p-2f629074.system.entry.js +1 -0
  369. package/dist/ripple/{priv-navigator-item.entry.js → p-3042aae4.entry.js} +1 -30
  370. package/dist/ripple/p-340b73a9.system.entry.js +1 -0
  371. package/dist/ripple/p-369b764a.entry.js +1 -0
  372. package/dist/ripple/p-384d9208.system.entry.js +1 -0
  373. package/dist/ripple/p-3b08f15d.system.entry.js +1 -0
  374. package/dist/ripple/p-3d459e5a.entry.js +1 -0
  375. package/dist/ripple/p-3e1202c6.entry.js +1 -0
  376. package/dist/ripple/p-3e9a2ef6.system.entry.js +1 -0
  377. package/dist/ripple/p-418e3d1a.system.entry.js +1 -0
  378. package/dist/ripple/p-44d2ecd5.entry.js +1 -0
  379. package/dist/ripple/p-4841e9cd.entry.js +1 -0
  380. package/dist/ripple/p-492a8a9f.entry.js +1 -0
  381. package/dist/ripple/p-4a28da80.system.entry.js +1 -0
  382. package/dist/ripple/{priv-option-list.entry.js → p-4b264fb2.entry.js} +1 -385
  383. package/dist/ripple/p-4b4671e7.entry.js +1 -0
  384. package/dist/ripple/p-4b5bb9c8.entry.js +1 -0
  385. package/dist/ripple/{wm-modal-pss-header.entry.js → p-4f4868cb.system.entry.js} +1 -39
  386. package/dist/ripple/p-54aeadde.entry.js +1 -0
  387. package/dist/ripple/p-56422175.entry.js +1 -0
  388. package/dist/ripple/p-568bb1f9.entry.js +1 -0
  389. package/dist/ripple/p-5802a317.system.entry.js +1 -0
  390. package/dist/ripple/p-5ae17300.system.entry.js +1 -0
  391. package/dist/ripple/p-5e3fbe45.entry.js +1 -0
  392. package/dist/ripple/p-60363868.entry.js +1 -0
  393. package/dist/ripple/p-792f7c79.entry.js +1 -0
  394. package/dist/ripple/p-7aa1c452.system.entry.js +1 -0
  395. package/dist/ripple/p-7fbbb63a.system.entry.js +1 -0
  396. package/dist/ripple/p-812615ae.entry.js +1 -0
  397. package/dist/ripple/{wm-snackbar.entry.js → p-86b22f7b.entry.js} +1 -185
  398. package/dist/ripple/p-8cbefd04.entry.js +1 -0
  399. package/dist/ripple/{wm-progress-indicator.entry.js → p-8ee4401f.entry.js} +1 -107
  400. package/dist/ripple/{priv-chart-popover.entry.js → p-94e4dc77.system.entry.js} +1 -134
  401. package/dist/ripple/p-9a8e3525.entry.js +1 -0
  402. package/dist/ripple/p-9c14176e.system.entry.js +1 -0
  403. package/dist/ripple/p-9c993a3e.system.entry.js +1 -0
  404. package/dist/ripple/p-BIzU753x.system.js +1 -0
  405. package/dist/ripple/p-BNmjUWhs.js +1 -0
  406. package/dist/ripple/p-CDk__KSi.system.js +1 -0
  407. package/dist/ripple/p-CFV9VgE2.system.js +1 -0
  408. package/dist/ripple/p-CGHKc6U6.js +1 -0
  409. package/dist/ripple/p-CTau6pR2.system.js +2 -0
  410. package/dist/ripple/p-CU95tthb.js +1 -0
  411. package/dist/ripple/p-CcozwjO1.js +1 -0
  412. package/dist/ripple/p-CwkTkxrj.system.js +1 -0
  413. package/dist/ripple/p-CyJHzEjr.js +1 -0
  414. package/dist/ripple/p-EopL5zo4.js +2 -0
  415. package/dist/ripple/p-GtT-372c.system.js +1 -0
  416. package/dist/ripple/p-YWpyar7R.system.js +1 -0
  417. package/dist/ripple/p-a4d4a752.entry.js +1 -0
  418. package/dist/ripple/p-a7b4f720.system.entry.js +1 -0
  419. package/dist/ripple/p-adffc8d9.system.entry.js +1 -0
  420. package/dist/ripple/p-b53e397f.entry.js +1 -0
  421. package/dist/ripple/p-b6956929.system.entry.js +1 -0
  422. package/dist/ripple/p-b79f5594.system.entry.js +1 -0
  423. package/dist/ripple/p-b94e08f4.system.entry.js +1 -0
  424. package/dist/ripple/p-bb930411.entry.js +1 -0
  425. package/dist/ripple/p-bd0f8d31.system.entry.js +1 -0
  426. package/dist/ripple/p-be146306.system.entry.js +1 -0
  427. package/dist/ripple/p-c59fa446.system.entry.js +1 -0
  428. package/dist/ripple/p-c7269416.entry.js +1 -0
  429. package/dist/ripple/p-c7f446e9.system.entry.js +1 -0
  430. package/dist/ripple/p-ca8c26b0.entry.js +1 -0
  431. package/dist/ripple/p-cccfdbb8.entry.js +1 -0
  432. package/dist/ripple/p-cfb2bbf1.system.entry.js +1 -0
  433. package/dist/ripple/p-d298ef0a.system.entry.js +1 -0
  434. package/dist/ripple/p-d66f8dfc.system.entry.js +1 -0
  435. package/dist/ripple/p-d715f567.system.entry.js +1 -0
  436. package/dist/ripple/p-d8cd69fb.entry.js +1 -0
  437. package/dist/ripple/p-d9033c6b.entry.js +1 -0
  438. package/dist/ripple/p-da5ad94c.system.entry.js +1 -0
  439. package/dist/ripple/p-da6646bf.entry.js +1 -0
  440. package/dist/ripple/p-dc44a726.entry.js +1 -0
  441. package/dist/ripple/p-e04561b5.system.entry.js +1 -0
  442. package/dist/ripple/p-e8cdf66c.entry.js +1 -0
  443. package/dist/ripple/p-ec1c0b3e.system.entry.js +1 -0
  444. package/dist/ripple/p-ef9c66dd.entry.js +1 -0
  445. package/dist/ripple/p-f44dafc1.entry.js +1 -0
  446. package/dist/ripple/p-f4c59921.system.entry.js +1 -0
  447. package/dist/ripple/p-f6e9cb0e.entry.js +1 -0
  448. package/dist/ripple/p-faa45b92.system.entry.js +1 -0
  449. package/dist/ripple/p-faf34fd1.system.entry.js +1 -0
  450. package/dist/ripple/{wm-tab-list.entry.js → p-fd006ae2.entry.js} +1 -175
  451. package/dist/ripple/p-fd9c8220.system.entry.js +1 -0
  452. package/dist/ripple/p-fe1ac4e0.entry.js +1 -0
  453. package/dist/ripple/p-fe5c9681.entry.js +1 -0
  454. package/dist/ripple/p-feb343ad.system.entry.js +1 -0
  455. package/dist/ripple/p-ff3cbb1d.entry.js +1 -0
  456. package/dist/ripple/p-rbkCjczS.system.js +1 -0
  457. package/dist/ripple/ripple.esm.js +1 -48
  458. package/dist/ripple/ripple.js +127 -0
  459. package/package.json +2 -2
  460. package/dist/ripple/index-CU5QNCKv.js +0 -4167
  461. package/dist/ripple/priv-calendar.entry.js +0 -566
  462. package/dist/ripple/priv-navigator-button.entry.js +0 -24
  463. package/dist/ripple/wm-action-menu.entry.js +0 -201
  464. package/dist/ripple/wm-button.entry.js +0 -197
  465. package/dist/ripple/wm-date-range.entry.js +0 -477
  466. package/dist/ripple/wm-datepicker.entry.js +0 -247
  467. package/dist/ripple/wm-line-chart.entry.js +0 -449
  468. package/dist/ripple/wm-modal-pss-footer.entry.js +0 -40
  469. package/dist/ripple/wm-modal-pss.entry.js +0 -135
  470. package/dist/ripple/wm-navigation-hamburger.entry.js +0 -48
  471. package/dist/ripple/wm-navigation-item.entry.js +0 -18
  472. package/dist/ripple/wm-navigator.entry.js +0 -368
  473. package/dist/ripple/wm-nested-select.entry.js +0 -308
  474. package/dist/ripple/wm-pagination.entry.js +0 -223
  475. package/dist/ripple/wm-tag-input.entry.js +0 -877
  476. package/dist/ripple/wm-timepicker.entry.js +0 -300
@@ -0,0 +1,57 @@
1
+ document.addEventListener("wmSelectBlurred", renderErrors);
2
+
3
+ function renderErrors() {
4
+ const errorDiv = document.getElementById("errors");
5
+ const select = document.getElementById("select1");
6
+ const selectedOption = Array.from(select.querySelectorAll("wm-option")).filter((o) => o.selected)[0];
7
+
8
+ if (selectedOption.value === "C") {
9
+ select.invalid = true;
10
+ select.errorMessage = "C is my least favorite letter.";
11
+ } else {
12
+ select.invalid = false;
13
+ select.errorMessage = null;
14
+ }
15
+ }
16
+
17
+ function testSelectedOption(selectComp) {
18
+ setTimeout(() => {
19
+ // making sure the selected and aria-selected attributes are always in sync
20
+ const options = selectComp.querySelectorAll("wm-option");
21
+ let selectedOption = Array.from(options).filter((option) => !!option.selected)[0];
22
+ const ariaSelectedOption = Array.from(options).filter((option) => !!option.getAttribute("aria-selected"))[0];
23
+ if (selectedOption != ariaSelectedOption) {
24
+ console.log(selectComp.id, selectedOption, ariaSelectedOption);
25
+ }
26
+ }, 150);
27
+ }
28
+
29
+ const selects = document.querySelectorAll("wm-select");
30
+ selects.forEach((select) => {
31
+ select.addEventListener("wmOptionSelected", (ev) => handleOptionSelected(ev));
32
+ select.addEventListener("wmOptionDeselected", (ev) => handleOptionDeselected(ev));
33
+ select.addEventListener("wmSelectAllSelected", (ev) => handleAllSelected(ev));
34
+ select.addEventListener("wmSelectAllDeselected", (ev) => handleAllDeselected(ev));
35
+ });
36
+
37
+ function handleOptionSelected(ev) {
38
+ const parentSelect = ev.target.parentElement;
39
+
40
+ if (!parentSelect.multiple) {
41
+ // in single select, deselect all other options
42
+ parentSelect.querySelectorAll("wm-option").forEach((option) => (option.selected = false));
43
+ }
44
+ ev.target.selected = true;
45
+ }
46
+
47
+ function handleOptionDeselected(ev) {
48
+ ev.target.selected = false;
49
+ }
50
+
51
+ function handleAllSelected(ev) {
52
+ ev.target.querySelectorAll("wm-option").forEach((option) => (option.selected = true));
53
+ }
54
+
55
+ function handleAllDeselected(ev) {
56
+ ev.target.querySelectorAll("wm-option").forEach((option) => (option.selected = false));
57
+ }
@@ -0,0 +1,60 @@
1
+ let notifications = [];
2
+
3
+ function getRandomId() {
4
+ return (Math.floor(Math.random() * 10000) + 1).toString();
5
+ }
6
+
7
+ function generateSnackbar(id, message, link, newWindow) {
8
+ let newNotification = {
9
+ id: id,
10
+ message: message,
11
+ link: link,
12
+ newWindow: newWindow,
13
+ };
14
+
15
+ const snackbar = document.getElementById("snackbar");
16
+ notifications = [newNotification, ...notifications];
17
+ snackbar.notifications = JSON.stringify(notifications);
18
+ }
19
+
20
+ function generateBasicSnackbar() {
21
+ const id = getRandomId();
22
+ const message = `Snackbar's id: ${id}`;
23
+ const link = "View this person in the table";
24
+ const newWindow = false;
25
+ generateSnackbar(id, message, link, newWindow);
26
+ }
27
+
28
+ function generateCustomSnackbar() {
29
+ const id = getRandomId();
30
+ const message = document.getElementById("custom-notif").value;
31
+ const link = document.getElementById("custom-link").value;
32
+ const newWindow = link && document.getElementById("new-window").checked;
33
+ generateSnackbar(id, message, link, newWindow);
34
+ }
35
+
36
+ function updateSnackText() {
37
+ notifications[0].message = notifications[0].message === "DING" ? "DONG" : "DING";
38
+ const snackbar = document.querySelector("#snackbar");
39
+ snackbar.notifications = JSON.stringify(notifications);
40
+ }
41
+
42
+ document.querySelector("#snack-basic").addEventListener("click", () => generateBasicSnackbar());
43
+ document.querySelector("#snack-custom").addEventListener("click", () => generateCustomSnackbar());
44
+ document.querySelector("#snack-update").addEventListener("click", () => updateSnackText());
45
+
46
+ document.addEventListener("wmSnackbarSnackFinished", function (ev) {
47
+ const snackbar = document.getElementById("snackbar");
48
+ let newSnacks = notifications.filter((snack) => snack.id !== ev.detail.id);
49
+ notifications = newSnacks;
50
+ snackbar.notifications = JSON.stringify(notifications);
51
+ });
52
+
53
+ document.addEventListener("wmSnackbarActionTriggered", function (ev) {
54
+ const snackbar = document.getElementById("snackbar");
55
+ let newSnacks = JSON.parse(snackbar.notifications).filter(function (snack) {
56
+ return snack.id !== +ev.detail.id;
57
+ });
58
+ snackbar.notifications = JSON.stringify(newSnacks);
59
+ console.log("You clicked the action.");
60
+ });
@@ -0,0 +1,44 @@
1
+ const tab1 = document.getElementById("tab-1");
2
+ if (tab1) {
3
+ tab1.addEventListener("wmTabSelected", function (ev) {
4
+ let activeTab = ev.detail.tabId;
5
+ let tabContainer = document.getElementById("tab-1-wrapper");
6
+ let panel = tabContainer.querySelector("#tab-panel");
7
+ let tabList = document.getElementById("tab-1");
8
+
9
+ tabList.selectedTab = activeTab;
10
+ });
11
+
12
+ const cloudTabs = document.getElementById("cloud-tabs");
13
+ cloudTabs &&
14
+ cloudTabs.addEventListener("wmTabSelected", (ev) => {
15
+ const tabId = ev.detail.tabId;
16
+ const cloudTabs = document.getElementById("cloud-tabs");
17
+ cloudTabs.selectedTab = tabId;
18
+ let panel = document.querySelector(`wm-tab-panel[tab-id=${tabId}]`);
19
+ console.log(panel);
20
+
21
+ if (panel) {
22
+ let text;
23
+
24
+ switch (tabId) {
25
+ case "cumulonimbus":
26
+ text =
27
+ 'Cumulonimbus (from Latin cumulus, "heaped" and nimbus, "rainstorm") is a dense, towering vertical cloud.';
28
+ break;
29
+ case "cirrostratus":
30
+ text =
31
+ "Cirrostratus /ˌsɪroʊˈstrɑːtəs/ is a high-level, very thin, generally uniform stratiform genus-type of cloud.";
32
+ break;
33
+ case "altostratus":
34
+ text =
35
+ "Altostratus is a middle altitude cloud genus belonging to the stratiform physical category characterized by a generally uniform gray to bluish-green sheet or layer.";
36
+ break;
37
+ default:
38
+ text = "";
39
+ }
40
+
41
+ panel.innerHTML = text;
42
+ }
43
+ });
44
+ }
@@ -0,0 +1,32 @@
1
+ const allTagInputs = document.querySelectorAll("wm-tag-input");
2
+
3
+ allTagInputs.forEach((ti) => {
4
+ const initialTags = Array.from(ti.querySelectorAll("wm-tag-option")).map((o) => o.textContent);
5
+
6
+ ti.addEventListener("wmTagInputTagAdded", (ev) => {
7
+ const ciTagName = ev.detail.toLowerCase().trim();
8
+ const ciExistingTagNames = Array.from(ti.querySelectorAll("wm-tag-option")).map((o) =>
9
+ o.textContent.toLowerCase().trim()
10
+ );
11
+ if (ti.tagInputType === "dropdown" && !ciExistingTagNames.includes(ciTagName)) {
12
+ const to = document.createElement("wm-tag-option");
13
+ to.textContent = ev.detail;
14
+ to.id = "tag" + Math.random().toString(36).substr(2, 6);
15
+ to.selected = true;
16
+ ti.appendChild(to);
17
+ }
18
+ });
19
+
20
+ ti.addEventListener("wmTagOptionSelected", (ev) => {
21
+ ev.target.selected = true;
22
+ });
23
+
24
+ ti.addEventListener("wmTagOptionDeselected", (ev) => {
25
+ const isUserTag = !initialTags.includes(ev.target.textContent);
26
+ if (isUserTag) {
27
+ ev.target.remove();
28
+ } else {
29
+ ev.target.selected = false;
30
+ }
31
+ });
32
+ });
@@ -0,0 +1,28 @@
1
+ const textAreaEls = document.querySelectorAll("wm-textarea");
2
+
3
+ textAreaEls.forEach((textAreaEl) => {
4
+ textAreaEl.addEventListener("wmTextareaValueChanged", (ev) => {
5
+ console.log("wmTextareaValueChanged heard: ", ev.target.value);
6
+ });
7
+
8
+ textAreaEl.addEventListener("blur", (ev) => {
9
+ textAreaEl.characterLimit && handleCharacterLimit(textAreaEl);
10
+ textAreaEl.requiredField && handleRequiredTextArea(textAreaEl);
11
+ });
12
+
13
+ function handleCharacterLimit(textAreaEl) {
14
+ if (textAreaEl.value.length > textAreaEl.characterLimit) {
15
+ textAreaEl.errorMessage = "Character limit exceeded, please reduce entered text.";
16
+ } else if (textAreaEl.errorMessage == "Character limit exceeded, please reduce entered text.") {
17
+ textAreaEl.errorMessage = "";
18
+ }
19
+ }
20
+
21
+ function handleRequiredTextArea(textAreaEl) {
22
+ if (textAreaEl.value.length == 0) {
23
+ textAreaEl.errorMessage = "This field is required.";
24
+ } else if (textAreaEl.errorMessage == "This field is required.") {
25
+ textAreaEl.errorMessage = "";
26
+ }
27
+ }
28
+ });
@@ -0,0 +1,32 @@
1
+ const timepickers = document.querySelectorAll("wm-timepicker");
2
+
3
+ timepickers.forEach((timepicker) => {
4
+ timepicker.addEventListener("wmTimepickerInputBlurred", async (ev) => {
5
+ // reformat time and validate for invalid date
6
+ if (timepicker.value) {
7
+ if (await timepicker.isValidTime(ev.target.value)) {
8
+ const displayTime = await timepicker.reformatTime("12", timepicker.value);
9
+
10
+ timepicker.errorMessage = "";
11
+ timepicker.value = displayTime;
12
+ } else {
13
+ timepicker.errorMessage = "Please enter a valid time";
14
+ }
15
+ }
16
+ });
17
+
18
+ timepicker.addEventListener("blur", (ev) => {
19
+ // validate for required time
20
+ if (timepicker.requiredField && timepicker.value === "") {
21
+ timepicker.errorMessage = "A time is required";
22
+ }
23
+ });
24
+
25
+ timepicker.addEventListener("wmTimepickerTimeSelected", async (ev) => {
26
+ // handle user time selection
27
+ const selectedTime = ev.detail.time;
28
+
29
+ timepicker.errorMessage = "";
30
+ timepicker.value = await timepicker.reformatTime("12", selectedTime);
31
+ });
32
+ });
@@ -0,0 +1,9 @@
1
+ requestAnimationFrame(() => {
2
+ // put toggletip in shadow DOM
3
+ const host = document.querySelector("#host");
4
+ const shadow = host.attachShadow({ mode: "open" });
5
+ const tsd = document.querySelector("#tsd");
6
+ tsd.label = "Toggletip in shadow DOM";
7
+ tsd.tooltip = "Toggletip in shadow DOM";
8
+ shadow.appendChild(tsd);
9
+ });
@@ -0,0 +1,139 @@
1
+ function addServerError() {
2
+ document.getElementById("uploader11").errorMessage = "An error has occurred!";
3
+ }
4
+ const uploaders = document.querySelectorAll("wm-uploader");
5
+
6
+ uploaders.forEach((upl) => {
7
+ upl.addEventListener("wmUploaderFilesSelected", (ev) => handleFilesSelected(ev));
8
+ upl.addEventListener("wmFileErrorCleared", (ev) => handleErrorCleared(ev));
9
+ upl.addEventListener("wmFileDownload", (ev) => alert("downloading " + ev.target.id));
10
+ upl.addEventListener("wmFilePreview", (ev) => alert("previewing " + ev.target.id));
11
+ upl.addEventListener("wmFileDelete", (ev) => removeFile(ev));
12
+ });
13
+
14
+ function validateFile(upl, file) {
15
+ const fileList = Array.from(upl.querySelectorAll("wm-file:not([error-message])"));
16
+ const sizeLimit = 100; // in MB
17
+
18
+ if (fileList.some((currentFile) => `${currentFile.name}.${currentFile.type}` === `${file.name}.${file.type}`)) {
19
+ // check for duplicate file name
20
+ return `A file named "${file.name}.${file.type}" has already been uploaded.`;
21
+ } else if (upl.maxSize && file.size / (1024 * 1024) > sizeLimit) {
22
+ // check against maxSize
23
+ return `The file is larger than maximum size ${upl.maxSize}.`;
24
+ } else if (!upl.fileTypes.split(" ").includes(file.type)) {
25
+ // check against accepted file types
26
+ return `.${file.type} is not an accepted file type.`;
27
+ } else {
28
+ return "";
29
+ }
30
+ }
31
+
32
+ function addFile(upl, newFile) {
33
+ const newFileEl = document.createElement("wm-file");
34
+ const convertedSize = convertBytes(newFile.size);
35
+ newFileEl.id = newFile.id;
36
+ newFileEl.name = newFile.name;
37
+ newFileEl.type = newFile.type;
38
+ newFileEl.lastUpdated = newFile.lastUpdated;
39
+ newFileEl.size = `${convertedSize.size} ${convertedSize.unit}`;
40
+ newFileEl.progress = newFile.progress;
41
+
42
+ upl.append(newFileEl);
43
+ }
44
+
45
+ function addError(upl, newFile, errorMessage) {
46
+ const newFileEl = document.createElement("wm-file");
47
+ newFileEl.id = newFile.id;
48
+ newFileEl.name = newFile.name;
49
+ newFileEl.type = newFile.type;
50
+ newFileEl.errorMessage = errorMessage;
51
+ upl.prepend(newFileEl);
52
+ }
53
+
54
+ function removeFile(ev) {
55
+ const upl = ev.target.parentElement;
56
+ const fileId = ev.target.id;
57
+ upl.querySelector(`#${fileId}`).remove();
58
+ }
59
+
60
+ function handleFilesSelected(ev) {
61
+ const upl = ev.target;
62
+ const selectedFiles = ev.detail;
63
+ let currentFiles = upl.querySelectorAll("wm-file:not([error-message])");
64
+
65
+ if (upl.maxFiles && currentFiles.length + selectedFiles.length > upl.maxFiles) {
66
+ // validate for number of files exceeding file limit
67
+ upl.errorMessage = "Upload unsuccessful because file selection would exceed the maximum number of files";
68
+ } else {
69
+ upl.errorMessage = "";
70
+
71
+ selectedFiles.map((file, idx) => {
72
+ const filenameParts = file.name.split(".");
73
+ const fileType = filenameParts.pop();
74
+ const name = filenameParts.join(".");
75
+ const currentDate = `${new Date().toLocaleDateString()} ${new Date().toLocaleTimeString()}`;
76
+ const fileId = `file${Math.floor(Math.random() * 9999)}`; // mock random file id
77
+ const uploadStagger = idx * 2000; // stagger for more realistic mocked upload "speed"
78
+ const newFile = {
79
+ id: fileId,
80
+ name: name,
81
+ type: fileType,
82
+ lastUpdated: currentDate,
83
+ size: file.size,
84
+ progress: 0,
85
+ };
86
+
87
+ const fileError = validateFile(upl, newFile);
88
+ if (!fileError) {
89
+ addFile(upl, newFile);
90
+
91
+ // mock series of upload progress updates
92
+ setTimeout(() => updateUploadProgress(upl, fileId, 25), 1000);
93
+ setTimeout(() => updateUploadProgress(upl, fileId, 50), 3000 + uploadStagger);
94
+ setTimeout(() => updateUploadProgress(upl, fileId, 75), 3250 + uploadStagger);
95
+ setTimeout(() => updateUploadProgress(upl, fileId, 100), 3500 + uploadStagger);
96
+ } else {
97
+ addError(upl, newFile, fileError);
98
+ }
99
+ });
100
+ }
101
+ }
102
+
103
+ function updateUploadProgress(upl, fileId, mockProgress) {
104
+ const fileEl = upl.querySelector(`#${fileId}`);
105
+ fileEl.progress = mockProgress;
106
+ }
107
+
108
+ function handleErrorCleared(ev) {
109
+ const upl = ev.target.parentElement;
110
+ const errorId = ev.target.id;
111
+ upl.querySelector(`#${errorId}`).remove();
112
+ }
113
+
114
+ function handleSubmit() {
115
+ const requiredUploader = document.getElementById("uploader2");
116
+ const fileList = requiredUploader.querySelectorAll("wm-file:not([error-message])");
117
+ requiredUploader.errorMessage = fileList.length === 0 ? "Please upload at least one file" : "";
118
+ }
119
+
120
+ function convertBytes(bytes, unit) {
121
+ const unitOrder = ["bytes", "KB", "MB", "GB", "TB"];
122
+ let unitIndex = 0;
123
+ let result = typeof bytes === "number" ? bytes : parseInt(bytes);
124
+
125
+ if (unit) {
126
+ // convert until result matches desired unit
127
+ while (unitOrder.indexOf(unit) > unitIndex) {
128
+ result /= 1024;
129
+ unitIndex++;
130
+ }
131
+ } else {
132
+ // convert until result is appropriate unit (value is under 1000)
133
+ while (result > 1000) {
134
+ result /= 1024;
135
+ unitIndex++;
136
+ }
137
+ }
138
+ return { size: result, unit: unitOrder[unitIndex] };
139
+ }
@@ -0,0 +1,6 @@
1
+ export const generateId = () => "random-id";
2
+ export const getTextDir = () => "rtl";
3
+ export const intl = {
4
+ formatMessage: (_) => "[translated text]",
5
+ };
6
+ export const adjustTooltipPosition = () => "bottom-right";