@watermarkinsights/ripple 5.11.0-4 → 5.11.0-5

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 (426) hide show
  1. package/dist/cjs/{chartFunctions-7314b414.js → chartFunctions-b47a5431.js} +3 -3
  2. package/dist/cjs/{functions-5ac8a62f.js → functions-e24249e6.js} +7 -104
  3. package/dist/{esm/app-globals-e7c0199c.js → cjs/global-6d269c79.js} +2 -7
  4. package/dist/cjs/index-e86c28b6.js +2649 -0
  5. package/dist/cjs/{intl-07aaf53c.js → intl-a70cf8c2.js} +1 -1
  6. package/dist/cjs/loader.cjs.js +3 -4
  7. package/dist/cjs/priv-calendar.cjs.entry.js +12 -13
  8. package/dist/cjs/priv-chart-popover.cjs.entry.js +6 -7
  9. package/dist/cjs/priv-navigator-button.cjs.entry.js +4 -5
  10. package/dist/cjs/priv-navigator-item.cjs.entry.js +4 -5
  11. package/dist/cjs/priv-option-list.cjs.entry.js +7 -8
  12. package/dist/cjs/ripple.cjs.js +11 -12
  13. package/dist/cjs/wm-action-menu_2.cjs.entry.js +8 -10
  14. package/dist/cjs/wm-button.cjs.entry.js +5 -6
  15. package/dist/cjs/wm-chart-slice.cjs.entry.js +1 -1
  16. package/dist/cjs/wm-chart.cjs.entry.js +7 -8
  17. package/dist/cjs/wm-date-range.cjs.entry.js +9 -10
  18. package/dist/cjs/wm-datepicker.cjs.entry.js +9 -10
  19. package/dist/cjs/wm-file-list.cjs.entry.js +4 -5
  20. package/dist/cjs/wm-file.cjs.entry.js +12 -13
  21. package/dist/cjs/wm-input.cjs.entry.js +6 -7
  22. package/dist/cjs/wm-line-chart.cjs.entry.js +20 -28
  23. package/dist/cjs/wm-modal-pss_3.cjs.entry.js +13 -16
  24. package/dist/cjs/wm-modal_3.cjs.entry.js +13 -16
  25. package/dist/cjs/wm-navigation_3.cjs.entry.js +13 -16
  26. package/dist/cjs/wm-navigator.cjs.entry.js +4 -5
  27. package/dist/cjs/wm-nested-select.cjs.entry.js +11 -12
  28. package/dist/cjs/wm-optgroup.cjs.entry.js +5 -6
  29. package/dist/cjs/wm-option_2.cjs.entry.js +11 -13
  30. package/dist/cjs/wm-pagination.cjs.entry.js +5 -6
  31. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +9 -11
  32. package/dist/cjs/wm-search.cjs.entry.js +9 -10
  33. package/dist/cjs/wm-snackbar.cjs.entry.js +8 -9
  34. package/dist/cjs/wm-tab-item_3.cjs.entry.js +11 -14
  35. package/dist/cjs/wm-tag-input.cjs.entry.js +10 -11
  36. package/dist/cjs/wm-tag-option.cjs.entry.js +2 -2
  37. package/dist/cjs/wm-textarea.cjs.entry.js +6 -7
  38. package/dist/cjs/wm-timepicker.cjs.entry.js +6 -7
  39. package/dist/cjs/wm-toggletip.cjs.entry.js +6 -7
  40. package/dist/cjs/wm-uploader.cjs.entry.js +7 -8
  41. package/dist/cjs/wm-wrapper.cjs.entry.js +1 -1
  42. package/dist/collection/collection-manifest.json +2 -2
  43. package/dist/collection/components/charts/chartFunctions.js +1 -1
  44. package/dist/collection/components/charts/chartFunctions.spec.js +16 -0
  45. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.css +570 -13
  46. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.e2e.js +81 -0
  47. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +2 -2
  48. package/dist/collection/components/charts/screenshots.e2e.js +96 -0
  49. package/dist/collection/components/charts/wm-chart/wm-chart.css +574 -17
  50. package/dist/collection/components/charts/wm-chart/wm-chart.e2e.js +213 -0
  51. package/dist/collection/components/charts/wm-chart/wm-chart.js +1 -1
  52. package/dist/collection/components/charts/wm-chart/wm-chart.spec.js +37 -0
  53. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.css +599 -68
  54. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.e2e.js +176 -0
  55. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +14 -21
  56. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.spec.js +163 -0
  57. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.css +574 -17
  58. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +1 -1
  59. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.css +570 -13
  60. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.e2e.js +69 -0
  61. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +1 -1
  62. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.spec.js +79 -0
  63. package/dist/collection/components/datepickers/datepicker.css +586 -25
  64. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.css +587 -51
  65. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +8 -8
  66. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.spec.js +89 -0
  67. package/dist/collection/components/datepickers/wm-date-range.e2e.js +443 -0
  68. package/dist/collection/components/datepickers/wm-date-range.js +13 -17
  69. package/dist/collection/components/datepickers/wm-date-range.spec.js +22 -0
  70. package/dist/collection/components/datepickers/wm-datepicker.e2e.js +382 -0
  71. package/dist/collection/components/datepickers/wm-datepicker.js +13 -17
  72. package/dist/collection/components/datepickers/wm-datepicker.spec.js +21 -0
  73. package/dist/collection/components/selects/priv-option-list/priv-option-list.css +576 -36
  74. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +7 -9
  75. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.css +594 -64
  76. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +6 -6
  77. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.css +570 -13
  78. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +1 -1
  79. package/dist/collection/components/selects/wm-option/wm-option.css +576 -30
  80. package/dist/collection/components/selects/wm-option/wm-option.e2e.js +22 -0
  81. package/dist/collection/components/selects/wm-option/wm-option.js +1 -1
  82. package/dist/collection/components/selects/wm-option/wm-option.spec.js +63 -0
  83. package/dist/collection/components/selects/wm-select/wm-select.css +588 -40
  84. package/dist/collection/components/selects/wm-select/wm-select.e2e.js +521 -0
  85. package/dist/collection/components/selects/wm-select/wm-select.js +3 -3
  86. package/dist/collection/components/selects/wm-select/wm-select.spec.js +271 -0
  87. package/dist/collection/components/wm-action-menu/wm-action-menu.css +570 -13
  88. package/dist/collection/components/wm-action-menu/wm-action-menu.e2e.js +200 -0
  89. package/dist/collection/components/wm-action-menu/wm-action-menu.js +1 -1
  90. package/dist/collection/components/wm-action-menu/wm-action-menu.spec.js +48 -0
  91. package/dist/collection/components/wm-button/wm-button.css +575 -28
  92. package/dist/collection/components/wm-button/wm-button.e2e.js +55 -0
  93. package/dist/collection/components/wm-button/wm-button.js +1 -1
  94. package/dist/collection/components/wm-button/wm-button.spec.js +74 -0
  95. package/dist/collection/components/wm-file/wm-file.css +573 -25
  96. package/dist/collection/components/wm-file/wm-file.js +8 -8
  97. package/dist/collection/components/wm-file/wm-file.spec.js +194 -0
  98. package/dist/collection/components/wm-file-list/wm-file-list.css +577 -20
  99. package/dist/collection/components/wm-file-list/wm-file-list.js +1 -1
  100. package/dist/collection/components/wm-file-list/wm-file-list.spec.js +69 -0
  101. package/dist/collection/components/wm-input/wm-input.css +585 -25
  102. package/dist/collection/components/wm-input/wm-input.e2e.js +32 -0
  103. package/dist/collection/components/wm-input/wm-input.js +1 -1
  104. package/dist/collection/components/wm-input/wm-input.spec.js +173 -0
  105. package/dist/collection/components/wm-menuitem/wm-menuitem.css +575 -18
  106. package/dist/collection/components/wm-menuitem/wm-menuitem.e2e.js +23 -0
  107. package/dist/collection/components/wm-menuitem/wm-menuitem.js +1 -1
  108. package/dist/collection/components/wm-menuitem/wm-menuitem.spec.js +54 -0
  109. package/dist/collection/components/wm-modal/wm-modal-footer.css +577 -20
  110. package/dist/collection/components/wm-modal/wm-modal-footer.js +1 -1
  111. package/dist/collection/components/wm-modal/wm-modal-footer.spec.js +11 -0
  112. package/dist/collection/components/wm-modal/wm-modal-header.css +577 -20
  113. package/dist/collection/components/wm-modal/wm-modal-header.js +1 -1
  114. package/dist/collection/components/wm-modal/wm-modal-header.spec.js +8 -0
  115. package/dist/collection/components/wm-modal/wm-modal.css +570 -13
  116. package/dist/collection/components/wm-modal/wm-modal.e2e.js +104 -0
  117. package/dist/collection/components/wm-modal/wm-modal.js +2 -2
  118. package/dist/collection/components/wm-modal/wm-modal.spec.js +30 -0
  119. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.css +570 -13
  120. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +1 -1
  121. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.css +577 -20
  122. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +1 -1
  123. package/dist/collection/components/wm-modal-pss/wm-modal-pss.css +570 -13
  124. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +2 -2
  125. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.css +575 -24
  126. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +1 -1
  127. package/dist/collection/components/wm-navigation/wm-navigation-item.css +570 -13
  128. package/dist/collection/components/wm-navigation/wm-navigation-item.js +1 -1
  129. package/dist/collection/components/wm-navigation/wm-navigation.css +570 -13
  130. package/dist/collection/components/wm-navigation/wm-navigation.e2e.js +102 -0
  131. package/dist/collection/components/wm-navigation/wm-navigation.js +3 -3
  132. package/dist/collection/components/wm-navigation/wm-navigation.spec.js +91 -0
  133. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +570 -13
  134. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.e2e.js +50 -0
  135. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +1 -1
  136. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +576 -19
  137. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +1 -1
  138. package/dist/collection/components/wm-navigator/wm-navigator.css +575 -18
  139. package/dist/collection/components/wm-navigator/wm-navigator.e2e.js +209 -0
  140. package/dist/collection/components/wm-navigator/wm-navigator.spec.js +177 -0
  141. package/dist/collection/components/wm-pagination/wm-pagination.css +575 -18
  142. package/dist/collection/components/wm-pagination/wm-pagination.e2e.js +312 -0
  143. package/dist/collection/components/wm-pagination/wm-pagination.js +1 -1
  144. package/dist/collection/components/wm-search/wm-search.css +573 -23
  145. package/dist/collection/components/wm-search/wm-search.e2e.js +76 -0
  146. package/dist/collection/components/wm-search/wm-search.js +6 -7
  147. package/dist/collection/components/wm-search/wm-search.spec.js +71 -0
  148. package/dist/collection/components/wm-snackbar/wm-snackbar.css +574 -34
  149. package/dist/collection/components/wm-snackbar/wm-snackbar.e2e.js +112 -0
  150. package/dist/collection/components/wm-snackbar/wm-snackbar.js +3 -3
  151. package/dist/collection/components/wm-snackbar/wm-snackbar.spec.js +9 -0
  152. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +570 -13
  153. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +1 -1
  154. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +576 -19
  155. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +1 -1
  156. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +570 -13
  157. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +1 -1
  158. package/dist/collection/components/wm-tabs/wm-tabs.e2e.js +91 -0
  159. package/dist/collection/components/wm-tabs/wm-tabs.spec.js +12 -0
  160. package/dist/collection/components/wm-tag-input/wm-tag-input.css +594 -68
  161. package/dist/collection/components/wm-tag-input/wm-tag-input.e2e.js +204 -0
  162. package/dist/collection/components/wm-tag-input/wm-tag-input.js +5 -5
  163. package/dist/collection/components/wm-tag-input/wm-tag-input.spec.js +195 -0
  164. package/dist/collection/components/wm-textarea/wm-textarea.css +585 -25
  165. package/dist/collection/components/wm-textarea/wm-textarea.e2e.js +41 -0
  166. package/dist/collection/components/wm-textarea/wm-textarea.js +1 -1
  167. package/dist/collection/components/wm-textarea/wm-textarea.spec.js +79 -0
  168. package/dist/collection/components/wm-timepicker/wm-timepicker.css +587 -37
  169. package/dist/collection/components/wm-timepicker/wm-timepicker.e2e.js +163 -0
  170. package/dist/collection/components/wm-timepicker/wm-timepicker.js +8 -11
  171. package/dist/collection/components/wm-timepicker/wm-timepicker.spec.js +147 -0
  172. package/dist/collection/components/wm-toggletip/wm-toggletip.css +573 -23
  173. package/dist/collection/components/wm-toggletip/wm-toggletip.e2e.js +69 -0
  174. package/dist/collection/components/wm-toggletip/wm-toggletip.js +2 -2
  175. package/dist/collection/components/wm-toggletip/wm-toggletip.spec.js +21 -0
  176. package/dist/collection/components/wm-uploader/wm-uploader.css +590 -40
  177. package/dist/collection/components/wm-uploader/wm-uploader.e2e.js +70 -0
  178. package/dist/collection/components/wm-uploader/wm-uploader.js +2 -2
  179. package/dist/collection/components/wm-uploader/wm-uploader.spec.js +234 -0
  180. package/dist/collection/global/functions.spec.js +126 -0
  181. package/dist/collection/lang/lang.spec.js +20 -0
  182. package/dist/esm/{chartFunctions-c273c613.js → chartFunctions-d2ecde7f.js} +3 -3
  183. package/dist/esm/{functions-f39e6177.js → functions-8800c690.js} +8 -105
  184. package/dist/{cjs/app-globals-9ac264d7.js → esm/global-f2ef720a.js} +1 -10
  185. package/dist/esm/index-558b5a82.js +2618 -0
  186. package/dist/esm/{intl-a0ebf99e.js → intl-cf443c87.js} +1 -1
  187. package/dist/esm/loader.js +4 -5
  188. package/dist/esm/priv-calendar.entry.js +12 -13
  189. package/dist/esm/priv-chart-popover.entry.js +6 -7
  190. package/dist/esm/priv-navigator-button.entry.js +4 -5
  191. package/dist/esm/priv-navigator-item.entry.js +4 -5
  192. package/dist/esm/priv-option-list.entry.js +7 -8
  193. package/dist/esm/ripple.js +12 -13
  194. package/dist/esm/wm-action-menu_2.entry.js +8 -10
  195. package/dist/esm/wm-button.entry.js +5 -6
  196. package/dist/esm/wm-chart-slice.entry.js +1 -1
  197. package/dist/esm/wm-chart.entry.js +7 -8
  198. package/dist/esm/wm-date-range.entry.js +9 -10
  199. package/dist/esm/wm-datepicker.entry.js +9 -10
  200. package/dist/esm/wm-file-list.entry.js +4 -5
  201. package/dist/esm/wm-file.entry.js +12 -13
  202. package/dist/esm/wm-input.entry.js +6 -7
  203. package/dist/esm/wm-line-chart.entry.js +20 -28
  204. package/dist/esm/wm-modal-pss_3.entry.js +13 -16
  205. package/dist/esm/wm-modal_3.entry.js +13 -16
  206. package/dist/esm/wm-navigation_3.entry.js +13 -16
  207. package/dist/esm/wm-navigator.entry.js +4 -5
  208. package/dist/esm/wm-nested-select.entry.js +11 -12
  209. package/dist/esm/wm-optgroup.entry.js +5 -6
  210. package/dist/esm/wm-option_2.entry.js +11 -13
  211. package/dist/esm/wm-pagination.entry.js +5 -6
  212. package/dist/esm/wm-progress-indicator_3.entry.js +9 -11
  213. package/dist/esm/wm-search.entry.js +9 -10
  214. package/dist/esm/wm-snackbar.entry.js +8 -9
  215. package/dist/esm/wm-tab-item_3.entry.js +11 -14
  216. package/dist/esm/wm-tag-input.entry.js +10 -11
  217. package/dist/esm/wm-tag-option.entry.js +2 -2
  218. package/dist/esm/wm-textarea.entry.js +6 -7
  219. package/dist/esm/wm-timepicker.entry.js +6 -7
  220. package/dist/esm/wm-toggletip.entry.js +6 -7
  221. package/dist/esm/wm-uploader.entry.js +7 -8
  222. package/dist/esm/wm-wrapper.entry.js +1 -1
  223. package/dist/esm-es5/{chartFunctions-c273c613.js → chartFunctions-d2ecde7f.js} +1 -1
  224. package/dist/esm-es5/functions-8800c690.js +1 -0
  225. package/dist/esm-es5/global-f2ef720a.js +1 -0
  226. package/dist/esm-es5/index-558b5a82.js +1 -0
  227. package/dist/esm-es5/{intl-a0ebf99e.js → intl-cf443c87.js} +1 -1
  228. package/dist/esm-es5/loader.js +1 -1
  229. package/dist/esm-es5/priv-calendar.entry.js +1 -1
  230. package/dist/esm-es5/priv-chart-popover.entry.js +1 -1
  231. package/dist/esm-es5/priv-navigator-button.entry.js +1 -1
  232. package/dist/esm-es5/priv-navigator-item.entry.js +1 -1
  233. package/dist/esm-es5/priv-option-list.entry.js +1 -1
  234. package/dist/esm-es5/ripple.js +1 -1
  235. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -1
  236. package/dist/esm-es5/wm-button.entry.js +1 -1
  237. package/dist/esm-es5/wm-chart-slice.entry.js +1 -1
  238. package/dist/esm-es5/wm-chart.entry.js +1 -1
  239. package/dist/esm-es5/wm-date-range.entry.js +1 -1
  240. package/dist/esm-es5/wm-datepicker.entry.js +1 -1
  241. package/dist/esm-es5/wm-file-list.entry.js +1 -1
  242. package/dist/esm-es5/wm-file.entry.js +1 -1
  243. package/dist/esm-es5/wm-input.entry.js +1 -1
  244. package/dist/esm-es5/wm-line-chart.entry.js +1 -1
  245. package/dist/esm-es5/wm-modal-pss_3.entry.js +1 -1
  246. package/dist/esm-es5/wm-modal_3.entry.js +1 -1
  247. package/dist/esm-es5/wm-navigation_3.entry.js +1 -1
  248. package/dist/esm-es5/wm-navigator.entry.js +1 -1
  249. package/dist/esm-es5/wm-nested-select.entry.js +1 -1
  250. package/dist/esm-es5/wm-optgroup.entry.js +1 -1
  251. package/dist/esm-es5/wm-option_2.entry.js +1 -1
  252. package/dist/esm-es5/wm-pagination.entry.js +1 -1
  253. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -1
  254. package/dist/esm-es5/wm-search.entry.js +1 -1
  255. package/dist/esm-es5/wm-snackbar.entry.js +1 -1
  256. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -1
  257. package/dist/esm-es5/wm-tag-input.entry.js +1 -1
  258. package/dist/esm-es5/wm-tag-option.entry.js +1 -1
  259. package/dist/esm-es5/wm-textarea.entry.js +1 -1
  260. package/dist/esm-es5/wm-timepicker.entry.js +1 -1
  261. package/dist/esm-es5/wm-toggletip.entry.js +1 -1
  262. package/dist/esm-es5/wm-uploader.entry.js +1 -1
  263. package/dist/esm-es5/wm-wrapper.entry.js +1 -1
  264. package/dist/loader/cdn.js +2 -1
  265. package/dist/loader/index.cjs.js +2 -1
  266. package/dist/loader/index.d.ts +0 -3
  267. package/dist/loader/index.es2017.js +2 -1
  268. package/dist/loader/index.js +2 -1
  269. package/dist/ripple/p-0021b81c.system.entry.js +1 -0
  270. package/dist/ripple/p-0e36d5b8.system.entry.js +1 -0
  271. package/dist/ripple/p-159c4e96.entry.js +1 -0
  272. package/dist/ripple/p-1940a508.entry.js +1 -0
  273. package/dist/ripple/p-1a4b6b02.system.entry.js +1 -0
  274. package/dist/ripple/p-1a71d867.system.entry.js +1 -0
  275. package/dist/ripple/p-1c486c10.entry.js +1 -0
  276. package/dist/ripple/p-1fce9f27.entry.js +1 -0
  277. package/dist/ripple/p-21b87733.system.entry.js +1 -0
  278. package/dist/ripple/p-2b21c6f5.system.entry.js +1 -0
  279. package/dist/ripple/p-32507c13.system.entry.js +1 -0
  280. package/dist/ripple/{p-823d7b4e.system.entry.js → p-32bf3f5b.system.entry.js} +1 -1
  281. package/dist/ripple/{p-bb25b9af.system.js → p-3322823d.system.js} +1 -1
  282. package/dist/ripple/{p-96505312.js → p-366920dc.js} +1 -1
  283. package/dist/ripple/p-39a7a8c2.system.entry.js +1 -0
  284. package/dist/ripple/p-39e26322.entry.js +1 -0
  285. package/dist/ripple/p-3a1c61a9.entry.js +1 -0
  286. package/dist/ripple/p-3aeaedcc.entry.js +1 -0
  287. package/dist/ripple/p-417ee34d.entry.js +1 -0
  288. package/dist/ripple/p-44f426ad.entry.js +1 -0
  289. package/dist/ripple/{p-c34c9cbb.system.entry.js → p-4743176d.system.entry.js} +1 -1
  290. package/dist/ripple/{p-13b1d775.entry.js → p-48e09589.entry.js} +1 -1
  291. package/dist/ripple/p-4de728e1.entry.js +1 -0
  292. package/dist/ripple/p-4ff87702.system.entry.js +1 -0
  293. package/dist/ripple/p-5415aaf9.system.entry.js +1 -0
  294. package/dist/ripple/p-544925c2.entry.js +1 -0
  295. package/dist/ripple/p-55d837e7.system.entry.js +1 -0
  296. package/dist/ripple/p-55e9e0cb.entry.js +1 -0
  297. package/dist/ripple/p-568c595f.js +2 -0
  298. package/dist/ripple/p-5e1a53e9.system.js +1 -0
  299. package/dist/ripple/p-5e9c9f0d.entry.js +1 -0
  300. package/dist/ripple/p-608f69c1.system.entry.js +1 -0
  301. package/dist/ripple/p-64b1e73b.entry.js +1 -0
  302. package/dist/ripple/{p-043901ab.system.entry.js → p-65d26233.system.entry.js} +1 -1
  303. package/dist/ripple/p-68e04222.entry.js +1 -0
  304. package/dist/ripple/p-6b014a04.system.entry.js +1 -0
  305. package/dist/ripple/p-704be1e8.system.entry.js +1 -0
  306. package/dist/ripple/p-70bce4ef.system.entry.js +1 -0
  307. package/dist/ripple/{p-9708c995.js → p-710c6115.js} +1 -1
  308. package/dist/ripple/p-727910d3.entry.js +1 -0
  309. package/dist/ripple/p-743eb986.system.entry.js +1 -0
  310. package/dist/ripple/p-7478303e.entry.js +1 -0
  311. package/dist/ripple/p-79043436.entry.js +1 -0
  312. package/dist/ripple/p-797d65b7.entry.js +1 -0
  313. package/dist/ripple/p-7b4af332.system.entry.js +1 -0
  314. package/dist/ripple/p-7cf5993c.system.entry.js +1 -0
  315. package/dist/ripple/p-878fd4af.system.entry.js +1 -0
  316. package/dist/ripple/{p-cd0cc88d.entry.js → p-88ebddd7.entry.js} +1 -1
  317. package/dist/ripple/p-915289ac.system.entry.js +1 -0
  318. package/dist/ripple/p-94495341.entry.js +1 -0
  319. package/dist/ripple/p-94717864.entry.js +1 -0
  320. package/dist/ripple/p-9dd401f8.entry.js +1 -0
  321. package/dist/ripple/p-9eaa0acb.system.entry.js +1 -0
  322. package/dist/ripple/p-a04ef164.system.entry.js +1 -0
  323. package/dist/ripple/p-a9a22fe9.system.entry.js +1 -0
  324. package/dist/ripple/p-ab8d78cc.system.js +2 -0
  325. package/dist/ripple/p-adc254e6.entry.js +1 -0
  326. package/dist/ripple/p-b02048a9.entry.js +1 -0
  327. package/dist/ripple/p-b52742ca.system.entry.js +1 -0
  328. package/dist/ripple/p-b9718c79.js +1 -0
  329. package/dist/ripple/{p-76d248e6.entry.js → p-b976c84b.entry.js} +1 -1
  330. package/dist/ripple/p-ba6705f0.system.entry.js +1 -0
  331. package/dist/ripple/p-bc52ce59.entry.js +1 -0
  332. package/dist/ripple/p-c7e30eb0.system.entry.js +1 -0
  333. package/dist/ripple/p-d57e8196.entry.js +1 -0
  334. package/dist/ripple/p-d585c49a.entry.js +1 -0
  335. package/dist/ripple/p-d6732390.system.js +1 -0
  336. package/dist/ripple/p-d6e58820.system.entry.js +1 -0
  337. package/dist/ripple/p-dc77d98a.entry.js +1 -0
  338. package/dist/ripple/p-dd01bd48.entry.js +1 -0
  339. package/dist/ripple/p-de272ae7.system.entry.js +1 -0
  340. package/dist/ripple/p-e2c6052b.system.entry.js +1 -0
  341. package/dist/ripple/{p-4c1efa04.system.js → p-e71ee9f4.system.js} +1 -1
  342. package/dist/ripple/p-e9068226.entry.js +1 -0
  343. package/dist/ripple/p-e9b8a6a9.entry.js +1 -0
  344. package/dist/ripple/p-eca78c2b.js +1 -0
  345. package/dist/ripple/p-edd87140.system.js +1 -0
  346. package/dist/ripple/p-f6eff655.system.entry.js +1 -0
  347. package/dist/ripple/p-f779ec68.system.entry.js +1 -0
  348. package/dist/ripple/ripple.css +1 -1
  349. package/dist/ripple/ripple.esm.js +1 -1
  350. package/dist/ripple/ripple.js +1 -1
  351. package/dist/types/stencil-public-runtime.d.ts +10 -3
  352. package/package.json +1 -1
  353. package/dist/cjs/index-788526f5.js +0 -1859
  354. package/dist/esm/index-130e07bb.js +0 -1828
  355. package/dist/esm-es5/app-globals-e7c0199c.js +0 -1
  356. package/dist/esm-es5/functions-f39e6177.js +0 -1
  357. package/dist/esm-es5/index-130e07bb.js +0 -1
  358. package/dist/ripple/p-044cbd11.system.entry.js +0 -1
  359. package/dist/ripple/p-07087139.system.entry.js +0 -1
  360. package/dist/ripple/p-0bffed17.entry.js +0 -1
  361. package/dist/ripple/p-0d77c2f2.system.entry.js +0 -1
  362. package/dist/ripple/p-0fb8f36d.entry.js +0 -1
  363. package/dist/ripple/p-11c9fc2e.entry.js +0 -1
  364. package/dist/ripple/p-26c0304e.entry.js +0 -1
  365. package/dist/ripple/p-2e1f1f9e.entry.js +0 -1
  366. package/dist/ripple/p-3405e16e.entry.js +0 -1
  367. package/dist/ripple/p-342e6ba1.system.entry.js +0 -1
  368. package/dist/ripple/p-35f8ac95.system.entry.js +0 -1
  369. package/dist/ripple/p-36fa8451.entry.js +0 -1
  370. package/dist/ripple/p-3f486eed.system.js +0 -1
  371. package/dist/ripple/p-43055c83.system.entry.js +0 -1
  372. package/dist/ripple/p-44b7ac3f.system.entry.js +0 -1
  373. package/dist/ripple/p-46979d51.entry.js +0 -1
  374. package/dist/ripple/p-486540be.system.entry.js +0 -1
  375. package/dist/ripple/p-4b0989d7.entry.js +0 -1
  376. package/dist/ripple/p-4b413899.system.js +0 -1
  377. package/dist/ripple/p-4ffed2a0.system.entry.js +0 -1
  378. package/dist/ripple/p-524f2756.entry.js +0 -1
  379. package/dist/ripple/p-540dc07f.entry.js +0 -1
  380. package/dist/ripple/p-564893b0.js +0 -1
  381. package/dist/ripple/p-585d603f.entry.js +0 -1
  382. package/dist/ripple/p-5a05046a.system.entry.js +0 -1
  383. package/dist/ripple/p-5c2fc698.entry.js +0 -1
  384. package/dist/ripple/p-5f247e4a.entry.js +0 -1
  385. package/dist/ripple/p-65d2c6b7.entry.js +0 -1
  386. package/dist/ripple/p-6b119eec.system.entry.js +0 -1
  387. package/dist/ripple/p-6c1553b1.system.entry.js +0 -1
  388. package/dist/ripple/p-72935ed4.entry.js +0 -1
  389. package/dist/ripple/p-7dec8712.system.entry.js +0 -1
  390. package/dist/ripple/p-7ed7b66f.system.entry.js +0 -1
  391. package/dist/ripple/p-8270cd9e.system.entry.js +0 -1
  392. package/dist/ripple/p-831d25cb.system.entry.js +0 -1
  393. package/dist/ripple/p-88973d98.system.entry.js +0 -1
  394. package/dist/ripple/p-89a2db02.js +0 -1
  395. package/dist/ripple/p-8a6c4a3b.system.js +0 -1
  396. package/dist/ripple/p-8acb1dc0.entry.js +0 -1
  397. package/dist/ripple/p-8b983e94.system.entry.js +0 -1
  398. package/dist/ripple/p-9160d382.system.entry.js +0 -1
  399. package/dist/ripple/p-91fc6acf.system.entry.js +0 -1
  400. package/dist/ripple/p-97c524e5.system.entry.js +0 -1
  401. package/dist/ripple/p-a89a0ce4.system.entry.js +0 -1
  402. package/dist/ripple/p-a96fd05a.entry.js +0 -1
  403. package/dist/ripple/p-aaa18797.entry.js +0 -1
  404. package/dist/ripple/p-aab342f1.entry.js +0 -1
  405. package/dist/ripple/p-aae83494.system.entry.js +0 -1
  406. package/dist/ripple/p-ac0655a0.entry.js +0 -1
  407. package/dist/ripple/p-ade89f97.system.entry.js +0 -1
  408. package/dist/ripple/p-b02dfe01.system.entry.js +0 -1
  409. package/dist/ripple/p-b8873f91.entry.js +0 -1
  410. package/dist/ripple/p-b8912fba.system.entry.js +0 -1
  411. package/dist/ripple/p-bad14b66.entry.js +0 -1
  412. package/dist/ripple/p-c22b9ac6.entry.js +0 -1
  413. package/dist/ripple/p-c66335a0.entry.js +0 -1
  414. package/dist/ripple/p-cef8a45b.system.js +0 -2
  415. package/dist/ripple/p-d19f494d.system.entry.js +0 -1
  416. package/dist/ripple/p-d254efea.system.entry.js +0 -1
  417. package/dist/ripple/p-d3ffe48c.system.entry.js +0 -1
  418. package/dist/ripple/p-d49cd886.entry.js +0 -1
  419. package/dist/ripple/p-d7ce58a3.entry.js +0 -1
  420. package/dist/ripple/p-d9da0502.js +0 -2
  421. package/dist/ripple/p-e3083b58.entry.js +0 -1
  422. package/dist/ripple/p-eb832c89.entry.js +0 -1
  423. package/dist/ripple/p-ecd38ef7.entry.js +0 -1
  424. package/dist/ripple/p-f1abfaa1.entry.js +0 -1
  425. package/dist/ripple/p-f4ed6ee8.system.entry.js +0 -1
  426. package/dist/ripple/p-fd862f4e.system.entry.js +0 -1
