@ukic/canary-web-components 3.0.0-canary.32 → 3.0.0-canary.34

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 (414) hide show
  1. package/dist/cjs/core.cjs.js +1 -1
  2. package/dist/cjs/{helpers-6f4b406b.js → helpers-f81fed28.js} +37 -1
  3. package/dist/cjs/helpers-f81fed28.js.map +1 -0
  4. package/dist/cjs/ic-alert.cjs.entry.js +6 -2
  5. package/dist/cjs/ic-alert.cjs.entry.js.map +1 -1
  6. package/dist/cjs/ic-button_3.cjs.entry.js +28 -16
  7. package/dist/cjs/ic-button_3.cjs.entry.js.map +1 -1
  8. package/dist/cjs/ic-calendar_2.cjs.entry.js +2 -2
  9. package/dist/cjs/ic-calendar_2.cjs.entry.js.map +1 -1
  10. package/dist/cjs/ic-card-horizontal.cjs.entry.js +1 -1
  11. package/dist/cjs/ic-checkbox-group.cjs.entry.js +23 -2
  12. package/dist/cjs/ic-checkbox-group.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ic-checkbox_3.cjs.entry.js +11 -7
  14. package/dist/cjs/ic-checkbox_3.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ic-data-row.cjs.entry.js +1 -1
  16. package/dist/cjs/ic-data-row.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ic-data-table-title-bar.cjs.entry.js +1 -1
  18. package/dist/cjs/ic-data-table.cjs.entry.js +11 -8
  19. package/dist/cjs/ic-data-table.cjs.entry.js.map +1 -1
  20. package/dist/cjs/ic-date-picker.cjs.entry.js +1 -1
  21. package/dist/cjs/ic-input-component-container_4.cjs.entry.js +3 -4
  22. package/dist/cjs/ic-input-component-container_4.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ic-menu.cjs.entry.js +1 -1
  24. package/dist/cjs/ic-menu.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ic-pagination_4.cjs.entry.js +8 -4
  26. package/dist/cjs/ic-pagination_4.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ic-skeleton.cjs.entry.js +20 -5
  28. package/dist/cjs/ic-skeleton.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ic-step.cjs.entry.js +16 -14
  30. package/dist/cjs/ic-step.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ic-stepper.cjs.entry.js +24 -4
  32. package/dist/cjs/ic-stepper.cjs.entry.js.map +1 -1
  33. package/dist/cjs/ic-switch.cjs.entry.js +4 -4
  34. package/dist/cjs/ic-switch.cjs.entry.js.map +1 -1
  35. package/dist/cjs/ic-tab-context.cjs.entry.js +1 -1
  36. package/dist/cjs/ic-tab-context.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ic-tab-group.cjs.entry.js +2 -2
  38. package/dist/cjs/ic-tab-group.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ic-tab-panel.cjs.entry.js +2 -2
  40. package/dist/cjs/ic-tab-panel.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ic-table-of-contents.cjs.entry.js +1 -1
  42. package/dist/cjs/ic-theme.cjs.entry.js +1 -1
  43. package/dist/cjs/ic-theme.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ic-time-input.cjs.entry.js +402 -100
  45. package/dist/cjs/ic-time-input.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ic-time-selector.cjs.entry.js +722 -0
  47. package/dist/cjs/ic-time-selector.cjs.entry.js.map +1 -0
  48. package/dist/cjs/ic-toast-region.cjs.entry.js +1 -1
  49. package/dist/cjs/ic-toast-region.cjs.entry.js.map +1 -1
  50. package/dist/cjs/ic-toast.cjs.entry.js +5 -5
  51. package/dist/cjs/ic-toast.cjs.entry.js.map +1 -1
  52. package/dist/cjs/{ic-toggle-button.cjs.entry.js → ic-toggle-button_2.cjs.entry.js} +276 -3
  53. package/dist/cjs/ic-toggle-button_2.cjs.entry.js.map +1 -0
  54. package/dist/cjs/ic-tree-item.cjs.entry.js +3 -3
  55. package/dist/cjs/ic-tree-view.cjs.entry.js +4 -4
  56. package/dist/cjs/index-d337cd8a.js +8 -8
  57. package/dist/cjs/loader.cjs.js +1 -1
  58. package/dist/collection/collection-manifest.json +1 -0
  59. package/dist/collection/components/ic-calendar/ic-calendar.css +8 -6
  60. package/dist/collection/components/ic-calendar/ic-calendar.stories.js +13 -0
  61. package/dist/collection/components/ic-calendar/ic-calendar.stories.js.map +1 -1
  62. package/dist/collection/components/ic-data-table/ic-data-table.js +10 -7
  63. package/dist/collection/components/ic-data-table/ic-data-table.js.map +1 -1
  64. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js +30 -6
  65. package/dist/collection/components/ic-pagination-bar/ic-pagination-bar.js.map +1 -1
  66. package/dist/collection/components/ic-time-input/ic-time-input.css +21 -3
  67. package/dist/collection/components/ic-time-input/ic-time-input.js +436 -108
  68. package/dist/collection/components/ic-time-input/ic-time-input.js.map +1 -1
  69. package/dist/collection/components/ic-time-input/ic-time-input.stories.js +62 -13
  70. package/dist/collection/components/ic-time-input/ic-time-input.stories.js.map +1 -1
  71. package/dist/collection/components/ic-time-input/test/helpers/ic-time-input.js +2 -0
  72. package/dist/collection/components/ic-time-input/test/helpers/ic-time-input.js.map +1 -1
  73. package/dist/collection/components/ic-time-selector/ic-time-selector.css +293 -0
  74. package/dist/collection/components/ic-time-selector/ic-time-selector.js +928 -0
  75. package/dist/collection/components/ic-time-selector/ic-time-selector.js.map +1 -0
  76. package/dist/collection/components/ic-time-selector/ic-time-selector.stories.js +192 -0
  77. package/dist/collection/components/ic-time-selector/ic-time-selector.stories.js.map +1 -0
  78. package/dist/collection/components/ic-time-selector/ic-time-selector.types.js +2 -0
  79. package/dist/collection/components/ic-time-selector/ic-time-selector.types.js.map +1 -0
  80. package/dist/collection/components/ic-tree-item/ic-tree-item.js +2 -2
  81. package/dist/collection/components/ic-tree-view/ic-tree-view.js +3 -3
  82. package/dist/collection/utils/helpers.js +35 -0
  83. package/dist/collection/utils/helpers.js.map +1 -1
  84. package/dist/collection/utils/types.js.map +1 -1
  85. package/dist/components/helpers2.js +36 -1
  86. package/dist/components/helpers2.js.map +1 -1
  87. package/dist/components/ic-alert.js +7 -2
  88. package/dist/components/ic-alert.js.map +1 -1
  89. package/dist/components/ic-button2.js +4 -4
  90. package/dist/components/ic-button2.js.map +1 -1
  91. package/dist/components/ic-calendar2.js +1 -1
  92. package/dist/components/ic-calendar2.js.map +1 -1
  93. package/dist/components/ic-checkbox-group.js +24 -2
  94. package/dist/components/ic-checkbox-group.js.map +1 -1
  95. package/dist/components/ic-data-row.js +1 -1
  96. package/dist/components/ic-data-row.js.map +1 -1
  97. package/dist/components/ic-data-table.js +10 -7
  98. package/dist/components/ic-data-table.js.map +1 -1
  99. package/dist/components/ic-input-validation2.js +4 -5
  100. package/dist/components/ic-input-validation2.js.map +1 -1
  101. package/dist/components/ic-loading-indicator2.js +27 -13
  102. package/dist/components/ic-loading-indicator2.js.map +1 -1
  103. package/dist/components/ic-menu2.js +1 -1
  104. package/dist/components/ic-menu2.js.map +1 -1
  105. package/dist/components/ic-pagination-bar2.js +11 -6
  106. package/dist/components/ic-pagination-bar2.js.map +1 -1
  107. package/dist/components/ic-pagination2.js +9 -4
  108. package/dist/components/ic-pagination2.js.map +1 -1
  109. package/dist/components/ic-skeleton.js +23 -6
  110. package/dist/components/ic-skeleton.js.map +1 -1
  111. package/dist/components/ic-step.js +17 -15
  112. package/dist/components/ic-step.js.map +1 -1
  113. package/dist/components/ic-stepper.js +24 -4
  114. package/dist/components/ic-stepper.js.map +1 -1
  115. package/dist/components/ic-switch.js +4 -4
  116. package/dist/components/ic-switch.js.map +1 -1
  117. package/dist/components/ic-tab-context.js +1 -1
  118. package/dist/components/ic-tab-context.js.map +1 -1
  119. package/dist/components/ic-tab-group.js +2 -2
  120. package/dist/components/ic-tab-group.js.map +1 -1
  121. package/dist/components/ic-tab-panel.js +2 -2
  122. package/dist/components/ic-tab-panel.js.map +1 -1
  123. package/dist/components/ic-theme.js +1 -1
  124. package/dist/components/ic-theme.js.map +1 -1
  125. package/dist/components/ic-time-input.js +432 -113
  126. package/dist/components/ic-time-input.js.map +1 -1
  127. package/dist/components/ic-time-selector.d.ts +11 -0
  128. package/dist/components/ic-time-selector.js +776 -0
  129. package/dist/components/ic-time-selector.js.map +1 -0
  130. package/dist/components/ic-toast-region.js +1 -1
  131. package/dist/components/ic-toast-region.js.map +1 -1
  132. package/dist/components/ic-toast.js +5 -5
  133. package/dist/components/ic-toast.js.map +1 -1
  134. package/dist/components/ic-toggle-button-group.js +1 -299
  135. package/dist/components/ic-toggle-button-group.js.map +1 -1
  136. package/dist/{esm/ic-toggle-button-group.entry.js → components/ic-toggle-button-group2.js} +70 -13
  137. package/dist/components/ic-toggle-button-group2.js.map +1 -0
  138. package/dist/components/ic-toggle-button.js +1 -228
  139. package/dist/components/ic-toggle-button.js.map +1 -1
  140. package/dist/{esm/ic-toggle-button.entry.js → components/ic-toggle-button2.js} +67 -12
  141. package/dist/components/ic-toggle-button2.js.map +1 -0
  142. package/dist/components/ic-tree-item.js +2 -2
  143. package/dist/components/ic-tree-view.js +4 -4
  144. package/dist/core/core.css +28 -6
  145. package/dist/core/core.esm.js +1 -1
  146. package/dist/core/core.esm.js.map +1 -1
  147. package/dist/core/{p-b80b08ae.entry.js → p-08f24329.entry.js} +2 -2
  148. package/dist/core/{p-96177a74.entry.js → p-0bca234b.entry.js} +2 -2
  149. package/dist/core/{p-96177a74.entry.js.map → p-0bca234b.entry.js.map} +1 -1
  150. package/dist/core/{p-615d474e.entry.js → p-14b8bf37.entry.js} +2 -2
  151. package/dist/core/{p-81f12581.entry.js → p-169ad948.entry.js} +2 -2
  152. package/dist/core/{p-5254a078.entry.js → p-1be17f22.entry.js} +2 -2
  153. package/dist/core/{p-5254a078.entry.js.map → p-1be17f22.entry.js.map} +1 -1
  154. package/dist/core/{p-847cbb16.entry.js → p-1d166343.entry.js} +2 -2
  155. package/dist/core/{p-15c05eb8.entry.js → p-1dbefb37.entry.js} +2 -2
  156. package/dist/core/p-1dbefb37.entry.js.map +1 -0
  157. package/dist/core/{p-b4bfaf8f.entry.js → p-201b41c7.entry.js} +2 -2
  158. package/dist/core/{p-24bac55f.entry.js → p-33509a89.entry.js} +2 -2
  159. package/dist/core/{p-e1920777.entry.js → p-3389625c.entry.js} +2 -2
  160. package/dist/core/{p-5a1cfb3c.entry.js → p-344752cb.entry.js} +2 -2
  161. package/dist/core/{p-6c238418.entry.js → p-348d7080.entry.js} +2 -2
  162. package/dist/core/{p-3ef2e98d.entry.js → p-39cdf5db.entry.js} +2 -2
  163. package/dist/core/{p-775b8dba.entry.js → p-409d03b2.entry.js} +2 -2
  164. package/dist/core/{p-775b8dba.entry.js.map → p-409d03b2.entry.js.map} +1 -1
  165. package/dist/core/p-492991ad.entry.js +2 -0
  166. package/dist/core/p-492991ad.entry.js.map +1 -0
  167. package/dist/core/{p-fd20470e.entry.js → p-496b314f.entry.js} +2 -2
  168. package/dist/core/{p-bd9a76d8.entry.js → p-508b6da3.entry.js} +2 -2
  169. package/dist/core/p-53dad961.entry.js +2 -0
  170. package/dist/core/p-53dad961.entry.js.map +1 -0
  171. package/dist/core/p-551a0fc1.entry.js +2 -0
  172. package/dist/core/p-551a0fc1.entry.js.map +1 -0
  173. package/dist/core/{p-f5cea10d.entry.js → p-5e6687a8.entry.js} +2 -2
  174. package/dist/core/{p-72171192.entry.js → p-60f4fe3a.entry.js} +2 -2
  175. package/dist/core/p-61c92598.entry.js +2 -0
  176. package/dist/core/p-61c92598.entry.js.map +1 -0
  177. package/dist/core/p-691dd972.entry.js +2 -0
  178. package/dist/core/p-691dd972.entry.js.map +1 -0
  179. package/dist/core/{p-c6c87e58.entry.js → p-6dfe0922.entry.js} +2 -2
  180. package/dist/core/{p-fd7f3b58.entry.js → p-770e92cd.entry.js} +2 -2
  181. package/dist/core/{p-7cf6b428.entry.js → p-79ead0e7.entry.js} +2 -2
  182. package/dist/core/{p-285892ef.entry.js → p-7b4b45cf.entry.js} +2 -2
  183. package/dist/core/p-7c4d6b13.entry.js +2 -0
  184. package/dist/core/p-7c4d6b13.entry.js.map +1 -0
  185. package/dist/core/{p-af821831.entry.js → p-7d878ad7.entry.js} +2 -2
  186. package/dist/core/p-7d878ad7.entry.js.map +1 -0
  187. package/dist/core/{p-afedcfdb.entry.js → p-7efdbab8.entry.js} +2 -2
  188. package/dist/core/p-829b34f9.js +2 -0
  189. package/dist/core/p-829b34f9.js.map +1 -0
  190. package/dist/core/{p-9a9605c3.entry.js → p-879c180d.entry.js} +2 -2
  191. package/dist/core/{p-444cd8d3.entry.js → p-8ab37b4d.entry.js} +2 -2
  192. package/dist/core/{p-31f3fb15.entry.js → p-8d42a6e5.entry.js} +2 -2
  193. package/dist/core/{p-31f3fb15.entry.js.map → p-8d42a6e5.entry.js.map} +1 -1
  194. package/dist/core/{p-c87cc0d1.entry.js → p-939025af.entry.js} +2 -2
  195. package/dist/core/{p-5a4344cb.entry.js → p-9dea5764.entry.js} +2 -2
  196. package/dist/core/{p-ffc1cea6.entry.js → p-a58cf6fd.entry.js} +2 -2
  197. package/dist/core/p-a58cf6fd.entry.js.map +1 -0
  198. package/dist/core/{p-53740194.entry.js → p-a8310dfd.entry.js} +2 -2
  199. package/dist/core/p-a8310dfd.entry.js.map +1 -0
  200. package/dist/core/{p-90611726.entry.js → p-a8a92e54.entry.js} +2 -2
  201. package/dist/core/{p-2646a629.entry.js → p-b76fdade.entry.js} +2 -2
  202. package/dist/core/{p-2646a629.entry.js.map → p-b76fdade.entry.js.map} +1 -1
  203. package/dist/core/{p-04cb17d7.entry.js → p-b9459ba2.entry.js} +2 -2
  204. package/dist/core/{p-04cb17d7.entry.js.map → p-b9459ba2.entry.js.map} +1 -1
  205. package/dist/core/p-bb3db366.entry.js +2 -0
  206. package/dist/core/p-bb3db366.entry.js.map +1 -0
  207. package/dist/core/p-bc6e5d64.entry.js +2 -0
  208. package/dist/core/p-bc6e5d64.entry.js.map +1 -0
  209. package/dist/core/{p-2188b483.entry.js → p-c0a7eed7.entry.js} +2 -2
  210. package/dist/core/{p-2bd2f38b.entry.js → p-c0b227d2.entry.js} +2 -2
  211. package/dist/core/{p-7a0f62c2.entry.js → p-c4b2774d.entry.js} +2 -2
  212. package/dist/core/{p-7026afad.entry.js → p-ca05573a.entry.js} +2 -2
  213. package/dist/core/{p-8c580d88.entry.js → p-d0607a70.entry.js} +2 -2
  214. package/dist/core/{p-adde6c66.entry.js → p-d376858f.entry.js} +2 -2
  215. package/dist/core/{p-adde6c66.entry.js.map → p-d376858f.entry.js.map} +1 -1
  216. package/dist/core/{p-e00e67ff.entry.js → p-dbd9a403.entry.js} +2 -2
  217. package/dist/core/{p-e00e67ff.entry.js.map → p-dbd9a403.entry.js.map} +1 -1
  218. package/dist/core/p-df064c8b.entry.js +2 -0
  219. package/dist/core/p-df064c8b.entry.js.map +1 -0
  220. package/dist/core/{p-e4ef4263.js → p-e519f607.js} +2 -2
  221. package/dist/core/{p-3f0bce15.entry.js → p-e5c6d01a.entry.js} +2 -2
  222. package/dist/core/{p-04a9f82f.entry.js → p-e8db8772.entry.js} +2 -2
  223. package/dist/core/{p-e4b82731.entry.js → p-ea04103e.entry.js} +2 -2
  224. package/dist/core/p-eac60693.entry.js +2 -0
  225. package/dist/core/p-eac60693.entry.js.map +1 -0
  226. package/dist/core/{p-8e592393.entry.js → p-ecc7fd71.entry.js} +2 -2
  227. package/dist/core/{p-6cfba272.entry.js → p-efe260f0.entry.js} +2 -2
  228. package/dist/core/{p-b6d6b26e.entry.js → p-f1b57f91.entry.js} +2 -2
  229. package/dist/core/{p-e4551a38.entry.js → p-f5dc04f7.entry.js} +2 -2
  230. package/dist/core/{p-25280383.entry.js → p-fb07921b.entry.js} +2 -2
  231. package/dist/core/p-fb07921b.entry.js.map +1 -0
  232. package/dist/core/{p-1900c7c7.entry.js → p-fd08156a.entry.js} +2 -2
  233. package/dist/core/{p-3594922d.entry.js → p-fe5b51bb.entry.js} +2 -2
  234. package/dist/core/{p-ef5b6622.entry.js → p-ff618439.entry.js} +2 -2
  235. package/dist/esm/core.js +1 -1
  236. package/dist/esm/{helpers-5419eb6c.js → helpers-063369f4.js} +2 -2
  237. package/dist/esm/{helpers-5419eb6c.js.map → helpers-063369f4.js.map} +1 -1
  238. package/dist/esm/{helpers-9f228880.js → helpers-a08b3f32.js} +37 -2
  239. package/dist/esm/helpers-a08b3f32.js.map +1 -0
  240. package/dist/esm/ic-accordion-group.entry.js +1 -1
  241. package/dist/esm/ic-accordion.entry.js +1 -1
  242. package/dist/esm/ic-action-chip.entry.js +1 -1
  243. package/dist/esm/ic-alert.entry.js +7 -3
  244. package/dist/esm/ic-alert.entry.js.map +1 -1
  245. package/dist/esm/ic-back-to-top.entry.js +1 -1
  246. package/dist/esm/ic-badge.entry.js +1 -1
  247. package/dist/esm/ic-breadcrumb-group.entry.js +1 -1
  248. package/dist/esm/ic-breadcrumb.entry.js +1 -1
  249. package/dist/esm/ic-button_3.entry.js +29 -17
  250. package/dist/esm/ic-button_3.entry.js.map +1 -1
  251. package/dist/esm/ic-calendar_2.entry.js +2 -2
  252. package/dist/esm/ic-calendar_2.entry.js.map +1 -1
  253. package/dist/esm/ic-card-horizontal.entry.js +1 -1
  254. package/dist/esm/ic-card-vertical.entry.js +1 -1
  255. package/dist/esm/ic-checkbox-group.entry.js +24 -3
  256. package/dist/esm/ic-checkbox-group.entry.js.map +1 -1
  257. package/dist/esm/ic-checkbox_3.entry.js +12 -8
  258. package/dist/esm/ic-checkbox_3.entry.js.map +1 -1
  259. package/dist/esm/ic-chip.entry.js +1 -1
  260. package/dist/esm/ic-data-row.entry.js +2 -2
  261. package/dist/esm/ic-data-row.entry.js.map +1 -1
  262. package/dist/esm/ic-data-table-title-bar.entry.js +1 -1
  263. package/dist/esm/ic-data-table.entry.js +11 -8
  264. package/dist/esm/ic-data-table.entry.js.map +1 -1
  265. package/dist/esm/ic-date-picker.entry.js +1 -1
  266. package/dist/esm/ic-dialog.entry.js +1 -1
  267. package/dist/esm/ic-divider.entry.js +1 -1
  268. package/dist/esm/ic-footer-link-group.entry.js +1 -1
  269. package/dist/esm/ic-footer-link.entry.js +1 -1
  270. package/dist/esm/ic-footer.entry.js +1 -1
  271. package/dist/esm/ic-hero.entry.js +1 -1
  272. package/dist/esm/ic-horizontal-scroll.entry.js +1 -1
  273. package/dist/esm/ic-input-component-container_4.entry.js +4 -5
  274. package/dist/esm/ic-input-component-container_4.entry.js.map +1 -1
  275. package/dist/esm/ic-link.entry.js +1 -1
  276. package/dist/esm/ic-menu-group.entry.js +1 -1
  277. package/dist/esm/ic-menu-item.entry.js +1 -1
  278. package/dist/esm/ic-menu.entry.js +2 -2
  279. package/dist/esm/ic-menu.entry.js.map +1 -1
  280. package/dist/esm/ic-navigation-button.entry.js +1 -1
  281. package/dist/esm/ic-navigation-group.entry.js +1 -1
  282. package/dist/esm/ic-navigation-item.entry.js +1 -1
  283. package/dist/esm/ic-navigation-menu.entry.js +1 -1
  284. package/dist/esm/ic-page-header.entry.js +1 -1
  285. package/dist/esm/ic-pagination_4.entry.js +9 -5
  286. package/dist/esm/ic-pagination_4.entry.js.map +1 -1
  287. package/dist/esm/ic-popover-menu.entry.js +1 -1
  288. package/dist/esm/ic-radio-group.entry.js +1 -1
  289. package/dist/esm/ic-radio-option.entry.js +1 -1
  290. package/dist/esm/ic-search-bar.entry.js +1 -1
  291. package/dist/esm/ic-side-navigation.entry.js +1 -1
  292. package/dist/esm/ic-skeleton.entry.js +20 -5
  293. package/dist/esm/ic-skeleton.entry.js.map +1 -1
  294. package/dist/esm/ic-status-tag.entry.js +1 -1
  295. package/dist/esm/ic-step.entry.js +17 -15
  296. package/dist/esm/ic-step.entry.js.map +1 -1
  297. package/dist/esm/ic-stepper.entry.js +25 -5
  298. package/dist/esm/ic-stepper.entry.js.map +1 -1
  299. package/dist/esm/ic-switch.entry.js +5 -5
  300. package/dist/esm/ic-switch.entry.js.map +1 -1
  301. package/dist/esm/ic-tab-context.entry.js +1 -1
  302. package/dist/esm/ic-tab-context.entry.js.map +1 -1
  303. package/dist/esm/ic-tab-group.entry.js +3 -3
  304. package/dist/esm/ic-tab-group.entry.js.map +1 -1
  305. package/dist/esm/ic-tab-panel.entry.js +2 -2
  306. package/dist/esm/ic-tab-panel.entry.js.map +1 -1
  307. package/dist/esm/ic-tab.entry.js +1 -1
  308. package/dist/esm/ic-table-of-contents.entry.js +1 -1
  309. package/dist/esm/ic-theme.entry.js +2 -2
  310. package/dist/esm/ic-theme.entry.js.map +1 -1
  311. package/dist/esm/ic-time-input.entry.js +402 -100
  312. package/dist/esm/ic-time-input.entry.js.map +1 -1
  313. package/dist/esm/ic-time-selector.entry.js +718 -0
  314. package/dist/esm/ic-time-selector.entry.js.map +1 -0
  315. package/dist/esm/ic-toast-region.entry.js +1 -1
  316. package/dist/esm/ic-toast-region.entry.js.map +1 -1
  317. package/dist/esm/ic-toast.entry.js +6 -6
  318. package/dist/esm/ic-toast.entry.js.map +1 -1
  319. package/dist/esm/ic-toggle-button_2.entry.js +449 -0
  320. package/dist/esm/ic-toggle-button_2.entry.js.map +1 -0
  321. package/dist/esm/ic-top-navigation.entry.js +1 -1
  322. package/dist/esm/ic-tree-item.entry.js +3 -3
  323. package/dist/esm/ic-tree-view.entry.js +4 -4
  324. package/dist/esm/ic-typography.entry.js +1 -1
  325. package/dist/esm/index-a7a720e7.js +8 -8
  326. package/dist/esm/loader.js +1 -1
  327. package/dist/types/components/ic-calendar/ic-calendar.stories.d.ts +20 -14
  328. package/dist/types/components/ic-pagination-bar/ic-pagination-bar.d.ts +4 -0
  329. package/dist/types/components/ic-time-input/ic-time-input.d.ts +27 -7
  330. package/dist/types/components/ic-time-input/ic-time-input.stories.d.ts +31 -7
  331. package/dist/types/components/ic-time-input/test/helpers/ic-time-input.d.ts +1 -0
  332. package/dist/types/components/ic-time-selector/ic-time-selector.d.ts +80 -0
  333. package/dist/types/components/ic-time-selector/ic-time-selector.stories.d.ts +134 -0
  334. package/dist/types/components/ic-time-selector/ic-time-selector.types.d.ts +1 -0
  335. package/dist/types/components.d.ts +137 -11
  336. package/dist/types/utils/helpers.d.ts +14 -0
  337. package/dist/types/utils/types.d.ts +2 -2
  338. package/hydrate/index.js +1384 -201
  339. package/hydrate/index.mjs +1384 -201
  340. package/package.json +30 -30
  341. package/dist/cjs/helpers-6f4b406b.js.map +0 -1
  342. package/dist/cjs/ic-toggle-button-group.cjs.entry.js +0 -267
  343. package/dist/cjs/ic-toggle-button-group.cjs.entry.js.map +0 -1
  344. package/dist/cjs/ic-toggle-button.cjs.entry.js.map +0 -1
  345. package/dist/core/p-0043b019.entry.js +0 -2
  346. package/dist/core/p-0043b019.entry.js.map +0 -1
  347. package/dist/core/p-15c05eb8.entry.js.map +0 -1
  348. package/dist/core/p-25280383.entry.js.map +0 -1
  349. package/dist/core/p-2c86ce4b.entry.js +0 -2
  350. package/dist/core/p-2c86ce4b.entry.js.map +0 -1
  351. package/dist/core/p-3891ce53.entry.js +0 -2
  352. package/dist/core/p-3891ce53.entry.js.map +0 -1
  353. package/dist/core/p-4992e9ac.entry.js +0 -2
  354. package/dist/core/p-4992e9ac.entry.js.map +0 -1
  355. package/dist/core/p-53740194.entry.js.map +0 -1
  356. package/dist/core/p-5b32aaf3.entry.js +0 -2
  357. package/dist/core/p-5b32aaf3.entry.js.map +0 -1
  358. package/dist/core/p-80111272.entry.js +0 -2
  359. package/dist/core/p-80111272.entry.js.map +0 -1
  360. package/dist/core/p-9044539c.entry.js +0 -2
  361. package/dist/core/p-9044539c.entry.js.map +0 -1
  362. package/dist/core/p-9a95f428.entry.js +0 -2
  363. package/dist/core/p-9a95f428.entry.js.map +0 -1
  364. package/dist/core/p-af821831.entry.js.map +0 -1
  365. package/dist/core/p-ba75ed34.entry.js +0 -2
  366. package/dist/core/p-ba75ed34.entry.js.map +0 -1
  367. package/dist/core/p-c3eddb99.entry.js +0 -2
  368. package/dist/core/p-c3eddb99.entry.js.map +0 -1
  369. package/dist/core/p-f48ce5f6.js +0 -2
  370. package/dist/core/p-f48ce5f6.js.map +0 -1
  371. package/dist/core/p-ffc1cea6.entry.js.map +0 -1
  372. package/dist/esm/helpers-9f228880.js.map +0 -1
  373. package/dist/esm/ic-toggle-button-group.entry.js.map +0 -1
  374. package/dist/esm/ic-toggle-button.entry.js.map +0 -1
  375. /package/dist/core/{p-b80b08ae.entry.js.map → p-08f24329.entry.js.map} +0 -0
  376. /package/dist/core/{p-615d474e.entry.js.map → p-14b8bf37.entry.js.map} +0 -0
  377. /package/dist/core/{p-81f12581.entry.js.map → p-169ad948.entry.js.map} +0 -0
  378. /package/dist/core/{p-847cbb16.entry.js.map → p-1d166343.entry.js.map} +0 -0
  379. /package/dist/core/{p-b4bfaf8f.entry.js.map → p-201b41c7.entry.js.map} +0 -0
  380. /package/dist/core/{p-24bac55f.entry.js.map → p-33509a89.entry.js.map} +0 -0
  381. /package/dist/core/{p-e1920777.entry.js.map → p-3389625c.entry.js.map} +0 -0
  382. /package/dist/core/{p-5a1cfb3c.entry.js.map → p-344752cb.entry.js.map} +0 -0
  383. /package/dist/core/{p-6c238418.entry.js.map → p-348d7080.entry.js.map} +0 -0
  384. /package/dist/core/{p-3ef2e98d.entry.js.map → p-39cdf5db.entry.js.map} +0 -0
  385. /package/dist/core/{p-fd20470e.entry.js.map → p-496b314f.entry.js.map} +0 -0
  386. /package/dist/core/{p-bd9a76d8.entry.js.map → p-508b6da3.entry.js.map} +0 -0
  387. /package/dist/core/{p-f5cea10d.entry.js.map → p-5e6687a8.entry.js.map} +0 -0
  388. /package/dist/core/{p-72171192.entry.js.map → p-60f4fe3a.entry.js.map} +0 -0
  389. /package/dist/core/{p-c6c87e58.entry.js.map → p-6dfe0922.entry.js.map} +0 -0
  390. /package/dist/core/{p-fd7f3b58.entry.js.map → p-770e92cd.entry.js.map} +0 -0
  391. /package/dist/core/{p-7cf6b428.entry.js.map → p-79ead0e7.entry.js.map} +0 -0
  392. /package/dist/core/{p-285892ef.entry.js.map → p-7b4b45cf.entry.js.map} +0 -0
  393. /package/dist/core/{p-afedcfdb.entry.js.map → p-7efdbab8.entry.js.map} +0 -0
  394. /package/dist/core/{p-9a9605c3.entry.js.map → p-879c180d.entry.js.map} +0 -0
  395. /package/dist/core/{p-444cd8d3.entry.js.map → p-8ab37b4d.entry.js.map} +0 -0
  396. /package/dist/core/{p-c87cc0d1.entry.js.map → p-939025af.entry.js.map} +0 -0
  397. /package/dist/core/{p-5a4344cb.entry.js.map → p-9dea5764.entry.js.map} +0 -0
  398. /package/dist/core/{p-90611726.entry.js.map → p-a8a92e54.entry.js.map} +0 -0
  399. /package/dist/core/{p-2188b483.entry.js.map → p-c0a7eed7.entry.js.map} +0 -0
  400. /package/dist/core/{p-2bd2f38b.entry.js.map → p-c0b227d2.entry.js.map} +0 -0
  401. /package/dist/core/{p-7a0f62c2.entry.js.map → p-c4b2774d.entry.js.map} +0 -0
  402. /package/dist/core/{p-7026afad.entry.js.map → p-ca05573a.entry.js.map} +0 -0
  403. /package/dist/core/{p-8c580d88.entry.js.map → p-d0607a70.entry.js.map} +0 -0
  404. /package/dist/core/{p-e4ef4263.js.map → p-e519f607.js.map} +0 -0
  405. /package/dist/core/{p-3f0bce15.entry.js.map → p-e5c6d01a.entry.js.map} +0 -0
  406. /package/dist/core/{p-04a9f82f.entry.js.map → p-e8db8772.entry.js.map} +0 -0
  407. /package/dist/core/{p-e4b82731.entry.js.map → p-ea04103e.entry.js.map} +0 -0
  408. /package/dist/core/{p-8e592393.entry.js.map → p-ecc7fd71.entry.js.map} +0 -0
  409. /package/dist/core/{p-6cfba272.entry.js.map → p-efe260f0.entry.js.map} +0 -0
  410. /package/dist/core/{p-b6d6b26e.entry.js.map → p-f1b57f91.entry.js.map} +0 -0
  411. /package/dist/core/{p-e4551a38.entry.js.map → p-f5dc04f7.entry.js.map} +0 -0
  412. /package/dist/core/{p-1900c7c7.entry.js.map → p-fd08156a.entry.js.map} +0 -0
  413. /package/dist/core/{p-3594922d.entry.js.map → p-fe5b51bb.entry.js.map} +0 -0
  414. /package/dist/core/{p-ef5b6622.entry.js.map → p-ff618439.entry.js.map} +0 -0
