@siemens/ix 4.4.0 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1195) hide show
  1. package/READMEOSS.html +24 -10
  2. package/components/index.js +1 -1
  3. package/components/ix-action-card.js +1 -1
  4. package/components/ix-application-header.js +1 -1
  5. package/components/ix-application-switch-modal.js +1 -1
  6. package/components/ix-application.js +1 -1
  7. package/components/ix-avatar.js +1 -1
  8. package/components/ix-blind.js +1 -1
  9. package/components/ix-breadcrumb-item.js +1 -1
  10. package/components/ix-breadcrumb.js +1 -1
  11. package/components/ix-button.js +1 -1
  12. package/components/ix-card-accordion.js +1 -1
  13. package/components/ix-card-content.js +1 -1
  14. package/components/ix-card-list.js +1 -1
  15. package/components/ix-card-title.js +1 -1
  16. package/components/ix-card.js +1 -1
  17. package/components/ix-category-filter.js +1 -1
  18. package/components/ix-checkbox-group.js +1 -1
  19. package/components/ix-checkbox.js +1 -1
  20. package/components/ix-chip.js +1 -1
  21. package/components/ix-col.js +1 -1
  22. package/components/ix-content-header.js +1 -1
  23. package/components/ix-content.js +1 -1
  24. package/components/ix-css-grid-item.js +1 -1
  25. package/components/ix-css-grid.js +1 -1
  26. package/components/ix-custom-field.js +1 -1
  27. package/components/ix-date-dropdown.js +1 -1
  28. package/components/ix-date-input.js +1 -1
  29. package/components/ix-date-picker.js +1 -1
  30. package/components/ix-date-time-card.js +1 -1
  31. package/components/{ix-validation-tooltip.d.ts → ix-datetime-input.d.ts} +4 -4
  32. package/components/ix-datetime-input.js +1 -0
  33. package/components/ix-datetime-picker.js +1 -1
  34. package/components/ix-divider.js +1 -1
  35. package/components/ix-dropdown-button.js +1 -1
  36. package/components/ix-dropdown-header.js +1 -1
  37. package/components/ix-dropdown-item.js +1 -1
  38. package/components/ix-dropdown-quick-actions.js +1 -1
  39. package/components/ix-dropdown.js +1 -1
  40. package/components/ix-empty-state.js +1 -1
  41. package/components/ix-event-list-item.js +1 -1
  42. package/components/ix-event-list.js +1 -1
  43. package/components/ix-expanding-search.js +1 -1
  44. package/components/ix-field-label.js +1 -1
  45. package/components/ix-field-wrapper.js +1 -1
  46. package/components/ix-filter-chip.js +1 -1
  47. package/components/ix-flip-tile-content.js +1 -1
  48. package/components/ix-flip-tile.js +1 -1
  49. package/components/ix-group-context-menu.js +1 -1
  50. package/components/ix-group-item.js +1 -1
  51. package/components/ix-group.js +1 -1
  52. package/components/ix-helper-text.js +1 -1
  53. package/components/ix-icon-button.js +1 -1
  54. package/components/ix-icon-toggle-button.js +1 -1
  55. package/components/ix-input.js +1 -1
  56. package/components/ix-key-value-list.js +1 -1
  57. package/components/ix-key-value.js +1 -1
  58. package/components/ix-kpi.js +1 -1
  59. package/components/ix-layout-auto.js +1 -1
  60. package/components/ix-layout-grid.js +1 -1
  61. package/components/ix-link-button.js +1 -1
  62. package/components/ix-menu-about-item.js +1 -1
  63. package/components/ix-menu-about-news.js +1 -1
  64. package/components/ix-menu-about.js +1 -1
  65. package/components/ix-menu-avatar-item.js +1 -1
  66. package/components/ix-menu-avatar.js +1 -1
  67. package/components/ix-menu-category.js +1 -1
  68. package/components/ix-menu-expand-icon.js +1 -1
  69. package/components/ix-menu-item.js +1 -1
  70. package/components/ix-menu-settings-item.js +1 -1
  71. package/components/ix-menu-settings.js +1 -1
  72. package/components/ix-menu.js +1 -1
  73. package/components/ix-message-bar.js +1 -1
  74. package/components/ix-modal-content.js +1 -1
  75. package/components/ix-modal-footer.js +1 -1
  76. package/components/ix-modal-header.js +1 -1
  77. package/components/ix-modal-loading.js +1 -1
  78. package/components/ix-modal.js +1 -1
  79. package/components/ix-number-input.js +1 -1
  80. package/components/ix-pagination.js +1 -1
  81. package/components/ix-pane-layout.js +1 -1
  82. package/components/ix-pane.js +1 -1
  83. package/components/ix-pill.js +1 -1
  84. package/components/ix-progress-indicator.js +1 -1
  85. package/components/ix-push-card.js +1 -1
  86. package/components/ix-radio-group.js +1 -1
  87. package/components/ix-radio.js +1 -1
  88. package/components/{ix-input-group.d.ts → ix-range-field.d.ts} +4 -4
  89. package/components/ix-range-field.js +1 -0
  90. package/components/ix-row.js +1 -1
  91. package/components/ix-select-item.js +1 -1
  92. package/components/ix-select.js +1 -1
  93. package/components/ix-slider.js +1 -1
  94. package/components/ix-spinner.js +1 -1
  95. package/components/ix-split-button.js +1 -1
  96. package/components/ix-tab-item.js +1 -1
  97. package/components/{ix-application-sidebar.d.ts → ix-tab-panel.d.ts} +4 -4
  98. package/components/ix-tab-panel.js +1 -0
  99. package/components/{ix-drawer.d.ts → ix-tab-set.d.ts} +4 -4
  100. package/components/ix-tab-set.js +1 -0
  101. package/components/ix-tabs.js +1 -1
  102. package/components/ix-textarea.js +1 -1
  103. package/components/ix-tile.js +1 -1
  104. package/components/ix-time-input.js +1 -1
  105. package/components/ix-time-picker.js +1 -1
  106. package/components/ix-toast-container.js +1 -1
  107. package/components/ix-toast.js +1 -1
  108. package/components/ix-toggle-button.js +1 -1
  109. package/components/ix-toggle.js +1 -1
  110. package/components/ix-tooltip.js +1 -1
  111. package/components/ix-tree-item.js +1 -1
  112. package/components/ix-tree.js +1 -1
  113. package/components/ix-typography.js +1 -1
  114. package/components/ix-upload.js +1 -1
  115. package/components/ix-workflow-step.js +1 -1
  116. package/components/ix-workflow-steps.js +1 -1
  117. package/components/p-4pTtJwcY.js +1 -0
  118. package/components/p-546lBshK.js +1 -0
  119. package/components/p-5jph302v.js +1 -0
  120. package/components/p-B1ZcjHve.js +1 -0
  121. package/components/{p-CRcg3Wl9.js → p-B1q6Xh9M.js} +1 -1
  122. package/components/p-B4Yxzuow.js +1 -0
  123. package/components/p-B5k8YVR0.js +1 -0
  124. package/components/p-B8RlWbEh.js +1 -0
  125. package/components/p-BE4QI9tD.js +1 -0
  126. package/components/p-BL9SR36X.js +1 -0
  127. package/components/p-BP8g-yqY.js +1 -0
  128. package/components/p-B_czElDE.js +1 -0
  129. package/components/p-BcxPyyrm.js +1 -0
  130. package/components/p-BooU9e46.js +1 -0
  131. package/components/p-Btv5ReUJ.js +1 -0
  132. package/components/p-BtvsjuLo.js +1 -0
  133. package/components/p-BwC_Hmai.js +1 -0
  134. package/components/p-Bxdy-8CE.js +1 -0
  135. package/components/p-Bxrgt3H_.js +1 -0
  136. package/components/p-By6x--zJ.js +1 -0
  137. package/components/p-Byed_Z2G.js +1 -0
  138. package/components/p-C-wf4kbs.js +1 -0
  139. package/components/p-C95SE6lT.js +1 -0
  140. package/components/p-C9HBQRMb.js +1 -0
  141. package/components/p-CDKHgTB8.js +1 -0
  142. package/components/p-CJ3dR7zd.js +1 -0
  143. package/components/p-CKYjdhXo.js +1 -0
  144. package/components/p-CQj_gEvY.js +1 -0
  145. package/components/p-CVmLf9WY.js +1 -0
  146. package/components/p-CWlPNXA-.js +1 -0
  147. package/components/p-CWshStHZ.js +1 -0
  148. package/components/p-CYgb41KQ.js +1 -0
  149. package/components/p-C_95k0nq.js +1 -0
  150. package/components/p-CcllZcv2.js +1 -0
  151. package/components/p-Cf71L4Ol.js +1 -0
  152. package/components/p-CgOv_MV_.js +1 -0
  153. package/components/p-CsP_r-y6.js +1 -0
  154. package/components/p-CuswfnZ5.js +1 -0
  155. package/components/p-D4RWuUBi.js +1 -0
  156. package/components/p-D4T7_gkf.js +1 -0
  157. package/components/p-D5gbubPJ.js +1 -0
  158. package/components/{p-DSTYytot.js → p-D5rshXh5.js} +1 -1
  159. package/components/p-D6Wm2E-0.js +1 -0
  160. package/components/p-D8Wb4thH.js +1 -0
  161. package/components/p-DN2Mr91y.js +1 -0
  162. package/components/p-DNIQ2C1K.js +1 -0
  163. package/components/p-DOCAISxs.js +1 -0
  164. package/components/p-DQql_9wo.js +1 -0
  165. package/components/p-DRw2l8Az.js +1 -0
  166. package/components/p-DSpVcflZ.js +1 -0
  167. package/components/p-DTcUamMt.js +1 -0
  168. package/components/p-DUkuP1OH.js +1 -0
  169. package/components/p-DdMuwGlF.js +1 -0
  170. package/components/p-DfnCSsMy.js +1 -0
  171. package/components/p-Djkc69iv.js +1 -0
  172. package/components/p-Dpk_WgCl.js +1 -0
  173. package/components/p-DuTDx0c-.js +1 -0
  174. package/components/p-Dx6rQdpk.js +1 -0
  175. package/components/p-Dx8kFukG.js +1 -0
  176. package/components/p-JXbYOM9q.js +1 -0
  177. package/components/p-JevOq-9X.js +1 -0
  178. package/components/p-MZOpritx.js +1 -0
  179. package/components/p-NLlCSNeG.js +1 -0
  180. package/components/p-VEcjhpT4.js +1 -0
  181. package/components/p-W0q0WVKl.js +1 -0
  182. package/components/p-XBJqkmoc.js +1 -0
  183. package/components/p-XBTykBKS.js +1 -0
  184. package/components/{p-BJxTLVYT.js → p-_Uc7YwjU.js} +1 -1
  185. package/components/p-qsIASuyM.js +1 -0
  186. package/components/p-uIG84RqI.js +1 -0
  187. package/components/p-wEbi9beJ.js +1 -0
  188. package/components/p-zs7a2E3b.js +1 -0
  189. package/components/package.json +1 -1
  190. package/dist/cjs/{a11y-DldCLr8D.js → a11y-C_6YiIMa.js} +1 -2
  191. package/dist/cjs/animation-hxDbANsw.js +81 -0
  192. package/dist/cjs/app-globals-V2Kpy_OQ.js +5 -0
  193. package/dist/cjs/aria-activedescendant.mixin-_lb0Xz2S.js +85 -0
  194. package/dist/cjs/{base-button-BvWcXXIH.js → base-button-C-1izOSS.js} +14 -10
  195. package/dist/cjs/{base-icon-button-DgnV_-qM.js → base-icon-button-BeXf6v9s.js} +3 -3
  196. package/dist/cjs/component-CYtonfpw.js +143 -0
  197. package/dist/cjs/{context-CmNuiaNz.js → context-DqdXbKw_.js} +5 -2
  198. package/dist/cjs/{dropdown-controller-BLOjtc6w.js → dropdown-controller-DeBeUVhj.js} +12 -9
  199. package/dist/cjs/{floating-ui.dom-CMzYsRR7.js → find-element-DPxOAdgO.js} +101 -0
  200. package/dist/cjs/focus-proxy-BCuVbpDb.js +48 -0
  201. package/dist/cjs/focus-trap-_cyPFvFq.js +106 -0
  202. package/dist/cjs/focus-utilities-yx7wWjEO.js +119 -0
  203. package/dist/cjs/focus-visible.mixin-BU5Ql7d1.js +42 -0
  204. package/dist/cjs/{helper-text-util-CX9jWl8m.js → helper-text-util-CvfY1JxE.js} +26 -8
  205. package/dist/cjs/id.mixin-DINDQztK.js +21 -0
  206. package/dist/cjs/index-B4J4JK0P.js +17 -0
  207. package/dist/cjs/{index-Dxeom0qd.js → index-BKQkUbyE.js} +529 -126
  208. package/dist/cjs/{index-DIYO-Liy.js → index-Dw-NwUuT.js} +2 -4
  209. package/dist/cjs/{index-BxmN3RtX.js → index-SVeYVn-h.js} +1 -2
  210. package/dist/cjs/index.cjs.js +266 -47
  211. package/dist/cjs/inherit-aria-attributes.mixin-Sl7J-OlO.js +36 -0
  212. package/dist/cjs/{picker-input.util-DJNAVluZ.js → input-picker.mixin-EoIayQV9.js} +25 -1
  213. package/dist/cjs/{input.fc-BIQRswZt.js → input.fc-CsACCdp7.js} +15 -17
  214. package/dist/cjs/ix-action-card.cjs.entry.js +39 -19
  215. package/dist/cjs/ix-application-header.cjs.entry.js +126 -69
  216. package/dist/cjs/ix-application-switch-modal.cjs.entry.js +9 -13
  217. package/dist/cjs/ix-application.cjs.entry.js +46 -34
  218. package/dist/cjs/ix-avatar_2.cjs.entry.js +126 -22
  219. package/dist/cjs/ix-blind.cjs.entry.js +37 -23
  220. package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +234 -43
  221. package/dist/cjs/ix-breadcrumb.cjs.entry.js +85 -68
  222. package/dist/cjs/ix-button.cjs.entry.js +227 -40
  223. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +30 -19
  224. package/dist/cjs/ix-card-list.cjs.entry.js +104 -54
  225. package/dist/cjs/ix-card_2.cjs.entry.js +17 -17
  226. package/dist/cjs/ix-category-filter.cjs.entry.js +180 -111
  227. package/dist/cjs/ix-checkbox-group.cjs.entry.js +52 -27
  228. package/dist/cjs/ix-checkbox.cjs.entry.js +58 -37
  229. package/dist/cjs/ix-chip.cjs.entry.js +317 -81
  230. package/dist/cjs/ix-col_4.cjs.entry.js +1109 -495
  231. package/dist/cjs/ix-content-header.cjs.entry.js +25 -17
  232. package/dist/cjs/ix-content.cjs.entry.js +7 -7
  233. package/dist/cjs/ix-css-grid-item.cjs.entry.js +6 -2
  234. package/dist/cjs/ix-css-grid.cjs.entry.js +13 -5
  235. package/dist/cjs/ix-custom-field.cjs.entry.js +41 -12
  236. package/dist/cjs/ix-date-dropdown.cjs.entry.js +170 -145
  237. package/dist/cjs/ix-date-input.cjs.entry.js +212 -125
  238. package/dist/cjs/ix-date-picker.cjs.entry.js +752 -0
  239. package/dist/cjs/ix-date-time-card.cjs.entry.js +25 -18
  240. package/dist/cjs/ix-datetime-input.cjs.entry.js +548 -0
  241. package/dist/cjs/ix-datetime-picker.cjs.entry.js +242 -58
  242. package/dist/cjs/ix-divider.cjs.entry.js +2 -2
  243. package/dist/cjs/ix-dropdown-button.cjs.entry.js +155 -38
  244. package/dist/cjs/ix-dropdown-header.cjs.entry.js +6 -2
  245. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +2 -2
  246. package/dist/cjs/ix-dropdown_2.cjs.entry.js +992 -0
  247. package/dist/cjs/ix-empty-state.cjs.entry.js +32 -6
  248. package/dist/cjs/ix-event-list-item.cjs.entry.js +38 -27
  249. package/dist/cjs/ix-event-list.cjs.entry.js +26 -26
  250. package/dist/cjs/ix-expanding-search.cjs.entry.js +58 -44
  251. package/dist/cjs/ix-field-label_2.cjs.entry.js +178 -56
  252. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +85 -37
  253. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +8 -8
  254. package/dist/cjs/ix-flip-tile.cjs.entry.js +43 -30
  255. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +51 -27
  256. package/dist/cjs/ix-group.cjs.entry.js +63 -40
  257. package/dist/cjs/ix-helper-text.cjs.entry.js +43 -16
  258. package/dist/cjs/ix-icon-button_2.cjs.entry.js +232 -52
  259. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +221 -45
  260. package/dist/cjs/ix-input.cjs.entry.js +128 -56
  261. package/dist/cjs/ix-key-value-list.cjs.entry.js +6 -6
  262. package/dist/cjs/ix-key-value.cjs.entry.js +24 -6
  263. package/dist/cjs/ix-kpi.cjs.entry.js +37 -13
  264. package/dist/cjs/ix-layout-auto.cjs.entry.js +15 -15
  265. package/dist/cjs/ix-link-button.cjs.entry.js +19 -15
  266. package/dist/cjs/ix-menu-about-item.cjs.entry.js +13 -6
  267. package/dist/cjs/ix-menu-about-news.cjs.entry.js +45 -18
  268. package/dist/cjs/ix-menu-about.cjs.entry.js +72 -28
  269. package/dist/cjs/ix-menu-avatar.cjs.entry.js +62 -31
  270. package/dist/cjs/ix-menu-category.cjs.entry.js +157 -74
  271. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +24 -24
  272. package/dist/cjs/ix-menu-item.cjs.entry.js +100 -51
  273. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +13 -6
  274. package/dist/cjs/ix-menu-settings.cjs.entry.js +87 -4
  275. package/dist/cjs/ix-menu.cjs.entry.js +123 -136
  276. package/dist/cjs/ix-message-bar.cjs.entry.js +33 -22
  277. package/dist/cjs/ix-modal-content_2.cjs.entry.js +36 -17
  278. package/dist/cjs/ix-modal-footer.cjs.entry.js +2 -2
  279. package/dist/cjs/ix-modal-loading.cjs.entry.js +2 -2
  280. package/dist/cjs/ix-modal.cjs.entry.js +98 -61
  281. package/dist/cjs/ix-number-input.cjs.entry.js +211 -131
  282. package/dist/cjs/ix-pagination.cjs.entry.js +108 -89
  283. package/dist/cjs/ix-pane-layout.cjs.entry.js +26 -27
  284. package/dist/cjs/ix-pane.cjs.entry.js +114 -82
  285. package/dist/cjs/ix-pill_4.cjs.entry.js +746 -0
  286. package/dist/cjs/ix-progress-indicator.cjs.entry.js +48 -40
  287. package/dist/cjs/ix-push-card.cjs.entry.js +36 -15
  288. package/dist/cjs/ix-radio-group.cjs.entry.js +63 -26
  289. package/dist/cjs/ix-radio.cjs.entry.js +51 -25
  290. package/dist/cjs/ix-range-field.cjs.entry.js +122 -0
  291. package/dist/cjs/ix-select.cjs.entry.js +398 -373
  292. package/dist/cjs/ix-slider.cjs.entry.js +108 -68
  293. package/dist/cjs/ix-split-button.cjs.entry.js +118 -48
  294. package/dist/cjs/ix-tab-panel.cjs.entry.js +30 -0
  295. package/dist/cjs/ix-textarea.cjs.entry.js +135 -48
  296. package/dist/cjs/ix-tile.cjs.entry.js +12 -12
  297. package/dist/cjs/ix-time-input.cjs.entry.js +298 -152
  298. package/dist/cjs/ix-toast-container.cjs.entry.js +14 -54
  299. package/dist/cjs/ix-toast.cjs.entry.js +47 -31
  300. package/dist/cjs/ix-toggle-button.cjs.entry.js +200 -27
  301. package/dist/cjs/ix-toggle.cjs.entry.js +244 -48
  302. package/dist/cjs/ix-tooltip.cjs.entry.js +76 -52
  303. package/dist/cjs/ix-tree-item.cjs.entry.js +50 -16
  304. package/dist/cjs/ix-tree.cjs.entry.js +101 -45
  305. package/dist/cjs/ix-typography.cjs.entry.js +19 -12
  306. package/dist/cjs/ix-upload.cjs.entry.js +80 -76
  307. package/dist/cjs/ix-workflow-step.cjs.entry.js +39 -34
  308. package/dist/cjs/ix-workflow-steps.cjs.entry.js +20 -15
  309. package/dist/cjs/{listener-BShKJBRB.js → listener-BafrcTaM.js} +7 -6
  310. package/dist/cjs/loader.cjs.js +3 -4
  311. package/dist/cjs/{logical-filter-operator-q-2KOPJs.js → logical-filter-operator-Dv9-d8FB.js} +2 -0
  312. package/dist/cjs/luxon-datetime-format-masks-DQVILoY7.js +43 -0
  313. package/dist/cjs/{make-ref-BaH6_YJk.js → make-ref-CHsa3FY7.js} +6 -2
  314. package/dist/cjs/menu-service-D_QsHUgR.js +63 -0
  315. package/dist/cjs/modal-_AhJoT78.js +190 -0
  316. package/dist/cjs/service-CRjXhKel.js +94 -0
  317. package/dist/cjs/shadow-dom-BG8VqeIu.js +91 -0
  318. package/dist/cjs/siemens-ix.cjs.js +4 -5
  319. package/dist/cjs/tab.mixin-DObUK6A4.js +21 -0
  320. package/dist/cjs/theme-switcher-sbkXOvhB.js +127 -0
  321. package/dist/cjs/time-picker-constraints-CxGhm1qV.js +79 -0
  322. package/dist/cjs/{tree.types-BygtRFW3.js → tree.types-Cs9O1Wtf.js} +2 -0
  323. package/dist/cjs/typed-event-Bw4IfJC0.js +44 -0
  324. package/dist/cjs/{validation-DF9UXqHB.js → validation-Dier-uPA.js} +32 -9
  325. package/dist/collection/collection-manifest.json +16 -9
  326. package/dist/collection/components/action-card/action-card.js +37 -19
  327. package/dist/collection/components/application/application.js +62 -48
  328. package/dist/collection/components/application-header/application-header.js +116 -84
  329. package/dist/collection/components/application-header/application-switch-modal/application-switch-modal.js +5 -7
  330. package/dist/collection/components/avatar/avatar.css +30 -5
  331. package/dist/collection/components/avatar/avatar.js +108 -35
  332. package/dist/collection/components/blind/blind.js +33 -16
  333. package/dist/collection/components/breadcrumb/breadcrumb.css +7 -2
  334. package/dist/collection/components/breadcrumb/breadcrumb.js +125 -79
  335. package/dist/collection/components/breadcrumb/breadcrumb.types.js +1 -0
  336. package/dist/collection/components/breadcrumb-item/breadcrumb-item.css +66 -90
  337. package/dist/collection/components/breadcrumb-item/breadcrumb-item.js +131 -69
  338. package/dist/collection/components/button/base-button.js +13 -9
  339. package/dist/collection/components/button/button.css +38 -45
  340. package/dist/collection/components/button/button.js +69 -59
  341. package/dist/collection/components/card/card.js +15 -16
  342. package/dist/collection/components/card-accordion/card-accordion.js +27 -17
  343. package/dist/collection/components/card-content/card-content.js +1 -1
  344. package/dist/collection/components/card-list/card-list.js +127 -54
  345. package/dist/collection/components/card-title/card-title.js +1 -1
  346. package/dist/collection/components/category-filter/category-filter.css +38 -45
  347. package/dist/collection/components/category-filter/category-filter.js +173 -105
  348. package/dist/collection/components/category-filter/filter-state.js +2 -4
  349. package/dist/collection/components/category-filter/input-state.js +2 -0
  350. package/dist/collection/components/checkbox/checkbox.css +1 -0
  351. package/dist/collection/components/checkbox/checkbox.js +52 -33
  352. package/dist/collection/components/checkbox-group/checkbox-group.js +48 -25
  353. package/dist/collection/components/chip/chip.css +369 -346
  354. package/dist/collection/components/chip/chip.js +171 -80
  355. package/dist/collection/components/chip/chip.types.js +18 -0
  356. package/dist/collection/components/col/col.js +20 -2
  357. package/dist/collection/components/content/content.js +5 -6
  358. package/dist/collection/components/content-header/content-header.js +23 -17
  359. package/dist/collection/components/css-grid/css-grid-item.js +5 -1
  360. package/dist/collection/components/css-grid/css-grid.js +12 -6
  361. package/dist/collection/components/custom-field/custom-field.js +38 -11
  362. package/dist/collection/components/date-dropdown/date-dropdown.css +202 -18
  363. package/dist/collection/components/date-dropdown/date-dropdown.js +168 -201
  364. package/dist/collection/components/date-input/date-input.css +4 -4
  365. package/dist/collection/components/date-input/date-input.js +199 -112
  366. package/dist/collection/components/date-picker/date-picker.css +66 -25
  367. package/dist/collection/components/date-picker/date-picker.js +582 -193
  368. package/dist/collection/components/date-time-card/date-time-card.css +3 -0
  369. package/dist/collection/components/date-time-card/date-time-card.js +43 -18
  370. package/dist/collection/components/datetime-input/datetime-input.css +621 -0
  371. package/dist/collection/components/datetime-input/datetime-input.js +1372 -0
  372. package/dist/collection/components/datetime-input/datetime-input.types.js +1 -0
  373. package/dist/collection/components/datetime-picker/datetime-picker.css +2 -10
  374. package/dist/collection/components/datetime-picker/datetime-picker.js +364 -58
  375. package/dist/collection/components/divider/divider.js +1 -1
  376. package/dist/collection/components/dropdown/dropdown-controller.js +12 -9
  377. package/dist/collection/components/dropdown/dropdown-focus.js +178 -0
  378. package/dist/collection/components/dropdown/dropdown.css +1 -1
  379. package/dist/collection/components/dropdown/dropdown.js +809 -201
  380. package/dist/collection/components/dropdown-button/dropdown-button.css +38 -0
  381. package/dist/collection/components/dropdown-button/dropdown-button.js +258 -36
  382. package/dist/collection/components/dropdown-header/dropdown-header.js +5 -1
  383. package/dist/collection/components/dropdown-item/dropdown-item.css +23 -3
  384. package/dist/collection/components/dropdown-item/dropdown-item.js +129 -26
  385. package/dist/collection/components/dropdown-item/dropdown-item.types.js +1 -0
  386. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  387. package/dist/collection/components/empty-state/empty-state.js +31 -7
  388. package/dist/collection/components/event-list/event-list.js +25 -26
  389. package/dist/collection/components/event-list-item/event-list-item.js +35 -26
  390. package/dist/collection/components/expanding-search/expanding-search.js +56 -42
  391. package/dist/collection/components/field-label/field-label.css +10 -0
  392. package/dist/collection/components/field-label/field-label.js +34 -11
  393. package/dist/collection/components/field-wrapper/field-wrapper.css +1 -2
  394. package/dist/collection/components/field-wrapper/field-wrapper.js +193 -49
  395. package/dist/collection/components/field-wrapper/helper-text-util.js +22 -5
  396. package/dist/collection/components/filter-chip/filter-chip.css +0 -5
  397. package/dist/collection/components/filter-chip/filter-chip.js +33 -11
  398. package/dist/collection/components/flip-tile/flip-tile.js +39 -27
  399. package/dist/collection/components/flip-tile-content/flip-tile-content.js +7 -9
  400. package/dist/collection/components/group/group-context-menu.js +3 -4
  401. package/dist/collection/components/group/group.js +60 -38
  402. package/dist/collection/components/group-item/group-item.js +45 -22
  403. package/dist/collection/components/helper-text/helper-text.js +37 -12
  404. package/dist/collection/components/icon-button/base-icon-button.js +1 -1
  405. package/dist/collection/components/icon-button/icon-button.css +38 -45
  406. package/dist/collection/components/icon-button/icon-button.js +58 -56
  407. package/dist/collection/components/icon-toggle-button/icon-toggle-button.css +38 -45
  408. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +61 -63
  409. package/dist/collection/components/input/input.css +4 -8
  410. package/dist/collection/components/input/input.fc.js +10 -11
  411. package/dist/collection/components/input/input.js +119 -49
  412. package/dist/collection/components/input/input.util.js +1 -2
  413. package/dist/collection/components/input/number-input.css +4 -4
  414. package/dist/collection/components/input/number-input.js +202 -124
  415. package/dist/collection/components/input/textarea.css +4 -4
  416. package/dist/collection/components/input/textarea.js +127 -42
  417. package/dist/collection/components/ix-playground/ix-playground.js +25 -0
  418. package/dist/collection/components/key-value/key-value.js +23 -7
  419. package/dist/collection/components/key-value-list/key-value-list.js +5 -7
  420. package/dist/collection/components/kpi/kpi.js +35 -13
  421. package/dist/collection/components/layout-auto/layout-auto.js +14 -15
  422. package/dist/collection/components/layout-grid/layout-grid.js +14 -16
  423. package/dist/collection/components/link-button/link-button.js +17 -15
  424. package/dist/collection/components/menu/menu-expand-icon.css +12 -5
  425. package/dist/collection/components/menu/menu-expand-icon.js +60 -45
  426. package/dist/collection/components/menu/menu.js +114 -160
  427. package/dist/collection/components/menu-about/menu-about.css +63 -3
  428. package/dist/collection/components/menu-about/menu-about.js +111 -36
  429. package/dist/collection/components/menu-about-item/menu-about-item.js +18 -14
  430. package/dist/collection/components/menu-about-news/menu-about-news.js +65 -17
  431. package/dist/collection/components/menu-avatar/menu-avatar.js +57 -27
  432. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +15 -4
  433. package/dist/collection/components/menu-category/menu-category.js +156 -42
  434. package/dist/collection/components/menu-item/menu-item.js +94 -46
  435. package/dist/collection/components/menu-settings/menu-settings.css +0 -3
  436. package/dist/collection/components/menu-settings/menu-settings.js +111 -36
  437. package/dist/collection/components/menu-settings-item/menu-settings-item.js +23 -16
  438. package/dist/collection/components/message-bar/message-bar.js +31 -22
  439. package/dist/collection/components/modal/modal.css +2 -1
  440. package/dist/collection/components/modal/modal.js +98 -63
  441. package/dist/collection/components/modal-content/modal-content.js +1 -1
  442. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  443. package/dist/collection/components/modal-header/modal-header.js +34 -16
  444. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  445. package/dist/collection/components/pagination/pagination.css +38 -45
  446. package/dist/collection/components/pagination/pagination.js +103 -85
  447. package/dist/collection/components/pane/pane.js +108 -77
  448. package/dist/collection/components/pane-layout/pane-layout.js +23 -25
  449. package/dist/collection/components/pill/pill.css +8 -24
  450. package/dist/collection/components/pill/pill.js +60 -29
  451. package/dist/collection/components/progress-indicator/progress-indicator.js +46 -39
  452. package/dist/collection/components/push-card/push-card.js +35 -16
  453. package/dist/collection/components/radio/radio.js +47 -23
  454. package/dist/collection/components/radio-group/radio-group.js +59 -24
  455. package/dist/collection/components/{input-group/input-group.css → range-field/range-field.css} +26 -39
  456. package/dist/collection/components/range-field/range-field.js +193 -0
  457. package/dist/collection/components/row/row.js +1 -1
  458. package/dist/collection/components/select/select.css +36 -13
  459. package/dist/collection/components/select/select.js +427 -383
  460. package/dist/collection/components/select/test/select-controller.js +89 -0
  461. package/dist/collection/components/select-item/select-item.js +46 -59
  462. package/dist/collection/components/slider/slider.css +0 -7
  463. package/dist/collection/components/slider/slider.js +101 -85
  464. package/dist/collection/components/spinner/spinner.js +14 -15
  465. package/dist/collection/components/split-button/split-button.css +36 -19
  466. package/dist/collection/components/split-button/split-button.js +116 -77
  467. package/dist/collection/components/tab-item/tab-item.css +73 -81
  468. package/dist/collection/components/tab-item/tab-item.js +279 -93
  469. package/dist/collection/components/tab-item/tab.mixin.js +40 -0
  470. package/dist/collection/components/{application-sidebar/application-sidebar.css → tab-panel/tab-panel.css} +3 -11
  471. package/dist/collection/components/tab-panel/tab-panel.js +67 -0
  472. package/dist/collection/components/{drawer/drawer.css → tab-set/tab-set.css} +1 -62
  473. package/dist/collection/components/tab-set/tab-set.js +92 -0
  474. package/dist/collection/components/tabs/tabs.css +71 -39
  475. package/dist/collection/components/tabs/tabs.js +261 -416
  476. package/dist/collection/components/tile/tile.js +11 -12
  477. package/dist/collection/components/time-input/time-input.css +4 -4
  478. package/dist/collection/components/time-input/time-input.js +349 -138
  479. package/dist/collection/components/time-picker/time-picker-column-values.js +25 -0
  480. package/dist/collection/components/time-picker/time-picker-compute-time.js +64 -0
  481. package/dist/collection/components/time-picker/time-picker-constraints.js +71 -0
  482. package/dist/collection/components/time-picker/time-picker-display.js +21 -0
  483. package/dist/collection/components/time-picker/time-picker-format.js +40 -0
  484. package/dist/collection/components/time-picker/time-picker-range.js +50 -0
  485. package/dist/collection/components/time-picker/time-picker-step-focus.js +32 -0
  486. package/dist/collection/components/time-picker/time-picker.css +17 -4
  487. package/dist/collection/components/time-picker/time-picker.js +544 -264
  488. package/dist/collection/components/toast/{styles/toast-container.css → toast-container.css} +6 -8
  489. package/dist/collection/components/toast/toast-container.js +15 -97
  490. package/dist/collection/components/toast/toast-utils.js +16 -4
  491. package/dist/collection/components/toast/toast.js +45 -30
  492. package/dist/collection/components/toggle/toggle.css +7 -4
  493. package/dist/collection/components/toggle/toggle.js +85 -44
  494. package/dist/collection/components/toggle-button/toggle-button.css +38 -45
  495. package/dist/collection/components/toggle-button/toggle-button.js +41 -46
  496. package/dist/collection/components/tooltip/tooltip.js +68 -44
  497. package/dist/collection/components/tree/tree.js +74 -34
  498. package/dist/collection/components/tree-item/default-tree-item.js +2 -0
  499. package/dist/collection/components/tree-item/tree-item.css +9 -4
  500. package/dist/collection/components/tree-item/tree-item.js +70 -15
  501. package/dist/collection/components/typography/typography.js +18 -13
  502. package/dist/collection/components/upload/upload.js +110 -75
  503. package/dist/collection/components/utils/a11y.js +1 -2
  504. package/dist/collection/components/utils/animation.js +24 -44
  505. package/dist/collection/components/utils/application-layout/service.js +22 -40
  506. package/dist/collection/components/utils/context.js +4 -1
  507. package/dist/collection/components/utils/delegate.js +1 -2
  508. package/dist/collection/components/utils/dependency-function.js +55 -0
  509. package/dist/collection/components/utils/event.js +16 -0
  510. package/dist/collection/components/utils/find-element.js +1 -1
  511. package/dist/collection/components/utils/focus/detect-keyboard-mode.js +28 -0
  512. package/dist/collection/components/utils/focus/focus-proxy.js +40 -0
  513. package/dist/collection/components/utils/focus/focus-trap.js +99 -0
  514. package/dist/collection/components/utils/focus/focus-utilities.js +117 -0
  515. package/dist/collection/components/utils/focus.js +9 -6
  516. package/dist/collection/components/utils/input/index.js +5 -0
  517. package/dist/collection/components/utils/input/validation.js +31 -8
  518. package/dist/collection/components/utils/internal/component.js +2 -1
  519. package/dist/collection/components/utils/internal/index.js +1 -1
  520. package/dist/collection/components/utils/internal/mixins/accessibility/aria-activedescendant.mixin.js +84 -0
  521. package/dist/collection/components/utils/internal/mixins/accessibility/inherit-aria-attributes.mixin.js +190 -0
  522. package/dist/collection/components/utils/internal/mixins/focus-visible.mixin.js +91 -0
  523. package/dist/collection/components/utils/internal/mixins/id.mixin.js +17 -0
  524. package/dist/collection/components/utils/internal/mixins/input/input-picker.mixin.js +45 -0
  525. package/dist/collection/components/utils/internal/mixins/setup.mixin.js +118 -0
  526. package/dist/collection/components/utils/lazy-list/lazy.js +24 -9
  527. package/dist/collection/components/utils/listener.js +6 -5
  528. package/dist/collection/components/utils/luxon-datetime-format-masks.js +38 -0
  529. package/dist/collection/components/utils/make-ref.js +5 -2
  530. package/dist/collection/components/utils/menu-service/menu-service.js +17 -37
  531. package/dist/collection/components/utils/menu-tabs/menu-tabs-utils.js +1 -49
  532. package/dist/collection/components/utils/modal/index.js +2 -2
  533. package/dist/collection/components/utils/modal/loading.js +34 -29
  534. package/dist/collection/components/utils/modal/message.js +133 -106
  535. package/dist/collection/components/utils/modal/modal.js +11 -8
  536. package/dist/collection/components/utils/overlay.js +1 -3
  537. package/dist/collection/components/utils/shadow-dom.js +42 -0
  538. package/dist/collection/components/{drawer → utils}/test/animejs.mock.js +8 -8
  539. package/dist/collection/components/utils/theme-switcher.js +85 -133
  540. package/dist/collection/components/utils/typed-event.js +29 -31
  541. package/dist/collection/components/workflow-step/workflow-step.js +37 -33
  542. package/dist/collection/components/workflow-steps/workflow-steps.js +19 -15
  543. package/dist/collection/public-api.js +4 -0
  544. package/dist/collection/tests/utils/test/page.js +34 -9
  545. package/dist/esm/{a11y-DAzBNVe7.js → a11y-B5k8YVR0.js} +1 -2
  546. package/dist/esm/animation-DNIQ2C1K.js +79 -0
  547. package/dist/esm/app-globals-DQuL1Twl.js +3 -0
  548. package/dist/esm/aria-activedescendant.mixin-CM-NUHTW.js +83 -0
  549. package/dist/esm/{base-button-CV0w47z9.js → base-button-hppF0uUM.js} +14 -10
  550. package/dist/esm/{base-icon-button-BuHd34qo.js → base-icon-button-_xVULsPr.js} +3 -3
  551. package/dist/esm/component-Chfbghog.js +139 -0
  552. package/dist/esm/{context-BniHpAE1.js → context-zqk3Dkv-.js} +5 -2
  553. package/dist/esm/{dropdown-controller-D3K9vmFp.js → dropdown-controller-D6Wm2E-0.js} +12 -9
  554. package/dist/esm/{floating-ui.dom-CAqtPJ4-.js → find-element-Bxrgt3H_.js} +100 -1
  555. package/dist/esm/focus-proxy-BgLEsVE2.js +43 -0
  556. package/dist/esm/focus-trap-DDLHqzV2.js +102 -0
  557. package/dist/esm/focus-utilities-DnaItyVQ.js +108 -0
  558. package/dist/esm/focus-visible.mixin-CoMZ6z5Z.js +40 -0
  559. package/dist/esm/{helper-text-util-C9sLzo0k.js → helper-text-util-AEl-1QU6.js} +26 -9
  560. package/dist/esm/id.mixin-CUbYLenp.js +19 -0
  561. package/dist/esm/{index-BEPo7U1W.js → index-Ca5WUunf.js} +529 -127
  562. package/dist/esm/{index-BBzEV-f4.js → index-Cl7fhG1I.js} +2 -3
  563. package/dist/esm/index-XBTykBKS.js +14 -0
  564. package/dist/esm/{index-BG5XMoOy.js → index-nCVTBc9Y.js} +1 -2
  565. package/dist/esm/index.js +262 -45
  566. package/dist/esm/inherit-aria-attributes.mixin-CBuZQFB-.js +34 -0
  567. package/dist/esm/{picker-input.util-D1uMJUKN.js → input-picker.mixin-Bo_sZpC4.js} +25 -2
  568. package/dist/esm/{input.fc-C1ytwpkt.js → input.fc-DjE-oOZc.js} +17 -19
  569. package/dist/esm/ix-action-card.entry.js +39 -19
  570. package/dist/esm/ix-application-header.entry.js +126 -69
  571. package/dist/esm/ix-application-switch-modal.entry.js +9 -13
  572. package/dist/esm/ix-application.entry.js +46 -34
  573. package/dist/esm/ix-avatar_2.entry.js +126 -22
  574. package/dist/esm/ix-blind.entry.js +37 -23
  575. package/dist/esm/ix-breadcrumb-item.entry.js +234 -43
  576. package/dist/esm/ix-breadcrumb.entry.js +85 -68
  577. package/dist/esm/ix-button.entry.js +227 -40
  578. package/dist/esm/ix-card-accordion_2.entry.js +30 -19
  579. package/dist/esm/ix-card-list.entry.js +104 -54
  580. package/dist/esm/ix-card_2.entry.js +17 -17
  581. package/dist/esm/ix-category-filter.entry.js +180 -111
  582. package/dist/esm/ix-checkbox-group.entry.js +52 -27
  583. package/dist/esm/ix-checkbox.entry.js +58 -37
  584. package/dist/esm/ix-chip.entry.js +317 -81
  585. package/dist/esm/ix-col_4.entry.js +1110 -496
  586. package/dist/esm/ix-content-header.entry.js +25 -17
  587. package/dist/esm/ix-content.entry.js +7 -7
  588. package/dist/esm/ix-css-grid-item.entry.js +6 -2
  589. package/dist/esm/ix-css-grid.entry.js +13 -5
  590. package/dist/esm/ix-custom-field.entry.js +41 -12
  591. package/dist/esm/ix-date-dropdown.entry.js +170 -145
  592. package/dist/esm/ix-date-input.entry.js +209 -122
  593. package/dist/esm/ix-date-picker.entry.js +750 -0
  594. package/dist/esm/ix-date-time-card.entry.js +25 -18
  595. package/dist/esm/ix-datetime-input.entry.js +546 -0
  596. package/dist/esm/ix-datetime-picker.entry.js +242 -58
  597. package/dist/esm/ix-divider.entry.js +2 -2
  598. package/dist/esm/ix-dropdown-button.entry.js +155 -38
  599. package/dist/esm/ix-dropdown-header.entry.js +6 -2
  600. package/dist/esm/ix-dropdown-quick-actions.entry.js +2 -2
  601. package/dist/esm/ix-dropdown_2.entry.js +989 -0
  602. package/dist/esm/ix-empty-state.entry.js +32 -6
  603. package/dist/esm/ix-event-list-item.entry.js +38 -27
  604. package/dist/esm/ix-event-list.entry.js +27 -27
  605. package/dist/esm/ix-expanding-search.entry.js +58 -44
  606. package/dist/esm/ix-field-label_2.entry.js +177 -55
  607. package/dist/esm/ix-filter-chip_2.entry.js +85 -37
  608. package/dist/esm/ix-flip-tile-content.entry.js +8 -8
  609. package/dist/esm/ix-flip-tile.entry.js +43 -30
  610. package/dist/esm/ix-group-context-menu_2.entry.js +51 -27
  611. package/dist/esm/ix-group.entry.js +63 -40
  612. package/dist/esm/ix-helper-text.entry.js +43 -16
  613. package/dist/esm/ix-icon-button_2.entry.js +232 -52
  614. package/dist/esm/ix-icon-toggle-button.entry.js +221 -45
  615. package/dist/esm/ix-input.entry.js +129 -57
  616. package/dist/esm/ix-key-value-list.entry.js +6 -6
  617. package/dist/esm/ix-key-value.entry.js +24 -6
  618. package/dist/esm/ix-kpi.entry.js +37 -13
  619. package/dist/esm/ix-layout-auto.entry.js +15 -15
  620. package/dist/esm/ix-link-button.entry.js +19 -15
  621. package/dist/esm/ix-menu-about-item.entry.js +13 -6
  622. package/dist/esm/ix-menu-about-news.entry.js +45 -18
  623. package/dist/esm/ix-menu-about.entry.js +72 -28
  624. package/dist/esm/ix-menu-avatar.entry.js +62 -31
  625. package/dist/esm/ix-menu-category.entry.js +157 -74
  626. package/dist/esm/ix-menu-expand-icon.entry.js +24 -24
  627. package/dist/esm/ix-menu-item.entry.js +100 -51
  628. package/dist/esm/ix-menu-settings-item.entry.js +13 -6
  629. package/dist/esm/ix-menu-settings.entry.js +90 -3
  630. package/dist/esm/ix-menu.entry.js +123 -136
  631. package/dist/esm/ix-message-bar.entry.js +33 -22
  632. package/dist/esm/ix-modal-content_2.entry.js +36 -17
  633. package/dist/esm/ix-modal-footer.entry.js +2 -2
  634. package/dist/esm/ix-modal-loading.entry.js +2 -2
  635. package/dist/esm/ix-modal.entry.js +98 -61
  636. package/dist/esm/ix-number-input.entry.js +212 -132
  637. package/dist/esm/ix-pagination.entry.js +108 -89
  638. package/dist/esm/ix-pane-layout.entry.js +26 -27
  639. package/dist/esm/ix-pane.entry.js +114 -82
  640. package/dist/esm/ix-pill_4.entry.js +741 -0
  641. package/dist/esm/ix-progress-indicator.entry.js +48 -40
  642. package/dist/esm/ix-push-card.entry.js +36 -15
  643. package/dist/esm/ix-radio-group.entry.js +63 -26
  644. package/dist/esm/ix-radio.entry.js +51 -25
  645. package/dist/esm/ix-range-field.entry.js +120 -0
  646. package/dist/esm/ix-select.entry.js +398 -373
  647. package/dist/esm/ix-slider.entry.js +108 -68
  648. package/dist/esm/ix-split-button.entry.js +118 -48
  649. package/dist/esm/ix-tab-panel.entry.js +28 -0
  650. package/dist/esm/ix-textarea.entry.js +136 -49
  651. package/dist/esm/ix-tile.entry.js +12 -12
  652. package/dist/esm/ix-time-input.entry.js +295 -149
  653. package/dist/esm/ix-toast-container.entry.js +14 -54
  654. package/dist/esm/ix-toast.entry.js +47 -31
  655. package/dist/esm/ix-toggle-button.entry.js +200 -27
  656. package/dist/esm/ix-toggle.entry.js +244 -48
  657. package/dist/esm/ix-tooltip.entry.js +69 -45
  658. package/dist/esm/ix-tree-item.entry.js +50 -16
  659. package/dist/esm/ix-tree.entry.js +101 -45
  660. package/dist/esm/ix-typography.entry.js +19 -12
  661. package/dist/esm/ix-upload.entry.js +80 -76
  662. package/dist/esm/ix-workflow-step.entry.js +39 -34
  663. package/dist/esm/ix-workflow-steps.entry.js +20 -15
  664. package/dist/esm/{listener-DcAn-vyA.js → listener-Dk6XGheN.js} +7 -6
  665. package/dist/esm/loader.js +4 -5
  666. package/dist/esm/{logical-filter-operator-BH3f5fa3.js → logical-filter-operator-C9HBQRMb.js} +2 -0
  667. package/dist/esm/luxon-datetime-format-masks-CoQiziG8.js +40 -0
  668. package/dist/esm/{make-ref-bcj7UEIC.js → make-ref-Djkc69iv.js} +6 -3
  669. package/dist/esm/menu-service-DTIYRV47.js +61 -0
  670. package/dist/esm/modal-DaGSr1j4.js +181 -0
  671. package/dist/esm/{rwd.util-pXYAoEyc.js → rwd.util-JJddxCCh.js} +1 -1
  672. package/dist/esm/service-CEglFEKY.js +92 -0
  673. package/dist/esm/shadow-dom-BIe8Nw9M.js +85 -0
  674. package/dist/esm/siemens-ix.js +5 -6
  675. package/dist/esm/tab.mixin-2hU1i4Yk.js +19 -0
  676. package/dist/esm/theme-switcher-CRVG13AN.js +124 -0
  677. package/dist/esm/time-picker-constraints-Bsg2RskF.js +74 -0
  678. package/dist/esm/{tree.types-DSTYytot.js → tree.types-D5rshXh5.js} +2 -0
  679. package/dist/esm/typed-event-CWshStHZ.js +42 -0
  680. package/dist/esm/{validation-CTBekLDe.js → validation-BT5aAuSO.js} +32 -9
  681. package/dist/siemens-ix/index.esm.js +1 -1
  682. package/dist/siemens-ix/p-04bbcd53.entry.js +1 -0
  683. package/dist/siemens-ix/p-077cb0a7.entry.js +1 -0
  684. package/dist/siemens-ix/p-0de68f63.entry.js +1 -0
  685. package/dist/siemens-ix/p-12647d5d.entry.js +1 -0
  686. package/dist/siemens-ix/p-12750b7b.entry.js +1 -0
  687. package/dist/siemens-ix/p-15aefb52.entry.js +1 -0
  688. package/dist/siemens-ix/p-1629de03.entry.js +1 -0
  689. package/dist/siemens-ix/p-1ce32501.entry.js +1 -0
  690. package/dist/siemens-ix/p-1fa6a663.entry.js +1 -0
  691. package/dist/siemens-ix/p-2142fab0.entry.js +1 -0
  692. package/dist/siemens-ix/p-21c0d22c.entry.js +1 -0
  693. package/dist/siemens-ix/p-222881a1.entry.js +1 -0
  694. package/dist/siemens-ix/p-232da11d.entry.js +1 -0
  695. package/dist/siemens-ix/p-23aaf08e.entry.js +1 -0
  696. package/dist/siemens-ix/p-25c784e4.entry.js +1 -0
  697. package/dist/siemens-ix/p-280d8b68.entry.js +1 -0
  698. package/dist/siemens-ix/{p-6aadd69d.entry.js → p-2a735134.entry.js} +1 -1
  699. package/dist/siemens-ix/p-2afcdc78.entry.js +1 -0
  700. package/dist/siemens-ix/p-2bef3c58.entry.js +1 -0
  701. package/dist/siemens-ix/p-2d7e415f.entry.js +1 -0
  702. package/dist/siemens-ix/p-2d8f3ea3.entry.js +1 -0
  703. package/dist/siemens-ix/p-2e5e7ccf.entry.js +1 -0
  704. package/dist/siemens-ix/p-38cb18b4.entry.js +1 -0
  705. package/dist/siemens-ix/p-3f752a9c.entry.js +1 -0
  706. package/dist/siemens-ix/p-40a26154.entry.js +1 -0
  707. package/dist/siemens-ix/p-44a3f1f0.entry.js +1 -0
  708. package/dist/siemens-ix/p-45552c4c.entry.js +1 -0
  709. package/dist/siemens-ix/p-48386b43.entry.js +1 -0
  710. package/dist/siemens-ix/p-4pTtJwcY.js +1 -0
  711. package/dist/siemens-ix/p-5024bd91.entry.js +1 -0
  712. package/dist/siemens-ix/p-50b75fdf.entry.js +1 -0
  713. package/dist/siemens-ix/p-58d349a2.entry.js +1 -0
  714. package/dist/siemens-ix/p-5a44cb29.entry.js +1 -0
  715. package/dist/siemens-ix/p-5ae844d7.entry.js +1 -0
  716. package/dist/siemens-ix/p-5b3f7baa.entry.js +1 -0
  717. package/dist/siemens-ix/p-5c478e3e.entry.js +1 -0
  718. package/dist/siemens-ix/p-61a481f3.entry.js +1 -0
  719. package/dist/siemens-ix/p-65b8ad90.entry.js +1 -0
  720. package/dist/siemens-ix/p-65bc8a0d.entry.js +1 -0
  721. package/dist/siemens-ix/p-68eb9150.entry.js +1 -0
  722. package/dist/siemens-ix/p-69459b73.entry.js +1 -0
  723. package/dist/siemens-ix/p-6df3d9e4.entry.js +1 -0
  724. package/dist/siemens-ix/p-6e63af65.entry.js +1 -0
  725. package/dist/siemens-ix/p-6fb379fb.entry.js +1 -0
  726. package/dist/siemens-ix/p-756c8779.entry.js +1 -0
  727. package/dist/siemens-ix/p-782fb465.entry.js +1 -0
  728. package/dist/siemens-ix/p-7a83e693.entry.js +1 -0
  729. package/dist/siemens-ix/p-82f44b05.entry.js +1 -0
  730. package/dist/siemens-ix/p-834330b3.entry.js +1 -0
  731. package/dist/siemens-ix/p-8493e35e.entry.js +1 -0
  732. package/dist/siemens-ix/p-84fbdef9.entry.js +1 -0
  733. package/dist/siemens-ix/p-85ce0a9f.entry.js +1 -0
  734. package/dist/siemens-ix/p-8937e9b1.entry.js +1 -0
  735. package/dist/siemens-ix/p-8cfddec2.entry.js +1 -0
  736. package/dist/siemens-ix/p-8d76c0b0.entry.js +1 -0
  737. package/dist/siemens-ix/p-9015a4c5.entry.js +1 -0
  738. package/dist/siemens-ix/p-91b02cb7.entry.js +1 -0
  739. package/dist/siemens-ix/p-9362c304.entry.js +1 -0
  740. package/dist/siemens-ix/p-9586a886.entry.js +1 -0
  741. package/dist/siemens-ix/p-986142f0.entry.js +1 -0
  742. package/dist/siemens-ix/p-9907d408.entry.js +1 -0
  743. package/dist/siemens-ix/p-9b8f1bc7.entry.js +1 -0
  744. package/dist/siemens-ix/p-B5k8YVR0.js +1 -0
  745. package/dist/siemens-ix/p-BFUINhFM.js +1 -0
  746. package/dist/siemens-ix/p-BIe8Nw9M.js +1 -0
  747. package/dist/siemens-ix/p-BL9SR36X.js +1 -0
  748. package/dist/siemens-ix/p-BZApVtkF.js +1 -0
  749. package/dist/siemens-ix/p-BgL7Z4IG.js +1 -0
  750. package/dist/siemens-ix/p-Bxrgt3H_.js +1 -0
  751. package/dist/siemens-ix/p-C9HBQRMb.js +1 -0
  752. package/dist/siemens-ix/p-CM-NUHTW.js +1 -0
  753. package/dist/siemens-ix/p-CUbYLenp.js +1 -0
  754. package/dist/siemens-ix/p-CWlPNXA-.js +1 -0
  755. package/dist/siemens-ix/p-CWshStHZ.js +1 -0
  756. package/dist/siemens-ix/p-Ca5WUunf.js +2 -0
  757. package/dist/siemens-ix/p-CgOv_MV_.js +1 -0
  758. package/dist/siemens-ix/p-Cl7fhG1I.js +1 -0
  759. package/dist/siemens-ix/p-CoQiziG8.js +1 -0
  760. package/dist/siemens-ix/p-CxGywkh5.js +1 -0
  761. package/dist/siemens-ix/p-D148LCh1.js +1 -0
  762. package/dist/siemens-ix/{p-DSTYytot.js → p-D5rshXh5.js} +1 -1
  763. package/dist/siemens-ix/p-D6Wm2E-0.js +1 -0
  764. package/dist/siemens-ix/p-DIWED8Ls.js +1 -0
  765. package/dist/siemens-ix/p-DNIQ2C1K.js +1 -0
  766. package/dist/siemens-ix/p-DQuL1Twl.js +1 -0
  767. package/dist/siemens-ix/p-Djkc69iv.js +1 -0
  768. package/dist/siemens-ix/p-Dl_bUxb7.js +1 -0
  769. package/dist/siemens-ix/p-DnCbHs-d.js +1 -0
  770. package/dist/siemens-ix/p-DnaItyVQ.js +1 -0
  771. package/dist/siemens-ix/p-DuTDx0c-.js +1 -0
  772. package/dist/siemens-ix/p-Dx6rQdpk.js +1 -0
  773. package/dist/siemens-ix/p-DzWThpzp.js +1 -0
  774. package/dist/siemens-ix/p-GLcPX9PU.js +1 -0
  775. package/dist/siemens-ix/{p-pXYAoEyc.js → p-JJddxCCh.js} +1 -1
  776. package/dist/siemens-ix/p-XBTykBKS.js +1 -0
  777. package/dist/siemens-ix/p-Z4IKO1Dx.js +1 -0
  778. package/dist/siemens-ix/p-a44e8a8f.entry.js +1 -0
  779. package/dist/siemens-ix/p-a5d60068.entry.js +1 -0
  780. package/dist/siemens-ix/p-ae5569aa.entry.js +1 -0
  781. package/dist/siemens-ix/p-afa900f7.entry.js +1 -0
  782. package/dist/siemens-ix/p-b17053bc.entry.js +1 -0
  783. package/dist/siemens-ix/p-b1930204.entry.js +1 -0
  784. package/dist/siemens-ix/{p-d458b450.entry.js → p-b517c2e1.entry.js} +1 -1
  785. package/dist/siemens-ix/p-b96eabf7.entry.js +1 -0
  786. package/dist/siemens-ix/p-ba0eaaf5.entry.js +1 -0
  787. package/dist/siemens-ix/p-bd60b9fe.entry.js +1 -0
  788. package/dist/siemens-ix/p-bef76eac.entry.js +1 -0
  789. package/dist/siemens-ix/p-c350c5d0.entry.js +1 -0
  790. package/dist/siemens-ix/p-c56497da.entry.js +1 -0
  791. package/dist/siemens-ix/p-c78a5414.entry.js +1 -0
  792. package/dist/siemens-ix/p-c921c01b.entry.js +1 -0
  793. package/dist/siemens-ix/p-cb9f8b47.entry.js +1 -0
  794. package/dist/siemens-ix/p-d34c0c51.entry.js +1 -0
  795. package/dist/siemens-ix/p-d440cd94.entry.js +1 -0
  796. package/dist/siemens-ix/{p-2b559d4b.entry.js → p-d798773f.entry.js} +1 -1
  797. package/dist/siemens-ix/p-d8c99656.entry.js +1 -0
  798. package/dist/siemens-ix/p-da8840cc.entry.js +1 -0
  799. package/dist/siemens-ix/p-dd2b271e.entry.js +1 -0
  800. package/dist/siemens-ix/p-de79c9cf.entry.js +1 -0
  801. package/dist/siemens-ix/p-dedd5fc0.entry.js +1 -0
  802. package/dist/siemens-ix/p-df13643b.entry.js +1 -0
  803. package/dist/siemens-ix/p-df32a25c.entry.js +1 -0
  804. package/dist/siemens-ix/p-e09fcd95.entry.js +1 -0
  805. package/dist/siemens-ix/p-e316d8a5.entry.js +1 -0
  806. package/dist/siemens-ix/p-ea440d84.entry.js +1 -0
  807. package/dist/siemens-ix/p-ed2aea43.entry.js +1 -0
  808. package/dist/siemens-ix/p-edb738d9.entry.js +1 -0
  809. package/dist/siemens-ix/p-f107a580.entry.js +1 -0
  810. package/dist/siemens-ix/p-f847a799.entry.js +1 -0
  811. package/dist/siemens-ix/p-fcac86a5.entry.js +1 -0
  812. package/dist/siemens-ix/p-fpBGwEVT.js +1 -0
  813. package/dist/siemens-ix/p-jBB3q9qq.js +1 -0
  814. package/dist/siemens-ix/p-yAf8WIcn.js +1 -0
  815. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  816. package/dist/siemens-ix/siemens-ix-standalone.css +1 -0
  817. package/dist/siemens-ix/siemens-ix.css +285 -988
  818. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  819. package/dist/siemens-ix/theme/classic-dark.css +1 -1
  820. package/dist/siemens-ix/theme/classic-light.css +1 -1
  821. package/dist/types/components/application/application.d.ts +8 -5
  822. package/dist/types/components/application-header/application-header.d.ts +0 -7
  823. package/dist/types/components/avatar/avatar.d.ts +60 -8
  824. package/dist/types/components/breadcrumb/breadcrumb.d.ts +29 -9
  825. package/dist/types/components/breadcrumb/breadcrumb.types.d.ts +9 -0
  826. package/dist/types/components/breadcrumb-item/breadcrumb-item.d.ts +42 -12
  827. package/dist/types/components/button/button.d.ts +31 -8
  828. package/dist/types/components/card-list/card-list.d.ts +8 -0
  829. package/dist/types/components/checkbox-group/checkbox-group.d.ts +2 -2
  830. package/dist/types/components/chip/chip.d.ts +48 -4
  831. package/dist/types/components/chip/chip.types.d.ts +2 -0
  832. package/dist/types/components/custom-field/custom-field.d.ts +2 -2
  833. package/dist/types/components/date-dropdown/date-dropdown.d.ts +18 -17
  834. package/dist/types/components/date-input/date-input.d.ts +18 -5
  835. package/dist/types/components/date-picker/date-picker.d.ts +62 -10
  836. package/dist/types/components/date-time-card/date-time-card.d.ts +4 -0
  837. package/dist/types/components/datetime-input/datetime-input.d.ts +210 -0
  838. package/dist/types/components/datetime-input/datetime-input.types.d.ts +3 -0
  839. package/dist/types/components/datetime-picker/datetime-picker.d.ts +32 -0
  840. package/dist/types/components/dropdown/dropdown-controller.d.ts +3 -2
  841. package/dist/types/components/dropdown/dropdown-focus.d.ts +20 -0
  842. package/dist/types/components/dropdown/dropdown.d.ts +109 -14
  843. package/dist/types/components/dropdown-button/dropdown-button.d.ts +82 -2
  844. package/dist/types/components/dropdown-item/dropdown-item.d.ts +55 -1
  845. package/dist/types/components/dropdown-item/dropdown-item.types.d.ts +1 -0
  846. package/dist/types/components/field-label/field-label.d.ts +3 -2
  847. package/dist/types/components/field-wrapper/field-wrapper.d.ts +39 -5
  848. package/dist/types/components/field-wrapper/helper-text-util.d.ts +11 -0
  849. package/dist/types/components/helper-text/helper-text.d.ts +2 -2
  850. package/dist/types/components/icon-button/icon-button.d.ts +31 -8
  851. package/dist/types/components/icon-toggle-button/icon-toggle-button.d.ts +31 -8
  852. package/dist/types/components/layout-auto/layout-auto.d.ts +2 -2
  853. package/dist/types/components/menu/menu-expand-icon.d.ts +4 -5
  854. package/dist/types/components/menu/menu.d.ts +0 -11
  855. package/dist/types/components/menu-about/menu-about.d.ts +19 -6
  856. package/dist/types/components/menu-about-item/menu-about-item.d.ts +20 -1
  857. package/dist/types/components/menu-about-news/menu-about-news.d.ts +22 -1
  858. package/dist/types/components/menu-category/menu-category.d.ts +23 -4
  859. package/dist/types/components/menu-item/menu-item.d.ts +2 -0
  860. package/dist/types/components/menu-settings/menu-settings.d.ts +19 -6
  861. package/dist/types/components/menu-settings-item/menu-settings-item.d.ts +21 -2
  862. package/dist/types/components/modal/modal.d.ts +6 -4
  863. package/dist/types/components/modal-header/modal-header.d.ts +2 -2
  864. package/dist/types/components/pill/pill.d.ts +16 -2
  865. package/dist/types/components/range-field/range-field.d.ts +34 -0
  866. package/dist/types/components/select/select.d.ts +82 -32
  867. package/dist/types/components/select/test/select-controller.d.ts +15 -0
  868. package/dist/types/components/select-item/select-item.d.ts +47 -7
  869. package/dist/types/components/slider/slider.d.ts +0 -6
  870. package/dist/types/components/split-button/split-button.d.ts +43 -8
  871. package/dist/types/components/tab-item/tab-item.d.ts +77 -15
  872. package/dist/types/components/tab-item/tab-item.types.d.ts +2 -1
  873. package/dist/types/components/tab-item/tab.mixin.d.ts +26 -0
  874. package/dist/types/components/tab-panel/tab-panel.d.ts +42 -0
  875. package/dist/types/components/tab-set/tab-set.d.ts +17 -0
  876. package/dist/types/components/tabs/tabs.d.ts +68 -58
  877. package/dist/types/components/time-input/time-input.d.ts +43 -6
  878. package/dist/types/components/time-picker/time-picker-column-values.d.ts +15 -0
  879. package/dist/types/components/time-picker/time-picker-compute-time.d.ts +6 -0
  880. package/dist/types/components/time-picker/time-picker-constraints.d.ts +16 -0
  881. package/dist/types/components/time-picker/time-picker-display.d.ts +6 -0
  882. package/dist/types/components/time-picker/time-picker-format.d.ts +13 -0
  883. package/dist/types/components/time-picker/time-picker-range.d.ts +11 -0
  884. package/dist/types/components/time-picker/time-picker-step-focus.d.ts +7 -0
  885. package/dist/types/components/time-picker/time-picker.d.ts +51 -9
  886. package/dist/types/components/time-picker/time-picker.types.d.ts +1 -0
  887. package/dist/types/components/toast/toast-container.d.ts +3 -11
  888. package/dist/types/components/toggle/toggle.d.ts +32 -1
  889. package/dist/types/components/toggle-button/toggle-button.d.ts +31 -6
  890. package/dist/types/components/tooltip/tooltip.d.ts +1 -1
  891. package/dist/types/components/tree/tree-model.d.ts +4 -0
  892. package/dist/types/components/tree-item/tree-item.d.ts +6 -0
  893. package/dist/types/components/upload/upload.d.ts +10 -4
  894. package/dist/types/components/utils/dependency-function.d.ts +16 -0
  895. package/dist/types/components/utils/event.d.ts +8 -0
  896. package/dist/types/components/utils/focus/detect-keyboard-mode.d.ts +5 -0
  897. package/dist/types/components/utils/focus/focus-proxy.d.ts +12 -0
  898. package/dist/types/components/utils/focus/focus-trap.d.ts +12 -0
  899. package/dist/types/components/utils/focus/focus-utilities.d.ts +32 -0
  900. package/dist/types/components/utils/input/index.d.ts +6 -2
  901. package/dist/types/components/utils/input/validation.d.ts +2 -2
  902. package/dist/types/components/utils/internal/component.d.ts +107 -2
  903. package/dist/types/components/utils/internal/index.d.ts +2 -1
  904. package/dist/types/components/utils/internal/mixins/accessibility/aria-activedescendant.mixin.d.ts +30 -0
  905. package/dist/types/components/utils/internal/mixins/accessibility/inherit-aria-attributes.mixin.d.ts +25 -0
  906. package/dist/types/components/utils/internal/mixins/focus-visible.mixin.d.ts +33 -0
  907. package/dist/types/components/utils/internal/mixins/id.mixin.d.ts +22 -0
  908. package/dist/types/components/utils/internal/mixins/input/input-picker.mixin.d.ts +24 -0
  909. package/dist/types/components/utils/internal/mixins/setup.mixin.d.ts +31 -0
  910. package/dist/types/components/utils/luxon-datetime-format-masks.d.ts +13 -0
  911. package/dist/types/components/utils/make-ref.d.ts +1 -0
  912. package/dist/types/components/utils/menu-tabs/menu-tabs-utils.d.ts +0 -5
  913. package/dist/types/components/utils/modal/index.d.ts +2 -2
  914. package/dist/types/components/utils/modal/loading.d.ts +8 -7
  915. package/dist/types/components/utils/modal/message.d.ts +27 -27
  916. package/dist/types/components/utils/modal/modal.d.ts +9 -18
  917. package/dist/types/components/utils/overlay.d.ts +2 -2
  918. package/dist/types/components/utils/shadow-dom.d.ts +16 -0
  919. package/dist/types/components/utils/test/animejs.mock.d.ts +1 -0
  920. package/dist/types/components/utils/theme-switcher.d.ts +24 -22
  921. package/dist/types/components.d.ts +1192 -613
  922. package/dist/types/public-api.d.ts +5 -0
  923. package/dist/types/tests/utils/test/page.d.ts +7 -1
  924. package/hydrate/index.js +12689 -6438
  925. package/hydrate/index.mjs +12689 -6438
  926. package/package.json +13 -7
  927. package/scss/_core.scss +3 -45
  928. package/scss/_standalone.scss +45 -0
  929. package/scss/components/_table.scss +5 -1
  930. package/scss/ix-core.scss +0 -2
  931. package/{dist/collection/components/menu-settings-item/menu-settings-item.css → scss/ix-standalone.scss} +2 -5
  932. package/scss/legacy/components/_checkboxes.scss +1 -1
  933. package/scss/legacy/components/_dropdown.scss +1 -1
  934. package/scss/legacy/components/_forms.scss +1 -1
  935. package/scss/legacy/components/_modal.scss +1 -1
  936. package/scss/legacy/components/_radiobuttons.scss +1 -1
  937. package/scss/legacy/mixins/_fonts.scss +1 -1
  938. package/scss/mixins/shadow-dom/_focus-visible.scss +12 -0
  939. package/scss/theme/classic/dark/_index.scss +0 -1
  940. package/scss/theme/classic/dark/_variables.scss +40 -40
  941. package/scss/theme/classic/light/_index.scss +0 -1
  942. package/scss/theme/classic/light/_variables.scss +40 -40
  943. package/scss/theme/classic/theme.scss +22 -28
  944. package/scss/theme/core/components/button.scss +29 -29
  945. package/scss/theme/core/components/chip.scss +4 -4
  946. package/scss/theme/core/components/link.scss +2 -2
  947. package/scss/theme/core/components/tab.scss +4 -4
  948. package/components/ix-application-sidebar.js +0 -1
  949. package/components/ix-drawer.js +0 -1
  950. package/components/ix-input-group.js +0 -1
  951. package/components/ix-validation-tooltip.js +0 -1
  952. package/components/p-0oJ9dyRQ.js +0 -1
  953. package/components/p-9tuDiQEH.js +0 -1
  954. package/components/p-AHG5KaOt.js +0 -1
  955. package/components/p-B0gQmZW3.js +0 -1
  956. package/components/p-B81cFxT_.js +0 -1
  957. package/components/p-BAIdCBnK.js +0 -1
  958. package/components/p-BH3f5fa3.js +0 -1
  959. package/components/p-BKNhBo9h.js +0 -1
  960. package/components/p-BLaucX4x.js +0 -1
  961. package/components/p-BM_otpzy.js +0 -1
  962. package/components/p-BWHIcA46.js +0 -1
  963. package/components/p-BWRJteYa.js +0 -1
  964. package/components/p-BYACnsyo.js +0 -1
  965. package/components/p-BbN-BCaw.js +0 -1
  966. package/components/p-BdCnOrqW.js +0 -1
  967. package/components/p-BhgW5qDm.js +0 -1
  968. package/components/p-Bi1VyG64.js +0 -1
  969. package/components/p-BncjKdXL.js +0 -1
  970. package/components/p-Bo9ALIy0.js +0 -1
  971. package/components/p-BvFOMxgl.js +0 -1
  972. package/components/p-C9SfsAWb.js +0 -1
  973. package/components/p-CAqtPJ4-.js +0 -1
  974. package/components/p-CFRrPFxi.js +0 -1
  975. package/components/p-CMi1hdQj.js +0 -1
  976. package/components/p-CPz6ThvB.js +0 -1
  977. package/components/p-CS1HnwQr.js +0 -1
  978. package/components/p-CYMB75De.js +0 -1
  979. package/components/p-CZsAGuDS.js +0 -1
  980. package/components/p-C_3dz2Xl.js +0 -1
  981. package/components/p-C_6_Rh7K.js +0 -1
  982. package/components/p-Cce1kE8J.js +0 -1
  983. package/components/p-CdT1qV2I.js +0 -1
  984. package/components/p-Cgi0rnuQ.js +0 -1
  985. package/components/p-ChDWY0o5.js +0 -1
  986. package/components/p-CjFgf9s9.js +0 -1
  987. package/components/p-CkBQGLbj.js +0 -1
  988. package/components/p-ClVzB9MP.js +0 -1
  989. package/components/p-CsGkJrm6.js +0 -1
  990. package/components/p-CxWzccPV.js +0 -1
  991. package/components/p-D3K9vmFp.js +0 -1
  992. package/components/p-DAzBNVe7.js +0 -1
  993. package/components/p-DNJriU2G.js +0 -1
  994. package/components/p-DQgVT_uh.js +0 -1
  995. package/components/p-DaVdylP8.js +0 -1
  996. package/components/p-DnKEXwdz.js +0 -1
  997. package/components/p-DrsekPHj.js +0 -1
  998. package/components/p-IsTvRVoY.js +0 -1
  999. package/components/p-LoRL-toz.js +0 -1
  1000. package/components/p-MJm14Xlr.js +0 -1
  1001. package/components/p-VHuL40oZ.js +0 -1
  1002. package/components/p-WUp_O0u4.js +0 -1
  1003. package/components/p-bcj7UEIC.js +0 -1
  1004. package/components/p-gkooEHol.js +0 -1
  1005. package/components/p-mraQmnXA.js +0 -1
  1006. package/components/p-rBthI1EV.js +0 -1
  1007. package/components/p-t0v_1-tY.js +0 -1
  1008. package/components/p-unwtt2da.js +0 -1
  1009. package/components/p-xCBXKXNq.js +0 -1
  1010. package/components/p-xrAJuWDf.js +0 -1
  1011. package/dist/cjs/animation-D5wGQwTg.js +0 -100
  1012. package/dist/cjs/app-globals-Cu3bQGoC.js +0 -8
  1013. package/dist/cjs/find-element-D7yD1Ukn.js +0 -103
  1014. package/dist/cjs/focus-Cl8_98b5.js +0 -67
  1015. package/dist/cjs/ix-application-sidebar.cjs.entry.js +0 -42
  1016. package/dist/cjs/ix-drawer.cjs.entry.js +0 -166
  1017. package/dist/cjs/ix-dropdown-item.cjs.entry.js +0 -63
  1018. package/dist/cjs/ix-dropdown.cjs.entry.js +0 -436
  1019. package/dist/cjs/ix-input-group.cjs.entry.js +0 -129
  1020. package/dist/cjs/ix-menu-settings-B3zMjM3D.js +0 -128
  1021. package/dist/cjs/ix-pill.cjs.entry.js +0 -87
  1022. package/dist/cjs/ix-tab-item_2.cjs.entry.js +0 -495
  1023. package/dist/cjs/ix-time-picker.cjs.entry.js +0 -689
  1024. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +0 -156
  1025. package/dist/cjs/menu-service-CW0vT80Q.js +0 -83
  1026. package/dist/cjs/modal-BPMUkqrW.js +0 -289
  1027. package/dist/cjs/service-DuiJmf7R.js +0 -104
  1028. package/dist/cjs/setup-icNDj1cf.js +0 -31
  1029. package/dist/cjs/shadow-dom-DT01VwcB.js +0 -48
  1030. package/dist/cjs/theme-switcher-BfjZ3MX8.js +0 -175
  1031. package/dist/cjs/typed-event-DxWATHPL.js +0 -46
  1032. package/dist/collection/components/application-sidebar/application-sidebar.js +0 -68
  1033. package/dist/collection/components/application-sidebar/events.js +0 -14
  1034. package/dist/collection/components/drawer/drawer.js +0 -392
  1035. package/dist/collection/components/input-group/input-group.js +0 -152
  1036. package/dist/collection/components/menu-about-item/menu-about-item.css +0 -12
  1037. package/dist/collection/components/menu-category/enter-leave.js +0 -29
  1038. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +0 -32
  1039. package/dist/collection/components/validation-tooltip/validation-tooltip.css +0 -225
  1040. package/dist/collection/components/validation-tooltip/validation-tooltip.js +0 -251
  1041. package/dist/esm/animation-BLaucX4x.js +0 -98
  1042. package/dist/esm/app-globals-Ciii0tIL.js +0 -6
  1043. package/dist/esm/find-element-CFRrPFxi.js +0 -100
  1044. package/dist/esm/focus-BAKpVknt.js +0 -65
  1045. package/dist/esm/ix-application-sidebar.entry.js +0 -40
  1046. package/dist/esm/ix-drawer.entry.js +0 -164
  1047. package/dist/esm/ix-dropdown-item.entry.js +0 -61
  1048. package/dist/esm/ix-dropdown.entry.js +0 -434
  1049. package/dist/esm/ix-input-group.entry.js +0 -127
  1050. package/dist/esm/ix-menu-settings-BrtDbSQ1.js +0 -123
  1051. package/dist/esm/ix-pill.entry.js +0 -85
  1052. package/dist/esm/ix-tab-item_2.entry.js +0 -492
  1053. package/dist/esm/ix-time-picker.entry.js +0 -687
  1054. package/dist/esm/ix-validation-tooltip.entry.js +0 -154
  1055. package/dist/esm/menu-service-BMvtckRa.js +0 -81
  1056. package/dist/esm/modal-BJAcx3Qd.js +0 -281
  1057. package/dist/esm/service-Da0kv8hS.js +0 -102
  1058. package/dist/esm/setup-eUHKNfBC.js +0 -28
  1059. package/dist/esm/shadow-dom-i60z1FJC.js +0 -43
  1060. package/dist/esm/theme-switcher-CpQ8JvHL.js +0 -172
  1061. package/dist/esm/typed-event-BdCnOrqW.js +0 -44
  1062. package/dist/siemens-ix/p-01283ae6.entry.js +0 -1
  1063. package/dist/siemens-ix/p-048bcd80.entry.js +0 -1
  1064. package/dist/siemens-ix/p-05d31b79.entry.js +0 -1
  1065. package/dist/siemens-ix/p-086cadf8.entry.js +0 -1
  1066. package/dist/siemens-ix/p-18c9b87e.entry.js +0 -1
  1067. package/dist/siemens-ix/p-1b119c78.entry.js +0 -1
  1068. package/dist/siemens-ix/p-1cdd52bc.entry.js +0 -1
  1069. package/dist/siemens-ix/p-23df8fd9.entry.js +0 -1
  1070. package/dist/siemens-ix/p-2441d048.entry.js +0 -1
  1071. package/dist/siemens-ix/p-24947da1.entry.js +0 -1
  1072. package/dist/siemens-ix/p-2b155e81.entry.js +0 -1
  1073. package/dist/siemens-ix/p-2d817735.entry.js +0 -1
  1074. package/dist/siemens-ix/p-3190954f.entry.js +0 -1
  1075. package/dist/siemens-ix/p-359fd705.entry.js +0 -1
  1076. package/dist/siemens-ix/p-3950fb46.entry.js +0 -1
  1077. package/dist/siemens-ix/p-39bab003.entry.js +0 -1
  1078. package/dist/siemens-ix/p-41e6c15a.entry.js +0 -1
  1079. package/dist/siemens-ix/p-44ceb2c5.entry.js +0 -1
  1080. package/dist/siemens-ix/p-46992171.entry.js +0 -1
  1081. package/dist/siemens-ix/p-48f612e5.entry.js +0 -1
  1082. package/dist/siemens-ix/p-49394ea8.entry.js +0 -1
  1083. package/dist/siemens-ix/p-526f3a49.entry.js +0 -1
  1084. package/dist/siemens-ix/p-52edd3f5.entry.js +0 -1
  1085. package/dist/siemens-ix/p-555ee3b3.entry.js +0 -1
  1086. package/dist/siemens-ix/p-57c72eda.entry.js +0 -1
  1087. package/dist/siemens-ix/p-599176fb.entry.js +0 -1
  1088. package/dist/siemens-ix/p-5a69c9e8.entry.js +0 -1
  1089. package/dist/siemens-ix/p-5d1b7333.entry.js +0 -1
  1090. package/dist/siemens-ix/p-5dca1d52.entry.js +0 -1
  1091. package/dist/siemens-ix/p-5f471e1f.entry.js +0 -1
  1092. package/dist/siemens-ix/p-60f84e32.entry.js +0 -1
  1093. package/dist/siemens-ix/p-62156528.entry.js +0 -1
  1094. package/dist/siemens-ix/p-6525aed2.entry.js +0 -1
  1095. package/dist/siemens-ix/p-67eacb9b.entry.js +0 -1
  1096. package/dist/siemens-ix/p-6e6dd3b2.entry.js +0 -1
  1097. package/dist/siemens-ix/p-772b82bc.entry.js +0 -1
  1098. package/dist/siemens-ix/p-77940c84.entry.js +0 -1
  1099. package/dist/siemens-ix/p-7a50b7bc.entry.js +0 -1
  1100. package/dist/siemens-ix/p-7bd3643e.entry.js +0 -1
  1101. package/dist/siemens-ix/p-7c83069f.entry.js +0 -1
  1102. package/dist/siemens-ix/p-7c9f479c.entry.js +0 -1
  1103. package/dist/siemens-ix/p-80d52f41.entry.js +0 -1
  1104. package/dist/siemens-ix/p-83ebc68a.entry.js +0 -1
  1105. package/dist/siemens-ix/p-87ddae31.entry.js +0 -1
  1106. package/dist/siemens-ix/p-8a49d412.entry.js +0 -1
  1107. package/dist/siemens-ix/p-90afea9d.entry.js +0 -1
  1108. package/dist/siemens-ix/p-91b62848.entry.js +0 -1
  1109. package/dist/siemens-ix/p-9432d8bc.entry.js +0 -1
  1110. package/dist/siemens-ix/p-9502ad09.entry.js +0 -1
  1111. package/dist/siemens-ix/p-957439fa.entry.js +0 -1
  1112. package/dist/siemens-ix/p-963a2b1c.entry.js +0 -1
  1113. package/dist/siemens-ix/p-9987b6aa.entry.js +0 -1
  1114. package/dist/siemens-ix/p-9ab70f63.entry.js +0 -1
  1115. package/dist/siemens-ix/p-9b042e1e.entry.js +0 -1
  1116. package/dist/siemens-ix/p-9cc7b831.entry.js +0 -1
  1117. package/dist/siemens-ix/p-9cd5c8fd.entry.js +0 -1
  1118. package/dist/siemens-ix/p-9d26ab4c.entry.js +0 -1
  1119. package/dist/siemens-ix/p-9f22ba26.entry.js +0 -1
  1120. package/dist/siemens-ix/p-BBzEV-f4.js +0 -1
  1121. package/dist/siemens-ix/p-BEPo7U1W.js +0 -2
  1122. package/dist/siemens-ix/p-BH3f5fa3.js +0 -1
  1123. package/dist/siemens-ix/p-BLaucX4x.js +0 -1
  1124. package/dist/siemens-ix/p-BUNsXW03.js +0 -1
  1125. package/dist/siemens-ix/p-BXpulp6I.js +0 -1
  1126. package/dist/siemens-ix/p-BayAOLV_.js +0 -1
  1127. package/dist/siemens-ix/p-BdCnOrqW.js +0 -1
  1128. package/dist/siemens-ix/p-BhgW5qDm.js +0 -1
  1129. package/dist/siemens-ix/p-BncjKdXL.js +0 -1
  1130. package/dist/siemens-ix/p-BtTxCH_z.js +0 -1
  1131. package/dist/siemens-ix/p-BvFOMxgl.js +0 -1
  1132. package/dist/siemens-ix/p-C6fzB3UQ.js +0 -1
  1133. package/dist/siemens-ix/p-CAqtPJ4-.js +0 -1
  1134. package/dist/siemens-ix/p-CFRrPFxi.js +0 -1
  1135. package/dist/siemens-ix/p-CUWFODSd.js +0 -1
  1136. package/dist/siemens-ix/p-CZsAGuDS.js +0 -1
  1137. package/dist/siemens-ix/p-Cv_GwYyx.js +0 -1
  1138. package/dist/siemens-ix/p-D3K9vmFp.js +0 -1
  1139. package/dist/siemens-ix/p-DAzBNVe7.js +0 -1
  1140. package/dist/siemens-ix/p-DKTq7BLY.js +0 -1
  1141. package/dist/siemens-ix/p-EA1w1TTe.js +0 -1
  1142. package/dist/siemens-ix/p-GJWUiWDT.js +0 -1
  1143. package/dist/siemens-ix/p-Tgy1PBFv.js +0 -1
  1144. package/dist/siemens-ix/p-W85AQR46.js +0 -1
  1145. package/dist/siemens-ix/p-a2651024.entry.js +0 -1
  1146. package/dist/siemens-ix/p-a37cd269.entry.js +0 -1
  1147. package/dist/siemens-ix/p-a41f8be4.entry.js +0 -1
  1148. package/dist/siemens-ix/p-a91f7f14.entry.js +0 -1
  1149. package/dist/siemens-ix/p-aa36835f.entry.js +0 -1
  1150. package/dist/siemens-ix/p-ab9cbf10.entry.js +0 -1
  1151. package/dist/siemens-ix/p-ada8618e.entry.js +0 -1
  1152. package/dist/siemens-ix/p-ae55e8e6.entry.js +0 -1
  1153. package/dist/siemens-ix/p-b2bd816c.entry.js +0 -1
  1154. package/dist/siemens-ix/p-b41a3733.entry.js +0 -1
  1155. package/dist/siemens-ix/p-b6ae81a9.entry.js +0 -1
  1156. package/dist/siemens-ix/p-bafa90ed.entry.js +0 -1
  1157. package/dist/siemens-ix/p-bbcef047.entry.js +0 -1
  1158. package/dist/siemens-ix/p-bcj7UEIC.js +0 -1
  1159. package/dist/siemens-ix/p-c187909f.entry.js +0 -1
  1160. package/dist/siemens-ix/p-c94c1d45.entry.js +0 -1
  1161. package/dist/siemens-ix/p-ced4c721.entry.js +0 -1
  1162. package/dist/siemens-ix/p-d3ad73e1.entry.js +0 -1
  1163. package/dist/siemens-ix/p-d3afd82f.entry.js +0 -1
  1164. package/dist/siemens-ix/p-d7086b5a.entry.js +0 -1
  1165. package/dist/siemens-ix/p-d8bc930c.entry.js +0 -1
  1166. package/dist/siemens-ix/p-daadd1ae.entry.js +0 -1
  1167. package/dist/siemens-ix/p-dd3bb443.entry.js +0 -1
  1168. package/dist/siemens-ix/p-df0fc6d4.entry.js +0 -1
  1169. package/dist/siemens-ix/p-e09125fd.entry.js +0 -1
  1170. package/dist/siemens-ix/p-e1978224.entry.js +0 -1
  1171. package/dist/siemens-ix/p-e1c15a19.entry.js +0 -1
  1172. package/dist/siemens-ix/p-e91b7758.entry.js +0 -1
  1173. package/dist/siemens-ix/p-f75eab15.entry.js +0 -1
  1174. package/dist/siemens-ix/p-f7b73fa9.entry.js +0 -1
  1175. package/dist/siemens-ix/p-f8a078e5.entry.js +0 -1
  1176. package/dist/siemens-ix/p-faa0599d.entry.js +0 -1
  1177. package/dist/siemens-ix/p-fb077c75.entry.js +0 -1
  1178. package/dist/siemens-ix/p-fb52d56c.entry.js +0 -1
  1179. package/dist/siemens-ix/p-fb75665a.entry.js +0 -1
  1180. package/dist/siemens-ix/p-fce55dc2.entry.js +0 -1
  1181. package/dist/siemens-ix/p-fe1c3443.entry.js +0 -1
  1182. package/dist/siemens-ix/p-fe5f2f38.entry.js +0 -1
  1183. package/dist/siemens-ix/p-gkooEHol.js +0 -1
  1184. package/dist/siemens-ix/p-i60z1FJC.js +0 -1
  1185. package/dist/types/components/application-sidebar/application-sidebar.d.ts +0 -7
  1186. package/dist/types/components/application-sidebar/events.d.ts +0 -4
  1187. package/dist/types/components/drawer/drawer.d.ts +0 -62
  1188. package/dist/types/components/drawer/test/animejs.mock.d.ts +0 -0
  1189. package/dist/types/components/input-group/input-group.d.ts +0 -25
  1190. package/dist/types/components/menu-category/enter-leave.d.ts +0 -7
  1191. package/dist/types/components/utils/menu-tabs/menu-tabs-fc.d.ts +0 -8
  1192. package/dist/types/components/validation-tooltip/validation-tooltip.d.ts +0 -46
  1193. /package/scss/{_common-variables.scss → misc/_common-variables.scss} +0 -0
  1194. /package/scss/{_normalize.scss → misc/_normalize.scss} +0 -0
  1195. /package/scss/{_z-index.scss → misc/_z-index.scss} +0 -0
