@watermarkinsights/ripple 3.7.0 → 3.8.0-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 (256) hide show
  1. package/README.md +3 -3
  2. package/dist/cjs/{functions-13b0e88e.js → functions-f0693632.js} +442 -442
  3. package/dist/cjs/{global-c802d13c.js → global-0d9945cb.js} +65 -65
  4. package/dist/cjs/{http-service-9e8c4dd5.js → http-service-494d81de.js} +49 -49
  5. package/dist/cjs/{interfaces-30a74c1f.js → interfaces-a3338581.js} +29 -29
  6. package/dist/cjs/loader.cjs.js +2 -2
  7. package/dist/cjs/priv-chart-popover.cjs.entry.js +79 -79
  8. package/dist/cjs/priv-datepicker.cjs.entry.js +673 -668
  9. package/dist/cjs/priv-navigator-button.cjs.entry.js +19 -19
  10. package/dist/cjs/priv-navigator-item.cjs.entry.js +23 -23
  11. package/dist/cjs/ripple.cjs.js +2 -2
  12. package/dist/cjs/wm-action-menu_2.cjs.entry.js +342 -342
  13. package/dist/cjs/wm-button.cjs.entry.js +237 -237
  14. package/dist/cjs/wm-chart-slice.cjs.entry.js +13 -13
  15. package/dist/cjs/wm-chart.cjs.entry.js +475 -475
  16. package/dist/cjs/wm-datepicker.cjs.entry.js +272 -263
  17. package/dist/cjs/wm-input.cjs.entry.js +135 -135
  18. package/dist/cjs/wm-modal-footer.cjs.entry.js +32 -32
  19. package/dist/cjs/wm-modal-header.cjs.entry.js +34 -34
  20. package/dist/cjs/wm-modal.cjs.entry.js +162 -162
  21. package/dist/cjs/wm-navigator.cjs.entry.js +269 -269
  22. package/dist/cjs/wm-network-uploader.cjs.entry.js +421 -421
  23. package/dist/cjs/wm-option_2.cjs.entry.js +496 -496
  24. package/dist/cjs/wm-pagination.cjs.entry.js +168 -168
  25. package/dist/cjs/wm-search.cjs.entry.js +233 -233
  26. package/dist/cjs/wm-snackbar.cjs.entry.js +171 -171
  27. package/dist/cjs/wm-tab-item_3.cjs.entry.js +298 -298
  28. package/dist/cjs/wm-tag-input.cjs.entry.js +580 -571
  29. package/dist/cjs/wm-timepicker.cjs.entry.js +384 -381
  30. package/dist/cjs/wm-toggletip.cjs.entry.js +125 -125
  31. package/dist/cjs/wm-uploader.cjs.entry.js +347 -347
  32. package/dist/cjs/wm-wrapper.cjs.entry.js +12 -12
  33. package/dist/collection/components/wm-action-menu/wm-action-menu.js +460 -460
  34. package/dist/collection/components/wm-button/wm-button.js +503 -503
  35. package/dist/collection/components/wm-chart/priv-chart-popover/priv-chart-popover.js +232 -232
  36. package/dist/collection/components/wm-chart/wm-chart-slice.js +64 -64
  37. package/dist/collection/components/wm-chart/wm-chart.css +3 -0
  38. package/dist/collection/components/wm-chart/wm-chart.js +718 -718
  39. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.js +1039 -1015
  40. package/dist/collection/components/wm-datepicker/wm-datepicker.js +483 -468
  41. package/dist/collection/components/wm-input/wm-input.js +423 -423
  42. package/dist/collection/components/wm-menuitem/wm-menuitem.js +444 -444
  43. package/dist/collection/components/wm-modal/wm-modal-footer.js +141 -141
  44. package/dist/collection/components/wm-modal/wm-modal-header.js +92 -92
  45. package/dist/collection/components/wm-modal/wm-modal.js +459 -459
  46. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +97 -97
  47. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +114 -114
  48. package/dist/collection/components/wm-navigator/wm-navigator.js +468 -468
  49. package/dist/collection/components/wm-option/wm-option.js +422 -422
  50. package/dist/collection/components/wm-pagination/wm-pagination.js +368 -368
  51. package/dist/collection/components/wm-search/wm-search.js +480 -480
  52. package/dist/collection/components/wm-select/wm-select.js +720 -720
  53. package/dist/collection/components/wm-snackbar/wm-snackbar.js +297 -297
  54. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +216 -216
  55. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +330 -330
  56. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +104 -104
  57. package/dist/collection/components/wm-tag-input/wm-tag-input.js +810 -801
  58. package/dist/collection/components/wm-timepicker/wm-timepicker.js +583 -580
  59. package/dist/collection/components/wm-toggletip/wm-toggletip.js +241 -241
  60. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.js +753 -753
  61. package/dist/collection/components/wm-uploader/wm-uploader.js +748 -748
  62. package/dist/collection/components/wm-wrapper/wm-wrapper.js +27 -27
  63. package/dist/collection/dev/scripts.js +20 -20
  64. package/dist/collection/global/__mocks__/functions.js +6 -6
  65. package/dist/collection/global/functions.js +445 -445
  66. package/dist/collection/global/global.js +72 -72
  67. package/dist/collection/global/interfaces.js +49 -49
  68. package/dist/collection/global/services/__mocks__/http-service.js +130 -130
  69. package/dist/collection/global/services/http-service.js +50 -50
  70. package/dist/collection/lang/lang.js +5 -5
  71. package/dist/collection/lang/missing.js +39 -39
  72. package/dist/collection/lang/piglatin.js +93 -93
  73. package/dist/esm/{functions-6ddad20e.js → functions-cbfc81d1.js} +442 -442
  74. package/dist/esm/{global-a4da88c7.js → global-6f2aeeeb.js} +65 -65
  75. package/dist/esm/{http-service-5d037e16.js → http-service-3dc3b3e7.js} +49 -49
  76. package/dist/esm/{interfaces-61c6305b.js → interfaces-2b97fab2.js} +29 -29
  77. package/dist/esm/loader.js +2 -2
  78. package/dist/esm/polyfills/core-js.js +0 -0
  79. package/dist/esm/polyfills/dom.js +0 -0
  80. package/dist/esm/polyfills/es5-html-element.js +0 -0
  81. package/dist/esm/polyfills/index.js +0 -0
  82. package/dist/esm/polyfills/system.js +0 -0
  83. package/dist/esm/priv-chart-popover.entry.js +79 -79
  84. package/dist/esm/priv-datepicker.entry.js +673 -668
  85. package/dist/esm/priv-navigator-button.entry.js +19 -19
  86. package/dist/esm/priv-navigator-item.entry.js +23 -23
  87. package/dist/esm/ripple.js +2 -2
  88. package/dist/esm/wm-action-menu_2.entry.js +342 -342
  89. package/dist/esm/wm-button.entry.js +237 -237
  90. package/dist/esm/wm-chart-slice.entry.js +13 -13
  91. package/dist/esm/wm-chart.entry.js +475 -475
  92. package/dist/esm/wm-datepicker.entry.js +272 -263
  93. package/dist/esm/wm-input.entry.js +135 -135
  94. package/dist/esm/wm-modal-footer.entry.js +32 -32
  95. package/dist/esm/wm-modal-header.entry.js +34 -34
  96. package/dist/esm/wm-modal.entry.js +162 -162
  97. package/dist/esm/wm-navigator.entry.js +269 -269
  98. package/dist/esm/wm-network-uploader.entry.js +421 -421
  99. package/dist/esm/wm-option_2.entry.js +496 -496
  100. package/dist/esm/wm-pagination.entry.js +168 -168
  101. package/dist/esm/wm-search.entry.js +233 -233
  102. package/dist/esm/wm-snackbar.entry.js +171 -171
  103. package/dist/esm/wm-tab-item_3.entry.js +298 -298
  104. package/dist/esm/wm-tag-input.entry.js +580 -571
  105. package/dist/esm/wm-timepicker.entry.js +384 -381
  106. package/dist/esm/wm-toggletip.entry.js +125 -125
  107. package/dist/esm/wm-uploader.entry.js +347 -347
  108. package/dist/esm/wm-wrapper.entry.js +12 -12
  109. package/dist/esm-es5/functions-cbfc81d1.js +15 -0
  110. package/dist/esm-es5/global-6f2aeeeb.js +1 -0
  111. package/dist/esm-es5/http-service-3dc3b3e7.js +1 -0
  112. package/dist/esm-es5/index-66f8130e.js +1 -0
  113. package/dist/esm-es5/index.js +0 -0
  114. package/dist/esm-es5/interfaces-2b97fab2.js +1 -0
  115. package/dist/esm-es5/loader.js +1 -0
  116. package/dist/esm-es5/priv-chart-popover.entry.js +1 -0
  117. package/dist/esm-es5/priv-datepicker.entry.js +1 -0
  118. package/dist/esm-es5/priv-navigator-button.entry.js +1 -0
  119. package/dist/esm-es5/priv-navigator-item.entry.js +1 -0
  120. package/dist/esm-es5/ripple.js +1 -0
  121. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -0
  122. package/dist/esm-es5/wm-button.entry.js +1 -0
  123. package/dist/esm-es5/wm-chart-slice.entry.js +1 -0
  124. package/dist/esm-es5/wm-chart.entry.js +1 -0
  125. package/dist/esm-es5/wm-datepicker.entry.js +1 -0
  126. package/dist/esm-es5/wm-input.entry.js +1 -0
  127. package/dist/esm-es5/wm-modal-footer.entry.js +1 -0
  128. package/dist/esm-es5/wm-modal-header.entry.js +1 -0
  129. package/dist/esm-es5/wm-modal.entry.js +1 -0
  130. package/dist/esm-es5/wm-navigator.entry.js +1 -0
  131. package/dist/esm-es5/wm-network-uploader.entry.js +1 -0
  132. package/dist/esm-es5/wm-option_2.entry.js +1 -0
  133. package/dist/esm-es5/wm-pagination.entry.js +1 -0
  134. package/dist/esm-es5/wm-search.entry.js +1 -0
  135. package/dist/esm-es5/wm-snackbar.entry.js +1 -0
  136. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -0
  137. package/dist/esm-es5/wm-tag-input.entry.js +1 -0
  138. package/dist/esm-es5/wm-timepicker.entry.js +1 -0
  139. package/dist/esm-es5/wm-toggletip.entry.js +1 -0
  140. package/dist/esm-es5/wm-uploader.entry.js +1 -0
  141. package/dist/esm-es5/wm-wrapper.entry.js +1 -0
  142. package/dist/index.js +1 -1
  143. package/dist/loader/index.js +1 -1
  144. package/dist/ripple/p-0418abd7.system.js +15 -0
  145. package/dist/ripple/p-065e2ca1.entry.js +1 -0
  146. package/dist/ripple/p-06627dcf.entry.js +1 -0
  147. package/dist/ripple/p-08b2262e.system.entry.js +1 -0
  148. package/dist/ripple/p-09432004.system.entry.js +1 -0
  149. package/dist/ripple/{p-bc9ca97b.entry.js → p-0d8bd4ee.entry.js} +1 -1
  150. package/dist/ripple/{p-cfdf1a79.entry.js → p-111f705a.entry.js} +1 -1
  151. package/dist/ripple/p-1d899a2d.system.entry.js +1 -0
  152. package/dist/ripple/p-252e91de.entry.js +1 -0
  153. package/dist/ripple/p-261ea633.system.entry.js +1 -0
  154. package/dist/ripple/p-2cdfb4cc.entry.js +1 -0
  155. package/dist/ripple/p-2d49a016.system.entry.js +1 -0
  156. package/dist/ripple/{p-e43b4eda.entry.js → p-2f91e2a6.entry.js} +1 -1
  157. package/dist/ripple/p-366a3db1.system.entry.js +1 -0
  158. package/dist/ripple/p-3e1dd662.entry.js +1 -0
  159. package/dist/ripple/p-3fb41fe3.system.entry.js +1 -0
  160. package/dist/ripple/{p-888bec42.js → p-43f1298b.js} +0 -0
  161. package/dist/ripple/p-50ea2036.system.js +1 -0
  162. package/dist/ripple/{p-d22c957d.entry.js → p-51d2b9a0.entry.js} +1 -1
  163. package/dist/ripple/p-5a528af7.entry.js +1 -0
  164. package/dist/ripple/{p-66513af1.entry.js → p-5ad7afc0.entry.js} +1 -1
  165. package/dist/ripple/p-5bd3aa5a.system.entry.js +1 -0
  166. package/dist/ripple/p-656f8dad.system.js +1 -0
  167. package/dist/ripple/p-67fcdd5d.entry.js +1 -0
  168. package/dist/ripple/p-6b4374e3.system.entry.js +1 -0
  169. package/dist/ripple/p-6bc37009.system.entry.js +1 -0
  170. package/dist/ripple/p-7a9aac92.system.entry.js +1 -0
  171. package/dist/ripple/p-7bc744bf.system.entry.js +1 -0
  172. package/dist/ripple/p-85d12cf2.system.entry.js +1 -0
  173. package/dist/ripple/{p-08b273ba.entry.js → p-8afdc986.entry.js} +1 -1
  174. package/dist/ripple/p-8d97d1d5.system.entry.js +1 -0
  175. package/dist/ripple/p-8f05bc58.system.entry.js +1 -0
  176. package/dist/ripple/p-90aebfd6.system.entry.js +1 -0
  177. package/dist/ripple/p-9276c5e4.entry.js +1 -0
  178. package/dist/ripple/p-92b6bc97.system.entry.js +1 -0
  179. package/dist/ripple/p-99548d58.system.js +1 -0
  180. package/dist/ripple/p-9d02957d.system.js +1 -0
  181. package/dist/ripple/p-ae4e95ce.system.entry.js +1 -0
  182. package/dist/ripple/p-b3ce2033.system.entry.js +1 -0
  183. package/dist/ripple/p-b4e9a8e3.entry.js +1 -0
  184. package/dist/ripple/{p-857a0bc0.js → p-b5edcf38.js} +0 -0
  185. package/dist/ripple/p-b626f3b9.system.entry.js +1 -0
  186. package/dist/ripple/p-b840acea.system.entry.js +1 -0
  187. package/dist/ripple/p-ba30bf08.js +1 -0
  188. package/dist/ripple/p-c10dee71.system.js +1 -0
  189. package/dist/ripple/p-c3a9a5da.system.entry.js +1 -0
  190. package/dist/ripple/p-c730ce74.entry.js +1 -0
  191. package/dist/ripple/p-d0643c9b.entry.js +1 -0
  192. package/dist/ripple/p-da78496a.entry.js +1 -0
  193. package/dist/ripple/{p-b8aa478f.entry.js → p-dc196bc2.entry.js} +1 -1
  194. package/dist/ripple/p-deae1a7a.entry.js +1 -0
  195. package/dist/ripple/p-e06b8ab3.system.entry.js +1 -0
  196. package/dist/ripple/{p-b495e06c.entry.js → p-e3bab713.entry.js} +1 -1
  197. package/dist/ripple/p-e8acac87.system.entry.js +1 -0
  198. package/dist/ripple/p-eed76888.system.entry.js +1 -0
  199. package/dist/ripple/p-f5df5903.system.js +1 -0
  200. package/dist/ripple/{p-a6d6eae7.js → p-fd8070fb.js} +0 -0
  201. package/dist/ripple/p-ff5ec153.entry.js +1 -0
  202. package/dist/ripple/ripple.esm.js +1 -1
  203. package/dist/ripple/ripple.js +130 -0
  204. package/dist/types/components/wm-action-menu/wm-action-menu.d.ts +48 -48
  205. package/dist/types/components/wm-button/wm-button.d.ts +44 -44
  206. package/dist/types/components/wm-chart/priv-chart-popover/priv-chart-popover.d.ts +23 -23
  207. package/dist/types/components/wm-chart/wm-chart-slice.d.ts +8 -8
  208. package/dist/types/components/wm-chart/wm-chart.d.ts +82 -82
  209. package/dist/types/components/wm-datepicker/priv-datepicker/priv-datepicker.d.ts +80 -76
  210. package/dist/types/components/wm-datepicker/wm-datepicker.d.ts +42 -41
  211. package/dist/types/components/wm-input/wm-input.d.ts +46 -46
  212. package/dist/types/components/wm-menuitem/wm-menuitem.d.ts +34 -34
  213. package/dist/types/components/wm-modal/wm-modal-footer.d.ts +15 -15
  214. package/dist/types/components/wm-modal/wm-modal-header.d.ts +12 -12
  215. package/dist/types/components/wm-modal/wm-modal.d.ts +41 -41
  216. package/dist/types/components/wm-navigator/priv-navigator-button/priv-navigator-button.d.ts +10 -10
  217. package/dist/types/components/wm-navigator/priv-navigator-item/priv-navigator-item.d.ts +13 -13
  218. package/dist/types/components/wm-navigator/wm-navigator.d.ts +61 -61
  219. package/dist/types/components/wm-option/wm-option.d.ts +32 -32
  220. package/dist/types/components/wm-pagination/wm-pagination.d.ts +32 -32
  221. package/dist/types/components/wm-search/wm-search.d.ts +86 -86
  222. package/dist/types/components/wm-select/wm-select.d.ts +66 -66
  223. package/dist/types/components/wm-snackbar/wm-snackbar.d.ts +35 -35
  224. package/dist/types/components/wm-tabs/wm-tab-item/wm-tab-item.d.ts +38 -38
  225. package/dist/types/components/wm-tabs/wm-tab-list/wm-tab-list.d.ts +53 -53
  226. package/dist/types/components/wm-tabs/wm-tab-panel/wm-tab-panel.d.ts +20 -20
  227. package/dist/types/components/wm-tag-input/wm-tag-input.d.ts +92 -92
  228. package/dist/types/components/wm-timepicker/wm-timepicker.d.ts +61 -61
  229. package/dist/types/components/wm-toggletip/wm-toggletip.d.ts +27 -27
  230. package/dist/types/components/wm-uploader/wm-network-uploader/wm-network-uploader.d.ts +85 -85
  231. package/dist/types/components/wm-uploader/wm-uploader.d.ts +80 -80
  232. package/dist/types/components/wm-wrapper/wm-wrapper.d.ts +7 -7
  233. package/dist/types/components.d.ts +25 -24
  234. package/dist/types/global/__mocks__/functions.d.ts +6 -6
  235. package/dist/types/global/functions.d.ts +40 -40
  236. package/dist/types/global/global.d.ts +1 -1
  237. package/dist/types/global/interfaces.d.ts +34 -34
  238. package/dist/types/global/services/__mocks__/http-service.d.ts +6 -6
  239. package/dist/types/global/services/http-service.d.ts +4 -4
  240. package/dist/types/lang/lang.d.ts +5 -5
  241. package/package.json +47 -47
  242. package/dist/ripple/p-0068e871.entry.js +0 -1
  243. package/dist/ripple/p-00999aeb.entry.js +0 -1
  244. package/dist/ripple/p-11c09317.entry.js +0 -1
  245. package/dist/ripple/p-196b4c55.entry.js +0 -1
  246. package/dist/ripple/p-1a3df227.entry.js +0 -1
  247. package/dist/ripple/p-3590a57f.entry.js +0 -1
  248. package/dist/ripple/p-3a178ac8.entry.js +0 -1
  249. package/dist/ripple/p-46371fad.entry.js +0 -1
  250. package/dist/ripple/p-5548fc7c.js +0 -1
  251. package/dist/ripple/p-5c73fd59.entry.js +0 -1
  252. package/dist/ripple/p-828316d6.entry.js +0 -1
  253. package/dist/ripple/p-9624967f.entry.js +0 -1
  254. package/dist/ripple/p-99e2c5f6.entry.js +0 -1
  255. package/dist/ripple/p-bf985c5d.entry.js +0 -1
  256. package/dist/ripple/p-cd6de442.entry.js +0 -1