@@ -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
+ });
@@ -300,9 +300,9 @@ export class Uploader {
300
300
  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", { ref: (el) => (this.dropOverlayEl = el), class: "drop-overlay", popover: "manual" }, h("span", { class: "upload-arrow" }), h("span", null, "Drop to Upload")))));
301
301
  }
302
302
  render() {
303
- return (h(Host, { key: '2fceb6af60332a9740298457c2dd6b3176f4d138', class: `-${this.dropArea}` }, this.uploaderType == "drop" && this.renderDropArea(), this.label && this.renderLabel(), this.renderHeader(), this.renderListContainer(), h("div", { key: '70f4e9a42c17a2583d9f5effad1c9ef7561ffe15', 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
303
+ return (h(Host, { class: `-${this.dropArea}` }, 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
304
304
  ,
305
- "aria-atomic": "true" }), h("div", { key: '3be25509a8136b8d09162c48bcd8c7766e17639a', ref: (el) => (this.politeLiveRegionEl = el), class: "live-region sr-only", "aria-live": "polite", "aria-atomic": "true" })));
305
+ "aria-atomic": "true" }), h("div", { ref: (el) => (this.politeLiveRegionEl = el), class: "live-region sr-only", "aria-live": "polite", "aria-atomic": "true" })));
306
306
  }
