@watermarkinsights/ripple 0.0.0 → 3.0.1-1

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 (282) hide show
  1. package/dist/{esm/app-globals-18876ad3.js → ripple/app-globals-b5693c90.js} +1 -1
  2. package/dist/{componentlibrary → ripple}/css-shim-bbdf0cc6.js +0 -0
  3. package/dist/{componentlibrary → ripple}/dom-1f98a75f.js +0 -0
  4. package/dist/{componentlibrary → ripple}/functions-316c1b23.js +0 -0
  5. package/dist/{componentlibrary → ripple}/http-service-5d037e16.js +0 -0
  6. package/dist/{esm/index-d5997567.js → ripple/index-20b65f86.js} +3 -3
  7. package/dist/ripple/index.esm.js +1 -0
  8. package/dist/{componentlibrary → ripple}/interfaces-50753346.js +0 -0
  9. package/dist/{componentlibrary → ripple}/priv-chart-popover.entry.js +1 -1
  10. package/dist/{componentlibrary → ripple}/priv-datepicker.entry.js +1 -1
  11. package/dist/{componentlibrary → ripple}/priv-navigator-button.entry.js +1 -1
  12. package/dist/{componentlibrary → ripple}/priv-navigator-item.entry.js +1 -1
  13. package/dist/{componentlibrary/componentlibrary.css → ripple/ripple.css} +0 -0
  14. package/dist/ripple/ripple.esm.js +125 -0
  15. package/dist/{componentlibrary → ripple}/shadow-css-67b66845.js +0 -0
  16. package/dist/{esm → ripple}/wm-action-menu.entry.js +1 -1
  17. package/dist/{componentlibrary → ripple}/wm-button.entry.js +1 -1
  18. package/dist/{componentlibrary → ripple}/wm-chart-slice.entry.js +1 -1
  19. package/dist/{componentlibrary → ripple}/wm-chart.entry.js +1 -1
  20. package/dist/{componentlibrary → ripple}/wm-datepicker.entry.js +1 -1
  21. package/dist/{componentlibrary → ripple}/wm-input.entry.js +1 -1
  22. package/dist/{componentlibrary → ripple}/wm-menuitem.entry.js +1 -1
  23. package/dist/{componentlibrary → ripple}/wm-modal-footer.entry.js +1 -1
  24. package/dist/{componentlibrary → ripple}/wm-modal-header.entry.js +1 -1
  25. package/dist/{componentlibrary → ripple}/wm-modal.entry.js +1 -1
  26. package/dist/{componentlibrary → ripple}/wm-navigator.entry.js +1 -1
  27. package/dist/{componentlibrary → ripple}/wm-network-uploader.entry.js +1 -1
  28. package/dist/{componentlibrary → ripple}/wm-option.entry.js +1 -1
  29. package/dist/{componentlibrary → ripple}/wm-pagination.entry.js +1 -1
  30. package/dist/{componentlibrary → ripple}/wm-search.entry.js +1 -1
  31. package/dist/{componentlibrary → ripple}/wm-select.entry.js +1 -1
  32. package/dist/{componentlibrary → ripple}/wm-snackbar.entry.js +1 -1
  33. package/dist/{esm → ripple}/wm-tab-item.entry.js +1 -1
  34. package/dist/{componentlibrary → ripple}/wm-tab-list.entry.js +1 -1
  35. package/dist/{componentlibrary → ripple}/wm-tab-panel.entry.js +1 -1
  36. package/dist/{componentlibrary → ripple}/wm-tag-input.entry.js +31 -6
  37. package/dist/{componentlibrary → ripple}/wm-timepicker.entry.js +1 -1
  38. package/dist/{componentlibrary → ripple}/wm-toggletip.entry.js +1 -1
  39. package/dist/{componentlibrary → ripple}/wm-uploader.entry.js +1 -1
  40. package/dist/{componentlibrary → ripple}/wm-wrapper.entry.js +1 -1
  41. package/dist/types/components/wm-tag-input/{wm-tag-input.d.ts → wm-tag-input.d.ts~ds312_tagInputMaxTags} +4 -0
  42. package/dist/types/{components.d.ts → components.d.ts~ds312_tagInputMaxTags} +2 -0
  43. package/dist/types/{stencil-public-runtime.d.ts → stencil-public-runtime.d.ts~ds312_tagInputMaxTags} +0 -0
  44. package/package.json +3 -3
  45. package/dist/cjs/app-globals-6b0c6e80.js +0 -110
  46. package/dist/cjs/app-globals-f1dd8fda.js +0 -47
  47. package/dist/cjs/componentlibrary.cjs.js +0 -20
  48. package/dist/cjs/css-shim-a7379e2b.js +0 -6
  49. package/dist/cjs/dom-3e7d9c3b.js +0 -75
  50. package/dist/cjs/functions-65513c61.js +0 -8360
  51. package/dist/cjs/functions-f2333f02.js +0 -6129
  52. package/dist/cjs/global-6849642d.js +0 -38
  53. package/dist/cjs/http-service-494d81de.js +0 -57
  54. package/dist/cjs/http-service-9e8c4dd5.js +0 -57
  55. package/dist/cjs/index-298ebef1.js +0 -2976
  56. package/dist/cjs/index.cjs.js +0 -2
  57. package/dist/cjs/interfaces-a3338581.js +0 -35
  58. package/dist/cjs/interfaces-b2beb752.js +0 -54
  59. package/dist/cjs/loader.cjs.js +0 -22
  60. package/dist/cjs/priv-chart-popover.cjs.entry.js +0 -89
  61. package/dist/cjs/priv-datepicker.cjs.entry.js +0 -672
  62. package/dist/cjs/priv-navigator-button.cjs.entry.js +0 -29
  63. package/dist/cjs/priv-navigator-item.cjs.entry.js +0 -34
  64. package/dist/cjs/shadow-css-09555044.js +0 -391
  65. package/dist/cjs/wm-action-menu.cjs.entry.js +0 -206
  66. package/dist/cjs/wm-action-menu_2.cjs.entry.js +0 -318
  67. package/dist/cjs/wm-button.cjs.entry.js +0 -152
  68. package/dist/cjs/wm-chart-slice.cjs.entry.js +0 -22
  69. package/dist/cjs/wm-chart.cjs.entry.js +0 -508
  70. package/dist/cjs/wm-datepicker.cjs.entry.js +0 -262
  71. package/dist/cjs/wm-input.cjs.entry.js +0 -110
  72. package/dist/cjs/wm-menuitem.cjs.entry.js +0 -118
  73. package/dist/cjs/wm-modal-footer.cjs.entry.js +0 -43
  74. package/dist/cjs/wm-modal-header.cjs.entry.js +0 -45
  75. package/dist/cjs/wm-modal.cjs.entry.js +0 -149
  76. package/dist/cjs/wm-navigator.cjs.entry.js +0 -279
  77. package/dist/cjs/wm-network-uploader.cjs.entry.js +0 -431
  78. package/dist/cjs/wm-option.cjs.entry.js +0 -123
  79. package/dist/cjs/wm-option_2.cjs.entry.js +0 -483
  80. package/dist/cjs/wm-pagination.cjs.entry.js +0 -176
  81. package/dist/cjs/wm-search.cjs.entry.js +0 -231
  82. package/dist/cjs/wm-select.cjs.entry.js +0 -366
  83. package/dist/cjs/wm-snackbar.cjs.entry.js +0 -160
  84. package/dist/cjs/wm-tab-item.cjs.entry.js +0 -82
  85. package/dist/cjs/wm-tab-item_3.cjs.entry.js +0 -316
  86. package/dist/cjs/wm-tab-list.cjs.entry.js +0 -205
  87. package/dist/cjs/wm-tab-panel.cjs.entry.js +0 -42
  88. package/dist/cjs/wm-tag-input.cjs.entry.js +0 -513
  89. package/dist/cjs/wm-timepicker.cjs.entry.js +0 -386
  90. package/dist/cjs/wm-toggletip.cjs.entry.js +0 -128
  91. package/dist/cjs/wm-uploader.cjs.entry.js +0 -342
  92. package/dist/cjs/wm-wrapper.cjs.entry.js +0 -21
  93. package/dist/collection/collection-manifest.json +0 -131
  94. package/dist/collection/components/wm-action-menu/wm-action-menu.css +0 -122
  95. package/dist/collection/components/wm-action-menu/wm-action-menu.js +0 -392
  96. package/dist/collection/components/wm-button/wm-button.css +0 -572
  97. package/dist/collection/components/wm-button/wm-button.js +0 -365
  98. package/dist/collection/components/wm-chart/priv-chart-popover/priv-chart-popover.css +0 -132
  99. package/dist/collection/components/wm-chart/priv-chart-popover/priv-chart-popover.js +0 -232
  100. package/dist/collection/components/wm-chart/wm-chart-slice.js +0 -64
  101. package/dist/collection/components/wm-chart/wm-chart.css +0 -337
  102. package/dist/collection/components/wm-chart/wm-chart.js +0 -710
  103. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.css +0 -365
  104. package/dist/collection/components/wm-datepicker/priv-datepicker/priv-datepicker.js +0 -1003
  105. package/dist/collection/components/wm-datepicker/wm-datepicker.css +0 -211
  106. package/dist/collection/components/wm-datepicker/wm-datepicker.js +0 -445
  107. package/dist/collection/components/wm-input/wm-input.css +0 -220
  108. package/dist/collection/components/wm-input/wm-input.js +0 -302
  109. package/dist/collection/components/wm-menuitem/wm-menuitem.css +0 -118
  110. package/dist/collection/components/wm-menuitem/wm-menuitem.js +0 -411
  111. package/dist/collection/components/wm-modal/wm-modal-footer.css +0 -84
  112. package/dist/collection/components/wm-modal/wm-modal-footer.js +0 -159
  113. package/dist/collection/components/wm-modal/wm-modal-header.css +0 -78
  114. package/dist/collection/components/wm-modal/wm-modal-header.js +0 -109
  115. package/dist/collection/components/wm-modal/wm-modal.css +0 -155
  116. package/dist/collection/components/wm-modal/wm-modal.js +0 -356
  117. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.css +0 -94
  118. package/dist/collection/components/wm-navigator/priv-navigator-button/priv-navigator-button.js +0 -97
  119. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.css +0 -67
  120. package/dist/collection/components/wm-navigator/priv-navigator-item/priv-navigator-item.js +0 -114
  121. package/dist/collection/components/wm-navigator/wm-navigator.css +0 -137
  122. package/dist/collection/components/wm-navigator/wm-navigator.js +0 -468
  123. package/dist/collection/components/wm-option/wm-option.css +0 -162
  124. package/dist/collection/components/wm-option/wm-option.js +0 -394
  125. package/dist/collection/components/wm-pagination/wm-pagination.css +0 -217
  126. package/dist/collection/components/wm-pagination/wm-pagination.js +0 -348
  127. package/dist/collection/components/wm-search/wm-search.css +0 -155
  128. package/dist/collection/components/wm-search/wm-search.js +0 -439
  129. package/dist/collection/components/wm-select/wm-select.css +0 -315
  130. package/dist/collection/components/wm-select/wm-select.js +0 -676
  131. package/dist/collection/components/wm-snackbar/wm-snackbar.css +0 -331
  132. package/dist/collection/components/wm-snackbar/wm-snackbar.js +0 -240
  133. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.css +0 -104
  134. package/dist/collection/components/wm-tabs/wm-tab-item/wm-tab-item.js +0 -202
  135. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.css +0 -73
  136. package/dist/collection/components/wm-tabs/wm-tab-list/wm-tab-list.js +0 -315
  137. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.css +0 -57
  138. package/dist/collection/components/wm-tabs/wm-tab-panel/wm-tab-panel.js +0 -104
  139. package/dist/collection/components/wm-tag-input/wm-tag-input.css +0 -408
  140. package/dist/collection/components/wm-tag-input/wm-tag-input.js +0 -707
  141. package/dist/collection/components/wm-timepicker/wm-timepicker.css +0 -370
  142. package/dist/collection/components/wm-timepicker/wm-timepicker.js +0 -567
  143. package/dist/collection/components/wm-toggletip/wm-toggletip.css +0 -350
  144. package/dist/collection/components/wm-toggletip/wm-toggletip.js +0 -217
  145. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.css +0 -642
  146. package/dist/collection/components/wm-uploader/wm-network-uploader/wm-network-uploader.js +0 -753
  147. package/dist/collection/components/wm-uploader/wm-uploader.css +0 -666
  148. package/dist/collection/components/wm-uploader/wm-uploader.js +0 -673
  149. package/dist/collection/components/wm-wrapper/wm-wrapper.js +0 -27
  150. package/dist/collection/dev/scripts.js +0 -20
  151. package/dist/collection/global/__mocks__/functions.js +0 -5
  152. package/dist/collection/global/functions.js +0 -420
  153. package/dist/collection/global/global.js +0 -39
  154. package/dist/collection/global/interfaces.js +0 -49
  155. package/dist/collection/global/services/__mocks__/http-service.js +0 -130
  156. package/dist/collection/global/services/http-service.js +0 -50
  157. package/dist/collection/lang/lang.js +0 -5
  158. package/dist/collection/lang/piglatin.js +0 -93
  159. package/dist/componentlibrary/app-globals-18876ad3.js +0 -45
  160. package/dist/componentlibrary/app-globals-307a1083.js +0 -108
  161. package/dist/componentlibrary/componentlibrary.esm.js +0 -1
  162. package/dist/componentlibrary/index-d5997567.js +0 -2938
  163. package/dist/componentlibrary/index.esm.js +0 -0
  164. package/dist/componentlibrary/p-01bdfed8.js +0 -16
  165. package/dist/componentlibrary/p-0ca70ed4.entry.js +0 -1
  166. package/dist/componentlibrary/p-126bde92.entry.js +0 -1
  167. package/dist/componentlibrary/p-12a67d93.entry.js +0 -1
  168. package/dist/componentlibrary/p-188deaf5.entry.js +0 -1
  169. package/dist/componentlibrary/p-2514df6f.entry.js +0 -1
  170. package/dist/componentlibrary/p-269b8a5f.entry.js +0 -1
  171. package/dist/componentlibrary/p-35e57079.entry.js +0 -1
  172. package/dist/componentlibrary/p-414e20f7.entry.js +0 -1
  173. package/dist/componentlibrary/p-43f1298b.js +0 -1
  174. package/dist/componentlibrary/p-4d387ec6.entry.js +0 -1
  175. package/dist/componentlibrary/p-59ba81d6.entry.js +0 -1
  176. package/dist/componentlibrary/p-5e3cbec8.entry.js +0 -1
  177. package/dist/componentlibrary/p-5e81e830.entry.js +0 -1
  178. package/dist/componentlibrary/p-64ff5040.js +0 -1
  179. package/dist/componentlibrary/p-68a871d3.entry.js +0 -1
  180. package/dist/componentlibrary/p-996a7395.entry.js +0 -1
  181. package/dist/componentlibrary/p-9b460452.entry.js +0 -1
  182. package/dist/componentlibrary/p-a416e410.entry.js +0 -1
  183. package/dist/componentlibrary/p-d550a94f.entry.js +0 -1
  184. package/dist/componentlibrary/p-e4735c23.entry.js +0 -1
  185. package/dist/componentlibrary/p-e725f388.entry.js +0 -1
  186. package/dist/componentlibrary/p-e9532ae5.entry.js +0 -1
  187. package/dist/componentlibrary/p-edf6f848.entry.js +0 -1
  188. package/dist/componentlibrary/p-fd8070fb.js +0 -1
  189. package/dist/componentlibrary/wm-action-menu.entry.js +0 -202
  190. package/dist/componentlibrary/wm-tab-item.entry.js +0 -78
  191. package/dist/esm/app-globals-307a1083.js +0 -108
  192. package/dist/esm/componentlibrary.js +0 -18
  193. package/dist/esm/css-shim-bbdf0cc6.js +0 -4
  194. package/dist/esm/dom-1f98a75f.js +0 -73
  195. package/dist/esm/functions-316c1b23.js +0 -8340
  196. package/dist/esm/functions-60034bf7.js +0 -6109
  197. package/dist/esm/global-430cb201.js +0 -36
  198. package/dist/esm/http-service-3dc3b3e7.js +0 -52
  199. package/dist/esm/http-service-5d037e16.js +0 -52
  200. package/dist/esm/index.js +0 -1
  201. package/dist/esm/interfaces-2b97fab2.js +0 -32
  202. package/dist/esm/interfaces-50753346.js +0 -51
  203. package/dist/esm/loader.js +0 -18
  204. package/dist/esm/polyfills/core-js.js +0 -11
  205. package/dist/esm/polyfills/css-shim.js +0 -1
  206. package/dist/esm/polyfills/dom.js +0 -79
  207. package/dist/esm/polyfills/es5-html-element.js +0 -1
  208. package/dist/esm/polyfills/index.js +0 -34
  209. package/dist/esm/polyfills/system.js +0 -6
  210. package/dist/esm/priv-chart-popover.entry.js +0 -85
  211. package/dist/esm/priv-datepicker.entry.js +0 -668
  212. package/dist/esm/priv-navigator-button.entry.js +0 -25
  213. package/dist/esm/priv-navigator-item.entry.js +0 -30
  214. package/dist/esm/shadow-css-67b66845.js +0 -389
  215. package/dist/esm/wm-action-menu_2.entry.js +0 -313
  216. package/dist/esm/wm-button.entry.js +0 -148
  217. package/dist/esm/wm-chart-slice.entry.js +0 -18
  218. package/dist/esm/wm-chart.entry.js +0 -504
  219. package/dist/esm/wm-datepicker.entry.js +0 -258
  220. package/dist/esm/wm-input.entry.js +0 -106
  221. package/dist/esm/wm-menuitem.entry.js +0 -114
  222. package/dist/esm/wm-modal-footer.entry.js +0 -39
  223. package/dist/esm/wm-modal-header.entry.js +0 -41
  224. package/dist/esm/wm-modal.entry.js +0 -145
  225. package/dist/esm/wm-navigator.entry.js +0 -275
  226. package/dist/esm/wm-network-uploader.entry.js +0 -427
  227. package/dist/esm/wm-option.entry.js +0 -119
  228. package/dist/esm/wm-option_2.entry.js +0 -478
  229. package/dist/esm/wm-pagination.entry.js +0 -172
  230. package/dist/esm/wm-search.entry.js +0 -227
  231. package/dist/esm/wm-select.entry.js +0 -362
  232. package/dist/esm/wm-snackbar.entry.js +0 -156
  233. package/dist/esm/wm-tab-item_3.entry.js +0 -310
  234. package/dist/esm/wm-tab-list.entry.js +0 -201
  235. package/dist/esm/wm-tab-panel.entry.js +0 -38
  236. package/dist/esm/wm-tag-input.entry.js +0 -509
  237. package/dist/esm/wm-timepicker.entry.js +0 -382
  238. package/dist/esm/wm-toggletip.entry.js +0 -124
  239. package/dist/esm/wm-uploader.entry.js +0 -338
  240. package/dist/esm/wm-wrapper.entry.js +0 -17
  241. package/dist/index.cjs.js +0 -1
  242. package/dist/index.js +0 -1
  243. package/dist/loader/cdn.js +0 -3
  244. package/dist/loader/index.cjs.js +0 -3
  245. package/dist/loader/index.d.ts +0 -13
  246. package/dist/loader/index.es2017.js +0 -3
  247. package/dist/loader/index.js +0 -4
  248. package/dist/loader/package.json +0 -10
  249. package/dist/types/components/wm-action-menu/wm-action-menu.d.ts +0 -43
  250. package/dist/types/components/wm-button/wm-button.d.ts +0 -36
  251. package/dist/types/components/wm-chart/priv-chart-popover/priv-chart-popover.d.ts +0 -23
  252. package/dist/types/components/wm-chart/wm-chart-slice.d.ts +0 -8
  253. package/dist/types/components/wm-chart/wm-chart.d.ts +0 -77
  254. package/dist/types/components/wm-datepicker/priv-datepicker/priv-datepicker.d.ts +0 -75
  255. package/dist/types/components/wm-datepicker/wm-datepicker.d.ts +0 -39
  256. package/dist/types/components/wm-input/wm-input.d.ts +0 -30
  257. package/dist/types/components/wm-menuitem/wm-menuitem.d.ts +0 -30
  258. package/dist/types/components/wm-modal/wm-modal-footer.d.ts +0 -15
  259. package/dist/types/components/wm-modal/wm-modal-header.d.ts +0 -12
  260. package/dist/types/components/wm-modal/wm-modal.d.ts +0 -34
  261. package/dist/types/components/wm-navigator/priv-navigator-button/priv-navigator-button.d.ts +0 -10
  262. package/dist/types/components/wm-navigator/priv-navigator-item/priv-navigator-item.d.ts +0 -13
  263. package/dist/types/components/wm-navigator/wm-navigator.d.ts +0 -61
  264. package/dist/types/components/wm-option/wm-option.d.ts +0 -28
  265. package/dist/types/components/wm-pagination/wm-pagination.d.ts +0 -31
  266. package/dist/types/components/wm-search/wm-search.d.ts +0 -78
  267. package/dist/types/components/wm-select/wm-select.d.ts +0 -63
  268. package/dist/types/components/wm-snackbar/wm-snackbar.d.ts +0 -32
  269. package/dist/types/components/wm-tabs/wm-tab-item/wm-tab-item.d.ts +0 -35
  270. package/dist/types/components/wm-tabs/wm-tab-list/wm-tab-list.d.ts +0 -50
  271. package/dist/types/components/wm-tabs/wm-tab-panel/wm-tab-panel.d.ts +0 -20
  272. package/dist/types/components/wm-timepicker/wm-timepicker.d.ts +0 -59
  273. package/dist/types/components/wm-toggletip/wm-toggletip.d.ts +0 -25
  274. package/dist/types/components/wm-uploader/wm-network-uploader/wm-network-uploader.d.ts +0 -85
  275. package/dist/types/components/wm-uploader/wm-uploader.d.ts +0 -75
  276. package/dist/types/components/wm-wrapper/wm-wrapper.d.ts +0 -7
  277. package/dist/types/global/__mocks__/functions.d.ts +0 -5
  278. package/dist/types/global/global.d.ts +0 -1
  279. package/dist/types/global/interfaces.d.ts +0 -33
  280. package/dist/types/global/services/__mocks__/http-service.d.ts +0 -6
  281. package/dist/types/global/services/http-service.d.ts +0 -4
  282. package/dist/types/lang/lang.d.ts +0 -5
@@ -1,567 +0,0 @@
1
- import { h, Component, Host, Element, Prop, Watch, State, Listen, Event } from "@stencil/core";
2
- import { intl, generateId, shouldOpenUp, isRelatedTarget } from "../../global/functions";
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");
40
- }
41
- else {
42
- this.moveDown(this.selectedOption);
43
- }
44
- break;
45
- case "ArrowUp":
46
- ev.preventDefault();
47
- if (this.isExpanded === false) {
48
- this.open("previous");
49
- }
50
- else {
51
- this.moveUp(this.selectedOption);
52
- }
53
- break;
54
- case "Enter":
55
- case " ":
56
- if (this.isExpanded) {
57
- ev.preventDefault();
58
- this.handleOptionClick(this.selectedOption.textContent);
59
- }
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();
66
- }
67
- break;
68
- case "Tab":
69
- if (this.isExpanded) {
70
- this.close();
71
- }
72
- break;
73
- case "Home":
74
- ev.preventDefault();
75
- if (this.isExpanded) {
76
- this.focusOption(this.optionsList[0]);
77
- this.setDropdownPosition("first");
78
- }
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");
85
- }
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;
144
- }
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":
305
- 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
- }]; }
567
- }