@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
@@ -7,62 +7,168 @@
7
7
  * LICENSE file in the root directory of this source tree.
8
8
  */
9
9
  import { autoUpdate, computePosition, flip, inline, offset, shift, } from "@floating-ui/dom";
10
- import { h, Host, } from "@stencil/core";
10
+ import { h, Host, Mixin, } from "@stencil/core";
11
11
  import { addDisposableEventListener, } from "../utils/disposable-event-listener";
12
12
  import { findElement } from "../utils/find-element";
13
- import { ArrowFocusController } from "../utils/focus";
13
+ import { addFocusTrap, } from "../utils/focus/focus-trap";
14
+ import { focusElementInContext, focusFirstDescendant, focusLastDescendant, queryElements, } from "../utils/focus/focus-utilities";
15
+ import { DefaultMixins } from "../utils/internal/component";
16
+ import { hasKeyboardMode, removeVisibleFocus, } from "../utils/internal/mixins/setup.mixin";
14
17
  import { makeRef } from "../utils/make-ref";
15
18
  import { requestAnimationFrameNoNgZone } from "../utils/requestAnimationFrame";
16
19
  import { dropdownController, hasDropdownItemWrapperImplemented, } from "./dropdown-controller";
20
+ import { configureKeyboardInteraction } from "./dropdown-focus";
17
21
  let sequenceId = 0;
