@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
@@ -16,19 +16,19 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
16
16
  r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
17
17
  return c > 3 && r && Object.defineProperty(target, key, r), r;
18
18
  };
19
- import { h, Host, } from "@stencil/core";
19
+ import { h, Host, Mixin, } from "@stencil/core";
20
20
  import { DateTime } from "luxon";
21
+ import { DefaultMixins } from "../utils/internal/component";
22
+ import { hasKeyboardMode } from "../utils/internal/mixins/setup.mixin";
21
23
  import { OnListener } from "../utils/listener";
22
- const LUXON_FORMAT_PATTERNS = {
23
- // h, hh, H, HH and various time formats that include hours
24
- hours: /\b[Hh]\b|HH|hh|H{3,4}|h{3,4}|t|tt|ttt|tttt|T|TT|TTT|TTTT/,
25
- // m, mm and time formats that include minutes
26
- minutes: /\bm\b|mm|t|tt|ttt|tttt|T|TT|TTT|TTTT/,
27
- // s, ss and time formats that include seconds
28
- seconds: /\bs\b|ss|tt|ttt|tttt|TT|TTT|TTTT/,
29
- // S, SSS (milliseconds), u/uu/uuu (fractional seconds), x/X (timestamps)
30
- milliseconds: /\bS\b|SSS|u|uu|uuu/,
31
- };
24
+ import { closestPassShadow } from "../utils/shadow-dom";
25
+ import { buildTimePickerColumnNumberArrays } from "./time-picker-column-values";
26
+ import { computeTimeWithRawUnitValue } from "./time-picker-compute-time";
27
+ import { getTimePickerConstraintBounds, hasActiveTimePickerConstraints, isWithinTimePickerConstraints, timeOfDayRangeIntersectsInclusiveBounds, } from "./time-picker-constraints";
28
+ import { formatTimePickerUnitValue, getTimePickerColumnSeparator, } from "./time-picker-display";
29
+ import { isFormat12Hour, LUXON_FORMAT_PATTERNS } from "./time-picker-format";
30
+ import { isSelectableForUnitWithinBounds } from "./time-picker-range";
31
+ import { findNextSelectableRingValue } from "./time-picker-step-focus";
32
32
  const HOUR_INTERVAL_DEFAULT = 1;
33
33
  const MINUTE_INTERVAL_DEFAULT = 1;
34
34
  const SECOND_INTERVAL_DEFAULT = 1;
@@ -41,90 +41,17 @@ const FORMATTED_TIME_EMPTY = {
41
41
  second: '',
42
42
  millisecond: '',
43
43
  };