@@ -6605,448 +6605,448 @@ function createIntl(config, cache) {
6605
6605
  return __assign(__assign({}, resolvedConfig), { formatters: formatters, formatNumber: formatNumber.bind(null, resolvedConfig, formatters.getNumberFormat), formatNumberToParts: formatNumberToParts.bind(null, resolvedConfig, formatters.getNumberFormat), formatRelativeTime: formatRelativeTime.bind(null, resolvedConfig, formatters.getRelativeTimeFormat), formatDate: formatDate.bind(null, resolvedConfig, formatters.getDateTimeFormat), formatDateToParts: formatDateToParts.bind(null, resolvedConfig, formatters.getDateTimeFormat), formatTime: formatTime.bind(null, resolvedConfig, formatters.getDateTimeFormat), formatDateTimeRange: formatDateTimeRange.bind(null, resolvedConfig, formatters.getDateTimeFormat), formatTimeToParts: formatTimeToParts.bind(null, resolvedConfig, formatters.getDateTimeFormat), formatPlural: formatPlural.bind(null, resolvedConfig, formatters.getPluralRules), formatMessage: formatMessage.bind(null, resolvedConfig, formatters), formatList: formatList.bind(null, resolvedConfig, formatters.getListFormat), formatListToParts: formatListToParts.bind(null, resolvedConfig, formatters.getListFormat), formatDisplayName: formatDisplayName.bind(null, resolvedConfig, formatters.getDisplayNames) });
6606
6606
  }
