@watermarkinsights/ripple 3.14.1 → 3.15.0-2

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 (263) hide show
  1. package/README.md +3 -3
  2. package/dist/cjs/{chartFunctions-0ea0888f.js → chartFunctions-08494c24.js} +419 -419
  3. package/dist/cjs/{functions-8d3ceccd.js → functions-e1b590e0.js} +528 -446
  4. package/dist/cjs/{global-12a09ffa.js → global-0a41410c.js} +62 -62
  5. package/dist/cjs/{http-service-9e8c4dd5.js → http-service-494d81de.js} +49 -49
  6. package/dist/cjs/{interfaces-30a74c1f.js → interfaces-a3338581.js} +29 -29
  7. package/dist/cjs/loader.cjs.js +2 -2
  8. package/dist/cjs/priv-chart-popover.cjs.entry.js +86 -86
  9. package/dist/cjs/priv-datepicker.cjs.entry.js +657 -657
  10. package/dist/cjs/priv-navigator-button.cjs.entry.js +18 -18
  11. package/dist/cjs/priv-navigator-item.cjs.entry.js +23 -23
  12. package/dist/cjs/ripple.cjs.js +2 -2
  13. package/dist/cjs/wm-action-menu_2.cjs.entry.js +329 -335
  14. package/dist/cjs/wm-button.cjs.entry.js +248 -241
  15. package/dist/cjs/wm-chart-slice.cjs.entry.js +13 -13
  16. package/dist/cjs/wm-chart.cjs.entry.js +110 -110
  17. package/dist/cjs/wm-datepicker.cjs.entry.js +265 -265
  18. package/dist/cjs/wm-input.cjs.entry.js +134 -134
  19. package/dist/cjs/wm-modal-footer.cjs.entry.js +33 -33
  20. package/dist/cjs/wm-modal-header.cjs.entry.js +36 -36
  21. package/dist/cjs/wm-modal.cjs.entry.js +163 -163
  22. package/dist/cjs/wm-navigation_3.cjs.entry.js +227 -227
  23. package/dist/cjs/wm-navigator.cjs.entry.js +268 -268
  24. package/dist/cjs/wm-network-uploader.cjs.entry.js +455 -454
  25. package/dist/cjs/wm-option_2.cjs.entry.js +720 -720
  26. package/dist/cjs/wm-pagination.cjs.entry.js +167 -167
  27. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +129 -129
  28. package/dist/cjs/wm-search.cjs.entry.js +232 -232
  29. package/dist/cjs/wm-snackbar.cjs.entry.js +170 -170
  30. package/dist/cjs/wm-tab-item_3.cjs.entry.js +296 -296
  31. package/dist/cjs/wm-tag-input.cjs.entry.js +579 -579
  32. package/dist/cjs/wm-timepicker.cjs.entry.js +383 -383
  33. package/dist/cjs/wm-toggletip.cjs.entry.js +124 -124
  34. package/dist/cjs/wm-uploader.cjs.entry.js +599 -629
  35. package/dist/cjs/wm-wrapper.cjs.entry.js +12 -12
  36. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +258 -258
  37. package/dist/collection/components/charts/wm-chart/wm-chart-slice.js +115 -115
  38. package/dist/collection/components/charts/wm-chart/wm-chart.js +328 -328
  39. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +195 -195
  40. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +88 -88
  41. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-slice.js +111 -111
  42. package/dist/collection/components/wm-action-menu/wm-action-menu.js +442 -448
  43. package/dist/collection/components/wm-button/wm-button.js +545 -504
  44. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.js +1024 -1024
  45. package/dist/collection/components/wm-datepicker/wm-datepicker.js +471 -471
  46. package/dist/collection/components/wm-input/wm-input.js +423 -423
  47. package/dist/collection/components/wm-menuitem/wm-menuitem.js +444 -444
  48. package/dist/collection/components/wm-modal/wm-modal-footer.js +136 -136
  49. package/dist/collection/components/wm-modal/wm-modal-header.js +87 -87
  50. package/dist/collection/components/wm-modal/wm-modal.js +461 -461
  51. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +162 -162
  52. package/dist/collection/components/wm-navigation/wm-navigation-item.js +121 -121
  53. package/dist/collection/components/wm-navigation/wm-navigation.js +218 -218
  54. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +97 -97
  55. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +114 -114
  56. package/dist/collection/components/wm-navigator/wm-navigator.js +468 -468
  57. package/dist/collection/components/wm-option/wm-option.js +428 -428
  58. package/dist/collection/components/wm-pagination/wm-pagination.js +368 -368
  59. package/dist/collection/components/wm-search/wm-search.js +480 -480
  60. package/dist/collection/components/wm-select/wm-select.js +1001 -1001
  61. package/dist/collection/components/wm-snackbar/wm-snackbar.js +297 -297
  62. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +216 -216
  63. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +330 -330
  64. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +104 -104
  65. package/dist/collection/components/wm-tag-input/wm-tag-input.js +810 -810
  66. package/dist/collection/components/wm-timepicker/wm-timepicker.js +583 -583
  67. package/dist/collection/components/wm-toggletip/wm-toggletip.js +241 -241
  68. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.js +788 -787
  69. package/dist/collection/components/wm-uploader/wm-uploader.js +1043 -1072
  70. package/dist/collection/components/wm-wrapper/wm-wrapper.js +27 -27
  71. package/dist/collection/dev/scripts.js +20 -20
  72. package/dist/collection/global/__mocks__/functions.js +6 -6
  73. package/dist/collection/global/chartFunctions.js +421 -421
  74. package/dist/collection/global/functions.js +441 -441
  75. package/dist/collection/global/global.js +69 -69
  76. package/dist/collection/global/interfaces.js +49 -49
  77. package/dist/collection/global/services/__mocks__/http-service.js +130 -130
  78. package/dist/collection/global/services/http-service.js +50 -50
  79. package/dist/collection/lang/lang.js +5 -5
  80. package/dist/collection/lang/missing.js +43 -43
  81. package/dist/collection/lang/piglatin.js +93 -93
  82. package/dist/esm/{chartFunctions-6f90586d.js → chartFunctions-a310b9d0.js} +419 -419
  83. package/dist/esm/{functions-11c0c4e2.js → functions-b4b62a23.js} +528 -446
  84. package/dist/esm/{global-5abca73e.js → global-e80a0ec8.js} +62 -62
  85. package/dist/esm/{http-service-5d037e16.js → http-service-3dc3b3e7.js} +49 -49
  86. package/dist/esm/{interfaces-61c6305b.js → interfaces-2b97fab2.js} +29 -29
  87. package/dist/esm/loader.js +2 -2
  88. package/dist/esm/polyfills/core-js.js +0 -0
  89. package/dist/esm/polyfills/dom.js +0 -0
  90. package/dist/esm/polyfills/es5-html-element.js +0 -0
  91. package/dist/esm/polyfills/index.js +0 -0
  92. package/dist/esm/polyfills/system.js +0 -0
  93. package/dist/esm/priv-chart-popover.entry.js +86 -86
  94. package/dist/esm/priv-datepicker.entry.js +657 -657
  95. package/dist/esm/priv-navigator-button.entry.js +18 -18
  96. package/dist/esm/priv-navigator-item.entry.js +23 -23
  97. package/dist/esm/ripple.js +2 -2
  98. package/dist/esm/wm-action-menu_2.entry.js +329 -335
  99. package/dist/esm/wm-button.entry.js +248 -241
  100. package/dist/esm/wm-chart-slice.entry.js +13 -13
  101. package/dist/esm/wm-chart.entry.js +110 -110
  102. package/dist/esm/wm-datepicker.entry.js +265 -265
  103. package/dist/esm/wm-input.entry.js +134 -134
  104. package/dist/esm/wm-modal-footer.entry.js +33 -33
  105. package/dist/esm/wm-modal-header.entry.js +36 -36
  106. package/dist/esm/wm-modal.entry.js +163 -163
  107. package/dist/esm/wm-navigation_3.entry.js +227 -227
  108. package/dist/esm/wm-navigator.entry.js +268 -268
  109. package/dist/esm/wm-network-uploader.entry.js +455 -454
  110. package/dist/esm/wm-option_2.entry.js +720 -720
  111. package/dist/esm/wm-pagination.entry.js +167 -167
  112. package/dist/esm/wm-progress-indicator_3.entry.js +129 -129
  113. package/dist/esm/wm-search.entry.js +232 -232
  114. package/dist/esm/wm-snackbar.entry.js +170 -170
  115. package/dist/esm/wm-tab-item_3.entry.js +296 -296
  116. package/dist/esm/wm-tag-input.entry.js +579 -579
  117. package/dist/esm/wm-timepicker.entry.js +383 -383
  118. package/dist/esm/wm-toggletip.entry.js +124 -124
  119. package/dist/esm/wm-uploader.entry.js +599 -629
  120. package/dist/esm/wm-wrapper.entry.js +12 -12
  121. package/dist/esm-es5/{chartFunctions-6f90586d.js → chartFunctions-a310b9d0.js} +1 -1
  122. package/dist/esm-es5/functions-b4b62a23.js +1 -0
  123. package/dist/esm-es5/global-e80a0ec8.js +1 -0
  124. package/dist/esm-es5/{http-service-5d037e16.js → http-service-3dc3b3e7.js} +0 -0
  125. package/dist/esm-es5/{interfaces-61c6305b.js → interfaces-2b97fab2.js} +0 -0
  126. package/dist/esm-es5/loader.js +1 -1
  127. package/dist/esm-es5/priv-chart-popover.entry.js +1 -1
  128. package/dist/esm-es5/priv-datepicker.entry.js +1 -1
  129. package/dist/esm-es5/ripple.js +1 -1
  130. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -1
  131. package/dist/esm-es5/wm-button.entry.js +1 -1
  132. package/dist/esm-es5/wm-chart.entry.js +1 -1
  133. package/dist/esm-es5/wm-datepicker.entry.js +1 -1
  134. package/dist/esm-es5/wm-input.entry.js +1 -1
  135. package/dist/esm-es5/wm-modal-header.entry.js +1 -1
  136. package/dist/esm-es5/wm-modal.entry.js +1 -1
  137. package/dist/esm-es5/wm-navigation_3.entry.js +1 -1
  138. package/dist/esm-es5/wm-navigator.entry.js +1 -1
  139. package/dist/esm-es5/wm-network-uploader.entry.js +1 -1
  140. package/dist/esm-es5/wm-option_2.entry.js +1 -1
  141. package/dist/esm-es5/wm-pagination.entry.js +1 -1
  142. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -1
  143. package/dist/esm-es5/wm-search.entry.js +1 -1
  144. package/dist/esm-es5/wm-snackbar.entry.js +1 -1
  145. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -1
  146. package/dist/esm-es5/wm-tag-input.entry.js +1 -1
  147. package/dist/esm-es5/wm-timepicker.entry.js +1 -1
  148. package/dist/esm-es5/wm-toggletip.entry.js +1 -1
  149. package/dist/esm-es5/wm-uploader.entry.js +1 -1
  150. package/dist/ripple/{p-07ebdcd4.system.entry.js → p-0f08a806.system.entry.js} +1 -1
  151. package/dist/ripple/{p-b793bc6f.system.entry.js → p-1ba2134b.system.entry.js} +1 -1
  152. package/dist/ripple/{p-626d5017.entry.js → p-1c75615f.entry.js} +1 -1
  153. package/dist/ripple/{p-42dbd978.entry.js → p-1cadcfc1.entry.js} +1 -1
  154. package/dist/ripple/{p-b2a9b5d6.system.entry.js → p-2531b343.system.entry.js} +1 -1
  155. package/dist/ripple/p-32da7cdf.entry.js +1 -0
  156. package/dist/ripple/p-375a850f.system.js +1 -0
  157. package/dist/ripple/p-3a71d9a3.entry.js +1 -0
  158. package/dist/ripple/{p-0e22a3a4.entry.js → p-428b8b24.entry.js} +1 -1
  159. package/dist/ripple/{p-888bec42.js → p-43f1298b.js} +0 -0
  160. package/dist/ripple/{p-80a00759.entry.js → p-477688c8.entry.js} +1 -1
  161. package/dist/ripple/{p-d927de70.system.entry.js → p-4be49461.system.entry.js} +1 -1
  162. package/dist/ripple/{p-7cb0035a.system.entry.js → p-51b60241.system.entry.js} +1 -1
  163. package/dist/ripple/p-5754e2b8.system.js +1 -0
  164. package/dist/ripple/{p-b5b7c71f.system.js → p-591fae61.system.js} +1 -1
  165. package/dist/ripple/p-5f589556.entry.js +1 -0
  166. package/dist/ripple/{p-b4837126.system.entry.js → p-617b738b.system.entry.js} +1 -1
  167. package/dist/ripple/{p-06012eb7.system.entry.js → p-61e2a39a.system.entry.js} +1 -1
  168. package/dist/ripple/{p-5018f8ae.entry.js → p-65d5f494.entry.js} +1 -1
  169. package/dist/ripple/{p-4f3f7b2b.entry.js → p-6ac734b7.entry.js} +1 -1
  170. package/dist/ripple/p-6d7a6954.js +1 -0
  171. package/dist/ripple/{p-97683ddc.entry.js → p-6ddfada6.entry.js} +1 -1
  172. package/dist/ripple/{p-57a718f0.system.entry.js → p-719864a5.system.entry.js} +1 -1
  173. package/dist/ripple/{p-caef11cc.entry.js → p-73a66a6c.entry.js} +1 -1
  174. package/dist/ripple/{p-c656fcf1.entry.js → p-75346877.entry.js} +1 -1
  175. package/dist/ripple/{p-dfa80ed1.entry.js → p-7833008a.entry.js} +1 -1
  176. package/dist/ripple/{p-08fc668c.system.entry.js → p-79542ae3.system.entry.js} +1 -1
  177. package/dist/ripple/{p-4073ac6a.entry.js → p-79b8e996.entry.js} +1 -1
  178. package/dist/ripple/{p-8b54c589.system.entry.js → p-7a07096b.system.entry.js} +1 -1
  179. package/dist/ripple/{p-c4c21c82.system.entry.js → p-93321f18.system.entry.js} +1 -1
  180. package/dist/ripple/p-96b47a13.js +1 -0
  181. package/dist/ripple/{p-c49ef079.system.entry.js → p-981788dd.system.entry.js} +1 -1
  182. package/dist/ripple/p-990db03b.system.entry.js +1 -0
  183. package/dist/ripple/p-99791f7a.system.js +1 -0
  184. package/dist/ripple/{p-e012273a.entry.js → p-9ad7db55.entry.js} +1 -1
  185. package/dist/ripple/{p-910b6dd5.system.entry.js → p-9caf189d.system.entry.js} +1 -1
  186. package/dist/ripple/{p-313b6073.system.js → p-9d02957d.system.js} +0 -0
  187. package/dist/ripple/{p-ffc34819.system.entry.js → p-9ef524df.system.entry.js} +1 -1
  188. package/dist/ripple/{p-84d0d2ff.system.entry.js → p-9fd29197.system.entry.js} +1 -1
  189. package/dist/ripple/{p-f0d3ceb1.system.entry.js → p-a2f8608f.system.entry.js} +1 -1
  190. package/dist/ripple/{p-dc7e5609.system.entry.js → p-aa35c9dd.system.entry.js} +1 -1
  191. package/dist/ripple/{p-6ffdab0d.system.entry.js → p-ab7ce269.system.entry.js} +1 -1
  192. package/dist/ripple/{p-410687ea.entry.js → p-b5a6aebc.entry.js} +1 -1
  193. package/dist/ripple/{p-4650a83c.system.entry.js → p-b6c197c7.system.entry.js} +1 -1
  194. package/dist/ripple/{p-9c60325b.entry.js → p-c5a3766f.entry.js} +1 -1
  195. package/dist/ripple/{p-2af0b657.system.entry.js → p-c95317b4.system.entry.js} +1 -1
  196. package/dist/ripple/p-ce696630.entry.js +1 -0
  197. package/dist/ripple/{p-17438cd5.entry.js → p-d3326191.entry.js} +1 -1
  198. package/dist/ripple/{p-fe4c1194.system.entry.js → p-e47b10b1.system.entry.js} +1 -1
  199. package/dist/ripple/{p-490dafa4.js → p-eb308bc7.js} +1 -1
  200. package/dist/ripple/{p-4afa52d4.entry.js → p-f5cec3d1.entry.js} +1 -1
  201. package/dist/ripple/{p-08b7ec08.system.js → p-f5df5903.system.js} +0 -0
  202. package/dist/ripple/{p-8a2cabf2.entry.js → p-f7c2b508.entry.js} +1 -1
  203. package/dist/ripple/{p-cb357a84.entry.js → p-fcb81a4e.entry.js} +1 -1
  204. package/dist/ripple/{p-a6d6eae7.js → p-fd8070fb.js} +0 -0
  205. package/dist/ripple/ripple.esm.js +1 -1
  206. package/dist/ripple/ripple.js +1 -1
  207. package/dist/types/components/charts/priv-chart-popover/priv-chart-popover.d.ts +27 -27
  208. package/dist/types/components/charts/wm-chart/wm-chart-slice.d.ts +11 -11
  209. package/dist/types/components/charts/wm-chart/wm-chart.d.ts +36 -36
  210. package/dist/types/components/charts/wm-progress-monitor/wm-progress-indicator.d.ts +27 -27
  211. package/dist/types/components/charts/wm-progress-monitor/wm-progress-monitor.d.ts +17 -17
  212. package/dist/types/components/charts/wm-progress-monitor/wm-progress-slice.d.ts +10 -10
  213. package/dist/types/components/wm-action-menu/wm-action-menu.d.ts +47 -47
  214. package/dist/types/components/wm-button/wm-button.d.ts +49 -43
  215. package/dist/types/components/wm-datepicker/priv-datepicker/priv-datepicker.d.ts +80 -80
  216. package/dist/types/components/wm-datepicker/wm-datepicker.d.ts +41 -41
  217. package/dist/types/components/wm-input/wm-input.d.ts +46 -46
  218. package/dist/types/components/wm-menuitem/wm-menuitem.d.ts +34 -34
  219. package/dist/types/components/wm-modal/wm-modal-footer.d.ts +14 -14
  220. package/dist/types/components/wm-modal/wm-modal-header.d.ts +11 -11
  221. package/dist/types/components/wm-modal/wm-modal.d.ts +41 -41
  222. package/dist/types/components/wm-navigation/wm-navigation-hamburger.d.ts +21 -21
  223. package/dist/types/components/wm-navigation/wm-navigation-item.d.ts +13 -13
  224. package/dist/types/components/wm-navigation/wm-navigation.d.ts +28 -28
  225. package/dist/types/components/wm-navigator/priv-navigator-button/priv-navigator-button.d.ts +10 -10
  226. package/dist/types/components/wm-navigator/priv-navigator-item/priv-navigator-item.d.ts +13 -13
  227. package/dist/types/components/wm-navigator/wm-navigator.d.ts +61 -61
  228. package/dist/types/components/wm-option/wm-option.d.ts +35 -35
  229. package/dist/types/components/wm-pagination/wm-pagination.d.ts +32 -32
  230. package/dist/types/components/wm-search/wm-search.d.ts +86 -86
  231. package/dist/types/components/wm-select/wm-select.d.ts +94 -94
  232. package/dist/types/components/wm-snackbar/wm-snackbar.d.ts +35 -35
  233. package/dist/types/components/wm-tabs/wm-tab-item/wm-tab-item.d.ts +38 -38
  234. package/dist/types/components/wm-tabs/wm-tab-list/wm-tab-list.d.ts +53 -53
  235. package/dist/types/components/wm-tabs/wm-tab-panel/wm-tab-panel.d.ts +20 -20
  236. package/dist/types/components/wm-tag-input/wm-tag-input.d.ts +92 -92
  237. package/dist/types/components/wm-timepicker/wm-timepicker.d.ts +61 -61
  238. package/dist/types/components/wm-toggletip/wm-toggletip.d.ts +27 -27
  239. package/dist/types/components/wm-uploader/wm-network-uploader/wm-network-uploader.d.ts +85 -85
  240. package/dist/types/components/wm-uploader/wm-uploader.d.ts +121 -118
  241. package/dist/types/components/wm-wrapper/wm-wrapper.d.ts +7 -7
  242. package/dist/types/components.d.ts +28 -24
  243. package/dist/types/global/__mocks__/functions.d.ts +6 -6
  244. package/dist/types/global/chartFunctions.d.ts +29 -29
  245. package/dist/types/global/functions.d.ts +42 -42
  246. package/dist/types/global/global.d.ts +1 -1
  247. package/dist/types/global/interfaces.d.ts +44 -44
  248. package/dist/types/global/services/__mocks__/http-service.d.ts +6 -6
  249. package/dist/types/global/services/http-service.d.ts +4 -4
  250. package/dist/types/lang/lang.d.ts +5 -5
  251. package/package.json +47 -47
  252. package/dist/esm-es5/functions-11c0c4e2.js +0 -1
  253. package/dist/esm-es5/global-5abca73e.js +0 -1
  254. package/dist/ripple/p-37b0a23c.system.js +0 -1
  255. package/dist/ripple/p-3e875e87.system.entry.js +0 -1
  256. package/dist/ripple/p-42bf2cd4.system.js +0 -1
  257. package/dist/ripple/p-70d0e993.js +0 -1
  258. package/dist/ripple/p-80b62707.entry.js +0 -1
  259. package/dist/ripple/p-d2a11410.entry.js +0 -1
  260. package/dist/ripple/p-db899686.system.js +0 -1
  261. package/dist/ripple/p-e2d5f8bd.js +0 -1
  262. package/dist/ripple/p-e4cb8aad.entry.js +0 -1
  263. package/dist/ripple/p-fa632547.entry.js +0 -1