44
- export class TimePicker {
44
+ export class TimePicker extends Mixin(...DefaultMixins) {
45
45
  constructor() {
46
- /**
47
- * Format of time string.
48
- * See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
49
- * Note: Formats that combine date and time (like f or F) are not supported. Timestamp tokens x and X are not supported either.
50
- */
51
- this.format = 'TT';
52
- /**
53
- * Corner style.
54
- */
55
- this.corners = 'rounded';
56
- /**
57
- * Embedded style (for use in other components).
58
- */
59
- this.embedded = false;
60
- /**
61
- * @internal Temporary prop needed until datetime-picker is reworked for new design.
62
- */
63
- this.dateTimePickerAppearance = false;
64
- /**
65
- * Hides the header of the picker.
66
- *
67
- * @since 3.2.0
68
- */
69
- this.hideHeader = false;
70
- /**
71
- * Interval for hour selection.
72
- *
73
- * @since 3.2.0
74
- */
75
- this.hourInterval = HOUR_INTERVAL_DEFAULT;
76
- /**
77
- * Interval for minute selection.
78
- *
79
- * @since 3.2.0
80
- */
81
- this.minuteInterval = MINUTE_INTERVAL_DEFAULT;
82
- /**
83
- * Interval for second selection.
84
- *
85
- * @since 3.2.0
86
- */
87
- this.secondInterval = SECOND_INTERVAL_DEFAULT;
88
- /**
89
- * Interval for millisecond selection.
90
- *
91
- * @since 3.2.0
92
- */
93
- this.millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
94
- /**
95
- * Text of the time confirm button.
96
- */
97
- this.i18nConfirmTime = CONFIRM_BUTTON_DEFAULT;
98
- /**
99
- * Text for the top header.
100
- */
101
- this.i18nHeader = HEADER_DEFAULT;
102
- /**
103
- * Text for the hour column header.
104
- */
105
- this.i18nHourColumnHeader = 'hr';
106
- /**
107
- * Text for the minute column header.
108
- */
109
- // eslint-disable-next-line @stencil-community/decorators-style
110
- this.i18nMinuteColumnHeader = 'min';
111
- /**
112
- * Text for the second column header.
113
- */
114
- // eslint-disable-next-line @stencil-community/decorators-style
115
- this.i18nSecondColumnHeader = 'sec';
116
- /**
117
- * Text for the millisecond column header.
118
- */
119
- // eslint-disable-next-line @stencil-community/decorators-style
120
- this.i18nMillisecondColumnHeader = 'ms';
121
- this.formattedTime = FORMATTED_TIME_EMPTY;
122
- this.timePickerDescriptors = [];
123
- this.isUnitFocused = false;
124
- this.focusedUnit = 'hour';
125
- this.focusedValue = 0;
126
- this.focusScrollAlignment = 'start';
46
+ super();
127
47
  }
48
+ hostElement;
49
+ /**
50
+ * Format of time string.
51
+ * See {@link https://moment.github.io/luxon/#/formatting?id=table-of-tokens} for all available tokens.
52
+ * Note: Formats that combine date and time (like f or F) are not supported. Timestamp tokens x and X are not supported either.
53
+ */
54
+ format = 'TT';
128
55
  watchFormatIntervalPropHandler(newValue) {
129
56
  if (!newValue) {
130
57
  return;
@@ -132,6 +59,30 @@ export class TimePicker {
132
59
  this.initPicker();
133
60
  this.updateScrollPositions();
134
61
  }
62
+ /**
63
+ * Corner style.
64
+ */
65
+ corners = 'rounded';
66
+ /**
67
+ * Embedded style (for use in other components).
68
+ */
69
+ embedded = false;
70
+ /**
71
+ * @internal Temporary prop needed until datetime-picker is reworked for new design.
72
+ */
73
+ dateTimePickerAppearance = false;
74
+ /**
75
+ * Hides the header of the picker.
76
+ *
77
+ * @since 3.2.0
78
+ */
79
+ hideHeader = false;
80
+ /**
81
+ * Interval for hour selection.
82
+ *
83
+ * @since 3.2.0
84
+ */
85
+ hourInterval = HOUR_INTERVAL_DEFAULT;
135
86
  watchHourIntervalPropHandler(newValue) {
136
87
  if (Number.isInteger(newValue) &&
137
88
  newValue >= 0 &&
@@ -142,6 +93,12 @@ export class TimePicker {
142
93
  this.printIntervalError('hour', newValue);
143
94
  this.hourInterval = HOUR_INTERVAL_DEFAULT;
144
95
  }
96
+ /**
97
+ * Interval for minute selection.
98
+ *
99
+ * @since 3.2.0
100
+ */
101
+ minuteInterval = MINUTE_INTERVAL_DEFAULT;
145
102
  watchMinuteIntervalPropHandler(newValue) {
146
103
  if (newValue >= 0 && newValue <= 59) {
147
104
  this.setTimePickerDescriptors();
@@ -150,6 +107,12 @@ export class TimePicker {
150
107
  this.printIntervalError('minute', newValue);
151
108
  this.minuteInterval = MINUTE_INTERVAL_DEFAULT;
152
109
  }
110
+ /**
111
+ * Interval for second selection.
112
+ *
113
+ * @since 3.2.0
114
+ */
115
+ secondInterval = SECOND_INTERVAL_DEFAULT;
153
116
  watchSecondIntervalPropHandler(newValue) {
154
117
  if (newValue >= 0 && newValue <= 59) {
155
118
  this.setTimePickerDescriptors();
@@ -158,6 +121,12 @@ export class TimePicker {
158
121
  this.printIntervalError('second', newValue);
159
122
  this.secondInterval = SECOND_INTERVAL_DEFAULT;
160
123
  }
124
+ /**
125
+ * Interval for millisecond selection.
126
+ *
127
+ * @since 3.2.0
128
+ */
129
+ millisecondInterval = MILLISECOND_INTERVAL_DEFAULT;
161
130
  watchMillisecondIntervalPropHandler(newValue) {
162
131
  if (newValue >= 0 && newValue <= 999) {
163
132
  this.setTimePickerDescriptors();
@@ -169,13 +138,79 @@ export class TimePicker {
169
138
  printIntervalError(intervalName, value) {
170
139
  console.error(`Value ${value} is not valid for ${intervalName}-interval. Falling back to default.`);
171
140
  }
141
+ warnIfConstraintTimeInvalid(prop, value, omitUnparsableWarning) {
142
+ const trimmed = value?.trim();
143
+ if (!trimmed) {
144
+ return;
145
+ }
146
+ const parsed = DateTime.fromFormat(trimmed, this.format);
147
+ if (parsed.isValid) {
148
+ return;
149
+ }
150
+ if (omitUnparsableWarning) {
151
+ return;
152
+ }
153
+ const detail = [parsed.invalidReason, parsed.invalidExplanation]
154
+ .filter(Boolean)
155
+ .join(': ');
156
+ console.warn(`[ix-time-picker] ${prop}="${trimmed}" does not match format "${this.format}". ` +
157
+ 'The constraint is ignored until the value matches `format`.' +
158
+ (detail ? ` (${detail})` : ''));
159
+ }
160
+ warnIfConstraintRangeInverted(minValue, maxValue) {
161
+ const minTrimmed = minValue?.trim();
162
+ const maxTrimmed = maxValue?.trim();
163
+ if (!minTrimmed || !maxTrimmed) {
164
+ return;
165
+ }
166
+ const minParsed = DateTime.fromFormat(minTrimmed, this.format);
167
+ const maxParsed = DateTime.fromFormat(maxTrimmed, this.format);
168
+ if (!minParsed.isValid || !maxParsed.isValid) {
169
+ return;
170
+ }
171
+ if (minParsed > maxParsed) {
172
+ console.warn(`[ix-time-picker] minTime="${minTrimmed}" is later than maxTime="${maxTrimmed}" for format "${this.format}". ` +
173
+ 'Both constraints are ignored.');
174
+ }
175
+ }
176
+ warnConstraintTimesIfInvalid(options) {
177
+ const omit = options?.omitUnparsableConstraintWarnings ?? false;
178
+ this.warnIfConstraintTimeInvalid('minTime', this.minTime, omit);
179
+ this.warnIfConstraintTimeInvalid('maxTime', this.maxTime, omit);
180
+ this.warnIfConstraintRangeInverted(this.minTime, this.maxTime);
181
+ }
182
+ /**
183
+ * Selected time value.
184
+ * Format has to match the `format` property.
185
+ */
186
+ time;
172
187
  watchTimePropHandler(newValue) {
188
+ if (newValue === undefined || newValue === '') {
189
+ this._time = this.getDefaultTime();
190
+ return;
191
+ }
173
192
  const timeFormat = DateTime.fromFormat(newValue, this.format);
174
193
  if (!timeFormat.isValid) {
175
194
  throw new Error('Format is not supported or not correct');
176
195
  }
177
196
  this._time = timeFormat;
178
197
  }
198
+ /** Earliest selectable time (`format` tokens). Invalid non-empty values are ignored.
199
+ *
200
+ * @since 5.0.0 */
201
+ minTime;
202
+ /** Latest selectable time (`format` tokens). Invalid non-empty values are ignored.
203
+ *
204
+ * @since 5.0.0 */
205
+ maxTime;
206
+ watchMinTimePropHandler() {
207
+ this.warnConstraintTimesIfInvalid();
208
+ this.syncKeyboardFocusWithConstraints();
209
+ }
210
+ watchMaxTimePropHandler() {
211
+ this.warnConstraintTimesIfInvalid();
212
+ this.syncKeyboardFocusWithConstraints();
213
+ }
179
214
  /**
180
215
  * Get default time value
181
216
  * @returns DateTime.now() for empty state (no selection)
@@ -183,27 +218,72 @@ export class TimePicker {
183
218
  getDefaultTime() {
184
219
  return DateTime.now();
185
220
  }
221
+ /**
222
+ * Text of the time confirm button.
223
+ */
224
+ i18nConfirmTime = CONFIRM_BUTTON_DEFAULT;
225
+ /**
226
+ * Text for the top header.
227
+ */
228
+ i18nHeader = HEADER_DEFAULT;
229
+ /**
230
+ * Text for the hour column header.
231
+ */
232
+ i18nHourColumnHeader = 'hr';
233
+ /**
234
+ * Text for the minute column header.
235
+ */
236
+ // eslint-disable-next-line @stencil-community/decorators-style
237
+ i18nMinuteColumnHeader = 'min';
238
+ /**
239
+ * Text for the second column header.
240
+ */
241
+ // eslint-disable-next-line @stencil-community/decorators-style
242
+ i18nSecondColumnHeader = 'sec';
243
+ /**
244
+ * Text for the millisecond column header.
245
+ */
246
+ // eslint-disable-next-line @stencil-community/decorators-style
247
+ i18nMillisecondColumnHeader = 'ms';
248
+ /**
249
+ * Time event. Emitted when the user confirms the selected time.
250
+ */
251
+ timeSelect;
252
+ /**
253
+ * Time change event. Emitted when the selected time changes while interacting with the picker.
254
+ */
255
+ timeChange;
186
256
  /**
187
257
  * Get the current time based on the wanted format
188
258
  */
189
259
  async getCurrentTime() {
190
- var _a;
191
- return (_a = this._time) === null || _a === void 0 ? void 0 : _a.toFormat(this.format);
260
+ return this._time?.toFormat(this.format);
192
261
  }
262
+ _time;
193
263
  onTimeChange() {
194
264
  const formattedTimeOld = this.formattedTime;
195
265
  this.setTimeRef();
196
266
  this.formattedTime = this.getFormattedTime();
197
267
  this.updateScrollPositions(formattedTimeOld);
198
268
  }
269
+ timeRef;
270
+ formattedTime = FORMATTED_TIME_EMPTY;
271
+ timePickerDescriptors = [];
272
+ isUnitFocused = false;
273
+ focusedUnit = 'hour';
274
+ focusedValue = 0;
275
+ visibilityObserver;
276
+ focusScrollAlignment = 'start';
199
277
  componentWillLoad() {
200
278
  this.initPicker();
201
279
  }
202
280
  initPicker() {
203
281
  let parsedTime;
282
+ let timePropDoesNotMatchFormat = false;
204
283
  if (this.time) {
205
284
  parsedTime = DateTime.fromFormat(this.time, this.format);
206
285
  if (!parsedTime.isValid) {
286
+ timePropDoesNotMatchFormat = true;
207
287
  console.error(`Invalid time format. The configured format does not match the format of the passed time. ${parsedTime.invalidReason}: ${parsedTime.invalidExplanation}`);
208
288
  parsedTime = this.getDefaultTime();
209
289
  }
@@ -213,28 +293,40 @@ export class TimePicker {
213
293
  }
214
294
  this._time = parsedTime;
215
295
  this.setTimeRef();
296
+ this.formattedTime = this.getFormattedTime();
216
297
  this.setTimePickerDescriptors();
217
298
  this.setInitialFocusedValueAndUnit();
218
299
  this.watchHourIntervalPropHandler(this.hourInterval);
219
300
  this.watchMinuteIntervalPropHandler(this.minuteInterval);
220
301
  this.watchSecondIntervalPropHandler(this.secondInterval);
221
302
  this.watchMillisecondIntervalPropHandler(this.millisecondInterval);
303
+ this.warnConstraintTimesIfInvalid({
304
+ omitUnparsableConstraintWarnings: timePropDoesNotMatchFormat,
305
+ });
222
306
  }
223
307
  componentDidLoad() {
308
+ super.componentDidLoad?.();
224
309
  this.updateScrollPositions();
225
310
  this.setupVisibilityObserver();
226
311
  }
227
312
  componentDidRender() {
228
- if (this.isUnitFocused) {
229
- const elementContainer = this.getElementContainer(this.focusedUnit, this.focusedValue);
230
- const elementList = this.getElementList(this.focusedUnit);
231
- if (elementContainer) {
313
+ if (!this.isUnitFocused) {
314
+ return;
315
+ }
316
+ const elementContainer = this.getElementContainer(this.focusedUnit, this.focusedValue);
317
+ const elementList = this.getElementList(this.focusedUnit);
318
+ if (!elementContainer) {
319
+ return;
320
+ }
321
+ if (hasKeyboardMode()) {
322
+ const active = this.hostElement.shadowRoot?.activeElement;
323
+ if (active !== elementContainer) {
232
324
  elementContainer.focus({ preventScroll: true });
233
- if (!this.isElementVisible(elementContainer, elementList)) {
234
- this.scrollElementIntoView(elementContainer, elementList, this.focusScrollAlignment);
235
- }
236
325
  }
237
326
  }
327
+ if (!this.isElementVisible(elementContainer, elementList)) {
328
+ this.scrollElementIntoView(elementContainer, elementList, this.focusScrollAlignment);
329
+ }
238
330
  }
239
331
  disconnectedCallback() {
240
332
  if (this.visibilityObserver) {
@@ -245,44 +337,29 @@ export class TimePicker {
245
337
  if (!this.isUnitFocused) {
246
338
  return;
247
339
  }
248
- let newValue = this.focusedValue;
249
340
  let shouldPreventDefault = true;
250
- let newValueInterval;
251
- switch (this.focusedUnit) {
252
- case 'hour':
253
- newValueInterval = this.hourInterval;
254
- break;
255
- case 'minute':
256
- newValueInterval = this.minuteInterval;
257
- break;
258
- case 'second':
259
- newValueInterval = this.secondInterval;
260
- break;
261
- case 'millisecond':
262
- newValueInterval = this.millisecondInterval;
263
- break;
264
- }
265
341
  switch (event.key) {
266
342
  case 'Tab':
267
343
  shouldPreventDefault = false;
268
344
  this.isUnitFocused = false;
269
345
  break;
270
346
  case 'ArrowUp':
271
- newValue -= newValueInterval;
272
347
  this.focusScrollAlignment = 'start';
273
- this.updateFocusedValue(newValue);
274
- this.updateDescriptorFocusedValue(this.focusedUnit, this.focusedValue);
348
+ this.stepFocusedValue(-1);
275
349
  break;
276
350
  case 'ArrowDown':
277
- newValue += newValueInterval;
278
351
  this.focusScrollAlignment = 'end';
279
- this.updateFocusedValue(newValue);
280
- this.updateDescriptorFocusedValue(this.focusedUnit, this.focusedValue);
352
+ this.stepFocusedValue(1);
281
353
  break;
282
354
  case 'Enter':
283
- case ' ':
284
- this.select(this.focusedUnit, this.focusedValue);
355
+ case ' ': {
356
+ const { bounds } = this.getUnitSelectionContext();
357
+ const base = this.buildCandidateBaseBeforeUnit(this.focusedUnit);
358
+ if (this.canSelectUnitValue(this.focusedUnit, this.focusedValue, bounds, base)) {
359
+ this.select(this.focusedUnit, this.focusedValue);
360
+ }
285
361
  break;
362
+ }
286
363
  default:
287
364
  return;
288
365
  }
@@ -291,17 +368,22 @@ export class TimePicker {
291
368
  }
292
369
  }
293
370
  onUnitCellBlur(unit, event) {
294
- var _a;
295
371
  const relatedTarget = event.relatedTarget;
372
+ const relatedUnit = relatedTarget?.dataset?.elementContainerId?.split('-')[0];
373
+ const movingWithinSameColumn = relatedUnit === unit;
296
374
  // Check if column lost focus to scroll back to selected value
297
- if (relatedTarget) {
298
- const relatedUnit = (_a = relatedTarget.dataset.elementContainerId) === null || _a === void 0 ? void 0 : _a.split('-')[0];
375
+ if (relatedTarget && !movingWithinSameColumn) {
299
376
  if (relatedUnit !== unit) {
300
377
  this.elementListScrollToTop(unit, Number(this.formattedTime[unit]), 'smooth');
301
378
  }
302
379
  }
380
+ // Still within this column (e.g. roving focus between cells)
381
+ if (movingWithinSameColumn) {
382
+ return;
383
+ }
303
384
  this.isUnitFocused = false;
304
- const focusedValue = Number(this.formattedTime[unit]);
385
+ const focusedValue = this.resolvePreservedFocusedValueOnColumnBlur(unit);
386
+ this.focusedValue = focusedValue;
305
387
  this.updateDescriptorFocusedValue(unit, focusedValue);
306
388
  }
307
389
  onUnitCellFocus(unit, value) {
@@ -311,12 +393,10 @@ export class TimePicker {
311
393
  this.updateDescriptorFocusedValue(unit, value);
312
394
  }
313
395
  getElementList(unit) {
314
- var _a;
315
- return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-element-list-id="${unit}"]`);
396
+ return this.hostElement.shadowRoot?.querySelector(`[data-element-list-id="${unit}"]`);
316
397
  }
317
398
  getElementContainer(unit, number) {
318
- var _a;
319
- return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-element-container-id="${unit}-${number}"]`);
399
+ return this.hostElement.shadowRoot?.querySelector(`[data-element-container-id="${unit}-${number}"]`);
320
400
  }
321
401
  isElementVisible(element, container) {
322
402
  const elementRect = element.getBoundingClientRect();
@@ -337,42 +417,21 @@ export class TimePicker {
337
417
  elementRect.top - containerRect.top - SCROLL_BUFFER;
338
418
  }
339
419
  }
340
- updateFocusedValue(value) {
341
- const numberArray = this.getNumberArrayForUnit(this.focusedUnit);
342
- const maxValue = numberArray[numberArray.length - 1];
343
- const minValue = numberArray[0];
344
- if (value > maxValue) {
345
- value = minValue;
346
- this.focusScrollAlignment = 'start';
347
- }
348
- else if (value < minValue) {
349
- value = maxValue;
350
- this.focusScrollAlignment = 'end';
351
- }
352
- this.focusedValue = value;
353
- }
354
420
  setInitialFocusedValueAndUnit() {
355
421
  const firstVisibleDescriptor = this.timePickerDescriptors.find((descriptor) => !descriptor.hidden);
356
422
  if (!firstVisibleDescriptor) {
357
423
  return;
358
424
  }
359
- const selectedValue = Number(this.formattedTime[firstVisibleDescriptor.unit]);
360
- const isValidSelection = firstVisibleDescriptor.numberArray.includes(selectedValue);
361
- this.focusedValue = isValidSelection
362
- ? selectedValue
363
- : firstVisibleDescriptor.numberArray[0];
425
+ this.focusedValue = this.getConstrainedFocusedValueForUnit(firstVisibleDescriptor.unit, firstVisibleDescriptor.numberArray);
364
426
  this.focusedUnit = firstVisibleDescriptor.unit;
365
427
  }
366
428
  setupVisibilityObserver() {
367
- let dropdownElement = this.hostElement;
368
- while (dropdownElement && dropdownElement.tagName !== 'IX-DROPDOWN') {
369
- dropdownElement = dropdownElement.parentElement;
370
- }
371
- if (!dropdownElement) {
429
+ const dropdown = closestPassShadow(this.hostElement, 'ix-dropdown');
430
+ if (!dropdown) {
372
431
  return;
373
432
  }
374
433
  this.visibilityObserver = new MutationObserver((mutations) => this.mutationObserverCallback(mutations));
375
- this.visibilityObserver.observe(dropdownElement, {
434
+ this.visibilityObserver.observe(dropdown, {
376
435
  attributes: true,
377
436
  attributeFilter: ['class', 'style'],
378
437
  });
@@ -402,8 +461,7 @@ export class TimePicker {
402
461
  }
403
462
  }
404
463
  areElementsRendered() {
405
- var _a;
406
- const elementLists = (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('.element-list');
464
+ const elementLists = this.hostElement.shadowRoot?.querySelectorAll('.element-list');
407
465
  if (!elementLists || elementLists.length === 0) {
408
466
  return false;
409
467
  }
@@ -422,33 +480,6 @@ export class TimePicker {
422
480
  millisecond: this._time.toFormat('S'),
423
481
  };
424
482
  }
425
- timeUpdate(unit, value) {
426
- let maxValue = DateTime.now().endOf('day').get(unit);
427
- if (unit === 'hour') {
428
- if (this.timeRef === 'PM') {
429
- // 12 PM should remain 12, other PM hours add 12
430
- value = value === 12 ? 12 : value + 12;
431
- }
432
- else if (this.timeRef === 'AM') {
433
- // 12 AM should be 0, other AM hours remain as is
434
- value = value === 12 ? 0 : value;
435
- maxValue = 12;
436
- }
437
- }
438
- if (value > maxValue) {
439
- value = maxValue;
440
- }
441
- else if (value < 0) {
442
- value = 0;
443
- }
444
- if (!this._time) {
445
- this._time = DateTime.now().startOf('day');
446
- }
447
- this._time = this._time.set({
448
- [unit]: value,
449
- });
450
- return value;
451
- }
452
483
  changeTimeReference(newTimeRef) {
453
484
  if (this.timeRef === newTimeRef) {
454
485
  return;
@@ -456,6 +487,8 @@ export class TimePicker {
456
487
  if (!this._time) {
457
488
  this._time = DateTime.now().startOf('day');
458
489
  }
490
+ const previousTime = this._time;
491
+ const previousRef = this.timeRef;
459
492
  this.timeRef = newTimeRef;
460
493
  const currentHour = this._time.hour;
461
494
  if (newTimeRef === 'PM' && currentHour < 12) {
@@ -464,83 +497,256 @@ export class TimePicker {
464
497
  else if (newTimeRef === 'AM' && currentHour >= 12) {
465
498
  this._time = this._time.minus({ hours: 12 });
466
499
  }
500
+ if (!this.isWithinTimeConstraints(this._time)) {
501
+ this._time = previousTime;
502
+ this.timeRef = previousRef;
503
+ return;
504
+ }
467
505
  this.timeChange.emit(this._time.toFormat(this.format));
468
506
  }
469
- isFormat12Hour(format) {
470
- // Remove any text that's inside quotes (literal text in Luxon format strings)
471
- let cleanFormat = '';
472
- let inQuote = false;
473
- for (let i = 0; i < format.length; i++) {
474
- const char = format[i];
475
- if (char === "'") {
476
- inQuote = !inQuote;
507
+ /** `_time` or “now” (constraints, AM/PM, confirm). */
508
+ referenceOrNow() {
509
+ return this._time ?? DateTime.now();
510
+ }
511
+ setTimeRef() {
512
+ const uses12HourFormat = isFormat12Hour(this.format);
513
+ if (!uses12HourFormat) {
514
+ this.timeRef = undefined;
515
+ return;
516
+ }
517
+ const clock = this.referenceOrNow();
518
+ this.timeRef = clock.hour >= 12 ? 'PM' : 'AM';
519
+ }
520
+ getConstraintBounds(referenceClock) {
521
+ const baseDay = (referenceClock ?? this.referenceOrNow()).startOf('day');
522
+ return getTimePickerConstraintBounds(this.minTime, this.maxTime, this.format, baseDay);
523
+ }
524
+ /** Bounds and `selectionBase` from {@link referenceOrNow}. */
525
+ getUnitSelectionContext() {
526
+ const referenceClock = this.referenceOrNow();
527
+ return {
528
+ bounds: this.getConstraintBounds(referenceClock),
529
+ selectionBase: this._time ?? referenceClock.startOf('day'),
530
+ };
531
+ }
532
+ isWithinTimeConstraints(candidate) {
533
+ const { min, max } = this.getConstraintBounds();
534
+ return isWithinTimePickerConstraints(candidate, min, max);
535
+ }
536
+ canSelectUnitValue(unit, rawValue, bounds, selectionBase) {
537
+ const base = selectionBase ?? this._time ?? DateTime.now().startOf('day');
538
+ const effectiveBounds = bounds ?? this.getConstraintBounds();
539
+ if (unit === 'hour' &&
540
+ hasActiveTimePickerConstraints(effectiveBounds.min, effectiveBounds.max)) {
541
+ const dayStart = base.startOf('day');
542
+ const hourStart = computeTimeWithRawUnitValue(dayStart, 'hour', rawValue, this.timeRef);
543
+ if (!hourStart) {
544
+ return false;
545
+ }
546
+ const hourEnd = hourStart.set({
547
+ minute: 59,
548
+ second: 59,
549
+ millisecond: 999,
550
+ });
551
+ return timeOfDayRangeIntersectsInclusiveBounds(hourStart, hourEnd, effectiveBounds.min, effectiveBounds.max);
552
+ }
553
+ const candidate = computeTimeWithRawUnitValue(base, unit, rawValue, this.timeRef);
554
+ if (!candidate) {
555
+ return false;
556
+ }
557
+ if (bounds) {
558
+ return this.isSelectableForUnitWithinBounds(unit, candidate, bounds);
559
+ }
560
+ return this.isWithinTimeConstraints(candidate);
561
+ }
562
+ isSelectableForUnitWithinBounds(unit, candidate, bounds) {
563
+ return isSelectableForUnitWithinBounds(unit, candidate, bounds);
564
+ }
565
+ /** Provisional `unit` for cross-column base: roving cell, earlier descriptors, else displayed digits. */
566
+ getProvisionalRawValue(unit) {
567
+ if (this.focusedUnit === unit) {
568
+ return this.focusedValue;
569
+ }
570
+ const order = this.timePickerDescriptors.map((d) => d.unit);
571
+ const iFocused = order.indexOf(this.focusedUnit);
572
+ const iUnit = order.indexOf(unit);
573
+ if (iUnit !== -1 && iFocused !== -1 && iUnit < iFocused) {
574
+ const d = this.timePickerDescriptors.find((x) => x.unit === unit);
575
+ if (d) {
576
+ return d.focusedValue;
477
577
  }
478
- else if (!inQuote) {
479
- cleanFormat += char;
578
+ }
579
+ const raw = this.formattedTime?.[unit];
580
+ if (raw === '' || raw === undefined) {
581
+ return 0;
582
+ }
583
+ return Number(raw);
584
+ }
585
+ /** Base time for `canSelect`/`select` on `targetUnit`: committed hour; mid-columns via {@link getProvisionalRawValue}. */
586
+ buildCandidateBaseBeforeUnit(targetUnit) {
587
+ const { selectionBase } = this.getUnitSelectionContext();
588
+ const order = this.timePickerDescriptors.map((d) => d.unit);
589
+ const targetIndex = order.indexOf(targetUnit);
590
+ if (targetIndex <= 0) {
591
+ return selectionBase;
592
+ }
593
+ let base = this._time ?? selectionBase;
594
+ for (let i = 1; i < targetIndex; i++) {
595
+ const unit = order[i];
596
+ if (unit === undefined) {
597
+ continue;
598
+ }
599
+ const raw = this.getProvisionalRawValue(unit);
600
+ const next = computeTimeWithRawUnitValue(base, unit, raw, this.timeRef);
601
+ if (next) {
602
+ base = next;
480
603
  }
481
604
  }
482
- // Check for specific 12-hour format tokens
483
- // Case-sensitive matching to distinguish between 'h' and 'H'
484
- return /h|a|t/.test(cleanFormat);
605
+ return base;
485
606
  }
486
- setTimeRef() {
487
- const uses12HourFormat = this.isFormat12Hour(this.format);
488
- if (uses12HourFormat && this._time) {
489
- this.timeRef = this._time.hour >= 12 ? 'PM' : 'AM';
607
+ getConstrainedFocusedValueForUnitWithBase(unit, numberArray, baseBeforeUnit) {
608
+ const { bounds } = this.getUnitSelectionContext();
609
+ const pickFirstSelectable = () => {
610
+ const found = numberArray.find((n) => this.canSelectUnitValue(unit, n, bounds, baseBeforeUnit));
611
+ return found ?? null;
612
+ };
613
+ const selected = Number(this.formattedTime[unit]);
614
+ if (!numberArray.includes(selected)) {
615
+ return pickFirstSelectable() ?? numberArray[0];
490
616
  }
491
- else {
492
- this.timeRef = undefined;
617
+ if (this.canSelectUnitValue(unit, selected, bounds, baseBeforeUnit)) {
618
+ return selected;
493
619
  }
620
+ return pickFirstSelectable() ?? numberArray[0];
494
621
  }
495
- getInitialFocusedValueForUnit(unit, numberArray) {
496
- const selectedValue = Number(this.formattedTime[unit]);
497
- return numberArray.includes(selectedValue) ? selectedValue : numberArray[0];
622
+ getConstrainedFocusedValueForUnit(unit, numberArray) {
623
+ return this.getConstrainedFocusedValueForUnitWithBase(unit, numberArray, this.buildCandidateBaseBeforeUnit(unit));
498
624
  }
499
- setTimePickerDescriptors() {
500
- let hourNumbers = [];
501
- let minuteNumbers = [];
502
- let secondNumbers = [];
503
- let millisecondsNumbers = [];
504
- if (this.timeRef !== undefined) {
505
- hourNumbers = Array.from({ length: Math.ceil(12 / this.hourInterval) }, (_, i) => i * this.hourInterval + 1).filter((hour) => hour <= 12);
625
+ resolvePreservedFocusedValueOnColumnBlur(unit) {
626
+ const arr = this.getNumberArrayForUnit(unit);
627
+ const { bounds } = this.getUnitSelectionContext();
628
+ const base = this.buildCandidateBaseBeforeUnit(unit);
629
+ const current = this.focusedValue;
630
+ if (arr.includes(current) &&
631
+ this.canSelectUnitValue(unit, current, bounds, base)) {
632
+ return current;
506
633
  }
507
- else {
508
- hourNumbers = Array.from({ length: Math.ceil(24 / this.hourInterval) }, (_, i) => i * this.hourInterval);
634
+ return this.getConstrainedFocusedValueForUnit(unit, arr);
635
+ }
636
+ syncKeyboardFocusWithConstraints() {
637
+ if (!this.timePickerDescriptors.length) {
638
+ return;
639
+ }
640
+ for (const d of this.timePickerDescriptors) {
641
+ const next = this.getConstrainedFocusedValueForUnit(d.unit, d.numberArray);
642
+ if (next !== d.focusedValue) {
643
+ this.updateDescriptorFocusedValue(d.unit, next);
644
+ }
509
645
  }
510
- minuteNumbers = Array.from({ length: Math.ceil(60 / this.minuteInterval) }, (_, i) => i * this.minuteInterval);
511
- secondNumbers = Array.from({ length: Math.ceil(60 / this.secondInterval) }, (_, i) => i * this.secondInterval);
512
- millisecondsNumbers = Array.from({ length: Math.ceil(1000 / this.millisecondInterval) }, (_, i) => i * this.millisecondInterval);
513
- this.timePickerDescriptors = [
646
+ const arr = this.getNumberArrayForUnit(this.focusedUnit);
647
+ if (arr.length) {
648
+ const nextFocused = this.getConstrainedFocusedValueForUnit(this.focusedUnit, arr);
649
+ if (nextFocused !== this.focusedValue) {
650
+ this.focusedValue = nextFocused;
651
+ }
652
+ }
653
+ }
654
+ findFirstSelectableInUnit(unit) {
655
+ const arr = this.getNumberArrayForUnit(unit);
656
+ const { bounds } = this.getUnitSelectionContext();
657
+ const base = this.buildCandidateBaseBeforeUnit(unit);
658
+ const found = arr.find((n) => this.canSelectUnitValue(unit, n, bounds, base));
659
+ return found ?? null;
660
+ }
661
+ getColumnTabStopValue(unit) {
662
+ const d = this.timePickerDescriptors.find((x) => x.unit === unit);
663
+ const arr = d?.numberArray ?? [];
664
+ if (!d || !arr.length) {
665
+ return null;
666
+ }
667
+ const { bounds } = this.getUnitSelectionContext();
668
+ const base = this.buildCandidateBaseBeforeUnit(unit);
669
+ const candidate = d.focusedValue;
670
+ if (arr.includes(candidate) &&
671
+ this.canSelectUnitValue(unit, candidate, bounds, base)) {
672
+ return candidate;
673
+ }
674
+ return this.findFirstSelectableInUnit(unit);
675
+ }
676
+ stepFocusedValue(direction) {
677
+ const unit = this.focusedUnit;
678
+ const arr = this.getNumberArrayForUnit(unit);
679
+ const { bounds } = this.getUnitSelectionContext();
680
+ const base = this.buildCandidateBaseBeforeUnit(unit);
681
+ const next = findNextSelectableRingValue(arr, this.focusedValue, direction, (candidate) => this.canSelectUnitValue(unit, candidate, bounds, base));
682
+ if (next === null) {
683
+ return;
684
+ }
685
+ this.focusedValue = next;
686
+ this.updateDescriptorFocusedValue(unit, next);
687
+ }
688
+ isConfirmDisabled() {
689
+ const referenceClock = this.referenceOrNow();
690
+ const { min, max } = this.getConstraintBounds(referenceClock);
691
+ if (!hasActiveTimePickerConstraints(min, max)) {
692
+ return false;
693
+ }
694
+ return !isWithinTimePickerConstraints(referenceClock, min, max);
695
+ }
696
+ setTimePickerDescriptors() {
697
+ const { hourNumbers, minuteNumbers, secondNumbers, millisecondsNumbers } = buildTimePickerColumnNumberArrays({
698
+ hourInterval: this.hourInterval,
699
+ minuteInterval: this.minuteInterval,
700
+ secondInterval: this.secondInterval,
701
+ millisecondInterval: this.millisecondInterval,
702
+ }, this.timeRef);
703
+ const { selectionBase } = this.getUnitSelectionContext();
704
+ const columns = [
514
705
  {
515
706
  unit: 'hour',
516
707
  header: this.i18nHourColumnHeader,
517
708
  hidden: !LUXON_FORMAT_PATTERNS.hours.test(this.format),
518
709
  numberArray: hourNumbers,
519
- focusedValue: this.getInitialFocusedValueForUnit('hour', hourNumbers),
520
710
  },
521
711
  {
522
712
  unit: 'minute',
523
713
  header: this.i18nMinuteColumnHeader,
524
714
  hidden: !LUXON_FORMAT_PATTERNS.minutes.test(this.format),
525
715
  numberArray: minuteNumbers,
526
- focusedValue: this.getInitialFocusedValueForUnit('minute', minuteNumbers),
527
716
  },
528
717
  {
529
718
  unit: 'second',
530
719
  header: this.i18nSecondColumnHeader,
531
720
  hidden: !LUXON_FORMAT_PATTERNS.seconds.test(this.format),
532
721
  numberArray: secondNumbers,
533
- focusedValue: this.getInitialFocusedValueForUnit('second', secondNumbers),
534
722
  },
535
723
  {
536
724
  unit: 'millisecond',
537
725
  header: this.i18nMillisecondColumnHeader,
538
726
  hidden: !LUXON_FORMAT_PATTERNS.milliseconds.test(this.format),
539
727
  numberArray: millisecondsNumbers,
540
- focusedValue: this.getInitialFocusedValueForUnit('millisecond', millisecondsNumbers),
541
728
  },
542
729
  ];
543
- this.timePickerDescriptors = this.timePickerDescriptors.filter((item) => !item.hidden);
730
+ let base = selectionBase;
731
+ const descriptors = [];
732
+ for (const col of columns) {
733
+ if (col.hidden) {
734
+ continue;
735
+ }
736
+ const focusedValue = this.getConstrainedFocusedValueForUnitWithBase(col.unit, col.numberArray, base);
737
+ descriptors.push({
738
+ unit: col.unit,
739
+ header: col.header,
740
+ hidden: false,
741
+ numberArray: col.numberArray,
742
+ focusedValue,
743
+ });
744
+ const next = computeTimeWithRawUnitValue(base, col.unit, focusedValue, this.timeRef);
745
+ if (next) {
746
+ base = next;
747
+ }
748
+ }
749
+ this.timePickerDescriptors = descriptors;
544
750
  }
545
751
  getNumberArrayForUnit(unit) {
546
752
  const descriptor = this.timePickerDescriptors.find((descriptor) => descriptor.unit === unit);
@@ -549,12 +755,40 @@ export class TimePicker {
549
755
  isSelected(unit, number) {
550
756
  return this.formattedTime[unit] === String(number);
551
757
  }
758
+ /** Roving tabindex: one tab stop per column; active column only the focused cell has `tabindex=0`. */
759
+ getUnitCellTabIndex(unit, number) {
760
+ const { bounds } = this.getUnitSelectionContext();
761
+ const base = this.buildCandidateBaseBeforeUnit(unit);
762
+ const cellIsSelectable = this.canSelectUnitValue(unit, number, bounds, base);
763
+ if (!cellIsSelectable) {
764
+ return -1;
765
+ }
766
+ if (this.isUnitFocused && this.focusedUnit === unit) {
767
+ return this.focusedValue === number ? 0 : -1;
768
+ }
769
+ const stop = this.getColumnTabStopValue(unit);
770
+ if (stop === null) {
771
+ return -1;
772
+ }
773
+ return stop === number ? 0 : -1;
774
+ }
552
775
  select(unit, number) {
553
776
  if (this.isSelected(unit, number)) {
554
777
  return;
555
778
  }
556
- this.formattedTime = Object.assign(Object.assign({}, this.formattedTime), { [unit]: String(number) });
557
- this.timeUpdate(unit, number);
779
+ const { bounds } = this.getUnitSelectionContext();
780
+ const base = this.buildCandidateBaseBeforeUnit(unit);
781
+ if (!this.canSelectUnitValue(unit, number, bounds, base)) {
782
+ return;
783
+ }
784
+ const candidate = computeTimeWithRawUnitValue(base, unit, number, this.timeRef);
785
+ if (!candidate) {
786
+ return;
787
+ }
788
+ if (this._time && candidate.toMillis() === this._time.toMillis()) {
789
+ return;
790
+ }
791
+ this._time = candidate;
558
792
  this.elementListScrollToTop(unit, number, 'smooth');
559
793
  this.timeChange.emit(this._time.toFormat(this.format));
560
794
  }
@@ -563,7 +797,10 @@ export class TimePicker {
563
797
  if (descriptorIndex !== -1) {
564
798
  this.timePickerDescriptors = [
565
799
  ...this.timePickerDescriptors.slice(0, descriptorIndex),
566
- Object.assign(Object.assign({}, this.timePickerDescriptors[descriptorIndex]), { focusedValue: value }),
800
+ {
801
+ ...this.timePickerDescriptors[descriptorIndex],
802
+ focusedValue: value,
803
+ },
567
804
  ...this.timePickerDescriptors.slice(descriptorIndex + 1),
568
805
  ];
569
806
  }
@@ -604,52 +841,45 @@ export class TimePicker {
604
841
  }
605
842
  }
606
843
  formatUnitValue(unit, value) {
607
- if (unit === 'millisecond') {
608
- return value.toString().padStart(3, '0');
609
- }
610
- return value < 10 ? `0${value}` : value.toString();
844
+ return formatTimePickerUnitValue(unit, value);
611
845
  }
612
846
  getColumnSeparator(currentIndex) {
613
- if (currentIndex + 1 < this.timePickerDescriptors.length) {
614
- const nextUnit = this.timePickerDescriptors[currentIndex + 1].unit;
615
- return nextUnit === 'millisecond' ? '.' : ':';
616
- }
617
- return ':';
618
- }
619
- getElementContainerTabIndex(number, descriptorUnit) {
620
- const descriptor = this.timePickerDescriptors.find((d) => d.unit === descriptorUnit);
621
- if (number === (descriptor === null || descriptor === void 0 ? void 0 : descriptor.focusedValue)) {
622
- return '0';
623
- }
624
- return '-1';
847
+ return getTimePickerColumnSeparator(currentIndex, this.timePickerDescriptors);
625
848
  }
626
849
  render() {
627
- return (h(Host, { key: 'bf0e82d6cc6f70a2bd0e07070779b597a51f985e' }, h("ix-date-time-card", { key: 'efe51b660fa864e91aaa9c8fd202413fa097a226', embedded: this.embedded, timePickerAppearance: true, corners: this.corners, hasFooter: !this.dateTimePickerAppearance, hideHeader: this.hideHeader }, h("div", { key: 'bb5e54a50faae4fdc6bddca52d3cd887781cac95', class: "header", slot: "header" }, h("ix-typography", { key: 'b8bd91e7ab853091c447852e31512eaa8311675b', format: "body" }, this.i18nHeader)), h("div", { key: '2b6d7fad8c616631a8b9d5338d40cd967d2a79df', class: "clock" }, this.timePickerDescriptors.map((descriptor, index) => (h("div", { class: "flex" }, h("div", { class: { columns: true, hidden: descriptor.hidden } }, h("div", { class: "column-header", title: descriptor.header }, descriptor.header), h("div", { "data-element-list-id": descriptor.unit, class: "element-list", tabIndex: -1 }, descriptor.numberArray.map((number) => {
628
- return (h("button", { "data-element-container-id": `${descriptor.unit}-${number}`, class: {
629
- selected: this.isSelected(descriptor.unit, number),
630
- 'element-container': true,
631
- }, onClick: () => {
632
- this.select(descriptor.unit, number);
633
- }, onFocus: () => this.onUnitCellFocus(descriptor.unit, number), onBlur: (e) => this.onUnitCellBlur(descriptor.unit, e), tabindex: this.getElementContainerTabIndex(number, descriptor.unit), "aria-label": `${descriptor.header}: ${number}` }, this.formatUnitValue(descriptor.unit, number)));
634
- }), h("div", { class: "element-list-padding" }))), index !== this.timePickerDescriptors.length - 1 && (h("div", { class: {
635
- 'column-separator': true,
636
- hidden: descriptor.hidden,
637
- } }, this.getColumnSeparator(index)))))), this.timeRef && (h("div", { key: 'f4b91233c7d069751b67b0e78b88e7130460dd48', class: "flex" }, h("div", { key: '2594a5881fb34d210893763d0cb2619902b5b931', class: "column-separator" }), h("div", { key: '66f23a06c1335cdcdd4c5c3892d8271cdd75be00', class: "columns" }, h("div", { key: '02945548ecd7b4aa4af27afb1dd30bd444fab251', class: "column-header", title: "AM/PM" }), h("div", { key: '7af4619130b2567eb6a7f0dd774e6222fba3ae63', class: "element-list", tabIndex: -1 }, h("button", { key: '0e3f956ea8e3c530eb96b941360a42e3a930e49f', "data-am-pm-id": "AM", class: {
850
+ const { bounds } = this.getUnitSelectionContext();
851
+ return (h(Host, { key: '148f502158a23cb3653c1f062a69cff199e93fdc' }, h("ix-date-time-card", { key: '5612a12cfb0a8b3c55c3491fcae620d63fa0bbd7', embedded: this.embedded, timePickerAppearance: true, corners: this.corners, hasFooter: !this.dateTimePickerAppearance, hideHeader: this.hideHeader }, h("div", { key: '80c1720b837cc3cef4fb4590f68dfe1ab23b8370', class: "header", slot: "header" }, h("ix-typography", { key: '087b23019ec2213c3a23b0c1c08da2328af144be', format: "body" }, this.i18nHeader)), h("div", { key: '1c4c0a0ca82ae0633fbecd5ed9453493c7b9cf98', class: "clock" }, this.timePickerDescriptors.map((descriptor, index) => {
852
+ return (h("div", { class: "flex" }, h("div", { class: { columns: true, hidden: descriptor.hidden }, hidden: descriptor.hidden }, h("div", { class: "column-header", title: descriptor.header }, descriptor.header), h("div", { role: "listbox", "aria-label": descriptor.header, "data-element-list-id": descriptor.unit, class: "element-list", tabindex: -1 }, descriptor.numberArray.map((number) => {
853
+ const cellTabIndex = this.getUnitCellTabIndex(descriptor.unit, number);
854
+ const disabled = !this.canSelectUnitValue(descriptor.unit, number, bounds, this.buildCandidateBaseBeforeUnit(descriptor.unit));
855
+ const selected = this.isSelected(descriptor.unit, number);
856
+ return (h("button", { role: "option", "aria-selected": selected ? 'true' : 'false', "data-element-container-id": `${descriptor.unit}-${number}`, class: {
857
+ selected,
858
+ 'element-container': true,
859
+ disabled,
860
+ }, disabled: disabled, onClick: () => {
861
+ this.select(descriptor.unit, number);
862
+ }, 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)));
863
+ }), h("div", { class: "element-list-padding" }))), index !== this.timePickerDescriptors.length - 1 && (h("div", { class: {
864
+ 'column-separator': true,
865
+ hidden: descriptor.hidden,
866
+ } }, this.getColumnSeparator(index)))));
867
+ }), this.timeRef && (h("div", { key: 'aee3e153f67ba1365ff56d36a72d1d5561d30e2a', class: "flex" }, h("div", { key: 'd18821a7a032522e161fdd1e74a5812d2111a6ae', class: "column-separator" }), h("div", { key: '57db4e6409de2fbf5d13647304af280866845695', class: "columns" }, h("div", { key: 'd60b46a2bc28606c7708eb3dbccee6fe76df8cc5', class: "column-header", title: "AM/PM" }), h("div", { key: '2d33c518b011e25fb334cd8e1f1efa9b79cd35ff', role: "listbox", "aria-label": "AM/PM", class: "element-list", tabindex: -1 }, h("button", { key: '0ee352467596e646e3afc588ccaa80cad649c551', role: "option", "aria-selected": this.timeRef === 'AM' ? 'true' : 'false', "data-am-pm-id": "AM", class: {
638
868
  selected: this.timeRef === 'AM',
639
869
  'element-container': true,
640
- }, onClick: () => this.changeTimeReference('AM'), tabindex: "0", "aria-label": "AM" }, "AM"), h("button", { key: '5edf7bd09a475bd976319326bfa30719724c4a05', "data-am-pm-id": "PM", class: {
870
+ }, onClick: () => this.changeTimeReference('AM'), tabindex: "0", "aria-label": "AM" }, "AM"), h("button", { key: '3c207b5fb9f759a101ce7d1959f93cbfda487274', role: "option", "aria-selected": this.timeRef === 'PM' ? 'true' : 'false', "data-am-pm-id": "PM", class: {
641
871
  selected: this.timeRef === 'PM',
642
872
  'element-container': true,
643
- }, onClick: () => this.changeTimeReference('PM'), tabindex: "0", "aria-label": "PM" }, "PM")))))), h("div", { key: '2132b54d59ffda5596061f7974af5790068160ff', class: {
873
+ }, onClick: () => this.changeTimeReference('PM'), tabindex: "0", "aria-label": "PM" }, "PM")))))), h("div", { key: 'fc56aa00e3d0280045272303181d49fbcf473bc6', class: {
644
874
  footer: true,
645
875
  'footer--compact': this.timePickerDescriptors.length <= 2,
646
- }, slot: "footer" }, h("ix-button", { key: 'd46dac7662296a8bcafc7fba212041f00f61f060', class: "confirm-button", onClick: () => {
647
- var _a;
648
- this.timeSelect.emit((_a = this._time) === null || _a === void 0 ? void 0 : _a.toFormat(this.format));
876
+ }, slot: "footer" }, h("ix-button", { key: '1c2361d8241d53b5f902f203b43a8bf768f8d1af', class: "confirm-button", disabled: this.isConfirmDisabled(), onClick: () => {
877
+ this.timeSelect.emit(this._time?.toFormat(this.format));
649
878
  } }, this.i18nConfirmTime)))));
650
879
  }
651
880
  static get is() { return "ix-time-picker"; }
652
881
  static get encapsulation() { return "shadow"; }
882
+ static get delegatesFocus() { return true; }
653
883
  static get originalStyleUrls() {
654
884
  return {
655
885
  "$": ["time-picker.scss"]
@@ -886,6 +1116,50 @@ export class TimePicker {
886
1116
  "reflect": false,
887
1117
  "attribute": "time"
888
1118
  },
1119
+ "minTime": {
1120
+ "type": "string",
1121
+ "mutable": false,
1122
+ "complexType": {
1123
+ "original": "string",
1124
+ "resolved": "string | undefined",
1125
+ "references": {}
1126
+ },
1127
+ "required": false,
1128
+ "optional": true,
1129
+ "docs": {
1130
+ "tags": [{
1131
+ "name": "since",
1132
+ "text": "5.0.0"
1133
+ }],
1134
+ "text": "Earliest selectable time (`format` tokens). Invalid non-empty values are ignored."
1135
+ },
1136
+ "getter": false,
1137
+ "setter": false,
1138
+ "reflect": false,
1139
+ "attribute": "min-time"
1140
+ },
1141
+ "maxTime": {
1142
+ "type": "string",
1143
+ "mutable": false,
1144
+ "complexType": {
1145
+ "original": "string",
1146
+ "resolved": "string | undefined",
1147
+ "references": {}
1148
+ },
1149
+ "required": false,
1150
+ "optional": true,
1151
+ "docs": {
1152
+ "tags": [{
1153
+ "name": "since",
1154
+ "text": "5.0.0"
1155
+ }],
1156
+ "text": "Latest selectable time (`format` tokens). Invalid non-empty values are ignored."
1157
+ },
1158
+ "getter": false,
1159
+ "setter": false,
1160
+ "reflect": false,
1161
+ "attribute": "max-time"
1162
+ },
889
1163
  "i18nConfirmTime": {
890
1164
  "type": "string",
891
1165
  "mutable": false,
@@ -943,7 +1217,7 @@ export class TimePicker {
943
1217
  "getter": false,
944
1218
  "setter": false,
945
1219
  "reflect": false,
946
- "attribute": "i18n-column-header",
1220
+ "attribute": "i18n-hour-column-header",
947
1221
  "defaultValue": "'hr'"
948
1222
  },
949
1223
  "i18nMinuteColumnHeader": {
@@ -1093,6 +1367,12 @@ export class TimePicker {
1093
1367
  }, {
1094
1368
  "propName": "time",
1095
1369
  "methodName": "watchTimePropHandler"
1370
+ }, {
1371
+ "propName": "minTime",
1372
+ "methodName": "watchMinTimePropHandler"
1373
+ }, {
1374
+ "propName": "maxTime",
1375
+ "methodName": "watchMaxTimePropHandler"
1096
1376
  }, {
1097
1377
  "propName": "_time",
1098
1378
  "methodName": "onTimeChange"