@watermarkinsights/ripple 3.13.0 → 3.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (308) hide show
  1. package/README.md +3 -3
  2. package/dist/cjs/{chartFunctions-34fdd3ce.js → chartFunctions-0ea0888f.js} +420 -420
  3. package/dist/cjs/{functions-120449cf.js → functions-8d3ceccd.js} +1894 -450
  4. package/dist/cjs/{global-c1940f7b.js → global-39ada944.js} +62 -62
  5. package/dist/cjs/{http-service-494d81de.js → http-service-9e8c4dd5.js} +49 -49
  6. package/dist/cjs/{index-acad7ab3.js → index-df6a3611.js} +4 -1
  7. package/dist/cjs/{interfaces-a3338581.js → interfaces-30a74c1f.js} +29 -29
  8. package/dist/cjs/loader.cjs.js +4 -4
  9. package/dist/cjs/priv-chart-popover.cjs.entry.js +87 -87
  10. package/dist/cjs/priv-datepicker.cjs.entry.js +658 -658
  11. package/dist/cjs/priv-navigator-button.cjs.entry.js +19 -19
  12. package/dist/cjs/priv-navigator-item.cjs.entry.js +24 -24
  13. package/dist/cjs/ripple.cjs.js +4 -4
  14. package/dist/cjs/wm-action-menu_2.cjs.entry.js +336 -336
  15. package/dist/cjs/wm-button.cjs.entry.js +242 -242
  16. package/dist/cjs/wm-chart-slice.cjs.entry.js +14 -14
  17. package/dist/cjs/wm-chart.cjs.entry.js +111 -111
  18. package/dist/cjs/wm-datepicker.cjs.entry.js +266 -266
  19. package/dist/cjs/wm-input.cjs.entry.js +135 -135
  20. package/dist/cjs/wm-modal-footer.cjs.entry.js +34 -34
  21. package/dist/cjs/wm-modal-header.cjs.entry.js +37 -37
  22. package/dist/cjs/wm-modal.cjs.entry.js +164 -164
  23. package/dist/cjs/wm-navigation_3.cjs.entry.js +228 -228
  24. package/dist/cjs/wm-navigator.cjs.entry.js +269 -269
  25. package/dist/cjs/wm-network-uploader.cjs.entry.js +455 -455
  26. package/dist/cjs/wm-option_2.cjs.entry.js +717 -710
  27. package/dist/cjs/wm-pagination.cjs.entry.js +168 -168
  28. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +130 -130
  29. package/dist/cjs/wm-search.cjs.entry.js +233 -233
  30. package/dist/cjs/wm-snackbar.cjs.entry.js +171 -171
  31. package/dist/cjs/wm-tab-item_3.cjs.entry.js +297 -297
  32. package/dist/cjs/wm-tag-input.cjs.entry.js +580 -580
  33. package/dist/cjs/wm-timepicker.cjs.entry.js +384 -384
  34. package/dist/cjs/wm-toggletip.cjs.entry.js +125 -125
  35. package/dist/cjs/wm-uploader.cjs.entry.js +630 -632
  36. package/dist/cjs/wm-wrapper.cjs.entry.js +13 -13
  37. package/dist/collection/collection-manifest.json +1 -1
  38. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +258 -258
  39. package/dist/collection/components/charts/wm-chart/wm-chart-slice.js +115 -115
  40. package/dist/collection/components/charts/wm-chart/wm-chart.js +328 -328
  41. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +195 -195
  42. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +88 -88
  43. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-slice.js +111 -111
  44. package/dist/collection/components/wm-action-menu/wm-action-menu.js +448 -448
  45. package/dist/collection/components/wm-button/wm-button.js +504 -504
  46. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.js +1024 -1024
  47. package/dist/collection/components/wm-datepicker/wm-datepicker.js +471 -471
  48. package/dist/collection/components/wm-input/wm-input.js +423 -423
  49. package/dist/collection/components/wm-menuitem/wm-menuitem.js +444 -444
  50. package/dist/collection/components/wm-modal/wm-modal-footer.js +136 -136
  51. package/dist/collection/components/wm-modal/wm-modal-header.js +87 -87
  52. package/dist/collection/components/wm-modal/wm-modal.js +461 -461
  53. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +162 -162
  54. package/dist/collection/components/wm-navigation/wm-navigation-item.js +121 -121
  55. package/dist/collection/components/wm-navigation/wm-navigation.js +218 -218
  56. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +97 -97
  57. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +114 -114
  58. package/dist/collection/components/wm-navigator/wm-navigator.js +468 -468
  59. package/dist/collection/components/wm-option/wm-option.css +13 -0
  60. package/dist/collection/components/wm-option/wm-option.js +427 -419
  61. package/dist/collection/components/wm-pagination/wm-pagination.js +368 -368
  62. package/dist/collection/components/wm-search/wm-search.js +480 -480
  63. package/dist/collection/components/wm-select/wm-select.css +5 -2
  64. package/dist/collection/components/wm-select/wm-select.js +978 -978
  65. package/dist/collection/components/wm-snackbar/wm-snackbar.js +297 -297
  66. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +216 -216
  67. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +330 -330
  68. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +104 -104
  69. package/dist/collection/components/wm-tag-input/wm-tag-input.js +810 -810
  70. package/dist/collection/components/wm-timepicker/wm-timepicker.js +583 -583
  71. package/dist/collection/components/wm-toggletip/wm-toggletip.js +241 -241
  72. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.js +787 -787
  73. package/dist/collection/components/wm-uploader/wm-uploader.js +1072 -1077
  74. package/dist/collection/components/wm-wrapper/wm-wrapper.js +27 -27
  75. package/dist/collection/dev/scripts.js +20 -20
  76. package/dist/collection/global/__mocks__/functions.js +6 -6
  77. package/dist/collection/global/chartFunctions.js +421 -421
  78. package/dist/collection/global/functions.js +441 -441
  79. package/dist/collection/global/global.js +69 -69
  80. package/dist/collection/global/interfaces.js +49 -49
  81. package/dist/collection/global/services/__mocks__/http-service.js +130 -130
  82. package/dist/collection/global/services/http-service.js +50 -50
  83. package/dist/collection/lang/lang.js +5 -5
  84. package/dist/collection/lang/missing.js +43 -43
  85. package/dist/collection/lang/piglatin.js +93 -93
  86. package/dist/esm/{chartFunctions-20f05eb5.js → chartFunctions-6f90586d.js} +420 -420
  87. package/dist/esm/{functions-036af8dc.js → functions-11c0c4e2.js} +1894 -450
  88. package/dist/esm/{global-e98c740f.js → global-d36a84c5.js} +62 -62
  89. package/dist/esm/{http-service-3dc3b3e7.js → http-service-5d037e16.js} +49 -49
  90. package/dist/esm/{index-7603f98e.js → index-17c79cc6.js} +4 -1
  91. package/dist/esm/{interfaces-2b97fab2.js → interfaces-61c6305b.js} +29 -29
  92. package/dist/esm/loader.js +4 -4
  93. package/dist/esm/polyfills/core-js.js +0 -0
  94. package/dist/esm/polyfills/css-shim.js +1 -1
  95. package/dist/esm/polyfills/dom.js +0 -0
  96. package/dist/esm/polyfills/es5-html-element.js +0 -0
  97. package/dist/esm/polyfills/index.js +0 -0
  98. package/dist/esm/polyfills/system.js +0 -0
  99. package/dist/esm/priv-chart-popover.entry.js +87 -87
  100. package/dist/esm/priv-datepicker.entry.js +658 -658
  101. package/dist/esm/priv-navigator-button.entry.js +19 -19
  102. package/dist/esm/priv-navigator-item.entry.js +24 -24
  103. package/dist/esm/ripple.js +4 -4
  104. package/dist/esm/wm-action-menu_2.entry.js +336 -336
  105. package/dist/esm/wm-button.entry.js +242 -242
  106. package/dist/esm/wm-chart-slice.entry.js +14 -14
  107. package/dist/esm/wm-chart.entry.js +111 -111
  108. package/dist/esm/wm-datepicker.entry.js +266 -266
  109. package/dist/esm/wm-input.entry.js +135 -135
  110. package/dist/esm/wm-modal-footer.entry.js +34 -34
  111. package/dist/esm/wm-modal-header.entry.js +37 -37
  112. package/dist/esm/wm-modal.entry.js +164 -164
  113. package/dist/esm/wm-navigation_3.entry.js +228 -228
  114. package/dist/esm/wm-navigator.entry.js +269 -269
  115. package/dist/esm/wm-network-uploader.entry.js +455 -455
  116. package/dist/esm/wm-option_2.entry.js +717 -710
  117. package/dist/esm/wm-pagination.entry.js +168 -168
  118. package/dist/esm/wm-progress-indicator_3.entry.js +130 -130
  119. package/dist/esm/wm-search.entry.js +233 -233
  120. package/dist/esm/wm-snackbar.entry.js +171 -171
  121. package/dist/esm/wm-tab-item_3.entry.js +297 -297
  122. package/dist/esm/wm-tag-input.entry.js +580 -580
  123. package/dist/esm/wm-timepicker.entry.js +384 -384
  124. package/dist/esm/wm-toggletip.entry.js +125 -125
  125. package/dist/esm/wm-uploader.entry.js +630 -632
  126. package/dist/esm/wm-wrapper.entry.js +13 -13
  127. package/dist/esm-es5/{chartFunctions-20f05eb5.js → chartFunctions-6f90586d.js} +1 -1
  128. package/dist/esm-es5/functions-11c0c4e2.js +1 -0
  129. package/dist/esm-es5/{global-e98c740f.js → global-d36a84c5.js} +1 -1
  130. package/dist/esm-es5/{http-service-3dc3b3e7.js → http-service-5d037e16.js} +0 -0
  131. package/dist/esm-es5/{index-7603f98e.js → index-17c79cc6.js} +1 -1
  132. package/dist/esm-es5/{interfaces-2b97fab2.js → interfaces-61c6305b.js} +0 -0
  133. package/dist/esm-es5/loader.js +1 -1
  134. package/dist/esm-es5/priv-chart-popover.entry.js +1 -1
  135. package/dist/esm-es5/priv-datepicker.entry.js +1 -1
  136. package/dist/esm-es5/priv-navigator-button.entry.js +1 -1
  137. package/dist/esm-es5/priv-navigator-item.entry.js +1 -1
  138. package/dist/esm-es5/ripple.js +1 -1
  139. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -1
  140. package/dist/esm-es5/wm-button.entry.js +1 -1
  141. package/dist/esm-es5/wm-chart-slice.entry.js +1 -1
  142. package/dist/esm-es5/wm-chart.entry.js +1 -1
  143. package/dist/esm-es5/wm-datepicker.entry.js +1 -1
  144. package/dist/esm-es5/wm-input.entry.js +1 -1
  145. package/dist/esm-es5/wm-modal-footer.entry.js +1 -1
  146. package/dist/esm-es5/wm-modal-header.entry.js +1 -1
  147. package/dist/esm-es5/wm-modal.entry.js +1 -1
  148. package/dist/esm-es5/wm-navigation_3.entry.js +1 -1
  149. package/dist/esm-es5/wm-navigator.entry.js +1 -1
  150. package/dist/esm-es5/wm-network-uploader.entry.js +1 -1
  151. package/dist/esm-es5/wm-option_2.entry.js +1 -1
  152. package/dist/esm-es5/wm-pagination.entry.js +1 -1
  153. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -1
  154. package/dist/esm-es5/wm-search.entry.js +1 -1
  155. package/dist/esm-es5/wm-snackbar.entry.js +1 -1
  156. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -1
  157. package/dist/esm-es5/wm-tag-input.entry.js +1 -1
  158. package/dist/esm-es5/wm-timepicker.entry.js +1 -1
  159. package/dist/esm-es5/wm-toggletip.entry.js +1 -1
  160. package/dist/esm-es5/wm-uploader.entry.js +1 -1
  161. package/dist/esm-es5/wm-wrapper.entry.js +1 -1
  162. package/dist/ripple/{p-1ccd994d.system.entry.js → p-06012eb7.system.entry.js} +1 -1
  163. package/dist/ripple/{p-06adbeb9.system.entry.js → p-07ebdcd4.system.entry.js} +1 -1
  164. package/dist/ripple/{p-f5df5903.system.js → p-08b7ec08.system.js} +0 -0
  165. package/dist/ripple/{p-7173b0a7.system.entry.js → p-08fc668c.system.entry.js} +1 -1
  166. package/dist/ripple/p-0e22a3a4.entry.js +1 -0
  167. package/dist/ripple/p-262c75ff.entry.js +1 -0
  168. package/dist/ripple/{p-2193190b.js → p-26f94f8f.js} +1 -1
  169. package/dist/ripple/{p-90ed3268.system.entry.js → p-27253ed2.system.entry.js} +1 -1
  170. package/dist/ripple/{p-0556279c.system.entry.js → p-2af0b657.system.entry.js} +1 -1
  171. package/dist/ripple/p-2e5cb321.entry.js +1 -0
  172. package/dist/ripple/{p-9d02957d.system.js → p-313b6073.system.js} +0 -0
  173. package/dist/ripple/{p-6bf5cbf4.system.entry.js → p-3e875e87.system.entry.js} +1 -1
  174. package/dist/ripple/p-4073ac6a.entry.js +1 -0
  175. package/dist/ripple/p-410687ea.entry.js +1 -0
  176. package/dist/ripple/p-41374812.system.js +1 -0
  177. package/dist/ripple/p-42dbd978.entry.js +1 -0
  178. package/dist/ripple/{p-752da0fb.system.entry.js → p-4439bdd1.system.entry.js} +1 -1
  179. package/dist/ripple/{p-bbcafbd6.system.entry.js → p-4650a83c.system.entry.js} +1 -1
  180. package/dist/ripple/{p-4ecd3430.js → p-490dafa4.js} +1 -1
  181. package/dist/ripple/p-4afa52d4.entry.js +1 -0
  182. package/dist/ripple/p-4f3f7b2b.entry.js +1 -0
  183. package/dist/ripple/p-5018f8ae.entry.js +1 -0
  184. package/dist/ripple/{p-cd3d74d1.system.entry.js → p-57a718f0.system.entry.js} +1 -1
  185. package/dist/ripple/p-57c94258.entry.js +1 -0
  186. package/dist/ripple/{p-1df2adee.system.entry.js → p-59678b70.system.entry.js} +1 -1
  187. package/dist/ripple/p-626d5017.entry.js +1 -0
  188. package/dist/ripple/{p-3a535823.system.js → p-6a8fd452.system.js} +1 -1
  189. package/dist/ripple/{p-c1443a0e.system.entry.js → p-6ffdab0d.system.entry.js} +1 -1
  190. package/dist/ripple/p-70d0e993.js +1 -0
  191. package/dist/ripple/{p-a0c3ef16.system.js → p-726b9452.system.js} +1 -1
  192. package/dist/ripple/p-758501d7.entry.js +1 -0
  193. package/dist/ripple/{p-af3ce4fc.system.entry.js → p-7cb0035a.system.entry.js} +1 -1
  194. package/dist/ripple/p-80a00759.entry.js +1 -0
  195. package/dist/ripple/p-80b62707.entry.js +1 -0
  196. package/dist/ripple/{p-995ba16f.system.entry.js → p-84d0d2ff.system.entry.js} +1 -1
  197. package/dist/ripple/p-86b9bfcf.system.entry.js +1 -0
  198. package/dist/ripple/{p-43f1298b.js → p-888bec42.js} +0 -0
  199. package/dist/ripple/p-8a2cabf2.entry.js +1 -0
  200. package/dist/ripple/{p-62eac2d6.system.entry.js → p-8b54c589.system.entry.js} +1 -1
  201. package/dist/ripple/{p-7ef6a7cf.system.entry.js → p-910b6dd5.system.entry.js} +1 -1
  202. package/dist/ripple/p-962f51ff.entry.js +1 -0
  203. package/dist/ripple/p-97683ddc.entry.js +1 -0
  204. package/dist/ripple/p-9c60325b.entry.js +1 -0
  205. package/dist/ripple/{p-fd8070fb.js → p-a6d6eae7.js} +0 -0
  206. package/dist/ripple/p-b0536ddb.entry.js +1 -0
  207. package/dist/ripple/{p-d48c56c7.system.entry.js → p-b4837126.system.entry.js} +1 -1
  208. package/dist/ripple/{p-04d8b674.system.js → p-b5b7c71f.system.js} +1 -1
  209. package/dist/ripple/{p-8612829b.system.entry.js → p-b793bc6f.system.entry.js} +1 -1
  210. package/dist/ripple/p-c2abdcba.js +1 -0
  211. package/dist/ripple/{p-04e44b30.system.entry.js → p-c49ef079.system.entry.js} +1 -1
  212. package/dist/ripple/{p-895f5ec5.system.entry.js → p-c4c21c82.system.entry.js} +1 -1
  213. package/dist/ripple/p-c656fcf1.entry.js +1 -0
  214. package/dist/ripple/p-caef11cc.entry.js +1 -0
  215. package/dist/ripple/p-cb357a84.entry.js +1 -0
  216. package/dist/ripple/p-d2a11410.entry.js +1 -0
  217. package/dist/ripple/{p-49fd7ede.system.entry.js → p-d927de70.system.entry.js} +1 -1
  218. package/dist/ripple/{p-ae6cfbca.system.entry.js → p-db44eb6f.system.entry.js} +1 -1
  219. package/dist/ripple/p-db899686.system.js +1 -0
  220. package/dist/ripple/{p-f23b3986.system.entry.js → p-dc7e5609.system.entry.js} +1 -1
  221. package/dist/ripple/p-dfa80ed1.entry.js +1 -0
  222. package/dist/ripple/p-e012273a.entry.js +1 -0
  223. package/dist/ripple/p-e4cb8aad.entry.js +1 -0
  224. package/dist/ripple/{p-e4439bc3.system.entry.js → p-f0d3ceb1.system.entry.js} +1 -1
  225. package/dist/ripple/{p-3b3e847c.system.entry.js → p-f17076c4.system.entry.js} +1 -1
  226. package/dist/ripple/p-fa632547.entry.js +1 -0
  227. package/dist/ripple/{p-0e9ccc6f.system.entry.js → p-fe4c1194.system.entry.js} +1 -1
  228. package/dist/ripple/{p-ca383a43.system.entry.js → p-ffc34819.system.entry.js} +1 -1
  229. package/dist/ripple/ripple.esm.js +1 -1
  230. package/dist/ripple/ripple.js +1 -1
  231. package/dist/types/components/charts/priv-chart-popover/priv-chart-popover.d.ts +27 -27
  232. package/dist/types/components/charts/wm-chart/wm-chart-slice.d.ts +11 -11
  233. package/dist/types/components/charts/wm-chart/wm-chart.d.ts +36 -36
  234. package/dist/types/components/charts/wm-progress-monitor/wm-progress-indicator.d.ts +27 -27
  235. package/dist/types/components/charts/wm-progress-monitor/wm-progress-monitor.d.ts +17 -17
  236. package/dist/types/components/charts/wm-progress-monitor/wm-progress-slice.d.ts +10 -10
  237. package/dist/types/components/wm-action-menu/wm-action-menu.d.ts +47 -47
  238. package/dist/types/components/wm-button/wm-button.d.ts +43 -43
  239. package/dist/types/components/wm-datepicker/priv-datepicker/priv-datepicker.d.ts +80 -80
  240. package/dist/types/components/wm-datepicker/wm-datepicker.d.ts +41 -41
  241. package/dist/types/components/wm-input/wm-input.d.ts +46 -46
  242. package/dist/types/components/wm-menuitem/wm-menuitem.d.ts +34 -34
  243. package/dist/types/components/wm-modal/wm-modal-footer.d.ts +14 -14
  244. package/dist/types/components/wm-modal/wm-modal-header.d.ts +11 -11
  245. package/dist/types/components/wm-modal/wm-modal.d.ts +41 -41
  246. package/dist/types/components/wm-navigation/wm-navigation-hamburger.d.ts +21 -21
  247. package/dist/types/components/wm-navigation/wm-navigation-item.d.ts +13 -13
  248. package/dist/types/components/wm-navigation/wm-navigation.d.ts +28 -28
  249. package/dist/types/components/wm-navigator/priv-navigator-button/priv-navigator-button.d.ts +10 -10
  250. package/dist/types/components/wm-navigator/priv-navigator-item/priv-navigator-item.d.ts +13 -13
  251. package/dist/types/components/wm-navigator/wm-navigator.d.ts +61 -61
  252. package/dist/types/components/wm-option/wm-option.d.ts +35 -35
  253. package/dist/types/components/wm-pagination/wm-pagination.d.ts +32 -32
  254. package/dist/types/components/wm-search/wm-search.d.ts +86 -86
  255. package/dist/types/components/wm-select/wm-select.d.ts +94 -93
  256. package/dist/types/components/wm-snackbar/wm-snackbar.d.ts +35 -35
  257. package/dist/types/components/wm-tabs/wm-tab-item/wm-tab-item.d.ts +38 -38
  258. package/dist/types/components/wm-tabs/wm-tab-list/wm-tab-list.d.ts +53 -53
  259. package/dist/types/components/wm-tabs/wm-tab-panel/wm-tab-panel.d.ts +20 -20
  260. package/dist/types/components/wm-tag-input/wm-tag-input.d.ts +92 -92
  261. package/dist/types/components/wm-timepicker/wm-timepicker.d.ts +61 -61
  262. package/dist/types/components/wm-toggletip/wm-toggletip.d.ts +27 -27
  263. package/dist/types/components/wm-uploader/wm-network-uploader/wm-network-uploader.d.ts +85 -85
  264. package/dist/types/components/wm-uploader/wm-uploader.d.ts +118 -119
  265. package/dist/types/components/wm-wrapper/wm-wrapper.d.ts +7 -7
  266. package/dist/types/components.d.ts +26 -26
  267. package/dist/types/global/__mocks__/functions.d.ts +6 -6
  268. package/dist/types/global/chartFunctions.d.ts +29 -29
  269. package/dist/types/global/functions.d.ts +42 -42
  270. package/dist/types/global/global.d.ts +1 -1
  271. package/dist/types/global/interfaces.d.ts +44 -44
  272. package/dist/types/global/services/__mocks__/http-service.d.ts +6 -6
  273. package/dist/types/global/services/http-service.d.ts +4 -4
  274. package/dist/types/lang/lang.d.ts +5 -5
  275. package/package.json +47 -47
  276. package/dist/esm-es5/functions-036af8dc.js +0 -15
  277. package/dist/ripple/p-17ceb8c1.entry.js +0 -1
  278. package/dist/ripple/p-1887286e.entry.js +0 -1
  279. package/dist/ripple/p-1d795f42.entry.js +0 -1
  280. package/dist/ripple/p-2996bfe6.entry.js +0 -1
  281. package/dist/ripple/p-2f860b24.entry.js +0 -1
  282. package/dist/ripple/p-358bde27.entry.js +0 -1
  283. package/dist/ripple/p-3680b55d.entry.js +0 -1
  284. package/dist/ripple/p-3a1d6fc4.entry.js +0 -1
  285. package/dist/ripple/p-4d59fe86.entry.js +0 -1
  286. package/dist/ripple/p-6aa6a818.entry.js +0 -1
  287. package/dist/ripple/p-726c979a.system.js +0 -15
  288. package/dist/ripple/p-7ae1a630.entry.js +0 -1
  289. package/dist/ripple/p-7ecbf258.entry.js +0 -1
  290. package/dist/ripple/p-7fae0cc2.entry.js +0 -1
  291. package/dist/ripple/p-8de546e8.entry.js +0 -1
  292. package/dist/ripple/p-93dee724.entry.js +0 -1
  293. package/dist/ripple/p-97c2b06f.entry.js +0 -1
  294. package/dist/ripple/p-9ae81a59.system.js +0 -1
  295. package/dist/ripple/p-9c92c93f.entry.js +0 -1
  296. package/dist/ripple/p-9e09d7a1.entry.js +0 -1
  297. package/dist/ripple/p-a04ba6c8.entry.js +0 -1
  298. package/dist/ripple/p-a9e0ce88.entry.js +0 -1
  299. package/dist/ripple/p-b3c71506.js +0 -1
  300. package/dist/ripple/p-bee0b62d.entry.js +0 -1
  301. package/dist/ripple/p-da403a48.system.entry.js +0 -1
  302. package/dist/ripple/p-de3367ee.js +0 -16
  303. package/dist/ripple/p-e083fca6.entry.js +0 -1
  304. package/dist/ripple/p-e524d462.entry.js +0 -1
  305. package/dist/ripple/p-e8d39f68.entry.js +0 -1
  306. package/dist/ripple/p-ed91be1a.entry.js +0 -1
  307. package/dist/ripple/p-fda61e7e.entry.js +0 -1
  308. package/dist/ripple/p-fe952112.entry.js +0 -1