@@ -1,504 +1,545 @@
1
- import { h, Component, Prop, Element, Listen, Watch, Host, State } from "@stencil/core";
2
- import { getIconCodeFromName } from "../../global/interfaces";
3
- import { generateId, adjustTooltipPlacement, toBool } from "../../global/functions";
4
- export class Button {
5
- constructor() {
6
- // icon and tooltip have reflect set to true. Without reflect, the react wrappers don't expose the attribute
7
- // and the component throws errors when they are required (when buttonType is icononly or navigational)
8
- this.disabled = false;
9
- this.buttonType = null;
10
- this.buttonStyle = null; // DEPRECATED in favor of button-type
11
- this.tooltipPosition = "bottom-right";
12
- this.permanentlyDelete = false;
13
- this.textWrap = true;
14
- this.tooltipVisible = false; // this is not part of the documented API but we need to expose as prop in order to change it from the focus method defined in WillLoad()
15
- this.isTabbing = false;
16
- this.btnPos = { old: {}, new: {} }; // for tooltip position. old and new are DOMRect
17
- this.id = generateId();
18
- this.ariaPopup = false;
19
- }
20
- get isDisabled() {
21
- // string "false" needs to be treated as bool False because react wrappers convert bool to string.
22
- return toBool(this.disabled);
23
- }
24
- get tempButtonType() {
25
- // uses of this getter should be replaced with this.buttonType when buttonStyle is fully phased out
26
- // don't forget to reset this.buttonType's default value to secondary
27
- return this.buttonType || this.buttonStyle || "secondary";
28
- }
29
- get isTruncated() {
30
- return !!this.buttonEl && this.buttonEl.offsetWidth < this.buttonEl.scrollWidth;
31
- }
32
- get hasTooltip() {
33
- // tooltip is only rendered for icononly and navigational types, or if the button text is truncated
34
- return this.tempButtonType === "icononly" || this.tempButtonType === "navigational" || this.isTruncated;
35
- }
36
- get tooltipEl() {
37
- return document.getElementById("wm-tooltip");
38
- }
39
- toggleTabbingOn() {
40
- this.isTabbing = true;
41
- }
42
- toggleTabbingOff() {
43
- this.isTabbing = false;
44
- }
45
- // we need to listen for scroll events during the capture phase because they do not bubble up
46
- // there can be layouts where the main content has 100vh and overflows
47
- // in these cases window will register no scroll events unless we catch on they way down
48
- handleScroll() {
49
- if (this.tooltipVisible) {
50
- this.hideTooltip();
51
- }
52
- }
53
- validateType(newValue) {
54
- const valid = [
55
- "primary",
56
- "secondary",
57
- "textonly",
58
- "icononly",
59
- "navigational",
60
- "selectoronly",
61
- "pairpositive",
62
- "pairnegative",
63
- ].includes(newValue);
64
- if (!valid) {
65
- this.buttonType = "secondary";
66
- }
67
- this.validateIcon();
68
- }
69
- // remove entire watcher after buttonStyle has been fully removed
70
- validateDeprecatedType(newValue) {
71
- const valid = ["primary", "secondary", "textonly", "icononly", "navigational", "selectoronly"].includes(newValue);
72
- if (!valid) {
73
- this.buttonStyle = "secondary";
74
- }
75
- this.validateIcon();
76
- }
77
- updateIcon() {
78
- this.icon = getIconCodeFromName(this.icon);
79
- }
80
- validateIcon() {
81
- switch (this.tempButtonType) {
82
- case "icononly":
83
- case "navigational":
84
- // if the style is icononly or navigational...
85
- // - an icon must be provided
86
- if (!this.icon) {
87
- console.error("wm-button should have a valid 'icon' property when button-type is set to 'icononly' or 'navigational'.");
88
- }
89
- // - if no tooltip text was passed and we couldn't generate one, throw an error
90
- if (!this.tooltip) {
91
- console.error("wm-button should have a valid 'tooltip' property when button-type is set to 'icononly' or 'navigational'.");
92
- }
93
- break;
94
- case "pairpositive":
95
- this.icon = "f12c";
96
- break;
97
- case "pairnegative":
98
- this.icon = "f739";
99
- break;
100
- }
101
- }
102
- handleKeydown(ev) {
103
- switch (ev.key) {
104
- case "Enter":
105
- ev.preventDefault();
106
- if (!this.isDisabled) {
107
- this.el.click();
108
- }
109
- break;
110
- }
111
- }
112
- componentWillLoad() {
113
- if (this.buttonStyle) {
114
- console.warn("wm-button: button-style has been deprecated as of v3.1.0. Please use button-type instead.");
115
- }
116
- this.validateType(this.tempButtonType);
117
- // replacing the prototype's focus event by our own
118
- // to delegate focus to the appropriate el in the shadow root
119
- // we could replace by ShadowRoot.delegatesFocus()
120
- // when there's enough support for it
121
- // @ts-ignore
122
- this.el.focus = function () {
123
- if (!this.disabled) {
124
- this.shadowRoot.querySelector("button").focus();
125
- // prevent tooltip from showing on programmatic focus
126
- requestAnimationFrame(() => {
127
- this.tooltipVisible = false;
128
- });
129
- }
130
- };
131
- if (this.icon) {
132
- this.icon = this.icon = getIconCodeFromName(this.icon);
133
- }
134
- }
135
- componentDidLoad() {
136
- if (document.body.classList.contains("wmcl-user-is-tabbing")) {
137
- this.toggleTabbingOn();
138
- }
139
- this.ariaPopup = !!this.el.getAttribute("aria-haspopup");
140
- this.btnPos.new = this.buttonEl.getBoundingClientRect();
141
- }
142
- showTooltip() {
143
- if (this.hasTooltip) {
144
- // set tooltip text
145
- this.tooltipEl.textContent = this.isTruncated ? this.el.textContent : this.tooltip;
146
- // adjust placement in case there is no space to place the tooltip where specified via prop
147
- // calculation outside of the function to keep it pure
148
- const adjustedTooltipPlacement = adjustTooltipPlacement(this.tooltipPosition, this.buttonEl, this.tooltipEl);
149
- this.btnPos.old = {};
150
- const tooltipRect = this.tooltipEl.getBoundingClientRect();
151
- this.tooltipEl.style.transitionDelay = "500ms";
152
- this.tooltipEl.style.opacity = "1";
153
- // This slight delay fixes an issue for keyboard users:
154
- // if they tab to a button out of screen bounds, the page scrolls
155
- // and hideTooltip() would be triggered before the tooltip would show
156
- setTimeout(() => {
157
- this.tooltipVisible = true;
158
- this.positionTooltip(adjustedTooltipPlacement, tooltipRect);
159
- }, 50);
160
- }
161
- }
162
- positionTooltip(tPos, tooltipRect) {
163
- if (this.tooltipVisible) {
164
- window.requestAnimationFrame(() => this.positionTooltip(tPos, tooltipRect));
165
- }
166
- this.btnPos.new = this.buttonEl.getBoundingClientRect();
167
- if (this.btnPos.new.top != this.btnPos.old.top || this.btnPos.new.left != this.btnPos.old.left) {
168
- // this is to figure out how to offset, given the size of the button and of the tooltip
169
- // to get the center positions, calculate the difference between the button width and the tooltip width
170
- const vDiff = (this.btnPos.new.height - tooltipRect.height) / 2;
171
- const hDiff = (this.btnPos.new.width - tooltipRect.width) / 2;
172
- // the naming convention defaults to center in the absence of a value
173
- // Values "top" and "bottom" imply horizontal centering; Values "right" and "left" imply vertical centering
174
- // therefore we first set to center first, then adjust accordingly
175
- let vPos = this.btnPos.new.top + vDiff;
176
- let hPos = this.btnPos.new.left + hDiff;
177
- if (tPos.includes("top")) {
178
- vPos = this.btnPos.new.top - tooltipRect.height - 8;
179
- }
180
- if (tPos.includes("bottom")) {
181
- vPos = this.btnPos.new.bottom + 8;
182
- }
183
- if (tPos.includes("left")) {
184
- hPos = this.btnPos.new.left - tooltipRect.width - 8;
185
- }
186
- if (tPos.includes("right")) {
187
- hPos = this.btnPos.new.right + 8;
188
- }
189
- // after all positioning has been calculated, if tooltip is off-screen or closer than 24px it is readjusted
190
- // this only occurs when the tooltip is overflowing to the left and is positioned top or bottom
191
- // (button placed too far left, or screen size under 268px)
192
- hPos = Math.max(hPos, 24);
193
- this.tooltipEl.style.setProperty("--wmTooltipTop", vPos + "px");
194
- this.tooltipEl.style.setProperty("--wmTooltipLeft", hPos + "px");
195
- // this.tooltipEl.style.top = vPos + "px";
196
- // this.tooltipEl.style.left = hPos + "px";
197
- // this.tooltipEl.style.top = (vPos / 16).toString() + "rem";
198
- // this.tooltipEl.style.left = (hPos / 16).toString() + "rem";
199
- this.btnPos.old = this.btnPos.new;
200
- }
201
- }
202
- hideTooltip() {
203
- if (this.hasTooltip) {
204
- this.tooltipEl.style.transitionDelay = "0s";
205
- this.tooltipEl.style.opacity = "0";
206
- this.tooltipVisible = false;
207
- }
208
- }
209
- showTooltipForKeyboardUsers() {
210
- if (this.isTabbing) {
211
- this.showTooltip();
212
- }
213
- }
214
- getClasses() {
215
- let classes = "wm-button";
216
- classes += this.permanentlyDelete ? " -permanentlydelete" : "";
217
- classes += this.tempButtonType ? " -" + this.tempButtonType : " -secondary";
218
- classes += this.textWrap ? "" : " nowrap";
219
- classes += this.isTabbing ? " user-is-tabbing" : "";
220
- classes += this.isTruncated ? " -truncated" : "";
221
- classes += this.customBackground === "dark" ? " dark" : "";
222
- return classes;
223
- }
224
- getAriaLabel() {
225
- if (this.tempButtonType === "icononly" || this.tempButtonType === "navigational") {
226
- return this.labelForIdenticalButtons || this.tooltip;
227
- }
228
- if (this.labelForIdenticalButtons) {
229
- return this.labelForIdenticalButtons;
230
- }
231
- }
232
- render() {
233
- return (h(Host, { class: this.isDisabled ? "button-disabled" : "" },
234
- h("button", { id: this.id, class: `${this.getClasses()}`, disabled: this.isDisabled, ref: (el) => (this.buttonEl = el), "aria-label": this.getAriaLabel(), "aria-hasPopup": this.ariaPopup ? "menu" : null, onMouseEnter: () => this.showTooltip(), onMouseLeave: () => this.hideTooltip(), onFocus: () => this.showTooltipForKeyboardUsers(), onBlur: () => this.hideTooltip(), onClick: () => this.hideTooltip() },
235
- this.icon && (h("span", { class: "mdi", style: this.iconSize ? { fontSize: this.iconSize } : {} }, String.fromCodePoint(parseInt(`0x${this.icon}`)))),
236
- h("span", { class: "button-text" },
237
- h("slot", null)))));
238
- }
239
- static get is() { return "wm-button"; }
240
- static get encapsulation() { return "shadow"; }
241
- static get originalStyleUrls() { return {
242
- "$": ["wm-button.scss"]
243
- }; }
244
- static get styleUrls() { return {
245
- "$": ["wm-button.css"]
246
- }; }
247
- static get properties() { return {
248
- "disabled": {
249
- "type": "boolean",
250
- "mutable": false,
251
- "complexType": {
252
- "original": "boolean",
253
- "resolved": "boolean",
254
- "references": {}
255
- },
256
- "required": false,
257
- "optional": false,
258
- "docs": {
259
- "tags": [],
260
- "text": ""
261
- },
262
- "attribute": "disabled",
263
- "reflect": true,
264
- "defaultValue": "false"
265
- },
266
- "buttonType": {
267
- "type": "string",
268
- "mutable": true,
269
- "complexType": {
270
- "original": "string | null",
271
- "resolved": "null | string",
272
- "references": {}
273
- },
274
- "required": false,
275
- "optional": false,
276
- "docs": {
277
- "tags": [],
278
- "text": ""
279
- },
280
- "attribute": "button-type",
281
- "reflect": false,
282
- "defaultValue": "null"
283
- },
284
- "buttonStyle": {
285
- "type": "string",
286
- "mutable": true,
287
- "complexType": {
288
- "original": "string | null",
289
- "resolved": "null | string",
290
- "references": {}
291
- },
292
- "required": false,
293
- "optional": false,
294
- "docs": {
295
- "tags": [],
296
- "text": ""
297
- },
298
- "attribute": "button-style",
299
- "reflect": false,
300
- "defaultValue": "null"
301
- },
302
- "icon": {
303
- "type": "string",
304
- "mutable": true,
305
- "complexType": {
306
- "original": "string",
307
- "resolved": "string | undefined",
308
- "references": {}
309
- },
310
- "required": false,
311
- "optional": true,
312
- "docs": {
313
- "tags": [],
314
- "text": ""
315
- },
316
- "attribute": "icon",
317
- "reflect": true
318
- },
319
- "iconSize": {
320
- "type": "string",
321
- "mutable": false,
322
- "complexType": {
323
- "original": "string",
324
- "resolved": "string | undefined",
325
- "references": {}
326
- },
327
- "required": false,
328
- "optional": true,
329
- "docs": {
330
- "tags": [],
331
- "text": ""
332
- },
333
- "attribute": "icon-size",
334
- "reflect": false
335
- },
336
- "tooltip": {
337
- "type": "string",
338
- "mutable": true,
339
- "complexType": {
340
- "original": "string",
341
- "resolved": "string | undefined",
342
- "references": {}
343
- },
344
- "required": false,
345
- "optional": true,
346
- "docs": {
347
- "tags": [],
348
- "text": ""
349
- },
350
- "attribute": "tooltip",
351
- "reflect": true
352
- },
353
- "labelForIdenticalButtons": {
354
- "type": "string",
355
- "mutable": false,
356
- "complexType": {
357
- "original": "string",
358
- "resolved": "string | undefined",
359
- "references": {}
360
- },
361
- "required": false,
362
- "optional": true,
363
- "docs": {
364
- "tags": [],
365
- "text": ""
366
- },
367
- "attribute": "label-for-identical-buttons",
368
- "reflect": false
369
- },
370
- "tooltipPosition": {
371
- "type": "string",
372
- "mutable": false,
373
- "complexType": {
374
- "original": "TooltipPlacement",
375
- "resolved": "\"bottom\" | \"bottom-left\" | \"bottom-right\" | \"left\" | \"right\" | \"top\" | \"top-left\" | \"top-right\"",
376
- "references": {
377
- "TooltipPlacement": {
378
- "location": "import",
379
- "path": "../../global/interfaces"
380
- }
381
- }
382
- },
383
- "required": false,
384
- "optional": false,
385
- "docs": {
386
- "tags": [],
387
- "text": ""
388
- },
389
- "attribute": "tooltip-position",
390
- "reflect": false,
391
- "defaultValue": "\"bottom-right\""
392
- },
393
- "permanentlyDelete": {
394
- "type": "boolean",
395
- "mutable": false,
396
- "complexType": {
397
- "original": "boolean",
398
- "resolved": "boolean | undefined",
399
- "references": {}
400
- },
401
- "required": false,
402
- "optional": true,
403
- "docs": {
404
- "tags": [],
405
- "text": ""
406
- },
407
- "attribute": "permanently-delete",
408
- "reflect": false,
409
- "defaultValue": "false"
410
- },
411
- "textWrap": {
412
- "type": "boolean",
413
- "mutable": false,
414
- "complexType": {
415
- "original": "boolean",
416
- "resolved": "boolean",
417
- "references": {}
418
- },
419
- "required": false,
420
- "optional": false,
421
- "docs": {
422
- "tags": [],
423
- "text": ""
424
- },
425
- "attribute": "text-wrap",
426
- "reflect": false,
427
- "defaultValue": "true"
428
- },
429
- "customBackground": {
430
- "type": "string",
431
- "mutable": false,
432
- "complexType": {
433
- "original": "string",
434
- "resolved": "string | undefined",
435
- "references": {}
436
- },
437
- "required": false,
438
- "optional": true,
439
- "docs": {
440
- "tags": [],
441
- "text": ""
442
- },
443
- "attribute": "custom-background",
444
- "reflect": false
445
- },
446
- "tooltipVisible": {
447
- "type": "boolean",
448
- "mutable": true,
449
- "complexType": {
450
- "original": "boolean",
451
- "resolved": "boolean",
452
- "references": {}
453
- },
454
- "required": false,
455
- "optional": false,
456
- "docs": {
457
- "tags": [],
458
- "text": ""
459
- },
460
- "attribute": "tooltip-visible",
461
- "reflect": false,
462
- "defaultValue": "false"
463
- }
464
- }; }
465
- static get states() { return {
466
- "isTabbing": {}
467
- }; }
468
- static get elementRef() { return "el"; }
469
- static get watchers() { return [{
470
- "propName": "buttonType",
471
- "methodName": "validateType"
472
- }, {
473
- "propName": "buttonStyle",
474
- "methodName": "validateDeprecatedType"
475
- }, {
476
- "propName": "icon",
477
- "methodName": "updateIcon"
478
- }]; }
479
- static get listeners() { return [{
480
- "name": "wmUserIsTabbing",
481
- "method": "toggleTabbingOn",
482
- "target": "window",
483
- "capture": false,
484
- "passive": false
485
- }, {
486
- "name": "wmUserIsNotTabbing",
487
- "method": "toggleTabbingOff",
488
- "target": "window",
489
- "capture": false,
490
- "passive": false
491
- }, {
492
- "name": "scroll",
493
- "method": "handleScroll",
494
- "target": "window",
495
- "capture": true,
496
- "passive": true
497
- }, {
498
- "name": "keydown",
499
- "method": "handleKeydown",
500
- "target": undefined,
501
- "capture": false,
502
- "passive": false
503
- }]; }
504
- }
1
+ import { h, Component, Prop, Element, Listen, Watch, Host, State } from "@stencil/core";
2
+ import { getIconCodeFromName } from "../../global/interfaces";
3
+ import { generateId, adjustTooltipPlacement, toBool } from "../../global/functions";
4
+ export class Button {
5
+ constructor() {
6
+ // icon and tooltip have reflect set to true. Without reflect, the react wrappers don't expose the attribute
7
+ // and the component throws errors when they are required (when buttonType is icononly or navigational)
8
+ this.disabled = false;
9
+ this.buttonType = null;
10
+ this.buttonStyle = null; // DEPRECATED in favor of button-type
11
+ this.tooltipPosition = "bottom-right";
12
+ this.permanentlyDelete = false;
13
+ this.textWrap = true;
14
+ this.tooltipVisible = false; // this is not part of the documented API but we need to expose as prop in order to change it from the focus method defined in WillLoad()
15
+ this.isTabbing = false;
16
+ this.btnPos = { old: {}, new: {} }; // for tooltip position. old and new are DOMRect
17
+ this.id = generateId();
18
+ this.ariaPopup = false;
19
+ }
20
+ get isDisabled() {
21
+ // string "false" needs to be treated as bool False because react wrappers convert bool to string.
22
+ return toBool(this.disabled);
23
+ }
24
+ get tempButtonType() {
25
+ // uses of this getter should be replaced with this.buttonType when buttonStyle is fully phased out
26
+ // don't forget to reset this.buttonType's default value to secondary
27
+ return this.buttonType || this.buttonStyle || "secondary";
28
+ }
29
+ get isTruncated() {
30
+ return (!!this.buttonEl && this.tempButtonType === "textonly" && this.buttonEl.offsetWidth < this.buttonEl.scrollWidth);
31
+ }
32
+ get hasTooltip() {
33
+ // tooltip is only rendered for icononly and navigational types, or if the button text is truncated
34
+ return this.tempButtonType === "icononly" || this.tempButtonType === "navigational" || this.isTruncated;
35
+ }
36
+ get tooltipEl() {
37
+ return document.getElementById("wm-tooltip");
38
+ }
39
+ get buttonClasses() {
40
+ let classes = "wm-button";
41
+ classes += this.permanentlyDelete ? " -permanentlydelete" : "";
42
+ classes += this.tempButtonType ? " -" + this.tempButtonType : " -secondary";
43
+ classes += this.textWrap ? "" : " nowrap";
44
+ classes += this.isTabbing ? " user-is-tabbing" : "";
45
+ classes += this.isTruncated ? " -truncated" : "";
46
+ classes += this.customBackground === "dark" ? " dark" : "";
47
+ return classes;
48
+ }
49
+ get iconStyles() {
50
+ let transformStyle = "";
51
+ transformStyle += this.iconRotate ? `rotate(${this.iconRotate}deg)` : "";
52
+ transformStyle += this.iconFlip === "horizontal" ? `scaleX(-1)` : "";
53
+ transformStyle += this.iconFlip === "vertical" ? `scaleY(-1)` : "";
54
+ return Object.assign(Object.assign({}, (this.iconSize && { fontSize: this.iconSize })), ((this.iconRotate || this.iconFlip) && { transform: transformStyle }));
55
+ }
56
+ toggleTabbingOn() {
57
+ this.isTabbing = true;
58
+ }
59
+ toggleTabbingOff() {
60
+ this.isTabbing = false;
61
+ }
62
+ // we need to listen for scroll events during the capture phase because they do not bubble up
63
+ // there can be layouts where the main content has 100vh and overflows
64
+ // in these cases window will register no scroll events unless we catch on they way down
65
+ handleScroll() {
66
+ if (this.tooltipVisible) {
67
+ this.hideTooltip();
68
+ }
69
+ }
70
+ validateType(newValue) {
71
+ const valid = [
72
+ "primary",
73
+ "secondary",
74
+ "textonly",
75
+ "icononly",
76
+ "navigational",
77
+ "selectoronly",
78
+ "pairpositive",
79
+ "pairnegative",
80
+ ].includes(newValue);
81
+ if (!valid) {
82
+ this.buttonType = "secondary";
83
+ }
84
+ this.validateIcon();
85
+ }
86
+ // remove entire watcher after buttonStyle has been fully removed
87
+ validateDeprecatedType(newValue) {
88
+ const valid = ["primary", "secondary", "textonly", "icononly", "navigational", "selectoronly"].includes(newValue);
89
+ if (!valid) {
90
+ this.buttonStyle = "secondary";
91
+ }
92
+ this.validateIcon();
93
+ }
94
+ updateIcon() {
95
+ this.icon = getIconCodeFromName(this.icon);
96
+ }
97
+ validateIcon() {
98
+ switch (this.tempButtonType) {
99
+ case "icononly":
100
+ case "navigational":
101
+ // if the style is icononly or navigational...
102
+ // - an icon must be provided
103
+ if (!this.icon) {
104
+ console.error("wm-button should have a valid 'icon' property when button-type is set to 'icononly' or 'navigational'.");
105
+ }
106
+ // - if no tooltip text was passed and we couldn't generate one, throw an error
107
+ if (!this.tooltip) {
108
+ console.error("wm-button should have a valid 'tooltip' property when button-type is set to 'icononly' or 'navigational'.");
109
+ }
110
+ break;
111
+ case "pairpositive":
112
+ this.icon = "f12c";
113
+ break;
114
+ case "pairnegative":
115
+ this.icon = "f739";
116
+ break;
117
+ }
118
+ }
119
+ handleKeydown(ev) {
120
+ switch (ev.key) {
121
+ case "Enter":
122
+ ev.preventDefault();
123
+ if (!this.isDisabled) {
124
+ this.el.click();
125
+ }
126
+ break;
127
+ }
128
+ }
129
+ componentWillLoad() {
130
+ if (this.buttonStyle) {
131
+ console.warn("wm-button: button-style has been deprecated as of v3.1.0. Please use button-type instead.");
132
+ }
133
+ this.validateType(this.tempButtonType);
134
+ // replacing the prototype's focus event by our own
135
+ // to delegate focus to the appropriate el in the shadow root
136
+ // we could replace by ShadowRoot.delegatesFocus()
137
+ // when there's enough support for it
138
+ // @ts-ignore
139
+ this.el.focus = function () {
140
+ if (!this.disabled) {
141
+ this.shadowRoot.querySelector("button").focus();
142
+ // prevent tooltip from showing on programmatic focus
143
+ requestAnimationFrame(() => {
144
+ this.tooltipVisible = false;
145
+ });
146
+ }
147
+ };
148
+ if (this.icon) {
149
+ this.icon = this.icon = getIconCodeFromName(this.icon);
150
+ }
151
+ }
152
+ componentDidLoad() {
153
+ if (document.body.classList.contains("wmcl-user-is-tabbing")) {
154
+ this.toggleTabbingOn();
155
+ }
156
+ this.ariaPopup = !!this.el.getAttribute("aria-haspopup");
157
+ this.btnPos.new = this.buttonEl.getBoundingClientRect();
158
+ }
159
+ showTooltip() {
160
+ if (this.hasTooltip) {
161
+ // set tooltip text
162
+ this.tooltipEl.textContent = this.isTruncated ? this.el.textContent : this.tooltip;
163
+ // adjust placement in case there is no space to place the tooltip where specified via prop
164
+ // calculation outside of the function to keep it pure
165
+ const adjustedTooltipPlacement = adjustTooltipPlacement(this.tooltipPosition, this.buttonEl, this.tooltipEl);
166
+ this.btnPos.old = {};
167
+ const tooltipRect = this.tooltipEl.getBoundingClientRect();
168
+ this.tooltipEl.style.transitionDelay = "500ms";
169
+ this.tooltipEl.style.opacity = "1";
170
+ // This slight delay fixes an issue for keyboard users:
171
+ // if they tab to a button out of screen bounds, the page scrolls
172
+ // and hideTooltip() would be triggered before the tooltip would show
173
+ setTimeout(() => {
174
+ this.tooltipVisible = true;
175
+ this.positionTooltip(adjustedTooltipPlacement, tooltipRect);
176
+ }, 50);
177
+ }
178
+ }
179
+ positionTooltip(tPos, tooltipRect) {
180
+ if (this.tooltipVisible) {
181
+ window.requestAnimationFrame(() => this.positionTooltip(tPos, tooltipRect));
182
+ }
183
+ this.btnPos.new = this.buttonEl.getBoundingClientRect();
184
+ if (this.btnPos.new.top != this.btnPos.old.top || this.btnPos.new.left != this.btnPos.old.left) {
185
+ // this is to figure out how to offset, given the size of the button and of the tooltip
186
+ // to get the center positions, calculate the difference between the button width and the tooltip width
187
+ const vDiff = (this.btnPos.new.height - tooltipRect.height) / 2;
188
+ const hDiff = (this.btnPos.new.width - tooltipRect.width) / 2;
189
+ // the naming convention defaults to center in the absence of a value
190
+ // Values "top" and "bottom" imply horizontal centering; Values "right" and "left" imply vertical centering
191
+ // therefore we first set to center first, then adjust accordingly
192
+ let vPos = this.btnPos.new.top + vDiff;
193
+ let hPos = this.btnPos.new.left + hDiff;
194
+ if (tPos.includes("top")) {
195
+ vPos = this.btnPos.new.top - tooltipRect.height - 8;
196
+ }
197
+ if (tPos.includes("bottom")) {
198
+ vPos = this.btnPos.new.bottom + 8;
199
+ }
200
+ if (tPos.includes("left")) {
201
+ hPos = this.btnPos.new.left - tooltipRect.width - 8;
202
+ }
203
+ if (tPos.includes("right")) {
204
+ hPos = this.btnPos.new.right + 8;
205
+ }
206
+ // after all positioning has been calculated, if tooltip is off-screen or closer than 24px it is readjusted
207
+ // this only occurs when the tooltip is overflowing to the left and is positioned top or bottom
208
+ // (button placed too far left, or screen size under 268px)
209
+ hPos = Math.max(hPos, 24);
210
+ this.tooltipEl.style.setProperty("--wmTooltipTop", vPos + "px");
211
+ this.tooltipEl.style.setProperty("--wmTooltipLeft", hPos + "px");
212
+ // this.tooltipEl.style.top = vPos + "px";
213
+ // this.tooltipEl.style.left = hPos + "px";
214
+ // this.tooltipEl.style.top = (vPos / 16).toString() + "rem";
215
+ // this.tooltipEl.style.left = (hPos / 16).toString() + "rem";
216
+ this.btnPos.old = this.btnPos.new;
217
+ }
218
+ }
219
+ hideTooltip() {
220
+ if (this.hasTooltip) {
221
+ this.tooltipEl.style.transitionDelay = "0s";
222
+ this.tooltipEl.style.opacity = "0";
223
+ this.tooltipVisible = false;
224
+ }
225
+ }
226
+ showTooltipForKeyboardUsers() {
227
+ if (this.isTabbing) {
228
+ this.showTooltip();
229
+ }
230
+ }
231
+ getAriaLabel() {
232
+ if (this.tempButtonType === "icononly" || this.tempButtonType === "navigational") {
233
+ return this.labelForIdenticalButtons || this.tooltip;
234
+ }
235
+ if (this.labelForIdenticalButtons) {
236
+ return this.labelForIdenticalButtons;
237
+ }
238
+ }
239
+ render() {
240
+ return (h(Host, { class: this.isDisabled ? "button-disabled" : "" },
241
+ h("button", { id: this.id, class: `${this.buttonClasses}`, disabled: this.isDisabled, ref: (el) => (this.buttonEl = el), "aria-label": this.getAriaLabel(), "aria-hasPopup": this.ariaPopup ? "menu" : null, onMouseEnter: () => this.showTooltip(), onMouseLeave: () => this.hideTooltip(), onFocus: () => this.showTooltipForKeyboardUsers(), onBlur: () => this.hideTooltip(), onClick: () => this.hideTooltip() },
242
+ this.icon && (h("span", { class: "mdi", style: this.iconStyles }, String.fromCodePoint(parseInt(`0x${this.icon}`)))),
243
+ h("span", { class: "button-text" },
244
+ h("slot", null)))));
245
+ }
246
+ static get is() { return "wm-button"; }
247
+ static get encapsulation() { return "shadow"; }
248
+ static get originalStyleUrls() { return {
249
+ "$": ["wm-button.scss"]
250
+ }; }
251
+ static get styleUrls() { return {
252
+ "$": ["wm-button.css"]
253
+ }; }
254
+ static get properties() { return {
255
+ "disabled": {
256
+ "type": "boolean",
257
+ "mutable": false,
258
+ "complexType": {
259
+ "original": "boolean",
260
+ "resolved": "boolean",
261
+ "references": {}
262
+ },
263
+ "required": false,
264
+ "optional": false,
265
+ "docs": {
266
+ "tags": [],
267
+ "text": ""
268
+ },
269
+ "attribute": "disabled",
270
+ "reflect": true,
271
+ "defaultValue": "false"
272
+ },
273
+ "buttonType": {
274
+ "type": "string",
275
+ "mutable": true,
276
+ "complexType": {
277
+ "original": "string | null",
278
+ "resolved": "null | string",
279
+ "references": {}
280
+ },
281
+ "required": false,
282
+ "optional": false,
283
+ "docs": {
284
+ "tags": [],
285
+ "text": ""
286
+ },
287
+ "attribute": "button-type",
288
+ "reflect": false,
289
+ "defaultValue": "null"
290
+ },
291
+ "buttonStyle": {
292
+ "type": "string",
293
+ "mutable": true,
294
+ "complexType": {
295
+ "original": "string | null",
296
+ "resolved": "null | string",
297
+ "references": {}
298
+ },
299
+ "required": false,
300
+ "optional": false,
301
+ "docs": {
302
+ "tags": [],
303
+ "text": ""
304
+ },
305
+ "attribute": "button-style",
306
+ "reflect": false,
307
+ "defaultValue": "null"
308
+ },
309
+ "icon": {
310
+ "type": "string",
311
+ "mutable": true,
312
+ "complexType": {
313
+ "original": "string",
314
+ "resolved": "string | undefined",
315
+ "references": {}
316
+ },
317
+ "required": false,
318
+ "optional": true,
319
+ "docs": {
320
+ "tags": [],
321
+ "text": ""
322
+ },
323
+ "attribute": "icon",
324
+ "reflect": true
325
+ },
326
+ "iconSize": {
327
+ "type": "string",
328
+ "mutable": false,
329
+ "complexType": {
330
+ "original": "string",
331
+ "resolved": "string | undefined",
332
+ "references": {}
333
+ },
334
+ "required": false,
335
+ "optional": true,
336
+ "docs": {
337
+ "tags": [],
338
+ "text": ""
339
+ },
340
+ "attribute": "icon-size",
341
+ "reflect": false
342
+ },
343
+ "iconRotate": {
344
+ "type": "number",
345
+ "mutable": false,
346
+ "complexType": {
347
+ "original": "number",
348
+ "resolved": "number | undefined",
349
+ "references": {}
350
+ },
351
+ "required": false,
352
+ "optional": true,
353
+ "docs": {
354
+ "tags": [],
355
+ "text": ""
356
+ },
357
+ "attribute": "icon-rotate",
358
+ "reflect": false
359
+ },
360
+ "iconFlip": {
361
+ "type": "string",
362
+ "mutable": false,
363
+ "complexType": {
364
+ "original": "\"horizontal\" | \"vertical\"",
365
+ "resolved": "\"horizontal\" | \"vertical\" | undefined",
366
+ "references": {}
367
+ },
368
+ "required": false,
369
+ "optional": true,
370
+ "docs": {
371
+ "tags": [],
372
+ "text": ""
373
+ },
374
+ "attribute": "icon-flip",
375
+ "reflect": false
376
+ },
377
+ "tooltip": {
378
+ "type": "string",
379
+ "mutable": true,
380
+ "complexType": {
381
+ "original": "string",
382
+ "resolved": "string | undefined",
383
+ "references": {}
384
+ },
385
+ "required": false,
386
+ "optional": true,
387
+ "docs": {
388
+ "tags": [],
389
+ "text": ""
390
+ },
391
+ "attribute": "tooltip",
392
+ "reflect": true
393
+ },
394
+ "labelForIdenticalButtons": {
395
+ "type": "string",
396
+ "mutable": false,
397
+ "complexType": {
398
+ "original": "string",
399
+ "resolved": "string | undefined",
400
+ "references": {}
401
+ },
402
+ "required": false,
403
+ "optional": true,
404
+ "docs": {
405
+ "tags": [],
406
+ "text": ""
407
+ },
408
+ "attribute": "label-for-identical-buttons",
409
+ "reflect": false
410
+ },
411
+ "tooltipPosition": {
412
+ "type": "string",
413
+ "mutable": false,
414
+ "complexType": {
415
+ "original": "TooltipPlacement",
416
+ "resolved": "\"bottom\" | \"bottom-left\" | \"bottom-right\" | \"left\" | \"right\" | \"top\" | \"top-left\" | \"top-right\"",
417
+ "references": {
418
+ "TooltipPlacement": {
419
+ "location": "import",
420
+ "path": "../../global/interfaces"
421
+ }
422
+ }
423
+ },
424
+ "required": false,
425
+ "optional": false,
426
+ "docs": {
427
+ "tags": [],
428
+ "text": ""
429
+ },
430
+ "attribute": "tooltip-position",
431
+ "reflect": false,
432
+ "defaultValue": "\"bottom-right\""
433
+ },
434
+ "permanentlyDelete": {
435
+ "type": "boolean",
436
+ "mutable": false,
437
+ "complexType": {
438
+ "original": "boolean",
439
+ "resolved": "boolean | undefined",
440
+ "references": {}
441
+ },
442
+ "required": false,
443
+ "optional": true,
444
+ "docs": {
445
+ "tags": [],
446
+ "text": ""
447
+ },
448
+ "attribute": "permanently-delete",
449
+ "reflect": false,
450
+ "defaultValue": "false"
451
+ },
452
+ "textWrap": {
453
+ "type": "boolean",
454
+ "mutable": false,
455
+ "complexType": {
456
+ "original": "boolean",
457
+ "resolved": "boolean",
458
+ "references": {}
459
+ },
460
+ "required": false,
461
+ "optional": false,
462
+ "docs": {
463
+ "tags": [],
464
+ "text": ""
465
+ },
466
+ "attribute": "text-wrap",
467
+ "reflect": false,
468
+ "defaultValue": "true"
469
+ },
470
+ "customBackground": {
471
+ "type": "string",
472
+ "mutable": false,
473
+ "complexType": {
474
+ "original": "string",
475
+ "resolved": "string | undefined",
476
+ "references": {}
477
+ },
478
+ "required": false,
479
+ "optional": true,
480
+ "docs": {
481
+ "tags": [],
482
+ "text": ""
483
+ },
484
+ "attribute": "custom-background",
485
+ "reflect": false
486
+ },
487
+ "tooltipVisible": {
488
+ "type": "boolean",
489
+ "mutable": true,
490
+ "complexType": {
491
+ "original": "boolean",
492
+ "resolved": "boolean",
493
+ "references": {}
494
+ },
495
+ "required": false,
496
+ "optional": false,
497
+ "docs": {
498
+ "tags": [],
499
+ "text": ""
500
+ },
501
+ "attribute": "tooltip-visible",
502
+ "reflect": false,
503
+ "defaultValue": "false"
504
+ }
505
+ }; }
506
+ static get states() { return {
507
+ "isTabbing": {}
508
+ }; }
509
+ static get elementRef() { return "el"; }
510
+ static get watchers() { return [{
511
+ "propName": "buttonType",
512
+ "methodName": "validateType"
513
+ }, {
514
+ "propName": "buttonStyle",
515
+ "methodName": "validateDeprecatedType"
516
+ }, {
517
+ "propName": "icon",
518
+ "methodName": "updateIcon"
519
+ }]; }
520
+ static get listeners() { return [{
521
+ "name": "wmUserIsTabbing",
522
+ "method": "toggleTabbingOn",
523
+ "target": "window",
524
+ "capture": false,
525
+ "passive": false
526
+ }, {
527
+ "name": "wmUserIsNotTabbing",
528
+ "method": "toggleTabbingOff",
529
+ "target": "window",
530
+ "capture": false,
531
+ "passive": false
532
+ }, {
533
+ "name": "scroll",
534
+ "method": "handleScroll",
535
+ "target": "window",
536
+ "capture": true,
537
+ "passive": true
538
+ }, {
539
+ "name": "keydown",
540
+ "method": "handleKeydown",
541
+ "target": undefined,
542
+ "capture": false,
543
+ "passive": false
544
+ }]; }
545
+ }