@@ -1,11 +1,13 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-Dxeom0qd.js');
3
+ var index = require('./index-BKQkUbyE.js');
4
4
  var breakpoints = require('./breakpoints-C5ZrUCbZ.js');
5
- var index$1 = require('./index-DIYO-Liy.js');
6
5
  var datetime = require('./datetime-CfABwu7I.js');
7
- var listener = require('./listener-BShKJBRB.js');
8
- var makeRef = require('./make-ref-BaH6_YJk.js');
6
+ var component = require('./component-CYtonfpw.js');
7
+ var listener = require('./listener-BafrcTaM.js');
8
+ var shadowDom = require('./shadow-dom-BG8VqeIu.js');
9
+ var timePickerConstraints = require('./time-picker-constraints-CxGhm1qV.js');
10
+ require('./focus-utilities-yx7wWjEO.js');
9
11
 
10
12
  const colCss = () => `:host{position:relative;flex-basis:0;flex-grow:1;width:100%;max-width:100%;min-height:1px;padding:calc(var(--ix-layout-grid-gutter) * 0.5)}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}`;
11
13
 
@@ -13,6 +15,23 @@ const Col = class {
13
15
  constructor(hostRef) {
14
16
  index.registerInstance(this, hostRef);
15
17
  }
18
+ static Breakpoints = ['', 'sm', 'md', 'lg'];
19
+ /**
20
+ * Size of the column
21
+ */
22
+ size;
23
+ /**
24
+ * Size of the column for sm screens
25
+ */
26
+ sizeSm;
27
+ /**
28
+ * Size of the column for md screens
29
+ */
30
+ sizeMd;
31
+ /**
32
+ * Size of the column for lg screens
33
+ */
34
+ sizeLg;
16
35
  onResize() {
17
36
  index.forceUpdate(this);
18
37
  }
@@ -64,13 +83,293 @@ const Col = class {
64
83
  };
65
84
  }