@@ -1,718 +1,725 @@
1
- import { r as registerInstance, c as createEvent, h, H as Host, g as getElement, f as forceUpdate } from './index-7603f98e.js';
2
- import { i as intl, d as debounce, g as generateId, l as shouldOpenUp, q as getTextDir } from './functions-036af8dc.js';
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement, f as forceUpdate } from './index-17c79cc6.js';
2
+ import { i as intl, d as debounce, g as generateId, l as shouldOpenUp, q as getTextDir } from './functions-11c0c4e2.js';
3
3
 
4
- const wmOptionCss = ":host(:not(:last-child)),wm-option:not(:last-child){border-bottom:2px solid rgba(46, 27, 70, 0.05)}:host,wm-option{display:block;cursor:pointer;position:relative;padding:1.25rem;background:#fff;font-family:inherit;list-style:none;color:#4a4a4a;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host:focus,:host.focus,wm-option:focus,wm-option.focus{outline:none;background:#f4f4f4}:host.icon,wm-option.icon{color:#575195}.checkbox:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f131\";display:inline;margin-right:0.25rem;color:#575195}:host([aria-selected=true]),wm-option[aria-selected=true]{background:rgba(46, 27, 70, 0.05);font-weight:500}:host([aria-selected=true]) .checkbox:before,wm-option[aria-selected=true] .checkbox:before{content:\"\\f132\"}:host([aria-disabled=true]),wm-option[aria-disabled=true]{font-style:italic;color:#6b6b6b;cursor:default}:host([aria-disabled=true]) .checkbox:before,wm-option[aria-disabled=true] .checkbox:before{color:#6b6b6b}:host(.multi-option),wm-option.multi-option{background:unset}:host(.hidden),wm-option.hidden,:host(.filtered-out),wm-option.filtered-out{display:none}:host(.duplicate.last),wm-option.duplicate.last{border-bottom:12px solid rgba(46, 27, 70, 0.05)}:host(.hassubinfo),wm-option.hassubinfo{display:-ms-flexbox;display:flex}:host(.hassubinfo) .option-wrapper,wm-option.hassubinfo .option-wrapper{-ms-flex:1;flex:1}:host(.hassubinfo) .subinfo,wm-option.hassubinfo .subinfo{-ms-flex:none;flex:none}.subinfo{font-style:italic}.option-wrapper{display:inline-block}::slotted{font-family:inherit}::slotted(i){font-size:0.875rem}::slotted(i):before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:inline-block;margin-right:0.625rem;pointer-events:none}:host(:focus),wm-option:focus{outline:none;background:#f4f4f4}:host(:hover){background:#f4f4f4;outline:none}";
4
+ const wmOptionCss = ":host(:not(:last-child)),wm-option:not(:last-child){border-bottom:2px solid rgba(46, 27, 70, 0.05)}:host,wm-option{display:block;cursor:pointer;position:relative;padding:1.25rem;background:#fff;font-family:inherit;list-style:none;color:#4a4a4a;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host:focus,:host.focus,wm-option:focus,wm-option.focus{outline:none;background:#f4f4f4}:host.icon,wm-option.icon{color:#575195}:host .sr-only,wm-option .sr-only{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;border:0 !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;white-space:nowrap !important;margin:-1px !important}.checkbox:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f131\";display:inline;margin-right:0.25rem;color:#575195}:host([aria-selected=true]),wm-option[aria-selected=true]{background:rgba(46, 27, 70, 0.05);font-weight:500}:host([aria-selected=true]) .checkbox:before,wm-option[aria-selected=true] .checkbox:before{content:\"\\f132\"}:host([aria-disabled=true]),wm-option[aria-disabled=true]{font-style:italic;color:#6b6b6b;cursor:default}:host([aria-disabled=true]) .checkbox:before,wm-option[aria-disabled=true] .checkbox:before{color:#6b6b6b}:host(.multi-option),wm-option.multi-option{background:unset}:host(.hidden),wm-option.hidden,:host(.filtered-out),wm-option.filtered-out{display:none}:host(.duplicate.last),wm-option.duplicate.last{border-bottom:12px solid rgba(46, 27, 70, 0.05)}:host(.hassubinfo),wm-option.hassubinfo{display:-ms-flexbox;display:flex}:host(.hassubinfo) .option-wrapper,wm-option.hassubinfo .option-wrapper{-ms-flex:1;flex:1}:host(.hassubinfo) .subinfo,wm-option.hassubinfo .subinfo{-ms-flex:none;flex:none}.subinfo{font-style:italic}.option-wrapper{display:inline-block}::slotted{font-family:inherit}::slotted(i){font-size:0.875rem}::slotted(i):before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:inline-block;margin-right:0.625rem;pointer-events:none}:host(:focus),wm-option:focus{outline:none;background:#f4f4f4}:host(:hover){background:#f4f4f4;outline:none}";
5
5
 
