@watermarkinsights/ripple 0.0.0 → 0.1.0-alpha.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 (580) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -1
  3. package/dist/cjs/app-globals-f836e216.js +103 -0
  4. package/dist/cjs/chartFunctions-608adb05.js +908 -0
  5. package/dist/cjs/{functions-f2333f02.js → functions-b188d5b3.js} +6137 -1590
  6. package/dist/cjs/index-786066a1.js +1880 -0
  7. package/dist/cjs/interfaces-8419be91.js +59 -0
  8. package/dist/cjs/intl-01531391.js +283 -0
  9. package/dist/cjs/loader.cjs.js +7 -14
  10. package/dist/cjs/priv-calendar.cjs.entry.js +608 -0
  11. package/dist/cjs/priv-chart-popover-old.cjs.entry.js +146 -0
  12. package/dist/cjs/priv-chart-popover_2.cjs.entry.js +194 -0
  13. package/dist/cjs/priv-navigator-button.cjs.entry.js +19 -19
  14. package/dist/cjs/priv-navigator-item.cjs.entry.js +24 -23
  15. package/dist/cjs/priv-option-list.cjs.entry.js +391 -0
  16. package/dist/cjs/ripple.cjs.js +25 -0
  17. package/dist/cjs/wm-action-menu_2.cjs.entry.js +471 -302
  18. package/dist/cjs/wm-button.cjs.entry.js +263 -142
  19. package/dist/cjs/wm-chart-bar.cjs.entry.js +441 -0
  20. package/dist/cjs/wm-chart-column.cjs.entry.js +544 -0
  21. package/dist/cjs/wm-chart-slice.cjs.entry.js +17 -12
  22. package/dist/cjs/wm-chart.cjs.entry.js +133 -478
  23. package/dist/cjs/wm-date-range.cjs.entry.js +526 -0
  24. package/dist/cjs/wm-datepicker.cjs.entry.js +285 -224
  25. package/dist/cjs/wm-file-list.cjs.entry.js +23 -0
  26. package/dist/cjs/wm-file.cjs.entry.js +210 -0
  27. package/dist/cjs/wm-flyout.cjs.entry.js +181 -0
  28. package/dist/cjs/wm-input.cjs.entry.js +121 -100
  29. package/dist/cjs/wm-line-chart.cjs.entry.js +541 -0
  30. package/dist/cjs/wm-modal-pss_3.cjs.entry.js +220 -0
  31. package/dist/cjs/wm-modal_3.cjs.entry.js +223 -0
  32. package/dist/cjs/wm-navigation_3.cjs.entry.js +188 -0
  33. package/dist/cjs/wm-navigator.cjs.entry.js +305 -250
  34. package/dist/cjs/wm-nested-select.cjs.entry.js +320 -0
  35. package/dist/cjs/wm-optgroup.cjs.entry.js +74 -0
  36. package/dist/cjs/wm-option_2.cjs.entry.js +517 -465
  37. package/dist/cjs/wm-pagination.cjs.entry.js +218 -165
  38. package/dist/cjs/wm-progress-indicator_3.cjs.entry.js +204 -0
  39. package/dist/cjs/wm-search.cjs.entry.js +182 -217
  40. package/dist/cjs/wm-snackbar.cjs.entry.js +158 -142
  41. package/dist/cjs/wm-tab-item_3.cjs.entry.js +317 -276
  42. package/dist/cjs/wm-tag-input.cjs.entry.js +940 -500
  43. package/dist/cjs/wm-tag-option.cjs.entry.js +43 -0
  44. package/dist/cjs/wm-textarea.cjs.entry.js +94 -0
  45. package/dist/cjs/wm-timepicker.cjs.entry.js +276 -349
  46. package/dist/cjs/wm-toggletip.cjs.entry.js +238 -114
  47. package/dist/cjs/wm-uploader.cjs.entry.js +322 -323
  48. package/dist/cjs/wm-wrapper.cjs.entry.js +12 -12
  49. package/dist/collection/collection-manifest.json +104 -34
  50. package/dist/collection/components/charts/chartFunctions.js +833 -0
  51. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.css +995 -0
  52. package/dist/collection/components/charts/priv-chart-popover/priv-chart-popover.js +340 -0
  53. package/dist/collection/components/charts/priv-chart-popover-old/priv-chart-popover-old.css +990 -0
  54. package/dist/collection/components/charts/priv-chart-popover-old/priv-chart-popover-old.js +263 -0
  55. package/dist/collection/components/charts/wm-chart/wm-chart-slice.js +125 -0
  56. package/dist/collection/components/charts/wm-chart/wm-chart.css +1326 -0
  57. package/dist/collection/components/charts/wm-chart/wm-chart.js +422 -0
  58. package/dist/collection/components/charts/wm-chart-bar/wm-chart-bar.css +1116 -0
  59. package/dist/collection/components/charts/wm-chart-bar/wm-chart-bar.js +579 -0
  60. package/dist/collection/components/charts/wm-chart-column/wm-chart-column.css +1169 -0
  61. package/dist/collection/components/charts/wm-chart-column/wm-chart-column.js +688 -0
  62. package/dist/collection/components/charts/wm-chart-legend/wm-chart-legend.css +932 -0
  63. package/dist/collection/components/charts/wm-chart-legend/wm-chart-legend.js +194 -0
  64. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.css +1208 -0
  65. package/dist/collection/components/charts/wm-line-chart/wm-line-chart.js +862 -0
  66. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.css +1326 -0
  67. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-indicator.js +264 -0
  68. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.css +967 -0
  69. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-monitor.js +151 -0
  70. package/dist/collection/components/charts/wm-progress-monitor/wm-progress-slice.js +121 -0
  71. package/dist/collection/components/datepickers/datepicker.css +1137 -0
  72. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.css +1403 -0
  73. package/dist/collection/components/datepickers/priv-calendar/priv-calendar.js +881 -0
  74. package/dist/collection/components/datepickers/wm-date-range.js +870 -0
  75. package/dist/collection/components/datepickers/wm-datepicker.js +579 -0
  76. package/dist/collection/components/selects/priv-option-list/priv-option-list.css +999 -0
  77. package/dist/collection/components/selects/priv-option-list/priv-option-list.js +778 -0
  78. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.css +1259 -0
  79. package/dist/collection/components/selects/wm-nested-select/wm-nested-select.js +626 -0
  80. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.css +909 -0
  81. package/dist/collection/components/selects/wm-optgroup/wm-optgroup.js +258 -0
  82. package/dist/collection/components/selects/wm-option/wm-option.css +1033 -0
  83. package/dist/collection/components/selects/wm-option/wm-option.js +530 -0
  84. package/dist/collection/components/selects/wm-select/wm-select.css +1187 -0
  85. package/dist/collection/components/selects/wm-select/wm-select.js +705 -0
  86. package/dist/collection/components/wm-action-menu/wm-action-menu.css +1614 -50
  87. package/dist/collection/components/wm-action-menu/wm-action-menu.js +605 -387
  88. package/dist/collection/components/wm-button/wm-button.css +1440 -385
  89. package/dist/collection/components/wm-button/wm-button.js +538 -348
  90. package/dist/collection/components/wm-file/wm-file.css +1086 -0
  91. package/dist/collection/components/wm-file/wm-file.js +428 -0
  92. package/dist/collection/components/wm-file-list/wm-file-list.css +899 -0
  93. package/dist/collection/components/wm-file-list/wm-file-list.js +45 -0
  94. package/dist/collection/components/wm-flyout/wm-flyout.css +1117 -0
  95. package/dist/collection/components/wm-flyout/wm-flyout.js +449 -0
  96. package/dist/collection/components/wm-input/wm-input.css +965 -96
  97. package/dist/collection/components/wm-input/wm-input.js +466 -291
  98. package/dist/collection/components/wm-menuitem/wm-menuitem.css +919 -55
  99. package/dist/collection/components/wm-menuitem/wm-menuitem.js +402 -397
  100. package/dist/collection/components/wm-modal/wm-modal-footer.css +871 -28
  101. package/dist/collection/components/wm-modal/wm-modal-footer.js +139 -156
  102. package/dist/collection/components/wm-modal/wm-modal-header.css +864 -16
  103. package/dist/collection/components/wm-modal/wm-modal-header.js +76 -106
  104. package/dist/collection/components/wm-modal/wm-modal.css +921 -93
  105. package/dist/collection/components/wm-modal/wm-modal.js +337 -337
  106. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.css +931 -0
  107. package/dist/collection/components/wm-modal-pss/wm-modal-pss-footer.js +138 -0
  108. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.css +925 -0
  109. package/dist/collection/components/wm-modal-pss/wm-modal-pss-header.js +82 -0
  110. package/dist/collection/components/wm-modal-pss/wm-modal-pss.css +1007 -0
  111. package/dist/collection/components/wm-modal-pss/wm-modal-pss.js +365 -0
  112. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.css +926 -0
  113. package/dist/collection/components/wm-navigation/wm-navigation-hamburger.js +119 -0
  114. package/dist/collection/components/wm-navigation/wm-navigation-item.css +935 -0
  115. package/dist/collection/components/wm-navigation/wm-navigation-item.js +98 -0
  116. package/dist/collection/components/wm-navigation/wm-navigation.css +977 -0
  117. package/dist/collection/components/wm-navigation/wm-navigation.js +190 -0
  118. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +868 -33
  119. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +83 -94
  120. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +876 -25
  121. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +120 -110
  122. package/dist/collection/components/wm-navigator/wm-navigator.css +891 -38
  123. package/dist/collection/components/wm-navigator/wm-navigator.js +491 -456
  124. package/dist/collection/components/wm-pagination/wm-pagination.css +895 -68
  125. package/dist/collection/components/wm-pagination/wm-pagination.js +374 -340
  126. package/dist/collection/components/wm-search/wm-search.css +895 -73
  127. package/dist/collection/components/wm-search/wm-search.js +411 -421
  128. package/dist/collection/components/wm-snackbar/wm-snackbar.css +979 -160
  129. package/dist/collection/components/wm-snackbar/wm-snackbar.js +258 -235
  130. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +904 -50
  131. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +162 -198
  132. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +922 -29
  133. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +334 -292
  134. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +862 -13
  135. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +83 -100
  136. package/dist/collection/components/wm-tag-input/wm-tag-input.css +1212 -200
  137. package/dist/collection/components/wm-tag-input/wm-tag-input.js +1283 -702
  138. package/dist/collection/components/wm-tag-input/wm-tag-option/wm-tag-option.js +243 -0
  139. package/dist/collection/components/wm-textarea/wm-textarea.css +1065 -0
  140. package/dist/collection/components/wm-textarea/wm-textarea.js +319 -0
  141. package/dist/collection/components/wm-timepicker/wm-timepicker.css +962 -168
  142. package/dist/collection/components/wm-timepicker/wm-timepicker.js +539 -553
  143. package/dist/collection/components/wm-toggletip/wm-toggletip.css +1094 -148
  144. package/dist/collection/components/wm-toggletip/wm-toggletip.js +370 -211
  145. package/dist/collection/components/wm-uploader/wm-uploader.css +1756 -438
  146. package/dist/collection/components/wm-uploader/wm-uploader.js +607 -661
  147. package/dist/collection/components/wm-wrapper/wm-wrapper.js +26 -25
  148. package/dist/collection/dev/action-menu.js +18 -0
  149. package/dist/collection/dev/chart-bar.js +423 -0
  150. package/dist/collection/dev/chart-column.js +437 -0
  151. package/dist/collection/dev/chart-small.js +56 -0
  152. package/dist/collection/dev/chart.js +18 -0
  153. package/dist/collection/dev/date-range.js +6 -0
  154. package/dist/collection/dev/datepicker.js +46 -0
  155. package/dist/collection/dev/file-list.js +16 -0
  156. package/dist/collection/dev/file.js +0 -0
  157. package/dist/collection/dev/flyout.js +194 -0
  158. package/dist/collection/dev/input.js +6 -0
  159. package/dist/collection/dev/line-chart.js +45 -0
  160. package/dist/collection/dev/modal.js +48 -0
  161. package/dist/collection/dev/navigation.js +13 -0
  162. package/dist/collection/dev/navigator.js +34 -0
  163. package/dist/collection/dev/nested-select.js +36 -0
  164. package/dist/collection/dev/pagination.js +7 -0
  165. package/dist/collection/dev/progress-monitor.js +0 -0
  166. package/dist/collection/dev/pss-modal.js +8 -0
  167. package/dist/collection/dev/scripts.js +43 -14
  168. package/dist/collection/dev/search.js +72 -0
  169. package/dist/collection/dev/select.js +57 -0
  170. package/dist/collection/dev/snackbar.js +68 -0
  171. package/dist/collection/dev/tabs.js +44 -0
  172. package/dist/collection/dev/tag-input.js +32 -0
  173. package/dist/collection/dev/textarea.js +28 -0
  174. package/dist/collection/dev/timepicker.js +32 -0
  175. package/dist/collection/dev/toggletip.js +9 -0
  176. package/dist/collection/dev/uploader.js +139 -0
  177. package/dist/collection/global/__mocks__/functions.js +2 -1
  178. package/dist/collection/global/functions.js +853 -371
  179. package/dist/collection/global/global.js +88 -28
  180. package/dist/collection/global/interfaces.js +62 -39
  181. package/dist/collection/global/intl.js +274 -0
  182. package/dist/collection/global/services/__mocks__/http-service.js +112 -112
  183. package/dist/collection/global/services/http-service.js +41 -41
  184. package/dist/collection/lang/missing.js +43 -0
  185. package/dist/collection/lang/piglatin.js +11 -3
  186. package/dist/esm/app-globals-d0ca31a6.js +101 -0
  187. package/dist/esm/chartFunctions-4bc77b76.js +883 -0
  188. package/dist/esm/{functions-60034bf7.js → functions-de887809.js} +6110 -1584
  189. package/dist/esm/index-ef50bc01.js +1849 -0
  190. package/dist/esm/interfaces-7e50d034.js +55 -0
  191. package/dist/esm/intl-56b47a7b.js +277 -0
  192. package/dist/esm/loader.js +7 -14
  193. package/dist/esm/priv-calendar.entry.js +604 -0
  194. package/dist/esm/priv-chart-popover-old.entry.js +142 -0
  195. package/dist/esm/priv-chart-popover_2.entry.js +189 -0
  196. package/dist/esm/priv-navigator-button.entry.js +19 -19
  197. package/dist/esm/priv-navigator-item.entry.js +24 -23
  198. package/dist/esm/priv-option-list.entry.js +387 -0
  199. package/dist/esm/ripple.js +20 -0
  200. package/dist/esm/wm-action-menu_2.entry.js +471 -302
  201. package/dist/esm/wm-button.entry.js +263 -142
  202. package/dist/esm/wm-chart-bar.entry.js +437 -0
  203. package/dist/esm/wm-chart-column.entry.js +540 -0
  204. package/dist/esm/wm-chart-slice.entry.js +17 -12
  205. package/dist/esm/wm-chart.entry.js +133 -478
  206. package/dist/esm/wm-date-range.entry.js +522 -0
  207. package/dist/esm/wm-datepicker.entry.js +285 -224
  208. package/dist/esm/wm-file-list.entry.js +19 -0
  209. package/dist/esm/wm-file.entry.js +206 -0
  210. package/dist/esm/wm-flyout.entry.js +177 -0
  211. package/dist/esm/wm-input.entry.js +121 -100
  212. package/dist/esm/wm-line-chart.entry.js +537 -0
  213. package/dist/esm/wm-modal-pss_3.entry.js +214 -0
  214. package/dist/esm/wm-modal_3.entry.js +217 -0
  215. package/dist/esm/wm-navigation_3.entry.js +182 -0
  216. package/dist/esm/wm-navigator.entry.js +305 -250
  217. package/dist/esm/wm-nested-select.entry.js +316 -0
  218. package/dist/esm/wm-optgroup.entry.js +70 -0
  219. package/dist/esm/wm-option_2.entry.js +517 -465
  220. package/dist/esm/wm-pagination.entry.js +218 -165
  221. package/dist/esm/wm-progress-indicator_3.entry.js +198 -0
  222. package/dist/esm/wm-search.entry.js +182 -217
  223. package/dist/esm/wm-snackbar.entry.js +158 -142
  224. package/dist/esm/wm-tab-item_3.entry.js +317 -276
  225. package/dist/esm/wm-tag-input.entry.js +940 -500
  226. package/dist/esm/wm-tag-option.entry.js +39 -0
  227. package/dist/esm/wm-textarea.entry.js +90 -0
  228. package/dist/esm/wm-timepicker.entry.js +276 -349
  229. package/dist/esm/wm-toggletip.entry.js +238 -114
  230. package/dist/esm/wm-uploader.entry.js +322 -323
  231. package/dist/esm/wm-wrapper.entry.js +12 -12
  232. package/dist/esm-es5/app-globals-d0ca31a6.js +1 -0
  233. package/dist/esm-es5/chartFunctions-4bc77b76.js +1 -0
  234. package/dist/esm-es5/functions-de887809.js +1 -0
  235. package/dist/esm-es5/index-ef50bc01.js +1 -0
  236. package/dist/esm-es5/index.js +0 -0
  237. package/dist/esm-es5/interfaces-7e50d034.js +1 -0
  238. package/dist/esm-es5/intl-56b47a7b.js +1 -0
  239. package/dist/esm-es5/loader.js +1 -0
  240. package/dist/esm-es5/priv-calendar.entry.js +1 -0
  241. package/dist/esm-es5/priv-chart-popover-old.entry.js +1 -0
  242. package/dist/esm-es5/priv-chart-popover_2.entry.js +1 -0
  243. package/dist/esm-es5/priv-navigator-button.entry.js +1 -0
  244. package/dist/esm-es5/priv-navigator-item.entry.js +1 -0
  245. package/dist/esm-es5/priv-option-list.entry.js +1 -0
  246. package/dist/esm-es5/ripple.js +1 -0
  247. package/dist/esm-es5/wm-action-menu_2.entry.js +1 -0
  248. package/dist/esm-es5/wm-button.entry.js +1 -0
  249. package/dist/esm-es5/wm-chart-bar.entry.js +1 -0
  250. package/dist/esm-es5/wm-chart-column.entry.js +1 -0
  251. package/dist/esm-es5/wm-chart-slice.entry.js +1 -0
  252. package/dist/esm-es5/wm-chart.entry.js +1 -0
  253. package/dist/esm-es5/wm-date-range.entry.js +1 -0
  254. package/dist/esm-es5/wm-datepicker.entry.js +1 -0
  255. package/dist/esm-es5/wm-file-list.entry.js +1 -0
  256. package/dist/esm-es5/wm-file.entry.js +1 -0
  257. package/dist/esm-es5/wm-flyout.entry.js +1 -0
  258. package/dist/esm-es5/wm-input.entry.js +1 -0
  259. package/dist/esm-es5/wm-line-chart.entry.js +1 -0
  260. package/dist/esm-es5/wm-modal-pss_3.entry.js +1 -0
  261. package/dist/esm-es5/wm-modal_3.entry.js +1 -0
  262. package/dist/esm-es5/wm-navigation_3.entry.js +1 -0
  263. package/dist/esm-es5/wm-navigator.entry.js +1 -0
  264. package/dist/esm-es5/wm-nested-select.entry.js +1 -0
  265. package/dist/esm-es5/wm-optgroup.entry.js +1 -0
  266. package/dist/esm-es5/wm-option_2.entry.js +1 -0
  267. package/dist/esm-es5/wm-pagination.entry.js +1 -0
  268. package/dist/esm-es5/wm-progress-indicator_3.entry.js +1 -0
  269. package/dist/esm-es5/wm-search.entry.js +1 -0
  270. package/dist/esm-es5/wm-snackbar.entry.js +1 -0
  271. package/dist/esm-es5/wm-tab-item_3.entry.js +1 -0
  272. package/dist/esm-es5/wm-tag-input.entry.js +1 -0
  273. package/dist/esm-es5/wm-tag-option.entry.js +1 -0
  274. package/dist/esm-es5/wm-textarea.entry.js +1 -0
  275. package/dist/esm-es5/wm-timepicker.entry.js +1 -0
  276. package/dist/esm-es5/wm-toggletip.entry.js +1 -0
  277. package/dist/esm-es5/wm-uploader.entry.js +1 -0
  278. package/dist/esm-es5/wm-wrapper.entry.js +1 -0
  279. package/dist/index.js +1 -1
  280. package/dist/loader/cdn.js +1 -2
  281. package/dist/loader/index.cjs.js +1 -2
  282. package/dist/loader/index.d.ts +13 -2
  283. package/dist/loader/index.es2017.js +1 -2
  284. package/dist/loader/index.js +1 -2
  285. package/dist/loader/package.json +2 -1
  286. package/dist/ripple/index.esm.js +0 -0
  287. package/dist/ripple/p-03a6850a.entry.js +1 -0
  288. package/dist/ripple/p-0c3162d5.system.entry.js +1 -0
  289. package/dist/ripple/p-0ec71f08.system.entry.js +1 -0
  290. package/dist/ripple/p-1032c0db.system.entry.js +1 -0
  291. package/dist/ripple/p-117c3d78.system.js +2 -0
  292. package/dist/ripple/p-12024d3b.system.entry.js +1 -0
  293. package/dist/ripple/p-13152ac1.system.entry.js +1 -0
  294. package/dist/ripple/p-1318ae67.entry.js +1 -0
  295. package/dist/ripple/p-137bf0c0.system.entry.js +1 -0
  296. package/dist/ripple/p-13bb6faf.entry.js +1 -0
  297. package/dist/ripple/p-16ff8110.entry.js +1 -0
  298. package/dist/ripple/p-1825d519.system.entry.js +1 -0
  299. package/dist/ripple/p-18417851.entry.js +1 -0
  300. package/dist/ripple/p-1c655f6b.entry.js +1 -0
  301. package/dist/ripple/p-1ce77857.system.entry.js +1 -0
  302. package/dist/ripple/p-1d76061a.entry.js +1 -0
  303. package/dist/ripple/p-22b57f73.system.entry.js +1 -0
  304. package/dist/ripple/p-24dfbf1d.system.entry.js +1 -0
  305. package/dist/ripple/p-28996d67.system.entry.js +1 -0
  306. package/dist/ripple/p-30118d12.system.entry.js +1 -0
  307. package/dist/ripple/p-32f3581a.entry.js +1 -0
  308. package/dist/ripple/p-334d8711.system.js +1 -0
  309. package/dist/ripple/p-3c8c5933.js +1 -0
  310. package/dist/ripple/p-436bf381.system.entry.js +1 -0
  311. package/dist/ripple/p-43843597.system.entry.js +1 -0
  312. package/dist/ripple/p-45999149.system.js +1 -0
  313. package/dist/ripple/p-48b596ae.entry.js +1 -0
  314. package/dist/ripple/p-4bab5360.system.js +1 -0
  315. package/dist/ripple/p-4ff0db4d.entry.js +1 -0
  316. package/dist/ripple/p-50ea2036.system.js +1 -0
  317. package/dist/ripple/p-57f1bafd.system.entry.js +1 -0
  318. package/dist/ripple/p-5b0e9165.entry.js +1 -0
  319. package/dist/ripple/p-6266fcbf.system.entry.js +1 -0
  320. package/dist/ripple/p-646e22d3.system.entry.js +1 -0
  321. package/dist/ripple/p-6950e8ed.system.js +1 -0
  322. package/dist/ripple/p-6c6da5db.entry.js +1 -0
  323. package/dist/ripple/p-6d2af8d9.system.entry.js +1 -0
  324. package/dist/ripple/p-6d46f775.system.entry.js +1 -0
  325. package/dist/ripple/p-6de0efee.entry.js +1 -0
  326. package/dist/ripple/p-7833db63.entry.js +1 -0
  327. package/dist/ripple/p-7b7c32af.entry.js +1 -0
  328. package/dist/ripple/p-817aa29c.entry.js +1 -0
  329. package/dist/ripple/p-82c9bd47.entry.js +1 -0
  330. package/dist/ripple/p-8480138d.entry.js +1 -0
  331. package/dist/ripple/p-85ef702d.entry.js +1 -0
  332. package/dist/ripple/p-86bcd942.system.entry.js +1 -0
  333. package/dist/ripple/p-8799bce9.entry.js +1 -0
  334. package/dist/ripple/p-8ac14bb1.system.js +1 -0
  335. package/dist/ripple/p-8dcc8c0c.entry.js +1 -0
  336. package/dist/ripple/p-8fa572a8.entry.js +1 -0
  337. package/dist/ripple/p-904545cc.js +1 -0
  338. package/dist/ripple/p-90cb5d27.system.entry.js +1 -0
  339. package/dist/ripple/p-9202ef69.system.entry.js +1 -0
  340. package/dist/ripple/p-9f971522.system.entry.js +1 -0
  341. package/dist/ripple/p-a5dc49c1.system.entry.js +1 -0
  342. package/dist/ripple/p-a73fb160.system.entry.js +1 -0
  343. package/dist/ripple/p-a9580e7a.system.entry.js +1 -0
  344. package/dist/ripple/p-b04a6351.entry.js +1 -0
  345. package/dist/ripple/p-b09998e1.entry.js +1 -0
  346. package/dist/ripple/p-b3a86ec4.system.entry.js +1 -0
  347. package/dist/ripple/p-b501f06c.entry.js +1 -0
  348. package/dist/ripple/p-b957033b.entry.js +1 -0
  349. package/dist/ripple/p-c2258438.entry.js +1 -0
  350. package/dist/ripple/p-ca3abcc0.system.entry.js +1 -0
  351. package/dist/ripple/p-cc455a6c.system.entry.js +1 -0
  352. package/dist/ripple/p-cda66d45.js +1 -0
  353. package/dist/ripple/p-cde2ca4d.system.entry.js +1 -0
  354. package/dist/ripple/p-cdf9c0e9.entry.js +1 -0
  355. package/dist/ripple/p-d0858afa.js +2 -0
  356. package/dist/ripple/p-d37f8f66.js +1 -0
  357. package/dist/ripple/p-d4ae193e.js +1 -0
  358. package/dist/ripple/p-d4d769a7.system.js +1 -0
  359. package/dist/ripple/p-d6a9000f.system.entry.js +1 -0
  360. package/dist/ripple/p-d6cd9f79.entry.js +1 -0
  361. package/dist/ripple/p-d9e4335e.entry.js +1 -0
  362. package/dist/ripple/p-dadf3ed3.entry.js +1 -0
  363. package/dist/ripple/p-dc3684b5.entry.js +1 -0
  364. package/dist/ripple/p-dca94e24.entry.js +1 -0
  365. package/dist/ripple/p-dcd6acc5.system.entry.js +1 -0
  366. package/dist/ripple/p-dd81e308.entry.js +1 -0
  367. package/dist/ripple/p-e11d9b06.system.entry.js +1 -0
  368. package/dist/ripple/p-e36e71dc.system.entry.js +1 -0
  369. package/dist/ripple/p-e6a81600.entry.js +1 -0
  370. package/dist/ripple/p-ef7d84da.system.entry.js +1 -0
  371. package/dist/ripple/p-f1de3153.entry.js +1 -0
  372. package/dist/ripple/p-f3e84476.system.entry.js +1 -0
  373. package/dist/ripple/p-f4d27fea.system.entry.js +1 -0
  374. package/dist/ripple/p-fcf4bd61.system.entry.js +1 -0
  375. package/dist/ripple/p-fd02c124.entry.js +1 -0
  376. package/dist/ripple/p-ffa20853.entry.js +1 -0
  377. package/dist/ripple/ripple.esm.js +1 -0
  378. package/dist/ripple/ripple.js +127 -0
  379. package/dist/types/components/charts/chartFunctions.d.ts +54 -0
  380. package/dist/types/components/charts/priv-chart-popover/priv-chart-popover.d.ts +35 -0
  381. package/dist/types/components/charts/priv-chart-popover-old/priv-chart-popover-old.d.ts +26 -0
  382. package/dist/types/components/charts/wm-chart/wm-chart-slice.d.ts +11 -0
  383. package/dist/types/components/charts/wm-chart/wm-chart.d.ts +44 -0
  384. package/dist/types/components/charts/wm-chart-bar/wm-chart-bar.d.ts +62 -0
  385. package/dist/types/components/charts/wm-chart-column/wm-chart-column.d.ts +73 -0
  386. package/dist/types/components/charts/wm-chart-legend/wm-chart-legend.d.ts +26 -0
  387. package/dist/types/components/charts/wm-line-chart/wm-line-chart.d.ts +87 -0
  388. package/dist/types/components/charts/wm-progress-monitor/wm-progress-indicator.d.ts +34 -0
  389. package/dist/types/components/charts/wm-progress-monitor/wm-progress-monitor.d.ts +22 -0
  390. package/dist/types/components/charts/wm-progress-monitor/wm-progress-slice.d.ts +10 -0
  391. package/dist/types/components/datepickers/priv-calendar/priv-calendar.d.ts +89 -0
  392. package/dist/types/components/datepickers/wm-date-range.d.ts +73 -0
  393. package/dist/types/components/datepickers/wm-datepicker.d.ts +54 -0
  394. package/dist/types/components/selects/priv-option-list/priv-option-list.d.ts +71 -0
  395. package/dist/types/components/selects/wm-nested-select/wm-nested-select.d.ts +62 -0
  396. package/dist/types/components/selects/wm-optgroup/wm-optgroup.d.ts +21 -0
  397. package/dist/types/components/selects/wm-option/wm-option.d.ts +40 -0
  398. package/dist/types/components/selects/wm-select/wm-select.d.ts +66 -0
  399. package/dist/types/components/wm-action-menu/wm-action-menu.d.ts +54 -40
  400. package/dist/types/components/wm-button/wm-button.d.ts +43 -34
  401. package/dist/types/components/wm-file/wm-file.d.ts +48 -0
  402. package/dist/types/components/wm-file-list/wm-file-list.d.ts +5 -0
  403. package/dist/types/components/wm-flyout/wm-flyout.d.ts +48 -0
  404. package/dist/types/components/wm-input/wm-input.d.ts +50 -28
  405. package/dist/types/components/wm-menuitem/wm-menuitem.d.ts +26 -27
  406. package/dist/types/components/wm-modal/wm-modal-footer.d.ts +12 -13
  407. package/dist/types/components/wm-modal/wm-modal-header.d.ts +8 -10
  408. package/dist/types/components/wm-modal/wm-modal.d.ts +28 -31
  409. package/dist/types/components/wm-modal-pss/wm-modal-pss-footer.d.ts +14 -0
  410. package/dist/types/components/wm-modal-pss/wm-modal-pss-header.d.ts +10 -0
  411. package/dist/types/components/wm-modal-pss/wm-modal-pss.d.ts +35 -0
  412. package/dist/types/components/wm-navigation/wm-navigation-hamburger.d.ts +16 -0
  413. package/dist/types/components/wm-navigation/wm-navigation-item.d.ts +9 -0
  414. package/dist/types/components/wm-navigation/wm-navigation.d.ts +24 -0
  415. package/dist/types/components/wm-navigator/priv-navigator-button/priv-navigator-button.d.ts +6 -7
  416. package/dist/types/components/wm-navigator/priv-navigator-item/priv-navigator-item.d.ts +10 -10
  417. package/dist/types/components/wm-navigator/wm-navigator.d.ts +55 -57
  418. package/dist/types/components/wm-pagination/wm-pagination.d.ts +31 -28
  419. package/dist/types/components/wm-search/wm-search.d.ts +71 -75
  420. package/dist/types/components/wm-snackbar/wm-snackbar.d.ts +27 -28
  421. package/dist/types/components/wm-tabs/wm-tab-item/wm-tab-item.d.ts +30 -31
  422. package/dist/types/components/wm-tabs/wm-tab-list/wm-tab-list.d.ts +32 -48
  423. package/dist/types/components/wm-tabs/wm-tab-panel/wm-tab-panel.d.ts +14 -16
  424. package/dist/types/components/wm-tag-input/wm-tag-input.d.ts +121 -80
  425. package/dist/types/components/wm-tag-input/wm-tag-option/wm-tag-option.d.ts +18 -0
  426. package/dist/types/components/wm-textarea/wm-textarea.d.ts +31 -0
  427. package/dist/types/components/wm-timepicker/wm-timepicker.d.ts +49 -55
  428. package/dist/types/components/wm-toggletip/wm-toggletip.d.ts +36 -23
  429. package/dist/types/components/wm-uploader/wm-uploader.d.ts +64 -72
  430. package/dist/types/components/wm-wrapper/wm-wrapper.d.ts +4 -4
  431. package/dist/types/components.d.ts +1516 -211
  432. package/dist/types/global/__mocks__/functions.d.ts +2 -1
  433. package/dist/types/global/functions.d.ts +67 -11
  434. package/dist/types/global/interfaces.d.ts +152 -23
  435. package/dist/types/global/intl.d.ts +62 -0
  436. package/dist/types/global/services/__mocks__/http-service.d.ts +1 -1
  437. package/dist/types/stencil-public-runtime.d.ts +338 -219
  438. package/package.json +16 -22
  439. package/dist/cjs/app-globals-6b0c6e80.js +0 -110
  440. package/dist/cjs/app-globals-f1dd8fda.js +0 -47
  441. package/dist/cjs/componentlibrary.cjs.js +0 -20
  442. package/dist/cjs/css-shim-a7379e2b.js +0 -6
  443. package/dist/cjs/dom-3e7d9c3b.js +0 -75
  444. package/dist/cjs/functions-65513c61.js +0 -8360
  445. package/dist/cjs/global-6849642d.js +0 -38
  446. package/dist/cjs/http-service-494d81de.js +0 -57
  447. package/dist/cjs/http-service-9e8c4dd5.js +0 -57
  448. package/dist/cjs/index-298ebef1.js +0 -2976
  449. package/dist/cjs/interfaces-a3338581.js +0 -35
  450. package/dist/cjs/interfaces-b2beb752.js +0 -54
  451. package/dist/cjs/priv-chart-popover.cjs.entry.js +0 -89
  452. package/dist/cjs/priv-datepicker.cjs.entry.js +0 -672
  453. package/dist/cjs/shadow-css-09555044.js +0 -391
  454. package/dist/cjs/wm-action-menu.cjs.entry.js +0 -206
  455. package/dist/cjs/wm-menuitem.cjs.entry.js +0 -118
  456. package/dist/cjs/wm-modal-footer.cjs.entry.js +0 -43
  457. package/dist/cjs/wm-modal-header.cjs.entry.js +0 -45
  458. package/dist/cjs/wm-modal.cjs.entry.js +0 -149
  459. package/dist/cjs/wm-network-uploader.cjs.entry.js +0 -431
  460. package/dist/cjs/wm-option.cjs.entry.js +0 -123
  461. package/dist/cjs/wm-select.cjs.entry.js +0 -366
  462. package/dist/cjs/wm-tab-item.cjs.entry.js +0 -82
  463. package/dist/cjs/wm-tab-list.cjs.entry.js +0 -205
  464. package/dist/cjs/wm-tab-panel.cjs.entry.js +0 -42
  465. package/dist/collection/components/wm-chart/priv-chart-popover/priv-chart-popover.css +0 -132
  466. package/dist/collection/components/wm-chart/priv-chart-popover/priv-chart-popover.js +0 -232
  467. package/dist/collection/components/wm-chart/wm-chart-slice.js +0 -64
  468. package/dist/collection/components/wm-chart/wm-chart.css +0 -337
  469. package/dist/collection/components/wm-chart/wm-chart.js +0 -710
  470. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.css +0 -365
  471. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.js +0 -1003
  472. package/dist/collection/components/wm-datepicker/wm-datepicker.css +0 -211
  473. package/dist/collection/components/wm-datepicker/wm-datepicker.js +0 -445
  474. package/dist/collection/components/wm-option/wm-option.css +0 -162
  475. package/dist/collection/components/wm-option/wm-option.js +0 -394
  476. package/dist/collection/components/wm-select/wm-select.css +0 -315
  477. package/dist/collection/components/wm-select/wm-select.js +0 -676
  478. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.css +0 -642
  479. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.js +0 -753
  480. package/dist/componentlibrary/app-globals-18876ad3.js +0 -45
  481. package/dist/componentlibrary/app-globals-307a1083.js +0 -108
  482. package/dist/componentlibrary/componentlibrary.css +0 -84
  483. package/dist/componentlibrary/componentlibrary.esm.js +0 -1
  484. package/dist/componentlibrary/css-shim-bbdf0cc6.js +0 -4
  485. package/dist/componentlibrary/dom-1f98a75f.js +0 -73
  486. package/dist/componentlibrary/functions-316c1b23.js +0 -8340
  487. package/dist/componentlibrary/http-service-5d037e16.js +0 -52
  488. package/dist/componentlibrary/index-d5997567.js +0 -2938
  489. package/dist/componentlibrary/interfaces-50753346.js +0 -51
  490. package/dist/componentlibrary/p-01bdfed8.js +0 -16
  491. package/dist/componentlibrary/p-0ca70ed4.entry.js +0 -1
  492. package/dist/componentlibrary/p-126bde92.entry.js +0 -1
  493. package/dist/componentlibrary/p-12a67d93.entry.js +0 -1
  494. package/dist/componentlibrary/p-188deaf5.entry.js +0 -1
  495. package/dist/componentlibrary/p-2514df6f.entry.js +0 -1
  496. package/dist/componentlibrary/p-269b8a5f.entry.js +0 -1
  497. package/dist/componentlibrary/p-35e57079.entry.js +0 -1
  498. package/dist/componentlibrary/p-414e20f7.entry.js +0 -1
  499. package/dist/componentlibrary/p-43f1298b.js +0 -1
  500. package/dist/componentlibrary/p-4d387ec6.entry.js +0 -1
  501. package/dist/componentlibrary/p-59ba81d6.entry.js +0 -1
  502. package/dist/componentlibrary/p-5e3cbec8.entry.js +0 -1
  503. package/dist/componentlibrary/p-5e81e830.entry.js +0 -1
  504. package/dist/componentlibrary/p-64ff5040.js +0 -1
  505. package/dist/componentlibrary/p-68a871d3.entry.js +0 -1
  506. package/dist/componentlibrary/p-996a7395.entry.js +0 -1
  507. package/dist/componentlibrary/p-9b460452.entry.js +0 -1
  508. package/dist/componentlibrary/p-a416e410.entry.js +0 -1
  509. package/dist/componentlibrary/p-d550a94f.entry.js +0 -1
  510. package/dist/componentlibrary/p-e4735c23.entry.js +0 -1
  511. package/dist/componentlibrary/p-e725f388.entry.js +0 -1
  512. package/dist/componentlibrary/p-e9532ae5.entry.js +0 -1
  513. package/dist/componentlibrary/p-edf6f848.entry.js +0 -1
  514. package/dist/componentlibrary/p-fd8070fb.js +0 -1
  515. package/dist/componentlibrary/priv-chart-popover.entry.js +0 -85
  516. package/dist/componentlibrary/priv-datepicker.entry.js +0 -668
  517. package/dist/componentlibrary/priv-navigator-button.entry.js +0 -25
  518. package/dist/componentlibrary/priv-navigator-item.entry.js +0 -30
  519. package/dist/componentlibrary/shadow-css-67b66845.js +0 -389
  520. package/dist/componentlibrary/wm-action-menu.entry.js +0 -202
  521. package/dist/componentlibrary/wm-button.entry.js +0 -148
  522. package/dist/componentlibrary/wm-chart-slice.entry.js +0 -18
  523. package/dist/componentlibrary/wm-chart.entry.js +0 -504
  524. package/dist/componentlibrary/wm-datepicker.entry.js +0 -258
  525. package/dist/componentlibrary/wm-input.entry.js +0 -106
  526. package/dist/componentlibrary/wm-menuitem.entry.js +0 -114
  527. package/dist/componentlibrary/wm-modal-footer.entry.js +0 -39
  528. package/dist/componentlibrary/wm-modal-header.entry.js +0 -41
  529. package/dist/componentlibrary/wm-modal.entry.js +0 -145
  530. package/dist/componentlibrary/wm-navigator.entry.js +0 -275
  531. package/dist/componentlibrary/wm-network-uploader.entry.js +0 -427
  532. package/dist/componentlibrary/wm-option.entry.js +0 -119
  533. package/dist/componentlibrary/wm-pagination.entry.js +0 -172
  534. package/dist/componentlibrary/wm-search.entry.js +0 -227
  535. package/dist/componentlibrary/wm-select.entry.js +0 -362
  536. package/dist/componentlibrary/wm-snackbar.entry.js +0 -156
  537. package/dist/componentlibrary/wm-tab-item.entry.js +0 -78
  538. package/dist/componentlibrary/wm-tab-list.entry.js +0 -201
  539. package/dist/componentlibrary/wm-tab-panel.entry.js +0 -38
  540. package/dist/componentlibrary/wm-tag-input.entry.js +0 -509
  541. package/dist/componentlibrary/wm-timepicker.entry.js +0 -382
  542. package/dist/componentlibrary/wm-toggletip.entry.js +0 -124
  543. package/dist/componentlibrary/wm-uploader.entry.js +0 -338
  544. package/dist/componentlibrary/wm-wrapper.entry.js +0 -17
  545. package/dist/esm/app-globals-18876ad3.js +0 -45
  546. package/dist/esm/app-globals-307a1083.js +0 -108
  547. package/dist/esm/componentlibrary.js +0 -18
  548. package/dist/esm/css-shim-bbdf0cc6.js +0 -4
  549. package/dist/esm/dom-1f98a75f.js +0 -73
  550. package/dist/esm/functions-316c1b23.js +0 -8340
  551. package/dist/esm/global-430cb201.js +0 -36
  552. package/dist/esm/http-service-3dc3b3e7.js +0 -52
  553. package/dist/esm/http-service-5d037e16.js +0 -52
  554. package/dist/esm/index-d5997567.js +0 -2938
  555. package/dist/esm/interfaces-2b97fab2.js +0 -32
  556. package/dist/esm/interfaces-50753346.js +0 -51
  557. package/dist/esm/polyfills/css-shim.js +0 -1
  558. package/dist/esm/priv-chart-popover.entry.js +0 -85
  559. package/dist/esm/priv-datepicker.entry.js +0 -668
  560. package/dist/esm/shadow-css-67b66845.js +0 -389
  561. package/dist/esm/wm-action-menu.entry.js +0 -202
  562. package/dist/esm/wm-menuitem.entry.js +0 -114
  563. package/dist/esm/wm-modal-footer.entry.js +0 -39
  564. package/dist/esm/wm-modal-header.entry.js +0 -41
  565. package/dist/esm/wm-modal.entry.js +0 -145
  566. package/dist/esm/wm-network-uploader.entry.js +0 -427
  567. package/dist/esm/wm-option.entry.js +0 -119
  568. package/dist/esm/wm-select.entry.js +0 -362
  569. package/dist/esm/wm-tab-item.entry.js +0 -78
  570. package/dist/esm/wm-tab-list.entry.js +0 -201
  571. package/dist/esm/wm-tab-panel.entry.js +0 -38
  572. package/dist/types/components/wm-chart/priv-chart-popover/priv-chart-popover.d.ts +0 -23
  573. package/dist/types/components/wm-chart/wm-chart-slice.d.ts +0 -8
  574. package/dist/types/components/wm-chart/wm-chart.d.ts +0 -77
  575. package/dist/types/components/wm-datepicker/priv-datepicker/priv-datepicker.d.ts +0 -75
  576. package/dist/types/components/wm-datepicker/wm-datepicker.d.ts +0 -39
  577. package/dist/types/components/wm-option/wm-option.d.ts +0 -28
  578. package/dist/types/components/wm-select/wm-select.d.ts +0 -63
  579. package/dist/types/components/wm-uploader/wm-network-uploader/wm-network-uploader.d.ts +0 -85
  580. /package/dist/{componentlibrary/index.esm.js → collection/dev/button.js} +0 -0