66
85
  render() {
67
- return (index.h(index.Host, { key: '552bf87dd4905b2cfc67dbda7c33e1edf89a9cf8', style: Object.assign({}, this.getColumnSizeStyling()) }, index.h("slot", { key: '293331e4b2de069f550f0d47e1525228e49fc159' })));
86
+ return (index.h(index.Host, { key: '92516eb3dfd8c82f3edd51707861615729ae0d45', style: {
87
+ ...this.getColumnSizeStyling(),
88
+ } }, index.h("slot", { key: '43e5c2cf90ba0f62a01bc47f22420c9d102fd7c4' })));
68
89
  }
69
90
  };
70
- Col.Breakpoints = ['', 'sm', 'md', 'lg'];
71
91
  Col.style = colCss();
72
92
 
73
- const datePickerCss = () => `:host{display:block;position:relative;max-width:21rem}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .header{display:flex;align-items:center;justify-content:space-between}:host .disabled-item{pointer-events:none;background-color:var(--theme-datepicker-day--background--disabled);color:var(--theme-datepicker-day--color--disabled);cursor:default}:host .selector{flex-basis:100%;display:flex;align-items:center;justify-content:center;padding:0 1rem}:host .selector .dropdown{color:var(--theme-menu-item--color);font-size:14px;line-height:20px}:host .selector .capitalize{text-transform:capitalize}:host .selector .month-dropdown-item{margin-left:4px;margin-right:4px}:host .selector .month-dropdown-item:focus-visible{outline:1px solid var(--theme-color-focus-bdr);outline-offset:var(--theme-btn--focus--outline-offset)}:host .selector .arrowYear{display:flex;position:relative;padding:0.75rem 2rem;align-items:center;cursor:pointer}:host .selector .arrowYear:hover{background-color:var(--theme-select-list-item--background--hover)}:host .selector .arrowYear.selected{background-color:var(--theme-select-list-item--background--selected)}:host .selector .arrowYear .arrowPosition{position:absolute;left:calc(1rem - 6px);top:calc(50% - 6px)}:host .selector .arrowYear .checkPosition{position:absolute;left:calc(1rem - 6px);top:calc(50% - 8px)}:host .selector .arrowYear .monthMargin{margin-left:10px}:host .wrapper{display:flex}:host .wrapper .overflow{overflow-y:scroll;max-height:250px}:host .grid{display:grid;grid-template-columns:repeat(7, 40px);grid-template-rows:repeat(7, 40px);align-items:center;justify-items:center;justify-content:center;color:var(--theme-datepicker-today--color)}:host .grid--show-week-numbers{grid-template-columns:24px repeat(7, 40px)}:host .grid .calendar-item{position:relative;display:flex;justify-content:center;align-items:center;background-color:var(--theme-datepicker-day--background);border:1px solid var(--theme-datepicker-day--background);width:40px;height:40px;cursor:pointer}:host .grid .calendar-item:focus-visible{outline:1px solid var(--theme-color-focus-bdr);box-shadow:inset 0 0 0 1px var(--theme-color-inv-contrast-text);background-color:var(--theme-datepicker-day--background--selected);border:inset 1px solid var(--theme-datepicker-day--border-color--selected);color:var(--theme-datepicker-day--color--selected);font-size:14px;line-height:20px;letter-spacing:0}:host .grid .calendar-item.today{border:1px solid var(--theme-datepicker-today--border-color)}:host .grid .calendar-item.today:hover{background-color:var(--theme-datepicker-day--background--hover)}:host .grid .calendar-item.today:active{background-color:var(--theme-datepicker-day--background--active)}:host .grid .calendar-item.today.selected{box-shadow:inset 0 0 0 1px white}:host .grid .calendar-item.today.selected:hover{background-color:var(--theme-datepicker-day--background--selected-hover)}:host .grid .calendar-item.today.selected:active{background-color:var(--theme-datepicker-day--background--selected-active)}:host .grid .calendar-item.today.selected.disabled{pointer-events:none;background-color:var(--theme-datepicker-day--background--selected-disabled);border:1px solid var(--theme-datepicker-day--background--selected-disabled);color:var(--theme-datepicker-day--color--selected-disabled)}:host .grid .calendar-item.today.range{background-color:var(--theme-datepicker-day--background--range);color:var(--theme-datepicker-day--color--range);border:1px solid var(--theme-datepicker-today--border-color--range);box-shadow:inset 0 0 0 1px white}:host .grid .calendar-item.today.range:hover{background-color:var(--theme-datepicker-day--background--range-hover);border:1px solid var(--theme-datepicker-today--border-color--range-hover)}:host .grid .calendar-item.today.range:active{background-color:var(--theme-datepicker-day--background--range-active);border:1px solid var(--theme-datepicker-today--border-color--range-active)}:host .grid .calendar-item.today.range.disabled{background-color:var(--theme-datepicker-day--background--range-disabled);color:var(--theme-datepicker-day--color--range-disabled);border:1px solid var(--theme-datepicker-today--border-color--range-disabled)}:host .grid .calendar-item.today.disabled{pointer-events:none;background-color:var(--theme-datepicker-day--background--disabled);color:var(--theme-datepicker-day--color--disabled);cursor:default}:host .grid .calendar-item:hover{background-color:var(--theme-datepicker-day--background--hover)}:host .grid .calendar-item:active{background-color:var(--theme-datepicker-day--background--active)}:host .grid .calendar-item.selected{background-color:var(--theme-datepicker-day--background--selected);color:var(--theme-datepicker-day--color--selected);border:1px solid var(--theme-datepicker-day--background--selected);font-weight:var(--theme-font-weight-bold)}:host .grid .calendar-item.selected:hover{background-color:var(--theme-datepicker-day--background--selected-hover)}:host .grid .calendar-item.selected:active{background-color:var(--theme-datepicker-day--background--selected-active)}:host .grid .calendar-item.selected.disabled{pointer-events:none;background-color:var(--theme-datepicker-day--background--selected-disabled);color:var(--theme-datepicker-day--color--selected-disabled)}:host .grid .calendar-item.range{background-color:var(--theme-datepicker-day--background--range);color:var(--theme-datepicker-day--color--range)}:host .grid .calendar-item.range:hover{background-color:var(--theme-datepicker-day--background--range-hover)}:host .grid .calendar-item.range:active{background-color:var(--theme-datepicker-day--background--range-active)}:host .grid .calendar-item.range.disabled{pointer-events:none;background-color:var(--theme-datepicker-day--background--range-disabled);color:var(--theme-datepicker-day--color--range-disabled)}:host .grid .calendar-item.disabled{pointer-events:none;background-color:var(--theme-datepicker-day--background--disabled);color:var(--theme-datepicker-day--color--disabled)}:host .grid .calendar-item.week-day{color:var(--theme-datepicker-weekday--color);font-size:var(--theme-ms-0);line-height:143%;border:none;background:none;cursor:initial}:host .grid .calendar-item.week-day .overflow{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:host .grid .calendar-item.empty-day{border:none;background:none;cursor:initial}:host .grid .calendar-item.week-number{font-size:10px;line-height:14px;color:var(--theme-datepicker-weekday--color);border:none;background:none;cursor:initial;width:1.5rem}:host .button{display:flex;justify-content:flex-end;margin-top:1rem}:host .hidden{display:none}`;
93
+ const layoutGridCss = () => `:host{--ix-layout-grid-gutter:24px;display:block;flex:1 1 0%;width:100%;padding-left:calc(var(--ix-layout-grid-gutter) * 0.5);padding-right:calc(var(--ix-layout-grid-gutter) * 0.5)}:host(.no-margin){padding-left:0;padding-right:0}`;
94
+
95
+ const LayoutGrid = class {
96
+ constructor(hostRef) {
97
+ index.registerInstance(this, hostRef);
98
+ }
99
+ /**
100
+ * The grid will not have any horizontal padding
101
+ */
102
+ noMargin = false;
103
+ /**
104
+ * Grid gap
105
+ */
106
+ gap = '24';
107
+ /**
108
+ * Overwrite the default number of columns. Choose between 2 and 12 columns.
109
+ */
110
+ columns = 12;
111
+ render() {
112
+ return (index.h(index.Host, { key: 'ad1e96a96876525cbe9da91c13786d914bb3ce6b', class: {
113
+ 'no-margin': this.noMargin,
114
+ }, style: {
115
+ '--ix-layout-grid-columns': `${this.columns}`,
116
+ '--ix-layout-grid-gutter': `${this.gap}px`,
117
+ } }, index.h("slot", { key: '6eb10f5be8cc7aa38e19e38b33d2b5c07e1fe421' })));
118
+ }
119
+ };
120
+ LayoutGrid.style = layoutGridCss();
121
+
122
+ const rowCss = () => `:host{display:flex;flex-wrap:wrap}:host(:not(:first-of-type)){margin-block-start:var(--ix-layout-grid-row-margin, 0)}`;
123
+
124
+ const Row = class {
125
+ constructor(hostRef) {
126
+ index.registerInstance(this, hostRef);
127
+ }
128
+ render() {
129
+ return (index.h(index.Host, { key: '88036865546dd8f57cac8099b7bef38d6420c722' }, index.h("slot", { key: '948ec4b33c9f03caa4feec78d76f397bd320d045' })));
130
+ }
131
+ };
132
+ Row.style = rowCss();
133
+
134
+ /*
135
+ * SPDX-FileCopyrightText: 2023 Siemens AG
136
+ *
137
+ * SPDX-License-Identifier: MIT
138
+ *
139
+ * This source code is licensed under the MIT license found in the
140
+ * LICENSE file in the root directory of this source tree.
141
+ */
142
+ /**
143
+ * Builds the discrete values shown in each time-picker column.
144
+ */
145
+ function buildTimePickerColumnNumberArrays(intervals, timeRef) {
146
+ const { hourInterval, minuteInterval, secondInterval, millisecondInterval } = intervals;
147
+ let hourNumbers;
148
+ if (timeRef === undefined) {
149
+ hourNumbers = Array.from({ length: Math.ceil(24 / hourInterval) }, (_, i) => i * hourInterval);
150
+ }
151
+ else {
152
+ hourNumbers = Array.from({ length: Math.ceil(12 / hourInterval) }, (_, i) => i * hourInterval + 1).filter((hour) => hour <= 12);
153
+ }
154
+ const minuteNumbers = Array.from({ length: Math.ceil(60 / minuteInterval) }, (_, i) => i * minuteInterval);
155
+ const secondNumbers = Array.from({ length: Math.ceil(60 / secondInterval) }, (_, i) => i * secondInterval);
156
+ const millisecondsNumbers = Array.from({ length: Math.ceil(1000 / millisecondInterval) }, (_, i) => i * millisecondInterval);
157
+ return { hourNumbers, minuteNumbers, secondNumbers, millisecondsNumbers };
158
+ }
159
+
160
+ /*
161
+ * SPDX-FileCopyrightText: 2023 Siemens AG
162
+ *
163
+ * SPDX-License-Identifier: MIT
164
+ *
165
+ * This source code is licensed under the MIT license found in the
166
+ * LICENSE file in the root directory of this source tree.
167
+ */
168
+ function maxValueForNonHourUnit(unit) {
169
+ switch (unit) {
170
+ case 'minute':
171
+ case 'second':
172
+ return 59;
173
+ case 'millisecond':
174
+ return 999;
175
+ case 'hour':
176
+ return 23;
177
+ }
178
+ }
179
+ function mapHourColumnValue(rawValue, timeRef) {
180
+ if (timeRef === 'PM') {
181
+ return {
182
+ value: rawValue === 12 ? 12 : rawValue + 12,
183
+ maxValue: 23,
184
+ };
185
+ }
186
+ if (timeRef === 'AM') {
187
+ return {
188
+ value: rawValue === 12 ? 0 : rawValue,
189
+ maxValue: 11,
190
+ };
191
+ }
192
+ return { value: rawValue, maxValue: 23 };
193
+ }
194
+ /**
195
+ * Applies a raw column value to a base time (including 12h rules).
196
+ */
197
+ function computeTimeWithRawUnitValue(baseTime, unit, rawValue, timeRef) {
198
+ let value;
199
+ let maxValue;
200
+ if (unit === 'hour') {
201
+ const mapped = mapHourColumnValue(rawValue, timeRef);
202
+ value = mapped.value;
203
+ maxValue = mapped.maxValue;
204
+ }
205
+ else {
206
+ value = rawValue;
207
+ maxValue = maxValueForNonHourUnit(unit);
208
+ }
209
+ if (value > maxValue) {
210
+ value = maxValue;
211
+ }
212
+ else if (value < 0) {
213
+ value = 0;
214
+ }
215
+ try {
216
+ return baseTime.set({
217
+ [unit]: value,
218
+ });
219
+ }
220
+ catch {
221
+ return null;
222
+ }
223
+ }
224
+
225
+ /*
226
+ * SPDX-FileCopyrightText: 2023 Siemens AG
227
+ *
228
+ * SPDX-License-Identifier: MIT
229
+ *
230
+ * This source code is licensed under the MIT license found in the
231
+ * LICENSE file in the root directory of this source tree.
232
+ */
233
+ function formatTimePickerUnitValue(unit, value) {
234
+ if (unit === 'millisecond') {
235
+ return value.toString().padStart(3, '0');
236
+ }
237
+ return value < 10 ? `0${value}` : value.toString();
238
+ }
239
+ function getTimePickerColumnSeparator(currentIndex, descriptors) {
240
+ if (currentIndex + 1 < descriptors.length) {
241
+ const nextUnit = descriptors[currentIndex + 1].unit;
242
+ return nextUnit === 'millisecond' ? '.' : ':';
243
+ }
244
+ return ':';
245
+ }
246
+
247
+ /*
248
+ * SPDX-FileCopyrightText: 2023 Siemens AG
249
+ *
250
+ * SPDX-License-Identifier: MIT
251
+ *
252
+ * This source code is licensed under the MIT license found in the
253
+ * LICENSE file in the root directory of this source tree.
254
+ */
255
+ /**
256
+ * Luxon format patterns used to decide which time-picker columns are shown.
257
+ */
258
+ const LUXON_FORMAT_PATTERNS = {
259
+ // h, hh, H, HH and various time formats that include hours
260
+ hours: /\b[Hh]\b|HH|hh|H{3,4}|h{3,4}|t|tt|ttt|tttt|T|TT|TTT|TTTT/,
261
+ // m, mm and time formats that include minutes
262
+ minutes: /\bm\b|mm|t|tt|ttt|tttt|T|TT|TTT|TTTT/,
263
+ // s, ss and time formats that include seconds
264
+ seconds: /\bs\b|ss|tt|ttt|tttt|TT|TTT|TTTT/,
265
+ // S–SSS, u–uuu (fractional seconds); ttt/tttt/TTT/TTTT include sub-second parts
266
+ milliseconds: /S{1,3}|u{1,3}|[tT]{3,4}/,
267
+ };
268
+ /**
269
+ * Whether the Luxon format string uses 12-hour clock semantics for the picker.
270
+ */
271
+ function isFormat12Hour(format) {
272
+ // Remove any text that's inside quotes (literal text in Luxon format strings)
273
+ let cleanFormat = '';
274
+ let inQuote = false;
275
+ for (const char of format) {
276
+ if (char === "'") {
277
+ inQuote = !inQuote;
278
+ }
279
+ else if (!inQuote) {
280
+ cleanFormat += char;
281
+ }
282
+ }
283
+ // Check for specific 12-hour format tokens
284
+ // Case-sensitive matching to distinguish between 'h' and 'H'
285
+ return /[hat]/.test(cleanFormat);
286
+ }
287
+
288
+ /*
289
+ * SPDX-FileCopyrightText: 2023 Siemens AG
290
+ *
291
+ * SPDX-License-Identifier: MIT
292
+ *
293
+ * This source code is licensed under the MIT license found in the
294
+ * LICENSE file in the root directory of this source tree.
295
+ */
296
+ function getCandidateRangeForUnit(unit, candidate) {
297
+ if (!candidate.isValid) {
298
+ return null;
299
+ }
300
+ if (unit === 'hour') {
301
+ return {
302
+ start: candidate.startOf('hour'),
303
+ end: candidate.endOf('hour'),
304
+ };
305
+ }
306
+ if (unit === 'minute') {
307
+ return {
308
+ start: candidate.set({ second: 0, millisecond: 0 }),
309
+ end: candidate.set({ second: 59, millisecond: 999 }),
310
+ };
311
+ }
312
+ if (unit === 'second') {
313
+ return {
314
+ start: candidate.set({ millisecond: 0 }),
315
+ end: candidate.set({ millisecond: 999 }),
316
+ };
317
+ }
318
+ return {
319
+ start: candidate,
320
+ end: candidate,
321
+ };
322
+ }
323
+ function isSelectableForUnitWithinBounds(unit, candidate, bounds) {
324
+ const candidateRange = getCandidateRangeForUnit(unit, candidate);
325
+ if (!candidateRange) {
326
+ return false;
327
+ }
328
+ const { min, max } = bounds;
329
+ const { start, end } = candidateRange;
330
+ if (min && end < min) {
331
+ return false;
332
+ }
333
+ if (max && start > max) {
334
+ return false;
335
+ }
336
+ return true;
337
+ }
338
+
339
+ /*
340
+ * SPDX-FileCopyrightText: 2023 Siemens AG
341
+ *
342
+ * SPDX-License-Identifier: MIT
343
+ *
344
+ * This source code is licensed under the MIT license found in the
345
+ * LICENSE file in the root directory of this source tree.
346
+ */
347
+ /**
348
+ * Moves one step in a ring over `values`, skipping entries where `canSelect`
349
+ * is false (same algorithm as {@link TimePicker#stepFocusedValue}).
350
+ *
351
+ * @returns the next selectable value, or `null` if `values` is empty or no entry is selectable.
352
+ */
353
+ function findNextSelectableRingValue(values, currentValue, direction, canSelect) {
354
+ if (!values.length) {
355
+ return null;
356
+ }
357
+ let idx = values.indexOf(currentValue);
358
+ if (idx === -1) {
359
+ // Start "before" first or "after" last so the first loop advance lands on an array edge.
360
+ idx = direction === 1 ? -1 : values.length;
361
+ }
362
+ for (const _ of values) {
363
+ idx = (idx + direction + values.length) % values.length;
364
+ const candidate = values[idx];
365
+ if (canSelect(candidate)) {
366
+ return candidate;
367
+ }
368
+ }
369
+ return null;
370
+ }
371
+
372
+ const timePickerCss = () => `.ix-form-control,.ix-form-control-plaintext{color:var(--theme-input--color);border-radius:var(--theme-input--border-radius);height:2rem;min-height:2rem;min-width:2rem;background-color:var(--theme-input--background);border:solid 1px var(--theme-input--border-color);box-shadow:var(--theme-input--box-shadow);padding-inline-start:0.5rem;padding-inline-end:0.5rem;font-family:Siemens Sans, sans-serif;font-size:0.875rem;font-weight:400;line-height:1.429em;color:var(--theme-color-std-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smooting:grayscale;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ix-form-control::-moz-placeholder,.ix-form-control-plaintext::-moz-placeholder{color:var(--theme-input-hint--color)}.ix-form-control::placeholder,.ix-form-control-plaintext::placeholder{color:var(--theme-input-hint--color)}.ix-form-control:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled),.ix-form-control-plaintext:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled){cursor:pointer}.ix-form-control:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled),.ix-form-control-plaintext:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled){cursor:pointer}.ix-form-control:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):hover,.ix-form-control:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled).hover,.ix-form-control-plaintext:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):hover,.ix-form-control-plaintext:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled).hover{background-color:var(--theme-input--background--hover);border-color:var(--theme-input--border-color--hover);cursor:auto}.ix-form-control:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):hover,.ix-form-control:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled).hover,.ix-form-control-plaintext:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):hover,.ix-form-control-plaintext:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled).hover{background-color:var(--theme-input--background--hover);border-color:var(--theme-input--border-color--hover);cursor:auto}.ix-form-control:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):focus-visible,.ix-form-control-plaintext:not(:-moz-read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):focus-visible{background-color:var(--theme-input--background--focus);border-color:var(--theme-input--border-color--focus);outline-offset:var(--theme-input--focus--outline-offset);box-shadow:var(--theme-input--box-shadow);outline:1px solid var(--theme-color-focus-bdr)}.ix-form-control:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):focus-visible,.ix-form-control-plaintext:not(:read-only):not([readonly]):not([readOnly]):not(.readonly):not(.disabled):not(:disabled):focus-visible{background-color:var(--theme-input--background--focus);border-color:var(--theme-input--border-color--focus);outline-offset:var(--theme-input--focus--outline-offset);box-shadow:var(--theme-input--box-shadow);outline:1px solid var(--theme-color-focus-bdr)}.ix-form-control:focus-visible{color:var(--theme-input--color)}.ix-form-control[type=number]::-webkit-inner-spin-button{margin-right:-2px;margin-left:2px;display:none}.ix-form-control[type=number]{text-align:right}.ix-form-control.readonly,.ix-form-control[readonly]{background:transparent !important;border-block-start:none !important;border-inline-start:none !important;border-inline-end:none !important;border-radius:0rem}.ix-form-control:-moz-read-only{box-shadow:none !important;outline:none !important;border-color:var(--theme-input--border-color);cursor:default !important}.ix-form-control:read-only,.ix-form-control[readonly],.ix-form-control[readOnly],.ix-form-control.readonly{box-shadow:none !important;outline:none !important;border-color:var(--theme-input--border-color);cursor:default !important}.ix-form-control:read-only::-moz-placeholder,.ix-form-control[readonly]::-moz-placeholder,.ix-form-control[readOnly]::-moz-placeholder,.ix-form-control.readonly::-moz-placeholder{color:transparent}.ix-form-control:-moz-read-only::placeholder{color:transparent}.ix-form-control:read-only::placeholder,.ix-form-control[readonly]::placeholder,.ix-form-control[readOnly]::placeholder,.ix-form-control.readonly::placeholder{color:transparent}.ix-form-control:disabled,.ix-form-control.disabled{background:transparent !important;border-block-start:none !important;border-inline-start:none !important;border-inline-end:none !important;border-radius:0rem;color:var(--theme-color-weak-text);border-color:var(--theme-input--border-color-bottom--disabled)}.ix-form-control:disabled::-moz-placeholder,.ix-form-control.disabled::-moz-placeholder{color:transparent}.ix-form-control:disabled::placeholder,.ix-form-control.disabled::placeholder{color:transparent}.ix-form-control-plaintext{outline:0}.form-group{position:relative}.input-wrapper{display:flex;position:relative;align-items:center;flex-wrap:nowrap}.input-wrapper>.glyph{display:block;position:absolute;margin-inline-start:0.312rem;color:var(--theme-color-std-text)}.input-wrapper>input{padding-inline-start:2.2rem}select.ix-form-control{padding:0 0.312rem}textarea.ix-form-control{padding:0.375rem 0.5rem}input.ix-form-control.disabled,input.ix-form-control:disabled{color:var(--theme-input--color--disabled)}input.ix-form-control:-moz-read-only{cursor:default}input.ix-form-control:read-only,input.ix-form-control.readonly{cursor:default}input{min-height:2rem;width:auto;padding:0.25rem 0.5rem;background-color:var(--theme-input--background);color:var(--theme-input--color);-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield;text-overflow:ellipsis;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color);border-radius:var(--theme-input--border-radius);box-shadow:var(--theme-input--box-shadow);font-feature-settings:"clig" off, "liga" off;font-family:Siemens Sans, Siemens Sans, Arial, Helvetica, sans-serif;font-style:normal;font-size:var(--theme-ms-0);line-height:var(--theme-line-height-md);font-weight:var(--theme-font-weight-normal);letter-spacing:var(--theme-letter-spacing-xl);text-decoration:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smooting:grayscale}input[type=number]{text-align:right}input[type=number]::-webkit-inner-spin-button{margin-right:-2px;margin-left:2px;display:none}input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--theme-color-component-info) inset !important;-webkit-text-fill-color:var(--theme-input--color--autofill) !important;background-color:var(--theme-input--background--autofill) !important;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color--autofill) !important;color:var(--theme-input--color--autofill) !important}input:-webkit-autofill,input:autofill{-webkit-box-shadow:0 0 0 1000px var(--theme-color-component-info) inset !important;-webkit-text-fill-color:var(--theme-input--color--autofill) !important;background-color:var(--theme-input--background--autofill) !important;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color--autofill) !important;color:var(--theme-input--color--autofill) !important}input::-moz-placeholder{color:var(--theme-input-hint--color)}input::placeholder{color:var(--theme-input-hint--color)}input.hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only),input:hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only){border-color:var(--theme-input--border-color--hover) !important;background-color:var(--theme-input--background--hover)}input.hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only),input:hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only){border-color:var(--theme-input--border-color--hover) !important;background-color:var(--theme-input--background--hover)}input.focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only),input:focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only){outline:1px solid var(--theme-color-focus-bdr);outline-offset:var(--theme-input--focus--outline-offset);border-color:var(--theme-input--border-color--focus) !important}input.focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only),input:focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only){outline:1px solid var(--theme-color-focus-bdr);outline-offset:var(--theme-input--focus--outline-offset);border-color:var(--theme-input--border-color--focus) !important}input:-moz-read-only{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--readonly)}input.read-only,input:read-only{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--readonly)}input.read-only::-moz-placeholder,input:read-only::-moz-placeholder{color:transparent}input:-moz-read-only::placeholder{color:transparent}input.read-only::placeholder,input:read-only::placeholder{color:transparent}input:disabled,input.disabled{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--disabled)}input:disabled::-moz-placeholder,input.disabled::-moz-placeholder{color:transparent}input:disabled::placeholder,input.disabled::placeholder{color:transparent}textarea{min-height:2rem;width:auto;padding:0.25rem 0.5rem;background-color:var(--theme-input--background);color:var(--theme-input--color);-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield;text-overflow:ellipsis;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color);border-radius:var(--theme-input--border-radius);box-shadow:var(--theme-input--box-shadow);font-feature-settings:"clig" off, "liga" off;font-family:Siemens Sans, Siemens Sans, Arial, Helvetica, sans-serif;font-style:normal;font-size:var(--theme-ms-0);line-height:var(--theme-line-height-md);font-weight:var(--theme-font-weight-normal);letter-spacing:var(--theme-letter-spacing-xl);text-decoration:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smooting:grayscale}textarea[type=number]{text-align:right}textarea[type=number]::-webkit-inner-spin-button{margin-right:-2px;margin-left:2px;display:none}textarea:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--theme-color-component-info) inset !important;-webkit-text-fill-color:var(--theme-input--color--autofill) !important;background-color:var(--theme-input--background--autofill) !important;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color--autofill) !important;color:var(--theme-input--color--autofill) !important}textarea:-webkit-autofill,textarea:autofill{-webkit-box-shadow:0 0 0 1000px var(--theme-color-component-info) inset !important;-webkit-text-fill-color:var(--theme-input--color--autofill) !important;background-color:var(--theme-input--background--autofill) !important;border:var(--theme-input--border-thickness, 1px) solid var(--theme-input--border-color--autofill) !important;color:var(--theme-input--color--autofill) !important}textarea::-moz-placeholder{color:var(--theme-input-hint--color)}textarea::placeholder{color:var(--theme-input-hint--color)}textarea.hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only),textarea:hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only){border-color:var(--theme-input--border-color--hover) !important;background-color:var(--theme-input--background--hover)}textarea.hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only),textarea:hover:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only){border-color:var(--theme-input--border-color--hover) !important;background-color:var(--theme-input--background--hover)}textarea.focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only),textarea:focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:-moz-read-only){outline:1px solid var(--theme-color-focus-bdr);outline-offset:var(--theme-input--focus--outline-offset);border-color:var(--theme-input--border-color--focus) !important}textarea.focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only),textarea:focus:not(.readonly,.read-only,.disabled,[readonly],[disabled],:read-only){outline:1px solid var(--theme-color-focus-bdr);outline-offset:var(--theme-input--focus--outline-offset);border-color:var(--theme-input--border-color--focus) !important}textarea:-moz-read-only{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--readonly)}textarea.read-only,textarea:read-only{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--readonly)}textarea.read-only::-moz-placeholder,textarea:read-only::-moz-placeholder{color:transparent}textarea:-moz-read-only::placeholder{color:transparent}textarea.read-only::placeholder,textarea:read-only::placeholder{color:transparent}textarea:disabled,textarea.disabled{box-shadow:none;background-color:transparent;outline:none;border:var(--theme-input--border-thickness) solid var(--theme-input--border-color--disabled)}textarea:disabled::-moz-placeholder,textarea.disabled::-moz-placeholder{color:transparent}textarea:disabled::placeholder,textarea.disabled::placeholder{color:transparent}textarea{min-height:2rem;padding:calc(0.375rem - var(--theme-input--border-thickness)) calc(0.5rem - var(--theme-input--border-thickness))}textarea:not([rows]){height:3.25rem}textarea.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]),input.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]){border-color:var(--theme-input--border-color--info)}textarea.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover,input.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover{border-color:var(--theme-input--border-color--info--hover) !important}textarea.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active,input.ix-info:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active{border-color:var(--theme-input--border-color--info--active) !important}textarea.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]),input.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]){background-color:var(--theme-input--background--warning);border-color:var(--theme-input--border-color--warning--active) !important}textarea.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover,input.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover{background-color:var(--theme-input--background--warning--hover);border-color:var(--theme-input--border-color--warning--hover) !important}textarea.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active,input.ix-warning:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active{border-color:var(--theme-input--border-color--warning--active) !important}textarea[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]),input[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]){background-color:var(--theme-input--background--invalid);border-color:var(--theme-input--border-color--invalid) !important}textarea[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover,input[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):hover{background-color:var(--theme-input--background--invalid--hover);border-color:var(--theme-input--border-color--invalid--hover) !important}textarea[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active,input[class*=ix-invalid]:not(.disabled):not(:disabled):not([disabled]):not(.readonly):not([readonly]):active{border-color:var(--theme-input--border-color--invalid--active) !important}:host{display:block;position:relative;width:-moz-fit-content;width:fit-content}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .standaloneAppearance{box-shadow:none}:host .hidden{display:none}:host .header{display:flex;align-items:center;justify-content:center;height:2rem}:host .clock{display:flex;justify-content:center;align-items:start}:host .clock .flex{display:flex;height:100%;align-items:start}:host .clock .flex .columns{display:flex;flex-direction:column;align-items:center;justify-content:space-around}:host .clock .flex .columns .column-header{height:2.5rem;width:2.5rem;line-height:2.5rem;text-align:center;color:var(--theme-color-soft-text);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}:host .clock .flex .column-separator{display:flex;align-items:center;justify-content:center;min-height:100%;margin-top:3rem;width:0.5rem}:host .clock .element-list{list-style-type:none;overflow:auto;padding:0.0625rem;margin:-0.0625rem;max-height:15.75rem}:host .clock .element-list button{all:unset}:host .clock .element-list .element-container{box-sizing:border-box;width:2.5rem;height:2.5rem;margin-bottom:0.125rem;display:flex;justify-content:center;align-items:center;cursor:pointer;color:var(--theme-color-primary)}:host .clock .element-list .element-container:hover:not(.disabled){background-color:var(--theme-datepicker-day--background--hover)}:host .clock .element-list .element-container:focus-visible{box-shadow:0 0 0 1px var(--theme-color-focus-bdr)}:host .clock .element-list .element-container.disabled{cursor:default}:host .clock .element-list .element-container.disabled:not(.selected){color:var(--theme-color-weak-text)}:host .clock .element-list .element-container:not(.selected).disabled:hover,:host .clock .element-list .element-container:not(.selected).disabled:active{background-color:transparent}:host .clock .element-list .element-container.selected{background-color:var(--theme-datepicker-day--background--selected);color:var(--theme-datepicker-day--color--selected);font-weight:var(--theme-font-weight-bold)}:host .clock .element-list .element-container.selected:hover:not(.disabled){background-color:var(--theme-datepicker-day--background--selected-hover)}:host .clock .element-list .element-container.selected:focus-visible{border:0.0625rem solid var(--theme-color-inv-contrast-text)}:host .clock .element-list .element-container.selected.disabled{background-color:var(--theme-datepicker-day--background--selected-disabled);color:var(--theme-datepicker-day--color--selected-disabled)}:host .clock .element-list .element-list-padding{width:2.5rem;height:13.125rem;min-height:13.125rem}:host .clock div.element-list{scrollbar-width:none;-ms-overflow-style:none}:host .clock div.element-list::-webkit-scrollbar{display:none}:host .footer{display:flex;justify-content:space-between;gap:0.5rem;flex-wrap:wrap}:host .footer .confirm-button{margin-left:auto}:host .footer--compact{flex-direction:column;align-items:center}:host .footer--compact .confirm-button{margin-left:initial}:host .default-space{margin-left:1rem}:host .text-align{text-align:center}`;
74
373
 
