@watermarkinsights/ripple 5.13.0-alpha.3 → 5.13.0-alpha.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 (470) hide show
  1. package/dist/components/wm-flyout.d.ts +11 -0
  2. package/dist/{components/index.js → ripple/app-globals-B7cOtGhY.js} +82 -3
  3. package/dist/{components/chartFunctions.js → ripple/chartFunctions-1XZcmyix.js} +3 -2
  4. package/dist/{components/functions.js → ripple/functions-DVLl0rH_.js} +7844 -146
  5. package/dist/ripple/index-CU5QNCKv.js +4167 -0
  6. package/dist/ripple/index.esm.js +1 -0
  7. package/dist/{collection/global/interfaces.js → ripple/interfaces-CrANcZM9.js} +6 -4
  8. package/dist/{esm/intl-DYVRT1s6.js → ripple/intl-7p27BJSM.js} +1 -1
  9. package/dist/ripple/priv-calendar.entry.js +566 -0
  10. package/dist/ripple/{p-3065bbe5.system.entry.js → priv-chart-popover.entry.js} +134 -1
  11. package/dist/ripple/priv-navigator-button.entry.js +24 -0
  12. package/dist/ripple/{p-568e29d3.entry.js → priv-navigator-item.entry.js} +30 -1
  13. package/dist/ripple/{p-42f9cd3d.entry.js → priv-option-list.entry.js} +385 -1
  14. package/dist/ripple/ripple.css +809 -1
  15. package/dist/ripple/ripple.esm.js +48 -1
  16. package/dist/ripple/wm-action-menu.entry.js +201 -0
  17. package/dist/{esm/wm-progress-monitor.entry.js → ripple/wm-button.entry.js} +175 -49
  18. package/dist/{esm → ripple}/wm-chart-slice.entry.js +1 -1
  19. package/dist/ripple/{p-74b1e110.entry.js → wm-chart.entry.js} +157 -1
  20. package/dist/ripple/wm-date-range.entry.js +477 -0
  21. package/dist/ripple/wm-datepicker.entry.js +247 -0
  22. package/dist/{esm/wm-navigation-item.entry.js → ripple/wm-file-list.entry.js} +7 -7
  23. package/dist/{esm/wm-navigation.entry.js → ripple/wm-file.entry.js} +157 -91
  24. package/dist/{components/wm-nested-select.js → ripple/wm-flyout.entry.js} +128 -312
  25. package/dist/{esm/wm-modal-header.entry.js → ripple/wm-input.entry.js} +99 -24
  26. package/dist/{cjs/wm-chart.cjs.entry.js → ripple/wm-line-chart.entry.js} +403 -113
  27. package/dist/{esm/wm-modal-pss-header.entry.js → ripple/wm-menuitem.entry.js} +114 -28
  28. package/dist/ripple/wm-modal-footer.entry.js +44 -0
  29. package/dist/{components/priv-navigator-button2.js → ripple/wm-modal-header.entry.js} +29 -35
  30. package/dist/ripple/wm-modal-pss-footer.entry.js +40 -0
  31. package/dist/ripple/wm-modal-pss-header.entry.js +39 -0
  32. package/dist/{cjs/priv-chart-popover.cjs.entry.js → ripple/wm-modal-pss.entry.js} +108 -109
  33. package/dist/{esm/wm-modal-footer.entry.js → ripple/wm-modal.entry.js} +117 -28
  34. package/dist/ripple/wm-navigation-hamburger.entry.js +48 -0
  35. package/dist/ripple/wm-navigation-item.entry.js +18 -0
  36. package/dist/{esm-es5/wm-modal-footer.entry.js → ripple/wm-navigation.entry.js} +116 -1
  37. package/dist/{esm/wm-chart.entry.js → ripple/wm-navigator.entry.js} +334 -123
  38. package/dist/ripple/wm-nested-select.entry.js +308 -0
  39. package/dist/{esm/wm-modal-pss-footer.entry.js → ripple/wm-optgroup.entry.js} +56 -28
  40. package/dist/{components/priv-option-list2.js → ripple/wm-option.entry.js} +134 -384
  41. package/dist/ripple/wm-pagination.entry.js +223 -0
  42. package/dist/ripple/{p-735d033a.entry.js → wm-progress-indicator.entry.js} +107 -1
  43. package/dist/ripple/wm-progress-monitor.entry.js +71 -0
  44. package/dist/{esm → ripple}/wm-progress-slice.entry.js +1 -1
  45. package/dist/{cjs/wm-nested-select.cjs.entry.js → ripple/wm-search.entry.js} +171 -273
  46. package/dist/{esm/wm-nested-select.entry.js → ripple/wm-select.entry.js} +134 -193
  47. package/dist/{components/priv-chart-popover2.js → ripple/wm-snackbar.entry.js} +155 -131
  48. package/dist/ripple/{p-b12640bd.entry.js → wm-tab-item.entry.js} +63 -1
  49. package/dist/{esm-es5/wm-file-list.entry.js → ripple/wm-tab-list.entry.js} +175 -1
  50. package/dist/{cjs/wm-navigation-item.cjs.entry.js → ripple/wm-tab-panel.entry.js} +24 -12
  51. package/dist/ripple/wm-tag-input.entry.js +877 -0
  52. package/dist/{esm → ripple}/wm-tag-option.entry.js +2 -2
  53. package/dist/{esm/priv-chart-popover.entry.js → ripple/wm-textarea.entry.js} +53 -108
  54. package/dist/ripple/wm-timepicker.entry.js +300 -0
  55. package/dist/{components/priv-navigator-item2.js → ripple/wm-toggletip.entry.js} +171 -44
  56. package/dist/ripple/{p-5b02ae40.entry.js → wm-uploader.entry.js} +313 -1
  57. package/dist/{esm → ripple}/wm-wrapper.entry.js +1 -1
  58. package/dist/types/components/wm-flyout/wm-flyout.d.ts +46 -0
  59. package/dist/types/components.d.ts +56 -0
  60. package/dist/types/global/functions.d.ts +1 -0
  61. package/package.json +30 -6
  62. package/dist/cjs/app-globals-DztnjEf7.js +0 -92
  63. package/dist/cjs/chartFunctions-CM2Nah_s.js +0 -731
  64. package/dist/cjs/functions-CoXfjC6r.js +0 -10450
  65. package/dist/cjs/index-Cig4P4gJ.js +0 -2082
  66. package/dist/cjs/index.cjs.js +0 -2
  67. package/dist/cjs/interfaces-C7YbtGnk.js +0 -37
  68. package/dist/cjs/intl-DVt1J717.js +0 -283
  69. package/dist/cjs/loader.cjs.js +0 -13
  70. package/dist/cjs/priv-calendar.cjs.entry.js +0 -568
  71. package/dist/cjs/priv-navigator-button_2.cjs.entry.js +0 -54
  72. package/dist/cjs/priv-option-list_2.cjs.entry.js +0 -556
  73. package/dist/cjs/ripple.cjs.js +0 -25
  74. package/dist/cjs/wm-action-menu_4.cjs.entry.js +0 -702
  75. package/dist/cjs/wm-chart-slice.cjs.entry.js +0 -20
  76. package/dist/cjs/wm-date-range.cjs.entry.js +0 -479
  77. package/dist/cjs/wm-datepicker.cjs.entry.js +0 -249
  78. package/dist/cjs/wm-file-list.cjs.entry.js +0 -20
  79. package/dist/cjs/wm-file.cjs.entry.js +0 -184
  80. package/dist/cjs/wm-input.cjs.entry.js +0 -113
  81. package/dist/cjs/wm-line-chart.cjs.entry.js +0 -451
  82. package/dist/cjs/wm-modal-footer.cjs.entry.js +0 -46
  83. package/dist/cjs/wm-modal-header.cjs.entry.js +0 -38
  84. package/dist/cjs/wm-modal-pss-footer.cjs.entry.js +0 -42
  85. package/dist/cjs/wm-modal-pss-header.cjs.entry.js +0 -41
  86. package/dist/cjs/wm-modal-pss.cjs.entry.js +0 -137
  87. package/dist/cjs/wm-modal.cjs.entry.js +0 -135
  88. package/dist/cjs/wm-navigation-hamburger.cjs.entry.js +0 -50
  89. package/dist/cjs/wm-navigation.cjs.entry.js +0 -118
  90. package/dist/cjs/wm-navigator.cjs.entry.js +0 -329
  91. package/dist/cjs/wm-optgroup.cjs.entry.js +0 -70
  92. package/dist/cjs/wm-pagination.cjs.entry.js +0 -225
  93. package/dist/cjs/wm-progress-indicator.cjs.entry.js +0 -109
  94. package/dist/cjs/wm-progress-monitor.cjs.entry.js +0 -73
  95. package/dist/cjs/wm-progress-slice.cjs.entry.js +0 -15
  96. package/dist/cjs/wm-search.cjs.entry.js +0 -210
  97. package/dist/cjs/wm-select.cjs.entry.js +0 -251
  98. package/dist/cjs/wm-tab-item.cjs.entry.js +0 -65
  99. package/dist/cjs/wm-tab-list.cjs.entry.js +0 -177
  100. package/dist/cjs/wm-tab-panel.cjs.entry.js +0 -34
  101. package/dist/cjs/wm-tag-input.cjs.entry.js +0 -879
  102. package/dist/cjs/wm-tag-option.cjs.entry.js +0 -37
  103. package/dist/cjs/wm-textarea.cjs.entry.js +0 -81
  104. package/dist/cjs/wm-timepicker.cjs.entry.js +0 -302
  105. package/dist/cjs/wm-toggletip.cjs.entry.js +0 -178
  106. package/dist/cjs/wm-uploader.cjs.entry.js +0 -315
  107. package/dist/cjs/wm-wrapper.cjs.entry.js +0 -19
  108. package/dist/collection/collection-manifest.json +0 -58
  109. package/dist/collection/components/charts/chartFunctions.js +0 -665
  110. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.css +0 -908
  111. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +0 -261
  112. package/dist/collection/components/charts/wm-chart/wm-chart-slice.js +0 -128
  113. package/dist/collection/components/charts/wm-chart/wm-chart.css +0 -1274
  114. package/dist/collection/components/charts/wm-chart/wm-chart.js +0 -445
  115. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.css +0 -1067
  116. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +0 -742
  117. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.css +0 -1274
  118. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +0 -271
  119. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.css +0 -909
  120. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +0 -154
  121. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-slice.js +0 -124
  122. package/dist/collection/components/datepickers/datepicker.css +0 -1044
  123. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.css +0 -1279
  124. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +0 -849
  125. package/dist/collection/components/datepickers/wm-date-range.js +0 -869
  126. package/dist/collection/components/datepickers/wm-datepicker.js +0 -538
  127. package/dist/collection/components/selects/priv-option-list/priv-option-list.css +0 -918
  128. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +0 -791
  129. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.css +0 -1181
  130. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +0 -644
  131. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.css +0 -830
  132. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +0 -265
  133. package/dist/collection/components/selects/wm-option/wm-option.css +0 -931
  134. package/dist/collection/components/selects/wm-option/wm-option.js +0 -539
  135. package/dist/collection/components/selects/wm-select/wm-select.css +0 -1104
  136. package/dist/collection/components/selects/wm-select/wm-select.js +0 -606
  137. package/dist/collection/components/wm-action-menu/wm-action-menu.css +0 -891
  138. package/dist/collection/components/wm-action-menu/wm-action-menu.js +0 -444
  139. package/dist/collection/components/wm-button/wm-button.css +0 -1261
  140. package/dist/collection/components/wm-button/wm-button.js +0 -510
  141. package/dist/collection/components/wm-file/wm-file.css +0 -927
  142. package/dist/collection/components/wm-file/wm-file.js +0 -423
  143. package/dist/collection/components/wm-file-list/wm-file-list.css +0 -820
  144. package/dist/collection/components/wm-file-list/wm-file-list.js +0 -47
  145. package/dist/collection/components/wm-input/wm-input.css +0 -993
  146. package/dist/collection/components/wm-input/wm-input.js +0 -498
  147. package/dist/collection/components/wm-menuitem/wm-menuitem.css +0 -891
  148. package/dist/collection/components/wm-menuitem/wm-menuitem.js +0 -425
  149. package/dist/collection/components/wm-modal/wm-modal-footer.css +0 -845
  150. package/dist/collection/components/wm-modal/wm-modal-footer.js +0 -152
  151. package/dist/collection/components/wm-modal/wm-modal-header.css +0 -844
  152. package/dist/collection/components/wm-modal/wm-modal-header.js +0 -83
  153. package/dist/collection/components/wm-modal/wm-modal.css +0 -892
  154. package/dist/collection/components/wm-modal/wm-modal.js +0 -356
  155. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.css +0 -852
  156. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +0 -148
  157. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.css +0 -846
  158. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +0 -86
  159. package/dist/collection/components/wm-modal-pss/wm-modal-pss.css +0 -928
  160. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +0 -369
  161. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.css +0 -847
  162. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +0 -120
  163. package/dist/collection/components/wm-navigation/wm-navigation-item.css +0 -856
  164. package/dist/collection/components/wm-navigation/wm-navigation-item.js +0 -99
  165. package/dist/collection/components/wm-navigation/wm-navigation.css +0 -898
  166. package/dist/collection/components/wm-navigation/wm-navigation.js +0 -192
  167. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +0 -850
  168. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +0 -90
  169. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +0 -830
  170. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +0 -130
  171. package/dist/collection/components/wm-navigator/wm-navigator.css +0 -903
  172. package/dist/collection/components/wm-navigator/wm-navigator.js +0 -515
  173. package/dist/collection/components/wm-pagination/wm-pagination.css +0 -971
  174. package/dist/collection/components/wm-pagination/wm-pagination.js +0 -373
  175. package/dist/collection/components/wm-search/wm-search.css +0 -896
  176. package/dist/collection/components/wm-search/wm-search.js +0 -462
  177. package/dist/collection/components/wm-snackbar/wm-snackbar.css +0 -1078
  178. package/dist/collection/components/wm-snackbar/wm-snackbar.js +0 -280
  179. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +0 -869
  180. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +0 -187
  181. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +0 -841
  182. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +0 -276
  183. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +0 -825
  184. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +0 -97
  185. package/dist/collection/components/wm-tag-input/wm-tag-input.css +0 -1276
  186. package/dist/collection/components/wm-tag-input/wm-tag-input.js +0 -1245
  187. package/dist/collection/components/wm-tag-input/wm-tag-option/wm-tag-option.js +0 -251
  188. package/dist/collection/components/wm-textarea/wm-textarea.css +0 -980
  189. package/dist/collection/components/wm-textarea/wm-textarea.js +0 -331
  190. package/dist/collection/components/wm-timepicker/wm-timepicker.css +0 -1094
  191. package/dist/collection/components/wm-timepicker/wm-timepicker.js +0 -559
  192. package/dist/collection/components/wm-toggletip/wm-toggletip.css +0 -1152
  193. package/dist/collection/components/wm-toggletip/wm-toggletip.js +0 -295
  194. package/dist/collection/components/wm-uploader/wm-uploader.css +0 -1563
  195. package/dist/collection/components/wm-uploader/wm-uploader.js +0 -618
  196. package/dist/collection/components/wm-wrapper/wm-wrapper.js +0 -28
  197. package/dist/collection/dev/action-menu.js +0 -0
  198. package/dist/collection/dev/button.js +0 -0
  199. package/dist/collection/dev/chart-small.js +0 -56
  200. package/dist/collection/dev/chart.js +0 -18
  201. package/dist/collection/dev/date-range.js +0 -6
  202. package/dist/collection/dev/datepicker.js +0 -46
  203. package/dist/collection/dev/file-list.js +0 -16
  204. package/dist/collection/dev/file.js +0 -0
  205. package/dist/collection/dev/input.js +0 -6
  206. package/dist/collection/dev/line-chart.js +0 -0
  207. package/dist/collection/dev/modal.js +0 -48
  208. package/dist/collection/dev/navigation.js +0 -13
  209. package/dist/collection/dev/navigator.js +0 -34
  210. package/dist/collection/dev/nested-select.js +0 -36
  211. package/dist/collection/dev/pagination.js +0 -7
  212. package/dist/collection/dev/progress-monitor.js +0 -0
  213. package/dist/collection/dev/pss-modal.js +0 -8
  214. package/dist/collection/dev/scripts.js +0 -49
  215. package/dist/collection/dev/search.js +0 -72
  216. package/dist/collection/dev/select.js +0 -57
  217. package/dist/collection/dev/snackbar.js +0 -60
  218. package/dist/collection/dev/tabs.js +0 -44
  219. package/dist/collection/dev/tag-input.js +0 -32
  220. package/dist/collection/dev/textarea.js +0 -28
  221. package/dist/collection/dev/timepicker.js +0 -32
  222. package/dist/collection/dev/toggletip.js +0 -9
  223. package/dist/collection/dev/uploader.js +0 -139
  224. package/dist/collection/global/__mocks__/functions.js +0 -6
  225. package/dist/collection/global/functions.js +0 -825
  226. package/dist/collection/global/global.js +0 -88
  227. package/dist/collection/global/intl.js +0 -274
  228. package/dist/collection/global/services/__mocks__/http-service.js +0 -130
  229. package/dist/collection/global/services/http-service.js +0 -50
  230. package/dist/collection/lang/lang.js +0 -5
  231. package/dist/collection/lang/missing.js +0 -43
  232. package/dist/collection/lang/piglatin.js +0 -101
  233. package/dist/components/interfaces.js +0 -34
  234. package/dist/components/intl.js +0 -277
  235. package/dist/components/priv-calendar.js +0 -6
  236. package/dist/components/priv-calendar2.js +0 -592
  237. package/dist/components/priv-chart-popover.js +0 -6
  238. package/dist/components/priv-navigator-button.js +0 -6
  239. package/dist/components/priv-navigator-item.js +0 -6
  240. package/dist/components/priv-option-list.js +0 -6
  241. package/dist/components/wm-action-menu.js +0 -6
  242. package/dist/components/wm-action-menu2.js +0 -231
  243. package/dist/components/wm-button.js +0 -6
  244. package/dist/components/wm-button2.js +0 -231
  245. package/dist/components/wm-chart-slice.js +0 -41
  246. package/dist/components/wm-chart.js +0 -197
  247. package/dist/components/wm-date-range.js +0 -522
  248. package/dist/components/wm-datepicker.js +0 -287
  249. package/dist/components/wm-file-list.js +0 -38
  250. package/dist/components/wm-file.js +0 -228
  251. package/dist/components/wm-input.js +0 -152
  252. package/dist/components/wm-line-chart.js +0 -497
  253. package/dist/components/wm-menuitem.js +0 -6
  254. package/dist/components/wm-menuitem2.js +0 -146
  255. package/dist/components/wm-modal-footer.js +0 -73
  256. package/dist/components/wm-modal-header.js +0 -61
  257. package/dist/components/wm-modal-pss-footer.js +0 -69
  258. package/dist/components/wm-modal-pss-header.js +0 -64
  259. package/dist/components/wm-modal-pss.js +0 -162
  260. package/dist/components/wm-modal.js +0 -161
  261. package/dist/components/wm-navigation-hamburger.js +0 -70
  262. package/dist/components/wm-navigation-item.js +0 -40
  263. package/dist/components/wm-navigation.js +0 -144
  264. package/dist/components/wm-navigator.js +0 -369
  265. package/dist/components/wm-optgroup.js +0 -107
  266. package/dist/components/wm-option.js +0 -6
  267. package/dist/components/wm-option2.js +0 -196
  268. package/dist/components/wm-pagination.js +0 -251
  269. package/dist/components/wm-progress-indicator.js +0 -144
  270. package/dist/components/wm-progress-monitor.js +0 -93
  271. package/dist/components/wm-progress-slice.js +0 -37
  272. package/dist/components/wm-search.js +0 -250
  273. package/dist/components/wm-select.js +0 -6
  274. package/dist/components/wm-select2.js +0 -294
  275. package/dist/components/wm-snackbar.js +0 -210
  276. package/dist/components/wm-tab-item.js +0 -85
  277. package/dist/components/wm-tab-list.js +0 -217
  278. package/dist/components/wm-tab-panel.js +0 -52
  279. package/dist/components/wm-tag-input.js +0 -919
  280. package/dist/components/wm-tag-option.js +0 -63
  281. package/dist/components/wm-textarea.js +0 -113
  282. package/dist/components/wm-timepicker.js +0 -333
  283. package/dist/components/wm-toggletip.js +0 -200
  284. package/dist/components/wm-uploader.js +0 -348
  285. package/dist/components/wm-wrapper.js +0 -34
  286. package/dist/esm/app-globals-9HoPoE5v.js +0 -90
  287. package/dist/esm/chartFunctions-BFCUD5JX.js +0 -714
  288. package/dist/esm/functions-ZDMCMR3o.js +0 -10410
  289. package/dist/esm/index-EopL5zo4.js +0 -2071
  290. package/dist/esm/index.js +0 -1
  291. package/dist/esm/interfaces-CyJHzEjr.js +0 -34
  292. package/dist/esm/loader.js +0 -11
  293. package/dist/esm/polyfills/core-js.js +0 -11
  294. package/dist/esm/polyfills/dom.js +0 -79
  295. package/dist/esm/polyfills/es5-html-element.js +0 -1
  296. package/dist/esm/polyfills/index.js +0 -34
  297. package/dist/esm/polyfills/system.js +0 -6
  298. package/dist/esm/priv-calendar.entry.js +0 -566
  299. package/dist/esm/priv-navigator-button_2.entry.js +0 -51
  300. package/dist/esm/priv-option-list_2.entry.js +0 -553
  301. package/dist/esm/ripple.js +0 -21
  302. package/dist/esm/wm-action-menu_4.entry.js +0 -697
  303. package/dist/esm/wm-date-range.entry.js +0 -477
  304. package/dist/esm/wm-datepicker.entry.js +0 -247
  305. package/dist/esm/wm-file-list.entry.js +0 -18
  306. package/dist/esm/wm-file.entry.js +0 -182
  307. package/dist/esm/wm-input.entry.js +0 -111
  308. package/dist/esm/wm-line-chart.entry.js +0 -449
  309. package/dist/esm/wm-modal-pss.entry.js +0 -135
  310. package/dist/esm/wm-modal.entry.js +0 -133
  311. package/dist/esm/wm-navigation-hamburger.entry.js +0 -48
  312. package/dist/esm/wm-navigator.entry.js +0 -327
  313. package/dist/esm/wm-optgroup.entry.js +0 -68
  314. package/dist/esm/wm-pagination.entry.js +0 -223
  315. package/dist/esm/wm-progress-indicator.entry.js +0 -107
  316. package/dist/esm/wm-search.entry.js +0 -208
  317. package/dist/esm/wm-select.entry.js +0 -249
  318. package/dist/esm/wm-tab-item.entry.js +0 -63
  319. package/dist/esm/wm-tab-list.entry.js +0 -175
  320. package/dist/esm/wm-tab-panel.entry.js +0 -32
  321. package/dist/esm/wm-tag-input.entry.js +0 -877
  322. package/dist/esm/wm-textarea.entry.js +0 -79
  323. package/dist/esm/wm-timepicker.entry.js +0 -300
  324. package/dist/esm/wm-toggletip.entry.js +0 -176
  325. package/dist/esm/wm-uploader.entry.js +0 -313
  326. package/dist/esm-es5/app-globals-9HoPoE5v.js +0 -1
  327. package/dist/esm-es5/chartFunctions-BFCUD5JX.js +0 -1
  328. package/dist/esm-es5/functions-ZDMCMR3o.js +0 -1
  329. package/dist/esm-es5/index-EopL5zo4.js +0 -1
  330. package/dist/esm-es5/index.js +0 -0
  331. package/dist/esm-es5/interfaces-CyJHzEjr.js +0 -1
  332. package/dist/esm-es5/intl-DYVRT1s6.js +0 -1
  333. package/dist/esm-es5/loader.js +0 -1
  334. package/dist/esm-es5/priv-calendar.entry.js +0 -1
  335. package/dist/esm-es5/priv-chart-popover.entry.js +0 -1
  336. package/dist/esm-es5/priv-navigator-button_2.entry.js +0 -1
  337. package/dist/esm-es5/priv-option-list_2.entry.js +0 -1
  338. package/dist/esm-es5/ripple.js +0 -1
  339. package/dist/esm-es5/wm-action-menu_4.entry.js +0 -1
  340. package/dist/esm-es5/wm-chart-slice.entry.js +0 -1
  341. package/dist/esm-es5/wm-chart.entry.js +0 -1
  342. package/dist/esm-es5/wm-date-range.entry.js +0 -1
  343. package/dist/esm-es5/wm-datepicker.entry.js +0 -1
  344. package/dist/esm-es5/wm-file.entry.js +0 -1
  345. package/dist/esm-es5/wm-input.entry.js +0 -1
  346. package/dist/esm-es5/wm-line-chart.entry.js +0 -1
  347. package/dist/esm-es5/wm-modal-header.entry.js +0 -1
  348. package/dist/esm-es5/wm-modal-pss-footer.entry.js +0 -1
  349. package/dist/esm-es5/wm-modal-pss-header.entry.js +0 -1
  350. package/dist/esm-es5/wm-modal-pss.entry.js +0 -1
  351. package/dist/esm-es5/wm-modal.entry.js +0 -1
  352. package/dist/esm-es5/wm-navigation-hamburger.entry.js +0 -1
  353. package/dist/esm-es5/wm-navigation-item.entry.js +0 -1
  354. package/dist/esm-es5/wm-navigation.entry.js +0 -1
  355. package/dist/esm-es5/wm-navigator.entry.js +0 -1
  356. package/dist/esm-es5/wm-nested-select.entry.js +0 -1
  357. package/dist/esm-es5/wm-optgroup.entry.js +0 -1
  358. package/dist/esm-es5/wm-pagination.entry.js +0 -1
  359. package/dist/esm-es5/wm-progress-indicator.entry.js +0 -1
  360. package/dist/esm-es5/wm-progress-monitor.entry.js +0 -1
  361. package/dist/esm-es5/wm-progress-slice.entry.js +0 -1
  362. package/dist/esm-es5/wm-search.entry.js +0 -1
  363. package/dist/esm-es5/wm-select.entry.js +0 -1
  364. package/dist/esm-es5/wm-tab-item.entry.js +0 -1
  365. package/dist/esm-es5/wm-tab-list.entry.js +0 -1
  366. package/dist/esm-es5/wm-tab-panel.entry.js +0 -1
  367. package/dist/esm-es5/wm-tag-input.entry.js +0 -1
  368. package/dist/esm-es5/wm-tag-option.entry.js +0 -1
  369. package/dist/esm-es5/wm-textarea.entry.js +0 -1
  370. package/dist/esm-es5/wm-timepicker.entry.js +0 -1
  371. package/dist/esm-es5/wm-toggletip.entry.js +0 -1
  372. package/dist/esm-es5/wm-uploader.entry.js +0 -1
  373. package/dist/esm-es5/wm-wrapper.entry.js +0 -1
  374. package/dist/index.cjs.js +0 -1
  375. package/dist/index.js +0 -1
  376. package/dist/loader/cdn.js +0 -2
  377. package/dist/loader/index.cjs.js +0 -2
  378. package/dist/loader/index.d.ts +0 -24
  379. package/dist/loader/index.es2017.js +0 -2
  380. package/dist/loader/index.js +0 -3
  381. package/dist/ripple/p-032f127e.entry.js +0 -1
  382. package/dist/ripple/p-0bd43518.system.entry.js +0 -1
  383. package/dist/ripple/p-0dccd9b4.system.entry.js +0 -1
  384. package/dist/ripple/p-0dffa9ff.system.entry.js +0 -1
  385. package/dist/ripple/p-10d2b86e.entry.js +0 -1
  386. package/dist/ripple/p-1818d7f9.entry.js +0 -1
  387. package/dist/ripple/p-18d22114.system.entry.js +0 -1
  388. package/dist/ripple/p-1a769629.system.entry.js +0 -1
  389. package/dist/ripple/p-271ba485.system.entry.js +0 -1
  390. package/dist/ripple/p-2d41fbed.system.entry.js +0 -1
  391. package/dist/ripple/p-2f26b6ac.entry.js +0 -1
  392. package/dist/ripple/p-306caa10.entry.js +0 -1
  393. package/dist/ripple/p-32f2f3b4.system.entry.js +0 -1
  394. package/dist/ripple/p-340b73a9.system.entry.js +0 -1
  395. package/dist/ripple/p-47b525bd.entry.js +0 -1
  396. package/dist/ripple/p-492a8a9f.entry.js +0 -1
  397. package/dist/ripple/p-4c316652.system.entry.js +0 -1
  398. package/dist/ripple/p-54aeadde.entry.js +0 -1
  399. package/dist/ripple/p-588a86ed.system.entry.js +0 -1
  400. package/dist/ripple/p-591fd100.entry.js +0 -1
  401. package/dist/ripple/p-5a6cbc14.system.entry.js +0 -1
  402. package/dist/ripple/p-5abe1171.system.entry.js +0 -1
  403. package/dist/ripple/p-5ae17300.system.entry.js +0 -1
  404. package/dist/ripple/p-5e438798.system.entry.js +0 -1
  405. package/dist/ripple/p-5ed4177e.entry.js +0 -1
  406. package/dist/ripple/p-6133160d.system.entry.js +0 -1
  407. package/dist/ripple/p-620aff89.entry.js +0 -1
  408. package/dist/ripple/p-65db2c0f.entry.js +0 -1
  409. package/dist/ripple/p-70ed57bf.entry.js +0 -1
  410. package/dist/ripple/p-77a8306c.entry.js +0 -1
  411. package/dist/ripple/p-7886fe5e.system.entry.js +0 -1
  412. package/dist/ripple/p-7ce09692.system.entry.js +0 -1
  413. package/dist/ripple/p-7cf1d9eb.system.entry.js +0 -1
  414. package/dist/ripple/p-7e786c28.system.entry.js +0 -1
  415. package/dist/ripple/p-812615ae.entry.js +0 -1
  416. package/dist/ripple/p-8a33538f.entry.js +0 -1
  417. package/dist/ripple/p-8b9c4e3e.entry.js +0 -1
  418. package/dist/ripple/p-90925ea9.entry.js +0 -1
  419. package/dist/ripple/p-959afdcf.entry.js +0 -1
  420. package/dist/ripple/p-997bdd2e.system.entry.js +0 -1
  421. package/dist/ripple/p-9db5f78e.entry.js +0 -1
  422. package/dist/ripple/p-BexWEx3U.system.js +0 -1
  423. package/dist/ripple/p-BgmAsS86.system.js +0 -1
  424. package/dist/ripple/p-Buh1DT2-.js +0 -1
  425. package/dist/ripple/p-CLZytLAw.system.js +0 -1
  426. package/dist/ripple/p-CTau6pR2.system.js +0 -2
  427. package/dist/ripple/p-CwkTkxrj.system.js +0 -1
  428. package/dist/ripple/p-CyJHzEjr.js +0 -1
  429. package/dist/ripple/p-DXsimRMV.js +0 -1
  430. package/dist/ripple/p-EopL5zo4.js +0 -2
  431. package/dist/ripple/p-GXdCI-yj.system.js +0 -1
  432. package/dist/ripple/p-UJrCrAlw.system.js +0 -1
  433. package/dist/ripple/p-YWpyar7R.system.js +0 -1
  434. package/dist/ripple/p-ZDMCMR3o.js +0 -1
  435. package/dist/ripple/p-b0b94ac4.system.entry.js +0 -1
  436. package/dist/ripple/p-b16431b0.system.entry.js +0 -1
  437. package/dist/ripple/p-b43cc69f.entry.js +0 -1
  438. package/dist/ripple/p-b4917824.entry.js +0 -1
  439. package/dist/ripple/p-b55babe1.system.entry.js +0 -1
  440. package/dist/ripple/p-ba48d47a.entry.js +0 -1
  441. package/dist/ripple/p-ba8ca46b.system.entry.js +0 -1
  442. package/dist/ripple/p-bee35fef.entry.js +0 -1
  443. package/dist/ripple/p-c273bb1c.system.entry.js +0 -1
  444. package/dist/ripple/p-cdebe76b.system.entry.js +0 -1
  445. package/dist/ripple/p-ce9634a2.entry.js +0 -1
  446. package/dist/ripple/p-d20ed498.entry.js +0 -1
  447. package/dist/ripple/p-d3e6498c.system.entry.js +0 -1
  448. package/dist/ripple/p-d40b6ef1.system.entry.js +0 -1
  449. package/dist/ripple/p-d4481342.system.entry.js +0 -1
  450. package/dist/ripple/p-d5bcab58.entry.js +0 -1
  451. package/dist/ripple/p-d7660e7d.entry.js +0 -1
  452. package/dist/ripple/p-d85f017a.system.entry.js +0 -1
  453. package/dist/ripple/p-da5ad94c.system.entry.js +0 -1
  454. package/dist/ripple/p-dcca5771.system.entry.js +0 -1
  455. package/dist/ripple/p-dd236f42.system.entry.js +0 -1
  456. package/dist/ripple/p-de33fd67.entry.js +0 -1
  457. package/dist/ripple/p-e0c9798d.system.entry.js +0 -1
  458. package/dist/ripple/p-e3700f4c.entry.js +0 -1
  459. package/dist/ripple/p-e901154b.entry.js +0 -1
  460. package/dist/ripple/p-e9fc862d.entry.js +0 -1
  461. package/dist/ripple/p-ea885cf3.system.entry.js +0 -1
  462. package/dist/ripple/p-f4c4218c.system.entry.js +0 -1
  463. package/dist/ripple/p-f57eb234.system.entry.js +0 -1
  464. package/dist/ripple/p-f858f5f9.system.entry.js +0 -1
  465. package/dist/ripple/p-f8721463.system.entry.js +0 -1
  466. package/dist/ripple/p-f881be15.entry.js +0 -1
  467. package/dist/ripple/p-f98949ad.entry.js +0 -1
  468. package/dist/ripple/p-fdcbcdf5.entry.js +0 -1
  469. package/dist/ripple/p-sXfORL9J.js +0 -1
  470. package/dist/ripple/ripple.js +0 -127