@@ -0,0 +1,928 @@
1
+ import { h, Host, } from "@stencil/core";
2
+ import { parseTimeHelper } from "../../utils/helpers";
3
+ import Check from "../../assets/check-icon.svg";
4
+ import Clear from "../../assets/close-icon.svg";
5
+ const COLUMN_TYPES = ["hour", "minute", "period"];
6
+ const COLUMN_CLASS = ".ic-time-selector-column";
7
+ const ITEM_CLASS = ".ic-time-selector-item";
8
+ export class TimeSelector {
9
+ constructor() {
10
+ this.minutes = Array.from({ length: 60 }, (_, i) => i);
11
+ this.periods = ["AM", "PM"];
12
+ this.minTime = null;
13
+ this.maxTime = null;
14
+ this.ariaLiveMessage = "";
15
+ /**
16
+ * An array of objects with start and end values that will be disabled in the time selector. The times can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object.
17
+ */
18
+ this.disableTimes = [];
19
+ /**
20
+ * The earliest time that will be allowed. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object.
21
+ */
22
+ this.min = "";
23
+ /**
24
+ * The latest time that will be allowed. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object.
25
+ */
26
+ this.max = "";
27
+ /**
28
+ * The size of the time selector to be displayed.
29
+ */
30
+ this.size = "medium";
31
+ /**
32
+ * Sets the theme color to the dark or light theme color. "inherit" will set the color based on the system settings or ic-theme component.
33
+ */
34
+ this.theme = "inherit";
35
+ /**
36
+ * The time period format: "12" for 12-hour, "24" for 24-hour. Defaults to "24".
37
+ */
38
+ this.timePeriod = "24";
39
+ /**
40
+ * The value of the time selector. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object.
41
+ */
42
+ this.value = "";
43
+ this.setTimeParts = (hour, minute) => {
44
+ let period = "AM";
45
+ if (this.timePeriod === "12") {
46
+ if (hour === 0) {
47
+ hour = 12;
48
+ period = "AM";
49
+ }
50
+ else if (hour === 12) {
51
+ period = "PM";
52
+ }
53
+ else if (hour > 12) {
54
+ hour = hour - 12;
55
+ period = "PM";
56
+ }
57
+ else {
58
+ period = "AM";
59
+ }
60
+ this.selectedHour = hour;
61
+ this.selectedPeriod = period;
62
+ }
63
+ else {
64
+ this.selectedHour = hour;
65
+ }
66
+ this.selectedMinute = minute;
67
+ };
68
+ this.checkIfScrollIsFinished = (column, scrollTop) => {
69
+ const isScrollFinished = setInterval(() => {
70
+ if (column.scrollTop === scrollTop + 56) {
71
+ column === null || column === void 0 ? void 0 : column.focus();
72
+ clearInterval(isScrollFinished);
73
+ }
74
+ }, 25);
75
+ };
76
+ this.handleSelect = (type, value) => {
77
+ var _a;
78
+ const prevValue = this.getSelectedValue(type);
79
+ switch (type) {
80
+ case "hour":
81
+ this.selectedHour = Number(value);
82
+ break;
83
+ case "minute":
84
+ this.selectedMinute = Number(value);
85
+ break;
86
+ case "period":
87
+ this.selectedPeriod = value;
88
+ break;
89
+ }
90
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
91
+ const idx = COLUMN_TYPES.indexOf(type);
92
+ if (columns && columns[idx]) {
93
+ columns[idx].focus();
94
+ window.requestAnimationFrame(() => {
95
+ this.scrollSelectedItem(type);
96
+ });
97
+ }
98
+ if (prevValue === undefined || prevValue === null) {
99
+ this.announceSelectedColumn(type);
100
+ }
101
+ else {
102
+ this.lastAnnouncedType = type;
103
+ this.lastAnnouncedValue = this.getSelectedValue(type);
104
+ }
105
+ };
106
+ this.isTimeDisabled = (hour, minute, type) => {
107
+ var _a, _b;
108
+ for (const t of this.disableTimes) {
109
+ if (t && typeof t === "object" && "start" in t && "end" in t) {
110
+ const startParts = parseTimeHelper(t.start).parts;
111
+ const endParts = parseTimeHelper(t.end).parts;
112
+ if (startParts && endParts) {
113
+ const timeVal = hour * 3600 + minute * 60;
114
+ const startVal = startParts.hour * 3600 + startParts.minute * 60;
115
+ const endVal = endParts.hour * 3600 + endParts.minute * 60;
116
+ if (timeVal >= startVal && timeVal <= endVal) {
117
+ return true;
118
+ }
119
+ }
120
+ }
121
+ }
122
+ if (this.min) {
123
+ this.minTime = parseTimeHelper(this.min).date;
124
+ if (this.minTime) {
125
+ const minHour = this.minTime.getHours();
126
+ const minMinute = this.minTime.getMinutes();
127
+ if (type === "hour") {
128
+ const highlightedMinute = (_a = this.selectedMinute) !== null && _a !== void 0 ? _a : minMinute;
129
+ if (hour < minHour ||
130
+ (hour === minHour && highlightedMinute < minMinute) ||
131
+ (hour === minHour && highlightedMinute === minMinute)) {
132
+ return true;
133
+ }
134
+ }
135
+ else if (type === "minute") {
136
+ if (hour === minHour && minute < minMinute) {
137
+ return true;
138
+ }
139
+ }
140
+ else {
141
+ if (hour < minHour ||
142
+ (hour === minHour && minute < minMinute) ||
143
+ (hour === minHour && minute === minMinute)) {
144
+ return true;
145
+ }
146
+ }
147
+ }
148
+ }
149
+ if (this.max) {
150
+ this.maxTime = parseTimeHelper(this.max).date;
151
+ if (this.maxTime) {
152
+ const maxHour = this.maxTime.getHours();
153
+ const maxMinute = this.maxTime.getMinutes();
154
+ if (type === "hour") {
155
+ const selectedMinute = (_b = this.selectedMinute) !== null && _b !== void 0 ? _b : 59;
156
+ if (hour > maxHour ||
157
+ (hour === maxHour && selectedMinute > maxMinute) ||
158
+ (hour === maxHour && selectedMinute === maxMinute)) {
159
+ return true;
160
+ }
161
+ }
162
+ else if (type === "minute") {
163
+ if (hour === maxHour && minute > maxMinute) {
164
+ return true;
165
+ }
166
+ }
167
+ else {
168
+ if (hour > maxHour ||
169
+ (hour === maxHour && minute > maxMinute) ||
170
+ (hour === maxHour && minute === maxMinute)) {
171
+ return true;
172
+ }
173
+ }
174
+ }
175
+ }
176
+ return false;
177
+ };
178
+ this.handleColumnKeyDown = (type, event) => {
179
+ var _a, _b, _c, _d, _e, _f, _g;
180
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
181
+ const idx = COLUMN_TYPES.indexOf(type);
182
+ if (!columns)
183
+ return;
184
+ const values = this.getColumnValues(type);
185
+ const selected = this.getSelectedValue(type);
186
+ const col = columns[idx];
187
+ if (!col)
188
+ return;
189
+ const selectHighlighted = () => {
190
+ const highlighted = this.getHighlightedValue(type, col);
191
+ if (highlighted !== null) {
192
+ this.handleSelect(type, highlighted);
193
+ }
194
+ else if (values.length > 0) {
195
+ this.handleSelect(type, values[0]);
196
+ }
197
+ };
198
+ switch (event.key) {
199
+ case "Enter":
200
+ case " ":
201
+ event.preventDefault();
202
+ selectHighlighted();
203
+ return;
204
+ case "ArrowRight":
205
+ event.preventDefault();
206
+ selectHighlighted();
207
+ if (idx < columns.length - 1) {
208
+ (_b = columns[idx + 1]) === null || _b === void 0 ? void 0 : _b.focus();
209
+ }
210
+ return;
211
+ case "ArrowLeft":
212
+ event.preventDefault();
213
+ if (idx > 0)
214
+ (_c = columns[idx - 1]) === null || _c === void 0 ? void 0 : _c.focus();
215
+ return;
216
+ case "Tab":
217
+ if (event.shiftKey) {
218
+ if (idx === 0) {
219
+ return;
220
+ }
221
+ else {
222
+ event.preventDefault();
223
+ (_d = columns[idx - 1]) === null || _d === void 0 ? void 0 : _d.focus();
224
+ }
225
+ }
226
+ else {
227
+ event.preventDefault();
228
+ selectHighlighted();
229
+ this.announceSelectedColumn(type);
230
+ if (idx < columns.length - 1) {
231
+ (_e = columns[idx + 1]) === null || _e === void 0 ? void 0 : _e.focus();
232
+ }
233
+ else {
234
+ (_g = (_f = this.el.shadowRoot) === null || _f === void 0 ? void 0 : _f.querySelector(".ic-time-selector-clear-btn")) === null || _g === void 0 ? void 0 : _g.focus();
235
+ this.updateAriaLiveMessage();
236
+ }
237
+ }
238
+ return;
239
+ case "ArrowUp":
240
+ case "ArrowDown": {
241
+ let idxInValues = values.findIndex((v) => v === selected);
242
+ if (idxInValues === -1)
243
+ idxInValues = 0;
244
+ let newIdx = idxInValues;
245
+ const direction = event.key === "ArrowUp" ? -1 : 1;
246
+ const maxIdx = values.length - 1;
247
+ do {
248
+ newIdx += direction;
249
+ } while (newIdx >= 0 &&
250
+ newIdx <= maxIdx &&
251
+ (() => {
252
+ var _a, _b;
253
+ if (type === "hour" || type === "minute") {
254
+ const hour = type === "hour"
255
+ ? values[newIdx]
256
+ : (_a = this.selectedHour) !== null && _a !== void 0 ? _a : 0;
257
+ const minute = type === "minute"
258
+ ? values[newIdx]
259
+ : (_b = this.selectedMinute) !== null && _b !== void 0 ? _b : 0;
260
+ return this.isTimeDisabled(hour, minute);
261
+ }
262
+ return false;
263
+ })());
264
+ this.ariaLiveMessage = `Selected ${type}: ${values[newIdx]}`;
265
+ if (newIdx >= 0 && newIdx <= maxIdx && newIdx !== idxInValues) {
266
+ this.handleSelect(type, values[newIdx]);
267
+ }
268
+ return;
269
+ }
270
+ default:
271
+ return;
272
+ }
273
+ };
274
+ this.renderColumn = (type, values, selected) => {
275
+ const isTimeColumn = type === "hour" || type === "minute";
276
+ const isPeriodColumn = type === "period";
277
+ const headerLabel = this.getHeaderLabel(type);
278
+ const topSpacerCount = 2;
279
+ let bottomSpacerCount = 6;
280
+ if (this.size === "large") {
281
+ bottomSpacerCount = 5;
282
+ }
283
+ else if (this.size === "small") {
284
+ bottomSpacerCount = 8;
285
+ }
286
+ return (h("div", { class: "ic-time-selector-column-wrapper" }, isPeriodColumn ? (h("div", { class: "ic-time-selector-header-row" })) : (headerLabel && (h("div", { class: "ic-time-selector-header-row" }, h("ic-typography", { variant: "subtitle-small" }, headerLabel)))), h("div", { class: {
287
+ "ic-time-selector-column": true,
288
+ "ic-time-selector-column-period": isPeriodColumn,
289
+ }, tabIndex: 0, onKeyDown: (e) => this.handleColumnKeyDown(type, e) }, h("ul", { class: "ic-time-selector-list", role: "listbox", "aria-label": type }, this.renderScrollRows(topSpacerCount, `${type}-top-spacer`), values.map((val) => {
290
+ var _a, _b;
291
+ let disabled = false;
292
+ if (isTimeColumn) {
293
+ const hour = type === "hour" ? val : (_a = this.selectedHour) !== null && _a !== void 0 ? _a : 0;
294
+ const minute = type === "minute"
295
+ ? val
296
+ : (_b = this.selectedMinute) !== null && _b !== void 0 ? _b : 0;
297
+ disabled = this.isTimeDisabled(hour, minute, type);
298
+ }
299
+ return (h("li", { class: {
300
+ "ic-time-selector-item": true,
301
+ selected: val === selected,
302
+ disabled,
303
+ }, role: "option", "aria-selected": val === selected ? "true" : "false", "aria-disabled": disabled ? "true" : "false", onClick: () => !disabled && this.handleSelect(type, val), tabIndex: -1, key: `${type}-val-${val}` }, h("ic-typography", { variant: "subtitle-small" }, typeof val === "number"
304
+ ? val.toString().padStart(2, "0")
305
+ : val)));
306
+ }), (isTimeColumn || isPeriodColumn) &&
307
+ this.renderScrollRows(bottomSpacerCount, `${type}-bottom-spacer`)))));
308
+ };
309
+ this.handleClear = () => {
310
+ this.selectedHour = undefined;
311
+ this.scrollSelectedItem("hour", true);
312
+ this.selectedMinute = undefined;
313
+ this.scrollSelectedItem("minute", true);
314
+ this.selectedPeriod = undefined;
315
+ this.scrollSelectedItem("period", true);
316
+ this.lastAnnouncedType = undefined;
317
+ this.lastAnnouncedValue = undefined;
318
+ this.icChange.emit({
319
+ value: null,
320
+ timeString: null,
321
+ timeObject: {
322
+ hour: null,
323
+ minute: null,
324
+ period: undefined,
325
+ },
326
+ });
327
+ };
328
+ this.handleConfirmClick = () => {
329
+ const hour = this.selectedHour != null ? this.selectedHour : null;
330
+ const minute = this.selectedMinute != null ? this.selectedMinute : null;
331
+ const period = this.selectedPeriod;
332
+ const hourStr = hour != null ? hour.toString().padStart(2, "0") : null;
333
+ const minuteStr = minute != null ? minute.toString().padStart(2, "0") : null;
334
+ let allSelected = false;
335
+ allSelected = hour !== null && minute !== null;
336
+ let value = null;
337
+ let timeString = null;
338
+ if (allSelected) {
339
+ let date24hours = hour;
340
+ if (hour != null && period && this.timePeriod === "12") {
341
+ if (period === "PM" && hour < 12)
342
+ date24hours = hour + 12;
343
+ if (period === "AM" && hour === 12)
344
+ date24hours = 0;
345
+ }
346
+ value = new Date();
347
+ value.setHours(date24hours !== null && date24hours !== void 0 ? date24hours : 0);
348
+ value.setMinutes(minute !== null && minute !== void 0 ? minute : 0);
349
+ timeString = hourStr + ":" + minuteStr + (period ? " " + period : "");
350
+ this.value = value;
351
+ }
352
+ this.icChange.emit({
353
+ value: allSelected ? value : null,
354
+ timeString: allSelected ? timeString : null,
355
+ timeObject: Object.assign({ hour: hourStr, minute: minuteStr }, (period ? { period } : {})),
356
+ });
357
+ };
358
+ }
359
+ watchMinHandler() {
360
+ this.minTime = parseTimeHelper(this.min).date;
361
+ }
362
+ watchMaxHandler() {
363
+ this.maxTime = parseTimeHelper(this.max).date;
364
+ }
365
+ watchValueHandler() {
366
+ this.setTime(this.value);
367
+ setTimeout(() => {
368
+ this.scrollSelectedItem("hour");
369
+ this.scrollSelectedItem("minute");
370
+ if (this.timePeriod === "12") {
371
+ this.scrollSelectedItem("period");
372
+ }
373
+ }, 0);
374
+ }
375
+ componentWillLoad() {
376
+ this.setTime(this.value);
377
+ }
378
+ componentDidLoad() {
379
+ setTimeout(() => {
380
+ if (this.selectedHour !== undefined && this.selectedHour !== null) {
381
+ this.scrollSelectedItem("hour");
382
+ }
383
+ else if (this.min) {
384
+ this.scrollMinTime("hour");
385
+ }
386
+ if (this.selectedMinute !== undefined && this.selectedMinute !== null) {
387
+ this.scrollSelectedItem("minute");
388
+ }
389
+ else if (this.min) {
390
+ this.scrollMinTime("minute");
391
+ }
392
+ if (this.timePeriod === "12") {
393
+ if (this.selectedPeriod !== undefined && this.selectedPeriod !== null) {
394
+ this.scrollSelectedItem("period");
395
+ }
396
+ else if (this.min) {
397
+ this.scrollMinTime("period");
398
+ }
399
+ }
400
+ this.updateAriaLiveMessage();
401
+ }, 0);
402
+ }
403
+ getHeaderLabel(type) {
404
+ switch (type) {
405
+ case "hour":
406
+ return "HH";
407
+ case "minute":
408
+ return "MM";
409
+ default:
410
+ return "";
411
+ }
412
+ }
413
+ setTime(time) {
414
+ if (time === null || time === undefined || time === "") {
415
+ this.handleClear();
416
+ return;
417
+ }
418
+ if (typeof time === "string") {
419
+ const zuluMatch = time.match(/^([0-9]{2}):([0-9]{2}):([0-9]{2})(?:\.[0-9]{1,3})?Z?$/);
420
+ if (zuluMatch) {
421
+ this.setTimeParts(Number(zuluMatch[1]), Number(zuluMatch[2]));
422
+ }
423
+ else {
424
+ const parts = time.split(":");
425
+ this.setTimeParts(Number(parts[0]) || 0, Number(parts[1]) || 0);
426
+ }
427
+ }
428
+ else {
429
+ const { parts } = parseTimeHelper(time);
430
+ if (parts) {
431
+ this.setTimeParts(parts.hour, parts.minute);
432
+ }
433
+ }
434
+ }
435
+ renderScrollRows(count, keyPrefix = "scroll-row") {
436
+ return Array.from({ length: count }).map((_, i) => {
437
+ const isLast = keyPrefix.endsWith("bottom-spacer")
438
+ ? i === count - 1
439
+ : false;
440
+ return (h("li", { class: Object.assign({ "ic-time-selector-item": true, "ic-time-selector-scroll-row": true }, (isLast ? { "ic-time-selector-scroll-row-last": true } : {})), "aria-hidden": "true", tabIndex: -1, key: `${keyPrefix}-${i}` }));
441
+ });
442
+ }
443
+ scrollSelectedItem(colClass, clear) {
444
+ var _a;
445
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
446
+ let colIdx = COLUMN_TYPES.indexOf(colClass);
447
+ if (colClass === "period" && (columns === null || columns === void 0 ? void 0 : columns.length)) {
448
+ colIdx = columns.length - 1;
449
+ }
450
+ const col = columns === null || columns === void 0 ? void 0 : columns[colIdx];
451
+ if (col) {
452
+ const items = col.querySelectorAll(ITEM_CLASS);
453
+ let selectedIdx = -1;
454
+ items.forEach((item, idx) => {
455
+ if (item.classList.contains("selected"))
456
+ selectedIdx = idx;
457
+ });
458
+ if (clear) {
459
+ selectedIdx = 0;
460
+ }
461
+ if (selectedIdx > -1) {
462
+ const scrollRow = col.querySelector(".ic-time-selector-scroll-row");
463
+ let resolvedHeight = 0;
464
+ if (scrollRow) {
465
+ resolvedHeight = parseFloat(getComputedStyle(scrollRow).height);
466
+ }
467
+ const offset = resolvedHeight * 2;
468
+ const scrollTop = items[selectedIdx].offsetTop - offset;
469
+ const prefersReducedMotion = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
470
+ col.scrollTo({
471
+ top: scrollTop,
472
+ behavior: prefersReducedMotion ? "instant" : "smooth",
473
+ });
474
+ if (clear) {
475
+ setTimeout(() => {
476
+ var _a;
477
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
478
+ if (columns && columns.length > 0) {
479
+ this.checkIfScrollIsFinished(columns[0], scrollTop);
480
+ }
481
+ }, 300);
482
+ }
483
+ }
484
+ }
485
+ }
486
+ scrollMinTime(colClass) {
487
+ var _a;
488
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
489
+ const colIdx = COLUMN_TYPES.indexOf(colClass);
490
+ const col = columns === null || columns === void 0 ? void 0 : columns[colIdx];
491
+ if (!col)
492
+ return;
493
+ const items = col.querySelectorAll(ITEM_CLASS);
494
+ let minHour = 0, minMinute = 0;
495
+ if (this.minTime) {
496
+ minHour = this.minTime.getHours() + 2;
497
+ minMinute = this.minTime.getMinutes() + 2;
498
+ }
499
+ else if (this.min) {
500
+ const minDate = parseTimeHelper(this.min).date;
501
+ if (minDate) {
502
+ minHour = minDate.getHours();
503
+ minMinute = minDate.getMinutes();
504
+ }
505
+ }
506
+ let targetIdx = -1;
507
+ const values = this.getColumnValues(colClass);
508
+ if (colClass === "hour") {
509
+ targetIdx = values.findIndex((v) => v === minHour);
510
+ }
511
+ else if (colClass === "minute") {
512
+ targetIdx = values.findIndex((v) => v === minMinute);
513
+ }
514
+ else if (colClass === "period") {
515
+ let period = "AM";
516
+ if (this.timePeriod === "12") {
517
+ if (minHour === 0) {
518
+ period = "AM";
519
+ }
520
+ else if (minHour === 12) {
521
+ period = "PM";
522
+ }
523
+ else if (minHour > 12) {
524
+ period = "PM";
525
+ }
526
+ else {
527
+ period = "AM";
528
+ }
529
+ }
530
+ targetIdx = values.findIndex((v) => v === period);
531
+ }
532
+ if (targetIdx > -1) {
533
+ const scrollRow = col.querySelector(".ic-time-selector-scroll-row");
534
+ let resolvedHeight = 0;
535
+ if (scrollRow) {
536
+ resolvedHeight = parseFloat(getComputedStyle(scrollRow).height);
537
+ }
538
+ const offset = resolvedHeight * 2;
539
+ const scrollTop = items[targetIdx].offsetTop - offset;
540
+ const prefersReducedMotion = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
541
+ col.scrollTo({
542
+ top: scrollTop,
543
+ behavior: prefersReducedMotion ? "instant" : "smooth",
544
+ });
545
+ }
546
+ }
547
+ announceSelectedColumn(type) {
548
+ const value = this.getSelectedValue(type);
549
+ if (value !== null &&
550
+ value !== undefined &&
551
+ (type !== this.lastAnnouncedType || value !== this.lastAnnouncedValue)) {
552
+ this.ariaLiveMessage = `Selected ${type}: ${value}`;
553
+ }
554
+ else {
555
+ this.ariaLiveMessage = "";
556
+ }
557
+ this.lastAnnouncedType = type;
558
+ this.lastAnnouncedValue = value;
559
+ }
560
+ getColumnValues(type) {
561
+ if (type === "hour")
562
+ return this.timePeriod === "12"
563
+ ? Array.from({ length: 12 }, (_, i) => i + 1)
564
+ : Array.from({ length: 24 }, (_, i) => i);
565
+ if (type === "minute")
566
+ return this.minutes;
567
+ if (type === "period")
568
+ return this.periods;
569
+ return [];
570
+ }
571
+ getSelectedValue(type) {
572
+ var _a, _b, _c;
573
+ if (type === "hour")
574
+ return (_a = this.selectedHour) !== null && _a !== void 0 ? _a : null;
575
+ if (type === "minute")
576
+ return (_b = this.selectedMinute) !== null && _b !== void 0 ? _b : null;
577
+ if (type === "period")
578
+ return (_c = this.selectedPeriod) !== null && _c !== void 0 ? _c : null;
579
+ return null;
580
+ }
581
+ getHighlightedValue(type, col) {
582
+ var _a, _b, _c;
583
+ const items = Array.from(col.querySelectorAll(ITEM_CLASS));
584
+ const realItems = items.filter((item) => !item.classList.contains("ic-time-selector-scroll-row"));
585
+ if (realItems.length === 0)
586
+ return null;
587
+ const highlightTop = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(".ic-time-selector-highlight-top");
588
+ const highlightBottom = (_b = this.el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector(".ic-time-selector-highlight-bottom");
589
+ if (!highlightTop || !highlightBottom)
590
+ return null;
591
+ const topRect = highlightTop.getBoundingClientRect();
592
+ const bottomRect = highlightBottom.getBoundingClientRect();
593
+ const highlightStart = topRect.bottom;
594
+ const highlightEnd = bottomRect.top;
595
+ for (const item of realItems) {
596
+ const itemRect = item.getBoundingClientRect();
597
+ const itemCenter = itemRect.top + itemRect.height / 2;
598
+ if (itemCenter >= highlightStart && itemCenter <= highlightEnd) {
599
+ const key = item.getAttribute("key");
600
+ if (key) {
601
+ const valStr = key.replace(`${type}-val-`, "");
602
+ if (type === "hour" || type === "minute") {
603
+ return Number(valStr);
604
+ }
605
+ else {
606
+ return valStr;
607
+ }
608
+ }
609
+ const text = (_c = item.textContent) === null || _c === void 0 ? void 0 : _c.trim();
610
+ if (type === "hour" || type === "minute") {
611
+ return text ? Number(text) : null;
612
+ }
613
+ else {
614
+ return text;
615
+ }
616
+ }
617
+ }
618
+ return null;
619
+ }
620
+ updateAriaLiveMessage() {
621
+ const hourStr = this.selectedHour != null
622
+ ? this.selectedHour.toString().padStart(2, "0")
623
+ : null;
624
+ const minuteStr = this.selectedMinute != null
625
+ ? this.selectedMinute.toString().padStart(2, "0")
626
+ : null;
627
+ let timeString = "";
628
+ let allSelected = false;
629
+ allSelected = hourStr !== null && minuteStr !== null;
630
+ if (allSelected) {
631
+ timeString =
632
+ hourStr +
633
+ ":" +
634
+ minuteStr +
635
+ (this.selectedPeriod ? " " + this.selectedPeriod : "");
636
+ }
637
+ this.ariaLiveMessage =
638
+ allSelected && timeString ? `Selected time: ${timeString}` : "";
639
+ }
640
+ render() {
641
+ var _a, _b, _c;
642
+ const hours = this.timePeriod === "12"
643
+ ? Array.from({ length: 12 }, (_, i) => i + 1)
644
+ : Array.from({ length: 24 }, (_, i) => i);
645
+ const columns = [
646
+ this.renderColumn("hour", hours, (_a = this.selectedHour) !== null && _a !== void 0 ? _a : null),
647
+ this.renderColumn("minute", this.minutes, (_b = this.selectedMinute) !== null && _b !== void 0 ? _b : null),
648
+ ];
649
+ let colonSelectedStates = [];
650
+ colonSelectedStates = [
651
+ this.selectedHour !== undefined && this.selectedMinute !== undefined,
652
+ ];
653
+ const isInPicker = this.el.closest("ic-time-picker") !== null;
654
+ const { size, theme, timePeriod } = this;
655
+ return (h(Host, { key: 'af65b8999b8c677a6ef2e33fe167fb5b333f0571', class: {
656
+ [`ic-theme-${theme}`]: theme !== "inherit",
657
+ [`ic-time-selector-${size}`]: true,
658
+ } }, h("div", { key: 'c345308cda9bc9b1a6e20ad7b1969c8e1b173efa', role: isInPicker ? "dialog" : undefined, "aria-modal": isInPicker ? true : undefined, "aria-label": "Select time. Use arrow keys to navigate and select the options and then tab to move onto the next selection.", class: {
659
+ "ic-time-selector-dialog-container": true,
660
+ } }, h("div", { key: '85f4f862ec0a9263e491e45dc4cacac69854d5d6', class: "ic-time-selector-highlight-lines" }, h("div", { key: 'd5175185db4049b2660ec4b81971ac13b9b307cb', class: "ic-time-selector-header-border" }), h("div", { key: 'b1be244ff1cdd68b33dad814f501c4e5c8486318', class: {
661
+ "ic-time-selector-highlight": true,
662
+ "ic-time-selector-highlight-top": true,
663
+ } }), h("div", { key: 'ec20a6536aa67a4dbc96f29ef42d424a0342ebe8', class: "ic-time-selector-columns" }, columns.map((col, idx) => [
664
+ col,
665
+ idx < columns.length - 1 ? (h("ic-typography", { class: {
666
+ "ic-time-selector-colon": true,
667
+ "ic-time-selector-colon-selected": colonSelectedStates[idx],
668
+ }, variant: "subtitle-small", "aria-hidden": "true", key: `colon-${idx}` }, ":")) : null,
669
+ ]), timePeriod !== "24" &&
670
+ this.renderColumn("period", this.periods, (_c = this.selectedPeriod) !== null && _c !== void 0 ? _c : null)), h("div", { key: '72b1abb5e7f19bf853b208dca7365c57b397d9f6', class: {
671
+ "ic-time-selector-highlight": true,
672
+ "ic-time-selector-highlight-bottom": true,
673
+ } })), h("div", { key: '2b8125333fd8e8d119d3496cb690a9c3d3711cb7', class: "ic-time-selector-actions" }, h("ic-button", { key: '5cd3db3be7006940e8e8ed8c2e823c384e6a677c', variant: "icon-tertiary", "aria-label": "Clear time", class: {
674
+ "ic-time-selector-clear-btn": true,
675
+ }, onClick: this.handleClear, disabled: this.selectedHour === undefined &&
676
+ this.selectedMinute === undefined &&
677
+ this.selectedPeriod === undefined, size: size, tabIndex: 0, onKeyDown: (e) => {
678
+ var _a;
679
+ if (e.key === "Tab" && e.shiftKey) {
680
+ e.preventDefault();
681
+ const columns = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll(COLUMN_CLASS);
682
+ if (columns && columns.length > 0) {
683
+ const lastCol = columns[columns.length - 1];
684
+ lastCol === null || lastCol === void 0 ? void 0 : lastCol.focus();
685
+ }
686
+ }
687
+ } }, h("span", { key: '4c6383f537d199e7d282d0dc5f4d8eac30c86e47', "aria-hidden": "true", innerHTML: Clear })), h("ic-button", { key: '021b111b463ddb83d4449fb2c77cf27c972c04b7', variant: "icon-tertiary", "aria-label": "Select time", class: "ic-time-selector-check-btn", onClick: this.handleConfirmClick, disabled: this.selectedHour === undefined &&
688
+ this.selectedMinute === undefined &&
689
+ this.selectedPeriod === undefined, size: size, tabIndex: 0 }, h("span", { key: '95ba008a5b36459cba5d972dee1356f8c0194297', "aria-hidden": "true", innerHTML: Check })))), h("div", { key: '266f4b6084ff8530d3832eee59546af9419eb7a3', class: "sr-only", "aria-live": "polite" }, this.ariaLiveMessage)));
690
+ }
691
+ static get is() { return "ic-time-selector"; }
692
+ static get encapsulation() { return "shadow"; }
693
+ static get originalStyleUrls() {
694
+ return {
695
+ "$": ["ic-time-selector.css"]
696
+ };
697
+ }
698
+ static get styleUrls() {
699
+ return {
700
+ "$": ["ic-time-selector.css"]
701
+ };
702
+ }
703
+ static get properties() {
704
+ return {
705
+ "disableTimes": {
706
+ "type": "unknown",
707
+ "mutable": false,
708
+ "complexType": {
709
+ "original": "IcDisableTimeSelection[]",
710
+ "resolved": "IcDisableTimeSelection[]",
711
+ "references": {
712
+ "IcDisableTimeSelection": {
713
+ "location": "import",
714
+ "path": "../../utils/types",
715
+ "id": "src/utils/types.ts::IcDisableTimeSelection"
716
+ }
717
+ }
718
+ },
719
+ "required": false,
720
+ "optional": false,
721
+ "docs": {
722
+ "tags": [],
723
+ "text": "An array of objects with start and end values that will be disabled in the time selector. The times can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object."
724
+ },
725
+ "getter": false,
726
+ "setter": false,
727
+ "defaultValue": "[]"
728
+ },
729
+ "min": {
730
+ "type": "string",
731
+ "mutable": false,
732
+ "complexType": {
733
+ "original": "string | Date",
734
+ "resolved": "Date | string",
735
+ "references": {
736
+ "Date": {
737
+ "location": "global",
738
+ "id": "global::Date"
739
+ }
740
+ }
741
+ },
742
+ "required": false,
743
+ "optional": false,
744
+ "docs": {
745
+ "tags": [],
746
+ "text": "The earliest time that will be allowed. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object."
747
+ },
748
+ "getter": false,
749
+ "setter": false,
750
+ "attribute": "min",
751
+ "reflect": false,
752
+ "defaultValue": "\"\""
753
+ },
754
+ "max": {
755
+ "type": "string",
756
+ "mutable": false,
757
+ "complexType": {
758
+ "original": "string | Date",
759
+ "resolved": "Date | string",
760
+ "references": {
761
+ "Date": {
762
+ "location": "global",
763
+ "id": "global::Date"
764
+ }
765
+ }
766
+ },
767
+ "required": false,
768
+ "optional": false,
769
+ "docs": {
770
+ "tags": [],
771
+ "text": "The latest time that will be allowed. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object."
772
+ },
773
+ "getter": false,
774
+ "setter": false,
775
+ "attribute": "max",
776
+ "reflect": false,
777
+ "defaultValue": "\"\""
778
+ },
779
+ "size": {
780
+ "type": "string",
781
+ "mutable": false,
782
+ "complexType": {
783
+ "original": "IcSizes",
784
+ "resolved": "\"large\" | \"medium\" | \"small\"",
785
+ "references": {
786
+ "IcSizes": {
787
+ "location": "import",
788
+ "path": "../../utils/types",
789
+ "id": "src/utils/types.ts::IcSizes"
790
+ }
791
+ }
792
+ },
793
+ "required": false,
794
+ "optional": false,
795
+ "docs": {
796
+ "tags": [],
797
+ "text": "The size of the time selector to be displayed."
798
+ },
799
+ "getter": false,
800
+ "setter": false,
801
+ "attribute": "size",
802
+ "reflect": false,
803
+ "defaultValue": "\"medium\""
804
+ },
805
+ "theme": {
806
+ "type": "string",
807
+ "mutable": false,
808
+ "complexType": {
809
+ "original": "IcThemeMode",
810
+ "resolved": "\"dark\" | \"inherit\" | \"light\" | undefined",
811
+ "references": {
812
+ "IcThemeMode": {
813
+ "location": "import",
814
+ "path": "../../utils/types",
815
+ "id": "src/utils/types.ts::IcThemeMode"
816
+ }
817
+ }
818
+ },
819
+ "required": false,
820
+ "optional": true,
821
+ "docs": {
822
+ "tags": [],
823
+ "text": "Sets the theme color to the dark or light theme color. \"inherit\" will set the color based on the system settings or ic-theme component."
824
+ },
825
+ "getter": false,
826
+ "setter": false,
827
+ "attribute": "theme",
828
+ "reflect": false,
829
+ "defaultValue": "\"inherit\""
830
+ },
831
+ "timePeriod": {
832
+ "type": "string",
833
+ "mutable": false,
834
+ "complexType": {
835
+ "original": "\"12\" | \"24\"",
836
+ "resolved": "\"12\" | \"24\"",
837
+ "references": {}
838
+ },
839
+ "required": false,
840
+ "optional": false,
841
+ "docs": {
842
+ "tags": [],
843
+ "text": "The time period format: \"12\" for 12-hour, \"24\" for 24-hour. Defaults to \"24\"."
844
+ },
845
+ "getter": false,
846
+ "setter": false,
847
+ "attribute": "time-period",
848
+ "reflect": false,
849
+ "defaultValue": "\"24\""
850
+ },
851
+ "value": {
852
+ "type": "string",
853
+ "mutable": true,
854
+ "complexType": {
855
+ "original": "string | Date | null | undefined",
856
+ "resolved": "Date | null | string | undefined",
857
+ "references": {
858
+ "Date": {
859
+ "location": "global",
860
+ "id": "global::Date"
861
+ }
862
+ }
863
+ },
864
+ "required": false,
865
+ "optional": true,
866
+ "docs": {
867
+ "tags": [],
868
+ "text": "The value of the time selector. The value can be in any format supported as `timeFormat`, in ISO 8601 time string format (`HH:MM:SS`) or as a JavaScript `Date` object."
869
+ },
870
+ "getter": false,
871
+ "setter": false,
872
+ "attribute": "value",
873
+ "reflect": false,
874
+ "defaultValue": "\"\""
875
+ }
876
+ };
877
+ }
878
+ static get states() {
879
+ return {
880
+ "selectedHour": {},
881
+ "selectedMinute": {},
882
+ "selectedPeriod": {},
883
+ "ariaLiveMessage": {}
884
+ };
885
+ }
886
+ static get events() {
887
+ return [{
888
+ "method": "icChange",
889
+ "name": "icChange",
890
+ "bubbles": true,
891
+ "cancelable": true,
892
+ "composed": true,
893
+ "docs": {
894
+ "tags": [],
895
+ "text": "Emitted when the value has changed."
896
+ },
897
+ "complexType": {
898
+ "original": "{\n value: Date | null;\n timeString: string | null;\n timeObject: {\n hour: string | null;\n minute: string | null;\n period?: IcTimePeriods;\n };\n }",
899
+ "resolved": "{ value: Date | null; timeString: string | null; timeObject: { hour: string | null; minute: string | null; period?: IcTimePeriods | undefined; }; }",
900
+ "references": {
901
+ "Date": {
902
+ "location": "global",
903
+ "id": "global::Date"
904
+ },
905
+ "IcTimePeriods": {
906
+ "location": "import",
907
+ "path": "./ic-time-selector.types",
908
+ "id": "src/components/ic-time-selector/ic-time-selector.types.ts::IcTimePeriods"
909
+ }
910
+ }
911
+ }
912
+ }];
913
+ }
914
+ static get elementRef() { return "el"; }
915
+ static get watchers() {
916
+ return [{
917
+ "propName": "min",
918
+ "methodName": "watchMinHandler"
919
+ }, {
920
+ "propName": "max",
921
+ "methodName": "watchMaxHandler"
922
+ }, {
923
+ "propName": "value",
924
+ "methodName": "watchValueHandler"
925
+ }];
926
+ }
927
+ }
928
+ //# sourceMappingURL=ic-time-selector.js.map