75
374
  /*
76
375
  * SPDX-FileCopyrightText: 2023 Siemens AG
@@ -90,579 +389,894 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta
90
389
  r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
91
390
  return c > 3 && r && Object.defineProperty(target, key, r), r;
92
391
  };
93
- const DatePicker = class {
392
+ const HOUR_INTERVAL_DEFAULT = 1;
393
+ const MINUTE_INTERVAL_DEFAULT = 1;
394
+ const SECOND_INTERVAL_DEFAULT = 1;
395
+ const MILLISECOND_INTERVAL_DEFAULT = 100;
396
+ const CONFIRM_BUTTON_DEFAULT = 'Confirm';
397
+ const HEADER_DEFAULT = 'Time';
398
+ const FORMATTED_TIME_EMPTY = {
399
+ hour: '',
400
+ minute: '',
401
+ second: '',
402
+ millisecond: '',
403
+ };
404
+ const TimePicker = class extends index.Mixin(...component.DefaultMixins) {
94
405
  constructor(hostRef) {
406
+ super();
95
407
  index.registerInstance(this, hostRef);
96
- this.dateChange = index.createEvent(this, "dateChange", 7);
97
- this.dateRangeChange = index.createEvent(this, "dateRangeChange", 7);
98
- this.dateSelect = index.createEvent(this, "dateSelect", 7);
99
- /**
100
- * Date format string.
101
- * See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
102
- */
103
- this.format = 'yyyy/LL/dd';
104
- /**
105
- * If true, disables date range selection (from/to).
106
- */
107
- this.singleSelection = false;
108
- /**
109
- * Corner style.
110
- */
111
- this.corners = 'rounded';
112
- /**
113
- * The earliest date that can be selected by the date picker.
114
- * If not set there will be no restriction.
115
- */
116
- this.minDate = '';
117
- /**
118
- * The latest date that can be selected by the date picker.
119
- * If not set there will be no restriction.
120
- */
121
- this.maxDate = '';
122
- /**
123
- * Text of the date select button.
124
- */
125
- this.i18nDone = 'Done';
126
- /**
127
- * ARIA label for the previous month icon button.
128
- * Will be set as aria-label on the nested HTML button element.
129
- */
130
- this.ariaLabelPreviousMonthButton = 'Previous month';
131
- /**
132
- * ARIA label for the next month icon button.
133
- * Will be set as aria-label on the nested HTML button element.
134
- */
135
- this.ariaLabelNextMonthButton = 'Next month';
136
- /**
137
- * The index of which day to start the week on, based on the Locale#weekdays array.
138
- * E.g. if the locale is en-us, weekStartIndex = 1 results in starting the week on Monday.
139
- */
140
- this.weekStartIndex = 0;
141
- /**
142
- * Shows week numbers displayed on the left side of the date picker.
143
- *
144
- * @since 3.0.0
145
- */
146
- this.showWeekNumbers = false;
147
- /** @internal */
148
- this.embedded = false;
149
- /** @internal */
150
- this.today = datetime.DateTime.now().toISO();
151
- /**
152
- * Enable Popover API rendering for dropdown.
153
- *
154
- * @default false
155
- * @since 4.3.0
156
- */
157
- this.enableTopLayer = false;
158
- this.selectedYear = 0;
159
- this.tempYear = 0;
160
- this.startYear = 0;
161
- this.endYear = 0;
162
- this.selectedMonth = 0;
163
- this.tempMonth = 0;
164
- this.dropdownButtonRef = makeRef.makeRef();
165
- this.yearContainerRef = makeRef.makeRef();
166
- this.firstMonthRef = makeRef.makeRef();
167
- this.focusedDay = 1;
168
- this.isDayFocus = false;
169
- this.monthChangedFromFocus = false;
170
- this.DAYS_IN_WEEK = 7;
171
- this.calendar = [];
172
- }
173
- watchFromPropHandler(newValue) {
408
+ this.timeSelect = index.createEvent(this, "timeSelect", 7);
409
+ this.timeChange = index.createEvent(this, "timeChange", 7);
410
+ }
411
+ get hostElement() { return index.getElement(this); }
412
+ /**
413
+ * Format of time string.
414
+ * See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
415
+ * Note: Formats that combine date and time (like f or F) are not supported. Timestamp tokens x and X are not supported either.
416
+ */
417
+ format = 'TT';
418
+ watchFormatIntervalPropHandler(newValue) {
174
419
  if (!newValue) {
175
- this.currFromDate = undefined;
176
420
  return;
177
421
  }
178
- const date = this.parseDateString(newValue);
179
- if (date) {
180
- this.currFromDate = date;
181
- this.updateSelectedYearMonth(date);
422
+ this.initPicker();
423
+ this.updateScrollPositions();
424
+ }
425
+ /**
426
+ * Corner style.
427
+ */
428
+ corners = 'rounded';
429
+ /**
430
+ * Embedded style (for use in other components).
431
+ */
432
+ embedded = false;
433
+ /**
434
+ * @internal Temporary prop needed until datetime-picker is reworked for new design.
435
+ */
436
+ dateTimePickerAppearance = false;
437
+ /**
438
+ * Hides the header of the picker.
439
+ *
440
+ * @since 3.2.0
441
+ */
442
+ hideHeader = false;
443
+ /**
444
+ * Interval for hour selection.
445
+ *
446
+ * @since 3.2.0
447
+ */
448
+ hourInterval = HOUR_INTERVAL_DEFAULT;
449
+ watchHourIntervalPropHandler(newValue) {
450
+ if (Number.isInteger(newValue) &&
451
+ newValue >= 0 &&
452
+ newValue <= (this.timeRef ? 12 : 23)) {
453
+ this.setTimePickerDescriptors();
454
+ return;
182
455
  }
456
+ this.printIntervalError('hour', newValue);
457
+ this.hourInterval = HOUR_INTERVAL_DEFAULT;
183
458
  }
184
- watchToPropHandler(newValue) {
185
- if (!newValue) {
186
- this.currToDate = undefined;
459
+ /**
460
+ * Interval for minute selection.
461
+ *
462
+ * @since 3.2.0
463
+ */
464
+ minuteInterval = MINUTE_INTERVAL_DEFAULT;
465
+ watchMinuteIntervalPropHandler(newValue) {
466
+ if (newValue >= 0 && newValue <= 59) {
467
+ this.setTimePickerDescriptors();
468
+ return;
469
+ }
470
+ this.printIntervalError('minute', newValue);
471
+ this.minuteInterval = MINUTE_INTERVAL_DEFAULT;
472
+ }
473
+ /**
474
+ * Interval for second selection.
475
+ *
476
+ * @since 3.2.0
477
+ */
478
+ secondInterval = SECOND_INTERVAL_DEFAULT;
479
+ watchSecondIntervalPropHandler(newValue) {
480
+ if (newValue >= 0 && newValue <= 59) {
481
+ this.setTimePickerDescriptors();
187
482
  return;
188
483
  }
189
- const date = this.parseDateString(newValue);
190
- if (date) {
191
- this.currToDate = date;
192
- this.updateSelectedYearMonth(date);
484
+ this.printIntervalError('second', newValue);
485
+ this.secondInterval = SECOND_INTERVAL_DEFAULT;
486
+ }
487
+ /**
488
+ * Interval for millisecond selection.
489
+ *
490
+ * @since 3.2.0
491
+ */
492
+ millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
493
+ watchMillisecondIntervalPropHandler(newValue) {
494
+ if (newValue >= 0 && newValue <= 999) {
495
+ this.setTimePickerDescriptors();
496
+ return;
193
497
  }
498
+ this.printIntervalError('millisecond', newValue);
499
+ this.millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
500
+ }
501
+ printIntervalError(intervalName, value) {
502
+ console.error(`Value ${value} is not valid for ${intervalName}-interval. Falling back to default.`);
194
503
  }
195
- onLocaleChange() {
196
- this.setTranslations();
504
+ warnIfConstraintTimeInvalid(prop, value, omitUnparsableWarning) {
505
+ const trimmed = value?.trim();
506
+ if (!trimmed) {
507
+ return;
508
+ }
509
+ const parsed = datetime.DateTime.fromFormat(trimmed, this.format);
510
+ if (parsed.isValid) {
511
+ return;
512
+ }
513
+ if (omitUnparsableWarning) {
514
+ return;
515
+ }
516
+ const detail = [parsed.invalidReason, parsed.invalidExplanation]
517
+ .filter(Boolean)
518
+ .join(': ');
519
+ console.warn(`[ix-time-picker] ${prop}="${trimmed}" does not match format "${this.format}". ` +
520
+ 'The constraint is ignored until the value matches `format`.' +
521
+ (detail ? ` (${detail})` : ''));
522
+ }
523
+ warnIfConstraintRangeInverted(minValue, maxValue) {
524
+ const minTrimmed = minValue?.trim();
525
+ const maxTrimmed = maxValue?.trim();
526
+ if (!minTrimmed || !maxTrimmed) {
527
+ return;
528
+ }
529
+ const minParsed = datetime.DateTime.fromFormat(minTrimmed, this.format);
530
+ const maxParsed = datetime.DateTime.fromFormat(maxTrimmed, this.format);
531
+ if (!minParsed.isValid || !maxParsed.isValid) {
532
+ return;
533
+ }
534
+ if (minParsed > maxParsed) {
535
+ console.warn(`[ix-time-picker] minTime="${minTrimmed}" is later than maxTime="${maxTrimmed}" for format "${this.format}". ` +
536
+ 'Both constraints are ignored.');
537
+ }
538
+ }
539
+ warnConstraintTimesIfInvalid(options) {
540
+ const omit = options?.omitUnparsableConstraintWarnings ?? false;
541
+ this.warnIfConstraintTimeInvalid('minTime', this.minTime, omit);
542
+ this.warnIfConstraintTimeInvalid('maxTime', this.maxTime, omit);
543
+ this.warnIfConstraintRangeInverted(this.minTime, this.maxTime);
197
544
  }
198
545
  /**
199
- * Get the currently selected date or range. The object returned contains `from` and `to` properties.
200
- * The property strings are formatted according to the `format` property and not affected by the `locale` property.
201
- * The locale applied is always `en-US`.
546
+ * Selected time value.
547
+ * Format has to match the `format` property.
202
548
  */
203
- async getCurrentDate() {
204
- var _a, _b, _c, _d;
205
- const _from = ((_a = this.currFromDate) === null || _a === void 0 ? void 0 : _a.isValid)
206
- ? (_b = this.currFromDate) === null || _b === void 0 ? void 0 : _b.toFormat(this.format)
207
- : undefined;
208
- const _to = ((_c = this.currToDate) === null || _c === void 0 ? void 0 : _c.isValid)
209
- ? (_d = this.currToDate) === null || _d === void 0 ? void 0 : _d.toFormat(this.format)
210
- : undefined;
211
- if (!this.singleSelection) {
212
- return {
213
- from: _from,
214
- to: _to,
215
- };
549
+ time;
550
+ watchTimePropHandler(newValue) {
551
+ if (newValue === undefined || newValue === '') {
552
+ this._time = this.getDefaultTime();
553
+ return;
554
+ }
555
+ const timeFormat = datetime.DateTime.fromFormat(newValue, this.format);
556
+ if (!timeFormat.isValid) {
557
+ throw new Error('Format is not supported or not correct');
558
+ }
559
+ this._time = timeFormat;
560
+ }
561
+ /** Earliest selectable time (`format` tokens). Invalid non-empty values are ignored.
562
+ *
563
+ * @since 5.0.0 */
564
+ minTime;
565
+ /** Latest selectable time (`format` tokens). Invalid non-empty values are ignored.
566
+ *
567
+ * @since 5.0.0 */
568
+ maxTime;
569
+ watchMinTimePropHandler() {
570
+ this.warnConstraintTimesIfInvalid();
571
+ this.syncKeyboardFocusWithConstraints();
572
+ }
573
+ watchMaxTimePropHandler() {
574
+ this.warnConstraintTimesIfInvalid();
575
+ this.syncKeyboardFocusWithConstraints();
576
+ }
577
+ /**
578
+ * Get default time value
579
+ * @returns DateTime.now() for empty state (no selection)
580
+ */
581
+ getDefaultTime() {
582
+ return datetime.DateTime.now();
583
+ }
584
+ /**
585
+ * Text of the time confirm button.
586
+ */
587
+ i18nConfirmTime = CONFIRM_BUTTON_DEFAULT;
588
+ /**
589
+ * Text for the top header.
590
+ */
591
+ i18nHeader = HEADER_DEFAULT;
592
+ /**
593
+ * Text for the hour column header.
594
+ */
595
+ i18nHourColumnHeader = 'hr';
596
+ /**
597
+ * Text for the minute column header.
598
+ */
599
+ // eslint-disable-next-line @stencil-community/decorators-style
600
+ i18nMinuteColumnHeader = 'min';
601
+ /**
602
+ * Text for the second column header.
603
+ */
604
+ // eslint-disable-next-line @stencil-community/decorators-style
605
+ i18nSecondColumnHeader = 'sec';
606
+ /**
607
+ * Text for the millisecond column header.
608
+ */
609
+ // eslint-disable-next-line @stencil-community/decorators-style
610
+ i18nMillisecondColumnHeader = 'ms';
611
+ /**
612
+ * Time event. Emitted when the user confirms the selected time.
613
+ */
614
+ timeSelect;
615
+ /**
616
+ * Time change event. Emitted when the selected time changes while interacting with the picker.
617
+ */
618
+ timeChange;
619
+ /**
620
+ * Get the current time based on the wanted format
621
+ */
622
+ async getCurrentTime() {
623
+ return this._time?.toFormat(this.format);
624
+ }
625
+ _time;
626
+ onTimeChange() {
627
+ const formattedTimeOld = this.formattedTime;
628
+ this.setTimeRef();
629
+ this.formattedTime = this.getFormattedTime();
630
+ this.updateScrollPositions(formattedTimeOld);
631
+ }
632
+ timeRef;
633
+ formattedTime = FORMATTED_TIME_EMPTY;
634
+ timePickerDescriptors = [];
635
+ isUnitFocused = false;
636
+ focusedUnit = 'hour';
637
+ focusedValue = 0;
638
+ visibilityObserver;
639
+ focusScrollAlignment = 'start';
640
+ componentWillLoad() {
641
+ this.initPicker();
642
+ }
643
+ initPicker() {
644
+ let parsedTime;
645
+ let timePropDoesNotMatchFormat = false;
646
+ if (this.time) {
647
+ parsedTime = datetime.DateTime.fromFormat(this.time, this.format);
648
+ if (!parsedTime.isValid) {
649
+ timePropDoesNotMatchFormat = true;
650
+ console.error(`Invalid time format. The configured format does not match the format of the passed time. ${parsedTime.invalidReason}: ${parsedTime.invalidExplanation}`);
651
+ parsedTime = this.getDefaultTime();
652
+ }
653
+ }
654
+ else {
655
+ parsedTime = this.getDefaultTime();
656
+ }
657
+ this._time = parsedTime;
658
+ this.setTimeRef();
659
+ this.formattedTime = this.getFormattedTime();
660
+ this.setTimePickerDescriptors();
661
+ this.setInitialFocusedValueAndUnit();
662
+ this.watchHourIntervalPropHandler(this.hourInterval);
663
+ this.watchMinuteIntervalPropHandler(this.minuteInterval);
664
+ this.watchSecondIntervalPropHandler(this.secondInterval);
665
+ this.watchMillisecondIntervalPropHandler(this.millisecondInterval);
666
+ this.warnConstraintTimesIfInvalid({
667
+ omitUnparsableConstraintWarnings: timePropDoesNotMatchFormat,
668
+ });
669
+ }
670
+ componentDidLoad() {
671
+ super.componentDidLoad?.();
672
+ this.updateScrollPositions();
673
+ this.setupVisibilityObserver();
674
+ }
675
+ componentDidRender() {
676
+ if (!this.isUnitFocused) {
677
+ return;
678
+ }
679
+ const elementContainer = this.getElementContainer(this.focusedUnit, this.focusedValue);
680
+ const elementList = this.getElementList(this.focusedUnit);
681
+ if (!elementContainer) {
682
+ return;
683
+ }
684
+ if (component.hasKeyboardMode()) {
685
+ const active = this.hostElement.shadowRoot?.activeElement;
686
+ if (active !== elementContainer) {
687
+ elementContainer.focus({ preventScroll: true });
688
+ }
689
+ }
690
+ if (!this.isElementVisible(elementContainer, elementList)) {
691
+ this.scrollElementIntoView(elementContainer, elementList, this.focusScrollAlignment);
692
+ }
693
+ }
694
+ disconnectedCallback() {
695
+ if (this.visibilityObserver) {
696
+ this.visibilityObserver.disconnect();
216
697
  }
217
- return {
218
- from: _from,
219
- to: undefined,
220
- };
221
698
  }
222
- handleKeyUp(event) {
223
- if (!this.isDayFocus) {
699
+ handleKeyDown(event) {
700
+ if (!this.isUnitFocused) {
224
701
  return;
225
702
  }
226
- let _focusedDay = this.focusedDay;
703
+ let shouldPreventDefault = true;
227
704
  switch (event.key) {
228
- case 'ArrowLeft':
229
- _focusedDay--;
230
- break;
231
- case 'ArrowRight':
232
- _focusedDay++;
705
+ case 'Tab':
706
+ shouldPreventDefault = false;
707
+ this.isUnitFocused = false;
233
708
  break;
234
709
  case 'ArrowUp':
235
- _focusedDay = _focusedDay - 7;
710
+ this.focusScrollAlignment = 'start';
711
+ this.stepFocusedValue(-1);
236
712
  break;
237
713
  case 'ArrowDown':
238
- _focusedDay = _focusedDay + 7;
714
+ this.focusScrollAlignment = 'end';
715
+ this.stepFocusedValue(1);
716
+ break;
717
+ case 'Enter':
718
+ case ' ': {
719
+ const { bounds } = this.getUnitSelectionContext();
720
+ const base = this.buildCandidateBaseBeforeUnit(this.focusedUnit);
721
+ if (this.canSelectUnitValue(this.focusedUnit, this.focusedValue, bounds, base)) {
722
+ this.select(this.focusedUnit, this.focusedValue);
723
+ }
239
724
  break;
725
+ }
240
726
  default:
241
727
  return;
242
728
  }
243
- if (_focusedDay > this.getDaysInCurrentMonth()) {
244
- _focusedDay = _focusedDay - this.getDaysInCurrentMonth();
245
- this.changeToAdjacentMonth(1);
246
- this.monthChangedFromFocus = true;
247
- }
248
- else if (_focusedDay < 1) {
249
- this.changeToAdjacentMonth(-1);
250
- _focusedDay = _focusedDay + this.getDaysInCurrentMonth();
251
- this.monthChangedFromFocus = true;
729
+ if (shouldPreventDefault) {
730
+ event.preventDefault();
252
731
  }
253
- this.focusedDay = _focusedDay;
254
- }
255
- getDaysInCurrentMonth() {
256
- return (datetime.DateTime.utc(this.selectedYear, this.selectedMonth + 1).daysInMonth || 0);
257
732
  }
258
- getDateTimeNow() {
259
- return datetime.DateTime.fromISO(this.today);
260
- }
261
- parseDateString(dateString) {
262
- const date = datetime.DateTime.fromFormat(dateString, this.format);
263
- if (!date.isValid) {
264
- console.error(date.invalidExplanation);
265
- return undefined;
733
+ onUnitCellBlur(unit, event) {
734
+ const relatedTarget = event.relatedTarget;
735
+ const relatedUnit = relatedTarget?.dataset?.elementContainerId?.split('-')[0];
736
+ const movingWithinSameColumn = relatedUnit === unit;
737
+ // Check if column lost focus to scroll back to selected value
738
+ if (relatedTarget && !movingWithinSameColumn) {
739
+ if (relatedUnit !== unit) {
740
+ this.elementListScrollToTop(unit, Number(this.formattedTime[unit]), 'smooth');
741
+ }
742
+ }
743
+ // Still within this column (e.g. roving focus between cells)
744
+ if (movingWithinSameColumn) {
745
+ return;
266
746
  }
267
- return date;
747
+ this.isUnitFocused = false;
748
+ const focusedValue = this.resolvePreservedFocusedValueOnColumnBlur(unit);
749
+ this.focusedValue = focusedValue;
750
+ this.updateDescriptorFocusedValue(unit, focusedValue);
268
751
  }
269
- updateSelectedYearMonth(date) {
270
- this.selectedYear = date.year;
271
- this.selectedMonth = date.month - 1;
752
+ onUnitCellFocus(unit, value) {
753
+ this.isUnitFocused = true;
754
+ this.focusedUnit = unit;
755
+ this.focusedValue = value;
756
+ this.updateDescriptorFocusedValue(unit, value);
272
757
  }
273
- onDayBlur() {
274
- this.isDayFocus = false;
758
+ getElementList(unit) {
759
+ return this.hostElement.shadowRoot?.querySelector(`[data-element-list-id="${unit}"]`);
275
760
  }
276
- onDayFocus() {
277
- this.isDayFocus = true;
761
+ getElementContainer(unit, number) {
762
+ return this.hostElement.shadowRoot?.querySelector(`[data-element-container-id="${unit}-${number}"]`);
278
763
  }
279
- componentWillLoad() {
280
- var _a, _b, _c, _d;
281
- this.setTranslations();
282
- this.currFromDate = this.from
283
- ? datetime.DateTime.fromFormat(this.from, this.format)
284
- : undefined;
285
- this.currToDate = this.to
286
- ? datetime.DateTime.fromFormat(this.to, this.format)
287
- : undefined;
288
- const year = (_b = (_a = this.currFromDate) === null || _a === void 0 ? void 0 : _a.year) !== null && _b !== void 0 ? _b : this.getDateTimeNow().year;
289
- this.startYear = year - 5;
290
- this.endYear = year + 5;
291
- this.selectedMonth =
292
- ((_d = (_c = this.currFromDate) === null || _c === void 0 ? void 0 : _c.month) !== null && _d !== void 0 ? _d : this.getDateTimeNow().month) - 1;
293
- this.selectedYear = year;
294
- this.tempMonth = this.selectedMonth;
295
- this.tempYear = this.selectedYear;
296
- }
297
- componentWillRender() {
298
- this.calculateCalendar();
764
+ isElementVisible(element, container) {
765
+ const elementRect = element.getBoundingClientRect();
766
+ const containerRect = container.getBoundingClientRect();
767
+ return (elementRect.top >= containerRect.top &&
768
+ elementRect.bottom <= containerRect.bottom);
299
769
  }
300
- componentDidRender() {
301
- if (!this.monthChangedFromFocus && !this.isDayFocus) {
770
+ scrollElementIntoView(element, container, alignment) {
771
+ const SCROLL_BUFFER = 1;
772
+ const containerRect = container.getBoundingClientRect();
773
+ const elementRect = element.getBoundingClientRect();
774
+ if (alignment === 'end') {
775
+ container.scrollTop +=
776
+ elementRect.bottom - containerRect.bottom + SCROLL_BUFFER;
777
+ }
778
+ else {
779
+ container.scrollTop +=
780
+ elementRect.top - containerRect.top - SCROLL_BUFFER;
781
+ }
782
+ }
783
+ setInitialFocusedValueAndUnit() {
784
+ const firstVisibleDescriptor = this.timePickerDescriptors.find((descriptor) => !descriptor.hidden);
785
+ if (!firstVisibleDescriptor) {
302
786
  return;
303
787
  }
304
- const dayElem = this.hostElement.shadowRoot.querySelector(`[id=day-cell-${this.focusedDay}]`);
305
- dayElem.focus();
788
+ this.focusedValue = this.getConstrainedFocusedValueForUnit(firstVisibleDescriptor.unit, firstVisibleDescriptor.numberArray);
789
+ this.focusedUnit = firstVisibleDescriptor.unit;
306
790
  }
307
- setTranslations() {
308
- this.dayNames = this.rotateWeekDayNames(datetime.Info.weekdays('long', {
309
- locale: this.locale,
310
- }), this.weekStartIndex);
311
- this.monthNames = datetime.Info.months('long', {
312
- locale: this.locale,
791
+ setupVisibilityObserver() {
792
+ const dropdown = shadowDom.closestPassShadow(this.hostElement, 'ix-dropdown');
793
+ if (!dropdown) {
794
+ return;
795
+ }
796
+ this.visibilityObserver = new MutationObserver((mutations) => this.mutationObserverCallback(mutations));
797
+ this.visibilityObserver.observe(dropdown, {
798
+ attributes: true,
799
+ attributeFilter: ['class', 'style'],
313
800
  });
314
801
  }
315
- /**
316
- * Rotate the WeekdayNames array.
317
- * Based on the position that should be the new 0-index.
318
- */
319
- rotateWeekDayNames(weekdays, index) {
320
- const clone = [...weekdays];
321
- if (index === 0) {
322
- return clone;
323
- }
324
- index = -index;
325
- const len = weekdays.length;
326
- clone.push(...clone.splice(0, ((-index % len) + len) % len));
327
- return clone;
328
- }
329
- async onDone() {
330
- const date = await this.getCurrentDate();
331
- this.dateSelect.emit(date);
332
- }
333
- calculateCalendar() {
334
- const calendar = [];
335
- const month = datetime.DateTime.utc(this.selectedYear, this.selectedMonth + 1);
336
- const monthStart = month.startOf('month');
337
- const monthEnd = month.endOf('month');
338
- let startWeek = monthStart.weekNumber;
339
- let endWeek = monthEnd.weekNumber;
340
- let monthStartWeekDayIndex = monthStart.weekday - 1;
341
- let monthEndWeekDayIndex = monthEnd.weekday - 1;
342
- if (this.weekStartIndex !== 0) {
343
- // Find the positions where to start/stop counting the day-numbers based on which day the week starts
344
- const weekdays = datetime.Info.weekdays();
345
- const monthStartWeekDayName = weekdays[monthStart.weekday];
346
- monthStartWeekDayIndex = this.dayNames.findIndex((d) => d === monthStartWeekDayName);
347
- const monthEndWeekDayName = weekdays[monthEnd.weekday];
348
- monthEndWeekDayIndex = this.dayNames.findIndex((d) => d === monthEndWeekDayName);
349
- }
350
- let correctLastWeek = false;
351
- if (endWeek === 1) {
352
- endWeek = monthEnd.weeksInWeekYear + 1;
353
- correctLastWeek = true;
354
- }
355
- let correctFirstWeek = false;
356
- if (startWeek === monthStart.weeksInWeekYear) {
357
- startWeek = 1;
358
- endWeek++;
359
- correctFirstWeek = true;
360
- }
361
- let currDayNumber = 1;
362
- for (let weekIndex = startWeek; weekIndex <= endWeek && currDayNumber <= 31; weekIndex++) {
363
- const daysArr = [];
364
- for (let j = 0; j < this.DAYS_IN_WEEK && currDayNumber <= 31; j++) {
365
- // Display empty cells until the calender starts/has ended
366
- if ((weekIndex === startWeek && j < monthStartWeekDayIndex) ||
367
- (weekIndex === endWeek && j > monthEndWeekDayIndex)) {
368
- daysArr.push(undefined);
369
- }
370
- else {
371
- daysArr.push(currDayNumber++);
372
- }
802
+ mutationObserverCallback(mutations) {
803
+ for (const mutation of mutations) {
804
+ if (mutation.type !== 'attributes') {
805
+ continue;
373
806
  }
374
- if (correctFirstWeek || correctLastWeek) {
375
- if (weekIndex === 1) {
376
- calendar.push({
377
- weekNumber: monthStart.weeksInWeekYear,
378
- dayNumbers: daysArr,
379
- });
380
- }
381
- else if (weekIndex === monthEnd.weekNumber) {
382
- calendar.push({
383
- weekNumber: 1,
384
- dayNumbers: daysArr,
385
- });
386
- }
387
- else {
388
- calendar.push({
389
- weekNumber: weekIndex - 1,
390
- dayNumbers: daysArr,
391
- });
807
+ const dropdown = mutation.target;
808
+ if (!dropdown.classList.contains('show')) {
809
+ // keep picker in sync with input
810
+ if (this.time) {
811
+ const timeFormat = datetime.DateTime.fromFormat(this.time, this.format);
812
+ if (timeFormat.isValid) {
813
+ this._time = datetime.DateTime.fromFormat(this.time, this.format);
814
+ this.setInitialFocusedValueAndUnit();
815
+ }
392
816
  }
393
817
  continue;
394
818
  }
395
- calendar.push({
396
- weekNumber: weekIndex,
397
- dayNumbers: daysArr,
398
- });
819
+ const elementsReady = this.areElementsRendered();
820
+ if (!elementsReady) {
821
+ continue;
822
+ }
823
+ this.updateScrollPositions();
399
824
  }
400
- this.calendar = calendar;
401
825
  }
402
- selectTempYear(event, year) {
403
- event === null || event === void 0 ? void 0 : event.stopPropagation();
404
- this.tempYear = year;
826
+ areElementsRendered() {
827
+ const elementLists = this.hostElement.shadowRoot?.querySelectorAll('.element-list');
828
+ if (!elementLists || elementLists.length === 0) {
829
+ return false;
830
+ }
831
+ return Array.from(elementLists).some((list) => list.offsetHeight > 0);
405
832
  }
406
- focusMonth() {
407
- var _a;
408
- (_a = this.firstMonthRef.current) === null || _a === void 0 ? void 0 : _a.focus();
833
+ getFormattedTime() {
834
+ if (!this._time) {
835
+ return FORMATTED_TIME_EMPTY;
836
+ }
837
+ return {
838
+ hour: this.timeRef !== undefined
839
+ ? this._time.toFormat('h')
840
+ : this._time.toFormat('H'),
841
+ minute: this._time.toFormat('m'),
842
+ second: this._time.toFormat('s'),
843
+ millisecond: this._time.toFormat('S'),
844
+ };
409
845
  }
410
- infiniteScrollYears() {
411
- const yearContainer = this.yearContainerRef.current;
412
- if (!yearContainer) {
846
+ changeTimeReference(newTimeRef) {
847
+ if (this.timeRef === newTimeRef) {
413
848
  return;
414
849
  }
415
- const scroll = yearContainer.scrollTop;
416
- const maxScroll = yearContainer.scrollHeight;
417
- const atTop = scroll === 0;
418
- const atBottom = Math.round(scroll + yearContainer.offsetHeight) >= maxScroll;
419
- const limit = 200;
420
- if (this.endYear - this.startYear > limit)
850
+ if (!this._time) {
851
+ this._time = datetime.DateTime.now().startOf('day');
852
+ }
853
+ const previousTime = this._time;
854
+ const previousRef = this.timeRef;
855
+ this.timeRef = newTimeRef;
856
+ const currentHour = this._time.hour;
857
+ if (newTimeRef === 'PM' && currentHour < 12) {
858
+ this._time = this._time.plus({ hours: 12 });
859
+ }
860
+ else if (newTimeRef === 'AM' && currentHour >= 12) {
861
+ this._time = this._time.minus({ hours: 12 });
862
+ }
863
+ if (!this.isWithinTimeConstraints(this._time)) {
864
+ this._time = previousTime;
865
+ this.timeRef = previousRef;
866
+ return;
867
+ }
868
+ this.timeChange.emit(this._time.toFormat(this.format));
869
+ }
870
+ /** `_time` or “now” (constraints, AM/PM, confirm). */
871
+ referenceOrNow() {
872
+ return this._time ?? datetime.DateTime.now();
873
+ }
874
+ setTimeRef() {
875
+ const uses12HourFormat = isFormat12Hour(this.format);
876
+ if (!uses12HourFormat) {
877
+ this.timeRef = undefined;
878
+ return;
879
+ }
880
+ const clock = this.referenceOrNow();
881
+ this.timeRef = clock.hour >= 12 ? 'PM' : 'AM';
882
+ }
883
+ getConstraintBounds(referenceClock) {
884
+ const baseDay = (referenceClock ?? this.referenceOrNow()).startOf('day');
885
+ return timePickerConstraints.getTimePickerConstraintBounds(this.minTime, this.maxTime, this.format, baseDay);
886
+ }
887
+ /** Bounds and `selectionBase` from {@link referenceOrNow}. */
888
+ getUnitSelectionContext() {
889
+ const referenceClock = this.referenceOrNow();
890
+ return {
891
+ bounds: this.getConstraintBounds(referenceClock),
892
+ selectionBase: this._time ?? referenceClock.startOf('day'),
893
+ };
894
+ }
895
+ isWithinTimeConstraints(candidate) {
896
+ const { min, max } = this.getConstraintBounds();
897
+ return timePickerConstraints.isWithinTimePickerConstraints(candidate, min, max);
898
+ }
899
+ canSelectUnitValue(unit, rawValue, bounds, selectionBase) {
900
+ const base = selectionBase ?? this._time ?? datetime.DateTime.now().startOf('day');
901
+ const effectiveBounds = bounds ?? this.getConstraintBounds();
902
+ if (unit === 'hour' &&
903
+ timePickerConstraints.hasActiveTimePickerConstraints(effectiveBounds.min, effectiveBounds.max)) {
904
+ const dayStart = base.startOf('day');
905
+ const hourStart = computeTimeWithRawUnitValue(dayStart, 'hour', rawValue, this.timeRef);
906
+ if (!hourStart) {
907
+ return false;
908
+ }
909
+ const hourEnd = hourStart.set({
910
+ minute: 59,
911
+ second: 59,
912
+ millisecond: 999,
913
+ });
914
+ return timePickerConstraints.timeOfDayRangeIntersectsInclusiveBounds(hourStart, hourEnd, effectiveBounds.min, effectiveBounds.max);
915
+ }
916
+ const candidate = computeTimeWithRawUnitValue(base, unit, rawValue, this.timeRef);
917
+ if (!candidate) {
918
+ return false;
919
+ }
920
+ if (bounds) {
921
+ return this.isSelectableForUnitWithinBounds(unit, candidate, bounds);
922
+ }
923
+ return this.isWithinTimeConstraints(candidate);
924
+ }
925
+ isSelectableForUnitWithinBounds(unit, candidate, bounds) {
926
+ return isSelectableForUnitWithinBounds(unit, candidate, bounds);
927
+ }
928
+ /** Provisional `unit` for cross-column base: roving cell, earlier descriptors, else displayed digits. */
929
+ getProvisionalRawValue(unit) {
930
+ if (this.focusedUnit === unit) {
931
+ return this.focusedValue;
932
+ }
933
+ const order = this.timePickerDescriptors.map((d) => d.unit);
934
+ const iFocused = order.indexOf(this.focusedUnit);
935
+ const iUnit = order.indexOf(unit);
936
+ if (iUnit !== -1 && iFocused !== -1 && iUnit < iFocused) {
937
+ const d = this.timePickerDescriptors.find((x) => x.unit === unit);
938
+ if (d) {
939
+ return d.focusedValue;
940
+ }
941
+ }
942
+ const raw = this.formattedTime?.[unit];
943
+ if (raw === '' || raw === undefined) {
944
+ return 0;
945
+ }
946
+ return Number(raw);
947
+ }
948
+ /** Base time for `canSelect`/`select` on `targetUnit`: committed hour; mid-columns via {@link getProvisionalRawValue}. */
949
+ buildCandidateBaseBeforeUnit(targetUnit) {
950
+ const { selectionBase } = this.getUnitSelectionContext();
951
+ const order = this.timePickerDescriptors.map((d) => d.unit);
952
+ const targetIndex = order.indexOf(targetUnit);
953
+ if (targetIndex <= 0) {
954
+ return selectionBase;
955
+ }
956
+ let base = this._time ?? selectionBase;
957
+ for (let i = 1; i < targetIndex; i++) {
958
+ const unit = order[i];
959
+ if (unit === undefined) {
960
+ continue;
961
+ }
962
+ const raw = this.getProvisionalRawValue(unit);
963
+ const next = computeTimeWithRawUnitValue(base, unit, raw, this.timeRef);
964
+ if (next) {
965
+ base = next;
966
+ }
967
+ }
968
+ return base;
969
+ }
970
+ getConstrainedFocusedValueForUnitWithBase(unit, numberArray, baseBeforeUnit) {
971
+ const { bounds } = this.getUnitSelectionContext();
972
+ const pickFirstSelectable = () => {
973
+ const found = numberArray.find((n) => this.canSelectUnitValue(unit, n, bounds, baseBeforeUnit));
974
+ return found ?? null;
975
+ };
976
+ const selected = Number(this.formattedTime[unit]);
977
+ if (!numberArray.includes(selected)) {
978
+ return pickFirstSelectable() ?? numberArray[0];
979
+ }
980
+ if (this.canSelectUnitValue(unit, selected, bounds, baseBeforeUnit)) {
981
+ return selected;
982
+ }
983
+ return pickFirstSelectable() ?? numberArray[0];
984
+ }
985
+ getConstrainedFocusedValueForUnit(unit, numberArray) {
986
+ return this.getConstrainedFocusedValueForUnitWithBase(unit, numberArray, this.buildCandidateBaseBeforeUnit(unit));
987
+ }
988
+ resolvePreservedFocusedValueOnColumnBlur(unit) {
989
+ const arr = this.getNumberArrayForUnit(unit);
990
+ const { bounds } = this.getUnitSelectionContext();
991
+ const base = this.buildCandidateBaseBeforeUnit(unit);
992
+ const current = this.focusedValue;
993
+ if (arr.includes(current) &&
994
+ this.canSelectUnitValue(unit, current, bounds, base)) {
995
+ return current;
996
+ }
997
+ return this.getConstrainedFocusedValueForUnit(unit, arr);
998
+ }
999
+ syncKeyboardFocusWithConstraints() {
1000
+ if (!this.timePickerDescriptors.length) {
421
1001
  return;
422
- if (atTop) {
423
- const first = yearContainer.firstElementChild;
424
- this.startYear -= 5;
425
- yearContainer.scrollTo(0, first.offsetTop);
1002
+ }
1003
+ for (const d of this.timePickerDescriptors) {
1004
+ const next = this.getConstrainedFocusedValueForUnit(d.unit, d.numberArray);
1005
+ if (next !== d.focusedValue) {
1006
+ this.updateDescriptorFocusedValue(d.unit, next);
1007
+ }
1008
+ }
1009
+ const arr = this.getNumberArrayForUnit(this.focusedUnit);
1010
+ if (arr.length) {
1011
+ const nextFocused = this.getConstrainedFocusedValueForUnit(this.focusedUnit, arr);
1012
+ if (nextFocused !== this.focusedValue) {
1013
+ this.focusedValue = nextFocused;
1014
+ }
1015
+ }
1016
+ }
1017
+ findFirstSelectableInUnit(unit) {
1018
+ const arr = this.getNumberArrayForUnit(unit);
1019
+ const { bounds } = this.getUnitSelectionContext();
1020
+ const base = this.buildCandidateBaseBeforeUnit(unit);
1021
+ const found = arr.find((n) => this.canSelectUnitValue(unit, n, bounds, base));
1022
+ return found ?? null;
1023
+ }
1024
+ getColumnTabStopValue(unit) {
1025
+ const d = this.timePickerDescriptors.find((x) => x.unit === unit);
1026
+ const arr = d?.numberArray ?? [];
1027
+ if (!d || !arr.length) {
1028
+ return null;
1029
+ }
1030
+ const { bounds } = this.getUnitSelectionContext();
1031
+ const base = this.buildCandidateBaseBeforeUnit(unit);
1032
+ const candidate = d.focusedValue;
1033
+ if (arr.includes(candidate) &&
1034
+ this.canSelectUnitValue(unit, candidate, bounds, base)) {
1035
+ return candidate;
1036
+ }
1037
+ return this.findFirstSelectableInUnit(unit);
1038
+ }
1039
+ stepFocusedValue(direction) {
1040
+ const unit = this.focusedUnit;
1041
+ const arr = this.getNumberArrayForUnit(unit);
1042
+ const { bounds } = this.getUnitSelectionContext();
1043
+ const base = this.buildCandidateBaseBeforeUnit(unit);
1044
+ const next = findNextSelectableRingValue(arr, this.focusedValue, direction, (candidate) => this.canSelectUnitValue(unit, candidate, bounds, base));
1045
+ if (next === null) {
426
1046
  return;
427
1047
  }
428
- if (atBottom) {
429
- const last = yearContainer.lastElementChild;
430
- this.endYear += 5;
431
- yearContainer.scrollTo(0, last.offsetTop);
1048
+ this.focusedValue = next;
1049
+ this.updateDescriptorFocusedValue(unit, next);
1050
+ }
1051
+ isConfirmDisabled() {
1052
+ const referenceClock = this.referenceOrNow();
1053
+ const { min, max } = this.getConstraintBounds(referenceClock);
1054
+ if (!timePickerConstraints.hasActiveTimePickerConstraints(min, max)) {
1055
+ return false;
432
1056
  }
1057
+ return !timePickerConstraints.isWithinTimePickerConstraints(referenceClock, min, max);
433
1058
  }
434
- selectMonth(month) {
435
- this.selectedMonth = month;
436
- this.selectedYear = this.tempYear;
437
- this.tempMonth = month;
438
- const dropdown = this.hostElement.shadowRoot.querySelector('ix-dropdown');
439
- if (dropdown) {
440
- dropdown.show = false;
1059
+ setTimePickerDescriptors() {
1060
+ const { hourNumbers, minuteNumbers, secondNumbers, millisecondsNumbers } = buildTimePickerColumnNumberArrays({
1061
+ hourInterval: this.hourInterval,
1062
+ minuteInterval: this.minuteInterval,
1063
+ secondInterval: this.secondInterval,
1064
+ millisecondInterval: this.millisecondInterval,
1065
+ }, this.timeRef);
1066
+ const { selectionBase } = this.getUnitSelectionContext();
1067
+ const columns = [
1068
+ {
1069
+ unit: 'hour',
1070
+ header: this.i18nHourColumnHeader,
1071
+ hidden: !LUXON_FORMAT_PATTERNS.hours.test(this.format),
1072
+ numberArray: hourNumbers,
1073
+ },
1074
+ {
1075
+ unit: 'minute',
1076
+ header: this.i18nMinuteColumnHeader,
1077
+ hidden: !LUXON_FORMAT_PATTERNS.minutes.test(this.format),
1078
+ numberArray: minuteNumbers,
1079
+ },
1080
+ {
1081
+ unit: 'second',
1082
+ header: this.i18nSecondColumnHeader,
1083
+ hidden: !LUXON_FORMAT_PATTERNS.seconds.test(this.format),
1084
+ numberArray: secondNumbers,
1085
+ },
1086
+ {
1087
+ unit: 'millisecond',
1088
+ header: this.i18nMillisecondColumnHeader,
1089
+ hidden: !LUXON_FORMAT_PATTERNS.milliseconds.test(this.format),
1090
+ numberArray: millisecondsNumbers,
1091
+ },
1092
+ ];
1093
+ let base = selectionBase;
1094
+ const descriptors = [];
1095
+ for (const col of columns) {
1096
+ if (col.hidden) {
1097
+ continue;
1098
+ }
1099
+ const focusedValue = this.getConstrainedFocusedValueForUnitWithBase(col.unit, col.numberArray, base);
1100
+ descriptors.push({
1101
+ unit: col.unit,
1102
+ header: col.header,
1103
+ hidden: false,
1104
+ numberArray: col.numberArray,
1105
+ focusedValue,
1106
+ });
1107
+ const next = computeTimeWithRawUnitValue(base, col.unit, focusedValue, this.timeRef);
1108
+ if (next) {
1109
+ base = next;
1110
+ }
441
1111
  }
1112
+ this.timePickerDescriptors = descriptors;
442
1113
  }
443
- changeToAdjacentMonth(number) {
444
- if (this.selectedMonth + number < 0) {
445
- this.selectedYear--;
446
- this.selectedMonth = 11;
1114
+ getNumberArrayForUnit(unit) {
1115
+ const descriptor = this.timePickerDescriptors.find((descriptor) => descriptor.unit === unit);
1116
+ return descriptor ? descriptor.numberArray : [];
1117
+ }
1118
+ isSelected(unit, number) {
1119
+ return this.formattedTime[unit] === String(number);
1120
+ }
1121
+ /** Roving tabindex: one tab stop per column; active column only the focused cell has `tabindex=0`. */
1122
+ getUnitCellTabIndex(unit, number) {
1123
+ const { bounds } = this.getUnitSelectionContext();
1124
+ const base = this.buildCandidateBaseBeforeUnit(unit);
1125
+ const cellIsSelectable = this.canSelectUnitValue(unit, number, bounds, base);
1126
+ if (!cellIsSelectable) {
1127
+ return -1;
447
1128
  }
448
- else if (this.selectedMonth + number > 11) {
449
- this.selectedYear++;
450
- this.selectedMonth = 0;
1129
+ if (this.isUnitFocused && this.focusedUnit === unit) {
1130
+ return this.focusedValue === number ? 0 : -1;
451
1131
  }
452
- else {
453
- this.selectedMonth += number;
1132
+ const stop = this.getColumnTabStopValue(unit);
1133
+ if (stop === null) {
1134
+ return -1;
454
1135
  }
1136
+ return stop === number ? 0 : -1;
455
1137
  }
456
- selectDay(selectedDay, target) {
457
- if (target.classList.contains('disabled')) {
1138
+ select(unit, number) {
1139
+ if (this.isSelected(unit, number)) {
458
1140
  return;
459
1141
  }
460
- const date = datetime.DateTime.fromJSDate(new Date(this.selectedYear, this.selectedMonth, selectedDay));
461
- if (this.singleSelection || this.currFromDate === undefined) {
462
- this.currFromDate = date;
463
- this.onDateChange();
1142
+ const { bounds } = this.getUnitSelectionContext();
1143
+ const base = this.buildCandidateBaseBeforeUnit(unit);
1144
+ if (!this.canSelectUnitValue(unit, number, bounds, base)) {
464
1145
  return;
465
1146
  }
466
- // Reset the range selection
467
- if (this.currToDate !== undefined) {
468
- this.currFromDate = date;
469
- this.currToDate = undefined;
470
- this.onDateChange();
1147
+ const candidate = computeTimeWithRawUnitValue(base, unit, number, this.timeRef);
1148
+ if (!candidate) {
471
1149
  return;
472
1150
  }
473
- // Swap from/to if the second date is before the current date
474
- if (date < this.currFromDate) {
475
- this.currToDate = this.currFromDate;
476
- this.currFromDate = date;
477
- this.onDateChange();
1151
+ if (this._time && candidate.toMillis() === this._time.toMillis()) {
478
1152
  return;
479
1153
  }
480
- // Set the range normally
481
- this.currToDate = date;
482
- this.onDateChange();
1154
+ this._time = candidate;
1155
+ this.elementListScrollToTop(unit, number, 'smooth');
1156
+ this.timeChange.emit(this._time.toFormat(this.format));
483
1157
  }
484
- onDateChange() {
485
- this.getCurrentDate().then((date) => {
486
- this.dateChange.emit(date);
487
- if (!this.singleSelection) {
488
- this.dateRangeChange.emit(date);
489
- }
490
- });
1158
+ updateDescriptorFocusedValue(unit, value) {
1159
+ const descriptorIndex = this.timePickerDescriptors.findIndex((d) => d.unit === unit);
1160
+ if (descriptorIndex !== -1) {
1161
+ this.timePickerDescriptors = [
1162
+ ...this.timePickerDescriptors.slice(0, descriptorIndex),
1163
+ {
1164
+ ...this.timePickerDescriptors[descriptorIndex],
1165
+ focusedValue: value,
1166
+ },
1167
+ ...this.timePickerDescriptors.slice(descriptorIndex + 1),
1168
+ ];
1169
+ }
491
1170
  }
492
- getDayClasses(day) {
493
- var _a, _b, _c;
494
- const todayObj = this.getDateTimeNow();
495
- const selectedDayObj = datetime.DateTime.fromJSDate(new Date(this.selectedYear, this.selectedMonth, day));
496
- return {
497
- 'calendar-item': true,
498
- 'empty-day': day === undefined,
499
- today: todayObj.hasSame(selectedDayObj, 'day'),
500
- selected: !!(((_a = this.currFromDate) === null || _a === void 0 ? void 0 : _a.hasSame(selectedDayObj, 'day')) ||
501
- ((_b = this.currToDate) === null || _b === void 0 ? void 0 : _b.hasSame(selectedDayObj, 'day'))),
502
- range: !!(this.currFromDate &&
503
- selectedDayObj.startOf('day') > this.currFromDate.startOf('day') &&
504
- this.currToDate !== undefined &&
505
- selectedDayObj.startOf('day') < ((_c = this.currToDate) === null || _c === void 0 ? void 0 : _c.startOf('day'))),
506
- disabled: !this.isWithinMinMaxDate(selectedDayObj),
507
- };
1171
+ elementListScrollToTop(unit, number, scrollBehaviour) {
1172
+ const elementList = this.getElementList(unit);
1173
+ const elementContainer = this.getElementContainer(unit, number);
1174
+ if (elementList && elementContainer) {
1175
+ const elementListHeight = elementList.clientHeight;
1176
+ const elementContainerHeight = elementContainer.clientHeight;
1177
+ // Offset which is used to adjust the scroll position to account for margins, elements being hidden, etc.
1178
+ let scrollPositionOffset = 11;
1179
+ if (this.hideHeader) {
1180
+ // 56 + 1 --> height of the header container and separator
1181
+ scrollPositionOffset -= 57;
1182
+ }
1183
+ const scrollPosition = elementContainer.offsetTop -
1184
+ elementListHeight / 2 +
1185
+ elementContainerHeight -
1186
+ scrollPositionOffset;
1187
+ elementList.scrollTo({
1188
+ top: scrollPosition,
1189
+ behavior: scrollBehaviour,
1190
+ });
1191
+ }
508
1192
  }
509
- isWithinMinMaxYear(year) {
510
- const minDateYear = this.minDate
511
- ? datetime.DateTime.fromFormat(this.minDate, this.format).year
512
- : undefined;
513
- const maxDateYear = this.maxDate
514
- ? datetime.DateTime.fromFormat(this.maxDate, this.format).year
515
- : undefined;
516
- const isBefore = minDateYear ? year < minDateYear : false;
517
- const isAfter = maxDateYear ? year > maxDateYear : false;
518
- return !isBefore && !isAfter;
519
- }
520
- isWithinMinMaxMonth(month) {
521
- const minDateObj = this.minDate
522
- ? datetime.DateTime.fromFormat(this.minDate, this.format)
523
- : undefined;
524
- const maxDateObj = this.maxDate
525
- ? datetime.DateTime.fromFormat(this.maxDate, this.format)
526
- : undefined;
527
- const minDateMonth = minDateObj === null || minDateObj === void 0 ? void 0 : minDateObj.month;
528
- const maxDateMonth = maxDateObj === null || maxDateObj === void 0 ? void 0 : maxDateObj.month;
529
- const isBefore = minDateMonth
530
- ? this.tempYear === minDateObj.year && month < minDateMonth
531
- : false;
532
- const isAfter = maxDateMonth
533
- ? this.tempYear === maxDateObj.year && month > maxDateMonth
534
- : false;
535
- return !isBefore && !isAfter;
536
- }
537
- isWithinMinMaxDate(date) {
538
- const _minDate = this.minDate
539
- ? datetime.DateTime.fromFormat(this.minDate, this.format)
540
- : undefined;
541
- const _maxDate = this.maxDate
542
- ? datetime.DateTime.fromFormat(this.maxDate, this.format)
543
- : undefined;
544
- const isBefore = _minDate
545
- ? date.startOf('day') < _minDate.startOf('day')
546
- : false;
547
- const isAfter = _maxDate
548
- ? date.startOf('day') > _maxDate.startOf('day')
549
- : false;
550
- return !isBefore && !isAfter;
551
- }
552
- renderYears() {
553
- const rows = [];
554
- for (let year = this.startYear; year <= this.endYear; year++) {
555
- rows.push(index.h("div", { key: year, class: {
556
- arrowYear: true,
557
- 'month-dropdown-item': true,
558
- 'disabled-item': !this.isWithinMinMaxYear(year),
559
- }, onClick: (event) => this.selectTempYear(event, year), onKeyUp: (event) => {
560
- if (event.key === 'Enter') {
561
- this.tempYear = year;
562
- this.focusMonth();
563
- }
564
- }, tabIndex: 0 }, index.h("ix-icon", { class: {
565
- hidden: this.tempYear !== year,
566
- arrowPosition: true,
567
- }, name: index$1.iconChevronRightSmall, size: "12" }), index.h("div", { style: { 'min-width': 'max-content' } }, `${year}`)));
1193
+ /**
1194
+ * Updates all scroll positions of the time picker elements
1195
+ * Updates only the elements that have changed if `formattedTimeOld` is provided
1196
+ */
1197
+ updateScrollPositions(formattedTimeOld = undefined) {
1198
+ for (const key in this.formattedTime) {
1199
+ const unitKey = key;
1200
+ if (!formattedTimeOld ||
1201
+ this.formattedTime[unitKey] !== formattedTimeOld[unitKey]) {
1202
+ this.elementListScrollToTop(unitKey, Number(this.formattedTime[unitKey]), 'instant');
1203
+ }
568
1204
  }
569
- return rows;
1205
+ }
1206
+ formatUnitValue(unit, value) {
1207
+ return formatTimePickerUnitValue(unit, value);
1208
+ }
1209
+ getColumnSeparator(currentIndex) {
1210
+ return getTimePickerColumnSeparator(currentIndex, this.timePickerDescriptors);
570
1211
  }
571
1212
  render() {
572
- return (index.h(index.Host, { key: '98ea6b7a88faa52ff75b8bba1cb2c9e22c4e73e8' }, index.h("ix-date-time-card", { key: 'e16c7a978263147e3e6b4a71f32d934eddf06d2c', corners: this.corners, embedded: this.embedded }, index.h("div", { key: 'b96e24b6b2d1876c9e10be3791a8a7417d83a380', class: "header", slot: "header" }, index.h("ix-icon-button", { key: '10ca5417cb64bb25679269f4608868d057cb9f54', onClick: () => this.changeToAdjacentMonth(-1), icon: index$1.iconChevronLeftSmall, variant: "tertiary", class: "arrows", "aria-label": this.ariaLabelPreviousMonthButton }), index.h("div", { key: '9a286af048e16def6e92bb5aaeef56ca63eeb819', class: "selector" }, index.h("ix-button", { key: '9c95aef10ee98999301b796562109b62ab460328', variant: "tertiary", ref: this.dropdownButtonRef, "data-testid": "year-month-button" }, index.h("span", { key: '87f8874169536008fc5a95ebb5f27c2d90c74013', class: "capitalize" }, this.monthNames[this.selectedMonth], " ", this.selectedYear)), index.h("ix-dropdown", { key: '03b7ee75c45fbf966782b6685956ca16f1b9ea7d', "data-testid": "year-month-dropdown", class: "dropdown", trigger: this.dropdownButtonRef.waitForCurrent(), ignoreRelatedSubmenu: true, placement: "bottom-start", enableTopLayer: this.enableTopLayer }, index.h("div", { key: '6ebe9445e018d9ea0d8ea234ffe04bd5b7c756d6', class: "wrapper" }, index.h("div", { key: '560f769508c69c1ca7ae836f657d6b2a9a0f54dc', "data-testid": "year-container", class: "overflow", onScroll: () => this.infiniteScrollYears(), ref: this.yearContainerRef }, this.renderYears()), index.h("div", { key: '8a933460c220113a5bfe96d8b59948c43095e073', class: "overflow", "data-testid": "month-container" }, this.monthNames.map((month, index$2) => (index.h("div", { key: month, ref: (ref) => {
573
- if (month === this.monthNames[0]) {
574
- this.firstMonthRef(ref);
575
- }
576
- }, class: {
577
- arrowYear: true,
578
- 'month-dropdown-item': true,
579
- selected: this.tempYear === this.selectedYear &&
580
- this.tempMonth === index$2,
581
- 'disabled-item': !this.isWithinMinMaxMonth(index$2),
582
- }, onClick: () => this.selectMonth(index$2), onKeyUp: (event) => event.key === 'Enter' && this.selectMonth(index$2), tabIndex: 0 }, index.h("ix-icon", { class: {
583
- hidden: this.tempYear !== this.selectedYear ||
584
- this.tempMonth !== index$2,
585
- checkPosition: true,
586
- }, name: index$1.iconSingleCheck, size: "16" }), index.h("div", null, index.h("span", { class: "capitalize monthMargin" }, `${month} ${this.tempYear}`))))))))), index.h("ix-icon-button", { key: 'd183b81face1835095ebf6b0f0b741f3bd177434', onClick: () => this.changeToAdjacentMonth(1), icon: index$1.iconChevronRightSmall, variant: "tertiary", class: "arrows", "aria-label": this.ariaLabelNextMonthButton })), index.h("div", { key: '747249d090059b0beea2d522efaafa0e816bd9b5', class: {
587
- grid: true,
588
- 'grid--show-week-numbers': this.showWeekNumbers,
589
- } }, this.showWeekNumbers && index.h("div", { key: '30566707d9ad58aea828bc579abb42fab5078d4e', class: "calendar-item week-day" }), this.dayNames.map((name) => (index.h("div", { key: name, class: "calendar-item week-day" }, index.h("div", { class: "overflow" }, name.slice(0, 3))))), this.calendar.map((week) => {
590
- return (index.h(index.Fragment, null, this.showWeekNumbers && (index.h("div", { class: "calendar-item week-number" }, week.weekNumber)), week.dayNumbers.map((day) => {
591
- return day ? (index.h("div", { key: day, id: `day-cell-${day}`, "date-calender-day": true, class: this.getDayClasses(day), onClick: (e) => {
592
- const target = e.currentTarget;
593
- this.selectDay(day, target);
594
- }, onKeyUp: (e) => {
595
- const target = e.currentTarget;
596
- if (e.key === 'Enter') {
597
- this.selectDay(day, target);
598
- }
599
- }, tabIndex: day === this.focusedDay ? 0 : -1, onFocus: () => this.onDayFocus(), onBlur: () => this.onDayBlur(), "aria-label": `${this.selectedMonth}: ${day}` }, day)) : (index.h("div", null));
600
- })));
601
- })), index.h("div", { key: '2b9a45684c662329a1e6e16062f5710d62112210', class: {
602
- button: true,
603
- hidden: this.singleSelection || this.embedded,
604
- } }, index.h("ix-button", { key: '35de7243b5de0016794880b7287a96b60dc2676c', onClick: () => this.onDone() }, this.i18nDone)))));
1213
+ const { bounds } = this.getUnitSelectionContext();
1214
+ return (index.h(index.Host, { key: '148f502158a23cb3653c1f062a69cff199e93fdc' }, index.h("ix-date-time-card", { key: '5612a12cfb0a8b3c55c3491fcae620d63fa0bbd7', embedded: this.embedded, timePickerAppearance: true, corners: this.corners, hasFooter: !this.dateTimePickerAppearance, hideHeader: this.hideHeader }, index.h("div", { key: '80c1720b837cc3cef4fb4590f68dfe1ab23b8370', class: "header", slot: "header" }, index.h("ix-typography", { key: '087b23019ec2213c3a23b0c1c08da2328af144be', format: "body" }, this.i18nHeader)), index.h("div", { key: '1c4c0a0ca82ae0633fbecd5ed9453493c7b9cf98', class: "clock" }, this.timePickerDescriptors.map((descriptor, index$1) => {
1215
+ return (index.h("div", { class: "flex" }, index.h("div", { class: { columns: true, hidden: descriptor.hidden }, hidden: descriptor.hidden }, index.h("div", { class: "column-header", title: descriptor.header }, descriptor.header), index.h("div", { role: "listbox", "aria-label": descriptor.header, "data-element-list-id": descriptor.unit, class: "element-list", tabindex: -1 }, descriptor.numberArray.map((number) => {
1216
+ const cellTabIndex = this.getUnitCellTabIndex(descriptor.unit, number);
1217
+ const disabled = !this.canSelectUnitValue(descriptor.unit, number, bounds, this.buildCandidateBaseBeforeUnit(descriptor.unit));
1218
+ const selected = this.isSelected(descriptor.unit, number);
1219
+ return (index.h("button", { role: "option", "aria-selected": selected ? 'true' : 'false', "data-element-container-id": `${descriptor.unit}-${number}`, class: {
1220
+ selected,
1221
+ 'element-container': true,
1222
+ disabled,
1223
+ }, disabled: disabled, onClick: () => {
1224
+ this.select(descriptor.unit, number);
1225
+ }, onFocus: () => this.onUnitCellFocus(descriptor.unit, number), onBlur: (e) => this.onUnitCellBlur(descriptor.unit, e), "aria-label": `${descriptor.header}: ${number}`, tabindex: cellTabIndex }, this.formatUnitValue(descriptor.unit, number)));
1226
+ }), index.h("div", { class: "element-list-padding" }))), index$1 !== this.timePickerDescriptors.length - 1 && (index.h("div", { class: {
1227
+ 'column-separator': true,
1228
+ hidden: descriptor.hidden,
1229
+ } }, this.getColumnSeparator(index$1)))));
1230
+ }), this.timeRef && (index.h("div", { key: 'aee3e153f67ba1365ff56d36a72d1d5561d30e2a', class: "flex" }, index.h("div", { key: 'd18821a7a032522e161fdd1e74a5812d2111a6ae', class: "column-separator" }), index.h("div", { key: '57db4e6409de2fbf5d13647304af280866845695', class: "columns" }, index.h("div", { key: 'd60b46a2bc28606c7708eb3dbccee6fe76df8cc5', class: "column-header", title: "AM/PM" }), index.h("div", { key: '2d33c518b011e25fb334cd8e1f1efa9b79cd35ff', role: "listbox", "aria-label": "AM/PM", class: "element-list", tabindex: -1 }, index.h("button", { key: '0ee352467596e646e3afc588ccaa80cad649c551', role: "option", "aria-selected": this.timeRef === 'AM' ? 'true' : 'false', "data-am-pm-id": "AM", class: {
1231
+ selected: this.timeRef === 'AM',
1232
+ 'element-container': true,
1233
+ }, onClick: () => this.changeTimeReference('AM'), tabindex: "0", "aria-label": "AM" }, "AM"), index.h("button", { key: '3c207b5fb9f759a101ce7d1959f93cbfda487274', role: "option", "aria-selected": this.timeRef === 'PM' ? 'true' : 'false', "data-am-pm-id": "PM", class: {
1234
+ selected: this.timeRef === 'PM',
1235
+ 'element-container': true,
1236
+ }, onClick: () => this.changeTimeReference('PM'), tabindex: "0", "aria-label": "PM" }, "PM")))))), index.h("div", { key: 'fc56aa00e3d0280045272303181d49fbcf473bc6', class: {
1237
+ footer: true,
1238
+ 'footer--compact': this.timePickerDescriptors.length <= 2,
1239
+ }, slot: "footer" }, index.h("ix-button", { key: '1c2361d8241d53b5f902f203b43a8bf768f8d1af', class: "confirm-button", disabled: this.isConfirmDisabled(), onClick: () => {
1240
+ this.timeSelect.emit(this._time?.toFormat(this.format));
1241
+ } }, this.i18nConfirmTime)))));
605
1242
  }
606
- get hostElement() { return index.getElement(this); }
1243
+ static get delegatesFocus() { return true; }
607
1244
  static get watchers() { return {
608
- "from": [{
609
- "watchFromPropHandler": 0
1245
+ "format": [{
1246
+ "watchFormatIntervalPropHandler": 0
1247
+ }],
1248
+ "hourInterval": [{
1249
+ "watchHourIntervalPropHandler": 0
1250
+ }],
1251
+ "minuteInterval": [{
1252
+ "watchMinuteIntervalPropHandler": 0
1253
+ }],
1254
+ "secondInterval": [{
1255
+ "watchSecondIntervalPropHandler": 0
1256
+ }],
1257
+ "millisecondInterval": [{
1258
+ "watchMillisecondIntervalPropHandler": 0
610
1259
  }],
611
- "to": [{
612
- "watchToPropHandler": 0
1260
+ "time": [{
1261
+ "watchTimePropHandler": 0
613
1262
  }],
614
- "locale": [{
615
- "onLocaleChange": 0
1263
+ "minTime": [{
1264
+ "watchMinTimePropHandler": 0
1265
+ }],
1266
+ "maxTime": [{
1267
+ "watchMaxTimePropHandler": 0
1268
+ }],
1269
+ "_time": [{
1270
+ "onTimeChange": 0
616
1271
  }]
617
1272
  }; }
618
1273
  };
619
1274
  __decorate([
620
1275
  listener.OnListener('keydown')
621
- ], DatePicker.prototype, "handleKeyUp", null);
622
- DatePicker.style = datePickerCss();
623
-
624
- const layoutGridCss = () => `:host{--ix-layout-grid-gutter:24px;display:block;flex:1 1 0%;width:100%;padding-left:calc(var(--ix-layout-grid-gutter) * 0.5);padding-right:calc(var(--ix-layout-grid-gutter) * 0.5)}:host(.no-margin){padding-left:0;padding-right:0}`;
625
-
626
- const LayoutGrid = class {
627
- constructor(hostRef) {
628
- index.registerInstance(this, hostRef);
629
- /**
630
- * The grid will not have any horizontal padding
631
- */
632
- this.noMargin = false;
633
- /**
634
- * Grid gap
635
- */
636
- this.gap = '24';
637
- /**
638
- * Overwrite the default number of columns. Choose between 2 and 12 columns.
639
- */
640
- this.columns = 12;
641
- }
642
- render() {
643
- return (index.h(index.Host, { key: '7ca75d3fb578d30d3b8e3d5d4455123ee7344456', class: {
644
- 'no-margin': this.noMargin,
645
- }, style: {
646
- '--ix-layout-grid-columns': `${this.columns}`,
647
- '--ix-layout-grid-gutter': `${this.gap}px`,
648
- } }, index.h("slot", { key: '566e2bf1294f8780e4aedb8e2874bd2f216d3712' })));
649
- }
650
- };
651
- LayoutGrid.style = layoutGridCss();
652
-
653
- const rowCss = () => `:host{display:flex;flex-wrap:wrap}:host(:not(:first-of-type)){margin-block-start:var(--ix-layout-grid-row-margin, 0)}`;
654
-
655
- const Row = class {
656
- constructor(hostRef) {
657
- index.registerInstance(this, hostRef);
658
- }
659
- render() {
660
- return (index.h(index.Host, { key: 'f38fd53867857b85a1b2d618125c81bba478cdac' }, index.h("slot", { key: '1fbd414a8c0bb275dcdc88a0e4ff54e944212739' })));
661
- }
662
- };
663
- Row.style = rowCss();
1276
+ ], TimePicker.prototype, "handleKeyDown", null);
1277
+ TimePicker.style = timePickerCss();
664
1278
 
665
1279
  exports.ix_col = Col;
666
- exports.ix_date_picker = DatePicker;
667
1280
  exports.ix_layout_grid = LayoutGrid;
668
1281
  exports.ix_row = Row;
1282
+ exports.ix_time_picker = TimePicker;