18
- export class Dropdown {
22
+ export class Dropdown extends Mixin(...DefaultMixins) {
19
23
  constructor() {
20
- /**
21
- * Suppress the automatic placement of the dropdown.
22
- */
23
- this.suppressAutomaticPlacement = false;
24
- /**
25
- * Show dropdown
26
- */
27
- this.show = false;
28
- /**
29
- * Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.
30
- * If the dropdown is a child of another one, it will be closed with the parent, regardless of its own close behavior.
31
- */
32
- this.closeBehavior = 'both';
33
- /**
34
- * Placement of the dropdown
35
- */
36
- this.placement = 'bottom-start';
37
- /**
38
- * Position strategy
39
- */
40
- this.positioningStrategy = 'fixed';
41
- /**
42
- * @internal
43
- * If initialization of this dropdown is expected to be deferred submenu discovery will have to be re-run globally by the controller.
44
- * This property indicates the need for that to the controller.
45
- */
46
- this.discoverAllSubmenus = false;
47
- /** @internal */
48
- this.ignoreRelatedSubmenu = false;
49
- /** @internal */
50
- this.suppressOverflowBehavior = false;
51
- /**
52
- * Enable Popover API rendering for top-layer positioning.
53
- *
54
- * @default false in v4.x, will default to true in v5.0.0
55
- */
56
- this.enableTopLayer = false;
57
- this.dialogRef = makeRef();
58
- this.localUId = `dropdown-${sequenceId++}`;
59
- this.assignedSubmenu = [];
60
- this.itemObserver = new MutationObserver(() => {
61
- if (this.arrowFocusController) {
62
- this.arrowFocusController.items = this.dropdownItems;
63
- }
64
- });
24
+ super();
65
25
  }
26
+ hostElement;
27
+ /**
28
+ * Suppress the automatic placement of the dropdown.
29
+ */
30
+ suppressAutomaticPlacement = false;
31
+ /**
32
+ * Show dropdown
33
+ */
34
+ show = false;
35
+ /**
36
+ * Define an element that triggers the dropdown.
37
+ * A trigger can either be a string that will be interpreted as id attribute or a DOM element.
38
+ */
39
+ trigger;
40
+ /**
41
+ * Define an anchor element
42
+ */
43
+ anchor;
44
+ /**
45
+ * Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.
46
+ * If the dropdown is a child of another one, it will be closed with the parent, regardless of its own close behavior.
47
+ */
48
+ closeBehavior = 'both';
49
+ /**
50
+ * Placement of the dropdown
51
+ */
52
+ placement = 'bottom-start';
53
+ /**
54
+ * Position strategy
55
+ */
56
+ positioningStrategy = 'fixed';
57
+ /**
58
+ * An optional header shown at the top of the dropdown
59
+ */
60
+ header;
61
+ /**
62
+ * By default the dropdown gets closed if the trigger is not visible anymore (e.g. due to scrolling). Setting this property prevents that behavior.
63
+ *
64
+ * @since 5.0.0
65
+ */
66
+ suppressTriggerVisibilityCheck = false;
67
+ /**
68
+ * Suppress automatic focus when the dropdown is shown
69
+ *
70
+ * @since 4.3.0
71
+ */
72
+ disableFocusHandling = false;
73
+ /**
74
+ * Close dropdown when tabbing away, and do not trap focus inside dropdown
75
+ *
76
+ * @since 4.3.0
77
+ */
78
+ disableFocusTrap = false;
79
+ /**
80
+ * Enable Popover API rendering for top-layer positioning.
81
+ *
82
+ * @default false in v5.x, will default to true in v6.0.0
83
+ * @since 4.3.0
84
+ */
85
+ enableTopLayer = false;
86
+ /**
87
+ * If true, the dropdown will try to focus checked items first when opened via keyboard, otherwise it will always focus the first focusable item.
88
+ *
89
+ * @since 5.0.0
90
+ */
91
+ focusCheckedItem = false;
92
+ /**
93
+ * Keys that will open the dropdown when the trigger is focused
94
+ *
95
+ * @internal
96
+ */
97
+ keyboardActivationKeys = [
98
+ 'Home',
99
+ 'End',
100
+ 'ArrowDown',
101
+ 'ArrowUp',
102
+ 'Enter',
103
+ ' ',
104
+ ];
105
+ /**
106
+ * Keys that will open the dropdown when the trigger is focused
107
+ *
108
+ * @internal
109
+ */
110
+ keyboardItemTriggerKeys = ['Enter', ' '];
111
+ /**
112
+ * Move dropdown along main axis of alignment
113
+ *
114
+ * @internal
115
+ */
116
+ offset;
117
+ /**
118
+ * @internal
119
+ */
120
+ overwriteDropdownStyle;
121
+ /**
122
+ * @internal
123
+ * If initialization of this dropdown is expected to be deferred submenu discovery will have to be re-run globally by the controller.
124
+ * This property indicates the need for that to the controller.
125
+ */
126
+ discoverAllSubmenus = false;
127
+ /** @internal */
128
+ ignoreRelatedSubmenu = false;
129
+ /** @internal */
130
+ suppressOverflowBehavior = false;
131
+ /** @internal */
132
+ focusHost;
133
+ /** @internal */
134
+ focusTrapOptions;
135
+ /** @internal */
136
+ hostRole;
137
+ /**
138
+ * @internal
139
+ * Called instead of the default focus-on-open logic when the dropdown is
140
+ * opened via keyboard. When not set, default behavior is used.
141
+ */
142
+ callbackFocusElement;
143
+ /**
144
+ * Fire event before visibility of dropdown has changed, preventing event will cancel showing dropdown
145
+ */
146
+ showChange;
147
+ /**
148
+ * Fire event after visibility of dropdown has changed
149
+ */
150
+ showChanged;
151
+ fallbackPlacement;
152
+ /**
153
+ * Will be fired only after dropdown changed visibility to "true"
154
+ *
155
+ * @internal
156
+ */
157
+ experimentalRequestFocus;
158
+ /**
159
+ * @internal
160
+ */
161
+ experimentalFocusNextElement;
162
+ autoUpdateCleanup;
163
+ dialogRef = makeRef();
164
+ intersectObserverTrigger;
165
+ triggerElement;
166
+ anchorElement;
167
+ forwardQueryElement = null;
168
+ dropdownElementId = `dropdown-${sequenceId++}`;
169
+ assignedSubmenu = [];
170
+ keyboardNavigationCleanup;
171
+ focusUtilities;
66
172
  connectedCallback() {
67
173
  dropdownController.connected(this);
68
174
  if (this.trigger != undefined) {
@@ -78,25 +184,8 @@ export class Dropdown {
78
184
  }
79
185
  }
80
186
  disconnectedCallback() {
81
- var _a;
82
187
  dropdownController.dismiss(this);
83
188
  dropdownController.disconnected(this);
84
- if (this.arrowFocusController) {
85
- (_a = this.arrowFocusController) === null || _a === void 0 ? void 0 : _a.disconnect();
86
- this.arrowFocusController = undefined;
87
- }
88
- if (this.itemObserver) {
89
- this.itemObserver.disconnect();
90
- this.itemObserver = undefined;
91
- }
92
- if (this.disposeClickListener) {
93
- this.disposeClickListener();
94
- this.disposeClickListener = undefined;
95
- }
96
- if (this.disposeKeyListener) {
97
- this.disposeKeyListener();
98
- this.disposeKeyListener = undefined;
99
- }
100
189
  if (this.autoUpdateCleanup) {
101
190
  this.autoUpdateCleanup();
102
191
  this.autoUpdateCleanup = undefined;
@@ -115,14 +204,14 @@ export class Dropdown {
115
204
  this.show = false;
116
205
  }
117
206
  getId() {
118
- return this.localUId;
207
+ return this.dropdownElementId;
119
208
  }
120
209
  willDismiss() {
121
- const { defaultPrevented } = this.showChanged.emit(false);
210
+ const { defaultPrevented } = this.showChange.emit(false);
122
211
  return !defaultPrevented;
123
212
  }
124
213
  willPresent() {
125
- const { defaultPrevented } = this.showChanged.emit(true);
214
+ const { defaultPrevented } = this.showChange.emit(true);
126
215
  return !defaultPrevented;
127
216
  }
128
217
  get dropdownItems() {
@@ -131,62 +220,184 @@ export class Dropdown {
131
220
  get slotElement() {
132
221
  return this.hostElement.shadowRoot.querySelector('slot');
133
222
  }
134
- addEventListenersFor() {
135
- var _a, _b, _c;
136
- (_a = this.disposeClickListener) === null || _a === void 0 ? void 0 : _a.call(this);
137
- (_b = this.disposeKeyListener) === null || _b === void 0 ? void 0 : _b.call(this);
138
- const toggleController = () => {
139
- if (!this.isPresent()) {
140
- dropdownController.present(this);
223
+ disposeClickListener;
224
+ disposeKeyListener;
225
+ toggleController() {
226
+ if (!this.isPresent()) {
227
+ dropdownController.present(this);
228
+ }
229
+ else {
230
+ dropdownController.dismiss(this);
231
+ }
232
+ dropdownController.dismissOthers(this.getId());
233
+ }
234
+ onTriggerClick = (event) => this.handleTriggerClick(event);
235
+ handleTriggerClick(event) {
236
+ if (!event.defaultPrevented) {
237
+ this.toggleController();
238
+ }
239
+ }
240
+ onTriggerKeydown = (event) => this.handleTriggerKeydown(event);
241
+ handleTriggerKeydown(event) {
242
+ const focusFirst = (element) => requestAnimationFrameNoNgZone(async () => {
243
+ let shouldPreventDefault = false;
244
+ if (this.callbackFocusElement) {
245
+ shouldPreventDefault =
246
+ (await this.callbackFocusElement(event)) ?? false;
141
247
  }
142
- else {
143
- dropdownController.dismiss(this);
248
+ if (shouldPreventDefault) {
249
+ return;
144
250
  }
145
- dropdownController.dismissOthers(this.getId());
146
- };
147
- if (!this.triggerElement) {
251
+ focusFirstDescendant(element, undefined, {
252
+ focusCheckedItem: this.focusCheckedItem,
253
+ });
254
+ });
255
+ const focusLast = (element) => requestAnimationFrameNoNgZone(async () => {
256
+ let shouldPreventDefault = false;
257
+ if (this.callbackFocusElement) {
258
+ shouldPreventDefault =
259
+ (await this.callbackFocusElement(event)) ?? false;
260
+ }
261
+ if (shouldPreventDefault) {
262
+ return;
263
+ }
264
+ focusLastDescendant(element);
265
+ });
266
+ const shouldCloseOnTab = this.disableFocusTrap === true && event.key === 'Tab';
267
+ if ((event.key === 'Escape' || shouldCloseOnTab) && this.show) {
268
+ dropdownController.dismiss(this);
269
+ return;
270
+ }
271
+ if (this.show) {
148
272
  return;
149
273
  }
150
- this.disposeClickListener = addDisposableEventListener(this.triggerElement, 'click', (event) => {
274
+ const navigationKeys = this.keyboardActivationKeys ?? [
275
+ 'Home',
276
+ 'End',
277
+ 'ArrowUp',
278
+ 'ArrowDown',
279
+ ' ',
280
+ 'Enter',
281
+ ];
282
+ if (!navigationKeys.includes(event.key)) {
283
+ return;
284
+ }
285
+ // If dropdown is not yet shown, try to open it
286
+ if (!this.isAnchorSubmenu()) {
151
287
  if (!event.defaultPrevented) {
152
- toggleController();
288
+ this.toggleController();
153
289
  }
290
+ if (this.disableFocusHandling) {
291
+ event.stopImmediatePropagation();
292
+ event.preventDefault();
293
+ }
294
+ else {
295
+ // Focus first item for all keys except ArrowUp (which focuses last)
296
+ if (event.altKey) {
297
+ return;
298
+ }
299
+ if (event.key === 'ArrowUp' || event.key === 'End') {
300
+ focusLast(this.hostElement);
301
+ }
302
+ else {
303
+ focusFirst(this.hostElement);
304
+ }
305
+ }
306
+ }
307
+ else if (!this.disableFocusHandling) {
308
+ // Dropdown is already open - handle focus navigation
309
+ if (this.callbackFocusElement) {
310
+ this.callbackFocusElement(event);
311
+ }
312
+ else if (event.key === 'ArrowUp' || event.key === 'End') {
313
+ focusLast(this.hostElement);
314
+ }
315
+ else {
316
+ focusFirst(this.hostElement);
317
+ }
318
+ }
319
+ this.experimentalRequestFocus.emit({
320
+ keyEvent: event,
154
321
  });
155
- (_c = this.triggerElement) === null || _c === void 0 ? void 0 : _c.setAttribute('data-ix-dropdown-trigger', this.localUId);
322
+ // Prevent click listener from also toggling the dropdown, which would close it again
323
+ event.preventDefault();
324
+ }
325
+ addEventListenersFor() {
326
+ if (!this.triggerElement) {
327
+ return;
328
+ }
329
+ if (!this.disposeClickListener) {
330
+ this.disposeClickListener = addDisposableEventListener(this.triggerElement, 'click', this.onTriggerClick);
331
+ }
332
+ if (!this.disposeKeyListener) {
333
+ this.disposeKeyListener = addDisposableEventListener(this.triggerElement, 'keydown', this.onTriggerKeydown);
334
+ }
335
+ this.triggerElement?.setAttribute('data-ix-dropdown-trigger', this.dropdownElementId);
156
336
  }
157
337
  /** @internal */
158
338
  async discoverSubmenu() {
159
- var _a;
160
- (_a = this.triggerElement) === null || _a === void 0 ? void 0 : _a.dispatchEvent(new CustomEvent('ix-assign-sub-menu', {
339
+ this.triggerElement?.dispatchEvent(new CustomEvent('ix-assign-sub-menu', {
161
340
  bubbles: true,
162
341
  composed: true,
163
342
  cancelable: true,
164
- detail: this.localUId,
343
+ detail: this.dropdownElementId,
165
344
  }));
166
345
  }
167
346
  registerKeyListener() {
168
347
  if (!this.triggerElement) {
169
348
  return;
170
349
  }
171
- this.disposeKeyListener = addDisposableEventListener(this.triggerElement, 'keydown', ((event) => {
172
- if (event.key !== 'ArrowDown') {
173
- return;
174
- }
175
- if (document.activeElement !== this.triggerElement) {
176
- return;
177
- }
178
- dropdownController.present(this);
179
- setTimeout(() => {
180
- this.focusDropdownItem(0);
181
- });
182
- }));
183
350
  }
184
351
  async registerListener(element) {
185
352
  this.triggerElement = await this.resolveElement(element);
186
- if (this.triggerElement) {
187
- this.addEventListenersFor();
188
- this.discoverSubmenu();
353
+ if (!this.triggerElement) {
354
+ return;
189
355
  }
356
+ this.addEventListenersFor();
357
+ this.discoverSubmenu();
358
+ }
359
+ addObserverForTriggerVisibility() {
360
+ if (this.intersectObserverTrigger) {
361
+ this.intersectObserverTrigger.disconnect();
362
+ }
363
+ if (this.suppressTriggerVisibilityCheck) {
364
+ return;
365
+ }
366
+ if (!this.triggerElement) {
367
+ return;
368
+ }
369
+ this.intersectObserverTrigger = new IntersectionObserver((entries) => {
370
+ entries.forEach((entry) => {
371
+ if (!entry.isIntersecting) {
372
+ dropdownController.dismiss(this);
373
+ return;
374
+ }
375
+ const isTopHidden = entry.intersectionRect.top > entry.boundingClientRect.top;
376
+ const isBottomHidden = entry.intersectionRect.bottom < entry.boundingClientRect.bottom;
377
+ const isLeftHidden = entry.intersectionRect.left > entry.boundingClientRect.left;
378
+ const isRightHidden = entry.intersectionRect.right < entry.boundingClientRect.right;
379
+ this.fallbackPlacement = undefined;
380
+ if (isTopHidden) {
381
+ this.fallbackPlacement = this.createFallbackPlacement('bottom');
382
+ }
383
+ if (isBottomHidden) {
384
+ this.fallbackPlacement = this.createFallbackPlacement('top');
385
+ }
386
+ if (isLeftHidden) {
387
+ this.fallbackPlacement = this.createFallbackPlacement('right');
388
+ }
389
+ if (isRightHidden) {
390
+ this.fallbackPlacement = this.createFallbackPlacement('left');
391
+ }
392
+ });
393
+ }, {
394
+ threshold: [0, 0.5, 1],
395
+ });
396
+ this.intersectObserverTrigger.observe(this.anchorElement);
397
+ }
398
+ createFallbackPlacement(side) {
399
+ const alignment = this.placement.endsWith('-end') ? 'end' : 'start';
400
+ return `${side}-${alignment}`;
190
401
  }
191
402
  async resolveElement(element) {
192
403
  const el = await findElement(element);
@@ -216,32 +427,95 @@ export class Dropdown {
216
427
  }
217
428
  }
218
429
  async changedShow(newShow) {
219
- var _a;
220
430
  if (!newShow) {
431
+ if (this.triggerElement &&
432
+ this.triggerElement.ariaHasPopup === 'menu' &&
433
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
434
+ this.triggerElement.ariaExpanded = 'false';
435
+ }
221
436
  this.cleanupOnHide();
222
437
  if (this.enableTopLayer) {
223
- await this.hideDropdownAsync();
438
+ await this.hideDialog();
224
439
  }
225
440
  return;
226
441
  }
227
- this.arrowFocusController = new ArrowFocusController(this.dropdownItems, this.hostElement, (index) => this.focusDropdownItem(index));
228
- (_a = this.itemObserver) === null || _a === void 0 ? void 0 : _a.observe(this.hostElement, {
229
- childList: true,
230
- subtree: true,
231
- });
442
+ await this.resolveAnchorElement();
232
443
  this.registerKeyListener();
233
- if (this.enableTopLayer) {
234
- await this.showDropdownAsync();
235
- return;
444
+ if (!this.disableFocusHandling && !this.callbackFocusElement) {
445
+ this.keyboardNavigationCleanup = configureKeyboardInteraction(() => this.forwardQueryElement ?? this.focusHost ?? this.hostElement, {
446
+ getEventListenerTarget: () => this.triggerElement ??
447
+ this.anchorElement,
448
+ onItemActivation: (event, activeElement) => {
449
+ event.preventDefault();
450
+ activeElement?.click();
451
+ },
452
+ itemTriggerKeys: this.keyboardItemTriggerKeys,
453
+ });
236
454
  }
237
- await this.resolveAnchorElement();
238
- if (this.anchorElement) {
239
- this.applyDropdownPosition();
455
+ if (!this.disableFocusTrap) {
456
+ addFocusTrap(this.focusHost ?? this.hostElement, this.focusTrapOptions).then((focusTrap) => {
457
+ this.focusUtilities = focusTrap;
458
+ });
459
+ }
460
+ if (this.triggerElement &&
461
+ this.triggerElement.ariaHasPopup === 'menu' &&
462
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
463
+ this.triggerElement.ariaExpanded = 'true';
464
+ }
465
+ if (this.enableTopLayer) {
466
+ const popover = await this.dialogRef.waitForCurrent();
467
+ if (!popover) {
468
+ return;
469
+ }
470
+ popover.showPopover();
240
471
  }
472
+ this.addObserverForTriggerVisibility();
473
+ this.applyDropdownPosition();
241
474
  }
242
- changedTrigger(newTriggerValue) {
475
+ async emitShowChanged(newShow) {
476
+ requestAnimationFrameNoNgZone(() => this.showChanged.emit(newShow));
477
+ }
478
+ changedTrigger(newTriggerValue, oldTriggerValue) {
479
+ if (newTriggerValue && newTriggerValue !== oldTriggerValue) {
480
+ this.disposeClickListener?.();
481
+ this.disposeClickListener = undefined;
482
+ this.disposeKeyListener?.();
483
+ this.disposeKeyListener = undefined;
484
+ }
243
485
  this.registerListener(newTriggerValue);
244
486
  }
487
+ applyFallbackPosition(element) {
488
+ requestAnimationFrameNoNgZone(() => {
489
+ const referenceElement = this.hostElement.parentElement || this.hostElement;
490
+ const refRect = referenceElement.getBoundingClientRect();
491
+ const transform = `translate(${Math.round(refRect.left)}px, ${Math.round(refRect.top)}px)`;
492
+ Object.assign(element.style, {
493
+ top: '0',
494
+ left: '0',
495
+ transform,
496
+ });
497
+ });
498
+ }
499
+ async hideDialog() {
500
+ const popover = await this.dialogRef.waitForCurrent();
501
+ if (popover?.matches(':popover-open')) {
502
+ popover.hidePopover();
503
+ }
504
+ }
505
+ cleanupOnHide() {
506
+ this.intersectObserverTrigger?.disconnect();
507
+ this.destroyAutoUpdate();
508
+ this.keyboardNavigationCleanup?.();
509
+ this.focusUtilities?.destroy();
510
+ this.resetForwardQueryElement();
511
+ removeVisibleFocus();
512
+ if (!this.disableFocusTrap && hasKeyboardMode()) {
513
+ // Restore focus to trigger element
514
+ requestAnimationFrameNoNgZone(() => {
515
+ this.triggerElement?.focus();
516
+ });
517
+ }
518
+ }
245
519
  destroyAutoUpdate() {
246
520
  if (this.autoUpdateCleanup) {
247
521
  this.autoUpdateCleanup();
@@ -249,68 +523,32 @@ export class Dropdown {
249
523
  }
250
524
  }
251
525
  isAnchorSubmenu() {
252
- var _a;
253
526
  if (!hasDropdownItemWrapperImplemented(this.anchorElement)) {
254
527
  // Is no official dropdown-item, but check if any dropdown-item
255
528
  // is placed somewhere up the DOM
256
- return !!((_a = this.anchorElement) === null || _a === void 0 ? void 0 : _a.closest('ix-dropdown-item'));
529
+ return !!this.anchorElement?.closest('ix-dropdown-item');
257
530
  }
258
531
  return true;
259
532
  }
260
- async showDropdownAsync() {
261
- const popover = await this.dialogRef.waitForCurrent();
262
- if (!popover) {
263
- return;
264
- }
265
- popover.showPopover();
266
- await this.resolveAnchorElement();
267
- if (this.anchorElement) {
268
- this.applyDropdownPosition();
269
- }
270
- else {
271
- requestAnimationFrameNoNgZone(() => {
272
- const referenceElement = this.hostElement.parentElement || this.hostElement;
273
- const refRect = referenceElement.getBoundingClientRect();
274
- const transform = `translate(${Math.round(refRect.left)}px, ${Math.round(refRect.top)}px)`;
275
- Object.assign(popover.style, {
276
- top: '0',
277
- left: '0',
278
- transform,
279
- });
280
- });
281
- }
282
- }
283
- async hideDropdownAsync() {
284
- const popover = await this.dialogRef.waitForCurrent();
285
- if (popover === null || popover === void 0 ? void 0 : popover.matches(':popover-open')) {
286
- popover.hidePopover();
287
- }
288
- }
289
- cleanupOnHide() {
290
- var _a, _b, _c;
291
- this.destroyAutoUpdate();
292
- (_a = this.arrowFocusController) === null || _a === void 0 ? void 0 : _a.disconnect();
293
- (_b = this.itemObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
294
- (_c = this.disposeKeyListener) === null || _c === void 0 ? void 0 : _c.call(this);
295
- }
296
533
  async applyDropdownPosition() {
297
- var _a, _b;
534
+ const targetElement = this.enableTopLayer
535
+ ? await this.dialogRef.waitForCurrent()
536
+ : this.hostElement;
298
537
  if (!this.show) {
299
538
  return;
300
539
  }
540
+ if (!targetElement) {
541
+ return;
542
+ }
301
543
  if (!this.anchorElement) {
544
+ this.applyFallbackPosition(targetElement);
302
545
  return;
303
546
  }
304
547
  const referenceElement = this.anchorElement;
305
548
  const isSubmenu = this.isAnchorSubmenu();
306
- let targetElement = this.hostElement;
307
549
  let strategy = this.positioningStrategy;
308
550
  if (this.enableTopLayer) {
309
- const dialog = await this.dialogRef.waitForCurrent();
310
- if (!dialog) {
311
- return;
312
- }
313
- targetElement = dialog;
551
+ // Popover API only supports fixed positioning
314
552
  strategy = 'fixed';
315
553
  }
316
554
  let positionConfig = {
@@ -318,11 +556,16 @@ export class Dropdown {
318
556
  middleware: [],
319
557
  };
320
558
  if (!this.suppressAutomaticPlacement) {
321
- (_a = positionConfig.middleware) === null || _a === void 0 ? void 0 : _a.push(flip({ fallbackStrategy: 'initialPlacement' }));
559
+ positionConfig.middleware?.push(flip({ fallbackStrategy: 'initialPlacement' }));
560
+ }
561
+ let placement = this.placement;
562
+ if (this.suppressTriggerVisibilityCheck === false &&
563
+ this.fallbackPlacement) {
564
+ placement = this.fallbackPlacement;
322
565
  }
323
- positionConfig.placement = isSubmenu ? 'right-start' : this.placement;
566
+ positionConfig.placement = isSubmenu ? 'right-start' : placement;
324
567
  positionConfig.middleware = [
325
- ...(((_b = positionConfig.middleware) === null || _b === void 0 ? void 0 : _b.filter(Boolean)) || []),
568
+ ...(positionConfig.middleware?.filter(Boolean) || []),
326
569
  inline(),
327
570
  shift(),
328
571
  ];
@@ -332,6 +575,8 @@ export class Dropdown {
332
575
  this.destroyAutoUpdate();
333
576
  this.autoUpdateCleanup = autoUpdate(referenceElement, targetElement, async () => {
334
577
  const computeResponse = await computePosition(referenceElement, targetElement, positionConfig);
578
+ this.hostElement.dataset.ixDropdownPlacement =
579
+ computeResponse.placement;
335
580
  Object.assign(targetElement.style, {
336
581
  top: '0',
337
582
  left: '0',
@@ -350,23 +595,11 @@ export class Dropdown {
350
595
  elementResize: true,
351
596
  });
352
597
  }
353
- focusDropdownItem(index) {
354
- requestAnimationFrameNoNgZone(() => {
355
- var _a, _b;
356
- const button = (_b = (_a = this.dropdownItems[index]) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('button');
357
- if (button) {
358
- button.focus();
359
- }
360
- });
361
- }
362
598
  async componentDidLoad() {
363
- if (this.show) {
364
- this.changedShow(true);
365
- }
366
599
  if (!this.trigger) {
367
600
  return;
368
601
  }
369
- this.changedTrigger(this.trigger);
602
+ this.changedTrigger(this.trigger, undefined);
370
603
  }
371
604
  async componentDidRender() {
372
605
  await this.applyDropdownPosition();
@@ -402,25 +635,64 @@ export class Dropdown {
402
635
  async updatePosition() {
403
636
  this.applyDropdownPosition();
404
637
  }
638
+ openSubmenu(event) {
639
+ const submenuIds = this.getAssignedSubmenuIds();
640
+ if (submenuIds.length === 0) {
641
+ return;
642
+ }
643
+ event.detail.activeElement.classList.add('ix-dropdown-submenu-trigger-active');
644
+ dropdownController.present(dropdownController.getDropdownById(submenuIds[0]));
645
+ this.forwardQueryElement = dropdownController.getDropdownById(submenuIds[0]).hostElement;
646
+ requestAnimationFrameNoNgZone(() => {
647
+ focusFirstDescendant(dropdownController.getDropdownById(submenuIds[0]).hostElement);
648
+ });
649
+ }
650
+ closeSubmenu() {
651
+ const parent = dropdownController.getParentDropdownId(this.getId());
652
+ if (parent) {
653
+ const parentDropdown = dropdownController.getDropdownById(parent);
654
+ const activeTriggers = queryElements(parentDropdown?.hostElement, '.ix-dropdown-submenu-trigger-active');
655
+ dropdownController.dismissChildren(parent);
656
+ if (parentDropdown && activeTriggers.length > 0) {
657
+ const activeTrigger = activeTriggers[0];
658
+ activeTrigger.classList.remove('ix-dropdown-submenu-trigger-active');
659
+ parentDropdown.hostElement.resetForwardQueryElement();
660
+ requestAnimationFrameNoNgZone(() => {
661
+ focusElementInContext(activeTrigger, parentDropdown.hostElement);
662
+ });
663
+ }
664
+ }
665
+ }
666
+ /**@internal */
667
+ async resetForwardQueryElement() {
668
+ this.forwardQueryElement = null;
669
+ }
405
670
  render() {
406
- if (this.enableTopLayer) {
407
- return (h(Host, { "data-ix-dropdown": this.localUId, class: {
408
- 'dropdown-menu': true,
409
- show: this.show,
410
- } }, h("dialog", { ref: this.dialogRef, class: {
411
- dialog: true,
412
- overflow: !this.suppressOverflowBehavior,
413
- }, popover: "manual", "aria-modal": "true", "aria-label": this.header, tabindex: -1, onClick: (event) => this.onDropdownClick(event) }, h("div", { class: "dropdown-container" }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null)))));
414
- }
415
- return (h(Host, { "data-ix-dropdown": this.localUId, class: {
671
+ const ariaAttributes = {};
672
+ if (this.triggerElement &&
673
+ this.triggerElement.tagName === 'IX-DROPDOWN-ITEM') {
674
+ ariaAttributes['aria-labelledby'] = this.triggerElement.id;
675
+ ariaAttributes['aria-owns'] = this.triggerElement.id;
676
+ ariaAttributes['role'] = 'menu';
677
+ }
678
+ else if (this.hostRole) {
679
+ ariaAttributes['role'] = this.hostRole;
680
+ }
681
+ return (h(Host, { key: 'e822f0f658533d267365bb69eed0223ecf9dc4eb', ...ariaAttributes, "aria-modal": "true", "data-ix-dropdown": this.dropdownElementId, "data-ix-focus-trap": true, class: {
416
682
  'dropdown-menu': true,
417
683
  show: this.show,
684
+ // overflow handling not needed when using top-layer
685
+ overflow: !this.suppressOverflowBehavior && !this.enableTopLayer,
686
+ }, style: this.enableTopLayer
687
+ ? {}
688
+ : {
689
+ margin: '0',
690
+ minWidth: '0px',
691
+ position: this.positioningStrategy,
692
+ }, onClick: (event) => this.onDropdownClick(event) }, this.enableTopLayer ? (h("dialog", { role: "presentation", ref: this.dialogRef, class: {
693
+ dialog: true,
418
694
  overflow: !this.suppressOverflowBehavior,
419
- }, style: {
420
- margin: '0',
421
- minWidth: '0px',
422
- position: this.positioningStrategy,
423
- }, role: "list", onClick: (event) => this.onDropdownClick(event) }, h("div", { style: { display: 'contents' } }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null))));
695
+ }, popover: "manual", tabindex: -1, onClick: (event) => this.onDropdownClick(event) }, h("div", { class: "dropdown-container" }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null)))) : (h("div", { style: { display: 'contents' }, role: "presentation" }, this.header && h("div", { class: "dropdown-header" }, this.header), this.show && h("slot", null)))));
424
696
  }
425
697
  static get is() { return "ix-dropdown"; }
426
698
  static get encapsulation() { return "shadow"; }
@@ -621,6 +893,166 @@ export class Dropdown {
621
893
  "reflect": false,
622
894
  "attribute": "header"
623
895
  },
896
+ "suppressTriggerVisibilityCheck": {
897
+ "type": "boolean",
898
+ "mutable": false,
899
+ "complexType": {
900
+ "original": "boolean",
901
+ "resolved": "boolean",
902
+ "references": {}
903
+ },
904
+ "required": false,
905
+ "optional": false,
906
+ "docs": {
907
+ "tags": [{
908
+ "name": "since",
909
+ "text": "5.0.0"
910
+ }],
911
+ "text": "By default the dropdown gets closed if the trigger is not visible anymore (e.g. due to scrolling). Setting this property prevents that behavior."
912
+ },
913
+ "getter": false,
914
+ "setter": false,
915
+ "reflect": false,
916
+ "attribute": "suppress-trigger-visibility-check",
917
+ "defaultValue": "false"
918
+ },
919
+ "disableFocusHandling": {
920
+ "type": "boolean",
921
+ "mutable": false,
922
+ "complexType": {
923
+ "original": "boolean",
924
+ "resolved": "boolean",
925
+ "references": {}
926
+ },
927
+ "required": false,
928
+ "optional": false,
929
+ "docs": {
930
+ "tags": [{
931
+ "name": "since",
932
+ "text": "4.3.0"
933
+ }],
934
+ "text": "Suppress automatic focus when the dropdown is shown"
935
+ },
936
+ "getter": false,
937
+ "setter": false,
938
+ "reflect": false,
939
+ "attribute": "disable-focus-handling",
940
+ "defaultValue": "false"
941
+ },
942
+ "disableFocusTrap": {
943
+ "type": "boolean",
944
+ "mutable": false,
945
+ "complexType": {
946
+ "original": "boolean",
947
+ "resolved": "boolean",
948
+ "references": {}
949
+ },
950
+ "required": false,
951
+ "optional": false,
952
+ "docs": {
953
+ "tags": [{
954
+ "name": "since",
955
+ "text": "4.3.0"
956
+ }],
957
+ "text": "Close dropdown when tabbing away, and do not trap focus inside dropdown"
958
+ },
959
+ "getter": false,
960
+ "setter": false,
961
+ "reflect": false,
962
+ "attribute": "disable-focus-trap",
963
+ "defaultValue": "false"
964
+ },
965
+ "enableTopLayer": {
966
+ "type": "boolean",
967
+ "mutable": false,
968
+ "complexType": {
969
+ "original": "boolean",
970
+ "resolved": "boolean",
971
+ "references": {}
972
+ },
973
+ "required": false,
974
+ "optional": false,
975
+ "docs": {
976
+ "tags": [{
977
+ "name": "default",
978
+ "text": "false in v5.x, will default to true in v6.0.0"
979
+ }, {
980
+ "name": "since",
981
+ "text": "4.3.0"
982
+ }],
983
+ "text": "Enable Popover API rendering for top-layer positioning."
984
+ },
985
+ "getter": false,
986
+ "setter": false,
987
+ "reflect": false,
988
+ "attribute": "enable-top-layer",
989
+ "defaultValue": "false"
990
+ },
991
+ "focusCheckedItem": {
992
+ "type": "boolean",
993
+ "mutable": false,
994
+ "complexType": {
995
+ "original": "boolean",
996
+ "resolved": "boolean",
997
+ "references": {}
998
+ },
999
+ "required": false,
1000
+ "optional": false,
1001
+ "docs": {
1002
+ "tags": [{
1003
+ "name": "since",
1004
+ "text": "5.0.0"
1005
+ }],
1006
+ "text": "If true, the dropdown will try to focus checked items first when opened via keyboard, otherwise it will always focus the first focusable item."
1007
+ },
1008
+ "getter": false,
1009
+ "setter": false,
1010
+ "reflect": false,
1011
+ "attribute": "focus-checked-item",
1012
+ "defaultValue": "false"
1013
+ },
1014
+ "keyboardActivationKeys": {
1015
+ "type": "unknown",
1016
+ "mutable": false,
1017
+ "complexType": {
1018
+ "original": "string[]",
1019
+ "resolved": "string[]",
1020
+ "references": {}
1021
+ },
1022
+ "required": false,
1023
+ "optional": false,
1024
+ "docs": {
1025
+ "tags": [{
1026
+ "name": "internal",
1027
+ "text": undefined
1028
+ }],
1029
+ "text": "Keys that will open the dropdown when the trigger is focused"
1030
+ },
1031
+ "getter": false,
1032
+ "setter": false,
1033
+ "defaultValue": "[\n 'Home',\n 'End',\n 'ArrowDown',\n 'ArrowUp',\n 'Enter',\n ' ',\n ]"
1034
+ },
1035
+ "keyboardItemTriggerKeys": {
1036
+ "type": "unknown",
1037
+ "mutable": false,
1038
+ "complexType": {
1039
+ "original": "string[]",
1040
+ "resolved": "string[]",
1041
+ "references": {}
1042
+ },
1043
+ "required": false,
1044
+ "optional": false,
1045
+ "docs": {
1046
+ "tags": [{
1047
+ "name": "internal",
1048
+ "text": undefined
1049
+ }],
1050
+ "text": "Keys that will open the dropdown when the trigger is focused"
1051
+ },
1052
+ "getter": false,
1053
+ "setter": false,
1054
+ "defaultValue": "['Enter', ' ']"
1055
+ },
624
1056
  "offset": {
625
1057
  "type": "unknown",
626
1058
  "mutable": false,
@@ -747,33 +1179,133 @@ export class Dropdown {
747
1179
  "attribute": "suppress-overflow-behavior",
748
1180
  "defaultValue": "false"
749
1181
  },
750
- "enableTopLayer": {
751
- "type": "boolean",
1182
+ "focusHost": {
1183
+ "type": "unknown",
752
1184
  "mutable": false,
753
1185
  "complexType": {
754
- "original": "boolean",
755
- "resolved": "boolean",
1186
+ "original": "HTMLElement",
1187
+ "resolved": "HTMLElement | undefined",
1188
+ "references": {
1189
+ "HTMLElement": {
1190
+ "location": "global",
1191
+ "id": "global::HTMLElement"
1192
+ }
1193
+ }
1194
+ },
1195
+ "required": false,
1196
+ "optional": true,
1197
+ "docs": {
1198
+ "tags": [{
1199
+ "name": "internal",
1200
+ "text": undefined
1201
+ }],
1202
+ "text": ""
1203
+ },
1204
+ "getter": false,
1205
+ "setter": false
1206
+ },
1207
+ "focusTrapOptions": {
1208
+ "type": "unknown",
1209
+ "mutable": false,
1210
+ "complexType": {
1211
+ "original": "FocusTrapOptions",
1212
+ "resolved": "undefined | { targetElement?: HTMLElement | MakeRef<any> | undefined; trapFocusInShadowDom?: boolean | undefined; excludeElements?: boolean | undefined; }",
1213
+ "references": {
1214
+ "FocusTrapOptions": {
1215
+ "location": "import",
1216
+ "path": "../utils/focus/focus-trap",
1217
+ "id": "src/components/utils/focus/focus-trap.ts::FocusTrapOptions",
1218
+ "referenceLocation": "FocusTrapOptions"
1219
+ }
1220
+ }
1221
+ },
1222
+ "required": false,
1223
+ "optional": true,
1224
+ "docs": {
1225
+ "tags": [{
1226
+ "name": "internal",
1227
+ "text": undefined
1228
+ }],
1229
+ "text": ""
1230
+ },
1231
+ "getter": false,
1232
+ "setter": false
1233
+ },
1234
+ "hostRole": {
1235
+ "type": "string",
1236
+ "mutable": false,
1237
+ "complexType": {
1238
+ "original": "string",
1239
+ "resolved": "string | undefined",
756
1240
  "references": {}
757
1241
  },
758
1242
  "required": false,
759
- "optional": false,
1243
+ "optional": true,
760
1244
  "docs": {
761
1245
  "tags": [{
762
- "name": "default",
763
- "text": "false in v4.x, will default to true in v5.0.0"
1246
+ "name": "internal",
1247
+ "text": undefined
764
1248
  }],
765
- "text": "Enable Popover API rendering for top-layer positioning."
1249
+ "text": ""
766
1250
  },
767
1251
  "getter": false,
768
1252
  "setter": false,
769
1253
  "reflect": false,
770
- "attribute": "enable-top-layer",
771
- "defaultValue": "false"
1254
+ "attribute": "host-role"
1255
+ },
1256
+ "callbackFocusElement": {
1257
+ "type": "unknown",
1258
+ "mutable": false,
1259
+ "complexType": {
1260
+ "original": "(\n event: KeyboardEvent\n ) => Promise<boolean | undefined>",
1261
+ "resolved": "((event: KeyboardEvent) => Promise<boolean | undefined>) | undefined",
1262
+ "references": {
1263
+ "KeyboardEvent": {
1264
+ "location": "global",
1265
+ "id": "global::KeyboardEvent"
1266
+ },
1267
+ "Promise": {
1268
+ "location": "global",
1269
+ "id": "global::Promise"
1270
+ }
1271
+ }
1272
+ },
1273
+ "required": false,
1274
+ "optional": true,
1275
+ "docs": {
1276
+ "tags": [{
1277
+ "name": "internal",
1278
+ "text": "Called instead of the default focus-on-open logic when the dropdown is\nopened via keyboard. When not set, default behavior is used."
1279
+ }],
1280
+ "text": ""
1281
+ },
1282
+ "getter": false,
1283
+ "setter": false
772
1284
  }
773
1285
  };
774
1286
  }
1287
+ static get states() {
1288
+ return {
1289
+ "fallbackPlacement": {}
1290
+ };
1291
+ }
775
1292
  static get events() {
776
1293
  return [{
1294
+ "method": "showChange",
1295
+ "name": "showChange",
1296
+ "bubbles": true,
1297
+ "cancelable": true,
1298
+ "composed": true,
1299
+ "docs": {
1300
+ "tags": [],
1301
+ "text": "Fire event before visibility of dropdown has changed, preventing event will cancel showing dropdown"
1302
+ },
1303
+ "complexType": {
1304
+ "original": "boolean",
1305
+ "resolved": "boolean",
1306
+ "references": {}
1307
+ }
1308
+ }, {
777
1309
  "method": "showChanged",
778
1310
  "name": "showChanged",
779
1311
  "bubbles": true,
@@ -788,6 +1320,47 @@ export class Dropdown {
788
1320
  "resolved": "boolean",
789
1321
  "references": {}
790
1322
  }
1323
+ }, {
1324
+ "method": "experimentalRequestFocus",
1325
+ "name": "experimentalRequestFocus",
1326
+ "bubbles": true,
1327
+ "cancelable": true,
1328
+ "composed": true,
1329
+ "docs": {
1330
+ "tags": [{
1331
+ "name": "internal",
1332
+ "text": undefined
1333
+ }],
1334
+ "text": "Will be fired only after dropdown changed visibility to \"true\""
1335
+ },
1336
+ "complexType": {
1337
+ "original": "{\n keyEvent: KeyboardEvent;\n }",
1338
+ "resolved": "{ keyEvent: KeyboardEvent; }",
1339
+ "references": {
1340
+ "KeyboardEvent": {
1341
+ "location": "global",
1342
+ "id": "global::KeyboardEvent"
1343
+ }
1344
+ }
1345
+ }
1346
+ }, {
1347
+ "method": "experimentalFocusNextElement",
1348
+ "name": "experimentalFocusNextElement",
1349
+ "bubbles": true,
1350
+ "cancelable": true,
1351
+ "composed": true,
1352
+ "docs": {
1353
+ "tags": [{
1354
+ "name": "internal",
1355
+ "text": undefined
1356
+ }],
1357
+ "text": ""
1358
+ },
1359
+ "complexType": {
1360
+ "original": "void",
1361
+ "resolved": "void",
1362
+ "references": {}
1363
+ }
791
1364
  }];
792
1365
  }
793
1366
  static get methods() {
@@ -828,6 +1401,26 @@ export class Dropdown {
828
1401
  "text": "Update position of dropdown",
829
1402
  "tags": []
830
1403
  }
1404
+ },
1405
+ "resetForwardQueryElement": {
1406
+ "complexType": {
1407
+ "signature": "() => Promise<void>",
1408
+ "parameters": [],
1409
+ "references": {
1410
+ "Promise": {
1411
+ "location": "global",
1412
+ "id": "global::Promise"
1413
+ }
1414
+ },
1415
+ "return": "Promise<void>"
1416
+ },
1417
+ "docs": {
1418
+ "text": "",
1419
+ "tags": [{
1420
+ "name": "internal",
1421
+ "text": undefined
1422
+ }]
1423
+ }
831
1424
  }
832
1425
  };
833
1426
  }
@@ -836,6 +1429,9 @@ export class Dropdown {
836
1429
  return [{
837
1430
  "propName": "show",
838
1431
  "methodName": "changedShow"
1432
+ }, {
1433
+ "propName": "show",
1434
+ "methodName": "emitShowChanged"
839
1435
  }, {
840
1436
  "propName": "trigger",
841
1437
  "methodName": "changedTrigger"
@@ -848,6 +1444,18 @@ export class Dropdown {
848
1444
  "target": undefined,
849
1445
  "capture": false,
850
1446
  "passive": false
1447
+ }, {
1448
+ "name": "ix-open-submenu",
1449
+ "method": "openSubmenu",
1450
+ "target": undefined,
1451
+ "capture": false,
1452
+ "passive": false
1453
+ }, {
1454
+ "name": "ix-close-submenu",
1455
+ "method": "closeSubmenu",
1456
+ "target": undefined,
1457
+ "capture": false,
1458
+ "passive": false
851
1459
  }];
852
1460
  }
853
1461
  }