6
- let Option = class {
7
- constructor(hostRef) {
8
- registerInstance(this, hostRef);
9
- this.wmOptionSelected = createEvent(this, "wmOptionSelected", 7);
10
- this.wmKeyUpPressed = createEvent(this, "wmKeyUpPressed", 7);
11
- this.wmKeyDownPressed = createEvent(this, "wmKeyDownPressed", 7);
12
- this.wmEscKeyPressed = createEvent(this, "wmEscKeyPressed", 7);
13
- this.wmHomeKeyPressed = createEvent(this, "wmHomeKeyPressed", 7);
14
- this.wmEndKeyPressed = createEvent(this, "wmEndKeyPressed", 7);
15
- this.wmEnterKeyPressed = createEvent(this, "wmEnterKeyPressed", 7);
16
- this.wmLetterPressed = createEvent(this, "wmLetterPressed", 7);
17
- this.wmOptionBlurred = createEvent(this, "wmOptionBlurred", 7);
18
- this.subinfo = undefined;
19
- this.disabled = false;
20
- this.selected = false;
21
- this.focused = false;
22
- this.searchTerm = "";
23
- }
24
- get hostClasses() {
25
- let classes = [];
26
- if (this.subinfo) {
27
- classes.push("hassubinfo");
28
- }
29
- if (this.parentSelectEl.multiple) {
30
- classes.push("multi-option");
31
- }
32
- if (!this.el.textContent.toLowerCase().includes(this.searchTerm)) {
33
- classes.push("filtered-out");
34
- }
35
- return classes.join(" ");
36
- }
37
- get parentSelectEl() {
38
- var _a;
39
- return ((_a = this.el.parentElement) === null || _a === void 0 ? void 0 : _a.nodeName) !== "WM-SELECT"
40
- ? this.el.getRootNode().host
41
- : this.el.parentElement;
42
- }
43
- handleKeydown(ev) {
44
- switch (ev.key) {
45
- case "ArrowUp":
46
- ev.preventDefault();
47
- this.wmKeyUpPressed.emit(this.el);
48
- break;
49
- case "ArrowDown":
50
- ev.preventDefault();
51
- this.wmKeyDownPressed.emit(this.el);
52
- break;
53
- case "Enter":
54
- ev.preventDefault();
55
- if (!this.disabled) {
56
- this.el.click();
57
- this.wmEnterKeyPressed.emit(this.el);
58
- }
59
- break;
60
- case " ":
61
- ev.preventDefault();
62
- this.el.click();
63
- break;
64
- case "Escape":
65
- ev.preventDefault();
66
- ev.stopPropagation(); // for instance if select is in a modal, esc should close the select but not the modal
67
- this.wmEscKeyPressed.emit();
68
- break;
69
- case "Home":
70
- ev.preventDefault();
71
- this.wmHomeKeyPressed.emit();
72
- break;
73
- case "End":
74
- ev.preventDefault();
75
- this.wmEndKeyPressed.emit();
76
- break;
77
- default:
78
- this.wmLetterPressed.emit(ev.key);
79
- }
80
- }
81
- handleSelection() {
82
- if (!this.disabled) {
83
- this.wmOptionSelected.emit(this.el);
84
- // the parent wm-select is in charge of the actual selection
85
- }
86
- }
87
- handleBlur(ev) {
88
- this.wmOptionBlurred.emit({ relatedTarget: ev.relatedTarget });
89
- }
90
- syncAriaSelected() {
91
- // this function only keeps the aria-selected attr in sync with the selected prop
92
- // all the logic for selecting / deselecting happens in the parent wm-select
93
- this.selected ? this.el.setAttribute("aria-selected", "true") : this.el.removeAttribute("aria-selected");
94
- }
95
- syncAriaDisabled() {
96
- this.disabled ? this.el.setAttribute("aria-disabled", "true") : this.el.removeAttribute("aria-disabled");
97
- }
98
- focusHandler(newValue) {
99
- if (newValue)
100
- this.el.focus();
101
- }
102
- updateDisabledOnClick() {
103
- if (this.disabled && this.el.onclick) {
104
- this.onClickFunc = this.el.onclick;
105
- this.el.onclick = null;
106
- }
107
- else if (!this.disabled && this.onClickFunc) {
108
- this.el.onclick = this.onClickFunc;
109
- }
110
- }
111
- handleSearch(ev) {
112
- // filter is case-insensitive, so
113
- this.searchTerm = ev.detail.searchTerm.toLowerCase();
114
- const regexp = new RegExp(`${this.searchTerm}`, "gi");
115
- const boldedText = this.el.textContent.replace(regexp, (match) => `<b>${match}</b>`);
116
- this.textEl.innerHTML = `<span>${boldedText}</span>`;
117
- }
118
- componentWillLoad() {
119
- this.syncAriaSelected();
120
- this.syncAriaDisabled();
121
- this.updateDisabledOnClick();
122
- this.parentSelectEl.addEventListener("wmSelectSearchChanged", (ev) => this.handleSearch(ev));
123
- }
124
- render() {
125
- return (h(Host, { role: "option", tabindex: this.focused ? 0 : -1, class: this.hostClasses }, h("div", { class: `option-wrapper ${this.parentSelectEl.multiple ? "checkbox" : ""}`, ref: (el) => (this.textEl = el) }, h("slot", null)), h("div", { class: "subinfo" }, this.subinfo)));
126
- }
127
- get el() { return getElement(this); }
128
- static get watchers() { return {
129
- "selected": ["syncAriaSelected"],
130
- "disabled": ["syncAriaDisabled", "updateDisabledOnClick"],
131
- "focused": ["focusHandler"]
132
- }; }
133
- };
6
+ const Option = class {
7
+ constructor(hostRef) {
8
+ registerInstance(this, hostRef);
9
+ this.wmOptionSelected = createEvent(this, "wmOptionSelected", 7);
10
+ this.wmKeyUpPressed = createEvent(this, "wmKeyUpPressed", 7);
11
+ this.wmKeyDownPressed = createEvent(this, "wmKeyDownPressed", 7);
12
+ this.wmEscKeyPressed = createEvent(this, "wmEscKeyPressed", 7);
13
+ this.wmHomeKeyPressed = createEvent(this, "wmHomeKeyPressed", 7);
14
+ this.wmEndKeyPressed = createEvent(this, "wmEndKeyPressed", 7);
15
+ this.wmEnterKeyPressed = createEvent(this, "wmEnterKeyPressed", 7);
16
+ this.wmLetterPressed = createEvent(this, "wmLetterPressed", 7);
17
+ this.wmOptionBlurred = createEvent(this, "wmOptionBlurred", 7);
18
+ this.subinfo = undefined;
19
+ this.disabled = false;
20
+ this.selected = false;
21
+ this.focused = false;
22
+ this.searchTerm = "";
23
+ }
24
+ get hostClasses() {
25
+ let classes = [];
26
+ if (this.subinfo) {
27
+ classes.push("hassubinfo");
28
+ }
29
+ if (this.parentSelectEl.multiple) {
30
+ classes.push("multi-option");
31
+ }
32
+ if (!this.el.textContent.toLowerCase().includes(this.searchTerm)) {
33
+ classes.push("filtered-out");
34
+ }
35
+ return classes.join(" ");
36
+ }
37
+ get parentSelectEl() {
38
+ var _a;
39
+ return ((_a = this.el.parentElement) === null || _a === void 0 ? void 0 : _a.nodeName) !== "WM-SELECT"
40
+ ? this.el.getRootNode().host
41
+ : this.el.parentElement;
42
+ }
43
+ handleKeydown(ev) {
44
+ switch (ev.key) {
45
+ case "ArrowUp":
46
+ ev.preventDefault();
47
+ this.wmKeyUpPressed.emit(this.el);
48
+ break;
49
+ case "ArrowDown":
50
+ ev.preventDefault();
51
+ this.wmKeyDownPressed.emit(this.el);
52
+ break;
53
+ case "Enter":
54
+ ev.preventDefault();
55
+ if (!this.disabled) {
56
+ this.el.click();
57
+ this.wmEnterKeyPressed.emit(this.el);
58
+ }
59
+ break;
60
+ case " ":
61
+ ev.preventDefault();
62
+ this.el.click();
63
+ break;
64
+ case "Escape":
65
+ ev.preventDefault();
66
+ ev.stopPropagation(); // for instance if select is in a modal, esc should close the select but not the modal
67
+ this.wmEscKeyPressed.emit();
68
+ break;
69
+ case "Home":
70
+ ev.preventDefault();
71
+ this.wmHomeKeyPressed.emit();
72
+ break;
73
+ case "End":
74
+ ev.preventDefault();
75
+ this.wmEndKeyPressed.emit();
76
+ break;
77
+ default:
78
+ this.wmLetterPressed.emit(ev.key);
79
+ }
80
+ }
81
+ handleSelection() {
82
+ if (!this.disabled) {
83
+ this.wmOptionSelected.emit(this.el);
84
+ // the parent wm-select is in charge of the actual selection
85
+ }
86
+ }
87
+ handleBlur(ev) {
88
+ this.wmOptionBlurred.emit({ relatedTarget: ev.relatedTarget });
89
+ }
90
+ syncAriaSelected() {
91
+ // this function only keeps the aria-selected attr in sync with the selected prop
92
+ // all the logic for selecting / deselecting happens in the parent wm-select
93
+ this.selected ? this.el.setAttribute("aria-selected", "true") : this.el.removeAttribute("aria-selected");
94
+ }
95
+ syncAriaDisabled() {
96
+ this.disabled ? this.el.setAttribute("aria-disabled", "true") : this.el.removeAttribute("aria-disabled");
97
+ }
98
+ focusHandler(newValue) {
99
+ if (newValue)
100
+ this.el.focus();
101
+ }
102
+ updateDisabledOnClick() {
103
+ if (this.disabled && this.el.onclick) {
104
+ this.onClickFunc = this.el.onclick;
105
+ this.el.onclick = null;
106
+ }
107
+ else if (!this.disabled && this.onClickFunc) {
108
+ this.el.onclick = this.onClickFunc;
109
+ }
110
+ }
111
+ handleSearch(ev) {
112
+ // filter is case-insensitive, so
113
+ this.searchTerm = ev.detail.searchTerm.toLowerCase();
114
+ if (this.searchTerm) {
115
+ const regexp = new RegExp(`${this.searchTerm}`, "gi");
116
+ const boldedText = this.el.textContent.replace(regexp, (match) => `<strong>${match}</strong>`);
117
+ // for voiceover, text splitting is read as separate phrases. i.e. hel<b>lo</b> will be read as "hel lo"
118
+ // aria-hidden and sr-only is used to circumvent this
119
+ this.textEl.innerHTML = boldedText;
120
+ }
121
+ else {
122
+ this.textEl.innerHTML = this.el.textContent;
123
+ }
124
+ }
125
+ componentWillLoad() {
126
+ this.syncAriaSelected();
127
+ this.syncAriaDisabled();
128
+ this.updateDisabledOnClick();
129
+ this.parentSelectEl.addEventListener("wmSelectSearchChanged", (ev) => this.handleSearch(ev));
130
+ }
131
+ render() {
132
+ return (h(Host, { role: "option", tabindex: this.focused ? 0 : -1, class: this.hostClasses }, h("div", { class: `option-wrapper ${this.parentSelectEl.multiple ? "checkbox" : ""}` }, h("span", { "aria-hidden": "true", ref: (el) => (this.textEl = el) }, this.el.textContent), h("span", { class: "sr-only" }, this.el.textContent)), h("div", { class: "subinfo" }, this.subinfo)));
133
+ }
134
+ get el() { return getElement(this); }
135
+ static get watchers() { return {
136
+ "selected": ["syncAriaSelected"],
137
+ "disabled": ["syncAriaDisabled", "updateDisabledOnClick"],
138
+ "focused": ["focusHandler"]
139
+ }; }
140
+ };
134
141
  Option.style = wmOptionCss;
