@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
@@ -0,0 +1,992 @@
1
+ 'use strict';
2
+
3
+ var index = require('./index-BKQkUbyE.js');
4
+ var findElement = require('./find-element-DPxOAdgO.js');
5
+ var disposableEventListener = require('./disposable-event-listener-BALEIeXq.js');
6
+ var focusTrap = require('./focus-trap-_cyPFvFq.js');
7
+ var focusUtilities = require('./focus-utilities-yx7wWjEO.js');
8
+ var component = require('./component-CYtonfpw.js');
9
+ var makeRef = require('./make-ref-CHsa3FY7.js');
10
+ var requestAnimationFrame = require('./requestAnimationFrame-B0rWQ3G-.js');
11
+ var dropdownController = require('./dropdown-controller-DeBeUVhj.js');
12
+ var index$1 = require('./index-Dw-NwUuT.js');
13
+ var a11y = require('./a11y-C_6YiIMa.js');
14
+ var id_mixin = require('./id.mixin-DINDQztK.js');
15
+ var focusVisible_mixin = require('./focus-visible.mixin-BU5Ql7d1.js');
16
+ require('./shadow-dom-BG8VqeIu.js');
17
+
18
+ /*
19
+ * SPDX-FileCopyrightText: 2025 Siemens AG
20
+ *
21
+ * SPDX-License-Identifier: MIT
22
+ *
23
+ * This source code is licensed under the MIT license found in the
24
+ * LICENSE file in the root directory of this source tree.
25
+ */
26
+ /**
27
+ * Originally based on Ionic's focus-visible utility.
28
+ * Fork of https://github.com/ionic-team/ionic-framework/blob/c37e2a5d9e765cf48d768061c9d453a13b187e13/core/src/utils/focus-trap.ts
29
+ */
30
+ // TODO: Remove valid elements, all elements with ix-focusable should be considered
31
+ const VALID_FOCUS_ELEMENTS = [
32
+ 'ix-dropdown-item',
33
+ 'ix-select-item',
34
+ 'ix-menu-item',
35
+ 'ix-menu-category',
36
+ ];
37
+ const QUERY_ARROW_ELEMENTS = VALID_FOCUS_ELEMENTS.map((selector) => `${selector}:not([tabindex^="-"]):not([disabled]):not([hidden])`).join(', ');
38
+ const QUERY_CURRENT_VISIBLE_FOCUS = VALID_FOCUS_ELEMENTS.map((selector) => `${selector}.${focusUtilities.IX_FOCUS_VISIBLE_ACTIVE}:not([tabindex^="-"]):not([disabled]):not([hidden])`).join(', ');
39
+ const getIndexOfDropdownItem = (items, item, selector = QUERY_ARROW_ELEMENTS) => {
40
+ if (!item) {
41
+ return -1;
42
+ }
43
+ if (!item.matches(selector)) {
44
+ return -1;
45
+ }
46
+ return items.findIndex((el) => el === item);
47
+ };
48
+ const getNextFocusableDropdownItem = (items, currentItem, selector = QUERY_CURRENT_VISIBLE_FOCUS) => {
49
+ const currentItemIndex = getIndexOfDropdownItem(items, currentItem, selector);
50
+ const nextIndex = currentItemIndex + 1;
51
+ return items[nextIndex >= items.length ? 0 : nextIndex];
52
+ };
53
+ const getPreviousFocusableItem = (items, currentItem, selector = QUERY_CURRENT_VISIBLE_FOCUS) => {
54
+ const currentItemIndex = getIndexOfDropdownItem(items, currentItem, selector);
55
+ const prevIndex = currentItemIndex - 1;
56
+ return items[prevIndex < 0 ? items.length - 1 : prevIndex];
57
+ };
58
+ const focusItem = (item) => {
59
+ requestAnimationFrame.requestAnimationFrameNoNgZone(async () => {
60
+ let element = item;
61
+ if (item.matches('ix-menu-category')) {
62
+ element = item.shadowRoot.querySelector('.category-parent');
63
+ }
64
+ if (element) {
65
+ focusUtilities.focusElement(element);
66
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => element.scrollIntoView({
67
+ block: 'nearest',
68
+ }));
69
+ }
70
+ });
71
+ };
72
+ const isTriggerElement = (element) => element.hasAttribute('data-ix-dropdown-trigger');
73
+ const configureKeyboardInteraction = (getItemsHost, options = {}) => {
74
+ const querySelector = options.querySelector ?? QUERY_ARROW_ELEMENTS;
75
+ const activeQuerySelector = options.activeQuerySelector ?? QUERY_CURRENT_VISIBLE_FOCUS;
76
+ const itemTriggerKeys = options.itemTriggerKeys ?? [
77
+ 'ArrowRight',
78
+ 'Enter',
79
+ ' ',
80
+ ];
81
+ const getActiveElement = options.getActiveElement ??
82
+ (() => {
83
+ return focusUtilities.queryElements(getItemsHost(), activeQuerySelector)[0];
84
+ });
85
+ const setItemActive = options.setItemActive ?? ((item) => focusItem(item));
86
+ const getEventListenerTarget = options.getEventListenerTarget ?? (() => getItemsHost());
87
+ const callback = async (event) => {
88
+ const activeElement = getActiveElement();
89
+ let items = [];
90
+ try {
91
+ // Collect items from slots if they exist
92
+ if (getItemsHost().querySelectorAll('slot').length > 0) {
93
+ const slotElements = Array.from(getItemsHost().querySelectorAll('slot'));
94
+ items = slotElements.flatMap((slot) => Array.from(slot.assignedElements({ flatten: true })).flatMap((el) => {
95
+ // Check if the assigned element itself matches the query
96
+ if (el?.matches(querySelector)) {
97
+ return [el];
98
+ }
99
+ // Otherwise, query its children
100
+ return Array.from(el.querySelectorAll(querySelector));
101
+ }));
102
+ }
103
+ items = [
104
+ ...items,
105
+ ...Array.from(getItemsHost().querySelectorAll(querySelector)),
106
+ ];
107
+ }
108
+ catch (e) {
109
+ }
110
+ if (options.beforeKeydown) {
111
+ options.beforeKeydown(event);
112
+ }
113
+ switch (event.key) {
114
+ case 'ArrowLeft': {
115
+ getItemsHost().dispatchEvent(new CustomEvent('ix-close-submenu', {
116
+ bubbles: true,
117
+ cancelable: true,
118
+ }));
119
+ break;
120
+ }
121
+ case 'ArrowDown': {
122
+ if (event.altKey) {
123
+ // ALT + DOWN opens the dropdown but prevent focus change
124
+ return;
125
+ }
126
+ // Disable movement/scroll with keyboard
127
+ event.preventDefault();
128
+ const nextItem = getNextFocusableDropdownItem(items, activeElement, activeQuerySelector);
129
+ if (nextItem !== undefined) {
130
+ setItemActive(nextItem);
131
+ }
132
+ break;
133
+ }
134
+ case 'ArrowUp': {
135
+ if (event.altKey) {
136
+ // ALT + DOWN opens the dropdown but prevent focus change
137
+ return;
138
+ }
139
+ // Disable movement/scroll with keyboard
140
+ event.preventDefault();
141
+ const prevItem = getPreviousFocusableItem(items, activeElement, activeQuerySelector);
142
+ if (prevItem !== undefined) {
143
+ setItemActive(prevItem);
144
+ }
145
+ break;
146
+ }
147
+ case 'Home': {
148
+ event.preventDefault();
149
+ const firstItem = items[0];
150
+ if (firstItem !== undefined) {
151
+ setItemActive(firstItem);
152
+ }
153
+ break;
154
+ }
155
+ case 'End': {
156
+ event.preventDefault();
157
+ const lastItem = items[items.length - 1];
158
+ if (lastItem !== undefined) {
159
+ setItemActive(lastItem);
160
+ }
161
+ break;
162
+ }
163
+ case 'ArrowRight':
164
+ case ' ':
165
+ case 'Enter': {
166
+ if (activeElement && isTriggerElement(activeElement)) {
167
+ const triggerEvent = new CustomEvent('ix-open-submenu', {
168
+ bubbles: true,
169
+ cancelable: true,
170
+ detail: {
171
+ activeElement: activeElement,
172
+ },
173
+ });
174
+ activeElement.dispatchEvent(triggerEvent);
175
+ return;
176
+ }
177
+ break;
178
+ }
179
+ }
180
+ if (itemTriggerKeys.includes(event.key)) {
181
+ options.onItemActivation?.(event, activeElement);
182
+ }
183
+ };
184
+ const listenerTarget = getEventListenerTarget();
185
+ listenerTarget.addEventListener('keydown', callback);
186
+ return () => listenerTarget.removeEventListener('keydown', callback);
187
+ };
188
+
189
+ const dropdownCss = () => `:host{background-color:var(--theme-color-2);border-radius:var(--theme-default-border-radius);min-width:0px;z-index:var(--theme-z-index-dropdown);box-shadow:var(--theme-shadow-4);padding:0.25rem 0px}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .dropdown-header{display:flex;align-items:center;height:2.5rem;color:var(--theme-menu-header--color);padding:0 1rem}:host(.overflow){max-height:calc(50vh - 3rem);overflow-y:auto}:host(:not(.show)){display:none !important}.dialog{margin:0;border:none;outline:none;padding:0.25rem 0px;min-width:0;max-width:100vw;width:-moz-max-content;width:max-content;height:-moz-fit-content;height:fit-content;background-color:var(--theme-color-2);border-radius:var(--theme-default-border-radius);box-shadow:var(--theme-shadow-4);overflow-x:visible;overflow-y:visible;inset:unset;color-scheme:inherit;color:var(--theme-color-std-text);box-sizing:border-box}.dialog *,.dialog *::after,.dialog *::before{box-sizing:border-box}.dialog .dropdown-container{display:block;position:relative}.dialog .dropdown-header{display:flex;align-items:center;height:2.5rem;color:var(--theme-menu-header--color);padding:0 1rem}.dialog.overflow{max-height:calc(50vh - 3rem);overflow-y:auto}`;
190
+
191
+ let sequenceId = 0;
192
+ const Dropdown = class extends index.Mixin(...component.DefaultMixins) {
193
+ constructor(hostRef) {
194
+ super();
195
+ index.registerInstance(this, hostRef);
196
+ this.showChange = index.createEvent(this, "showChange", 7);
197
+ this.showChanged = index.createEvent(this, "showChanged", 7);
198
+ this.experimentalRequestFocus = index.createEvent(this, "experimentalRequestFocus", 7);
199
+ this.experimentalFocusNextElement = index.createEvent(this, "experimentalFocusNextElement", 7);
200
+ }
201
+ get hostElement() { return index.getElement(this); }
202
+ /**
203
+ * Suppress the automatic placement of the dropdown.
204
+ */
205
+ suppressAutomaticPlacement = false;
206
+ /**
207
+ * Show dropdown
208
+ */
209
+ show = false;
210
+ /**
211
+ * Define an element that triggers the dropdown.
212
+ * A trigger can either be a string that will be interpreted as id attribute or a DOM element.
213
+ */
214
+ trigger;
215
+ /**
216
+ * Define an anchor element
217
+ */
218
+ anchor;
219
+ /**
220
+ * Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.
221
+ * If the dropdown is a child of another one, it will be closed with the parent, regardless of its own close behavior.
222
+ */
223
+ closeBehavior = 'both';
224
+ /**
225
+ * Placement of the dropdown
226
+ */
227
+ placement = 'bottom-start';
228
+ /**
229
+ * Position strategy
230
+ */
231
+ positioningStrategy = 'fixed';
232
+ /**
233
+ * An optional header shown at the top of the dropdown
234
+ */
235
+ header;
236
+ /**
237
+ * By default the dropdown gets closed if the trigger is not visible anymore (e.g. due to scrolling). Setting this property prevents that behavior.
238
+ *
239
+ * @since 5.0.0
240
+ */
241
+ suppressTriggerVisibilityCheck = false;
242
+ /**
243
+ * Suppress automatic focus when the dropdown is shown
244
+ *
245
+ * @since 4.3.0
246
+ */
247
+ disableFocusHandling = false;
248
+ /**
249
+ * Close dropdown when tabbing away, and do not trap focus inside dropdown
250
+ *
251
+ * @since 4.3.0
252
+ */
253
+ disableFocusTrap = false;
254
+ /**
255
+ * Enable Popover API rendering for top-layer positioning.
256
+ *
257
+ * @default false in v5.x, will default to true in v6.0.0
258
+ * @since 4.3.0
259
+ */
260
+ enableTopLayer = false;
261
+ /**
262
+ * If true, the dropdown will try to focus checked items first when opened via keyboard, otherwise it will always focus the first focusable item.
263
+ *
264
+ * @since 5.0.0
265
+ */
266
+ focusCheckedItem = false;
267
+ /**
268
+ * Keys that will open the dropdown when the trigger is focused
269
+ *
270
+ * @internal
271
+ */
272
+ keyboardActivationKeys = [
273
+ 'Home',
274
+ 'End',
275
+ 'ArrowDown',
276
+ 'ArrowUp',
277
+ 'Enter',
278
+ ' ',
279
+ ];
280
+ /**
281
+ * Keys that will open the dropdown when the trigger is focused
282
+ *
283
+ * @internal
284
+ */
285
+ keyboardItemTriggerKeys = ['Enter', ' '];
286
+ /**
287
+ * Move dropdown along main axis of alignment
288
+ *
289
+ * @internal
290
+ */
291
+ offset;
292
+ /**
293
+ * @internal
294
+ */
295
+ overwriteDropdownStyle;
296
+ /**
297
+ * @internal
298
+ * If initialization of this dropdown is expected to be deferred submenu discovery will have to be re-run globally by the controller.
299
+ * This property indicates the need for that to the controller.
300
+ */
301
+ discoverAllSubmenus = false;
302
+ /** @internal */
303
+ ignoreRelatedSubmenu = false;
304
+ /** @internal */
305
+ suppressOverflowBehavior = false;
306
+ /** @internal */
307
+ focusHost;
308
+ /** @internal */
309
+ focusTrapOptions;
310
+ /** @internal */
311
+ hostRole;
312
+ /**
313
+ * @internal
314
+ * Called instead of the default focus-on-open logic when the dropdown is
315
+ * opened via keyboard. When not set, default behavior is used.
316
+ */
317
+ callbackFocusElement;
318
+ /**
319
+ * Fire event before visibility of dropdown has changed, preventing event will cancel showing dropdown
320
+ */
321
+ showChange;
322
+ /**
323
+ * Fire event after visibility of dropdown has changed
324
+ */
325
+ showChanged;
326
+ fallbackPlacement;
327
+ /**
328
+ * Will be fired only after dropdown changed visibility to "true"
329
+ *
330
+ * @internal
331
+ */
332
+ experimentalRequestFocus;
333
+ /**
334
+ * @internal
335
+ */
336
+ experimentalFocusNextElement;
337
+ autoUpdateCleanup;
338
+ dialogRef = makeRef.makeRef();
339
+ intersectObserverTrigger;
340
+ triggerElement;
341
+ anchorElement;
342
+ forwardQueryElement = null;
343
+ dropdownElementId = `dropdown-${sequenceId++}`;
344
+ assignedSubmenu = [];
345
+ keyboardNavigationCleanup;
346
+ focusUtilities;
347
+ connectedCallback() {
348
+ dropdownController.dropdownController.connected(this);
349
+ if (this.trigger != undefined) {
350
+ this.registerListener(this.trigger);
351
+ }
352
+ }
353
+ cacheSubmenuId(event) {
354
+ event.stopImmediatePropagation();
355
+ event.preventDefault();
356
+ const { detail } = event;
357
+ if (this.assignedSubmenu.indexOf(detail) === -1) {
358
+ this.assignedSubmenu.push(detail);
359
+ }
360
+ }
361
+ disconnectedCallback() {
362
+ dropdownController.dropdownController.dismiss(this);
363
+ dropdownController.dropdownController.disconnected(this);
364
+ if (this.autoUpdateCleanup) {
365
+ this.autoUpdateCleanup();
366
+ this.autoUpdateCleanup = undefined;
367
+ }
368
+ }
369
+ getAssignedSubmenuIds() {
370
+ return this.assignedSubmenu;
371
+ }
372
+ isPresent() {
373
+ return this.show;
374
+ }
375
+ present() {
376
+ this.show = true;
377
+ }
378
+ dismiss() {
379
+ this.show = false;
380
+ }
381
+ getId() {
382
+ return this.dropdownElementId;
383
+ }
384
+ willDismiss() {
385
+ const { defaultPrevented } = this.showChange.emit(false);
386
+ return !defaultPrevented;
387
+ }
388
+ willPresent() {
389
+ const { defaultPrevented } = this.showChange.emit(true);
390
+ return !defaultPrevented;
391
+ }
392
+ get dropdownItems() {
393
+ return Array.from(this.hostElement.querySelectorAll('ix-dropdown-item'));
394
+ }
395
+ get slotElement() {
396
+ return this.hostElement.shadowRoot.querySelector('slot');
397
+ }
398
+ disposeClickListener;
399
+ disposeKeyListener;
400
+ toggleController() {
401
+ if (!this.isPresent()) {
402
+ dropdownController.dropdownController.present(this);
403
+ }
404
+ else {
405
+ dropdownController.dropdownController.dismiss(this);
406
+ }
407
+ dropdownController.dropdownController.dismissOthers(this.getId());
408
+ }
409
+ onTriggerClick = (event) => this.handleTriggerClick(event);
410
+ handleTriggerClick(event) {
411
+ if (!event.defaultPrevented) {
412
+ this.toggleController();
413
+ }
414
+ }
415
+ onTriggerKeydown = (event) => this.handleTriggerKeydown(event);
416
+ handleTriggerKeydown(event) {
417
+ const focusFirst = (element) => requestAnimationFrame.requestAnimationFrameNoNgZone(async () => {
418
+ let shouldPreventDefault = false;
419
+ if (this.callbackFocusElement) {
420
+ shouldPreventDefault =
421
+ (await this.callbackFocusElement(event)) ?? false;
422
+ }
423
+ if (shouldPreventDefault) {
424
+ return;
425
+ }
426
+ focusUtilities.focusFirstDescendant(element, undefined, {
427
+ focusCheckedItem: this.focusCheckedItem,
428
+ });
429
+ });
430
+ const focusLast = (element) => requestAnimationFrame.requestAnimationFrameNoNgZone(async () => {
431
+ let shouldPreventDefault = false;
432
+ if (this.callbackFocusElement) {
433
+ shouldPreventDefault =
434
+ (await this.callbackFocusElement(event)) ?? false;
435
+ }
436
+ if (shouldPreventDefault) {
437
+ return;
438
+ }
439
+ focusUtilities.focusLastDescendant(element);
440
+ });
441
+ const shouldCloseOnTab = this.disableFocusTrap === true && event.key === 'Tab';
442
+ if ((event.key === 'Escape' || shouldCloseOnTab) && this.show) {
443
+ dropdownController.dropdownController.dismiss(this);
444
+ return;
445
+ }
446
+ if (this.show) {
447
+ return;
448
+ }
449
+ const navigationKeys = this.keyboardActivationKeys ?? [
450
+ 'Home',
451
+ 'End',
452
+ 'ArrowUp',
453
+ 'ArrowDown',
454
+ ' ',
455
+ 'Enter',
456
+ ];
457
+ if (!navigationKeys.includes(event.key)) {
458
+ return;
459
+ }
460
+ // If dropdown is not yet shown, try to open it
461
+ if (!this.isAnchorSubmenu()) {
462
+ if (!event.defaultPrevented) {
463
+ this.toggleController();
464
+ }
465
+ if (this.disableFocusHandling) {
466
+ event.stopImmediatePropagation();
467
+ event.preventDefault();
468
+ }
469
+ else {
470
+ // Focus first item for all keys except ArrowUp (which focuses last)
471
+ if (event.altKey) {
472
+ return;
473
+ }
474
+ if (event.key === 'ArrowUp' || event.key === 'End') {
475
+ focusLast(this.hostElement);
476
+ }
477
+ else {
478
+ focusFirst(this.hostElement);
479
+ }
480
+ }
481
+ }
482
+ else if (!this.disableFocusHandling) {
483
+ // Dropdown is already open - handle focus navigation
484
+ if (this.callbackFocusElement) {
485
+ this.callbackFocusElement(event);
486
+ }
487
+ else if (event.key === 'ArrowUp' || event.key === 'End') {
488
+ focusLast(this.hostElement);
489
+ }
490
+ else {
491
+ focusFirst(this.hostElement);
492
+ }
493
+ }
494
+ this.experimentalRequestFocus.emit({
495
+ keyEvent: event,
496
+ });
497
+ // Prevent click listener from also toggling the dropdown, which would close it again
498
+ event.preventDefault();
499
+ }
500
+ addEventListenersFor() {
501
+ if (!this.triggerElement) {
502
+ return;
503
+ }
504
+ if (!this.disposeClickListener) {
505
+ this.disposeClickListener = disposableEventListener.addDisposableEventListener(this.triggerElement, 'click', this.onTriggerClick);
506
+ }
507
+ if (!this.disposeKeyListener) {
508
+ this.disposeKeyListener = disposableEventListener.addDisposableEventListener(this.triggerElement, 'keydown', this.onTriggerKeydown);
509
+ }
510
+ this.triggerElement?.setAttribute('data-ix-dropdown-trigger', this.dropdownElementId);
511
+ }
512
+ /** @internal */
513
+ async discoverSubmenu() {
514
+ this.triggerElement?.dispatchEvent(new CustomEvent('ix-assign-sub-menu', {
515
+ bubbles: true,
516
+ composed: true,
517
+ cancelable: true,
518
+ detail: this.dropdownElementId,
519
+ }));
520
+ }
521
+ registerKeyListener() {
522
+ if (!this.triggerElement) {
523
+ return;
524
+ }
525
+ }
526
+ async registerListener(element) {
527
+ this.triggerElement = await this.resolveElement(element);
528
+ if (!this.triggerElement) {
529
+ return;
530
+ }
531
+ this.addEventListenersFor();
532
+ this.discoverSubmenu();
533
+ }
534
+ addObserverForTriggerVisibility() {
535
+ if (this.intersectObserverTrigger) {
536
+ this.intersectObserverTrigger.disconnect();
537
+ }
538
+ if (this.suppressTriggerVisibilityCheck) {
539
+ return;
540
+ }
541
+ if (!this.triggerElement) {
542
+ return;
543
+ }
544
+ this.intersectObserverTrigger = new IntersectionObserver((entries) => {
545
+ entries.forEach((entry) => {
546
+ if (!entry.isIntersecting) {
547
+ dropdownController.dropdownController.dismiss(this);
548
+ return;
549
+ }
550
+ const isTopHidden = entry.intersectionRect.top > entry.boundingClientRect.top;
551
+ const isBottomHidden = entry.intersectionRect.bottom < entry.boundingClientRect.bottom;
552
+ const isLeftHidden = entry.intersectionRect.left > entry.boundingClientRect.left;
553
+ const isRightHidden = entry.intersectionRect.right < entry.boundingClientRect.right;
554
+ this.fallbackPlacement = undefined;
555
+ if (isTopHidden) {
556
+ this.fallbackPlacement = this.createFallbackPlacement('bottom');
557
+ }
558
+ if (isBottomHidden) {
559
+ this.fallbackPlacement = this.createFallbackPlacement('top');
560
+ }
561
+ if (isLeftHidden) {
562
+ this.fallbackPlacement = this.createFallbackPlacement('right');
563
+ }
564
+ if (isRightHidden) {
565
+ this.fallbackPlacement = this.createFallbackPlacement('left');
566
+ }
567
+ });
568
+ }, {
569
+ threshold: [0, 0.5, 1],
570
+ });
571
+ this.intersectObserverTrigger.observe(this.anchorElement);
572
+ }
573
+ createFallbackPlacement(side) {
574
+ const alignment = this.placement.endsWith('-end') ? 'end' : 'start';
575
+ return `${side}-${alignment}`;
576
+ }
577
+ async resolveElement(element) {
578
+ const el = await findElement.findElement(element);
579
+ return this.checkForSubmenuAnchor(el);
580
+ }
581
+ async checkForSubmenuAnchor(element) {
582
+ if (!element) {
583
+ return undefined;
584
+ }
585
+ if (dropdownController.hasDropdownItemWrapperImplemented(element)) {
586
+ const dropdownItem = await element.getDropdownItemElement();
587
+ dropdownItem.isSubMenu = true;
588
+ this.hostElement.style.zIndex = `var(--theme-z-index-dropdown)`;
589
+ }
590
+ if (element.tagName === 'IX-DROPDOWN-ITEM') {
591
+ element.isSubMenu = true;
592
+ this.hostElement.style.zIndex = `var(--theme-z-index-dropdown)`;
593
+ }
594
+ return element;
595
+ }
596
+ async resolveAnchorElement() {
597
+ if (this.anchor) {
598
+ this.anchorElement = await this.resolveElement(this.anchor);
599
+ }
600
+ else if (this.trigger) {
601
+ this.anchorElement = await this.resolveElement(this.trigger);
602
+ }
603
+ }
604
+ async changedShow(newShow) {
605
+ if (!newShow) {
606
+ if (this.triggerElement &&
607
+ this.triggerElement.ariaHasPopup === 'menu' &&
608
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
609
+ this.triggerElement.ariaExpanded = 'false';
610
+ }
611
+ this.cleanupOnHide();
612
+ if (this.enableTopLayer) {
613
+ await this.hideDialog();
614
+ }
615
+ return;
616
+ }
617
+ await this.resolveAnchorElement();
618
+ this.registerKeyListener();
619
+ if (!this.disableFocusHandling && !this.callbackFocusElement) {
620
+ this.keyboardNavigationCleanup = configureKeyboardInteraction(() => this.forwardQueryElement ?? this.focusHost ?? this.hostElement, {
621
+ getEventListenerTarget: () => this.triggerElement ??
622
+ this.anchorElement,
623
+ onItemActivation: (event, activeElement) => {
624
+ event.preventDefault();
625
+ activeElement?.click();
626
+ },
627
+ itemTriggerKeys: this.keyboardItemTriggerKeys,
628
+ });
629
+ }
630
+ if (!this.disableFocusTrap) {
631
+ focusTrap.addFocusTrap(this.focusHost ?? this.hostElement, this.focusTrapOptions).then((focusTrap) => {
632
+ this.focusUtilities = focusTrap;
633
+ });
634
+ }
635
+ if (this.triggerElement &&
636
+ this.triggerElement.ariaHasPopup === 'menu' &&
637
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
638
+ this.triggerElement.ariaExpanded = 'true';
639
+ }
640
+ if (this.enableTopLayer) {
641
+ const popover = await this.dialogRef.waitForCurrent();
642
+ if (!popover) {
643
+ return;
644
+ }
645
+ popover.showPopover();
646
+ }
647
+ this.addObserverForTriggerVisibility();
648
+ this.applyDropdownPosition();
649
+ }
650
+ async emitShowChanged(newShow) {
651
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => this.showChanged.emit(newShow));
652
+ }
653
+ changedTrigger(newTriggerValue, oldTriggerValue) {
654
+ if (newTriggerValue && newTriggerValue !== oldTriggerValue) {
655
+ this.disposeClickListener?.();
656
+ this.disposeClickListener = undefined;
657
+ this.disposeKeyListener?.();
658
+ this.disposeKeyListener = undefined;
659
+ }
660
+ this.registerListener(newTriggerValue);
661
+ }
662
+ applyFallbackPosition(element) {
663
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => {
664
+ const referenceElement = this.hostElement.parentElement || this.hostElement;
665
+ const refRect = referenceElement.getBoundingClientRect();
666
+ const transform = `translate(${Math.round(refRect.left)}px, ${Math.round(refRect.top)}px)`;
667
+ Object.assign(element.style, {
668
+ top: '0',
669
+ left: '0',
670
+ transform,
671
+ });
672
+ });
673
+ }
674
+ async hideDialog() {
675
+ const popover = await this.dialogRef.waitForCurrent();
676
+ if (popover?.matches(':popover-open')) {
677
+ popover.hidePopover();
678
+ }
679
+ }
680
+ cleanupOnHide() {
681
+ this.intersectObserverTrigger?.disconnect();
682
+ this.destroyAutoUpdate();
683
+ this.keyboardNavigationCleanup?.();
684
+ this.focusUtilities?.destroy();
685
+ this.resetForwardQueryElement();
686
+ component.removeVisibleFocus();
687
+ if (!this.disableFocusTrap && component.hasKeyboardMode()) {
688
+ // Restore focus to trigger element
689
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => {
690
+ this.triggerElement?.focus();
691
+ });
692
+ }
693
+ }
694
+ destroyAutoUpdate() {
695
+ if (this.autoUpdateCleanup) {
696
+ this.autoUpdateCleanup();
697
+ this.autoUpdateCleanup = undefined;
698
+ }
699
+ }
700
+ isAnchorSubmenu() {
701
+ if (!dropdownController.hasDropdownItemWrapperImplemented(this.anchorElement)) {
702
+ // Is no official dropdown-item, but check if any dropdown-item
703
+ // is placed somewhere up the DOM
704
+ return !!this.anchorElement?.closest('ix-dropdown-item');
705
+ }
706
+ return true;
707
+ }
708
+ async applyDropdownPosition() {
709
+ const targetElement = this.enableTopLayer
710
+ ? await this.dialogRef.waitForCurrent()
711
+ : this.hostElement;
712
+ if (!this.show) {
713
+ return;
714
+ }
715
+ if (!targetElement) {
716
+ return;
717
+ }
718
+ if (!this.anchorElement) {
719
+ this.applyFallbackPosition(targetElement);
720
+ return;
721
+ }
722
+ const referenceElement = this.anchorElement;
723
+ const isSubmenu = this.isAnchorSubmenu();
724
+ let strategy = this.positioningStrategy;
725
+ if (this.enableTopLayer) {
726
+ // Popover API only supports fixed positioning
727
+ strategy = 'fixed';
728
+ }
729
+ let positionConfig = {
730
+ strategy,
731
+ middleware: [],
732
+ };
733
+ if (!this.suppressAutomaticPlacement) {
734
+ positionConfig.middleware?.push(findElement.flip({ fallbackStrategy: 'initialPlacement' }));
735
+ }
736
+ let placement = this.placement;
737
+ if (this.suppressTriggerVisibilityCheck === false &&
738
+ this.fallbackPlacement) {
739
+ placement = this.fallbackPlacement;
740
+ }
741
+ positionConfig.placement = isSubmenu ? 'right-start' : placement;
742
+ positionConfig.middleware = [
743
+ ...(positionConfig.middleware?.filter(Boolean) || []),
744
+ findElement.inline(),
745
+ findElement.shift(),
746
+ ];
747
+ if (this.offset) {
748
+ positionConfig.middleware.push(findElement.offset(this.offset));
749
+ }
750
+ this.destroyAutoUpdate();
751
+ this.autoUpdateCleanup = findElement.autoUpdate(referenceElement, targetElement, async () => {
752
+ const computeResponse = await findElement.computePosition(referenceElement, targetElement, positionConfig);
753
+ this.hostElement.dataset.ixDropdownPlacement =
754
+ computeResponse.placement;
755
+ Object.assign(targetElement.style, {
756
+ top: '0',
757
+ left: '0',
758
+ transform: `translate(${Math.round(computeResponse.x)}px,${Math.round(computeResponse.y)}px)`,
759
+ });
760
+ if (this.overwriteDropdownStyle) {
761
+ const overwriteStyle = await this.overwriteDropdownStyle({
762
+ dropdownRef: targetElement,
763
+ triggerRef: this.triggerElement,
764
+ });
765
+ Object.assign(targetElement.style, overwriteStyle);
766
+ }
767
+ }, {
768
+ ancestorResize: true,
769
+ ancestorScroll: true,
770
+ elementResize: true,
771
+ });
772
+ }
773
+ async componentDidLoad() {
774
+ if (!this.trigger) {
775
+ return;
776
+ }
777
+ this.changedTrigger(this.trigger, undefined);
778
+ }
779
+ async componentDidRender() {
780
+ await this.applyDropdownPosition();
781
+ await this.resolveAnchorElement();
782
+ }
783
+ isTriggerElement(element) {
784
+ const trigger = !!element.hasAttribute('data-ix-dropdown-trigger');
785
+ return trigger;
786
+ }
787
+ onDropdownClick(event) {
788
+ const target = dropdownController.dropdownController.pathIncludesTrigger(event.composedPath());
789
+ if (target) {
790
+ if (target !== this.triggerElement) {
791
+ event.preventDefault();
792
+ }
793
+ if (this.isTriggerElement(target)) {
794
+ if (this.closeBehavior === 'outside') {
795
+ event.preventDefault();
796
+ }
797
+ return;
798
+ }
799
+ }
800
+ if (!event.defaultPrevented &&
801
+ (this.closeBehavior === 'inside' || this.closeBehavior === 'both')) {
802
+ dropdownController.dropdownController.dismissAll([this.getId()], this.ignoreRelatedSubmenu);
803
+ return;
804
+ }
805
+ dropdownController.dropdownController.dismissOthers(this.getId());
806
+ }
807
+ /**
808
+ * Update position of dropdown
809
+ */
810
+ async updatePosition() {
811
+ this.applyDropdownPosition();
812
+ }
813
+ openSubmenu(event) {
814
+ const submenuIds = this.getAssignedSubmenuIds();
815
+ if (submenuIds.length === 0) {
816
+ return;
817
+ }
818
+ event.detail.activeElement.classList.add('ix-dropdown-submenu-trigger-active');
819
+ dropdownController.dropdownController.present(dropdownController.dropdownController.getDropdownById(submenuIds[0]));
820
+ this.forwardQueryElement = dropdownController.dropdownController.getDropdownById(submenuIds[0]).hostElement;
821
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => {
822
+ focusUtilities.focusFirstDescendant(dropdownController.dropdownController.getDropdownById(submenuIds[0]).hostElement);
823
+ });
824
+ }
825
+ closeSubmenu() {
826
+ const parent = dropdownController.dropdownController.getParentDropdownId(this.getId());
827
+ if (parent) {
828
+ const parentDropdown = dropdownController.dropdownController.getDropdownById(parent);
829
+ const activeTriggers = focusUtilities.queryElements(parentDropdown?.hostElement, '.ix-dropdown-submenu-trigger-active');
830
+ dropdownController.dropdownController.dismissChildren(parent);
831
+ if (parentDropdown && activeTriggers.length > 0) {
832
+ const activeTrigger = activeTriggers[0];
833
+ activeTrigger.classList.remove('ix-dropdown-submenu-trigger-active');
834
+ parentDropdown.hostElement.resetForwardQueryElement();
835
+ requestAnimationFrame.requestAnimationFrameNoNgZone(() => {
836
+ focusUtilities.focusElementInContext(activeTrigger, parentDropdown.hostElement);
837
+ });
838
+ }
839
+ }
840
+ }
841
+ /**@internal */
842
+ async resetForwardQueryElement() {
843
+ this.forwardQueryElement = null;
844
+ }
845
+ render() {
846
+ const ariaAttributes = {};
847
+ if (this.triggerElement &&
848
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
849
+ ariaAttributes['aria-labelledby'] = this.triggerElement.id;
850
+ ariaAttributes['aria-owns'] = this.triggerElement.id;
851
+ ariaAttributes['role'] = 'menu';
852
+ }
853
+ else if (this.hostRole) {
854
+ ariaAttributes['role'] = this.hostRole;
855
+ }
856
+ return (index.h(index.Host, { key: 'e822f0f658533d267365bb69eed0223ecf9dc4eb', ...ariaAttributes, "aria-modal": "true", "data-ix-dropdown": this.dropdownElementId, "data-ix-focus-trap": true, class: {
857
+ 'dropdown-menu': true,
858
+ show: this.show,
859
+ // overflow handling not needed when using top-layer
860
+ overflow: !this.suppressOverflowBehavior && !this.enableTopLayer,
861
+ }, style: this.enableTopLayer
862
+ ? {}
863
+ : {
864
+ margin: '0',
865
+ minWidth: '0px',
866
+ position: this.positioningStrategy,
867
+ }, onClick: (event) => this.onDropdownClick(event) }, this.enableTopLayer ? (index.h("dialog", { role: "presentation", ref: this.dialogRef, class: {
868
+ dialog: true,
869
+ overflow: !this.suppressOverflowBehavior,
870
+ }, popover: "manual", tabindex: -1, onClick: (event) => this.onDropdownClick(event) }, index.h("div", { class: "dropdown-container" }, this.header && index.h("div", { class: "dropdown-header" }, this.header), this.show && index.h("slot", null)))) : (index.h("div", { style: { display: 'contents' }, role: "presentation" }, this.header && index.h("div", { class: "dropdown-header" }, this.header), this.show && index.h("slot", null)))));
871
+ }
872
+ static get watchers() { return {
873
+ "show": [{
874
+ "changedShow": 0
875
+ }, {
876
+ "emitShowChanged": 0
877
+ }],
878
+ "trigger": [{
879
+ "changedTrigger": 0
880
+ }]
881
+ }; }
882
+ };
883
+ Dropdown.style = dropdownCss();
884
+
885
+ const dropdownItemCss = () => `:host{--ix-dropdown-item-checked-color:var(--theme-color-primary);display:flex;flex-direction:row;position:relative;height:2.5rem;width:auto;overflow:hidden;cursor:pointer}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host .dropdown-item{all:unset;display:flex;flex-direction:row;align-items:center;position:relative;height:calc(100% - 2px);border:0.0625rem solid transparent;white-space:nowrap;width:calc(100% - 0.5rem - 1.5rem);padding:0 0.5rem;padding-right:1.5rem}:host .dropdown-item.no-checked-field{width:calc(100% - 1rem - 1.5rem);padding:0 1rem;padding-right:1.5rem}:host .dropdown-item-checked{display:flex;align-items:center;justify-content:center;position:relative;height:100%;width:1rem;min-width:1rem;margin-right:0.5rem;color:var(--ix-dropdown-item-checked-color)}:host .dropdown-item-icon{margin-right:0.5rem;color:var(--theme-color-std-text)}:host .dropdown-item-text{display:block;position:relative;overflow:hidden;text-overflow:ellipsis;white-space:pre}:host .submenu-icon{margin-left:auto}:host(.icon-only) .dropdown-item-icon{margin-right:0px}:host(.icon-only) .dropdown-item-checked{display:none}:host(.icon-only) .dropdown-item{width:calc(100% - 0.5rem - 0.5rem);padding:0 0.5rem;padding-right:0.5rem}:host(.submenu) .dropdown-item{width:calc(100% - 0.5rem - 0.5rem);padding:0 0.5rem;padding-right:0.5rem}:host(:not(.disabled):not(:disabled).hover),:host(:not(.disabled):not(:disabled):hover){background-color:var(--theme-ghost--background--hover)}:host(:not(.disabled):not(:disabled).active),:host(:not(.disabled):not(:disabled):active){background-color:var(--theme-ghost--background--active)}:host(.disabled){pointer-events:none;color:var(--theme-color-weak-text) !important}:host(.disabled) .dropdown-item-icon{color:var(--theme-color-weak-text) !important}:host(:focus-visible){outline:none}:host(:focus-visible) .dropdown-item{border-color:var(--theme-color-focus-bdr)}:host(.ix-focused){outline:none}:host(.ix-focused) .dropdown-item{border-color:var(--theme-color-focus-bdr)}:host(.outline-visible){outline:0.0625rem solid var(--theme-color-focus-bdr);outline-offset:-0.0625rem}:host([hidden]){display:none !important}`;
886
+
887
+ const DropdownItem = class extends index.Mixin(...component.DefaultMixins, id_mixin.ComponentIdMixin, focusVisible_mixin.FocusVisibleMixin) {
888
+ constructor(hostRef) {
889
+ super();
890
+ index.registerInstance(this, hostRef);
891
+ this.itemClick = index.createEvent(this, "itemClick", 7);
892
+ }
893
+ get hostElement() { return index.getElement(this); }
894
+ /**
895
+ * Label of dropdown item
896
+ */
897
+ label;
898
+ /**
899
+ * Icon of dropdown item
900
+ */
901
+ icon;
902
+ /**
903
+ * ARIA label for the icon
904
+ */
905
+ ariaLabelIcon;
906
+ /**
907
+ * ARIA label for the item's button
908
+ * Will be set as aria-label for the nested HTML button element
909
+ *
910
+ * @since 3.2.0
911
+ */
912
+ ariaLabelButton;
913
+ /**
914
+ * Display hover state
915
+ */
916
+ hover = false;
917
+ /**
918
+ * Disable item and remove event listeners
919
+ */
920
+ disabled = false;
921
+ /**
922
+ * Whether the item is checked or not. If true a checkmark will mark the item as checked.
923
+ */
924
+ checked = false;
925
+ /**
926
+ * Role of the host surface.
927
+ * Use `option` when the item represents a listbox option (e.g. inside select); use `menuitem` in menus.
928
+ *
929
+ * @since 5.0.0
930
+ */
931
+ itemRole = 'menuitem';
932
+ /** @internal */
933
+ isSubMenu = false;
934
+ /** @internal */
935
+ suppressChecked = false;
936
+ /** @internal */
937
+ hasVisualFocus = false;
938
+ /** @internal */
939
+ itemClick;
940
+ /** @internal */
941
+ async emitItemClick() {
942
+ this.itemClick.emit(this.hostElement);
943
+ }
944
+ /** @internal */
945
+ async getDropdownItemElement() {
946
+ return this.hostElement;
947
+ }
948
+ isIconOnly() {
949
+ return (this.label === undefined &&
950
+ this.hostElement.innerText === '' &&
951
+ this.icon !== undefined);
952
+ }
953
+ render() {
954
+ const id = this.getHostElementId();
955
+ let submenuAriaAttributes = {};
956
+ if (this.isSubMenu) {
957
+ submenuAriaAttributes = {
958
+ 'aria-haspopup': 'menu',
959
+ 'aria-expanded': 'false',
960
+ };
961
+ }
962
+ return (index.h(index.Host, { key: '7eab5813bffdb69a55c339ef91acfaff1d075683', id: id, role: this.itemRole, "aria-disabled": a11y.a11yBoolean(this.disabled), "aria-label": this.hostElement.ariaLabel ?? this.ariaLabelButton, class: {
963
+ hover: this.hover,
964
+ 'icon-only': this.isIconOnly(),
965
+ disabled: this.disabled,
966
+ submenu: this.isSubMenu,
967
+ [focusUtilities.IX_FOCUS_VISIBLE]: !this.disabled,
968
+ 'outline-visible': this.hasVisualFocus,
969
+ }, onClick: () => {
970
+ if (!this.disabled) {
971
+ this.emitItemClick();
972
+ }
973
+ }, onKeyDown: (event) => {
974
+ if (!this.disabled && (event.key === 'Enter' || event.key === ' ')) {
975
+ this.emitItemClick();
976
+ }
977
+ }, ...submenuAriaAttributes }, index.h("div", { key: 'd3027e3165c38811222d4a82afae6a8f4a85ee29', class: {
978
+ 'dropdown-item': true,
979
+ 'no-checked-field': this.suppressChecked,
980
+ disabled: this.disabled,
981
+ } }, !this.suppressChecked ? (index.h("div", { class: "dropdown-item-checked" }, this.checked ? (index.h("ix-icon", { "aria-hidden": "true", class: "checkmark", name: index$1.iconSingleCheck, size: "16" })) : null)) : null, this.icon ? (index.h("ix-icon", { class: "dropdown-item-icon", name: this.icon, "aria-label": this.ariaLabelIcon })) : null, index.h("div", { key: 'bc618870c35cf9f4c8da8dbf8e6148c9cdd6ec22', class: "dropdown-item-text" }, this.label, index.h("slot", { key: '6c65471535c990245af19722ed847cd6b534d419' })), this.isSubMenu ? (index.h("ix-icon", { name: index$1.iconChevronRightSmall, class: 'submenu-icon' })) : null)));
982
+ }
983
+ static get watchers() { return {
984
+ "ixFocusVisible": [{
985
+ "$internal_checkAriaSelected": 0
986
+ }]
987
+ }; }
988
+ };
989
+ DropdownItem.style = dropdownItemCss();
990
+
991
+ exports.ix_dropdown = Dropdown;
992
+ exports.ix_dropdown_item = DropdownItem;