@@ -1,665 +0,0 @@
1
- import { h } from "@stencil/core";
2
- import { checkForActiveElInShadow, getPosition, intl, safeMultiplyFloat } from "../../global/functions";
3
- const colors = {
4
- salmon: "#ff5f4e",
5
- cyan: "#19a1a9",
6
- forest: "#088000",
7
- sleet: "#7f97ad",
8
- midnight: "#2e1b46",
9
- lavender: "#8b86ca",
10
- periwinkle: "#575195",
11
- gray: "#6b6b6b",
12
- };
13
- export const allChartsDetails = {
14
- // for progress monitor
15
- doughnut: {
16
- size: 155,
17
- colors: [colors.forest, colors.gray],
18
- thickness: 0.73,
19
- padding: 25,
20
- category: "doughnut",
21
- },
22
- doughnut1: {
23
- size: 130,
24
- colors: [colors.lavender, colors.midnight, colors.gray],
25
- thickness: 0.5,
26
- padding: 90,
27
- category: "doughnut",
28
- },
29
- doughnut2: {
30
- size: 130,
31
- colors: [colors.periwinkle, colors.cyan, colors.midnight, colors.salmon, colors.gray],
32
- thickness: 0.5,
33
- padding: 90,
34
- category: "doughnut",
35
- },
36
- doughnut3: {
37
- size: 130,
38
- colors: [colors.lavender, colors.midnight, "#0089e4", colors.forest, "#ea8500", "#d54f41", "#146ca9"],
39
- thickness: 0.5,
40
- padding: 90,
41
- category: "doughnut",
42
- },
43
- // for progress monitor
44
- bar: {
45
- size: 350,
46
- colors: [colors.forest, colors.gray],
47
- padding: 0,
48
- category: "stackedBar",
49
- },
50
- bar2: {
51
- size: 400,
52
- colors: [colors.gray, colors.lavender, colors.periwinkle, colors.midnight, colors.cyan, colors.salmon],
53
- padding: 0,
54
- category: "stackedBar",
55
- },
56
- bar3: {
57
- size: 300,
58
- colors: ["#0d696e", colors.cyan, "#8e4129", colors.salmon],
59
- padding: 0,
60
- category: "stackedBar",
61
- },
62
- bar4: {
63
- size: 400,
64
- colors: [colors.salmon, colors.cyan, colors.periwinkle],
65
- padding: 0,
66
- category: "stackedBar",
67
- },
68
- bar5: {
69
- size: 400,
70
- colors: [
71
- colors.gray, // this is only used if prop notStartedColor is set
72
- colors.lavender,
73
- colors.midnight,
74
- "#0089e4",
75
- colors.forest,
76
- "#ea8500",
77
- "#d54f41",
78
- "#146ca9",
79
- ],
80
- padding: 0,
81
- category: "stackedBar",
82
- },
83
- bar6: {
84
- size: 400,
85
- colors: [colors.lavender],
86
- padding: 0,
87
- category: "simpleBar",
88
- },
89
- bar7: {
90
- size: 400,
91
- colors: [colors.periwinkle, colors.cyan, colors.salmon, colors.gray],
92
- padding: 0,
93
- category: "simpleBar",
94
- },
95
- };
96
- function showValue(valueFormat) {
97
- return valueFormat === "percentage" || valueFormat === "amount" ? "show-values" : "";
98
- }
99
- export const textHiddenMessage = intl.formatMessage({
100
- id: "chart.hiddenValues",
101
- defaultMessage: "Values are hidden when too close together.",
102
- description: "Text displayed when a chart has some values hidden",
103
- });
104
- export const seeDetailsMessage = intl.formatMessage({
105
- id: "chart.clickToSeeDetails",
106
- defaultMessage: "Click or use arrow keys to see details.",
107
- description: "Text displayed, guiding user to interact to see more details.",
108
- });
109
- export function abbrNumber(num) {
110
- return num > 999 || num < -999 ? Math.round(num / 100) / 10 + "K" : num;
111
- }
112
- export function amountToPercent(val, total, asInt) {
113
- return asInt ? Math.round((val * 100) / total) : Math.round((val * 10000) / total) / 100; // with 2 decimals
114
- }
115
- export function amountToDegree(val, total) {
116
- // In a circle of {total}, determine degrees of slice {val}
117
- return (val * 360) / total;
118
- }
119
- export function toFixed(number) {
120
- return parseFloat((Math.floor(number * 100) / 100).toFixed(2));
121
- }
122
- export function polarToCartesian(half, radius, startAngle, endAngle) {
123
- var x = toFixed(half + half * radius * Math.cos((Math.PI * startAngle) / 180));
124
- var y = toFixed(half + half * radius * Math.sin((Math.PI * startAngle) / 180));
125
- if (endAngle !== undefined) {
126
- // if a 2nd angle value was passed, return 2 pairs of coords
127
- var x2 = toFixed(half + half * radius * Math.cos((Math.PI * endAngle) / 180));
128
- var y2 = toFixed(half + half * radius * Math.sin((Math.PI * endAngle) / 180));
129
- return { x1: x, y1: y, x2, y2 };
130
- }
131
- return { x, y };
132
- }
133
- function getArc(radius, largeArcFlag, x, y, chartSize) {
134
- var z = toFixed((chartSize / 2) * radius);
135
- return `A ${z}, ${z} 0 ${largeArcFlag} ${toFixed(x)}, ${toFixed(y)}`;
136
- }
137
- function scale(val, inMin, inMax, outMin, outMax) {
138
- let scaled = ((val - inMin) * (outMax - outMin)) / (inMax - inMin) + outMin;
139
- // clip the values so that whatever is passed in the output is never smaller than outMin or greater than outMax
140
- return scaled < outMin ? outMin : scaled > outMax ? outMax : scaled;
141
- }
142
- function minSpacing(width) {
143
- // minimum spacing between 2 ticks, in px
144
- return scale(width, 300, 900, 70, 150);
145
- }
146
- function getMaxTicks(width) {
147
- return Math.round(width / minSpacing(width));
148
- }
149
- export function getInterval(largest, maxticks) {
150
- const minimum = largest / maxticks;
151
- const magnitude = 10 ** Math.floor(Math.log10(minimum));
152
- const residual = minimum / magnitude;
153
- let interval;
154
- if (residual > 5) {
155
- interval = 10 * magnitude;
156
- }
157
- else if (residual > 3) {
158
- interval = 5 * magnitude;
159
- }
160
- else if (residual > 2) {
161
- interval = 3 * magnitude;
162
- }
163
- else if (residual > 1.5) {
164
- interval = 2 * magnitude;
165
- }
166
- else if (residual > 1) {
167
- interval = 1.5 * magnitude;
168
- }
169
- else {
170
- interval = magnitude;
171
- }
172
- return interval;
173
- }
174
- function handleSliceKeyDown(ev) {
175
- if (this.popoverEl && this.popoverEl.open && ev.key === "Enter") {
176
- const popoverBtn = this.popoverEl.querySelector("button");
177
- popoverBtn && popoverBtn.click();
178
- }
179
- }
180
- export function handleSliceClick(ev, s) {
181
- if (this.popoverEl && !this.isTabbing) {
182
- s.coords = { x: ev.clientX, y: ev.clientY };
183
- openPopover(this.popoverEl, s);
184
- highlightSegmentInfo(Array.from(this.el.shadowRoot.querySelectorAll("[data-segmentindex")), s);
185
- }
186
- }
187
- function handleSliceFocus(ev, s) {
188
- if (this.popoverEl && this.isTabbing) {
189
- this.focusedSliceId = s.id;
190
- s.coords = getPosition(ev.target);
191
- s.coords.x = s.coords.x + 30;
192
- s.coords.y = s.coords.y + 30;
193
- openPopover(this.popoverEl, s);
194
- highlightSegmentInfo(Array.from(this.el.shadowRoot.querySelectorAll("[data-segmentindex")), s);
195
- }
196
- }
197
- export function handleChartKeydown(ev) {
198
- switch (ev.key) {
199
- // arrow up / left
200
- case "ArrowUp":
201
- case "ArrowLeft":
202
- ev.preventDefault();
203
- this.isTabbing = true; // shd already be true. just in case user clicked on chart then pressed an arrow key
204
- focusPrevious.call(this);
205
- break;
206
- // arrow right / down
207
- case "ArrowRight":
208
- case "ArrowDown":
209
- ev.preventDefault();
210
- this.isTabbing = true; // shd already be true. just in case user clicked on chart then pressed an arrow key
211
- focusNext.call(this);
212
- break;
213
- // tab
214
- case "Tab":
215
- exitChart.call(this);
216
- break;
217
- case "Escape":
218
- this.popoverEl.open = false;
219
- this.userIsNavigating = false;
220
- break;
221
- }
222
- }
223
- export function openPopover(popoverEl, s) {
224
- popoverEl.open = false;
225
- if (s.title && s.text) {
226
- popoverEl.sliceDetails = Object.assign({}, s);
227
- window.setTimeout(() => (popoverEl.open = true), 30);
228
- }
229
- }
230
- function focusNext() {
231
- const activeEl = checkForActiveElInShadow(document.activeElement);
232
- const index =
233
- // if the active el is not in the array the first element gets focused
234
- (this.sliceEls.indexOf(activeEl) + 1) % this.sliceEls.length;
235
- focusSlice.call(this, index);
236
- }
237
- function focusPrevious() {
238
- if (this.sliceEls) {
239
- const activeEl = checkForActiveElInShadow(document.activeElement);
240
- let index = this.sliceEls.indexOf(activeEl);
241
- if (index === -1) {
242
- // not in the array : focus the first slice
243
- index = 0;
244
- }
245
- else if (index === 0) {
246
- // first slice : focus the last slice
247
- index = this.sliceEls.length - 1;
248
- }
249
- else {
250
- // anything else: focus previous
251
- index -= 1;
252
- }
253
- focusSlice.call(this, index);
254
- }
255
- }
256
- function focusSlice(index) {
257
- if (this.sliceEls && this.el) {
258
- this.userIsNavigating = true;
259
- // set tabindex of the wrapper to -1 while slices are being focused, to allow for shft-tabbing out of the component directly
260
- this.componentWrapperEl.tabIndex = -1;
261
- // @ts-ignore
262
- this.el.focusable = false; // for Edge
263
- this.sliceEls.map((p) => {
264
- p.tabIndex = -1;
265
- // @ts-ignore
266
- p.focusable = false; // for Edge
267
- });
268
- this.sliceEls[index].tabIndex = 0;
269
- // @ts-ignore
270
- this.sliceEls[index].focusable = true; // for Edge
271
- this.sliceEls[index].focus();
272
- // for keyboard focus on doughnuts
273
- this.focusedSliceId = this.sliceEls[index].id;
274
- window.setTimeout(() => {
275
- if (this.popoverEl) {
276
- this.popoverEl.open = true;
277
- }
278
- }, 10);
279
- }
280
- }
281
- export function exitChart() {
282
- this.focusedSliceId = undefined;
283
- this.sliceEls &&
284
- this.sliceEls.map((p) => {
285
- p.tabIndex = -1;
286
- // @ts-ignore
287
- p.focusable = false; // for Edge
288
- });
289
- this.userIsNavigating = false;
290
- // delay so that we can tab out of component before chart becomes focusable again
291
- // and in case user was still pressing an arrow key when they pressed tab
292
- window.setTimeout(() => {
293
- this.componentWrapperEl.tabIndex = 0;
294
- // @ts-ignore
295
- this.el.focusable = true; // for Edge
296
- if (this.popoverEl) {
297
- this.popoverEl.open = false;
298
- }
299
- }, 100);
300
- }
301
- export async function getDetails(chartType) {
302
- this.slicesDetails = [];
303
- let acc = 0;
304
- const children = Array.from(this.el.children);
305
- this.total = children.reduce((total, slice) => (total += parseInt(slice.getAttribute("amount") || "0")), 0);
306
- let chartColors = [...allChartsDetails[chartType].colors];
307
- if (this.chartType === "bar2") {
308
- if (children.length <= 5) {
309
- // remove lavender
310
- chartColors.splice(1, 1);
311
- }
312
- if (children.length <= 4) {
313
- // remove midnight
314
- chartColors.splice(2, 1);
315
- }
316
- }
317
- // Set colors when bar3 has only 2 slices
318
- if (chartType === "bar3" && children.length === 2) {
319
- chartColors = [chartColors[1], chartColors[3]];
320
- }
321
- // Set colors when doughnut2 has less than 5 slices
322
- // (rm 2nd neutral color midnight)
323
- if (chartType === "doughnut2" && children.length < 5) {
324
- chartColors.splice(2, 1);
325
- // with 3 slices or less, also remove first color
326
- // (only pos, neg and unknown remain)
327
- if (children.length < 4) {
328
- chartColors.shift();
329
- }
330
- }
331
- // for bar5, first color should be skipped unless notStartedColor is set to true
332
- if (chartType === "bar5" && !this.notStartedColor) {
333
- chartColors.shift();
334
- }
335
- children.forEach((c, i) => {
336
- const amount = parseInt(c.getAttribute("amount") || "0");
337
- const perc = amountToPercent(amount, this.total, true);
338
- let colorIndex = i;
339
- // bars in bar6 are all the same color
340
- if (chartType === "bar6") {
341
- colorIndex = 0;
342
- }
343
- const sliceDetails = {
344
- amount: amount,
345
- visualAmount: amount,
346
- perc: perc,
347
- legend: c.getAttribute("legend"),
348
- color: chartColors[colorIndex] || colors.gray,
349
- offset: acc,
350
- id: `${this.uid}-${i + 1}`,
351
- title: c.getAttribute("popover-title"),
352
- text: c.getAttribute("popover-text"),
353
- buttonText: c.getAttribute("popover-button-text"),
354
- sliceRef: c,
355
- inSmallCluster: false,
356
- index: i,
357
- };
358
- acc += amount;
359
- this.slicesDetails.push(sliceDetails);
360
- });
361
- }
362
- function sortSlicesDetails(slicesDetails, total) {
363
- // sort slices by decreasing amount
364
- let sortedSlicesDetails = [...slicesDetails].sort((a, b) => a.amount === b.amount ? 0 : a.amount > b.amount ? -1 : 1);
365
- let acc = 0;
366
- sortedSlicesDetails
367
- .filter((s) => s.amount > 0)
368
- .forEach((s, idx) => {
369
- const prev = sortedSlicesDetails[idx === 0 ? sortedSlicesDetails.length - 1 : idx - 1];
370
- const next = sortedSlicesDetails[idx === sortedSlicesDetails.length - 1 ? 0 : idx + 1];
371
- const prevPerc = amountToPercent(prev.amount, total, true);
372
- const nextPerc = amountToPercent(next.amount, total, true);
373
- // determine whether the slice is in a cluster of small values
374
- // to avoid percentage text overlap for small values
375
- // because <1% slice percentage text has an additional character
376
- // the inSmallCluster threshold needs to be widened for that slice only
377
- const neighborLimit = s.perc === 0 ? 8 : 5;
378
- const isSmall = s.perc < 4;
379
- const prevIsSmall = prevPerc < neighborLimit;
380
- const nextIsSmall = nextPerc < neighborLimit;
381
- let inSmallCluster = isSmall && (prevIsSmall || nextIsSmall);
382
- s.inSmallCluster = inSmallCluster;
383
- s.offset = acc;
384
- acc += s.amount;
385
- });
386
- return sortedSlicesDetails;
387
- }
388
- function getPathData(amount, offset, chartType) {
389
- const startAngle = amountToDegree(offset, this.total) - 90; // start at noon, not at 3 o'clock
390
- const activeAngle = (amount / this.total) * 360;
391
- let endAngle = startAngle + activeAngle;
392
- const largeArcFlagOuter = activeAngle > 180 ? "1 1" : "0 1";
393
- const largeArcFlagInner = activeAngle > 180 ? "1 0" : "0 0";
394
- const half = this.chartDetails.size / 2;
395
- const innerRadius = this.chartDetails.thickness;
396
- const outerRadius = 1;
397
- const isProgressIndicator = chartType === "doughnut";
398
- const outerSeparatorOffset = 1.5;
399
- const innerSeparatorOffset = isProgressIndicator ? 2.25 : 3;
400
- if (activeAngle === 360) {
401
- // fix to avoid bad svg shape when the path goes all around (100%)
402
- endAngle -= 0.01;
403
- }
404
- const outerCoords = polarToCartesian(half, outerRadius, startAngle + outerSeparatorOffset, // Addition for slice separator
405
- endAngle);
406
- const innerCoords = polarToCartesian(half, innerRadius, startAngle + innerSeparatorOffset, // Addition for slice separator
407
- endAngle);
408
- const moveTo = `M ${outerCoords.x1}, ${outerCoords.y1} `;
409
- const arc1 = getArc(outerRadius, largeArcFlagOuter, outerCoords.x2, outerCoords.y2, this.chartDetails.size);
410
- const line = ` L ${innerCoords.x2}, ${innerCoords.y2} `;
411
- const arc2 = getArc(innerRadius, largeArcFlagInner, innerCoords.x1, innerCoords.y1, this.chartDetails.size);
412
- return moveTo + arc1 + line + arc2 + " z";
413
- }
414
- export function renderInstructionsText() {
415
- const chartInstructions = intl.formatMessage({
416
- id: "chart.instructions",
417
- defaultMessage: "Use arrow keys to browse elements, press Tab to exit.",
418
- description: "For screen readers only, instructions on how to interact with the chart component",
419
- });
420
- return h("div", { id: "chart-instructions" }, chartInstructions);
421
- }
422
- function renderFilter() {
423
- return (h("defs", null, h("filter", { id: "wmHoverDropShadow" }, h("feGaussianBlur", { stdDeviation: "3" }), h("feOffset", { result: "offsetblur" }), h("feFlood", { "flood-color": "#333" }), h("feComposite", { operator: "in", in2: "offsetblur" }), h("feMerge", null, h("feMergeNode", null), h("feMergeNode", { in: "SourceGraphic" })))));
424
- }
425
- function applyMinimumAngle(minimumAngle, slicesDetails, total) {
426
- const allAngles = slicesDetails.map((s) => amountToDegree(s.amount, total));
427
- const hasTooSmallAngle = allAngles.some((angle) => angle !== 0 && angle < minimumAngle);
428
- if (hasTooSmallAngle) {
429
- // all angles initially sum to 360
430
- // increase all angles below minimum to meet minimum, sum should now exceed 360
431
- // all unchanged angles should be proportionally reduced, so they sum to (360 - sum of changed angles)
432
- // For Example:
433
- // angles: 100 200 5 4 3 48 = 360, increasedAngles: 100 200 7 7 7 48 = 369
434
- // unchangedAnglesSum = 348, changedAnglesSum = 21
435
- // unchangedTargetSum: 360 - 21 = 339, targetDifference: 348 - 339 = 9
436
- // reductionRatio = 9/339
437
- // adjustedAngles: 97.345 194.69 7 7 7 46.725 = approx 360
438
- const increasedAngles = allAngles.map((angle) => (angle == 0 ? angle : Math.max(angle, minimumAngle)));
439
- const unchangedAnglesSum = increasedAngles.reduce((acc, cur) => acc + (cur > minimumAngle && cur !== 0 ? cur : 0), 0);
440
- const changedAnglesSum = increasedAngles.reduce((acc, cur) => acc + (cur > minimumAngle && cur !== 0 ? 0 : cur), 0);
441
- const unchangedTargetSum = 360 - changedAnglesSum;
442
- const targetDifference = unchangedAnglesSum - unchangedTargetSum;
443
- const reductionRatio = targetDifference / unchangedTargetSum;
444
- const adjustedAngles = increasedAngles.map((angle) => angle > minimumAngle ? angle - reductionRatio * angle : angle == 0 ? 0 : minimumAngle);
445
- // apply new amounts based on adjust angles
446
- let offsetAcc = 0;
447
- slicesDetails = slicesDetails.map((s, idx) => {
448
- const visualAmount = (adjustedAngles[idx] / 360) * total;
449
- const newOffset = offsetAcc;
450
- offsetAcc += visualAmount;
451
- return Object.assign(Object.assign({}, s), { visualAmount: visualAmount, offset: newOffset });
452
- });
453
- }
454
- return slicesDetails;
455
- }
456
- export function renderDoughnut(chartType) {
457
- const outerSize = this.chartDetails.size + this.chartDetails.padding;
458
- const isProgressIndicator = chartType === "doughnut";
459
- // no sorting in progress indicators
460
- let slicesDetails = isProgressIndicator ? this.slicesDetails : sortSlicesDetails(this.slicesDetails, this.total);
461
- slicesDetails = applyMinimumAngle(7, slicesDetails, this.total);
462
- // perc is only for progress indicator
463
- const amount = slicesDetails[0].amount;
464
- let perc = amountToPercent(amount, this.total, true);
465
- if (perc === 0 && amount > 0) {
466
- perc = "<1%";
467
- }
468
- else if (perc === 100 && amount < this.total) {
469
- perc = ">99%";
470
- }
471
- else {
472
- perc = perc + "%";
473
- }
474
- return (h("div", { class: "chart-wrapper doughnut-wrapper" }, h("svg", { width: outerSize + "px", height: outerSize + "px", id: `graphic-${this.uid}`, class: "doughnut-svg" }, renderFilter(), slicesDetails.map((s) => renderPath.call(this, s, chartType)), renderFocusOutline.call(this), isProgressIndicator ? (h("text", { class: "value", x: "50%", y: "50%", "font-size": "1.5rem", "font-weight": "500", "text-anchor": "middle", "dominant-baseline": "middle" }, perc)) : (h("g", { transform: `translate(${this.chartDetails.padding / 2}, ${this.chartDetails.padding / 2})`, "text-anchor": "middle", "dominant-baseline": "middle" }, slicesDetails.map((s) => s.amount > 0 && !s.inSmallCluster ? renderDoughnutText.call(this, s) : ""))))));
475
- }
476
- export function highlightSegmentInfo(infoEls, s) {
477
- infoEls.forEach((el) => {
478
- if (el.dataset.segmentindex && parseInt(el.dataset.segmentindex) !== s.index) {
479
- el.classList.add("faded");
480
- }
481
- else {
482
- el.classList.remove("faded");
483
- }
484
- });
485
- }
486
- export function removeSegmentInfoHighlight(infoEls) {
487
- infoEls.forEach((el) => {
488
- el.classList.remove("faded");
489
- });
490
- }
491
- function renderPath(s, chartType) {
492
- const percentageValue = amountToPercent(s.amount, this.total, true) + "%";
493
- return (!isNaN(s.amount) && (h("g", { transform: `translate(${this.chartDetails.padding / 2}, ${this.chartDetails.padding / 2})` }, h("path", { id: s.id, class: "segment doughnut-segment", fill: s.visualAmount ? s.color : "transparent", d: getPathData.call(this, s.visualAmount, s.offset, chartType), onClick: (ev) => handleSliceClick.call(this, ev, s), onFocus: (ev) => handleSliceFocus.call(this, ev, s), onKeyDown: (ev) => handleSliceKeyDown.call(this, ev), role: "img", "aria-label": `${s.legend}, ${percentageValue}`, "data-segmentindex": s.index }))));
494
- }
495
- function renderFocusOutline() {
496
- return this.isTabbing ? (h("g", { transform: `translate(${this.chartDetails.padding / 2}, ${this.chartDetails.padding / 2})` }, h("use", { tabindex: -1, id: "kfbg1", xlinkHref: `#${this.focusedSliceId}` }), h("use", { tabindex: -1, id: "kfstroke", xlinkHref: `#${this.focusedSliceId}` }), h("use", { tabindex: -1, id: "kfbg2", xlinkHref: `#${this.focusedSliceId}` }))) : ("");
497
- }
498
- function renderDoughnutText(s) {
499
- const arcMiddle = amountToDegree(s.offset + s.visualAmount / 2, this.total);
500
- let { x, y } = polarToCartesian(this.chartDetails.size / 2, 1.4, arcMiddle - 90);
501
- let val;
502
- if (s.perc === 0 && s.amount > 0) {
503
- val = "<1%";
504
- }
505
- else if (s.perc === 100 && s.amount < this.total) {
506
- val = ">99%";
507
- }
508
- else {
509
- val = s.perc + "%";
510
- }
511
- return (h("text", { class: "value", x: x + "px", y: y + "px", "data-segmentindex": s.index }, val));
512
- }
513
- export function renderStackedBar(chartType) {
514
- const isHybridBar = chartType === "bar";
515
- // if the text for any value > 0 overlaps with another, hide it and display warning
516
- const textEls = this.el.shadowRoot.querySelectorAll(".value");
517
- // if DOM is not ready (no textEls), we need to rerender
518
- // we don't have to do it here though, because it's already taken care of
519
- // as a side effect of the observer in componentWillLoad
520
- // (observers fire on init)
521
- if (textEls.length > 0) {
522
- requestAnimationFrame(() => {
523
- let prevTextEls = [];
524
- const margin = 4;
525
- let showMsg = false;
526
- textEls.forEach((textEl) => {
527
- textEl.classList.remove("hidden");
528
- const currentValue = parseInt(textEl.dataset.value);
529
- // only proceed if there are prevTextEls to check for overlap, and current value is not 0
530
- if (prevTextEls.length > 0 && currentValue != 0) {
531
- const currentLeftEdge = textEl.getBoundingClientRect().left - margin;
532
- // check for overlap with all prevTextEls & hide the smaller value if overlap occurs
533
- prevTextEls.forEach((prevTextEl) => {
534
- const prevValue = parseInt(prevTextEl.dataset.value);
535
- const valuesOverlap = prevTextEl.getBoundingClientRect().right > currentLeftEdge;
536
- if (valuesOverlap) {
537
- const smallerValueEl = currentValue < prevValue ? textEl : prevTextEl;
538
- smallerValueEl.classList.add("hidden");
539
- showMsg = true;
540
- }
541
- });
542
- }
543
- // prevTextEls only need to be checked if they are visible and have a non-zero value
544
- if (!textEl.classList.contains("hidden") && currentValue > 0) {
545
- prevTextEls.push(textEl);
546
- }
547
- });
548
- // progress monitor doesn't have this message
549
- (this.isBar || this.isDoughnut) && this.showHiddenValuesMessage(showMsg);
550
- });
551
- }
552
- return (h("div", { class: "chart-wrapper bar-wrapper" }, isHybridBar ? (h("div", { class: "single-perc" }, amountToPercent(this.slicesDetails[0].amount, this.total, true) + "%")) : (""), this.chartType === "bar3" && this.drawAxis(), h("div", { class: `inner-stacked-bar-wrapper ${showValue(this.valueFormat)}` }, !isHybridBar ? (h("div", { class: `values ${this.valueFormat}` }, this.slicesDetails.map((s) => this.renderBarText(s, 5)))) : (""), h("div", { class: "stacked-bar-segments-wrapper" }, this.slicesDetails.map((s) => renderStackedBarSegment.call(this, s, 5))), isHybridBar ? renderCompletionMessage.call(this) : ""), this.chartType === "bar3" ? (h("div", { class: "bar3-axis-label", "aria-hidden": "true" }, h("span", null, "0%"), h("span", null, "100%"))) : ("")));
553
- }
554
- function renderStackedBarSegment(s, minimumWidth) {
555
- const segmentPercentage = amountToPercent(s.amount, this.total, false);
556
- const barWrapper = this.el.shadowRoot.querySelector(".stacked-bar-segments-wrapper");
557
- const availableWidth = barWrapper ? barWrapper.offsetWidth : this.el.offsetWidth;
558
- const meetsSizeMinimum = (segmentPercentage / 100) * availableWidth >= minimumWidth;
559
- const renderedWidth = meetsSizeMinimum || s.amount == 0 ? `${segmentPercentage}%` : `${minimumWidth}px`;
560
- let segmentValue = "";
561
- if (this.valueFormat == "percentage") {
562
- segmentValue = `${amountToPercent(s.amount, this.total, true)} %`;
563
- }
564
- else if (this.valueFormat == "amount") {
565
- segmentValue = s.amount.toString();
566
- }
567
- return (h("div", { class: `segment stacked-bar-segment ${amountToPercent(s.amount, this.total, false) === 0 ? "zero" : ""} ${meetsSizeMinimum ? "" : "fixed-width"}`, style: {
568
- backgroundColor: s.color,
569
- width: renderedWidth,
570
- }, onClick: (ev) => handleSliceClick.call(this, ev, s), onFocus: (ev) => handleSliceFocus.call(this, ev, s), onKeyDown: (ev) => handleSliceKeyDown.call(this, ev), "data-segmentindex": s.index }, h("span", { class: "sr-only" }, `${s.legend} ${segmentValue}`)));
571
- }
572
- export function renderSimpleBar(chartType) {
573
- // find largest number and get interval, numTicks, chartMaxVal for all.
574
- const largest = this.slicesDetails
575
- .map((s) => s.amount)
576
- .reduce((a, b) => {
577
- return a > b ? a : b;
578
- });
579
- const labelWidth = parseInt(getComputedStyle(this.el).getPropertyValue("--labelWidth"), 10);
580
- const chartPadding = 48;
581
- const componentWidth = this.el.getBoundingClientRect().width;
582
- const chartWidth = componentWidth - labelWidth - chartPadding;
583
- let numTicks = getMaxTicks(chartWidth);
584
- let interval = getInterval(largest, numTicks);
585
- // after the algorithm finds an interval, remove extra ticks so that the greater number is always between the last tick and the one before that
586
- const lastTickVal = numTicks * interval;
587
- const extraTicks = Math.floor((lastTickVal - largest) / interval);
588
- numTicks -= extraTicks;
589
- this.el.style.setProperty("--backgroundSize", 100 / numTicks + "%");
590
- this.el.style.setProperty("--labelWidth", this.labelWidth);
591
- if (chartType === "bar7" && !this.showBarLegend) {
592
- this.el.style.setProperty("--labelWidth", "0px");
593
- }
594
- // we have to prep the data here rather than iterate directly in the return statement
595
- // because CSS grid needs a flat structure, and return functions must
596
- // have a single parent element
597
- const rows = [];
598
- this.slicesDetails.forEach((s) => {
599
- s.legend && rows.push(renderSimpleBarLegend(s.legend, this.showBarLegend, chartType));
600
- rows.push(renderSimpleBarItem.call(this, s, interval, numTicks, largest));
601
- });
602
- const ticks = [];
603
- for (let i = 1; i <= numTicks; i++) {
604
- const tickVal = abbrNumber(safeMultiplyFloat(i, interval));
605
- ticks.push(h("div", { class: "tick" }, h("span", null, tickVal)));
606
- }
607
- const showGrid = chartType === "bar6" && this.showGrid && this.el.getBoundingClientRect().width > 300;
608
- return (h("div", { class: "chart-wrapper simple-bar-wrapper" }, h("div", { class: `chart ${showValue(this.valueFormat)}` }, showGrid && h("div", { class: "gridlines" }), h("div", { class: "rows" }, rows)), showGrid && (h("div", { class: "x-axis", "aria-hidden": "true" }, h("div", { class: "zero" }, h("span", null, "0")), ticks))));
609
- }
610
- function renderSimpleBarLegend(legend, show, chartType) {
611
- // not sure how to collapse the left column to 0 width with CSS grid. text should still be available to SR.
612
- const hidden = chartType === "bar7" && !show ? " hidden" : "";
613
- return h("label", { class: `label${hidden}` }, legend);
614
- }
615
- function renderSimpleBarItem(s, interval, ticks, largest) {
616
- const chartMaxVal = this.currentChartType === "bar6" ? interval * ticks : largest;
617
- const width = amountToPercent(s.amount, chartMaxVal, false);
618
- const cssWidth = width ? width + "%" : "1px";
619
- const amt = abbrNumber(s.amount);
620
- let displayValue = this.valueFormat === "amount" ? amt : "";
621
- if (this.currentChartType === "bar6" && this.valueFormat === "percentage") {
622
- displayValue = s.amount + "%";
623
- }
624
- else if (this.currentChartType === "bar7" && this.valueFormat === "percentage") {
625
- displayValue = (this.total === 0 ? "0" : amountToPercent(s.amount, this.total, true)) + "%";
626
- }
627
- return (h("div", { class: "bar segment", style: {
628
- backgroundColor: s.color,
629
- width: cssWidth,
630
- }, onClick: (ev) => handleSliceClick.call(this, ev, s), onFocus: (ev) => handleSliceFocus.call(this, ev, s), onKeyDown: (ev) => handleSliceKeyDown.call(this, ev), "data-segmentindex": s.index }, h("div", { class: "value" }, displayValue)));
631
- }
632
- export function renderLegend(chartType) {
633
- // legend is hidden for bar1 and bar6 types regardless of showLegend value
634
- if (this.showLegend) {
635
- const showMsg = this.slicesDetails.reduce((hasCluster, cur) => (hasCluster = cur.inSmallCluster ? true : hasCluster), false);
636
- this.isDoughnut && this.showHiddenValuesMessage(showMsg);
637
- return (h("div", { class: "legend-wrapper" }, h("div", { class: `legend ${chartType} ${this.mode === "bar" ? "--top" : "--bottom"}`, "aria-hidden": "true" }, this.slicesDetails.map((s) => {
638
- const printValue = this.printModeFormat == "amount"
639
- ? `${s.amount}/${this.total}`
640
- : `${amountToPercent(s.amount, this.total, true)}%`;
641
- // when both legend and amount are omitted, the legend is not shown for that particular option (it's been deactivated by the user)
642
- if (!!s.amount || !!s.legend) {
643
- return renderLegendItem.call(this, { key: s.legend, color: s.color }, printValue, s);
644
- }
645
- })), this.isDoughnut && !this.printMode && renderHiddenValuesMessage()));
646
- }
647
- }
648
- export function renderLegendItem(legendItem, printValue = "", s = null) {
649
- const handleLegendItemClick = (ev) => {
650
- if (s) {
651
- s.coords = { x: ev.clientX, y: ev.clientY };
652
- openPopover(this.popoverEl, s);
653
- highlightSegmentInfo(Array.from(this.el.shadowRoot.querySelectorAll("[data-segmentindex")), s);
654
- }
655
- };
656
- return (h("div", { class: "legend-item", onClick: (ev) => handleLegendItemClick(ev), "data-segmentindex": s ? s.index : null }, h("div", { class: "legend-color", style: { backgroundColor: legendItem.color } }), h("div", { class: "legend-text" }, legendItem.key, printValue && h("span", { class: `print-value ${this.printMode ? "force-visible" : ""}` }, ": ", printValue))));
657
- }
658
- export function renderCompletionMessage() {
659
- if (this.completionMessage) {
660
- return h("div", { class: "completion-message" }, this.completionMessage);
661
- }
662
- }
663
- export function renderHiddenValuesMessage() {
664
- return (h("div", { class: "hidden-values-warning hidden" }, textHiddenMessage, h("br", null), seeDetailsMessage));
665
- }