135
142
 
136
- const wmSelectCss = ":host{position:relative;display:block;-webkit-box-sizing:border-box;box-sizing:border-box;font-family:inherit}:host .sr-only{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;border:0 !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;white-space:nowrap !important;margin:-1px !important}.wrapper{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;font-size:0.875rem}.wrapper .label{display:block;line-height:normal;font-weight:600;white-space:nowrap;margin-bottom:0.25rem}.wrapper .label .required{color:#c0392b}.wrapper.label-left{-ms-flex-direction:row;flex-direction:row}.wrapper.label-left .label-wrapper{line-height:2.5rem}.wrapper.label-left .label-wrapper .label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;min-height:2.5rem;white-space:normal;margin-bottom:0;margin-right:0.75rem}.wrapper.label-none label{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;border:0 !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;white-space:nowrap !important;margin:-1px !important}.wrapper.invalid .label{color:#c0392b}.wrapper.invalid .label:after{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f026\";margin-left:0.3125rem}[dir=RTL] .wrapper.invalid .label:after{margin-left:0;margin-right:0.3125rem}.wrapper.rtl.label-left .label{margin-right:0;margin-left:0.75rem}.wrapper .button-wrapper{position:relative;-ms-flex:1;flex:1;font-size:1.125rem;color:#575195;min-width:8.75rem}.wrapper .button-wrapper .displayedoption{-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-wrap:nowrap;flex-wrap:nowrap;background:transparent;width:100%;border:solid 1px rgba(35, 35, 35, 0.6);padding:0 1.875rem 0 0.9375rem;cursor:pointer;height:2.5rem;line-height:normal;font-family:inherit;color:#575195;font-weight:400;font-size:0.875rem;text-transform:none;text-align:left}@media only screen and (max-width: 768px){.wrapper .button-wrapper .displayedoption{height:2.75rem}}.wrapper .button-wrapper .displayedoption:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f140\";position:absolute;right:0.5625rem;pointer-events:none}.wrapper .button-wrapper .displayedoption:hover:not(:disabled):not(.-disabled):not(.-raised){background:transparent;text-decoration:none}.wrapper .button-wrapper .displayedoption:active{-ms-transform:scale(1, 1) !important;-webkit-transform:scale(1, 1) !important;transform:scale(1, 1) !important}.wrapper .button-wrapper .displayedoption:focus{outline:none}.wrapper .button-wrapper .displayedoption::-moz-focus-inner{border:0}.wrapper .button-wrapper .displayedoption.user-is-tabbing:focus{-webkit-box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e;-moz-box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e;box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e}.wrapper .button-wrapper .displayedoption.user-is-tabbing:focus::-moz-focus-inner{border:0}.wrapper .button-wrapper .displayedoption .overflowcontrol{display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-ms-flex:1;flex:1}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo{display:-ms-flexbox;display:flex}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo .button-text{-ms-flex:1;flex:1;text-overflow:ellipsis;overflow:hidden;min-width:0}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo .subinfo{-ms-flex:none;flex:none;font-style:italic}.wrapper .button-wrapper .displayedoption .overflow-counter{font-weight:bold;margin-left:0.5rem}.wrapper .button-wrapper>.displayedoption[disabled]{color:#6b6b6b;border-color:#8a8a8a;background:#f0f0f0;cursor:default}.wrapper .button-wrapper>.dropdown{-webkit-overflow-scrolling:touch;overflow:auto;max-height:12.5rem;-webkit-box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);-moz-box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);-ms-transition:transform 0.25s ease;-webkit-transition:transform 0.25s ease;-moz-transition:transform 0.25s ease;-webkit-transition:-webkit-transform 0.25s ease;transition:-webkit-transform 0.25s ease;transition:transform 0.25s ease;transition:transform 0.25s ease, -webkit-transform 0.25s ease;-ms-transform:scale(1, 0);-webkit-transform:scale(1, 0);-moz-transform:scale(1, 0);transform:scale(1, 0);-ms-transform-origin:center top;-webkit-transform-origin:center top;-moz-transform-origin:center top;transform-origin:center top;-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;position:absolute;top:0;right:0;background:#fff;z-index:100;width:100%;font-size:0.875rem}.wrapper .button-wrapper>.dropdown.upwards{top:unset;bottom:calc(100% - 2.5rem);-ms-transform-origin:center bottom;-webkit-transform-origin:center bottom;-moz-transform-origin:center bottom;transform-origin:center bottom}.wrapper .button-wrapper>.dropdown.hidden{visibility:hidden}.wrapper .button-wrapper>.dropdown.open{-ms-transform:scale(1, 1);-webkit-transform:scale(1, 1);-moz-transform:scale(1, 1);transform:scale(1, 1)}.wrapper.invalid .button-wrapper .displayedoption{-webkit-box-shadow:0 0 0 1px #c0392b;-moz-box-shadow:0 0 0 1px #c0392b;box-shadow:0 0 0 1px #c0392b;border-color:#c0392b}.wrapper .error-message{color:#c0392b;font-size:0.875rem;margin-top:0.25rem;margin-bottom:0.25rem;display:block;top:100%;left:0;font-style:italic}.search{-webkit-box-sizing:border-box;box-sizing:border-box;border-bottom:2px solid rgba(46, 27, 70, 0.05);padding:1.25rem}.search .searchfield-wrapper{-webkit-box-sizing:border-box;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;height:2.75rem;width:100%;padding:0 0.75rem;-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;border:1px solid #4a4a4a}.search .searchfield-wrapper:focus,.search .searchfield-wrapper.focus{-webkit-box-shadow:0 0 0 1px #20cbd4;-moz-box-shadow:0 0 0 1px #20cbd4;box-shadow:0 0 0 1px #20cbd4;outline:none;border-color:#20cbd4}.search .searchfield{width:100%;border:none;outline:none;font-family:inherit;font-size:0.875rem;margin-left:0.25rem}.search .icon:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f349\";color:#6b6b6b;font-size:0.875rem}.search-results-message{padding:1.25rem;color:#4a4a4a;font-size:0.875rem;font-style:italic}.rtl>.dropdown{-ms-transform-origin:left top;-webkit-transform-origin:left top;-moz-transform-origin:left top;transform-origin:left top;left:0;right:auto}.rtl>.dropdown .option{padding-left:3rem;padding-right:1.25rem}.rtl>.displayedoption{padding:0 0.9375rem 0 1.875rem;text-align:right}.rtl>.displayedoption:before{right:auto;left:0.5625rem}";
143
+ const wmSelectCss = ":host{position:relative;display:block;-webkit-box-sizing:border-box;box-sizing:border-box;font-family:inherit}:host .sr-only{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;border:0 !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;white-space:nowrap !important;margin:-1px !important}.wrapper{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;font-size:0.875rem}.wrapper .label{display:block;line-height:normal;font-weight:600;white-space:nowrap;margin-bottom:0.25rem}.wrapper .label .required{color:#c0392b}.wrapper.label-left{-ms-flex-direction:row;flex-direction:row}.wrapper.label-left .label-wrapper{line-height:2.5rem}.wrapper.label-left .label-wrapper .label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;min-height:2.5rem;white-space:normal;margin-bottom:0;margin-right:0.75rem}.wrapper.label-none label{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;border:0 !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;-webkit-clip-path:inset(50%) !important;clip-path:inset(50%) !important;white-space:nowrap !important;margin:-1px !important}.wrapper.invalid .label{color:#c0392b}.wrapper.invalid .label:after{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f026\";margin-left:0.3125rem}[dir=RTL] .wrapper.invalid .label:after{margin-left:0;margin-right:0.3125rem}.wrapper.rtl.label-left .label{margin-right:0;margin-left:0.75rem}.wrapper .button-wrapper{position:relative;-ms-flex:1;flex:1;font-size:1.125rem;color:#575195;min-width:8.75rem}.wrapper .button-wrapper .displayedoption{-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-wrap:nowrap;flex-wrap:nowrap;background:transparent;width:100%;border:solid 1px rgba(35, 35, 35, 0.6);padding:0 1.875rem 0 0.9375rem;cursor:pointer;height:2.5rem;line-height:normal;font-family:inherit;color:#575195;font-weight:400;font-size:0.875rem;text-transform:none;text-align:left}@media only screen and (max-width: 768px){.wrapper .button-wrapper .displayedoption{height:2.75rem}}.wrapper .button-wrapper .displayedoption:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f140\";position:absolute;right:0.5625rem;pointer-events:none}.wrapper .button-wrapper .displayedoption:hover:not(:disabled):not(.-disabled):not(.-raised){background:transparent;text-decoration:none}.wrapper .button-wrapper .displayedoption:active{-ms-transform:scale(1, 1) !important;-webkit-transform:scale(1, 1) !important;transform:scale(1, 1) !important}.wrapper .button-wrapper .displayedoption:focus{outline:none}.wrapper .button-wrapper .displayedoption::-moz-focus-inner{border:0}.wrapper .button-wrapper .displayedoption.user-is-tabbing:focus{-webkit-box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e;-moz-box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e;box-shadow:0 2px 2px 0 rgba(244, 243, 246, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.1), 0 0 4px 3px #61279e}.wrapper .button-wrapper .displayedoption.user-is-tabbing:focus::-moz-focus-inner{border:0}.wrapper .button-wrapper .displayedoption .overflowcontrol{display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-ms-flex:1;flex:1}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo{display:-ms-flexbox;display:flex}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo .button-text{-ms-flex:1;flex:1;text-overflow:ellipsis;overflow:hidden;min-width:0}.wrapper .button-wrapper .displayedoption .overflowcontrol.hassubinfo .subinfo{-ms-flex:none;flex:none;font-style:italic}.wrapper .button-wrapper .displayedoption .overflow-counter{font-weight:bold;margin-left:0.5rem}.wrapper .button-wrapper>.displayedoption[disabled]{color:#6b6b6b;border-color:#8a8a8a;background:#f0f0f0;cursor:default}.wrapper .button-wrapper>.dropdown{-webkit-overflow-scrolling:touch;-webkit-box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);-moz-box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);box-shadow:0 4px 15px 0 rgba(0, 0, 0, 0.2);-ms-transition:transform 0.25s ease;-webkit-transition:transform 0.25s ease;-moz-transition:transform 0.25s ease;-webkit-transition:-webkit-transform 0.25s ease;transition:-webkit-transform 0.25s ease;transition:transform 0.25s ease;transition:transform 0.25s ease, -webkit-transform 0.25s ease;-ms-transform:scale(1, 0);-webkit-transform:scale(1, 0);-moz-transform:scale(1, 0);transform:scale(1, 0);-ms-transform-origin:center top;-webkit-transform-origin:center top;-moz-transform-origin:center top;transform-origin:center top;-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;position:absolute;top:0;right:0;background:#fff;z-index:100;width:100%;font-size:0.875rem}.wrapper .button-wrapper>.dropdown.upwards{top:unset;bottom:calc(100% - 2.5rem);-ms-transform-origin:center bottom;-webkit-transform-origin:center bottom;-moz-transform-origin:center bottom;transform-origin:center bottom}.wrapper .button-wrapper>.dropdown.hidden{visibility:hidden}.wrapper .button-wrapper>.dropdown.open{-ms-transform:scale(1, 1);-webkit-transform:scale(1, 1);-moz-transform:scale(1, 1);transform:scale(1, 1)}.wrapper.invalid .button-wrapper .displayedoption{-webkit-box-shadow:0 0 0 1px #c0392b;-moz-box-shadow:0 0 0 1px #c0392b;box-shadow:0 0 0 1px #c0392b;border-color:#c0392b}.wrapper .error-message{color:#c0392b;font-size:0.875rem;margin-top:0.25rem;margin-bottom:0.25rem;display:block;top:100%;left:0;font-style:italic}.options-wrapper{max-height:12.5rem;overflow:auto}.search{-webkit-box-sizing:border-box;box-sizing:border-box;border-bottom:2px solid rgba(46, 27, 70, 0.05);padding:1.25rem}.search .searchfield-wrapper{-webkit-box-sizing:border-box;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;height:2.75rem;width:100%;padding:0 0.75rem;-webkit-border-radius:3px;-moz-border-radius:3px;-ms-border-radius:3px;border-radius:3px;border:1px solid #4a4a4a}.search .searchfield-wrapper:focus,.search .searchfield-wrapper.focus{-webkit-box-shadow:0 0 0 1px #20cbd4;-moz-box-shadow:0 0 0 1px #20cbd4;box-shadow:0 0 0 1px #20cbd4;outline:none;border-color:#20cbd4}.search .searchfield{width:100%;border:none;outline:none;font-family:inherit;font-size:0.875rem;margin-left:0.25rem}.search .icon:before{display:inline-block;font:normal normal normal 24px/1 \"Material Design Icons\";font-size:inherit;text-rendering:auto;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;content:\"\\f349\";color:#6b6b6b;font-size:0.875rem}.search-results-message{padding:1.25rem;color:#4a4a4a;font-size:0.875rem;font-style:italic}.rtl>.dropdown{-ms-transform-origin:left top;-webkit-transform-origin:left top;-moz-transform-origin:left top;transform-origin:left top;left:0;right:auto}.rtl>.dropdown .option{padding-left:3rem;padding-right:1.25rem}.rtl>.displayedoption{padding:0 0.9375rem 0 1.875rem;text-align:right}.rtl>.displayedoption:before{right:auto;left:0.5625rem}";
137
144
 