@@ -1,567 +1,553 @@
1
- import { h, Component, Host, Element, Prop, Watch, State, Listen, Event } from "@stencil/core";
2
- import { intl, generateId, shouldOpenUp, isRelatedTarget } from "../../global/functions";
1
+ import { h, Host } from "@stencil/core";
2
+ import { intl, shouldOpenUp, toBool, handleDisabledAttribute, showTooltip, hideTooltip } from "../../global/functions";
3
3
  export class Timepicker {
4
- constructor() {
5
- this.disabled = false;
6
- this.value = "";
7
- this.label = "";
8
- this.labelPosition = "top";
9
- this.requiredField = false;
10
- this.isExpanded = false;
11
- this.isTabbing = false;
12
- this.twelveHrValid = /^(0?[0-9]|1[0-2])\s*:?\s*([0-5][0-9])?\s?(a|p|am|pm)?$/i;
13
- this.twentyFourHrValid = /^(0?[0-9]|1[0-9]|2[0-4])\s*:?\s*([0-5][0-9])?$/;
14
- this.uid = "";
15
- this.timeFormat = "hh:mm";
16
- this.times = [];
17
- this.openUp = false;
18
- this.buttonAriaLabel = intl.formatMessage({
19
- id: "time.selectTime",
20
- defaultMessage: "Select time",
21
- });
22
- }
23
- toggleTabbingOn() {
24
- this.isTabbing = true;
25
- }
26
- toggleTabbingOff() {
27
- this.isTabbing = false;
28
- }
29
- blurHandler(ev) {
30
- if (ev.target !== this.el && this.isExpanded) {
31
- this.close();
32
- }
33
- }
34
- handleKey(ev) {
35
- switch (ev.key) {
36
- case "ArrowDown":
37
- ev.preventDefault();
38
- if (this.isExpanded === false) {
39
- this.open("next");
4
+ constructor() {
5
+ this.twelveHrValid = /^(0?[0-9]|1[0-2])\s*:?\s*([0-5][0-9])?\s?(a|p|am|pm)?$/i;
6
+ this.twentyFourHrValid = /^(0?[0-9]|1[0-9]|2[0-4])\s*:?\s*([0-5][0-9])?$/;
7
+ this.timeFormat = "hh:mm";
8
+ this.times = this.generateTimeIntervals();
9
+ this.openUp = false;
10
+ this.buttonAriaLabel = intl.formatMessage({
11
+ id: "time.selectTime",
12
+ defaultMessage: "Select time",
13
+ description: "Button text for screen readers.",
14
+ });
15
+ this.disabled = false;
16
+ this.value = "";
17
+ this.errorMessage = undefined;
18
+ this.label = "";
19
+ this.labelPosition = "top";
20
+ this.requiredField = false;
21
+ this.preselected = undefined;
22
+ this.isExpanded = false;
23
+ }
24
+ get selectedOption() {
25
+ return this.optionsList.filter((option) => option.tabIndex === 0)[0];
26
+ }
27
+ get optionsList() {
28
+ return Array.from(this.optionsEl.querySelectorAll("li"));
29
+ }
30
+ get isDisabled() {
31
+ // string "false" needs to be treated as bool False because react wrappers convert bool to string.
32
+ return toBool(this.disabled);
33
+ }
34
+ async isValidTime(input) {
35
+ return this.isValidTimeInternal(input);
36
+ }
37
+ isValidTimeInternal(input) {
38
+ return this.twelveHrValid.test(input) || this.twentyFourHrValid.test(input);
39
+ }
40
+ async reformatTime(format, time) {
41
+ return this.reformatTimeInternal(format, time);
42
+ }
43
+ announce(message) {
44
+ if (this.liveRegionEl.textContent === message) {
45
+ message += "\u00A0";
40
46
  }
41
- else {
42
- this.moveDown(this.selectedOption);
47
+ this.liveRegionEl.textContent = message;
48
+ }
49
+ reformatTimeInternal(format, time) {
50
+ let [hours, minutes, amPm] = this.splitTime(time);
51
+ if (format === "12") {
52
+ if (hours === 12 && !amPm) {
53
+ amPm = "PM";
54
+ }
55
+ if (hours === 0 || hours === 24) {
56
+ hours = 12;
57
+ }
58
+ if (hours > 12) {
59
+ hours -= 12;
60
+ amPm = "PM";
61
+ }
62
+ if (amPm && amPm.toUpperCase().includes("P")) {
63
+ amPm = "PM";
64
+ }
65
+ else {
66
+ amPm = "AM";
67
+ }
68
+ return `${hours.toString().padStart(2, "0")}:${minutes} ${amPm}`;
43
69
  }
44
- break;
45
- case "ArrowUp":
46
- ev.preventDefault();
47
- if (this.isExpanded === false) {
48
- this.open("previous");
70
+ else if (format === "24") {
71
+ if (hours === 24) {
72
+ hours = 0;
73
+ }
74
+ if (hours === 12 && amPm && amPm.toUpperCase().includes("A")) {
75
+ hours -= 12;
76
+ }
77
+ if (amPm && amPm.toUpperCase().includes("P") && hours !== 12) {
78
+ hours += 12;
79
+ }
80
+ return `${hours.toString().padStart(2, "0")}:${minutes}`;
49
81
  }
50
82
  else {
51
- this.moveUp(this.selectedOption);
83
+ return time;
52
84
  }
53
- break;
54
- case "Enter":
55
- case " ":
56
- if (this.isExpanded) {
57
- ev.preventDefault();
58
- this.handleOptionClick(this.selectedOption.textContent);
85
+ }
86
+ handleKey(ev) {
87
+ switch (ev.key) {
88
+ case "ArrowDown":
89
+ ev.preventDefault();
90
+ if (this.isExpanded === false) {
91
+ this.open("next");
92
+ }
93
+ else {
94
+ this.moveNext(this.selectedOption);
95
+ }
96
+ break;
97
+ case "ArrowUp":
98
+ ev.preventDefault();
99
+ if (this.isExpanded === false) {
100
+ this.open("previous");
101
+ }
102
+ else {
103
+ this.movePrevious(this.selectedOption);
104
+ }
105
+ break;
106
+ case "Enter":
107
+ case " ":
108
+ if (this.isExpanded) {
109
+ ev.preventDefault();
110
+ this.handleOptionClick(this.selectedOption.dataset.time);
111
+ }
112
+ break;
113
+ case "Escape":
114
+ ev.preventDefault();
115
+ if (this.isExpanded) {
116
+ ev.stopPropagation(); // for instance if select is in a modal, esc should close the select but not the modal
117
+ this.close();
118
+ }
119
+ break;
120
+ case "Tab":
121
+ if (this.isExpanded) {
122
+ this.close(false);
123
+ }
124
+ break;
125
+ case "Home":
126
+ ev.preventDefault();
127
+ if (this.isExpanded) {
128
+ this.focusOption(this.optionsList[0]);
129
+ }
130
+ break;
131
+ case "End":
132
+ ev.preventDefault();
133
+ if (this.isExpanded) {
134
+ this.focusOption(this.optionsList[this.optionsList.length - 1]);
135
+ }
136
+ break;
59
137
  }
60
- break;
61
- case "Escape":
62
- ev.preventDefault();
63
- if (this.isExpanded) {
64
- ev.stopPropagation(); // for instance if select is in a modal, esc should close the select but not the modal
65
- this.close();
138
+ }
139
+ handleDisabledChange() {
140
+ handleDisabledAttribute(this.el, this.isDisabled);
141
+ }
142
+ handleValueChange() {
143
+ this.inputEl.value = this.value ? this.value : "";
144
+ }
145
+ announceError() {
146
+ if (this.errorMessage) {
147
+ setTimeout(() => this.announce(this.errorMessage), 100);
66
148
  }
67
- break;
68
- case "Tab":
69
- if (this.isExpanded) {
70
- this.close();
149
+ }
150
+ componentWillLoad() {
151
+ if (this.label === "") {
152
+ console.error("You must include a label prop for the timepicker (for accessibility reasons), even if the label position is none.");
71
153
  }
72
- break;
73
- case "Home":
74
- ev.preventDefault();
75
- if (this.isExpanded) {
76
- this.focusOption(this.optionsList[0]);
77
- this.setDropdownPosition("first");
154
+ this.timeFormat = intl.formatMessage({
155
+ id: "time.timeFormat",
156
+ defaultMessage: "hh:mm",
157
+ });
158
+ handleDisabledAttribute(this.el, this.isDisabled);
159
+ }
160
+ componentDidLoad() {
161
+ this.optionsEl.classList.add("hidden");
162
+ }
163
+ handleOptionClick(time) {
164
+ this.close();
165
+ this.wmTimepickerTimeSelected.emit({ time: time });
166
+ }
167
+ handleInputBlur() {
168
+ this.wmTimepickerInputBlurred.emit();
169
+ this.tpWrapper.classList.remove("focus");
170
+ }
171
+ handleLabelMouseEnter(ev) {
172
+ const labelEl = ev.target;
173
+ if (labelEl.scrollWidth > labelEl.clientWidth) {
174
+ showTooltip("right", ev.target, this.label);
78
175
  }
79
- break;
80
- case "End":
81
- ev.preventDefault();
82
- if (this.isExpanded) {
83
- this.focusOption(this.optionsList[this.optionsList.length - 1]);
84
- this.setDropdownPosition("last");
176
+ }
177
+ generateTimeIntervals() {
178
+ let timeIntervals = [];
179
+ let startTime = 0;
180
+ for (let i = 0; startTime < 24 * 60; i++) {
181
+ const h = Math.floor(startTime / 60);
182
+ const hour = h.toString().padStart(2, "0");
183
+ const m = (startTime % 60).toString();
184
+ const min = m.padStart(2, "0");
185
+ timeIntervals[i] = `${hour}:${min}`;
186
+ startTime = startTime + 15;
85
187
  }
86
- break;
87
- }
88
- }
89
- updateErrorState() {
90
- this.displayedErrorMessage = this.errorMessage;
91
- }
92
- componentWillLoad() {
93
- if (this.label === "") {
94
- throw new Error("You must include a label prop for the datepicker input (for accessibility requirements), even if the label position is none.");
95
- }
96
- this.el.focus = function () {
97
- if (!this.disabled) {
98
- this.shadowRoot.querySelector("input").focus();
99
- }
100
- };
101
- this.uid = this.el.id ? this.el.id : generateId();
102
- this.updateErrorState();
103
- this.timeFormat = intl.formatMessage({
104
- id: "time.timeFormat",
105
- defaultMessage: "hh:mm",
106
- });
107
- this.times = this.generateTimes();
108
- }
109
- componentDidLoad() {
110
- this.optionsEl.classList.add("hidden");
111
- this.optionsList = Array.from(this.optionsEl.querySelectorAll("li"));
112
- if (this.value) {
113
- this.processInput();
114
- }
115
- }
116
- isValidTime(input) {
117
- return this.twelveHrValid.test(input) || this.twentyFourHrValid.test(input);
118
- }
119
- generateTimes() {
120
- let times = [];
121
- let startTime = 0;
122
- for (let i = 0; startTime < 24 * 60; i++) {
123
- const h = Math.floor(startTime / 60);
124
- const hour = h.toString().padStart(2, "0");
125
- const m = (startTime % 60).toString();
126
- const min = m.padStart(2, "0");
127
- times[i] = `${hour}:${min}`;
128
- startTime = startTime + 15;
129
- }
130
- return times;
131
- }
132
- findNearestTimeInterval(time) {
133
- let formattedTime = this.formatToStorage(time);
134
- const minutes = parseInt(formattedTime.slice(3, 5));
135
- // first find the closest 15 min increment
136
- if (minutes % 15 !== 0) {
137
- const hour = parseInt(formattedTime.slice(0, 2));
138
- let roundedMinutes = (Math.round(minutes / 15) * 15).toString().padStart(2, "0");
139
- if (roundedMinutes === "60") {
140
- roundedMinutes = "00";
141
- let roundedHour = hour + 1;
142
- if (roundedHour === 24) {
143
- roundedHour = 0;
188
+ return timeIntervals;
189
+ }
190
+ splitTime(time) {
191
+ const splitTime = this.twelveHrValid.exec(time) || this.twentyFourHrValid.exec(time);
192
+ let hours = parseInt(splitTime[1]);
193
+ let minutes = splitTime[2] || "00";
194
+ let amPm = splitTime ? splitTime[3] : undefined;
195
+ // handles edge case uncaught by regex '0pm'
196
+ if (hours === 0 && (amPm === null || amPm === void 0 ? void 0 : amPm.toUpperCase().includes("P"))) {
197
+ // if user types '0pm' we change it to midnight
198
+ amPm = "AM";
144
199
  }
145
- formattedTime = formattedTime.replace(`${hour.toString().padStart(2, "0")}:`, `${roundedHour.toString().padStart(2, "0")}:`);
146
- }
147
- if (parseInt(roundedMinutes) < 8) {
148
- roundedMinutes = "00";
149
- }
150
- time = formattedTime.replace(`:${minutes.toString().padStart(2, "0")}`, `:${roundedMinutes}`);
151
- }
152
- return time;
153
- }
154
- handleListSelection(time) {
155
- time = this.findNearestTimeInterval(time);
156
- const option = this.optionsList.filter((o) => o.textContent == this.formatToDisplay(time))[0];
157
- // not DOM focus, just setting the proper ARIA attributes
158
- option && this.focusOption(option);
159
- }
160
- setValue(time) {
161
- this.inputEl.value = this.formatToDisplay(time);
162
- this.value = this.formatToStorage(time);
163
- // update the selection in the list
164
- // so it opens on the closest item
165
- this.handleListSelection(time);
166
- this.wmTimepickerOnChange.emit({
167
- value: this.value,
168
- isValid: !!this.displayedErrorMessage,
169
- });
170
- }
171
- processInput() {
172
- if (this.isValidTime(this.value)) {
173
- this.setValue(this.value);
174
- }
175
- const newErrorMessage = this.determineErrorMessage();
176
- this.displayedErrorMessage = newErrorMessage;
177
- }
178
- determineErrorMessage() {
179
- let message = this.errorMessage;
180
- const requiredError = intl.formatMessage({
181
- id: "time.requiredError",
182
- defaultMessage: "A time is required.",
183
- });
184
- const invalidError = intl.formatMessage({
185
- id: "time.invalidTime",
186
- defaultMessage: "Please enter a valid time.",
187
- });
188
- const isValid = this.isValidTime(this.value);
189
- if (isValid && !this.errorMessage) {
190
- message = null;
191
- }
192
- else if (!isValid && !this.errorMessage) {
193
- if (this.requiredField && !this.value) {
194
- message = requiredError;
195
- }
196
- else if (this.value) {
197
- message = invalidError;
198
- }
199
- else {
200
- message = null;
201
- }
202
- }
203
- return message;
204
- }
205
- splitTime(time) {
206
- const splitTime = this.twelveHrValid.exec(time) || this.twentyFourHrValid.exec(time);
207
- let hours = parseInt(splitTime[1]);
208
- let minutes = splitTime[2] || "00";
209
- let amPm = splitTime ? splitTime[3] : undefined;
210
- // handles edge case uncaught by regex '0pm'
211
- if (hours === 0 && (amPm === null || amPm === void 0 ? void 0 : amPm.toUpperCase().includes("P"))) {
212
- // if user types '0pm' we change it to midnight
213
- amPm = "AM";
214
- }
215
- return [hours, minutes, amPm];
216
- }
217
- formatToDisplay(time) {
218
- let [hours, minutes, amPm] = this.splitTime(time);
219
- // at the moment the component only displays in 12hr AM/PM
220
- if (hours === 12 && !amPm) {
221
- amPm = "PM";
222
- }
223
- if (hours === 0 || hours === 24) {
224
- hours = 12;
225
- }
226
- if (hours > 12) {
227
- hours -= 12;
228
- amPm = "PM";
229
- }
230
- if (amPm && amPm.toUpperCase().includes("P")) {
231
- amPm = "PM";
232
- }
233
- else {
234
- amPm = "AM";
235
- }
236
- return `${hours.toString().padStart(2, "0")}:${minutes} ${amPm}`;
237
- }
238
- formatToStorage(time) {
239
- let [hours, minutes, amPm] = this.splitTime(time);
240
- if (hours === 24) {
241
- hours = 0;
242
- }
243
- if (hours === 12 && amPm && amPm.toUpperCase().includes("A")) {
244
- hours -= 12;
245
- }
246
- if (amPm && amPm.toUpperCase().includes("P") && hours !== 12) {
247
- hours += 12;
248
- }
249
- return `${hours.toString().padStart(2, "0")}:${minutes}`;
250
- }
251
- open(itemToSelect) {
252
- this.el.focus();
253
- this.openUp = shouldOpenUp(this.el, this.optionsEl);
254
- this.isExpanded = true;
255
- this.optionsEl.classList.remove("hidden");
256
- if (this.errorMessage || !this.value) {
257
- this.handleListSelection("09:00");
258
- }
259
- this.setDropdownPosition("center", this.selectedOption);
260
- window.requestAnimationFrame(() => {
261
- if (itemToSelect === "next") {
262
- this.moveDown(this.selectedOption);
263
- }
264
- else if (itemToSelect === "previous") {
265
- this.moveUp(this.selectedOption);
266
- }
267
- });
268
- }
269
- close() {
270
- this.isExpanded = false;
271
- window.setTimeout(() => {
272
- this.optionsEl.classList.add("hidden");
273
- // Returns focus to button after popup closes (no need if user is tabbing)
274
- // Delay is necessary for screenreader to get new expanded state before focus
275
- // window.requestAnimationFrame is probably enough, but since we are already using setTimeout it may as well be here
276
- // also UX wise, it makes sense for the button to only be focused after the animation is complete
277
- this.buttonEl.focus();
278
- }, 150);
279
- }
280
- focusOption(item) {
281
- // not an actual focus, just accessibility stuff
282
- this.optionsList.forEach((option) => {
283
- option.removeAttribute("aria-selected");
284
- });
285
- this.inputEl.setAttribute("aria-activedescendant", item.id);
286
- item.setAttribute("aria-selected", "true");
287
- this.selectedOption = item;
288
- }
289
- setDropdownPosition(position, item) {
290
- switch (position) {
291
- case "top":
292
- const prevItem = item === null || item === void 0 ? void 0 : item.previousElementSibling;
293
- this.optionsEl.scrollTop =
294
- prevItem.getBoundingClientRect().top - this.optionsEl.getBoundingClientRect().top + this.optionsEl.scrollTop;
295
- break;
296
- case "bottom":
297
- const nextItem = item === null || item === void 0 ? void 0 : item.nextElementSibling;
298
- this.optionsEl.scrollTop =
299
- nextItem.getBoundingClientRect().bottom -
300
- this.optionsEl.getBoundingClientRect().top +
301
- this.optionsEl.scrollTop -
302
- this.optionsEl.offsetHeight;
303
- break;
304
- case "center":
200
+ return [hours, minutes, amPm];
201
+ }
202
+ open(itemToSelect) {
203
+ this.openUp = shouldOpenUp(this.el, this.optionsEl.clientHeight);
204
+ this.isExpanded = true;
205
+ this.optionsEl.classList.remove("hidden");
206
+ // focus hierarchy: preselected prop -> parsed time -> 09:00
207
+ let focusOnOpenEl = this.optionsList[36]; // 09:00
208
+ if (this.preselected) {
209
+ focusOnOpenEl = this.optionsList.filter((option) => option.dataset.time == this.preselected)[0];
210
+ }
211
+ else if (this.isValidTimeInternal(this.value)) {
212
+ const nearestTime = this.findNearestTimeInterval(this.reformatTimeInternal("24", this.value));
213
+ focusOnOpenEl = this.optionsList.filter((option) => option.dataset.time == nearestTime)[0];
214
+ }
215
+ // position option in center of dropdown
305
216
  this.optionsEl.scrollTop =
306
- (this.optionsList.findIndex((x) => x.textContent === (item === null || item === void 0 ? void 0 : item.textContent)) - 2) * item.offsetHeight;
307
- break;
308
- case "first":
309
- this.optionsEl.scrollTop = 0;
310
- break;
311
- case "last":
312
- this.optionsEl.scrollTop = this.optionsList[0].clientHeight * this.optionsList.length;
313
- break;
314
- }
315
- }
316
- moveUp(el) {
317
- const prevEl = el.previousElementSibling;
318
- if (prevEl) {
319
- // scroll option to top of dropdown if partially obscured / out of view
320
- if (prevEl.getBoundingClientRect().top < this.optionsEl.getBoundingClientRect().top) {
321
- this.setDropdownPosition("top", el);
322
- }
323
- this.focusOption(prevEl);
324
- }
325
- else {
326
- this.focusOption(this.optionsList[this.optionsList.length - 1]);
327
- this.setDropdownPosition("last");
328
- }
329
- }
330
- moveDown(el) {
331
- const nextEl = el.nextElementSibling;
332
- if (nextEl) {
333
- // scroll option to bottom of dropdown if partially obscured / out of view
334
- if (nextEl.getBoundingClientRect().bottom > this.optionsEl.getBoundingClientRect().bottom) {
335
- this.setDropdownPosition("bottom", el);
336
- }
337
- this.focusOption(nextEl);
338
- }
339
- else {
340
- this.focusOption(this.optionsList[0]);
341
- this.setDropdownPosition("first");
342
- }
343
- }
344
- handleOptionClick(time) {
345
- this.close();
346
- this.value = time;
347
- this.processInput();
348
- }
349
- handleInput() {
350
- this.value = this.inputEl.value;
351
- if (this.isValidTime(this.value)) {
352
- this.handleListSelection(this.findNearestTimeInterval(this.value));
353
- this.setDropdownPosition("center", this.selectedOption);
354
- }
355
- }
356
- handleBlur(ev) {
357
- // do not validate if clicking to an element that should prevent validation (e.g. close button on modal)
358
- const shouldPreventValidation = this.preventValidation && isRelatedTarget(ev, this.preventValidation);
359
- if (!shouldPreventValidation) {
360
- this.processInput();
361
- }
362
- this.tpWrapper.classList.remove("focus");
363
- }
364
- renderOptions() {
365
- return this.times.map((time, index) => (h("li", { id: `option${index + 1}`, role: "option", "aria-selected": time === "09:00" ? "true" : false, onClick: () => this.handleOptionClick(time) }, this.formatToDisplay(time))));
366
- }
367
- render() {
368
- return (h(Host, { id: this.uid, invalid: !!this.displayedErrorMessage ? "true" : null },
369
- h("div", { class: `wrapper label-${this.labelPosition} ${!!this.displayedErrorMessage ? "invalid" : ""}`, ref: (t) => (this.tpWrapper = t) },
370
- h("div", { class: "label-wrapper" }, this.labelPosition !== "none" && (h("label", { id: `label-${this.uid}`, class: "label", htmlFor: `time-input-${this.uid}` },
371
- this.label,
372
- this.requiredField && (h("span", { class: "required", "aria-hidden": "true" }, "*"))))),
373
- h("div", null,
374
- h("div", { class: "inner-wrapper" },
375
- h("input", { id: `time-input-${this.uid}`, "aria-label": this.label, "aria-describedby": `error-${this.uid}`, ref: (el) => (this.inputEl = el), onBlur: (ev) => this.handleBlur(ev), onInput: () => this.handleInput(), disabled: this.disabled, required: this.requiredField, placeholder: this.timeFormat, autocomplete: "off", onFocus: () => this.tpWrapper.classList.add("focus") }),
376
- h("button", { id: `btn-${this.uid}`, class: this.isTabbing ? "user-is-tabbing" : "", ref: (el) => (this.buttonEl = el), disabled: this.disabled, "aria-controls": `list-${this.uid}`, "aria-expanded": this.isExpanded ? "true" : "false", "aria-label": this.buttonAriaLabel, "aria-describedby": `time-input-${this.uid}`, onClick: () => (this.isExpanded ? this.close() : this.open()) },
377
- h("span", { class: "clock" })),
378
- h("ul", { class: `options ${this.isExpanded ? "open" : ""} ${this.openUp ? "upwards" : ""}`, id: `list-${this.uid}`, role: "listbox", "aria-labelledby": `label-${this.uid}`, "aria-describedby": this.isExpanded ? "collapsed" : null, ref: (el) => (this.optionsEl = el) }, this.renderOptions())),
379
- h("div", { id: `error-${this.uid}`, class: "error", "aria-live": "assertive", "aria-atomic": "true" }, this.displayedErrorMessage)))));
380
- }
381
- static get is() { return "wm-timepicker"; }
382
- static get encapsulation() { return "shadow"; }
383
- static get originalStyleUrls() { return {
384
- "$": ["wm-timepicker.scss"]
385
- }; }
386
- static get styleUrls() { return {
387
- "$": ["wm-timepicker.css"]
388
- }; }
389
- static get properties() { return {
390
- "disabled": {
391
- "type": "boolean",
392
- "mutable": false,
393
- "complexType": {
394
- "original": "boolean",
395
- "resolved": "boolean",
396
- "references": {}
397
- },
398
- "required": false,
399
- "optional": false,
400
- "docs": {
401
- "tags": [],
402
- "text": ""
403
- },
404
- "attribute": "disabled",
405
- "reflect": false,
406
- "defaultValue": "false"
407
- },
408
- "value": {
409
- "type": "string",
410
- "mutable": true,
411
- "complexType": {
412
- "original": "string",
413
- "resolved": "string",
414
- "references": {}
415
- },
416
- "required": false,
417
- "optional": false,
418
- "docs": {
419
- "tags": [],
420
- "text": ""
421
- },
422
- "attribute": "value",
423
- "reflect": true,
424
- "defaultValue": "\"\""
425
- },
426
- "errorMessage": {
427
- "type": "string",
428
- "mutable": false,
429
- "complexType": {
430
- "original": "string | null",
431
- "resolved": "null | string | undefined",
432
- "references": {}
433
- },
434
- "required": false,
435
- "optional": true,
436
- "docs": {
437
- "tags": [],
438
- "text": ""
439
- },
440
- "attribute": "error-message",
441
- "reflect": false
442
- },
443
- "label": {
444
- "type": "string",
445
- "mutable": false,
446
- "complexType": {
447
- "original": "string",
448
- "resolved": "string",
449
- "references": {}
450
- },
451
- "required": false,
452
- "optional": false,
453
- "docs": {
454
- "tags": [],
455
- "text": ""
456
- },
457
- "attribute": "label",
458
- "reflect": false,
459
- "defaultValue": "\"\""
460
- },
461
- "labelPosition": {
462
- "type": "string",
463
- "mutable": false,
464
- "complexType": {
465
- "original": "\"top\" | \"left\" | \"none\"",
466
- "resolved": "\"left\" | \"none\" | \"top\"",
467
- "references": {}
468
- },
469
- "required": false,
470
- "optional": false,
471
- "docs": {
472
- "tags": [],
473
- "text": ""
474
- },
475
- "attribute": "label-position",
476
- "reflect": false,
477
- "defaultValue": "\"top\""
478
- },
479
- "requiredField": {
480
- "type": "boolean",
481
- "mutable": false,
482
- "complexType": {
483
- "original": "boolean",
484
- "resolved": "boolean",
485
- "references": {}
486
- },
487
- "required": false,
488
- "optional": false,
489
- "docs": {
490
- "tags": [],
491
- "text": ""
492
- },
493
- "attribute": "required-field",
494
- "reflect": false,
495
- "defaultValue": "false"
496
- },
497
- "preventValidation": {
498
- "type": "string",
499
- "mutable": false,
500
- "complexType": {
501
- "original": "string",
502
- "resolved": "string | undefined",
503
- "references": {}
504
- },
505
- "required": false,
506
- "optional": true,
507
- "docs": {
508
- "tags": [],
509
- "text": ""
510
- },
511
- "attribute": "prevent-validation",
512
- "reflect": false
513
- }
514
- }; }
515
- static get states() { return {
516
- "selectedOption": {},
517
- "isExpanded": {},
518
- "isTabbing": {},
519
- "displayedErrorMessage": {}
520
- }; }
521
- static get events() { return [{
522
- "method": "wmTimepickerOnChange",
523
- "name": "wmTimepickerOnChange",
524
- "bubbles": true,
525
- "cancelable": true,
526
- "composed": true,
527
- "docs": {
528
- "tags": [],
529
- "text": ""
530
- },
531
- "complexType": {
532
- "original": "{\r\n value: string;\r\n isValid: boolean;\r\n }",
533
- "resolved": "{ value: string; isValid: boolean; }",
534
- "references": {}
535
- }
536
- }]; }
537
- static get elementRef() { return "el"; }
538
- static get watchers() { return [{
539
- "propName": "errorMessage",
540
- "methodName": "updateErrorState"
541
- }]; }
542
- static get listeners() { return [{
543
- "name": "wmUserIsTabbing",
544
- "method": "toggleTabbingOn",
545
- "target": "window",
546
- "capture": false,
547
- "passive": false
548
- }, {
549
- "name": "wmUserIsNotTabbing",
550
- "method": "toggleTabbingOff",
551
- "target": "window",
552
- "capture": false,
553
- "passive": false
554
- }, {
555
- "name": "click",
556
- "method": "blurHandler",
557
- "target": "document",
558
- "capture": false,
559
- "passive": false
560
- }, {
561
- "name": "keydown",
562
- "method": "handleKey",
563
- "target": undefined,
564
- "capture": false,
565
- "passive": false
566
- }]; }
217
+ (this.optionsList.findIndex((x) => x.textContent === (focusOnOpenEl === null || focusOnOpenEl === void 0 ? void 0 : focusOnOpenEl.textContent)) - 2) *
218
+ focusOnOpenEl.offsetHeight;
219
+ this.focusOption(focusOnOpenEl);
220
+ window.requestAnimationFrame(() => {
221
+ if (itemToSelect === "next") {
222
+ this.moveNext(this.selectedOption);
223
+ }
224
+ else if (itemToSelect === "previous") {
225
+ this.movePrevious(this.selectedOption);
226
+ }
227
+ });
228
+ }
229
+ close(returnFocus = true) {
230
+ this.isExpanded = false;
231
+ window.setTimeout(() => {
232
+ this.optionsEl.classList.add("hidden");
233
+ // Returns focus to button after popup closes (no need if user is tabbing)
234
+ // Delay is necessary for screenreader to get new expanded state before focus
235
+ // window.requestAnimationFrame is probably enough, but since we are already using setTimeout it may as well be here
236
+ // also UX wise, it makes sense for the button to only be focused after the animation is complete
237
+ if (returnFocus) {
238
+ this.buttonEl.focus();
239
+ }
240
+ }, 150);
241
+ }
242
+ focusOption(item) {
243
+ this.optionsList.forEach((option) => {
244
+ option.tabIndex = -1;
245
+ });
246
+ item.tabIndex = 0;
247
+ item.scrollIntoView({ block: "nearest" });
248
+ item.focus();
249
+ }
250
+ movePrevious(optionEl) {
251
+ this.focusOption(optionEl.previousElementSibling
252
+ ? optionEl.previousElementSibling
253
+ : this.optionsList[this.optionsList.length - 1]);
254
+ }
255
+ moveNext(optionEl) {
256
+ this.focusOption(optionEl.nextElementSibling ? optionEl.nextElementSibling : this.optionsList[0]);
257
+ }
258
+ findNearestTimeInterval(time) {
259
+ // accepts time in 24hr format
260
+ const minutes = parseInt(time.slice(3, 5));
261
+ // first find the closest 15 min increment
262
+ if (minutes % 15 !== 0) {
263
+ const hour = parseInt(time.slice(0, 2));
264
+ let roundedMinutes = (Math.round(minutes / 15) * 15).toString().padStart(2, "0");
265
+ if (roundedMinutes === "60") {
266
+ roundedMinutes = "00";
267
+ let roundedHour = hour + 1;
268
+ if (roundedHour === 24) {
269
+ roundedHour = 0;
270
+ }
271
+ time = time.replace(`${hour.toString().padStart(2, "0")}:`, `${roundedHour.toString().padStart(2, "0")}:`);
272
+ }
273
+ if (parseInt(roundedMinutes) < 8) {
274
+ roundedMinutes = "00";
275
+ }
276
+ time = time.replace(`:${minutes.toString().padStart(2, "0")}`, `:${roundedMinutes}`);
277
+ }
278
+ return time;
279
+ }
280
+ renderOptions() {
281
+ return this.times.map((time, index) => (h("li", { id: `option${index + 1}`, "data-time": time, role: "option", onClick: () => this.handleOptionClick(time) }, this.reformatTimeInternal("12", time))));
282
+ }
283
+ render() {
284
+ return (h(Host, { key: 'f057602385c3afa3fa41bfaede121e1a71046e04', onBlur: () => this.close(false) }, h("div", { key: 'ac40efb8246f22f8952e4a5719a86ad44d946125', class: `wrapper label-${this.labelPosition} ${!!this.errorMessage ? "invalid" : ""}`, ref: (t) => (this.tpWrapper = t) }, h("div", { key: '63a8f7cc6531e0755e08d4828de669f8b4e7995b', class: "label-wrapper" }, this.labelPosition !== "none" && (h("label", { key: 'cb8841c9d1cc202514f6de78e0c143dc905cb22e', id: "label", class: "label", htmlFor: "time-input", onMouseEnter: (ev) => this.handleLabelMouseEnter(ev), onMouseLeave: () => hideTooltip() }, this.label)), this.labelPosition !== "none" && this.requiredField && (h("div", { key: 'ad989be822d6ebf295481098ea02b88c1983a680', "aria-hidden": "true", class: "required" }, "*"))), h("div", { key: 'c8cea84d56c4e198d9466820fb574090d62f4f82' }, h("div", { key: '02fdd089d088ec43a569ade536fde18ea31a39a9', class: "inner-wrapper" }, h("input", { key: '30080a9b2c5af94c17c278bd23c0123d1da95822', id: "time-input", "aria-label": this.label, "aria-describedby": "error", ref: (el) => (this.inputEl = el), onBlur: () => this.handleInputBlur(), onInput: () => (this.value = this.inputEl.value), disabled: this.isDisabled, "aria-required": this.requiredField ? "true" : null, placeholder: this.timeFormat, autocomplete: "off", value: this.value, onFocus: () => this.tpWrapper.classList.add("focus") }), h("button", { key: '90a7fd0188f1d590509579b013cc506150749f9e', id: "btn", ref: (el) => (this.buttonEl = el), disabled: this.isDisabled, "aria-controls": "list", "aria-expanded": this.isExpanded ? "true" : "false", "aria-label": this.buttonAriaLabel, "aria-describedby": "time-input", onClick: () => (this.isExpanded ? this.close() : this.open()),
285
+ // This addresses an issue in Safari, where clicking buttons does not focus them
286
+ // if the button does not receive focus when clicked, Timepicker incorrectly emits a blur event
287
+ onMouseDown: (ev) => {
288
+ ev.preventDefault();
289
+ this.buttonEl.focus();
290
+ } }, h("span", { key: 'b9b7f2326eaf2047ae3cfbbaa1b853c02f92013d', class: "svg-icon svg-time" })), h("ul", { key: '321445600548b008758c69b2246d6965e8e93a6a', class: `options ${this.isExpanded ? "open" : ""} ${this.openUp ? "upwards" : ""}`, id: "list", role: "listbox", "aria-labelledby": "label", "aria-describedby": this.isExpanded ? "collapsed" : null, tabindex: -1, ref: (el) => (this.optionsEl = el) }, this.renderOptions())), h("div", { key: '18e73b79a9b9372eb498b6a0c3438ef785b846f8', id: "error", class: "error" }, this.errorMessage)), h("div", { key: 'c80be090a83309d0a23daad6d0ebe6191082597e', id: "live-polite", class: "sr-only", "aria-live": "polite", "aria-atomic": "true", ref: (el) => (this.liveRegionEl = el) }))));
291
+ }
292
+ static get is() { return "wm-timepicker"; }
293
+ static get encapsulation() { return "shadow"; }
294
+ static get delegatesFocus() { return true; }
295
+ static get originalStyleUrls() {
296
+ return {
297
+ "$": ["wm-timepicker.scss"]
298
+ };
299
+ }
300
+ static get styleUrls() {
301
+ return {
302
+ "$": ["wm-timepicker.css"]
303
+ };
304
+ }
305
+ static get properties() {
306
+ return {
307
+ "disabled": {
308
+ "type": "boolean",
309
+ "mutable": false,
310
+ "complexType": {
311
+ "original": "boolean",
312
+ "resolved": "boolean",
313
+ "references": {}
314
+ },
315
+ "required": false,
316
+ "optional": false,
317
+ "docs": {
318
+ "tags": [],
319
+ "text": ""
320
+ },
321
+ "attribute": "disabled",
322
+ "reflect": false,
323
+ "defaultValue": "false"
324
+ },
325
+ "value": {
326
+ "type": "string",
327
+ "mutable": true,
328
+ "complexType": {
329
+ "original": "string",
330
+ "resolved": "string",
331
+ "references": {}
332
+ },
333
+ "required": false,
334
+ "optional": false,
335
+ "docs": {
336
+ "tags": [],
337
+ "text": ""
338
+ },
339
+ "attribute": "value",
340
+ "reflect": false,
341
+ "defaultValue": "\"\""
342
+ },
343
+ "errorMessage": {
344
+ "type": "string",
345
+ "mutable": false,
346
+ "complexType": {
347
+ "original": "string",
348
+ "resolved": "string | undefined",
349
+ "references": {}
350
+ },
351
+ "required": false,
352
+ "optional": true,
353
+ "docs": {
354
+ "tags": [],
355
+ "text": ""
356
+ },
357
+ "attribute": "error-message",
358
+ "reflect": false
359
+ },
360
+ "label": {
361
+ "type": "string",
362
+ "mutable": false,
363
+ "complexType": {
364
+ "original": "string",
365
+ "resolved": "string",
366
+ "references": {}
367
+ },
368
+ "required": false,
369
+ "optional": false,
370
+ "docs": {
371
+ "tags": [],
372
+ "text": ""
373
+ },
374
+ "attribute": "label",
375
+ "reflect": false,
376
+ "defaultValue": "\"\""
377
+ },
378
+ "labelPosition": {
379
+ "type": "string",
380
+ "mutable": false,
381
+ "complexType": {
382
+ "original": "\"top\" | \"left\" | \"none\"",
383
+ "resolved": "\"left\" | \"none\" | \"top\"",
384
+ "references": {}
385
+ },
386
+ "required": false,
387
+ "optional": false,
388
+ "docs": {
389
+ "tags": [],
390
+ "text": ""
391
+ },
392
+ "attribute": "label-position",
393
+ "reflect": false,
394
+ "defaultValue": "\"top\""
395
+ },
396
+ "requiredField": {
397
+ "type": "boolean",
398
+ "mutable": false,
399
+ "complexType": {
400
+ "original": "boolean",
401
+ "resolved": "boolean",
402
+ "references": {}
403
+ },
404
+ "required": false,
405
+ "optional": false,
406
+ "docs": {
407
+ "tags": [],
408
+ "text": ""
409
+ },
410
+ "attribute": "required-field",
411
+ "reflect": false,
412
+ "defaultValue": "false"
413
+ },
414
+ "preselected": {
415
+ "type": "string",
416
+ "mutable": false,
417
+ "complexType": {
418
+ "original": "string",
419
+ "resolved": "string | undefined",
420
+ "references": {}
421
+ },
422
+ "required": false,
423
+ "optional": true,
424
+ "docs": {
425
+ "tags": [],
426
+ "text": ""
427
+ },
428
+ "attribute": "preselected",
429
+ "reflect": false
430
+ }
431
+ };
432
+ }
433
+ static get states() {
434
+ return {
435
+ "isExpanded": {}
436
+ };
437
+ }
438
+ static get events() {
439
+ return [{
440
+ "method": "wmTimepickerInputBlurred",
441
+ "name": "wmTimepickerInputBlurred",
442
+ "bubbles": true,
443
+ "cancelable": true,
444
+ "composed": true,
445
+ "docs": {
446
+ "tags": [],
447
+ "text": ""
448
+ },
449
+ "complexType": {
450
+ "original": "any",
451
+ "resolved": "any",
452
+ "references": {}
453
+ }
454
+ }, {
455
+ "method": "wmTimepickerTimeSelected",
456
+ "name": "wmTimepickerTimeSelected",
457
+ "bubbles": true,
458
+ "cancelable": true,
459
+ "composed": true,
460
+ "docs": {
461
+ "tags": [],
462
+ "text": ""
463
+ },
464
+ "complexType": {
465
+ "original": "any",
466
+ "resolved": "any",
467
+ "references": {}
468
+ }
469
+ }];
470
+ }
471
+ static get methods() {
472
+ return {
473
+ "isValidTime": {
474
+ "complexType": {
475
+ "signature": "(input: string) => Promise<boolean>",
476
+ "parameters": [{
477
+ "name": "input",
478
+ "type": "string",
479
+ "docs": ""
480
+ }],
481
+ "references": {
482
+ "Promise": {
483
+ "location": "global",
484
+ "id": "global::Promise"
485
+ }
486
+ },
487
+ "return": "Promise<boolean>"
488
+ },
489
+ "docs": {
490
+ "text": "",
491
+ "tags": []
492
+ }
493
+ },
494
+ "reformatTime": {
495
+ "complexType": {
496
+ "signature": "(format: \"12\" | \"24\", time: TimeFormat12 | TimeFormat24) => Promise<string>",
497
+ "parameters": [{
498
+ "name": "format",
499
+ "type": "\"12\" | \"24\"",
500
+ "docs": ""
501
+ }, {
502
+ "name": "time",
503
+ "type": "string",
504
+ "docs": ""
505
+ }],
506
+ "references": {
507
+ "Promise": {
508
+ "location": "global",
509
+ "id": "global::Promise"
510
+ },
511
+ "TimeFormat12": {
512
+ "location": "import",
513
+ "path": "../../global/interfaces",
514
+ "id": "src/global/interfaces.ts::TimeFormat12"
515
+ },
516
+ "TimeFormat24": {
517
+ "location": "import",
518
+ "path": "../../global/interfaces",
519
+ "id": "src/global/interfaces.ts::TimeFormat24"
520
+ }
521
+ },
522
+ "return": "Promise<string>"
523
+ },
524
+ "docs": {
525
+ "text": "",
526
+ "tags": []
527
+ }
528
+ }
529
+ };
530
+ }
531
+ static get elementRef() { return "el"; }
532
+ static get watchers() {
533
+ return [{
534
+ "propName": "disabled",
535
+ "methodName": "handleDisabledChange"
536
+ }, {
537
+ "propName": "value",
538
+ "methodName": "handleValueChange"
539
+ }, {
540
+ "propName": "errorMessage",
541
+ "methodName": "announceError"
542
+ }];
543
+ }
544
+ static get listeners() {
545
+ return [{
546
+ "name": "keydown",
547
+ "method": "handleKey",
548
+ "target": undefined,
549
+ "capture": false,
550
+ "passive": false
551
+ }];
552
+ }
567
553
  }