6607
6607
 
6608
- const DEFAULT_LANGUAGE = "en";
6609
- function getBrowserLang() {
6610
- const langAttr = document.documentElement.getAttribute("lang");
6611
- if (!!langAttr) {
6612
- return langAttr;
6613
- }
6614
- else if (window.navigator && window.navigator.language) {
6615
- const lang = window.navigator.languages ? window.navigator.languages[0] : window.navigator.language;
6616
- return lang.slice(0, 2);
6617
- }
6618
- else {
6619
- return DEFAULT_LANGUAGE;
6620
- }
6621
- }
6622
- // prevents memory leak
6623
- const cache = createIntlCache();
6624
- const locale = getBrowserLang();
6625
- const intl = createIntl({
6626
- locale: locale,
6627
- defaultLocale: "en",
6628
- messages: lang[locale] || en,
6629
- }, cache);
6630
- function generateId() {
6631
- return "wmcl-" + Math.random().toString(36).substr(2, 10);
6632
- }
6633
- function debounce(fn, wait) {
6634
- let timeout;
6635
- return function () {
6636
- const context = this;
6637
- const functionCall = () => fn.apply(context, arguments);
6638
- clearTimeout(timeout);
6639
- timeout = setTimeout(functionCall, wait);
6640
- };
6641
- }
6642
- function getTextDir() {
6643
- const dir = document.querySelector("html").getAttribute("dir");
6644
- return dir ? dir.toLowerCase() : "";
6645
- }
6646
- function getPosition(el) {
6647
- const coords = el.getBoundingClientRect();
6648
- let x = coords.x;
6649
- let y = coords.y;
6650
- // Edge doesn't have x and y
6651
- if (!x) {
6652
- if (getTextDir() === "rtl") {
6653
- x = coords.right;
6654
- }
6655
- else {
6656
- x = coords.left;
6657
- }
6658
- y = coords.top;
6659
- }
6660
- return { x, y };
6661
- }
6662
- function findParentWithScrollbar(el) {
6663
- while (!!el) {
6664
- if (el.scrollHeight > el.clientHeight && ["scroll", "auto"].includes(window.getComputedStyle(el).overflowY)) {
6665
- return el;
6666
- }
6667
- el = el.parentElement;
6668
- }
6669
- }
6670
- function findParentWithHiddenOverflow(el) {
6671
- while (!!el) {
6672
- if (window.getComputedStyle(el).overflowY !== "visible") {
6673
- return el;
6674
- }
6675
- el = el.parentElement;
6676
- }
6677
- }
6678
- function getClosableElementMeasurements(fixedEl, closableEl) {
6679
- const parent = findParentWithHiddenOverflow(fixedEl);
6680
- // if parent is not found, measurements are checked against the viewport
6681
- return {
6682
- closableElHeight: closableEl.clientHeight,
6683
- closableElWidth: closableEl.clientWidth,
6684
- // NB boundingClientRect.bottom is space from top of viewport to bottom of el
6685
- // to get space below the el -> height of viewport minus boundingClientRect.bottom
6686
- spaceAbove: parent
6687
- ? fixedEl.getBoundingClientRect().top - parent.getBoundingClientRect().top
6688
- : fixedEl.getBoundingClientRect().top,
6689
- // NB boundingClientRect.bottom is space from top of viewport to bottom of el
6690
- // to get space below the el -> height of viewport minus boundingClientRect.bottom
6691
- spaceBelow: parent
6692
- ? parent.getBoundingClientRect().bottom - fixedEl.getBoundingClientRect().bottom
6693
- : document.documentElement.clientHeight - fixedEl.getBoundingClientRect().bottom,
6694
- spaceLeft: parent
6695
- ? fixedEl.getBoundingClientRect().left - parent.getBoundingClientRect().left
6696
- : fixedEl.getBoundingClientRect().left,
6697
- spaceRight: parent
6698
- ? parent.getBoundingClientRect().right - fixedEl.getBoundingClientRect().right
6699
- : document.documentElement.clientWidth - fixedEl.getBoundingClientRect().right,
6700
- };
6701
- }
6702
- function shouldOpenUp(fixedEl, //the element visible on the page when the component is closed
6703
- closableEl, //the dropdown/popup/etc that becomes visible when the component is open
6704
- offsetAbove = 0, // if closableEl covers a part of fixedEl, that part should be offset
6705
- offsetBelow = 0 // if closableEl covers a part of fixedEl, that part should be offset
6706
- ) {
6707
- const { closableElHeight, spaceAbove, spaceBelow } = getClosableElementMeasurements(fixedEl, closableEl);
6708
- //we want to open up only if there's not enough space below AND there is enough space above
6709
- const openUp = closableElHeight > spaceBelow + offsetBelow && closableElHeight <= spaceAbove + offsetAbove;
6710
- return openUp;
6711
- }
6712
- function shouldOpenDown(fixedEl, //the element visible on the page when the component is closed
6713
- closableEl, //the dropdown/popup/etc that becomes visible when the component is open
6714
- offsetAbove = 0, // if closableEl covers a part of fixedEl, that part should be offset
6715
- offsetBelow = 0 // if closableEl covers a part of fixedEl, that part should be offset
6716
- ) {
6717
- const { closableElHeight, spaceAbove, spaceBelow } = getClosableElementMeasurements(fixedEl, closableEl);
6718
- //we want to open up only if there's not enough space below AND there is enough space above
6719
- const openDown = closableElHeight > spaceAbove + offsetAbove && closableElHeight <= spaceBelow + offsetBelow;
6720
- return openDown;
6721
- }
6722
- function shouldShiftRight(fixedEl, closableEl) {
6723
- const { closableElWidth, spaceLeft, spaceRight } = getClosableElementMeasurements(fixedEl, closableEl);
6724
- const needsSpaceLeft = closableElWidth > spaceLeft && spaceRight > spaceLeft;
6725
- return needsSpaceLeft;
6726
- }
6727
- function shouldShiftLeft(fixedEl, closableEl) {
6728
- const { closableElWidth, spaceLeft, spaceRight } = getClosableElementMeasurements(fixedEl, closableEl);
6729
- const needsSpaceRight = closableElWidth > spaceRight && spaceLeft > spaceRight;
6730
- return needsSpaceRight;
6731
- }
6732
- function adjustTooltipPosition(tPos, el, tooltipEl) {
6733
- // position must be reset before measurements are taken in adjustTooltipPosition
6734
- // otherwise text-wrapping from previous position makes width measurement inconsistent
6735
- tooltipEl.style.top = "";
6736
- tooltipEl.style.left = "";
6737
- const { spaceLeft, spaceRight, spaceBelow, spaceAbove } = getClosableElementMeasurements(el, tooltipEl);
6738
- const tooltipWidth = tooltipEl.getBoundingClientRect().width;
6739
- const tooltipHeight = tooltipEl.getBoundingClientRect().height;
6740
- const enoughSpaceAbove = spaceAbove > tooltipHeight;
6741
- const enoughSpaceBelow = spaceBelow > tooltipHeight;
6742
- // a tooltip should never be closer than 24px to the edge of a screen
6743
- const enoughSpaceLeft = spaceLeft - 24 > tooltipWidth;
6744
- const enoughSpaceRight = spaceRight - 24 > tooltipWidth;
6745
- const swapAbove = (position) => {
6746
- return !enoughSpaceAbove ? position.replace("top", "bottom") : position;
6747
- };
6748
- const swapBelow = (position) => {
6749
- return !enoughSpaceBelow && enoughSpaceAbove ? position.replace("bottom", "top") : position;
6750
- };
6751
- const swapLeft = (position, centeredPosition) => {
6752
- if (!enoughSpaceLeft && enoughSpaceRight) {
6753
- position = position.replace("left", "right");
6754
- }
6755
- else if (!enoughSpaceLeft && !enoughSpaceRight) {
6756
- position = centeredPosition;
6757
- }
6758
- return position;
6759
- };
6760
- const swapRight = (position, centeredPosition) => {
6761
- if (!enoughSpaceRight && enoughSpaceLeft) {
6762
- position = position.replace("right", "left");
6763
- }
6764
- else if (!enoughSpaceRight && !enoughSpaceLeft) {
6765
- position = centeredPosition;
6766
- }
6767
- return position;
6768
- };
6769
- // horizontal checks must occur before vertical checks, because horizontal can affect vertical positioning but not vice versa
6770
- switch (tPos) {
6771
- case "left":
6772
- tPos = swapLeft(tPos, "bottom");
6773
- case "right":
6774
- tPos = swapRight(tPos, "bottom");
6775
- case "top-left":
6776
- tPos = swapLeft(tPos, "top");
6777
- tPos = swapAbove(tPos);
6778
- case "top-right":
6779
- tPos = swapRight(tPos, "top");
6780
- tPos = swapAbove(tPos);
6781
- case "bottom-left":
6782
- tPos = swapLeft(tPos, "bottom");
6783
- tPos = swapBelow(tPos);
6784
- case "bottom-right":
6785
- tPos = swapRight(tPos, "bottom");
6786
- tPos = swapBelow(tPos);
6787
- case "top":
6788
- tPos = swapAbove(tPos);
6789
- case "bottom":
6790
- tPos = swapBelow(tPos);
6791
- }
6792
- return tPos;
6793
- }
6794
- function hasRoomRight(x, spaceNeeded) {
6795
- let horizOffset = 0;
6796
- // if (getTextDir() === "ltr") {
6797
- if (x.type === "click") {
6798
- // if it's a mouse event, deal with mouse coords
6799
- horizOffset = x.clientX;
6800
- // if it's a focus event, the offset is 0
6801
- }
6802
- else if (x.type === "focus") {
6803
- horizOffset = 0;
6804
- }
6805
- else {
6806
- // otherwise an element was passed, calculate how far it is from the edge of the window
6807
- let el = x; // re-assignment is for clarity
6808
- while (el) {
6809
- if (el.tagName == "BODY") {
6810
- // deal with browser quirks with body/window/document and page scroll
6811
- var xScroll = el.scrollLeft || document.documentElement.scrollLeft;
6812
- horizOffset += el.offsetLeft - xScroll + el.clientLeft;
6813
- }
6814
- else {
6815
- // for all other non-BODY elements
6816
- horizOffset += el.offsetLeft - el.scrollLeft + el.clientLeft;
6817
- }
6818
- el = el.offsetParent;
6819
- }
6820
- // }
6821
- }
6822
- return window.innerWidth - horizOffset >= spaceNeeded;
6823
- }
6824
- function checkForActiveElInShadow(element) {
6825
- while (element && element.shadowRoot) {
6826
- element = element.shadowRoot.activeElement;
6827
- }
6828
- return element;
6829
- }
6830
- function checkForFocusableElInShadow(element) {
6831
- const selectors = [
6832
- "button",
6833
- "a",
6834
- "input",
6835
- "select",
6836
- "textarea",
6837
- "wm-button",
6838
- "wm-search",
6839
- "wm-select",
6840
- "wm-action-menu",
6841
- "wm-tab-item",
6842
- "wm-datepicker",
6843
- ];
6844
- let focusableEl = element;
6845
- selectors.forEach((selector) => {
6846
- if (focusableEl && focusableEl.shadowRoot) {
6847
- let elInShadow = focusableEl.shadowRoot.querySelector(selector);
6848
- if (elInShadow) {
6849
- if (selector.startsWith("wm-")) {
6850
- focusableEl = checkForFocusableElInShadow(elInShadow);
6851
- }
6852
- else {
6853
- focusableEl = elInShadow;
6854
- }
6855
- }
6856
- }
6857
- });
6858
- return focusableEl;
6859
- }
6860
- function isFocusable(element) {
6861
- if (element.tabIndex > 0 || (element.tabIndex === 0 && element.getAttribute("tabIndex") !== null)) {
6862
- return true;
6863
- }
6864
- if (element.disabled) {
6865
- return false;
6866
- }
6867
- switch (element.nodeName) {
6868
- case "A":
6869
- return !!element.href && element.rel != "ignore";
6870
- case "INPUT":
6871
- return element.type != "hidden" && element.type != "file";
6872
- case "BUTTON":
6873
- case "SELECT":
6874
- case "TEXTAREA":
6875
- case "WM-BUTTON":
6876
- case "WM-SELECT":
6877
- case "WM-ACTION-MENU":
6878
- case "WM-DATEPICKER":
6879
- case "WM-TIMEPICKER":
6880
- case "WM-INPUT":
6881
- case "WM-TAG-INPUT":
6882
- case "WM-TAB-ITEM":
6883
- case "WM-SEARCH":
6884
- return true;
6885
- default:
6886
- return false;
6887
- }
6888
- }
6889
- function getFirstFocusableDescendant(element) {
6890
- if (isFocusable(element)) {
6891
- return checkForFocusableElInShadow(element);
6892
- }
6893
- else if (element.childNodes.length > 0) {
6894
- element.childNodes.forEach((i) => {
6895
- const childEl = getFirstFocusableDescendant(i);
6896
- return childEl && checkForFocusableElInShadow(childEl);
6897
- });
6898
- }
6899
- }
6900
- function hasValidType(file, types) {
6901
- const acceptedExtensions = types.split(" ");
6902
- const parts = file.name && file.name.split(".");
6903
- const ext = parts && parts.length > 1 && parts[parts.length - 1];
6904
- return ext
6905
- ? acceptedExtensions.includes(ext.toLowerCase())
6906
- : // fallback: if we couldn't obtain an extension,
6907
- // validate based on MIME type...
6908
- !!file.type
6909
- ? getAcceptedMimeTypesList(acceptedExtensions).includes(file.type)
6910
- : // ...and if that failed too, accept the file
6911
- // as it's preferable to accept an invalid file
6912
- // than refusing a valid one (back-end will take care of what slips through)
6913
- true;
6914
- }
6915
- // takes a string (space separated list of extensions), returns an array of strings (corresponding MIME types)
6916
- function getAcceptedMimeTypesList(acceptedExtensions) {
6917
- // this is just a list of common file types (regardless of whether they are/can be valid or not)
6918
- // front end checks are just a convenience to users, independent of security.
6919
- // it allows users to be notified of an invalid type as soon as they select the file, rather than when it gets uploaded
6920
- const lookupTable = {
6921
- aac: ["audio/aac"],
6922
- abw: ["application/x-abiword"],
6923
- arc: ["application/x-freearc"],
6924
- avi: ["video/x-msvideo"],
6925
- azw: ["application/vnd.amazon.ebook"],
6926
- bin: ["application/octet-stream"],
6927
- bmp: ["image/bmp"],
6928
- bz: ["application/x-bzip"],
6929
- bz2: ["application/x-bzip2"],
6930
- csh: ["application/x-csh"],
6931
- css: ["text/css"],
6932
- csv: ["text/csv"],
6933
- doc: ["application/msword"],
6934
- docx: ["application/vnd.openxmlformats-officedocument.wordprocessingml.document"],
6935
- eot: ["application/vnd.ms-fontobject"],
6936
- epub: ["application/epub+zip"],
6937
- gz: ["application/gzip"],
6938
- gif: ["image/gif"],
6939
- htm: ["text/html"],
6940
- html: ["text/html"],
6941
- ico: ["image/vnd.microsoft.icon"],
6942
- ics: ["text/calendar"],
6943
- jar: ["application/java-archive"],
6944
- jpeg: ["image/jpeg"],
6945
- jpg: ["image/jpeg"],
6946
- js: ["text/javascript"],
6947
- json: ["application/json"],
6948
- jsonld: ["application/ld+json"],
6949
- log: ["text/plain"],
6950
- mid: ["audio/x-midi"],
6951
- midi: ["audio/x-midi"],
6952
- mjs: ["text/javascript"],
6953
- mp3: ["audio/mpeg"],
6954
- mpeg: ["video/mpeg"],
6955
- mpkg: ["application/vnd.apple.installer+xml"],
6956
- odp: ["application/vnd.oasis.opendocument.presentation"],
6957
- ods: ["application/vnd.oasis.opendocument.spreadsheet"],
6958
- odt: ["application/vnd.oasis.opendocument.text"],
6959
- oga: ["audio/ogg"],
6960
- ogv: ["video/ogg"],
6961
- ogx: ["application/ogg"],
6962
- opus: ["audio/opus"],
6963
- otf: ["font/otf"],
6964
- png: ["image/png"],
6965
- pdf: ["application/pdf"],
6966
- php: ["application/php"],
6967
- ppt: ["application/vnd.ms-powerpoint"],
6968
- pptx: ["application/vnd.openxmlformats-officedocument.presentationml.presentation"],
6969
- rar: ["application/vnd.rar", "application/x-rar", "application/x-rar-compressed"],
6970
- rtf: ["application/rtf"],
6971
- sh: ["application/x-sh"],
6972
- svg: ["image/svg+xml"],
6973
- swf: ["application/x-shockwave-flash"],
6974
- tar: ["application/x-tar"],
6975
- tif: ["image/tiff"],
6976
- tiff: ["image/tiff"],
6977
- ts: ["video/mp2t"],
6978
- ttf: ["font/ttf"],
6979
- txt: ["text/plain"],
6980
- vsd: ["application/vnd.visio"],
6981
- wav: ["audio/wav"],
6982
- weba: ["audio/webm"],
6983
- webm: ["video/webm"],
6984
- webp: ["image/webp"],
6985
- woff: ["font/woff"],
6986
- woff2: ["font/woff2"],
6987
- xhtml: ["application/xhtml+xml"],
6988
- xls: ["application/vnd.ms-excel"],
6989
- xlsx: ["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],
6990
- xml: ["application/xml", "text/xml"],
6991
- xul: ["application/vnd.mozilla.xul+xml"],
6992
- zip: ["application/zip", "application/x-zip-compressed", "multipart/x-zip"],
6993
- "3gp": ["video/3gpp", "audio/3gpp"],
6994
- "3g2": ["video/3gpp2", "audio/3gpp2"],
6995
- "7z": ["application/x-7z-compressed"],
6996
- };
6997
- return acceptedExtensions.reduce((acc, ext) => acc.concat(lookupTable[ext]), []);
6998
- }
6999
- function snakeCaseToCamelCase(str) {
7000
- const snakeCaseRegexp = /^([a-z0-9]*)(_[a-z0-9]*)*$/g;
7001
- if (snakeCaseRegexp.test(str)) {
7002
- let camelCase = "";
7003
- let arr = str.split("_");
7004
- arr.forEach((word, idx) => {
7005
- camelCase += idx === 0 ? word.toLowerCase() : word.charAt(0).toUpperCase() + word.slice(1);
7006
- });
7007
- return camelCase;
7008
- }
7009
- else {
7010
- return str;
7011
- }
7012
- }
7013
- function getNewIndexToFocus(currentIndex, direction, listLength) {
7014
- let newIndex = currentIndex;
7015
- if (direction === "ArrowDown") {
7016
- newIndex = (currentIndex + 1) % listLength;
7017
- }
7018
- if (direction === "ArrowUp") {
7019
- newIndex = currentIndex === 0 ? listLength - 1 : currentIndex - 1;
7020
- }
7021
- return newIndex;
7022
- }
7023
- function isRelatedTarget(ev, id) {
7024
- // used for onBlur events to check the element that has been clicked
7025
- const ids = id.split(" ");
7026
- return ev.relatedTarget && ids.includes(ev.relatedTarget.id);
7027
- }
7028
- /*
7029
- * this is going to be needed to solve the extra tabbing on navigator
7030
- * and for programmatic focus of tabs
7031
- * Here's a draft, not bug proof, see:
7032
- * https://stackoverflow.com/a/10730308/3741713
7033
-
7034
- function getKeyboardFocusableElements(element = document) {
7035
- const els = Array.from(element.querySelectorAll('a, button, input, textarea, select, details, [tabindex]:not([tabindex="-1"]), wm-search, wm-timepicker, wm-tab-list, wm-tab-item, wm-button, wm-action-menu'));
7036
- return els.filter((el: Element) => !el.hasAttribute("disabled")) as HTMLElement[];
7037
- }
7038
-
7039
- export function getPreviousKeyboardFocusableElement(element: HTMLElement) {
7040
- const els = getKeyboardFocusableElements();
7041
- const current = els.indexOf(element);
7042
- return els[current - 1] as HTMLElement;
7043
- }
7044
-
7045
- export function getNextKeyboardFocusableElement(element: HTMLElement) {
7046
- const els = getKeyboardFocusableElements();
7047
- const current = els.indexOf(element);
7048
- return els[current + 1] as HTMLElement;
7049
- }
6608
+ const DEFAULT_LANGUAGE = "en";
6609
+ function getBrowserLang() {
6610
+ const langAttr = document.documentElement.getAttribute("lang");
6611
+ if (!!langAttr) {
6612
+ return langAttr;
6613
+ }
6614
+ else if (window.navigator && window.navigator.language) {
6615
+ const lang = window.navigator.languages ? window.navigator.languages[0] : window.navigator.language;
6616
+ return lang.slice(0, 2);
6617
+ }
6618
+ else {
6619
+ return DEFAULT_LANGUAGE;
6620
+ }
6621
+ }
6622
+ // prevents memory leak
6623
+ const cache = createIntlCache();
6624
+ const locale = getBrowserLang();
6625
+ const intl = createIntl({
6626
+ locale: locale,
6627
+ defaultLocale: "en",
6628
+ messages: lang[locale] || en,
6629
+ }, cache);
6630
+ function generateId() {
6631
+ return "wmcl-" + Math.random().toString(36).substr(2, 10);
6632
+ }
6633
+ function debounce(fn, wait) {
6634
+ let timeout;
6635
+ return function () {
6636
+ const context = this;
6637
+ const functionCall = () => fn.apply(context, arguments);
6638
+ clearTimeout(timeout);
6639
+ timeout = setTimeout(functionCall, wait);
6640
+ };
6641
+ }
6642
+ function getTextDir() {
6643
+ const dir = document.querySelector("html").getAttribute("dir");
6644
+ return dir ? dir.toLowerCase() : "";
6645
+ }
6646
+ function getPosition(el) {
6647
+ const coords = el.getBoundingClientRect();
6648
+ let x = coords.x;
6649
+ let y = coords.y;
6650
+ // Edge doesn't have x and y
6651
+ if (!x) {
6652
+ if (getTextDir() === "rtl") {
6653
+ x = coords.right;
6654
+ }
6655
+ else {
6656
+ x = coords.left;
6657
+ }
6658
+ y = coords.top;
6659
+ }
6660
+ return { x, y };
6661
+ }
6662
+ function findParentWithScrollbar(el) {
6663
+ while (!!el) {
6664
+ if (el.scrollHeight > el.clientHeight && ["scroll", "auto"].includes(window.getComputedStyle(el).overflowY)) {
6665
+ return el;
6666
+ }
6667
+ el = el.parentElement;
6668
+ }
6669
+ }
6670
+ function findParentWithHiddenOverflow(el) {
6671
+ while (!!el) {
6672
+ if (window.getComputedStyle(el).overflowY !== "visible") {
6673
+ return el;
6674
+ }
6675
+ el = el.parentElement;
6676
+ }
6677
+ }
6678
+ function getClosableElementMeasurements(fixedEl, closableEl) {
6679
+ const parent = findParentWithHiddenOverflow(fixedEl);
6680
+ // if parent is not found, measurements are checked against the viewport
6681
+ return {
6682
+ closableElHeight: closableEl.clientHeight,
6683
+ closableElWidth: closableEl.clientWidth,
6684
+ // NB boundingClientRect.bottom is space from top of viewport to bottom of el
6685
+ // to get space below the el -> height of viewport minus boundingClientRect.bottom
6686
+ spaceAbove: parent
6687
+ ? fixedEl.getBoundingClientRect().top - parent.getBoundingClientRect().top
6688
+ : fixedEl.getBoundingClientRect().top,
6689
+ // NB boundingClientRect.bottom is space from top of viewport to bottom of el
6690
+ // to get space below the el -> height of viewport minus boundingClientRect.bottom
6691
+ spaceBelow: parent
6692
+ ? parent.getBoundingClientRect().bottom - fixedEl.getBoundingClientRect().bottom
6693
+ : document.documentElement.clientHeight - fixedEl.getBoundingClientRect().bottom,
6694
+ spaceLeft: parent
6695
+ ? fixedEl.getBoundingClientRect().left - parent.getBoundingClientRect().left
6696
+ : fixedEl.getBoundingClientRect().left,
6697
+ spaceRight: parent
6698
+ ? parent.getBoundingClientRect().right - fixedEl.getBoundingClientRect().right
6699
+ : document.documentElement.clientWidth - fixedEl.getBoundingClientRect().right,
6700
+ };
6701
+ }
6702
+ function shouldOpenUp(fixedEl, //the element visible on the page when the component is closed
6703
+ closableEl, //the dropdown/popup/etc that becomes visible when the component is open
6704
+ offsetAbove = 0, // if closableEl covers a part of fixedEl, that part should be offset
6705
+ offsetBelow = 0 // if closableEl covers a part of fixedEl, that part should be offset
6706
+ ) {
6707
+ const { closableElHeight, spaceAbove, spaceBelow } = getClosableElementMeasurements(fixedEl, closableEl);
6708
+ //we want to open up only if there's not enough space below AND there is enough space above
6709
+ const openUp = closableElHeight > spaceBelow + offsetBelow && closableElHeight <= spaceAbove + offsetAbove;
6710
+ return openUp;
6711
+ }
6712
+ function shouldOpenDown(fixedEl, //the element visible on the page when the component is closed
6713
+ closableEl, //the dropdown/popup/etc that becomes visible when the component is open
6714
+ offsetAbove = 0, // if closableEl covers a part of fixedEl, that part should be offset
6715
+ offsetBelow = 0 // if closableEl covers a part of fixedEl, that part should be offset
6716
+ ) {
6717
+ const { closableElHeight, spaceAbove, spaceBelow } = getClosableElementMeasurements(fixedEl, closableEl);
6718
+ //we want to open up only if there's not enough space below AND there is enough space above
6719
+ const openDown = closableElHeight > spaceAbove + offsetAbove && closableElHeight <= spaceBelow + offsetBelow;
6720
+ return openDown;
6721
+ }
6722
+ function shouldShiftRight(fixedEl, closableEl) {
6723
+ const { closableElWidth, spaceLeft, spaceRight } = getClosableElementMeasurements(fixedEl, closableEl);
6724
+ const needsSpaceLeft = closableElWidth > spaceLeft && spaceRight > spaceLeft;
6725
+ return needsSpaceLeft;
6726
+ }
6727
+ function shouldShiftLeft(fixedEl, closableEl) {
6728
+ const { closableElWidth, spaceLeft, spaceRight } = getClosableElementMeasurements(fixedEl, closableEl);
6729
+ const needsSpaceRight = closableElWidth > spaceRight && spaceLeft > spaceRight;
6730
+ return needsSpaceRight;
6731
+ }
6732
+ function adjustTooltipPosition(tPos, el, tooltipEl) {
6733
+ // position must be reset before measurements are taken in adjustTooltipPosition
6734
+ // otherwise text-wrapping from previous position makes width measurement inconsistent
6735
+ tooltipEl.style.top = "";
6736
+ tooltipEl.style.left = "";
6737
+ const { spaceLeft, spaceRight, spaceBelow, spaceAbove } = getClosableElementMeasurements(el, tooltipEl);
6738
+ const tooltipWidth = tooltipEl.getBoundingClientRect().width;
6739
+ const tooltipHeight = tooltipEl.getBoundingClientRect().height;
6740
+ const enoughSpaceAbove = spaceAbove > tooltipHeight;
6741
+ const enoughSpaceBelow = spaceBelow > tooltipHeight;
6742
+ // a tooltip should never be closer than 24px to the edge of a screen
6743
+ const enoughSpaceLeft = spaceLeft - 24 > tooltipWidth;
6744
+ const enoughSpaceRight = spaceRight - 24 > tooltipWidth;
6745
+ const swapAbove = (position) => {
6746
+ return !enoughSpaceAbove ? position.replace("top", "bottom") : position;
6747
+ };
6748
+ const swapBelow = (position) => {
6749
+ return !enoughSpaceBelow && enoughSpaceAbove ? position.replace("bottom", "top") : position;
6750
+ };
6751
+ const swapLeft = (position, centeredPosition) => {
6752
+ if (!enoughSpaceLeft && enoughSpaceRight) {
6753
+ position = position.replace("left", "right");
6754
+ }
6755
+ else if (!enoughSpaceLeft && !enoughSpaceRight) {
6756
+ position = centeredPosition;
6757
+ }
6758
+ return position;
6759
+ };
6760
+ const swapRight = (position, centeredPosition) => {
6761
+ if (!enoughSpaceRight && enoughSpaceLeft) {
6762
+ position = position.replace("right", "left");
6763
+ }
6764
+ else if (!enoughSpaceRight && !enoughSpaceLeft) {
6765
+ position = centeredPosition;
6766
+ }
6767
+ return position;
6768
+ };
6769
+ // horizontal checks must occur before vertical checks, because horizontal can affect vertical positioning but not vice versa
6770
+ switch (tPos) {
6771
+ case "left":
6772
+ tPos = swapLeft(tPos, "bottom");
6773
+ case "right":
6774
+ tPos = swapRight(tPos, "bottom");
6775
+ case "top-left":
6776
+ tPos = swapLeft(tPos, "top");
6777
+ tPos = swapAbove(tPos);
6778
+ case "top-right":
6779
+ tPos = swapRight(tPos, "top");
6780
+ tPos = swapAbove(tPos);
6781
+ case "bottom-left":
6782
+ tPos = swapLeft(tPos, "bottom");
6783
+ tPos = swapBelow(tPos);
6784
+ case "bottom-right":
6785
+ tPos = swapRight(tPos, "bottom");
6786
+ tPos = swapBelow(tPos);
6787
+ case "top":
6788
+ tPos = swapAbove(tPos);
6789
+ case "bottom":
6790
+ tPos = swapBelow(tPos);
6791
+ }
6792
+ return tPos;
6793
+ }
6794
+ function hasRoomRight(x, spaceNeeded) {
6795
+ let horizOffset = 0;
6796
+ // if (getTextDir() === "ltr") {
6797
+ if (x.type === "click") {
6798
+ // if it's a mouse event, deal with mouse coords
6799
+ horizOffset = x.clientX;
6800
+ // if it's a focus event, the offset is 0
6801
+ }
6802
+ else if (x.type === "focus") {
6803
+ horizOffset = 0;
6804
+ }
6805
+ else {
6806
+ // otherwise an element was passed, calculate how far it is from the edge of the window
6807
+ let el = x; // re-assignment is for clarity
6808
+ while (el) {
6809
+ if (el.tagName == "BODY") {
6810
+ // deal with browser quirks with body/window/document and page scroll
6811
+ var xScroll = el.scrollLeft || document.documentElement.scrollLeft;
6812
+ horizOffset += el.offsetLeft - xScroll + el.clientLeft;
6813
+ }
6814
+ else {
6815
+ // for all other non-BODY elements
6816
+ horizOffset += el.offsetLeft - el.scrollLeft + el.clientLeft;
6817
+ }
6818
+ el = el.offsetParent;
6819
+ }
6820
+ // }
6821
+ }
6822
+ return window.innerWidth - horizOffset >= spaceNeeded;
6823
+ }
6824
+ function checkForActiveElInShadow(element) {
6825
+ while (element && element.shadowRoot) {
6826
+ element = element.shadowRoot.activeElement;
6827
+ }
6828
+ return element;
6829
+ }
6830
+ function checkForFocusableElInShadow(element) {
6831
+ const selectors = [
6832
+ "button",
6833
+ "a",
6834
+ "input",
6835
+ "select",
6836
+ "textarea",
6837
+ "wm-button",
6838
+ "wm-search",
6839
+ "wm-select",
6840
+ "wm-action-menu",
6841
+ "wm-tab-item",
6842
+ "wm-datepicker",
6843
+ ];
6844
+ let focusableEl = element;
6845
+ selectors.forEach((selector) => {
6846
+ if (focusableEl && focusableEl.shadowRoot) {
6847
+ let elInShadow = focusableEl.shadowRoot.querySelector(selector);
6848
+ if (elInShadow) {
6849
+ if (selector.startsWith("wm-")) {
6850
+ focusableEl = checkForFocusableElInShadow(elInShadow);
6851
+ }
6852
+ else {
6853
+ focusableEl = elInShadow;
6854
+ }
6855
+ }
6856
+ }
6857
+ });
6858
+ return focusableEl;
6859
+ }
6860
+ function isFocusable(element) {
6861
+ if (element.tabIndex > 0 || (element.tabIndex === 0 && element.getAttribute("tabIndex") !== null)) {
6862
+ return true;
6863
+ }
6864
+ if (element.disabled) {
6865
+ return false;
6866
+ }
6867
+ switch (element.nodeName) {
6868
+ case "A":
6869
+ return !!element.href && element.rel != "ignore";
6870
+ case "INPUT":
6871
+ return element.type != "hidden" && element.type != "file";
6872
+ case "BUTTON":
6873
+ case "SELECT":
6874
+ case "TEXTAREA":
6875
+ case "WM-BUTTON":
6876
+ case "WM-SELECT":
6877
+ case "WM-ACTION-MENU":
6878
+ case "WM-DATEPICKER":
6879
+ case "WM-TIMEPICKER":
6880
+ case "WM-INPUT":
6881
+ case "WM-TAG-INPUT":
6882
+ case "WM-TAB-ITEM":
6883
+ case "WM-SEARCH":
6884
+ return true;
6885
+ default:
6886
+ return false;
6887
+ }
6888
+ }
6889
+ function getFirstFocusableDescendant(element) {
6890
+ if (isFocusable(element)) {
6891
+ return checkForFocusableElInShadow(element);
6892
+ }
6893
+ else if (element.childNodes.length > 0) {
6894
+ element.childNodes.forEach((i) => {
6895
+ const childEl = getFirstFocusableDescendant(i);
6896
+ return childEl && checkForFocusableElInShadow(childEl);
6897
+ });
6898
+ }
6899
+ }
6900
+ function hasValidType(file, types) {
6901
+ const acceptedExtensions = types.split(" ");
6902
+ const parts = file.name && file.name.split(".");
6903
+ const ext = parts && parts.length > 1 && parts[parts.length - 1];
6904
+ return ext
6905
+ ? acceptedExtensions.includes(ext.toLowerCase())
6906
+ : // fallback: if we couldn't obtain an extension,
6907
+ // validate based on MIME type...
6908
+ !!file.type
6909
+ ? getAcceptedMimeTypesList(acceptedExtensions).includes(file.type)
6910
+ : // ...and if that failed too, accept the file
6911
+ // as it's preferable to accept an invalid file
6912
+ // than refusing a valid one (back-end will take care of what slips through)
6913
+ true;
6914
+ }
6915
+ // takes a string (space separated list of extensions), returns an array of strings (corresponding MIME types)
6916
+ function getAcceptedMimeTypesList(acceptedExtensions) {
6917
+ // this is just a list of common file types (regardless of whether they are/can be valid or not)
6918
+ // front end checks are just a convenience to users, independent of security.
6919
+ // it allows users to be notified of an invalid type as soon as they select the file, rather than when it gets uploaded
6920
+ const lookupTable = {
6921
+ aac: ["audio/aac"],
6922
+ abw: ["application/x-abiword"],
6923
+ arc: ["application/x-freearc"],
6924
+ avi: ["video/x-msvideo"],
6925
+ azw: ["application/vnd.amazon.ebook"],
6926
+ bin: ["application/octet-stream"],
6927
+ bmp: ["image/bmp"],
6928
+ bz: ["application/x-bzip"],
6929
+ bz2: ["application/x-bzip2"],
6930
+ csh: ["application/x-csh"],
6931
+ css: ["text/css"],
6932
+ csv: ["text/csv"],
6933
+ doc: ["application/msword"],
6934
+ docx: ["application/vnd.openxmlformats-officedocument.wordprocessingml.document"],
6935
+ eot: ["application/vnd.ms-fontobject"],
6936
+ epub: ["application/epub+zip"],
6937
+ gz: ["application/gzip"],
6938
+ gif: ["image/gif"],
6939
+ htm: ["text/html"],
6940
+ html: ["text/html"],
6941
+ ico: ["image/vnd.microsoft.icon"],
6942
+ ics: ["text/calendar"],
6943
+ jar: ["application/java-archive"],
6944
+ jpeg: ["image/jpeg"],
6945
+ jpg: ["image/jpeg"],
6946
+ js: ["text/javascript"],
6947
+ json: ["application/json"],
6948
+ jsonld: ["application/ld+json"],
6949
+ log: ["text/plain"],
6950
+ mid: ["audio/x-midi"],
6951
+ midi: ["audio/x-midi"],
6952
+ mjs: ["text/javascript"],
6953
+ mp3: ["audio/mpeg"],
6954
+ mpeg: ["video/mpeg"],
6955
+ mpkg: ["application/vnd.apple.installer+xml"],
6956
+ odp: ["application/vnd.oasis.opendocument.presentation"],
6957
+ ods: ["application/vnd.oasis.opendocument.spreadsheet"],
6958
+ odt: ["application/vnd.oasis.opendocument.text"],
6959
+ oga: ["audio/ogg"],
6960
+ ogv: ["video/ogg"],
6961
+ ogx: ["application/ogg"],
6962
+ opus: ["audio/opus"],
6963
+ otf: ["font/otf"],
6964
+ png: ["image/png"],
6965
+ pdf: ["application/pdf"],
6966
+ php: ["application/php"],
6967
+ ppt: ["application/vnd.ms-powerpoint"],
6968
+ pptx: ["application/vnd.openxmlformats-officedocument.presentationml.presentation"],
6969
+ rar: ["application/vnd.rar", "application/x-rar", "application/x-rar-compressed"],
6970
+ rtf: ["application/rtf"],
6971
+ sh: ["application/x-sh"],
6972
+ svg: ["image/svg+xml"],
6973
+ swf: ["application/x-shockwave-flash"],
6974
+ tar: ["application/x-tar"],
6975
+ tif: ["image/tiff"],
6976
+ tiff: ["image/tiff"],
6977
+ ts: ["video/mp2t"],
6978
+ ttf: ["font/ttf"],
6979
+ txt: ["text/plain"],
6980
+ vsd: ["application/vnd.visio"],
6981
+ wav: ["audio/wav"],
6982
+ weba: ["audio/webm"],
6983
+ webm: ["video/webm"],
6984
+ webp: ["image/webp"],
6985
+ woff: ["font/woff"],
6986
+ woff2: ["font/woff2"],
6987
+ xhtml: ["application/xhtml+xml"],
6988
+ xls: ["application/vnd.ms-excel"],
6989
+ xlsx: ["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],
6990
+ xml: ["application/xml", "text/xml"],
6991
+ xul: ["application/vnd.mozilla.xul+xml"],
6992
+ zip: ["application/zip", "application/x-zip-compressed", "multipart/x-zip"],
6993
+ "3gp": ["video/3gpp", "audio/3gpp"],
6994
+ "3g2": ["video/3gpp2", "audio/3gpp2"],
6995
+ "7z": ["application/x-7z-compressed"],
6996
+ };
6997
+ return acceptedExtensions.reduce((acc, ext) => acc.concat(lookupTable[ext]), []);
6998
+ }
6999
+ function snakeCaseToCamelCase(str) {
7000
+ const snakeCaseRegexp = /^([a-z0-9]*)(_[a-z0-9]*)*$/g;
7001
+ if (snakeCaseRegexp.test(str)) {
7002
+ let camelCase = "";
7003
+ let arr = str.split("_");
7004
+ arr.forEach((word, idx) => {
7005
+ camelCase += idx === 0 ? word.toLowerCase() : word.charAt(0).toUpperCase() + word.slice(1);
7006
+ });
7007
+ return camelCase;
7008
+ }
7009
+ else {
7010
+ return str;
7011
+ }
7012
+ }
7013
+ function getNewIndexToFocus(currentIndex, direction, listLength) {
7014
+ let newIndex = currentIndex;
7015
+ if (direction === "ArrowDown") {
7016
+ newIndex = (currentIndex + 1) % listLength;
7017
+ }
7018
+ if (direction === "ArrowUp") {
7019
+ newIndex = currentIndex === 0 ? listLength - 1 : currentIndex - 1;
7020
+ }
7021
+ return newIndex;
7022
+ }
7023
+ function isRelatedTarget(ev, id) {
7024
+ // used for onBlur events to check the element that has been clicked
7025
+ const ids = id.split(" ");
7026
+ return ev.relatedTarget && ids.includes(ev.relatedTarget.id);
7027
+ }
7028
+ /*
7029
+ * this is going to be needed to solve the extra tabbing on navigator
7030
+ * and for programmatic focus of tabs
7031
+ * Here's a draft, not bug proof, see:
7032
+ * https://stackoverflow.com/a/10730308/3741713
7033
+
7034
+ function getKeyboardFocusableElements(element = document) {
7035
+ const els = Array.from(element.querySelectorAll('a, button, input, textarea, select, details, [tabindex]:not([tabindex="-1"]), wm-search, wm-timepicker, wm-tab-list, wm-tab-item, wm-button, wm-action-menu'));
7036
+ return els.filter((el: Element) => !el.hasAttribute("disabled")) as HTMLElement[];
7037
+ }
7038
+
7039
+ export function getPreviousKeyboardFocusableElement(element: HTMLElement) {
7040
+ const els = getKeyboardFocusableElements();
7041
+ const current = els.indexOf(element);
7042
+ return els[current - 1] as HTMLElement;
7043
+ }
7044
+
7045
+ export function getNextKeyboardFocusableElement(element: HTMLElement) {
7046
+ const els = getKeyboardFocusableElements();
7047
+ const current = els.indexOf(element);
7048
+ return els[current + 1] as HTMLElement;
7049
+ }
7050
7050
  */
7051
7051
 
7052
7052
  export { adjustTooltipPosition as a, getPosition as b, checkForActiveElInShadow as c, debounce as d, isRelatedTarget as e, findParentWithScrollbar as f, generateId as g, checkForFocusableElInShadow as h, intl as i, getFirstFocusableDescendant as j, getNewIndexToFocus as k, shouldOpenUp as l, shouldOpenDown as m, shouldShiftRight as n, shouldShiftLeft as o, hasValidType as p, getTextDir as q, hasRoomRight as r, snakeCaseToCamelCase as s };