138
- let Select = class {
139
- constructor(hostRef) {
140
- registerInstance(this, hostRef);
141
- this.wmSelectDidLoad = createEvent(this, "wmSelectDidLoad", 7);
142
- this.wmSelectBlurred = createEvent(this, "wmSelectBlurred", 7);
143
- this.wmComponentBlurred = createEvent(this, "wmComponentBlurred", 7);
144
- this.wmSelectSearchChanged = createEvent(this, "wmSelectSearchChanged", 7);
145
- this.disabled = false;
146
- this.invalid = false;
147
- this.labelPosition = "top";
148
- this.requiredField = false;
149
- this.errorMessage = "";
150
- this.multiple = false;
151
- this.search = false;
152
- this.placeholder = intl.formatMessage({
153
- id: "select.multiPlaceholder",
154
- defaultMessage: "Make a selection",
155
- description: "Placeholder text. Use imperative",
156
- });
157
- this.searchPlaceholder = intl.formatMessage({
158
- id: "select.searchPlaceholder",
159
- defaultMessage: "Search",
160
- description: "Placeholder text. Use imperative",
161
- });
162
- this.allSelectedMessage = intl.formatMessage({
163
- id: "select.allSelected",
164
- defaultMessage: "All selected",
165
- description: "Text displayed when all options are selected",
166
- });
167
- this.requiredMessage = intl.formatMessage({
168
- id: "global.requiredField",
169
- defaultMessage: "required field",
170
- });
171
- this.isTabbing = false;
172
- this.isExpanded = false;
173
- this.announcement = "";
174
- this.keysSoFar = "";
175
- this.searchIndex = 0;
176
- this.keyClear = null;
177
- this.openUp = false;
178
- //////////////////////////////////////
179
- //////////////////////////////////////
180
- // for multiselect button text
181
- this.overflowCount = 0;
182
- this.displayedOptions = [];
183
- this.debouncedSearch = debounce(() => {
184
- this.wmSelectSearchChanged.emit({ searchTerm: this.searchTerm });
185
- if (this.filteredOptions.length) {
186
- this.announce(this.resultsFoundMessage);
187
- }
188
- else {
189
- this.announce(this.noResultsFoundMessage);
190
- }
191
- }, 150);
192
- }
193
- get childOptions() {
194
- return Array.from(this.el.querySelectorAll("wm-option"));
195
- }
196
- get duplicateOptions() {
197
- return Array.from(this.el.shadowRoot.querySelectorAll("wm-option"));
198
- }
199
- get allOptionEls() {
200
- // this includes both slotted wm-options and internally created wm-options
201
- return this.duplicateOptions.concat(this.childOptions);
202
- }
203
- get visibleOptionEls() {
204
- return this.allOptionEls.filter((option) => !option.classList.contains("hidden") && !option.classList.contains("filtered-out"));
205
- }
206
- //////////////////////////////////////
207
- // for search variants
208
- get searchTerm() {
209
- return this.searchFieldEl ? this.searchFieldEl.value : "";
210
- }
211
- get filteredOptions() {
212
- return this.childOptions.filter((option) => { var _a; return (_a = option.textContent) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(this.searchTerm.toLowerCase()); });
213
- }
214
- get selectedOptions() {
215
- return Array.from(this.el.querySelectorAll("wm-option")).filter((x) => x.selected);
216
- }
217
- get allSelected() {
218
- return this.childOptions.filter((option) => option.selected).length === this.childOptions.length;
219
- }
220
- //////////////////////////////////////
221
- get resultsFoundMessage() {
222
- return intl.formatMessage({
223
- id: "select.searchResultsFound",
224
- defaultMessage: "{numResults, plural, one {1 option found} other {# options found}}",
225
- description: "The message read by the screen reader, indicating how many results a search returned",
226
- }, { numResults: this.filteredOptions.length });
227
- }
228
- get noResultsFoundMessage() {
229
- return intl.formatMessage({
230
- id: "select.noSearchResults",
231
- defaultMessage: "No results found. Please try your search again.",
232
- description: "The message displayed when no options pass the search filter",
233
- });
234
- }
235
- toggleTabbingOn() {
236
- this.isTabbing = true;
237
- }
238
- toggleTabbingOff() {
239
- this.isTabbing = false;
240
- }
241
- handleOptionSelection(ev) {
242
- if (!this.multiple) {
243
- // ensure only one option is selected at a time, unselect all other options
244
- this.childOptions.forEach((option) => (option.selected = option === ev.detail));
245
- }
246
- this.focusOption(ev.detail);
247
- this.selectOption(ev.detail);
248
- if (!this.multiple) {
249
- this.close();
250
- }
251
- }
252
- handleChildEnter() {
253
- // only occurs for multiselects. handle the click, then close
254
- this.close();
255
- }
256
- handleChildUp(ev) {
257
- this.moveUp(ev.detail);
258
- }
259
- handleChildDown(ev) {
260
- this.moveDown(ev.detail);
261
- }
262
- moveToFirstOption() {
263
- this.focusOption(this.visibleOptionEls[0]);
264
- }
265
- moveToLastOption() {
266
- this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
267
- }
268
- closePopupOnEscape() {
269
- this.close();
270
- }
271
- handleOptionBlur(ev) {
272
- // if the Option is blurred to something other than the component emit a blur event with the appropriate relatedTarget
273
- // keeps our component's blur events accurate, and closes when focusing browser address bar
274
- if (!this.isElOrChild(ev.detail.relatedTarget)) {
275
- const event = new CustomEvent("blur");
276
- // @ts-ignore
277
- event.relatedTarget = ev.detail.relatedTarget;
278
- this.el.dispatchEvent(event);
279
- }
280
- }
281
- handleClick(ev) {
282
- if (!this.isElOrChild(ev.target)) {
283
- this.close();
284
- }
285
- }
286
- handleButtonBlur(ev) {
287
- if (this.isElOrChild(ev.relatedTarget)) {
288
- // do not emit a blur event when opening the dropdown and focusing the Options
289
- ev.stopPropagation();
290
- }
291
- }
292
- handleSearchFieldBlur(ev) {
293
- this.searchFieldWrapperEl.classList.remove("focus");
294
- if (this.isElOrChild(ev.relatedTarget)) {
295
- // do not emit a blur event when moving from searchfield to options
296
- ev.stopPropagation();
297
- }
298
- }
299
- handleKey(ev) {
300
- switch (ev.key) {
301
- case "ArrowDown":
302
- if (this.isExpanded === false) {
303
- ev.preventDefault();
304
- this.open("next");
305
- }
306
- break;
307
- case "ArrowUp":
308
- if (this.isExpanded === false) {
309
- ev.preventDefault();
310
- this.open("previous");
311
- }
312
- break;
313
- }
314
- }
315
- componentWillLoad() {
316
- if (!this.label) {
317
- console.error("For accessibility purposes, this component requires a label (even if `label-position` is set to `none`).");
318
- }
319
- this.el.focus = function () {
320
- if (!this.disabled) {
321
- this.shadowRoot.querySelector("button").focus();
322
- }
323
- };
324
- this.uid = this.el.id ? this.el.id : generateId();
325
- if (document.body.classList.contains("wmcl-user-is-tabbing")) {
326
- this.toggleTabbingOn();
327
- }
328
- // set initial selections
329
- if (this.selectedOptions.length > 0) {
330
- this.selectedOptions.forEach((x) => {
331
- this.displayedOptions.push(x);
332
- });
333
- // single Select only, pre-select if no default option from dev
334
- }
335
- else if (!this.multiple) {
336
- this.selectOption(this.allOptionEls[0]);
337
- }
338
- }
339
- componentDidLoad() {
340
- this.wmSelectDidLoad.emit();
341
- if (this.multiple && this.allOptionEls.filter((x) => x.subinfo).length > 0) {
342
- throw new Error("wm-select with the multiple prop cannot have subinfo options");
343
- }
344
- if (this.multiple && !this.placeholder) {
345
- throw new Error("wm-select with the multiple prop needs to also use the placeholder prop.");
346
- }
347
- this.dropdownEl.classList.add("hidden");
348
- forceUpdate(this.el);
349
- // Dev can overwrite the max-height rule set in the Sass file
350
- if (this.maxHeight) {
351
- this.dropdownEl.style.maxHeight = this.maxHeight;
352
- }
353
- const mutationObserver = new MutationObserver(() => this.handleSelectedMutation());
354
- mutationObserver.observe(this.el, {
355
- attributes: true,
356
- attributeFilter: ["selected"],
357
- subtree: true,
358
- });
359
- if (this.multiple) {
360
- this.updateOptionVisibility();
361
- }
362
- this.setButtonText();
363
- }
364
- componentWillUpdate() {
365
- if (this.multiple) {
366
- // find last visible duplicate option and apply .last class
367
- const visibleDuplicateOptions = this.visibleOptionEls.filter((option) => option.classList.contains("duplicate"));
368
- visibleDuplicateOptions.forEach((option, idx) => {
369
- if (idx === visibleDuplicateOptions.length - 1) {
370
- option.classList.add("last");
371
- }
372
- else {
373
- option.classList.remove("last");
374
- }
375
- });
376
- }
377
- }
378
- handleSelectedMutation() {
379
- // dispatch change event after selected options change
380
- // mutation observer prevents emitting event when an already selected option is selected again
381
- const event = new CustomEvent("change");
382
- // @ts-ignore
383
- this.el.dispatchEvent(event);
384
- }
385
- moveUp(el) {
386
- const prevEl = this.visibleOptionEls[this.visibleOptionEls.indexOf(el) - 1];
387
- if (prevEl) {
388
- // scroll option to top of dropdown if partially obscured / out of view
389
- if (prevEl.getBoundingClientRect().top < this.dropdownEl.getBoundingClientRect().top) {
390
- this.scrollOptionToTop(prevEl);
391
- }
392
- this.focusOption(prevEl);
393
- }
394
- else if (this.search) {
395
- // if top of list and search variant, focus search field
396
- this.searchFieldEl.focus();
397
- }
398
- else {
399
- // if top of list, focus last element
400
- this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
401
- }
402
- }
403
- moveDown(el) {
404
- const nextEl = this.visibleOptionEls[this.visibleOptionEls.indexOf(el) + 1];
405
- if (nextEl) {
406
- // scroll option to bottom of dropdown if partially obscured / out of view
407
- if (nextEl.getBoundingClientRect().bottom > this.dropdownEl.getBoundingClientRect().bottom) {
408
- this.scrollOptionToBottom(nextEl);
409
- }
410
- this.focusOption(nextEl);
411
- }
412
- else {
413
- // if end of list, focus first option in all variants
414
- this.focusOption(this.visibleOptionEls[0]);
415
- }
416
- }
417
- scrollOptionToTop(option) {
418
- this.dropdownEl.scrollTop =
419
- option.getBoundingClientRect().top - this.dropdownEl.getBoundingClientRect().top + this.dropdownEl.scrollTop;
420
- }
421
- scrollOptionToBottom(option) {
422
- this.dropdownEl.scrollTop =
423
- option.getBoundingClientRect().bottom -
424
- this.dropdownEl.getBoundingClientRect().top +
425
- this.dropdownEl.scrollTop -
426
- this.dropdownEl.offsetHeight;
427
- }
428
- open(optionToSelect) {
429
- if (!this.disabled) {
430
- const elHeight = this.el.clientHeight;
431
- const buttonHeight = this.buttonEl.clientHeight;
432
- this.openUp = shouldOpenUp(this.el, this.dropdownEl,
433
- // when opening up, dropdown covers both label and button
434
- elHeight,
435
- // when opening down, dropdown covers only the button
436
- buttonHeight);
437
- this.isExpanded = true;
438
- this.dropdownEl.classList.remove("hidden");
439
- window.requestAnimationFrame(() => {
440
- switch (optionToSelect) {
441
- case "next":
442
- // search variant focuses search field
443
- // all others focus option "after" last selected option (this can be the first option)
444
- if (this.search) {
445
- this.searchFieldEl.focus();
446
- this.dropdownEl.scrollTop = 0;
447
- }
448
- else {
449
- this.moveDown(this.visibleOptionEls.filter((x) => x.selected).slice(-1)[0]);
450
- }
451
- break;
452
- case "previous":
453
- // search variant focuses last option
454
- // all others focus option "above" first selected option (this can be the last option)
455
- if (this.search) {
456
- this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
457
- }
458
- else {
459
- this.moveUp(this.visibleOptionEls.filter((x) => x.selected)[0]);
460
- }
461
- break;
462
- default:
463
- // search variant focuses search field
464
- // all others focus the selected option
465
- // if no option is selected (empty multiselect), focuses first option
466
- if (this.search) {
467
- this.searchFieldEl.focus();
468
- this.dropdownEl.scrollTop = 0;
469
- }
470
- else if (this.selectedOptions.length > 0) {
471
- this.focusOption(this.visibleOptionEls.filter((x) => x.selected)[0]);
472
- }
473
- else {
474
- this.focusOption(this.visibleOptionEls[0]);
475
- }
476
- break;
477
- }
478
- });
479
- }
480
- }
481
- close(returnFocus = true) {
482
- if (this.isExpanded) {
483
- this.isExpanded = false;
484
- this.allOptionEls.map((i) => (i.focused = false));
485
- window.setTimeout(() => {
486
- this.dropdownEl.classList.add("hidden");
487
- if (this.multiple) {
488
- this.updateOptionVisibility();
489
- }
490
- // clear search field, reset filtered / bolded state of wm-options
491
- if (this.search) {
492
- this.searchFieldEl.value = "";
493
- this.wmSelectSearchChanged.emit({ searchTerm: this.searchTerm });
494
- }
495
- // Returns focus to button after popup closes (no need if user is tabbing)
496
- // Delay is necessary for screenreader to get new expanded state before focus
497
- // window.requestAnimationFrame is probably enough, but since we are already using setTimeout it may as well be here
498
- // also UX wise, it makes sense for the button to only be focused after the animation is complete
499
- if (returnFocus) {
500
- this.el.focus();
501
- }
502
- }, 150);
503
- }
504
- }
505
- updateOptionVisibility() {
506
- // this runs for search multiselects, where selected options are rendered at the top of the dropdown list
507
- // slotted wm-options are hidden if selected, and duplicate wm-options are made visible if selected
508
- this.childOptions.forEach((option, idx) => {
509
- const duplicateOption = this.duplicateOptions[idx];
510
- if (option.selected) {
511
- option.classList.add("hidden");
512
- duplicateOption.classList.remove("hidden");
513
- }
514
- else {
515
- option.classList.remove("hidden");
516
- duplicateOption.classList.add("hidden");
517
- }
518
- });
519
- }
520
- focusOption(option) {
521
- this.allOptionEls.forEach((i) => (i.focused = i === option));
522
- option.focus();
523
- }
524
- selectOption(option) {
525
- // this function does not necessarily change an options selected property to true
526
- // in cases of multiselect, it toggles the selected property
527
- if (option.classList.contains("duplicate")) {
528
- // if clicking on a duplicate option, toggle selected property of real one, then rerender
529
- const correspondingOption = this.findCorrespondingOption(option);
530
- correspondingOption.selected = !correspondingOption.selected;
531
- forceUpdate(this.el);
532
- }
533
- else if (this.multiple) {
534
- option.selected = !option.selected;
535
- }
536
- else {
537
- this.allOptionEls.forEach((x) => (x.selected = x === option));
538
- }
539
- this.setButtonText();
540
- }
541
- findAndFocusOption(ev) {
542
- const character = ev.detail.toUpperCase();
543
- if (!this.keysSoFar) {
544
- for (var i = 0; i < this.allOptionEls.length; i++) {
545
- if (this.allOptionEls[i].focused) {
546
- this.searchIndex = i;
547
- }
548
- }
549
- }
550
- this.keysSoFar += character;
551
- this.clearKeysSoFarAfterDelay();
552
- var nextMatch = this.findMatchInRange(this.allOptionEls, this.searchIndex + 1, this.allOptionEls.length);
553
- if (!nextMatch) {
554
- nextMatch = this.findMatchInRange(this.allOptionEls, 0, this.searchIndex);
555
- }
556
- if (nextMatch) {
557
- this.focusOption(nextMatch);
558
- }
559
- }
560
- clearKeysSoFarAfterDelay() {
561
- if (this.keyClear) {
562
- window.clearTimeout(this.keyClear);
563
- this.keyClear = null;
564
- }
565
- this.keyClear = window.setTimeout(function () {
566
- this.keysSoFar = "";
567
- this.keyClear = null;
568
- }.bind(this), 500);
569
- }
570
- findMatchInRange(list, startIndex, endIndex) {
571
- // Find the first option starting with the keysSoFar substring, searching in
572
- // the specified range of options
573
- for (var n = startIndex; n < endIndex; n++) {
574
- var label = list[n].textContent;
575
- if (label && label.toUpperCase().indexOf(this.keysSoFar) === 0) {
576
- return list[n];
577
- }
578
- }
579
- return null;
580
- }
581
- findCorrespondingOption(el) {
582
- // if duplicate, returns the child wm-option
583
- // if child wm-option, returns duplicate
584
- const isDuplicate = el.classList.contains("duplicate");
585
- return isDuplicate
586
- ? this.childOptions[this.duplicateOptions.indexOf(el)]
587
- : this.duplicateOptions[this.childOptions.indexOf(el)];
588
- }
589
- isElOrChild(el) {
590
- var _a;
591
- // determines whether or not the element is the component, a child of the component, or exists within the component's shadowroot
592
- return el === this.el || this.el.contains(el) || ((_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(el));
593
- }
594
- exposeErrors() {
595
- // When the error changes, a new id is set for the error container and the button's aria-describedby attribute is updated accordingly. This is to make sure the screen reader announces teh updated errors in Firefox. See this longstanding bug: https://bugzilla.mozilla.org/show_bug.cgi?id=493683
596
- const newId = generateId();
597
- this.errorContainer.id = `wm-errors-${newId}`;
598
- this.buttonEl.setAttribute("aria-describedby", `wm-errors-${newId}`);
599
- }
600
- renderErrorContainer() {
601
- return (h("div", { id: "wm-errors", class: this.errorMessage ? "error-message" : "", ref: (el) => (this.errorContainer = el), "aria-live": "assertive", "aria-atomic": "true" }, this.errorMessage));
602
- }
603
- handleComponentBlur(ev) {
604
- // Do not close or emit custom blur event when blurring to an element inside (wm-option)
605
- if (!this.el.contains(ev.relatedTarget)) {
606
- this.close(false);
607
- this.wmSelectBlurred.emit();
608
- this.wmComponentBlurred.emit(); // deprecated
609
- }
610
- }
611
- handleSearchFieldKeyDown(ev) {
612
- switch (ev.key) {
613
- case "ArrowDown":
614
- ev.preventDefault();
615
- if (this.visibleOptionEls.length) {
616
- this.focusOption(this.visibleOptionEls[0]);
617
- }
618
- break;
619
- case "ArrowUp":
620
- ev.preventDefault();
621
- if (this.visibleOptionEls.length) {
622
- this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
623
- }
624
- break;
625
- case "Escape":
626
- ev.preventDefault();
627
- this.close();
628
- break;
629
- }
630
- }
631
- setButtonText() {
632
- this.displayedOptions = this.childOptions
633
- .filter((x) => x.selected)
634
- .map((y) => (!y.classList.contains("hidden") ? y : this.findCorrespondingOption(y)));
635
- // handle overflow + counter for multiselect
636
- if (this.multiple) {
637
- // this is a fixed measurement accounting for the max width of a 3 character overflow counter
638
- const overflowCounterWidth = 38;
639
- const computedStyle = window.getComputedStyle(this.buttonEl);
640
- // there seems to be no quick way to get an elements width without padding, except for subtracting padding manually
641
- const paddingLeft = parseInt(computedStyle.getPropertyValue("padding-left").slice(0, -2));
642
- const paddingRight = parseInt(computedStyle.getPropertyValue("padding-right").slice(0, -2));
643
- const availableSpace = this.buttonEl.clientWidth - paddingLeft - paddingRight - overflowCounterWidth;
644
- let optionsWidths = this.displayedOptions.map((x) => x.shadowRoot.querySelector(".option-wrapper").clientWidth);
645
- let optionsTotalWidth = optionsWidths.reduce((acc, x) => acc + x, 0);
646
- this.overflowCount = 0;
647
- while (optionsTotalWidth > availableSpace && this.displayedOptions.length > 1) {
648
- this.overflowCount++;
649
- optionsTotalWidth -= optionsWidths[optionsWidths.length - 1];
650
- optionsWidths.pop();
651
- this.displayedOptions.pop();
652
- }
653
- }
654
- }
655
- announce(message) {
656
- // \u00A0 is a non-breaking space character, which causes the message to be read as a new one
657
- if (this.liveRegionEl.textContent === message) {
658
- message += "\u00A0";
659
- }
660
- this.announcement = message;
661
- }
662
- renderButtonText() {
663
- if (this.multiple && this.displayedOptions.length < 1) {
664
- return h("span", null, this.placeholder);
665
- }
666
- else if (this.multiple && this.allSelected && this.overflowCount > 0) {
667
- return this.allSelectedMessage;
668
- }
669
- else {
670
- return this.displayedOptions.map((x, idx) => (h("span", null, idx > 0 ? ", " : "", x.textContent)));
671
- }
672
- }
673
- renderSubinfo() {
674
- // multiselects cannot have subinfo for options
675
- if (!this.multiple && this.selectedOptions.length > 0 && this.selectedOptions[0].subinfo) {
676
- return h("span", { class: "subinfo" }, this.selectedOptions[0].subinfo);
677
- }
678
- }
679
- renderOverflowCount() {
680
- if (this.overflowCount > 0 && !this.allSelected) {
681
- return (h("span", null, h("span", { class: "overflow-counter" }, "+", this.overflowCount)));
682
- }
683
- }
684
- renderSearchField() {
685
- return (h("div", { class: "search" }, h("div", { class: "searchfield-wrapper", ref: (el) => (this.searchFieldWrapperEl = el) }, h("div", { class: "icon" }), h("input", { ref: (el) => (this.searchFieldEl = el), class: "searchfield", role: "combobox", "aria-controls": `list-${this.uid}`, "aria-expanded": this.isExpanded ? "true" : "false", onKeyDown: (ev) => this.handleSearchFieldKeyDown(ev), onFocus: () => this.searchFieldWrapperEl.classList.add("focus"), onBlur: (ev) => this.handleSearchFieldBlur(ev), onInput: () => this.debouncedSearch(), placeholder: this.searchPlaceholder }))));
686
- }
687
- renderSearchFailedMessage() {
688
- return h("div", { class: "search-results-message" }, this.noResultsFoundMessage);
689
- }
690
- renderDuplicateOptions() {
691
- return Array.from(this.el.children).map((option) => {
692
- return (h("wm-option", { class: "duplicate", selected: option.selected }, option.textContent));
693
- });
694
- }
695
- render() {
696
- const buttonProps = {
697
- id: `selectbtn-${this.uid}`,
698
- ["disabled"]: this.disabled,
699
- ["aria-controls"]: `list-${this.uid}`,
700
- ["aria-labelledby"]: `label-${this.uid} selectbtn-${this.uid}`,
701
- ["aria-describedby"]: "wm-errors",
702
- ["aria-expanded"]: this.isExpanded ? "true" : "false",
703
- onClick: () => (this.isExpanded ? this.close() : this.open()),
704
- };
705
- return (h(Host, { onBlur: (ev) => this.handleComponentBlur(ev) }, h("div", { class: `wrapper ${getTextDir()} label-${this.labelPosition} ${this.invalid || this.errorMessage ? "invalid" : ""}` }, h("div", { class: "label-wrapper" }, h("label", { class: "label", id: `label-${this.uid}`, htmlFor: `selectbtn-${this.uid}` }, this.label,
706
- // we can't use aria-required or required attributes because it's invalid on the elements we're using (button controlling a listbox)
707
- this.requiredField ? (h("span", { class: "required" }, h("span", { class: "sr-only" }, this.requiredMessage), h("span", { "aria-hidden": "true" }, "*"))) : (""))), h("div", { class: "button-wrapper" }, h("button", Object.assign({}, buttonProps, { class: `displayedoption ${this.isTabbing ? "user-is-tabbing" : ""}`, ref: (el) => (this.buttonEl = el), onBlur: (ev) => this.handleButtonBlur(ev), onFocus: () => this.close() }), h("span", { class: this.selectedOptions.length > 0 && this.selectedOptions.filter((x) => x.subinfo).length > 0
708
- ? "overflowcontrol hassubinfo"
709
- : "overflowcontrol" }, h("span", { class: "button-text" }, this.renderButtonText()), this.renderSubinfo()), this.renderOverflowCount()), h("div", { class: `dropdown ${this.isExpanded ? "open" : ""} ${this.openUp ? "upwards" : ""}`, ref: (el) => (this.dropdownEl = el) }, this.search && this.renderSearchField(), h("div", { id: `list-${this.uid}`, tabindex: -1, role: "listbox", "aria-multiselectable": this.multiple ? "true" : null, "aria-labelledby": `label-${this.uid}` }, this.search && this.filteredOptions.length === 0 && this.renderSearchFailedMessage(), this.multiple && this.renderDuplicateOptions(), h("slot", null))), this.renderErrorContainer(), h("div", { "aria-live": "polite", class: "sr-only", ref: (el) => (this.liveRegionEl = el) }, this.announcement)))));
710
- }
711
- get el() { return getElement(this); }
712
- static get watchers() { return {
713
- "errorMessage": ["exposeErrors"]
714
- }; }
715
- };
145
+ const Select = class {
146
+ constructor(hostRef) {
147
+ registerInstance(this, hostRef);
148
+ this.wmSelectDidLoad = createEvent(this, "wmSelectDidLoad", 7);
149
+ this.wmSelectBlurred = createEvent(this, "wmSelectBlurred", 7);
150
+ this.wmComponentBlurred = createEvent(this, "wmComponentBlurred", 7);
151
+ this.wmSelectSearchChanged = createEvent(this, "wmSelectSearchChanged", 7);
152
+ this.disabled = false;
153
+ this.invalid = false;
154
+ this.labelPosition = "top";
155
+ this.requiredField = false;
156
+ this.errorMessage = "";
157
+ this.multiple = false;
158
+ this.search = false;
159
+ this.placeholder = intl.formatMessage({
160
+ id: "select.multiPlaceholder",
161
+ defaultMessage: "Make a selection",
162
+ description: "Placeholder text. Use imperative",
163
+ });
164
+ this.searchPlaceholder = intl.formatMessage({
165
+ id: "select.searchPlaceholder",
166
+ defaultMessage: "Search",
167
+ description: "Placeholder text. Use imperative",
168
+ });
169
+ this.allSelectedMessage = intl.formatMessage({
170
+ id: "select.allSelected",
171
+ defaultMessage: "All selected",
172
+ description: "Text displayed when all options are selected",
173
+ });
174
+ this.requiredMessage = intl.formatMessage({
175
+ id: "global.requiredField",
176
+ defaultMessage: "required field",
177
+ });
178
+ this.isTabbing = false;
179
+ this.isExpanded = false;
180
+ this.announcement = "";
181
+ this.keysSoFar = "";
182
+ this.searchIndex = 0;
183
+ this.keyClear = null;
184
+ this.openUp = false;
185
+ //////////////////////////////////////
186
+ //////////////////////////////////////
187
+ // for multiselect button text
188
+ this.overflowCount = 0;
189
+ this.displayedOptions = [];
190
+ this.debouncedSearch = debounce(() => {
191
+ this.wmSelectSearchChanged.emit({ searchTerm: this.searchTerm });
192
+ if (this.filteredOptions.length) {
193
+ this.announce(this.resultsFoundMessage);
194
+ }
195
+ else {
196
+ this.announce(this.noResultsFoundMessage);
197
+ }
198
+ }, 150);
199
+ }
200
+ get childOptions() {
201
+ return Array.from(this.el.querySelectorAll("wm-option"));
202
+ }
203
+ get duplicateOptions() {
204
+ return Array.from(this.el.shadowRoot.querySelectorAll("wm-option"));
205
+ }
206
+ get allOptionEls() {
207
+ // this includes both slotted wm-options and internally created wm-options
208
+ return this.duplicateOptions.concat(this.childOptions);
209
+ }
210
+ get visibleOptionEls() {
211
+ return this.allOptionEls.filter((option) => !option.classList.contains("hidden") && !option.classList.contains("filtered-out"));
212
+ }
213
+ //////////////////////////////////////
214
+ // for search variants
215
+ get searchTerm() {
216
+ return this.searchFieldEl ? this.searchFieldEl.value : "";
217
+ }
218
+ get filteredOptions() {
219
+ return this.childOptions.filter((option) => { var _a; return (_a = option.textContent) === null || _a === void 0 ? void 0 : _a.toLowerCase().includes(this.searchTerm.toLowerCase()); });
220
+ }
221
+ get selectedOptions() {
222
+ return Array.from(this.el.querySelectorAll("wm-option")).filter((x) => x.selected);
223
+ }
224
+ get allSelected() {
225
+ return this.childOptions.filter((option) => option.selected).length === this.childOptions.length;
226
+ }
227
+ //////////////////////////////////////
228
+ get resultsFoundMessage() {
229
+ return intl.formatMessage({
230
+ id: "select.searchResultsFound",
231
+ defaultMessage: "{numResults, plural, one {1 option found} other {# options found}}",
232
+ description: "The message read by the screen reader, indicating how many results a search returned",
233
+ }, { numResults: this.filteredOptions.length });
234
+ }
235
+ get noResultsFoundMessage() {
236
+ return intl.formatMessage({
237
+ id: "select.noSearchResults",
238
+ defaultMessage: "No results found. Please try your search again.",
239
+ description: "The message displayed when no options pass the search filter",
240
+ });
241
+ }
242
+ toggleTabbingOn() {
243
+ this.isTabbing = true;
244
+ }
245
+ toggleTabbingOff() {
246
+ this.isTabbing = false;
247
+ }
248
+ handleOptionSelection(ev) {
249
+ if (!this.multiple) {
250
+ // ensure only one option is selected at a time, unselect all other options
251
+ this.childOptions.forEach((option) => (option.selected = option === ev.detail));
252
+ }
253
+ this.focusOption(ev.detail);
254
+ this.selectOption(ev.detail);
255
+ if (!this.multiple) {
256
+ this.close();
257
+ }
258
+ }
259
+ handleChildEnter() {
260
+ // only occurs for multiselects. handle the click, then close
261
+ this.close();
262
+ }
263
+ handleChildUp(ev) {
264
+ this.moveUp(ev.detail);
265
+ }
266
+ handleChildDown(ev) {
267
+ this.moveDown(ev.detail);
268
+ }
269
+ moveToFirstOption() {
270
+ this.focusOption(this.visibleOptionEls[0]);
271
+ }
272
+ moveToLastOption() {
273
+ this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
274
+ }
275
+ closePopupOnEscape() {
276
+ this.close();
277
+ }
278
+ handleOptionBlur(ev) {
279
+ // if the Option is blurred to something other than the component emit a blur event with the appropriate relatedTarget
280
+ // keeps our component's blur events accurate, and closes when focusing browser address bar
281
+ if (!this.isElOrChild(ev.detail.relatedTarget)) {
282
+ const event = new CustomEvent("blur");
283
+ // @ts-ignore
284
+ event.relatedTarget = ev.detail.relatedTarget;
285
+ this.el.dispatchEvent(event);
286
+ }
287
+ }
288
+ handleClick(ev) {
289
+ if (!this.isElOrChild(ev.target)) {
290
+ this.close();
291
+ }
292
+ }
293
+ handleButtonBlur(ev) {
294
+ if (this.isElOrChild(ev.relatedTarget)) {
295
+ // do not emit a blur event when opening the dropdown and focusing the Options
296
+ ev.stopPropagation();
297
+ }
298
+ }
299
+ handleSearchFieldBlur(ev) {
300
+ this.searchFieldWrapperEl.classList.remove("focus");
301
+ if (this.isElOrChild(ev.relatedTarget)) {
302
+ // do not emit a blur event when moving from searchfield to options
303
+ ev.stopPropagation();
304
+ }
305
+ }
306
+ handleKey(ev) {
307
+ switch (ev.key) {
308
+ case "ArrowDown":
309
+ if (this.isExpanded === false) {
310
+ ev.preventDefault();
311
+ this.open("next");
312
+ }
313
+ break;
314
+ case "ArrowUp":
315
+ if (this.isExpanded === false) {
316
+ ev.preventDefault();
317
+ this.open("previous");
318
+ }
319
+ break;
320
+ }
321
+ }
322
+ componentWillLoad() {
323
+ if (!this.label) {
324
+ console.error("For accessibility purposes, this component requires a label (even if `label-position` is set to `none`).");
325
+ }
326
+ this.el.focus = function () {
327
+ if (!this.disabled) {
328
+ this.shadowRoot.querySelector("button").focus();
329
+ }
330
+ };
331
+ this.uid = this.el.id ? this.el.id : generateId();
332
+ if (document.body.classList.contains("wmcl-user-is-tabbing")) {
333
+ this.toggleTabbingOn();
334
+ }
335
+ // set initial selections
336
+ if (this.selectedOptions.length > 0) {
337
+ this.selectedOptions.forEach((x) => {
338
+ this.displayedOptions.push(x);
339
+ });
340
+ // single Select only, pre-select if no default option from dev
341
+ }
342
+ else if (!this.multiple) {
343
+ this.selectOption(this.allOptionEls[0]);
344
+ }
345
+ }
346
+ componentDidLoad() {
347
+ this.wmSelectDidLoad.emit();
348
+ if (this.multiple && this.allOptionEls.filter((x) => x.subinfo).length > 0) {
349
+ throw new Error("wm-select with the multiple prop cannot have subinfo options");
350
+ }
351
+ if (this.multiple && !this.placeholder) {
352
+ throw new Error("wm-select with the multiple prop needs to also use the placeholder prop.");
353
+ }
354
+ this.dropdownEl.classList.add("hidden");
355
+ forceUpdate(this.el);
356
+ // Dev can overwrite the max-height rule set in the Sass file
357
+ if (this.maxHeight) {
358
+ this.listboxEl.style.maxHeight = this.maxHeight;
359
+ }
360
+ const mutationObserver = new MutationObserver(() => this.handleSelectedMutation());
361
+ mutationObserver.observe(this.el, {
362
+ attributes: true,
363
+ attributeFilter: ["selected"],
364
+ subtree: true,
365
+ });
366
+ if (this.multiple) {
367
+ this.updateOptionVisibility();
368
+ }
369
+ this.setButtonText();
370
+ }
371
+ componentWillUpdate() {
372
+ if (this.multiple) {
373
+ // find last visible duplicate option and apply .last class
374
+ const visibleDuplicateOptions = this.visibleOptionEls.filter((option) => option.classList.contains("duplicate"));
375
+ visibleDuplicateOptions.forEach((option, idx) => {
376
+ if (idx === visibleDuplicateOptions.length - 1) {
377
+ option.classList.add("last");
378
+ }
379
+ else {
380
+ option.classList.remove("last");
381
+ }
382
+ });
383
+ }
384
+ }
385
+ handleSelectedMutation() {
386
+ // dispatch change event after selected options change
387
+ // mutation observer prevents emitting event when an already selected option is selected again
388
+ const event = new CustomEvent("change");
389
+ // @ts-ignore
390
+ this.el.dispatchEvent(event);
391
+ }
392
+ moveUp(el) {
393
+ const prevEl = this.visibleOptionEls[this.visibleOptionEls.indexOf(el) - 1];
394
+ if (prevEl) {
395
+ // scroll option to top of dropdown if partially obscured / out of view
396
+ if (prevEl.getBoundingClientRect().top < this.listboxEl.getBoundingClientRect().top) {
397
+ this.scrollOptionToTop(prevEl);
398
+ }
399
+ this.focusOption(prevEl);
400
+ }
401
+ else if (this.search) {
402
+ // if top of list and search variant, focus search field
403
+ this.searchFieldEl.focus();
404
+ }
405
+ else {
406
+ // if top of list, focus last element
407
+ this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
408
+ }
409
+ }
410
+ moveDown(el) {
411
+ const nextEl = this.visibleOptionEls[this.visibleOptionEls.indexOf(el) + 1];
412
+ if (nextEl) {
413
+ // scroll option to bottom of dropdown if partially obscured / out of view
414
+ if (nextEl.getBoundingClientRect().bottom > this.listboxEl.getBoundingClientRect().bottom) {
415
+ this.scrollOptionToBottom(nextEl);
416
+ }
417
+ this.focusOption(nextEl);
418
+ }
419
+ else {
420
+ // if end of list, focus first option in all variants
421
+ this.focusOption(this.visibleOptionEls[0]);
422
+ }
423
+ }
424
+ scrollOptionToTop(option) {
425
+ this.listboxEl.scrollTop =
426
+ option.getBoundingClientRect().top - this.listboxEl.getBoundingClientRect().top + this.listboxEl.scrollTop;
427
+ }
428
+ scrollOptionToBottom(option) {
429
+ this.listboxEl.scrollTop =
430
+ option.getBoundingClientRect().bottom -
431
+ this.listboxEl.getBoundingClientRect().top +
432
+ this.listboxEl.scrollTop -
433
+ this.listboxEl.offsetHeight;
434
+ }
435
+ open(optionToSelect) {
436
+ if (!this.disabled) {
437
+ const elHeight = this.el.clientHeight;
438
+ const buttonHeight = this.buttonEl.clientHeight;
439
+ this.openUp = shouldOpenUp(this.el, this.dropdownEl,
440
+ // when opening up, dropdown covers both label and button
441
+ elHeight,
442
+ // when opening down, dropdown covers only the button
443
+ buttonHeight);
444
+ this.isExpanded = true;
445
+ this.dropdownEl.classList.remove("hidden");
446
+ window.requestAnimationFrame(() => {
447
+ switch (optionToSelect) {
448
+ case "next":
449
+ // search variant focuses search field
450
+ // all others focus option "after" last selected option (this can be the first option)
451
+ if (this.search) {
452
+ this.searchFieldEl.focus();
453
+ this.listboxEl.scrollTop = 0;
454
+ }
455
+ else {
456
+ this.moveDown(this.visibleOptionEls.filter((x) => x.selected).slice(-1)[0]);
457
+ }
458
+ break;
459
+ case "previous":
460
+ // search variant focuses last option
461
+ // all others focus option "above" first selected option (this can be the last option)
462
+ if (this.search) {
463
+ this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
464
+ }
465
+ else {
466
+ this.moveUp(this.visibleOptionEls.filter((x) => x.selected)[0]);
467
+ }
468
+ break;
469
+ default:
470
+ // search variant focuses search field
471
+ // all others focus the selected option
472
+ // if no option is selected (empty multiselect), focuses first option
473
+ if (this.search) {
474
+ this.searchFieldEl.focus();
475
+ this.listboxEl.scrollTop = 0;
476
+ }
477
+ else if (this.selectedOptions.length > 0) {
478
+ this.focusOption(this.visibleOptionEls.filter((x) => x.selected)[0]);
479
+ }
480
+ else {
481
+ this.focusOption(this.visibleOptionEls[0]);
482
+ }
483
+ break;
484
+ }
485
+ });
486
+ }
487
+ }
488
+ close(returnFocus = true) {
489
+ if (this.isExpanded) {
490
+ this.isExpanded = false;
491
+ this.allOptionEls.map((i) => (i.focused = false));
492
+ window.setTimeout(() => {
493
+ this.dropdownEl.classList.add("hidden");
494
+ if (this.multiple) {
495
+ this.updateOptionVisibility();
496
+ }
497
+ // clear search field, reset filtered / bolded state of wm-options
498
+ if (this.search) {
499
+ this.searchFieldEl.value = "";
500
+ this.wmSelectSearchChanged.emit({ searchTerm: this.searchTerm });
501
+ }
502
+ // Returns focus to button after popup closes (no need if user is tabbing)
503
+ // Delay is necessary for screenreader to get new expanded state before focus
504
+ // window.requestAnimationFrame is probably enough, but since we are already using setTimeout it may as well be here
505
+ // also UX wise, it makes sense for the button to only be focused after the animation is complete
506
+ if (returnFocus) {
507
+ this.el.focus();
508
+ }
509
+ }, 150);
510
+ }
511
+ }
512
+ updateOptionVisibility() {
513
+ // this runs for search multiselects, where selected options are rendered at the top of the dropdown list
514
+ // slotted wm-options are hidden if selected, and duplicate wm-options are made visible if selected
515
+ this.childOptions.forEach((option, idx) => {
516
+ const duplicateOption = this.duplicateOptions[idx];
517
+ if (option.selected) {
518
+ option.classList.add("hidden");
519
+ duplicateOption.classList.remove("hidden");
520
+ }
521
+ else {
522
+ option.classList.remove("hidden");
523
+ duplicateOption.classList.add("hidden");
524
+ }
525
+ });
526
+ }
527
+ focusOption(option) {
528
+ this.allOptionEls.forEach((i) => (i.focused = i === option));
529
+ option.focus();
530
+ }
531
+ selectOption(option) {
532
+ // this function does not necessarily change an options selected property to true
533
+ // in cases of multiselect, it toggles the selected property
534
+ if (option.classList.contains("duplicate")) {
535
+ // if clicking on a duplicate option, toggle selected property of real one, then rerender
536
+ const correspondingOption = this.findCorrespondingOption(option);
537
+ correspondingOption.selected = !correspondingOption.selected;
538
+ forceUpdate(this.el);
539
+ }
540
+ else if (this.multiple) {
541
+ option.selected = !option.selected;
542
+ }
543
+ else {
544
+ this.allOptionEls.forEach((x) => (x.selected = x === option));
545
+ }
546
+ this.setButtonText();
547
+ }
548
+ findAndFocusOption(ev) {
549
+ const character = ev.detail.toUpperCase();
550
+ if (!this.keysSoFar) {
551
+ for (var i = 0; i < this.allOptionEls.length; i++) {
552
+ if (this.allOptionEls[i].focused) {
553
+ this.searchIndex = i;
554
+ }
555
+ }
556
+ }
557
+ this.keysSoFar += character;
558
+ this.clearKeysSoFarAfterDelay();
559
+ var nextMatch = this.findMatchInRange(this.allOptionEls, this.searchIndex + 1, this.allOptionEls.length);
560
+ if (!nextMatch) {
561
+ nextMatch = this.findMatchInRange(this.allOptionEls, 0, this.searchIndex);
562
+ }
563
+ if (nextMatch) {
564
+ this.focusOption(nextMatch);
565
+ }
566
+ }
567
+ clearKeysSoFarAfterDelay() {
568
+ if (this.keyClear) {
569
+ window.clearTimeout(this.keyClear);
570
+ this.keyClear = null;
571
+ }
572
+ this.keyClear = window.setTimeout(function () {
573
+ this.keysSoFar = "";
574
+ this.keyClear = null;
575
+ }.bind(this), 500);
576
+ }
577
+ findMatchInRange(list, startIndex, endIndex) {
578
+ // Find the first option starting with the keysSoFar substring, searching in
579
+ // the specified range of options
580
+ for (var n = startIndex; n < endIndex; n++) {
581
+ var label = list[n].textContent;
582
+ if (label && label.toUpperCase().indexOf(this.keysSoFar) === 0) {
583
+ return list[n];
584
+ }
585
+ }
586
+ return null;
587
+ }
588
+ findCorrespondingOption(el) {
589
+ // if duplicate, returns the child wm-option
590
+ // if child wm-option, returns duplicate
591
+ const isDuplicate = el.classList.contains("duplicate");
592
+ return isDuplicate
593
+ ? this.childOptions[this.duplicateOptions.indexOf(el)]
594
+ : this.duplicateOptions[this.childOptions.indexOf(el)];
595
+ }
596
+ isElOrChild(el) {
597
+ var _a;
598
+ // determines whether or not the element is the component, a child of the component, or exists within the component's shadowroot
599
+ return el === this.el || this.el.contains(el) || ((_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(el));
600
+ }
601
+ exposeErrors() {
602
+ // When the error changes, a new id is set for the error container and the button's aria-describedby attribute is updated accordingly. This is to make sure the screen reader announces teh updated errors in Firefox. See this longstanding bug: https://bugzilla.mozilla.org/show_bug.cgi?id=493683
603
+ const newId = generateId();
604
+ this.errorContainer.id = `wm-errors-${newId}`;
605
+ this.buttonEl.setAttribute("aria-describedby", `wm-errors-${newId}`);
606
+ }
607
+ renderErrorContainer() {
608
+ return (h("div", { id: "wm-errors", class: this.errorMessage ? "error-message" : "", ref: (el) => (this.errorContainer = el), "aria-live": "assertive", "aria-atomic": "true" }, this.errorMessage));
609
+ }
610
+ handleComponentBlur(ev) {
611
+ // Do not close or emit custom blur event when blurring to an element inside (wm-option)
612
+ if (!this.el.contains(ev.relatedTarget)) {
613
+ this.close(false);
614
+ this.wmSelectBlurred.emit();
615
+ this.wmComponentBlurred.emit(); // deprecated
616
+ }
617
+ }
618
+ handleSearchFieldKeyDown(ev) {
619
+ switch (ev.key) {
620
+ case "ArrowDown":
621
+ ev.preventDefault();
622
+ if (this.visibleOptionEls.length) {
623
+ this.focusOption(this.visibleOptionEls[0]);
624
+ }
625
+ break;
626
+ case "ArrowUp":
627
+ ev.preventDefault();
628
+ if (this.visibleOptionEls.length) {
629
+ this.focusOption(this.visibleOptionEls[this.visibleOptionEls.length - 1]);
630
+ }
631
+ break;
632
+ case "Escape":
633
+ ev.preventDefault();
634
+ this.close();
635
+ break;
636
+ }
637
+ }
638
+ setButtonText() {
639
+ this.displayedOptions = this.childOptions
640
+ .filter((x) => x.selected)
641
+ .map((y) => (!y.classList.contains("hidden") ? y : this.findCorrespondingOption(y)));
642
+ // handle overflow + counter for multiselect
643
+ if (this.multiple) {
644
+ // this is a fixed measurement accounting for the max width of a 3 character overflow counter
645
+ const overflowCounterWidth = 38;
646
+ const computedStyle = window.getComputedStyle(this.buttonEl);
647
+ // there seems to be no quick way to get an elements width without padding, except for subtracting padding manually
648
+ const paddingLeft = parseInt(computedStyle.getPropertyValue("padding-left").slice(0, -2));
649
+ const paddingRight = parseInt(computedStyle.getPropertyValue("padding-right").slice(0, -2));
650
+ const availableSpace = this.buttonEl.clientWidth - paddingLeft - paddingRight - overflowCounterWidth;
651
+ let optionsWidths = this.displayedOptions.map((x) => x.shadowRoot.querySelector(".option-wrapper").clientWidth);
652
+ let optionsTotalWidth = optionsWidths.reduce((acc, x) => acc + x, 0);
653
+ this.overflowCount = 0;
654
+ while (optionsTotalWidth > availableSpace && this.displayedOptions.length > 1) {
655
+ this.overflowCount++;
656
+ optionsTotalWidth -= optionsWidths[optionsWidths.length - 1];
657
+ optionsWidths.pop();
658
+ this.displayedOptions.pop();
659
+ }
660
+ }
661
+ }
662
+ announce(message) {
663
+ // \u00A0 is a non-breaking space character, which causes the message to be read as a new one
664
+ if (this.liveRegionEl.textContent === message) {
665
+ message += "\u00A0";
666
+ }
667
+ this.announcement = message;
668
+ }
669
+ renderButtonText() {
670
+ if (this.multiple && this.displayedOptions.length < 1) {
671
+ return h("span", null, this.placeholder);
672
+ }
673
+ else if (this.multiple && this.allSelected && this.overflowCount > 0) {
674
+ return this.allSelectedMessage;
675
+ }
676
+ else {
677
+ return this.displayedOptions.map((x, idx) => (h("span", null, idx > 0 ? ", " : "", x.textContent)));
678
+ }
679
+ }
680
+ renderSubinfo() {
681
+ // multiselects cannot have subinfo for options
682
+ if (!this.multiple && this.selectedOptions.length > 0 && this.selectedOptions[0].subinfo) {
683
+ return h("span", { class: "subinfo" }, this.selectedOptions[0].subinfo);
684
+ }
685
+ }
686
+ renderOverflowCount() {
687
+ if (this.overflowCount > 0 && !this.allSelected) {
688
+ return (h("span", null, h("span", { class: "overflow-counter" }, "+", this.overflowCount)));
689
+ }
690
+ }
691
+ renderSearchField() {
692
+ return (h("div", { class: "search" }, h("div", { class: "searchfield-wrapper", ref: (el) => (this.searchFieldWrapperEl = el) }, h("div", { class: "icon" }), h("input", { ref: (el) => (this.searchFieldEl = el), class: "searchfield", role: "combobox", "aria-controls": `list-${this.uid}`, "aria-expanded": this.isExpanded ? "true" : "false", onKeyDown: (ev) => this.handleSearchFieldKeyDown(ev), onFocus: () => this.searchFieldWrapperEl.classList.add("focus"), onBlur: (ev) => this.handleSearchFieldBlur(ev), onInput: () => this.debouncedSearch(), placeholder: this.searchPlaceholder }))));
693
+ }
694
+ renderSearchFailedMessage() {
695
+ return h("div", { class: "search-results-message" }, this.noResultsFoundMessage);
696
+ }
697
+ renderDuplicateOptions() {
698
+ return Array.from(this.el.children).map((option) => {
699
+ return (h("wm-option", { class: "duplicate", selected: option.selected }, option.textContent));
700
+ });
701
+ }
702
+ render() {
703
+ const buttonProps = {
704
+ id: `selectbtn-${this.uid}`,
705
+ ["disabled"]: this.disabled,
706
+ ["aria-controls"]: `list-${this.uid}`,
707
+ ["aria-labelledby"]: `label-${this.uid} selectbtn-${this.uid}`,
708
+ ["aria-describedby"]: "wm-errors",
709
+ ["aria-expanded"]: this.isExpanded ? "true" : "false",
710
+ onClick: () => (this.isExpanded ? this.close() : this.open()),
711
+ };
712
+ return (h(Host, { onBlur: (ev) => this.handleComponentBlur(ev) }, h("div", { class: `wrapper ${getTextDir()} label-${this.labelPosition} ${this.invalid || this.errorMessage ? "invalid" : ""}` }, h("div", { class: "label-wrapper" }, h("label", { class: "label", id: `label-${this.uid}`, htmlFor: `selectbtn-${this.uid}` }, this.label,
713
+ // we can't use aria-required or required attributes because it's invalid on the elements we're using (button controlling a listbox)
714
+ this.requiredField ? (h("span", { class: "required" }, h("span", { class: "sr-only" }, this.requiredMessage), h("span", { "aria-hidden": "true" }, "*"))) : (""))), h("div", { class: "button-wrapper" }, h("button", Object.assign({}, buttonProps, { class: `displayedoption ${this.isTabbing ? "user-is-tabbing" : ""}`, ref: (el) => (this.buttonEl = el), onBlur: (ev) => this.handleButtonBlur(ev), onFocus: () => this.close() }), h("span", { class: this.selectedOptions.length > 0 && this.selectedOptions.filter((x) => x.subinfo).length > 0
715
+ ? "overflowcontrol hassubinfo"
716
+ : "overflowcontrol" }, h("span", { class: "button-text" }, this.renderButtonText()), this.renderSubinfo()), this.renderOverflowCount()), h("div", { class: `dropdown ${this.isExpanded ? "open" : ""} ${this.openUp ? "upwards" : ""}`, ref: (el) => (this.dropdownEl = el) }, this.search && this.renderSearchField(), h("div", { id: `list-${this.uid}`, class: "options-wrapper", tabindex: -1, role: "listbox", "aria-multiselectable": this.multiple ? "true" : null, "aria-labelledby": `label-${this.uid}`, ref: (el) => (this.listboxEl = el) }, this.search && this.filteredOptions.length === 0 && this.renderSearchFailedMessage(), this.multiple && this.renderDuplicateOptions(), h("slot", null))), this.renderErrorContainer(), h("div", { id: "announcement", "aria-live": "polite", class: "sr-only", ref: (el) => (this.liveRegionEl = el) }, this.announcement)))));
717
+ }
718
+ get el() { return getElement(this); }
719
+ static get watchers() { return {
720
+ "errorMessage": ["exposeErrors"]
721
+ }; }
722
+ };
716
723
  Select.style = wmSelectCss;
717
724
 
718
725
  export { Option as wm_option, Select as wm_select };