307
307
  static get is() { return "wm-uploader"; }
308
308
  static get encapsulation() { return "shadow"; }
@@ -0,0 +1,234 @@
1
+ jest.mock("../../global/services/http-service");
2
+ import { newSpecPage } from "@stencil/core/testing";
3
+ import { Uploader } from "./wm-uploader";
4
+ import { File } from "../wm-file/wm-file";
5
+ // mock ResizeObserver
6
+ global.ResizeObserver = jest.fn().mockImplementation(() => ({
7
+ observe: jest.fn(),
8
+ unobserve: jest.fn(),
9
+ disconnect: jest.fn(),
10
+ }));
11
+ // mock MutationObserver
12
+ global.MutationObserver = jest.fn().mockImplementation(() => ({
13
+ observe: jest.fn(),
14
+ unobserve: jest.fn(),
15
+ disconnect: jest.fn(),
16
+ }));
17
+ describe("wm-uploader", () => {
18
+ let html, page;
19
+ beforeEach(async () => {
20
+ html = `<wm-uploader
21
+ id="uploader1"
22
+ button-text="Upload new document"
23
+ max-size="200 MB"
24
+ max-files="5"
25
+ >
26
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
27
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
28
+ </wm-uploader>`;
29
+ page = await newSpecPage({ components: [Uploader, File], html });
30
+ await page.waitForChanges();
31
+ });
32
+ afterEach(() => {
33
+ html = undefined;
34
+ page = undefined;
35
+ });
36
+ it("has necessary aria properties", async () => {
37
+ let inputEl = page.root.shadowRoot.querySelector("input");
38
+ expect(inputEl).toEqualAttribute("aria-describedby", "file-count max-size accepted-types");
39
+ html = `<wm-uploader
40
+ id="uploader1"
41
+ button-text="Upload new document"
42
+ label="example label"
43
+ required-field="true"
44
+ ></wm-uploader>`;
45
+ page = await newSpecPage({ components: [Uploader, File], html });
46
+ await page.waitForChanges();
47
+ inputEl = page.root.shadowRoot.querySelector("input");
48
+ expect(inputEl).toEqualAttribute("aria-label", "example label, Upload new document");
49
+ expect(inputEl).toEqualAttribute("aria-required", "true");
50
+ html = `<wm-uploader
51
+ id="uploader1"
52
+ button-text="Upload new document"
53
+ required-field="true"
54
+ ></wm-uploader>`;
55
+ page = await newSpecPage({ components: [Uploader, File], html });
56
+ await page.waitForChanges();
57
+ inputEl = page.root.shadowRoot.querySelector("input");
58
+ expect(inputEl).toEqualAttribute("aria-label", "Upload new document");
59
+ html = `<wm-uploader
60
+ id="uploader1"
61
+ button-text="Upload new document"
62
+ label="Upload new document"
63
+ required-field="true"
64
+ ></wm-uploader>`;
65
+ page = await newSpecPage({ components: [Uploader, File], html });
66
+ await page.waitForChanges();
67
+ inputEl = page.root.shadowRoot.querySelector("input");
68
+ expect(inputEl).toEqualAttribute("aria-label", "Upload new document");
69
+ });
70
+ it("renders button text based on button-text prop", () => {
71
+ const labelEl = page.root.shadowRoot.querySelector("label");
72
+ expect(labelEl.textContent).toBe("Upload new document");
73
+ });
74
+ it("uploads files", async () => {
75
+ const input = page.root.shadowRoot.querySelector("input");
76
+ // fake files which the components uploadFiles() function will process
77
+ // @ts-ignore
78
+ input.files = {
79
+ length: 2,
80
+ 0: {
81
+ lastModified: 1562163068000,
82
+ lastModifiedDate: new Date(1562163068000),
83
+ name: "third_file.pdf",
84
+ size: 104857600,
85
+ type: "application/pdf",
86
+ webkitRelativePath: "",
87
+ },
88
+ 1: {
89
+ lastModified: 1562062469000,
90
+ lastModifiedDate: new Date(1562062469000),
91
+ name: "fourth file.jpg",
92
+ size: 123456,
93
+ type: "image/jpeg",
94
+ webkitRelativePath: "",
95
+ },
96
+ };
97
+ // triggering the change event will run validations and emit event wmUploaderFilesSelected
98
+ const ev = new Event("change");
99
+ let validFiles = [];
100
+ page.root.addEventListener("wmUploaderFilesSelected", (ev) => (validFiles = ev.detail));
101
+ input.dispatchEvent(ev);
102
+ await page.waitForChanges();
103
+ expect(validFiles[0].name).toBe("third_file.pdf");
104
+ expect(validFiles[1].size).toBe(123456);
105
+ });
106
+ it("disables button when upload is in progress", async () => {
107
+ html = `<wm-uploader id="uploader1">
108
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB" progress="30"></wm-file>
109
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
110
+ </wm-uploader>`;
111
+ page = await newSpecPage({ components: [Uploader, File], html });
112
+ await page.waitForChanges();
113
+ const labelEl = page.root.shadowRoot.querySelector("label");
114
+ expect(labelEl).toHaveClass("disabled");
115
+ });
116
+ it("renders max-files text, if set", async () => {
117
+ let html, page;
118
+ html = `<wm-uploader
119
+ id="uploader1"
120
+ button-text="Upload new document"
121
+ ></wm-uploader>`;
122
+ page = await newSpecPage({ components: [Uploader, File], html });
123
+ await page.waitForChanges();
124
+ let fileCountEl = page.root.shadowRoot.querySelector("#file-count");
125
+ expect(fileCountEl).toBeFalsy();
126
+ html = `<wm-uploader
127
+ id="uploader1"
128
+ max-files="3"
129
+ >
130
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
131
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
132
+ </wm-uploader>`;
133
+ page = await newSpecPage({ components: [Uploader, File], html });
134
+ await page.waitForChanges();
135
+ fileCountEl = page.root.shadowRoot.querySelector("#file-count");
136
+ expect(fileCountEl).toBeTruthy();
137
+ expect(fileCountEl.textContent).toBe("2 of 3 Files");
138
+ });
139
+ it("renders max-size text, if set", async () => {
140
+ let html, page;
141
+ html = `<wm-uploader
142
+ id="uploader1"
143
+ button-text="Upload new document"
144
+ ></wm-uploader>`;
145
+ page = await newSpecPage({ components: [Uploader, File], html });
146
+ await page.waitForChanges();
147
+ let maxSizeEl = page.root.shadowRoot.querySelector("#max-size");
148
+ expect(maxSizeEl).toBeFalsy();
149
+ html = `<wm-uploader
150
+ id="uploader1"
151
+ max-size="25 MB"
152
+ button-text="Upload new document"
153
+ ></wm-uploader>`;
154
+ page = await newSpecPage({ components: [Uploader, File], html });
155
+ await page.waitForChanges();
156
+ maxSizeEl = page.root.shadowRoot.querySelector("#max-size");
157
+ expect(maxSizeEl).toBeTruthy();
158
+ expect(maxSizeEl.textContent).toBe("Maximum file size 25 MB");
159
+ });
160
+ it("announces error when max-files has been reached and button clicked", async () => {
161
+ html = `<wm-uploader
162
+ id="uploader1"
163
+ max-files="2"
164
+ >
165
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
166
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
167
+ </wm-uploader>`;
168
+ page = await newSpecPage({ components: [Uploader, File], html });
169
+ await page.waitForChanges();
170
+ const input = page.root.shadowRoot.querySelector("input");
171
+ input.click();
172
+ await page.waitForChanges();
173
+ const liveRegion = page.root.shadowRoot.querySelector(".live-region").textContent;
174
+ expect(liveRegion).toBe("The maximum number of files has been reached");
175
+ });
176
+ it("singularizes the accepted file types message", async () => {
177
+ let message = page.root.shadowRoot.querySelector("#accepted-types").textContent;
178
+ expect(message).toBe("Accepted file types: .pdf, .txt, .log, .xml, .doc, .docx, .xls, .xlsx, .ppt, .pptx, .gif, .jpg, .jpeg, .png, .csv");
179
+ html = `<wm-uploader
180
+ id="uploader1"
181
+ file-types="jpeg"
182
+ button-text="Upload new document"
183
+ files='[{"id": "file1", "name": "File retrieved from server", "type": "pdf", "lastUpdated": "1/28/2020"},{"id": "file2", "name": "Second file", "type": "jpeg", "lastUpdated": "2/14/2019"}]'
184
+ ></wm-uploader>`;
185
+ page = await newSpecPage({ components: [Uploader, File], html });
186
+ await page.waitForChanges();
187
+ message = page.root.shadowRoot.querySelector("#accepted-types").textContent;
188
+ expect(message).toBe("Accepted file type: .jpeg");
189
+ });
190
+ it("provides wm-files with the proper show-info", async () => {
191
+ // defaults to time
192
+ let infoEl = await page.root.querySelector("wm-file").shadowRoot.querySelector(".file-info");
193
+ expect(infoEl.textContent).toBe("1/28/2020");
194
+ // size
195
+ html = `<wm-uploader
196
+ id="uploader1"
197
+ button-text="Upload new document"
198
+ show-info="size"
199
+ >
200
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
201
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
202
+ </wm-uploader>`;
203
+ page = await newSpecPage({ components: [Uploader, File], html });
204
+ await page.waitForChanges();
205
+ infoEl = await page.root.querySelector("wm-file").shadowRoot.querySelector(".file-info");
206
+ expect(infoEl.textContent).toBe("28 KB");
207
+ // time
208
+ html = `<wm-uploader
209
+ id="uploader1"
210
+ button-text="Upload new document"
211
+ show-info="time"
212
+ >
213
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
214
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
215
+ </wm-uploader>`;
216
+ page = await newSpecPage({ components: [Uploader, File], html });
217
+ await page.waitForChanges();
218
+ infoEl = await page.root.querySelector("wm-file").shadowRoot.querySelector(".file-info");
219
+ expect(infoEl.textContent).toBe("1/28/2020");
220
+ // none
221
+ html = `<wm-uploader
222
+ id="uploader1"
223
+ button-text="Upload new document"
224
+ show-info="none"
225
+ >
226
+ <wm-file id="file1" name="File retrieved from server" type="pdf" last-updated="1/28/2020" size="28 KB"></wm-file>
227
+ <wm-file id="file2" name="Second file" type="jpeg" last-updated="2/14/2019" size="3 MB""></wm-file>
228
+ </wm-uploader>`;
229
+ page = await newSpecPage({ components: [Uploader, File], html });
230
+ await page.waitForChanges();
231
+ infoEl = await page.root.querySelector("wm-file").shadowRoot.querySelector(".file-info");
232
+ expect(infoEl).toBe(null);
233
+ });
234
+ });
@@ -0,0 +1,126 @@
1
+ import { csvToArray, getAcceptedMimeTypesList, intl, snakeCaseToCamelCase, getNewIndexToFocus, transposeMatrix, wrapAround, skipByInterval, getSmallestSkipInterval, calcPercentageInRange, } from "./functions";
2
+ describe("Global functions", () => {
3
+ it("converts the list of extensions into a list of MIME types", () => {
4
+ expect(getAcceptedMimeTypesList(["pdf", "doc", "txt"])).toMatchObject([
5
+ "application/pdf",
6
+ "application/msword",
7
+ "text/plain",
8
+ ]);
9
+ });
10
+ it("translates", () => {
11
+ expect(intl.formatMessage({ id: "date.Monday", defaultMessage: "Monday" })).toEqual("Monday"); // falls back to English when language attribute is not set
12
+ });
13
+ it("changes string from snake_case to camelCase", async () => {
14
+ expect(snakeCaseToCamelCase("snake_case")).toBe("snakeCase");
15
+ expect(snakeCaseToCamelCase("even_more_words")).toBe("evenMoreWords");
16
+ expect(snakeCaseToCamelCase("camelCase")).toBe("camelCase");
17
+ expect(snakeCaseToCamelCase("A regular sentence")).toBe("A regular sentence");
18
+ expect(snakeCaseToCamelCase("singleword")).toBe("singleword");
19
+ });
20
+ it("parses comma separated values properly", async () => {
21
+ expect(csvToArray("one, two, three")).toStrictEqual(["one", "two", "three"]);
22
+ expect(csvToArray("four,five, six")).toStrictEqual(["four", "five", "six"]);
23
+ expect(csvToArray("seven eight,nine ten eleven")).toStrictEqual(["seven eight", "nine ten eleven"]);
24
+ });
25
+ it("gets new index to focus correctly", async () => {
26
+ let index = 1;
27
+ let direction = "ArrowDown";
28
+ let listLength = 5;
29
+ // moves forward
30
+ expect(getNewIndexToFocus(index, direction, listLength)).toBe(index + 1);
31
+ // wraps backwards
32
+ index = 4;
33
+ expect(getNewIndexToFocus(index, direction, listLength)).toBe(0);
34
+ // moves backwards
35
+ direction = "ArrowUp";
36
+ index = 2;
37
+ expect(getNewIndexToFocus(index, direction, listLength)).toBe(index - 1);
38
+ // wraps forward
39
+ index = 0;
40
+ expect(getNewIndexToFocus(index, direction, listLength)).toBe(listLength - 1);
41
+ });
42
+ it("transposes matrices correctly", () => {
43
+ expect(transposeMatrix([
44
+ [0, 1, 2],
45
+ [3, 4, 5],
46
+ [6, 7, 8],
47
+ ])).toStrictEqual([
48
+ [0, 3, 6],
49
+ [1, 4, 7],
50
+ [2, 5, 8],
51
+ ]);
52
+ expect(transposeMatrix([
53
+ [0, 1, 2, 3],
54
+ [4, 5, 6, 7],
55
+ [8, 9, 10, 11],
56
+ ])).toStrictEqual([
57
+ [0, 4, 8],
58
+ [1, 5, 9],
59
+ [2, 6, 10],
60
+ [3, 7, 11],
61
+ ]);
62
+ expect(transposeMatrix([
63
+ ["0", "1", "2"],
64
+ ["3", "4", "5"],
65
+ ["6", "7", "8"],
66
+ ])).toStrictEqual([
67
+ ["0", "3", "6"],
68
+ ["1", "4", "7"],
69
+ ["2", "5", "8"],
70
+ ]);
71
+ expect(transposeMatrix([
72
+ [0, "1", 2],
73
+ [3, 4, [5]],
74
+ [{ key: "value" }, 7, 8],
75
+ ])).toStrictEqual([
76
+ [0, 3, { key: "value" }],
77
+ ["1", 4, 7],
78
+ [2, [5], 8],
79
+ ]);
80
+ });
81
+ it("wraps around indices correctly", () => {
82
+ // forward steps
83
+ expect(wrapAround(0, 1, 8)).toBe(1);
84
+ expect(wrapAround(2, 3, 8)).toBe(5);
85
+ expect(wrapAround(7, 1, 8)).toBe(8);
86
+ // forward to 0
87
+ expect(wrapAround(8, 1, 8)).toBe(0);
88
+ expect(wrapAround(2, 7, 8)).toBe(0);
89
+ // forward beyond 0
90
+ expect(wrapAround(8, 4, 8)).toBe(3);
91
+ expect(wrapAround(2, 10, 8)).toBe(3);
92
+ // backward steps
93
+ expect(wrapAround(8, -1, 8)).toBe(7);
94
+ expect(wrapAround(5, -3, 8)).toBe(2);
95
+ expect(wrapAround(1, -1, 8)).toBe(0);
96
+ // backward to end
97
+ expect(wrapAround(0, -1, 8)).toBe(8);
98
+ expect(wrapAround(7, -8, 8)).toBe(8);
99
+ // backward beyond end
100
+ expect(wrapAround(0, -7, 8)).toBe(2);
101
+ expect(wrapAround(2, -7, 8)).toBe(4);
102
+ // multiple wraps
103
+ expect(wrapAround(0, 10, 2)).toBe(1);
104
+ expect(wrapAround(0, -10, 2)).toBe(2);
105
+ });
106
+ it("skips by interval correctly", () => {
107
+ const list = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
108
+ expect(skipByInterval(list, 0)).toStrictEqual([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);
109
+ expect(skipByInterval(list, 1)).toStrictEqual([0, 2, 4, 6, 8]);
110
+ expect(skipByInterval(list, 2)).toStrictEqual([0, 3, 6, 9]);
111
+ expect(skipByInterval(list, 3)).toStrictEqual([0, 4, 8]);
112
+ expect(skipByInterval(list, 4)).toStrictEqual([0, 5]);
113
+ expect(skipByInterval(list, 5)).toStrictEqual([0, 6]);
114
+ expect(skipByInterval(list, 20)).toStrictEqual([0]);
115
+ expect(getSmallestSkipInterval(list, 6)).toStrictEqual({ skipInterval: 1, skippedList: [0, 2, 4, 6, 8] });
116
+ expect(getSmallestSkipInterval(list, 5)).toStrictEqual({ skipInterval: 1, skippedList: [0, 2, 4, 6, 8] });
117
+ expect(getSmallestSkipInterval(list, 3)).toStrictEqual({ skipInterval: 3, skippedList: [0, 4, 8] });
118
+ expect(getSmallestSkipInterval(list, 1)).toStrictEqual({ skipInterval: 9, skippedList: [0] });
119
+ });
120
+ it("calcs percentage in range properly", () => {
121
+ expect(calcPercentageInRange(13, 0, 100)).toBe(13);
122
+ expect(calcPercentageInRange(-75, -100, 0)).toBe(25);
123
+ expect(calcPercentageInRange(50, 25, 75)).toBe(50);
124
+ expect(calcPercentageInRange(150, 100, 300)).toBe(25);
125
+ });
126
+ });
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ const en = require("./en.json");
3
+ const fr = require("./fr.json");
4
+ const es = require("./es.json");
5
+ const pig = require("./pig.json");
6
+ describe("translations", () => {
7
+ it("has translated strings for every key", () => {
8
+ let missingFR = [];
9
+ let missingES = [];
10
+ let missingPIG = [];
11
+ for (let i = 0; i < Object.keys(en).length; i++) {
12
+ !Object.keys(fr).includes(Object.keys(en)[i]) && missingFR.push(Object.keys(en)[i]);
13
+ !Object.keys(es).includes(Object.keys(en)[i]) && missingES.push(Object.keys(en)[i]);
14
+ !Object.keys(pig).includes(Object.keys(en)[i]) && missingPIG.push(Object.keys(en)[i]);
15
+ }
16
+ expect(missingFR.length).toBe(0);
17
+ expect(missingES.length).toBe(0);
18
+ expect(missingPIG.length).toBe(0);
19
+ });
20
+ });
@@ -1,5 +1,5 @@
1
- import { h } from './index-130e07bb.js';
2
- import { i as intl, c as checkForActiveElInShadow, e as safeMultiplyFloat, f as getPosition } from './functions-f39e6177.js';
1
+ import { h } from './index-558b5a82.js';
2
+ import { i as intl, c as checkForActiveElInShadow, e as safeMultiplyFloat, f as getPosition } from './functions-8800c690.js';
3
3
 
4
4
  const colors = {
5
5
  salmon: "#ff5f4e",
@@ -69,7 +69,7 @@ const allChartsDetails = {
69
69
  bar5: {
70
70
  size: 400,
71
71
  colors: [
72
- colors.gray, // this is only used if prop notStartedColor is set
72
+ colors.gray,
73
73
  colors.lavender,
74
74
  colors.midnight,
75
75
  "#0089e4",