@siemens/ix 0.0.0-pr-1373-20240705054533 → 0.0.0-pr-1522-20241022123832

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 (1191) hide show
  1. package/components/a11y.js +1 -1
  2. package/components/a11y.js.map +1 -1
  3. package/components/application-header.js +51 -15
  4. package/components/application-header.js.map +1 -1
  5. package/components/avatar.js +1 -1
  6. package/components/avatar.js.map +1 -1
  7. package/components/base-button.js +2 -2
  8. package/components/base-button.js.map +1 -1
  9. package/components/button.js +2 -2
  10. package/components/button.js.map +1 -1
  11. package/components/card-accordion.js +6 -6
  12. package/components/card-accordion.js.map +1 -1
  13. package/components/card-content.js +1 -1
  14. package/components/card-title.js +1 -1
  15. package/components/card.js +4 -4
  16. package/components/card.js.map +1 -1
  17. package/components/col.js +1 -1
  18. package/components/col.js.map +1 -1
  19. package/components/context.js +6 -3
  20. package/components/context.js.map +1 -1
  21. package/components/date-picker.js +53 -41
  22. package/components/date-picker.js.map +1 -1
  23. package/components/date-time-card.js +1 -1
  24. package/components/divider.js +1 -1
  25. package/components/dropdown-controller.js +148 -0
  26. package/components/dropdown-controller.js.map +1 -0
  27. package/components/dropdown-item.js +4 -4
  28. package/components/dropdown-item.js.map +1 -1
  29. package/components/dropdown.js +115 -201
  30. package/components/dropdown.js.map +1 -1
  31. package/components/filter-chip.js +1 -1
  32. package/components/floating-ui.dom.esm.js +533 -60
  33. package/components/floating-ui.dom.esm.js.map +1 -1
  34. package/components/group-context-menu.js +1 -1
  35. package/components/group-context-menu.js.map +1 -1
  36. package/components/group-item.js +4 -8
  37. package/components/group-item.js.map +1 -1
  38. package/components/icon-button.js +1 -1
  39. package/components/index.js +1 -0
  40. package/components/index.js.map +1 -1
  41. package/components/ix-action-card.js +1 -1
  42. package/components/ix-action-card.js.map +1 -1
  43. package/components/ix-application-sidebar.js +1 -1
  44. package/components/ix-application-switch-modal.js +1 -1
  45. package/components/ix-application.js +4 -4
  46. package/components/ix-application.js.map +1 -1
  47. package/components/ix-basic-navigation.js +18 -12
  48. package/components/ix-basic-navigation.js.map +1 -1
  49. package/components/ix-blind.js +5 -5
  50. package/components/ix-blind.js.map +1 -1
  51. package/components/ix-breadcrumb.js +9 -10
  52. package/components/ix-breadcrumb.js.map +1 -1
  53. package/components/ix-card-list.js +6 -6
  54. package/components/ix-card-list.js.map +1 -1
  55. package/components/ix-category-filter.js +129 -71
  56. package/components/ix-category-filter.js.map +1 -1
  57. package/components/ix-chip.js +4 -4
  58. package/components/ix-chip.js.map +1 -1
  59. package/components/ix-content-header.js +2 -2
  60. package/components/ix-content-header.js.map +1 -1
  61. package/components/ix-content.js +3 -3
  62. package/components/ix-css-grid-item.js +1 -1
  63. package/components/ix-css-grid.js +8 -3
  64. package/components/ix-css-grid.js.map +1 -1
  65. package/components/ix-date-dropdown.js +25 -16
  66. package/components/ix-date-dropdown.js.map +1 -1
  67. package/components/ix-datetime-picker.js +1 -1
  68. package/components/ix-drawer.js +2 -2
  69. package/components/ix-dropdown-button.js +5 -7
  70. package/components/ix-dropdown-button.js.map +1 -1
  71. package/components/ix-dropdown-header.js +1 -1
  72. package/components/ix-dropdown-header.js.map +1 -1
  73. package/components/ix-dropdown-quick-actions.js +1 -1
  74. package/components/ix-empty-state.js +1 -1
  75. package/components/ix-empty-state.js.map +1 -1
  76. package/components/ix-event-list-item.js +4 -4
  77. package/components/ix-event-list.js +2 -2
  78. package/components/ix-expanding-search.js +4 -4
  79. package/components/ix-flip-tile-content.js +1 -1
  80. package/components/ix-flip-tile.js +4 -4
  81. package/components/ix-form-field.js +2 -2
  82. package/components/ix-form-field.js.map +1 -1
  83. package/components/ix-group.js +69 -44
  84. package/components/ix-group.js.map +1 -1
  85. package/components/ix-icon-toggle-button.js +1 -2
  86. package/components/ix-icon-toggle-button.js.map +1 -1
  87. package/components/ix-input-group.js +1 -1
  88. package/components/ix-key-value-list.js +1 -1
  89. package/components/ix-key-value.js +1 -1
  90. package/components/ix-kpi.js +3 -3
  91. package/components/ix-kpi.js.map +1 -1
  92. package/components/ix-link-button.js +3 -3
  93. package/components/ix-map-navigation.js +21 -15
  94. package/components/ix-map-navigation.js.map +1 -1
  95. package/components/ix-menu-about-item.js +1 -1
  96. package/components/ix-menu-about-news.js +4 -4
  97. package/components/ix-menu-about-news.js.map +1 -1
  98. package/components/ix-menu-about.js +1 -1
  99. package/components/ix-menu-avatar.js +2 -2
  100. package/components/ix-menu-category.js +5 -5
  101. package/components/ix-menu-category.js.map +1 -1
  102. package/components/ix-menu-settings-item.js +1 -1
  103. package/components/ix-menu.js +12 -12
  104. package/components/ix-menu.js.map +1 -1
  105. package/components/ix-message-bar.js +1 -1
  106. package/components/ix-modal-example.js +1 -1
  107. package/components/ix-modal-footer.js +1 -1
  108. package/components/ix-modal-loading.js +1 -1
  109. package/components/ix-modal.js +11 -4
  110. package/components/ix-modal.js.map +1 -1
  111. package/components/ix-pagination.js +3 -3
  112. package/components/ix-pagination.js.map +1 -1
  113. package/components/ix-pane-layout.js +1 -1
  114. package/components/ix-pane.js +6 -6
  115. package/components/ix-pane.js.map +1 -1
  116. package/components/ix-pill.js +4 -4
  117. package/components/ix-pill.js.map +1 -1
  118. package/components/ix-playground-internal.js +1 -1
  119. package/components/ix-playground-internal.js.map +1 -1
  120. package/components/ix-push-card.js +1 -1
  121. package/components/ix-push-card.js.map +1 -1
  122. package/components/ix-slider.js +21 -14
  123. package/components/ix-slider.js.map +1 -1
  124. package/components/ix-split-button-item.js +1 -1
  125. package/components/ix-split-button.js +1 -1
  126. package/components/ix-tile.js +4 -4
  127. package/components/ix-tile.js.map +1 -1
  128. package/components/ix-toast-container.js +2 -2
  129. package/components/ix-toast-container.js.map +1 -1
  130. package/components/ix-toggle-button.js +2 -2
  131. package/components/ix-toggle.js +2 -2
  132. package/components/ix-tree.js +21 -7
  133. package/components/ix-tree.js.map +1 -1
  134. package/components/ix-upload.js +60 -4
  135. package/components/ix-upload.js.map +1 -1
  136. package/components/ix-validation-tooltip.js +2 -2
  137. package/components/ix-workflow-step.js +3 -3
  138. package/components/ix-workflow-step.js.map +1 -1
  139. package/components/ix-workflow-steps.js +1 -1
  140. package/components/ix-workflow-steps.js.map +1 -1
  141. package/components/layout-grid.js +2 -2
  142. package/components/layout-grid.js.map +1 -1
  143. package/components/listener.js +2 -2
  144. package/components/listener.js.map +1 -1
  145. package/components/logical-filter-operator.js +1 -1
  146. package/components/logical-filter-operator.js.map +1 -1
  147. package/components/make-ref.js +7 -12
  148. package/components/make-ref.js.map +1 -1
  149. package/components/map-navigation-overlay.js +2 -2
  150. package/components/menu-avatar-item.js +1 -1
  151. package/components/menu-expand-icon.js +1 -1
  152. package/components/menu-expand-icon.js.map +1 -1
  153. package/components/menu-item.js +14 -14
  154. package/components/menu-item.js.map +1 -1
  155. package/components/menu-tabs-fc.js +17 -14
  156. package/components/menu-tabs-fc.js.map +1 -1
  157. package/components/modal-content.js +2 -2
  158. package/components/modal-content.js.map +1 -1
  159. package/components/modal-header.js +2 -2
  160. package/components/modal-header.js.map +1 -1
  161. package/components/row.js +1 -1
  162. package/components/row.js.map +1 -1
  163. package/components/select-item.js +1 -1
  164. package/components/select.js +83 -73
  165. package/components/select.js.map +1 -1
  166. package/components/shadow-dom.js +1 -1
  167. package/components/shadow-dom.js.map +1 -1
  168. package/components/spinner.js +1 -1
  169. package/components/tab-item.js +3 -3
  170. package/components/tab-item.js.map +1 -1
  171. package/components/tabs.js +77 -43
  172. package/components/tabs.js.map +1 -1
  173. package/components/theme-switcher.js +1 -0
  174. package/components/theme-switcher.js.map +1 -1
  175. package/components/time-picker.js +4 -4
  176. package/components/time-picker.js.map +1 -1
  177. package/components/toast.js +2 -2
  178. package/components/toast.js.map +1 -1
  179. package/components/tooltip.js +25 -23
  180. package/components/tooltip.js.map +1 -1
  181. package/components/tree-item.js +8 -8
  182. package/components/tree-item.js.map +1 -1
  183. package/components/typography.js +3 -25
  184. package/components/typography.js.map +1 -1
  185. package/dist/cjs/{a11y-d3ce56d1.js → a11y-eba397e8.js} +2 -2
  186. package/dist/cjs/{a11y-d3ce56d1.js.map → a11y-eba397e8.js.map} +1 -1
  187. package/dist/cjs/{base-button-3735b8c2.js → base-button-a472cf2f.js} +3 -3
  188. package/dist/cjs/base-button-a472cf2f.js.map +1 -0
  189. package/dist/cjs/{base-icon-button-44c72bc8.js → base-icon-button-9ff5faad.js} +2 -2
  190. package/dist/cjs/{base-icon-button-44c72bc8.js.map → base-icon-button-9ff5faad.js.map} +1 -1
  191. package/dist/cjs/{context-98f4a0b3.js → context-6644f454.js} +7 -4
  192. package/dist/cjs/context-6644f454.js.map +1 -0
  193. package/dist/cjs/disposable-event-listener-1ed769b9.js +20 -0
  194. package/dist/cjs/disposable-event-listener-1ed769b9.js.map +1 -0
  195. package/dist/cjs/dropdown-controller-1781ef55.js +151 -0
  196. package/dist/cjs/dropdown-controller-1781ef55.js.map +1 -0
  197. package/dist/cjs/{floating-ui.dom.esm-94b4d17c.js → floating-ui.dom.esm-9dde6cd6.js} +534 -60
  198. package/dist/cjs/floating-ui.dom.esm-9dde6cd6.js.map +1 -0
  199. package/dist/cjs/{focus-9c8ffbb0.js → focus-83f8f1ba.js} +21 -18
  200. package/dist/cjs/focus-83f8f1ba.js.map +1 -0
  201. package/dist/cjs/index.cjs.js +4 -3
  202. package/dist/cjs/index.cjs.js.map +1 -1
  203. package/dist/cjs/ix-action-card.cjs.entry.js +1 -1
  204. package/dist/cjs/ix-action-card.cjs.entry.js.map +1 -1
  205. package/dist/cjs/ix-application-header.cjs.entry.js +34 -8
  206. package/dist/cjs/ix-application-header.cjs.entry.js.map +1 -1
  207. package/dist/cjs/ix-application-sidebar.cjs.entry.js +1 -1
  208. package/dist/cjs/ix-application-switch-modal.cjs.entry.js +1 -1
  209. package/dist/cjs/ix-application.cjs.entry.js +7 -7
  210. package/dist/cjs/ix-application.cjs.entry.js.map +1 -1
  211. package/dist/cjs/ix-avatar_2.cjs.entry.js +5 -5
  212. package/dist/cjs/ix-avatar_2.cjs.entry.js.map +1 -1
  213. package/dist/cjs/ix-basic-navigation.cjs.entry.js +3 -3
  214. package/dist/cjs/ix-basic-navigation.cjs.entry.js.map +1 -1
  215. package/dist/cjs/ix-blind.cjs.entry.js +6 -6
  216. package/dist/cjs/ix-blind.cjs.entry.js.map +1 -1
  217. package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +2 -2
  218. package/dist/cjs/ix-breadcrumb.cjs.entry.js +10 -9
  219. package/dist/cjs/ix-breadcrumb.cjs.entry.js.map +1 -1
  220. package/dist/cjs/ix-button.cjs.entry.js +3 -3
  221. package/dist/cjs/ix-button.cjs.entry.js.map +1 -1
  222. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +7 -7
  223. package/dist/cjs/ix-card-accordion_2.cjs.entry.js.map +1 -1
  224. package/dist/cjs/ix-card-list.cjs.entry.js +6 -6
  225. package/dist/cjs/ix-card-list.cjs.entry.js.map +1 -1
  226. package/dist/cjs/ix-card_2.cjs.entry.js +5 -5
  227. package/dist/cjs/ix-card_2.cjs.entry.js.map +1 -1
  228. package/dist/cjs/ix-category-filter.cjs.entry.js +131 -71
  229. package/dist/cjs/ix-category-filter.cjs.entry.js.map +1 -1
  230. package/dist/cjs/ix-chip.cjs.entry.js +4 -4
  231. package/dist/cjs/ix-chip.cjs.entry.js.map +1 -1
  232. package/dist/cjs/ix-col_4.cjs.entry.js +58 -42
  233. package/dist/cjs/ix-col_4.cjs.entry.js.map +1 -1
  234. package/dist/cjs/ix-content-header.cjs.entry.js +2 -2
  235. package/dist/cjs/ix-content-header.cjs.entry.js.map +1 -1
  236. package/dist/cjs/ix-content.cjs.entry.js +4 -4
  237. package/dist/cjs/ix-css-grid-item.cjs.entry.js +1 -1
  238. package/dist/cjs/ix-css-grid.cjs.entry.js +8 -3
  239. package/dist/cjs/ix-css-grid.cjs.entry.js.map +1 -1
  240. package/dist/cjs/ix-date-dropdown.cjs.entry.js +25 -15
  241. package/dist/cjs/ix-date-dropdown.cjs.entry.js.map +1 -1
  242. package/dist/cjs/ix-date-time-card.cjs.entry.js +1 -1
  243. package/dist/cjs/ix-datetime-picker.cjs.entry.js +1 -1
  244. package/dist/cjs/ix-divider.cjs.entry.js +1 -1
  245. package/dist/cjs/ix-drawer.cjs.entry.js +2 -2
  246. package/dist/cjs/ix-dropdown-button.cjs.entry.js +4 -5
  247. package/dist/cjs/ix-dropdown-button.cjs.entry.js.map +1 -1
  248. package/dist/cjs/ix-dropdown-header.cjs.entry.js +1 -1
  249. package/dist/cjs/ix-dropdown-header.cjs.entry.js.map +1 -1
  250. package/dist/cjs/ix-dropdown-item.cjs.entry.js +4 -4
  251. package/dist/cjs/ix-dropdown-item.cjs.entry.js.map +1 -1
  252. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +1 -1
  253. package/dist/cjs/ix-dropdown.cjs.entry.js +95 -196
  254. package/dist/cjs/ix-dropdown.cjs.entry.js.map +1 -1
  255. package/dist/cjs/ix-empty-state.cjs.entry.js +1 -1
  256. package/dist/cjs/ix-empty-state.cjs.entry.js.map +1 -1
  257. package/dist/cjs/ix-event-list-item.cjs.entry.js +5 -5
  258. package/dist/cjs/ix-event-list.cjs.entry.js +2 -2
  259. package/dist/cjs/ix-expanding-search.cjs.entry.js +4 -4
  260. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +2 -2
  261. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +1 -1
  262. package/dist/cjs/ix-flip-tile.cjs.entry.js +4 -4
  263. package/dist/cjs/ix-form-field.cjs.entry.js +2 -2
  264. package/dist/cjs/ix-form-field.cjs.entry.js.map +1 -1
  265. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +6 -10
  266. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js.map +1 -1
  267. package/dist/cjs/ix-group.cjs.entry.js +68 -44
  268. package/dist/cjs/ix-group.cjs.entry.js.map +1 -1
  269. package/dist/cjs/ix-icon-button_2.cjs.entry.js +5 -5
  270. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +4 -5
  271. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js.map +1 -1
  272. package/dist/cjs/ix-input-group.cjs.entry.js +2 -2
  273. package/dist/cjs/ix-key-value-list.cjs.entry.js +1 -1
  274. package/dist/cjs/ix-key-value.cjs.entry.js +1 -1
  275. package/dist/cjs/ix-kpi.cjs.entry.js +3 -3
  276. package/dist/cjs/ix-kpi.cjs.entry.js.map +1 -1
  277. package/dist/cjs/ix-link-button.cjs.entry.js +3 -3
  278. package/dist/cjs/ix-map-navigation-overlay.cjs.entry.js +2 -2
  279. package/dist/cjs/ix-map-navigation.cjs.entry.js +4 -4
  280. package/dist/cjs/ix-map-navigation.cjs.entry.js.map +1 -1
  281. package/dist/cjs/ix-menu-about-item.cjs.entry.js +1 -1
  282. package/dist/cjs/ix-menu-about-news.cjs.entry.js +4 -4
  283. package/dist/cjs/ix-menu-about-news.cjs.entry.js.map +1 -1
  284. package/dist/cjs/ix-menu-about.cjs.entry.js +2 -2
  285. package/dist/cjs/ix-menu-avatar.cjs.entry.js +3 -3
  286. package/dist/cjs/ix-menu-category.cjs.entry.js +6 -6
  287. package/dist/cjs/ix-menu-category.cjs.entry.js.map +1 -1
  288. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +3 -3
  289. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js.map +1 -1
  290. package/dist/cjs/ix-menu-item.cjs.entry.js +14 -14
  291. package/dist/cjs/ix-menu-item.cjs.entry.js.map +1 -1
  292. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +1 -1
  293. package/dist/cjs/ix-menu-settings.cjs.entry.js +1 -1
  294. package/dist/cjs/ix-menu.cjs.entry.js +14 -14
  295. package/dist/cjs/ix-menu.cjs.entry.js.map +1 -1
  296. package/dist/cjs/ix-message-bar.cjs.entry.js +1 -1
  297. package/dist/cjs/ix-modal-content_2.cjs.entry.js +5 -5
  298. package/dist/cjs/ix-modal-content_2.cjs.entry.js.map +1 -1
  299. package/dist/cjs/ix-modal-example.cjs.entry.js +1 -1
  300. package/dist/cjs/ix-modal-footer.cjs.entry.js +1 -1
  301. package/dist/cjs/ix-modal-loading.cjs.entry.js +1 -1
  302. package/dist/cjs/ix-modal.cjs.entry.js +13 -6
  303. package/dist/cjs/ix-modal.cjs.entry.js.map +1 -1
  304. package/dist/cjs/ix-pagination.cjs.entry.js +5 -5
  305. package/dist/cjs/ix-pagination.cjs.entry.js.map +1 -1
  306. package/dist/cjs/ix-pane-layout.cjs.entry.js +1 -1
  307. package/dist/cjs/ix-pane.cjs.entry.js +6 -6
  308. package/dist/cjs/ix-pane.cjs.entry.js.map +1 -1
  309. package/dist/cjs/ix-pill.cjs.entry.js +4 -4
  310. package/dist/cjs/ix-pill.cjs.entry.js.map +1 -1
  311. package/dist/cjs/ix-playground-internal.cjs.entry.js +1 -1
  312. package/dist/cjs/ix-playground-internal.cjs.entry.js.map +1 -1
  313. package/dist/cjs/ix-push-card.cjs.entry.js +1 -1
  314. package/dist/cjs/ix-push-card.cjs.entry.js.map +1 -1
  315. package/dist/cjs/ix-select.cjs.entry.js +86 -73
  316. package/dist/cjs/ix-select.cjs.entry.js.map +1 -1
  317. package/dist/cjs/ix-slider.cjs.entry.js +23 -16
  318. package/dist/cjs/ix-slider.cjs.entry.js.map +1 -1
  319. package/dist/cjs/ix-split-button-item.cjs.entry.js +2 -2
  320. package/dist/cjs/ix-split-button.cjs.entry.js +1 -1
  321. package/dist/cjs/ix-tab-item_2.cjs.entry.js +74 -44
  322. package/dist/cjs/ix-tab-item_2.cjs.entry.js.map +1 -1
  323. package/dist/cjs/ix-tile.cjs.entry.js +4 -4
  324. package/dist/cjs/ix-tile.cjs.entry.js.map +1 -1
  325. package/dist/cjs/ix-time-picker.cjs.entry.js +4 -4
  326. package/dist/cjs/ix-time-picker.cjs.entry.js.map +1 -1
  327. package/dist/cjs/ix-toast-container.cjs.entry.js +2 -2
  328. package/dist/cjs/ix-toast-container.cjs.entry.js.map +1 -1
  329. package/dist/cjs/ix-toast.cjs.entry.js +2 -2
  330. package/dist/cjs/ix-toast.cjs.entry.js.map +1 -1
  331. package/dist/cjs/ix-toggle-button.cjs.entry.js +4 -4
  332. package/dist/cjs/ix-toggle.cjs.entry.js +3 -3
  333. package/dist/cjs/ix-tooltip.cjs.entry.js +26 -24
  334. package/dist/cjs/ix-tooltip.cjs.entry.js.map +1 -1
  335. package/dist/cjs/ix-tree-item.cjs.entry.js +8 -8
  336. package/dist/cjs/ix-tree-item.cjs.entry.js.map +1 -1
  337. package/dist/cjs/ix-tree.cjs.entry.js +21 -7
  338. package/dist/cjs/ix-tree.cjs.entry.js.map +1 -1
  339. package/dist/cjs/ix-typography.cjs.entry.js +3 -24
  340. package/dist/cjs/ix-typography.cjs.entry.js.map +1 -1
  341. package/dist/cjs/ix-upload.cjs.entry.js +58 -4
  342. package/dist/cjs/ix-upload.cjs.entry.js.map +1 -1
  343. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +3 -3
  344. package/dist/cjs/ix-workflow-step.cjs.entry.js +3 -3
  345. package/dist/cjs/ix-workflow-step.cjs.entry.js.map +1 -1
  346. package/dist/cjs/ix-workflow-steps.cjs.entry.js +1 -1
  347. package/dist/cjs/ix-workflow-steps.cjs.entry.js.map +1 -1
  348. package/dist/cjs/{listener-bc3e7c0c.js → listener-164d1a4a.js} +3 -3
  349. package/dist/cjs/listener-164d1a4a.js.map +1 -0
  350. package/dist/cjs/loader.cjs.js +1 -1
  351. package/dist/cjs/{logical-filter-operator-5564322e.js → logical-filter-operator-4917393f.js} +2 -2
  352. package/dist/cjs/{logical-filter-operator-5564322e.js.map → logical-filter-operator-4917393f.js.map} +1 -1
  353. package/dist/cjs/{make-ref-c25629b7.js → make-ref-499e1e41.js} +8 -13
  354. package/dist/cjs/make-ref-499e1e41.js.map +1 -0
  355. package/dist/cjs/{menu-tabs-fc-df53f176.js → menu-tabs-fc-b532aeb4.js} +18 -15
  356. package/dist/cjs/menu-tabs-fc-b532aeb4.js.map +1 -0
  357. package/dist/cjs/{shadow-dom-73f9d553.js → shadow-dom-454acc38.js} +2 -2
  358. package/dist/cjs/{shadow-dom-73f9d553.js.map → shadow-dom-454acc38.js.map} +1 -1
  359. package/dist/cjs/siemens-ix.cjs.js +1 -1
  360. package/dist/cjs/{theme-switcher-2d2bde85.js → theme-switcher-88b70d73.js} +2 -1
  361. package/dist/cjs/theme-switcher-88b70d73.js.map +1 -0
  362. package/dist/collection/components/action-card/action-card.js +8 -5
  363. package/dist/collection/components/action-card/action-card.js.map +1 -1
  364. package/dist/collection/components/application/application.css +26 -6
  365. package/dist/collection/components/application/application.js +3 -3
  366. package/dist/collection/components/application/application.js.map +1 -1
  367. package/dist/collection/components/application-header/application-header.css +9 -7
  368. package/dist/collection/components/application-header/application-header.js +78 -6
  369. package/dist/collection/components/application-header/application-header.js.map +1 -1
  370. package/dist/collection/components/application-header/application-switch-modal/application-switch-modal.js +1 -1
  371. package/dist/collection/components/application-sidebar/application-sidebar.js +1 -1
  372. package/dist/collection/components/avatar/avatar.css +42 -0
  373. package/dist/collection/components/basic-navigation/basic-navigation.js +7 -4
  374. package/dist/collection/components/basic-navigation/basic-navigation.js.map +1 -1
  375. package/dist/collection/components/blind/blind.css +1 -1
  376. package/dist/collection/components/blind/blind.js +10 -10
  377. package/dist/collection/components/blind/blind.js.map +1 -1
  378. package/dist/collection/components/blind/test/blind.ct.js +1 -1
  379. package/dist/collection/components/blind/test/blind.ct.js.map +1 -1
  380. package/dist/collection/components/breadcrumb/breadcrumb.js +9 -10
  381. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  382. package/dist/collection/components/button/base-button.js +2 -2
  383. package/dist/collection/components/button/base-button.js.map +1 -1
  384. package/dist/collection/components/button/button.js +3 -3
  385. package/dist/collection/components/button/button.js.map +1 -1
  386. package/dist/collection/components/card/card.css +3 -3
  387. package/dist/collection/components/card/card.js +10 -6
  388. package/dist/collection/components/card/card.js.map +1 -1
  389. package/dist/collection/components/card-accordion/card-accordion.css +4 -4
  390. package/dist/collection/components/card-accordion/card-accordion.js +5 -5
  391. package/dist/collection/components/card-accordion/card-accordion.js.map +1 -1
  392. package/dist/collection/components/card-content/card-content.js +1 -1
  393. package/dist/collection/components/card-list/card-list.css +6 -0
  394. package/dist/collection/components/card-list/card-list.js +5 -5
  395. package/dist/collection/components/card-list/card-list.js.map +1 -1
  396. package/dist/collection/components/card-title/card-title.js +1 -1
  397. package/dist/collection/components/category-filter/category-filter.css +20 -20
  398. package/dist/collection/components/category-filter/category-filter.js +138 -78
  399. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  400. package/dist/collection/components/category-filter/logical-filter-operator.js +1 -1
  401. package/dist/collection/components/category-filter/logical-filter-operator.js.map +1 -1
  402. package/dist/collection/components/category-filter/test/category-filter.ct.js +52 -0
  403. package/dist/collection/components/category-filter/test/category-filter.ct.js.map +1 -0
  404. package/dist/collection/components/chip/chip.css +2 -2
  405. package/dist/collection/components/chip/chip.js +5 -5
  406. package/dist/collection/components/chip/chip.js.map +1 -1
  407. package/dist/collection/components/col/col.css +1 -1
  408. package/dist/collection/components/col/col.js +2 -2
  409. package/dist/collection/components/col/col.js.map +1 -1
  410. package/dist/collection/components/content/content.js +3 -3
  411. package/dist/collection/components/content-header/content-header.css +6 -3
  412. package/dist/collection/components/content-header/content-header.js +2 -2
  413. package/dist/collection/components/content-header/content-header.js.map +1 -1
  414. package/dist/collection/components/css-grid/css-grid-item.js +1 -1
  415. package/dist/collection/components/css-grid/css-grid.js +9 -4
  416. package/dist/collection/components/css-grid/css-grid.js.map +1 -1
  417. package/dist/collection/components/date-dropdown/date-dropdown.js +34 -21
  418. package/dist/collection/components/date-dropdown/date-dropdown.js.map +1 -1
  419. package/dist/collection/components/date-picker/date-picker.js +62 -48
  420. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  421. package/dist/collection/components/date-time-card/date-time-card.js +1 -1
  422. package/dist/collection/components/datetime-picker/datetime-picker.js +1 -1
  423. package/dist/collection/components/divider/divider.js +1 -1
  424. package/dist/collection/components/drawer/drawer.js +2 -2
  425. package/dist/collection/components/dropdown/dropdown-controller.js +15 -11
  426. package/dist/collection/components/dropdown/dropdown-controller.js.map +1 -1
  427. package/dist/collection/components/dropdown/dropdown.js +95 -62
  428. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  429. package/dist/collection/components/dropdown/test/dropdown.ct.js +19 -8
  430. package/dist/collection/components/dropdown/test/dropdown.ct.js.map +1 -1
  431. package/dist/collection/components/dropdown-button/dropdown-button.js +7 -13
  432. package/dist/collection/components/dropdown-button/dropdown-button.js.map +1 -1
  433. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  434. package/dist/collection/components/dropdown-header/dropdown-header.js.map +1 -1
  435. package/dist/collection/components/dropdown-item/dropdown-item.css +3 -3
  436. package/dist/collection/components/dropdown-item/dropdown-item.js +5 -5
  437. package/dist/collection/components/dropdown-item/dropdown-item.js.map +1 -1
  438. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  439. package/dist/collection/components/empty-state/empty-state.js +1 -1
  440. package/dist/collection/components/empty-state/empty-state.js.map +1 -1
  441. package/dist/collection/components/event-list/event-list.js +2 -2
  442. package/dist/collection/components/event-list-item/event-list-item.js +4 -4
  443. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  444. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  445. package/dist/collection/components/flip-tile/flip-tile.js +4 -4
  446. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  447. package/dist/collection/components/form-field/form-field.css +10 -10
  448. package/dist/collection/components/form-field/form-field.js +1 -1
  449. package/dist/collection/components/grid/layout-grid.css +1 -1
  450. package/dist/collection/components/grid/layout-grid.js +3 -3
  451. package/dist/collection/components/grid/layout-grid.js.map +1 -1
  452. package/dist/collection/components/group/group-context-menu.css +1 -1
  453. package/dist/collection/components/group/group-context-menu.js +2 -2
  454. package/dist/collection/components/group/group-context-menu.js.map +1 -1
  455. package/dist/collection/components/group/group.css +3 -2
  456. package/dist/collection/components/group/group.js +84 -48
  457. package/dist/collection/components/group/group.js.map +1 -1
  458. package/dist/collection/components/group/test/group.ct.js +70 -2
  459. package/dist/collection/components/group/test/group.ct.js.map +1 -1
  460. package/dist/collection/components/group-item/group-item.css +0 -4
  461. package/dist/collection/components/group-item/group-item.js +9 -12
  462. package/dist/collection/components/group-item/group-item.js.map +1 -1
  463. package/dist/collection/components/icon-button/icon-button.js +1 -1
  464. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -2
  465. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js.map +1 -1
  466. package/dist/collection/components/input-group/input-group.js +1 -1
  467. package/dist/collection/components/key-value/key-value.js +1 -1
  468. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  469. package/dist/collection/components/kpi/kpi.css +1 -1
  470. package/dist/collection/components/kpi/kpi.js +4 -4
  471. package/dist/collection/components/kpi/kpi.js.map +1 -1
  472. package/dist/collection/components/link-button/link-button.js +3 -3
  473. package/dist/collection/components/map-navigation/map-navigation.css +3 -3
  474. package/dist/collection/components/map-navigation/map-navigation.js +2 -2
  475. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js +2 -2
  476. package/dist/collection/components/menu/menu-expand-icon.css +1 -1
  477. package/dist/collection/components/menu/menu-expand-icon.js +3 -3
  478. package/dist/collection/components/menu/menu-expand-icon.js.map +1 -1
  479. package/dist/collection/components/menu/menu.css +4 -3
  480. package/dist/collection/components/menu/menu.js +12 -12
  481. package/dist/collection/components/menu/menu.js.map +1 -1
  482. package/dist/collection/components/menu/test/menu.ct.js +1 -1
  483. package/dist/collection/components/menu/test/menu.ct.js.map +1 -1
  484. package/dist/collection/components/menu-about/menu-about.js +1 -1
  485. package/dist/collection/components/menu-about/test/menu-about.ct.js +44 -0
  486. package/dist/collection/components/menu-about/test/menu-about.ct.js.map +1 -0
  487. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  488. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  489. package/dist/collection/components/menu-about-news/menu-about-news.js.map +1 -1
  490. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -2
  491. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  492. package/dist/collection/components/menu-category/menu-category.js +5 -5
  493. package/dist/collection/components/menu-category/menu-category.js.map +1 -1
  494. package/dist/collection/components/menu-item/menu-item.js +24 -21
  495. package/dist/collection/components/menu-item/menu-item.js.map +1 -1
  496. package/dist/collection/components/menu-settings/menu-settings.js +1 -1
  497. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  498. package/dist/collection/components/message-bar/message-bar.js +1 -1
  499. package/dist/collection/components/modal/modal.css +19 -9
  500. package/dist/collection/components/modal/modal.js +11 -4
  501. package/dist/collection/components/modal/modal.js.map +1 -1
  502. package/dist/collection/components/modal/test/modal.ct.js +47 -1
  503. package/dist/collection/components/modal/test/modal.ct.js.map +1 -1
  504. package/dist/collection/components/modal-content/modal-content.css +2 -2
  505. package/dist/collection/components/modal-content/modal-content.js +1 -1
  506. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  507. package/dist/collection/components/modal-header/modal-header.css +6 -7
  508. package/dist/collection/components/modal-header/modal-header.js +4 -4
  509. package/dist/collection/components/modal-header/modal-header.js.map +1 -1
  510. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  511. package/dist/collection/components/pagination/pagination.js +5 -4
  512. package/dist/collection/components/pagination/pagination.js.map +1 -1
  513. package/dist/collection/components/pane/pane.css +1 -1
  514. package/dist/collection/components/pane/pane.js +7 -7
  515. package/dist/collection/components/pane/pane.js.map +1 -1
  516. package/dist/collection/components/pane/test/panes.ct.js +1 -1
  517. package/dist/collection/components/pane/test/panes.ct.js.map +1 -1
  518. package/dist/collection/components/pane-layout/pane-layout.js +1 -1
  519. package/dist/collection/components/pill/pill.css +2 -2
  520. package/dist/collection/components/pill/pill.js +5 -5
  521. package/dist/collection/components/pill/pill.js.map +1 -1
  522. package/dist/collection/components/playground/example-modal.js +1 -1
  523. package/dist/collection/components/playground/playground.js +2 -2
  524. package/dist/collection/components/playground/playground.js.map +1 -1
  525. package/dist/collection/components/push-card/push-card.js +9 -6
  526. package/dist/collection/components/push-card/push-card.js.map +1 -1
  527. package/dist/collection/components/row/row.css +1 -1
  528. package/dist/collection/components/row/row.js +2 -2
  529. package/dist/collection/components/row/row.js.map +1 -1
  530. package/dist/collection/components/select/select.js +83 -73
  531. package/dist/collection/components/select/select.js.map +1 -1
  532. package/dist/collection/components/select/test/select.ct.js +48 -3
  533. package/dist/collection/components/select/test/select.ct.js.map +1 -1
  534. package/dist/collection/components/select-item/select-item.js +1 -1
  535. package/dist/collection/components/slider/slider.css +1 -1
  536. package/dist/collection/components/slider/slider.js +24 -16
  537. package/dist/collection/components/slider/slider.js.map +1 -1
  538. package/dist/collection/components/slider/test/slider.ct.js +15 -6
  539. package/dist/collection/components/slider/test/slider.ct.js.map +1 -1
  540. package/dist/collection/components/spinner/spinner.js +1 -1
  541. package/dist/collection/components/split-button/split-button.js +1 -1
  542. package/dist/collection/components/split-button-item/split-button-item.js +1 -1
  543. package/dist/collection/components/tab-item/tab-item.js +4 -4
  544. package/dist/collection/components/tab-item/tab-item.js.map +1 -1
  545. package/dist/collection/components/tabs/tabs.css +1 -1
  546. package/dist/collection/components/tabs/tabs.js +78 -43
  547. package/dist/collection/components/tabs/tabs.js.map +1 -1
  548. package/dist/collection/components/tabs/test/tabs.ct.js +35 -9
  549. package/dist/collection/components/tabs/test/tabs.ct.js.map +1 -1
  550. package/dist/collection/components/tile/tile.css +1 -1
  551. package/dist/collection/components/tile/tile.js +5 -5
  552. package/dist/collection/components/tile/tile.js.map +1 -1
  553. package/dist/collection/components/time-picker/time-picker.css +10 -10
  554. package/dist/collection/components/time-picker/time-picker.js +3 -3
  555. package/dist/collection/components/time-picker/time-picker.js.map +1 -1
  556. package/dist/collection/components/toast/styles/toast-container.css +1 -1
  557. package/dist/collection/components/toast/toast-container.js +3 -3
  558. package/dist/collection/components/toast/toast-container.js.map +1 -1
  559. package/dist/collection/components/toast/toast-utils.js.map +1 -1
  560. package/dist/collection/components/toast/toast.css +1 -1
  561. package/dist/collection/components/toast/toast.js +3 -3
  562. package/dist/collection/components/toast/toast.js.map +1 -1
  563. package/dist/collection/components/toggle/toggle.js +2 -2
  564. package/dist/collection/components/toggle-button/toggle-button.js +2 -2
  565. package/dist/collection/components/tooltip/tooltip.css +15 -5
  566. package/dist/collection/components/tooltip/tooltip.js +39 -35
  567. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  568. package/dist/collection/components/tree/test/tree.ct.js +37 -1
  569. package/dist/collection/components/tree/test/tree.ct.js.map +1 -1
  570. package/dist/collection/components/tree/tree-model.js.map +1 -1
  571. package/dist/collection/components/tree/tree.css +1 -1
  572. package/dist/collection/components/tree/tree.js +26 -11
  573. package/dist/collection/components/tree/tree.js.map +1 -1
  574. package/dist/collection/components/tree-item/tree-item.css +9 -0
  575. package/dist/collection/components/tree-item/tree-item.js +13 -12
  576. package/dist/collection/components/tree-item/tree-item.js.map +1 -1
  577. package/dist/collection/components/typography/test/ix-typography.spec.js +0 -14
  578. package/dist/collection/components/typography/test/ix-typography.spec.js.map +1 -1
  579. package/dist/collection/components/typography/type-mapping.js +3 -0
  580. package/dist/collection/components/typography/type-mapping.js.map +1 -1
  581. package/dist/collection/components/typography/typography.js +6 -42
  582. package/dist/collection/components/typography/typography.js.map +1 -1
  583. package/dist/collection/components/upload/test/upload.ct.js +17 -0
  584. package/dist/collection/components/upload/test/upload.ct.js.map +1 -0
  585. package/dist/collection/components/upload/upload.js +50 -6
  586. package/dist/collection/components/upload/upload.js.map +1 -1
  587. package/dist/collection/components/utils/condition-checks.js +1 -1
  588. package/dist/collection/components/utils/condition-checks.js.map +1 -1
  589. package/dist/collection/components/utils/context.js +6 -3
  590. package/dist/collection/components/utils/context.js.map +1 -1
  591. package/dist/collection/components/utils/disposable-event-listener.js +19 -0
  592. package/dist/collection/components/utils/disposable-event-listener.js.map +1 -0
  593. package/dist/collection/components/utils/element-reference.js +2 -0
  594. package/dist/collection/components/utils/element-reference.js.map +1 -0
  595. package/dist/collection/components/utils/focus.js +19 -17
  596. package/dist/collection/components/utils/focus.js.map +1 -1
  597. package/dist/collection/components/utils/listener.js +2 -2
  598. package/dist/collection/components/utils/listener.js.map +1 -1
  599. package/dist/collection/components/utils/make-ref.js +7 -12
  600. package/dist/collection/components/utils/make-ref.js.map +1 -1
  601. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +11 -8
  602. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js.map +1 -1
  603. package/dist/collection/components/utils/notification-color.js.map +1 -1
  604. package/dist/collection/components/utils/shadow-dom.js +1 -1
  605. package/dist/collection/components/utils/shadow-dom.js.map +1 -1
  606. package/dist/collection/components/utils/theme-switcher.js +1 -0
  607. package/dist/collection/components/utils/theme-switcher.js.map +1 -1
  608. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  609. package/dist/collection/components/workflow-step/workflow-step.css +1 -1
  610. package/dist/collection/components/workflow-step/workflow-step.js +4 -4
  611. package/dist/collection/components/workflow-step/workflow-step.js.map +1 -1
  612. package/dist/collection/components/workflow-steps/test/workflow-steps.ct.js +2 -2
  613. package/dist/collection/components/workflow-steps/test/workflow-steps.ct.js.map +1 -1
  614. package/dist/collection/components/workflow-steps/workflow-steps.css +1 -1
  615. package/dist/collection/components/workflow-steps/workflow-steps.js +2 -2
  616. package/dist/collection/components/workflow-steps/workflow-steps.js.map +1 -1
  617. package/dist/collection/index.js +1 -0
  618. package/dist/collection/index.js.map +1 -1
  619. package/dist/collection/tests/application/application.e2e.js.map +1 -1
  620. package/dist/collection/tests/application-header/application-header.e2e.js +9 -0
  621. package/dist/collection/tests/application-header/application-header.e2e.js.map +1 -1
  622. package/dist/collection/tests/avatar/avatar.e2e.js +6 -0
  623. package/dist/collection/tests/avatar/avatar.e2e.js.map +1 -1
  624. package/dist/collection/tests/card-list/card-list.e2e.js +7 -1
  625. package/dist/collection/tests/card-list/card-list.e2e.js.map +1 -1
  626. package/dist/collection/tests/dropdown/dropdown.e2e.js +6 -0
  627. package/dist/collection/tests/dropdown/dropdown.e2e.js.map +1 -1
  628. package/dist/collection/tests/group/group.e2e.js +12 -3
  629. package/dist/collection/tests/group/group.e2e.js.map +1 -1
  630. package/dist/collection/tests/input/input.e2e.js +12 -0
  631. package/dist/collection/tests/input/input.e2e.js.map +1 -1
  632. package/dist/collection/tests/slider/slider.e2e.js +31 -0
  633. package/dist/collection/tests/slider/slider.e2e.js.map +1 -1
  634. package/dist/collection/tests/tabs/tabs.e2e.js +1 -1
  635. package/dist/collection/tests/tabs/tabs.e2e.js.map +1 -1
  636. package/dist/collection/tests/tooltip/tooltip.e2e.js +22 -0
  637. package/dist/collection/tests/tooltip/tooltip.e2e.js.map +1 -1
  638. package/dist/collection/tests/tree/tree.e2e.js +12 -0
  639. package/dist/collection/tests/tree/tree.e2e.js.map +1 -1
  640. package/dist/collection/tests/utils/test/page.js +3 -12
  641. package/dist/collection/tests/utils/test/page.js.map +1 -1
  642. package/dist/esm/{a11y-d5444a76.js → a11y-2e34777f.js} +2 -2
  643. package/dist/esm/{a11y-d5444a76.js.map → a11y-2e34777f.js.map} +1 -1
  644. package/dist/esm/{base-button-1b40b11d.js → base-button-103d6f26.js} +3 -3
  645. package/dist/esm/base-button-103d6f26.js.map +1 -0
  646. package/dist/esm/{base-icon-button-bc1dabe0.js → base-icon-button-9770fa3e.js} +2 -2
  647. package/dist/esm/{base-icon-button-bc1dabe0.js.map → base-icon-button-9770fa3e.js.map} +1 -1
  648. package/dist/esm/{context-c9078420.js → context-42311cff.js} +7 -4
  649. package/dist/esm/context-42311cff.js.map +1 -0
  650. package/dist/esm/disposable-event-listener-ff2cb862.js +18 -0
  651. package/dist/esm/disposable-event-listener-ff2cb862.js.map +1 -0
  652. package/dist/esm/dropdown-controller-c79f65b3.js +148 -0
  653. package/dist/esm/dropdown-controller-c79f65b3.js.map +1 -0
  654. package/dist/esm/{floating-ui.dom.esm-6e7c098f.js → floating-ui.dom.esm-d4ad786a.js} +534 -61
  655. package/dist/esm/floating-ui.dom.esm-d4ad786a.js.map +1 -0
  656. package/dist/esm/{focus-d4d3abaf.js → focus-5ccebfbc.js} +21 -18
  657. package/dist/esm/focus-5ccebfbc.js.map +1 -0
  658. package/dist/esm/index.js +3 -3
  659. package/dist/esm/index.js.map +1 -1
  660. package/dist/esm/ix-action-card.entry.js +1 -1
  661. package/dist/esm/ix-action-card.entry.js.map +1 -1
  662. package/dist/esm/ix-application-header.entry.js +35 -9
  663. package/dist/esm/ix-application-header.entry.js.map +1 -1
  664. package/dist/esm/ix-application-sidebar.entry.js +1 -1
  665. package/dist/esm/ix-application-switch-modal.entry.js +1 -1
  666. package/dist/esm/ix-application.entry.js +7 -7
  667. package/dist/esm/ix-application.entry.js.map +1 -1
  668. package/dist/esm/ix-avatar_2.entry.js +5 -5
  669. package/dist/esm/ix-avatar_2.entry.js.map +1 -1
  670. package/dist/esm/ix-basic-navigation.entry.js +3 -3
  671. package/dist/esm/ix-basic-navigation.entry.js.map +1 -1
  672. package/dist/esm/ix-blind.entry.js +6 -6
  673. package/dist/esm/ix-blind.entry.js.map +1 -1
  674. package/dist/esm/ix-breadcrumb-item.entry.js +2 -2
  675. package/dist/esm/ix-breadcrumb.entry.js +10 -9
  676. package/dist/esm/ix-breadcrumb.entry.js.map +1 -1
  677. package/dist/esm/ix-button.entry.js +3 -3
  678. package/dist/esm/ix-button.entry.js.map +1 -1
  679. package/dist/esm/ix-card-accordion_2.entry.js +7 -7
  680. package/dist/esm/ix-card-accordion_2.entry.js.map +1 -1
  681. package/dist/esm/ix-card-list.entry.js +6 -6
  682. package/dist/esm/ix-card-list.entry.js.map +1 -1
  683. package/dist/esm/ix-card_2.entry.js +5 -5
  684. package/dist/esm/ix-card_2.entry.js.map +1 -1
  685. package/dist/esm/ix-category-filter.entry.js +131 -71
  686. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  687. package/dist/esm/ix-chip.entry.js +4 -4
  688. package/dist/esm/ix-chip.entry.js.map +1 -1
  689. package/dist/esm/ix-col_4.entry.js +58 -42
  690. package/dist/esm/ix-col_4.entry.js.map +1 -1
  691. package/dist/esm/ix-content-header.entry.js +2 -2
  692. package/dist/esm/ix-content-header.entry.js.map +1 -1
  693. package/dist/esm/ix-content.entry.js +4 -4
  694. package/dist/esm/ix-css-grid-item.entry.js +1 -1
  695. package/dist/esm/ix-css-grid.entry.js +8 -3
  696. package/dist/esm/ix-css-grid.entry.js.map +1 -1
  697. package/dist/esm/ix-date-dropdown.entry.js +25 -15
  698. package/dist/esm/ix-date-dropdown.entry.js.map +1 -1
  699. package/dist/esm/ix-date-time-card.entry.js +1 -1
  700. package/dist/esm/ix-datetime-picker.entry.js +1 -1
  701. package/dist/esm/ix-divider.entry.js +1 -1
  702. package/dist/esm/ix-drawer.entry.js +2 -2
  703. package/dist/esm/ix-dropdown-button.entry.js +4 -5
  704. package/dist/esm/ix-dropdown-button.entry.js.map +1 -1
  705. package/dist/esm/ix-dropdown-header.entry.js +1 -1
  706. package/dist/esm/ix-dropdown-header.entry.js.map +1 -1
  707. package/dist/esm/ix-dropdown-item.entry.js +4 -4
  708. package/dist/esm/ix-dropdown-item.entry.js.map +1 -1
  709. package/dist/esm/ix-dropdown-quick-actions.entry.js +1 -1
  710. package/dist/esm/ix-dropdown.entry.js +82 -183
  711. package/dist/esm/ix-dropdown.entry.js.map +1 -1
  712. package/dist/esm/ix-empty-state.entry.js +1 -1
  713. package/dist/esm/ix-empty-state.entry.js.map +1 -1
  714. package/dist/esm/ix-event-list-item.entry.js +5 -5
  715. package/dist/esm/ix-event-list.entry.js +2 -2
  716. package/dist/esm/ix-expanding-search.entry.js +4 -4
  717. package/dist/esm/ix-filter-chip_2.entry.js +2 -2
  718. package/dist/esm/ix-flip-tile-content.entry.js +1 -1
  719. package/dist/esm/ix-flip-tile.entry.js +4 -4
  720. package/dist/esm/ix-form-field.entry.js +2 -2
  721. package/dist/esm/ix-form-field.entry.js.map +1 -1
  722. package/dist/esm/ix-group-context-menu_2.entry.js +6 -10
  723. package/dist/esm/ix-group-context-menu_2.entry.js.map +1 -1
  724. package/dist/esm/ix-group.entry.js +68 -44
  725. package/dist/esm/ix-group.entry.js.map +1 -1
  726. package/dist/esm/ix-icon-button_2.entry.js +5 -5
  727. package/dist/esm/ix-icon-toggle-button.entry.js +4 -5
  728. package/dist/esm/ix-icon-toggle-button.entry.js.map +1 -1
  729. package/dist/esm/ix-input-group.entry.js +2 -2
  730. package/dist/esm/ix-key-value-list.entry.js +1 -1
  731. package/dist/esm/ix-key-value.entry.js +1 -1
  732. package/dist/esm/ix-kpi.entry.js +3 -3
  733. package/dist/esm/ix-kpi.entry.js.map +1 -1
  734. package/dist/esm/ix-link-button.entry.js +3 -3
  735. package/dist/esm/ix-map-navigation-overlay.entry.js +2 -2
  736. package/dist/esm/ix-map-navigation.entry.js +4 -4
  737. package/dist/esm/ix-map-navigation.entry.js.map +1 -1
  738. package/dist/esm/ix-menu-about-item.entry.js +1 -1
  739. package/dist/esm/ix-menu-about-news.entry.js +4 -4
  740. package/dist/esm/ix-menu-about-news.entry.js.map +1 -1
  741. package/dist/esm/ix-menu-about.entry.js +2 -2
  742. package/dist/esm/ix-menu-avatar.entry.js +3 -3
  743. package/dist/esm/ix-menu-category.entry.js +6 -6
  744. package/dist/esm/ix-menu-category.entry.js.map +1 -1
  745. package/dist/esm/ix-menu-expand-icon.entry.js +3 -3
  746. package/dist/esm/ix-menu-expand-icon.entry.js.map +1 -1
  747. package/dist/esm/ix-menu-item.entry.js +15 -15
  748. package/dist/esm/ix-menu-item.entry.js.map +1 -1
  749. package/dist/esm/ix-menu-settings-item.entry.js +1 -1
  750. package/dist/esm/ix-menu-settings.entry.js +1 -1
  751. package/dist/esm/ix-menu.entry.js +14 -14
  752. package/dist/esm/ix-menu.entry.js.map +1 -1
  753. package/dist/esm/ix-message-bar.entry.js +1 -1
  754. package/dist/esm/ix-modal-content_2.entry.js +5 -5
  755. package/dist/esm/ix-modal-content_2.entry.js.map +1 -1
  756. package/dist/esm/ix-modal-example.entry.js +1 -1
  757. package/dist/esm/ix-modal-footer.entry.js +1 -1
  758. package/dist/esm/ix-modal-loading.entry.js +1 -1
  759. package/dist/esm/ix-modal.entry.js +13 -6
  760. package/dist/esm/ix-modal.entry.js.map +1 -1
  761. package/dist/esm/ix-pagination.entry.js +5 -5
  762. package/dist/esm/ix-pagination.entry.js.map +1 -1
  763. package/dist/esm/ix-pane-layout.entry.js +1 -1
  764. package/dist/esm/ix-pane.entry.js +6 -6
  765. package/dist/esm/ix-pane.entry.js.map +1 -1
  766. package/dist/esm/ix-pill.entry.js +4 -4
  767. package/dist/esm/ix-pill.entry.js.map +1 -1
  768. package/dist/esm/ix-playground-internal.entry.js +1 -1
  769. package/dist/esm/ix-playground-internal.entry.js.map +1 -1
  770. package/dist/esm/ix-push-card.entry.js +1 -1
  771. package/dist/esm/ix-push-card.entry.js.map +1 -1
  772. package/dist/esm/ix-select.entry.js +86 -73
  773. package/dist/esm/ix-select.entry.js.map +1 -1
  774. package/dist/esm/ix-slider.entry.js +23 -16
  775. package/dist/esm/ix-slider.entry.js.map +1 -1
  776. package/dist/esm/ix-split-button-item.entry.js +2 -2
  777. package/dist/esm/ix-split-button.entry.js +1 -1
  778. package/dist/esm/ix-tab-item_2.entry.js +74 -44
  779. package/dist/esm/ix-tab-item_2.entry.js.map +1 -1
  780. package/dist/esm/ix-tile.entry.js +4 -4
  781. package/dist/esm/ix-tile.entry.js.map +1 -1
  782. package/dist/esm/ix-time-picker.entry.js +4 -4
  783. package/dist/esm/ix-time-picker.entry.js.map +1 -1
  784. package/dist/esm/ix-toast-container.entry.js +2 -2
  785. package/dist/esm/ix-toast-container.entry.js.map +1 -1
  786. package/dist/esm/ix-toast.entry.js +2 -2
  787. package/dist/esm/ix-toast.entry.js.map +1 -1
  788. package/dist/esm/ix-toggle-button.entry.js +4 -4
  789. package/dist/esm/ix-toggle.entry.js +3 -3
  790. package/dist/esm/ix-tooltip.entry.js +26 -24
  791. package/dist/esm/ix-tooltip.entry.js.map +1 -1
  792. package/dist/esm/ix-tree-item.entry.js +8 -8
  793. package/dist/esm/ix-tree-item.entry.js.map +1 -1
  794. package/dist/esm/ix-tree.entry.js +21 -7
  795. package/dist/esm/ix-tree.entry.js.map +1 -1
  796. package/dist/esm/ix-typography.entry.js +3 -24
  797. package/dist/esm/ix-typography.entry.js.map +1 -1
  798. package/dist/esm/ix-upload.entry.js +58 -4
  799. package/dist/esm/ix-upload.entry.js.map +1 -1
  800. package/dist/esm/ix-validation-tooltip.entry.js +3 -3
  801. package/dist/esm/ix-workflow-step.entry.js +3 -3
  802. package/dist/esm/ix-workflow-step.entry.js.map +1 -1
  803. package/dist/esm/ix-workflow-steps.entry.js +1 -1
  804. package/dist/esm/ix-workflow-steps.entry.js.map +1 -1
  805. package/dist/esm/{listener-4f3baab5.js → listener-ade7081c.js} +3 -3
  806. package/dist/esm/listener-ade7081c.js.map +1 -0
  807. package/dist/esm/loader.js +1 -1
  808. package/dist/esm/{logical-filter-operator-f6701df5.js → logical-filter-operator-d793d1c3.js} +2 -2
  809. package/dist/esm/{logical-filter-operator-f6701df5.js.map → logical-filter-operator-d793d1c3.js.map} +1 -1
  810. package/dist/esm/{make-ref-c80046bf.js → make-ref-4b76e9b5.js} +8 -13
  811. package/dist/esm/make-ref-4b76e9b5.js.map +1 -0
  812. package/dist/esm/{menu-tabs-fc-d9a7dd06.js → menu-tabs-fc-b549da52.js} +18 -15
  813. package/dist/esm/menu-tabs-fc-b549da52.js.map +1 -0
  814. package/dist/esm/{shadow-dom-60e9243d.js → shadow-dom-cc0bc152.js} +2 -2
  815. package/dist/esm/{shadow-dom-60e9243d.js.map → shadow-dom-cc0bc152.js.map} +1 -1
  816. package/dist/esm/siemens-ix.js +1 -1
  817. package/dist/esm/{theme-switcher-b10fb4da.js → theme-switcher-5fcf712d.js} +2 -1
  818. package/dist/esm/theme-switcher-5fcf712d.js.map +1 -0
  819. package/dist/siemens-ix/index.esm.js +1 -1
  820. package/dist/siemens-ix/index.esm.js.map +1 -1
  821. package/dist/siemens-ix/{p-bf14c60b.entry.js → p-0379b864.entry.js} +2 -2
  822. package/dist/siemens-ix/{p-24a8737a.entry.js → p-054451cb.entry.js} +2 -2
  823. package/dist/siemens-ix/{p-5aa0b93c.entry.js → p-0691b6a5.entry.js} +2 -2
  824. package/dist/siemens-ix/{p-5aa0b93c.entry.js.map → p-0691b6a5.entry.js.map} +1 -1
  825. package/dist/siemens-ix/{p-90440046.entry.js → p-06f9e19f.entry.js} +2 -2
  826. package/dist/siemens-ix/p-093c25b1.entry.js +2 -0
  827. package/dist/siemens-ix/p-093c25b1.entry.js.map +1 -0
  828. package/dist/siemens-ix/{p-fb4c79c6.entry.js → p-0996d9f6.entry.js} +2 -2
  829. package/dist/siemens-ix/{p-453fa360.entry.js → p-09e0ede1.entry.js} +2 -2
  830. package/dist/siemens-ix/{p-453fa360.entry.js.map → p-09e0ede1.entry.js.map} +1 -1
  831. package/dist/siemens-ix/{p-7076210b.entry.js → p-0b8718d9.entry.js} +2 -2
  832. package/dist/siemens-ix/p-0b8718d9.entry.js.map +1 -0
  833. package/dist/siemens-ix/{p-1da901d5.js → p-0e983f70.js} +2 -2
  834. package/dist/siemens-ix/p-0e983f70.js.map +1 -0
  835. package/dist/siemens-ix/p-0f099811.entry.js +2 -0
  836. package/dist/siemens-ix/{p-0f7ef743.entry.js.map → p-0f099811.entry.js.map} +1 -1
  837. package/dist/siemens-ix/{p-bea7c748.entry.js → p-0f4e62f3.entry.js} +2 -2
  838. package/dist/siemens-ix/p-10368ba0.entry.js +2 -0
  839. package/dist/siemens-ix/{p-2ebfd4fd.entry.js.map → p-10368ba0.entry.js.map} +1 -1
  840. package/dist/siemens-ix/p-10a522ca.js +2 -0
  841. package/dist/siemens-ix/p-10a522ca.js.map +1 -0
  842. package/dist/siemens-ix/p-156fa685.entry.js +2 -0
  843. package/dist/siemens-ix/p-156fa685.entry.js.map +1 -0
  844. package/dist/siemens-ix/{p-4f8ac3bf.js → p-157b1b28.js} +1 -1
  845. package/dist/siemens-ix/{p-4f8ac3bf.js.map → p-157b1b28.js.map} +1 -1
  846. package/dist/siemens-ix/p-17240a7f.entry.js +2 -0
  847. package/dist/siemens-ix/p-17240a7f.entry.js.map +1 -0
  848. package/dist/siemens-ix/p-178ce002.js +2 -0
  849. package/dist/siemens-ix/p-178ce002.js.map +1 -0
  850. package/dist/siemens-ix/p-1a8e3fea.entry.js +2 -0
  851. package/dist/siemens-ix/{p-a8d291fa.entry.js → p-1b6dda61.entry.js} +2 -2
  852. package/dist/siemens-ix/p-1b6dda61.entry.js.map +1 -0
  853. package/dist/siemens-ix/{p-bc2c74c5.entry.js → p-1e3d6d27.entry.js} +2 -2
  854. package/dist/siemens-ix/{p-1db6be55.js → p-24afab39.js} +2 -2
  855. package/dist/{cjs/menu-tabs-fc-df53f176.js.map → siemens-ix/p-24afab39.js.map} +1 -1
  856. package/dist/siemens-ix/p-26609c63.entry.js +2 -0
  857. package/dist/siemens-ix/p-26609c63.entry.js.map +1 -0
  858. package/dist/siemens-ix/{p-68644ee1.entry.js → p-2c1540ba.entry.js} +2 -2
  859. package/dist/siemens-ix/{p-68644ee1.entry.js.map → p-2c1540ba.entry.js.map} +1 -1
  860. package/dist/siemens-ix/{p-9ebc4fc3.entry.js → p-2f232c45.entry.js} +2 -2
  861. package/dist/siemens-ix/p-2f232c45.entry.js.map +1 -0
  862. package/dist/siemens-ix/{p-6af4415c.entry.js → p-3028d530.entry.js} +2 -2
  863. package/dist/siemens-ix/{p-6af4415c.entry.js.map → p-3028d530.entry.js.map} +1 -1
  864. package/dist/siemens-ix/p-3150070f.entry.js +2 -0
  865. package/dist/siemens-ix/p-3150070f.entry.js.map +1 -0
  866. package/dist/siemens-ix/{p-f78246bd.entry.js → p-315ecf68.entry.js} +2 -2
  867. package/dist/siemens-ix/{p-712e0ee0.js → p-345e1c73.js} +1 -1
  868. package/dist/siemens-ix/{p-712e0ee0.js.map → p-345e1c73.js.map} +1 -1
  869. package/dist/siemens-ix/{p-fc5814df.entry.js → p-380a7d93.entry.js} +2 -2
  870. package/dist/siemens-ix/p-380a7d93.entry.js.map +1 -0
  871. package/dist/siemens-ix/p-3b576b4e.js +2 -0
  872. package/dist/siemens-ix/{p-112069ca.entry.js → p-3be4c628.entry.js} +2 -2
  873. package/dist/siemens-ix/p-3be4c628.entry.js.map +1 -0
  874. package/dist/siemens-ix/p-3e867ef9.entry.js +2 -0
  875. package/dist/siemens-ix/p-3e867ef9.entry.js.map +1 -0
  876. package/dist/siemens-ix/p-40f20208.entry.js +2 -0
  877. package/dist/siemens-ix/p-40f20208.entry.js.map +1 -0
  878. package/dist/siemens-ix/{p-d95cbd1f.entry.js → p-41935530.entry.js} +2 -2
  879. package/dist/siemens-ix/{p-d95cbd1f.entry.js.map → p-41935530.entry.js.map} +1 -1
  880. package/dist/siemens-ix/{p-b663ca16.entry.js → p-41d9a2e4.entry.js} +2 -2
  881. package/dist/siemens-ix/p-476e4a9d.entry.js +2 -0
  882. package/dist/siemens-ix/p-476e4a9d.entry.js.map +1 -0
  883. package/dist/siemens-ix/{p-25ee1b62.js → p-4ac31849.js} +1 -1
  884. package/dist/siemens-ix/{p-25ee1b62.js.map → p-4ac31849.js.map} +1 -1
  885. package/dist/siemens-ix/{p-2c4c03d4.entry.js → p-509dba4c.entry.js} +2 -2
  886. package/dist/siemens-ix/{p-113cc793.entry.js → p-50bcb3f8.entry.js} +2 -2
  887. package/dist/siemens-ix/{p-dcb3e5be.entry.js → p-5232d441.entry.js} +2 -2
  888. package/dist/siemens-ix/p-5bf37272.entry.js +2 -0
  889. package/dist/siemens-ix/p-5bf37272.entry.js.map +1 -0
  890. package/dist/siemens-ix/{p-5f25e7fd.entry.js → p-619a80d3.entry.js} +2 -2
  891. package/dist/siemens-ix/{p-5f25e7fd.entry.js.map → p-619a80d3.entry.js.map} +1 -1
  892. package/dist/siemens-ix/p-633a8884.entry.js +2 -0
  893. package/dist/siemens-ix/p-633a8884.entry.js.map +1 -0
  894. package/dist/siemens-ix/{p-dde7eb80.entry.js → p-66d4e328.entry.js} +2 -2
  895. package/dist/siemens-ix/{p-dde7eb80.entry.js.map → p-66d4e328.entry.js.map} +1 -1
  896. package/dist/siemens-ix/{p-1a122c76.entry.js → p-6913e59d.entry.js} +2 -2
  897. package/dist/siemens-ix/{p-fb47546b.entry.js → p-6a9577b5.entry.js} +2 -2
  898. package/dist/siemens-ix/p-6a9577b5.entry.js.map +1 -0
  899. package/dist/siemens-ix/{p-882a0233.entry.js → p-72472fa5.entry.js} +2 -2
  900. package/dist/siemens-ix/{p-1d581190.js → p-72d096e9.js} +2 -2
  901. package/dist/siemens-ix/p-72d096e9.js.map +1 -0
  902. package/dist/siemens-ix/{p-052340f9.entry.js → p-7354cdb0.entry.js} +2 -2
  903. package/dist/siemens-ix/p-737954bf.entry.js +2 -0
  904. package/dist/siemens-ix/p-737954bf.entry.js.map +1 -0
  905. package/dist/siemens-ix/p-737c61da.entry.js +2 -0
  906. package/dist/siemens-ix/{p-4430117a.entry.js.map → p-737c61da.entry.js.map} +1 -1
  907. package/dist/siemens-ix/p-73bd61ca.entry.js +2 -0
  908. package/dist/siemens-ix/{p-0653a145.entry.js → p-74461f94.entry.js} +2 -2
  909. package/dist/siemens-ix/{p-b4ce366d.entry.js → p-7815494b.entry.js} +2 -2
  910. package/dist/siemens-ix/p-7815494b.entry.js.map +1 -0
  911. package/dist/siemens-ix/{p-53352bfb.entry.js → p-8578629c.entry.js} +2 -2
  912. package/dist/siemens-ix/p-8578629c.entry.js.map +1 -0
  913. package/dist/siemens-ix/p-8a56153a.entry.js +2 -0
  914. package/dist/siemens-ix/{p-92a18c10.entry.js.map → p-8a56153a.entry.js.map} +1 -1
  915. package/dist/siemens-ix/{p-fb2b78f7.entry.js → p-8b21fc75.entry.js} +2 -2
  916. package/dist/siemens-ix/p-8b21fc75.entry.js.map +1 -0
  917. package/dist/siemens-ix/p-8b2b4ce3.entry.js +2 -0
  918. package/dist/siemens-ix/p-8b2b4ce3.entry.js.map +1 -0
  919. package/dist/siemens-ix/p-8f48462b.entry.js +2 -0
  920. package/dist/siemens-ix/p-8f48462b.entry.js.map +1 -0
  921. package/dist/siemens-ix/p-9144ea56.entry.js +2 -0
  922. package/dist/siemens-ix/p-9144ea56.entry.js.map +1 -0
  923. package/dist/siemens-ix/p-98af5c4d.entry.js +2 -0
  924. package/dist/siemens-ix/p-98af5c4d.entry.js.map +1 -0
  925. package/dist/siemens-ix/p-99a1cd81.entry.js +2 -0
  926. package/dist/siemens-ix/{p-96a3a750.entry.js → p-9b8c6123.entry.js} +2 -2
  927. package/dist/siemens-ix/p-9b8c6123.entry.js.map +1 -0
  928. package/dist/siemens-ix/p-9cd40e56.entry.js +2 -0
  929. package/dist/siemens-ix/p-9cd40e56.entry.js.map +1 -0
  930. package/dist/siemens-ix/{p-2946fd70.entry.js → p-ad0c6a32.entry.js} +2 -2
  931. package/dist/siemens-ix/p-af7a836c.entry.js +2 -0
  932. package/dist/siemens-ix/p-af7a836c.entry.js.map +1 -0
  933. package/dist/siemens-ix/{p-6fd7ecd0.entry.js → p-b247d124.entry.js} +2 -2
  934. package/dist/siemens-ix/p-b53aa733.entry.js +2 -0
  935. package/dist/siemens-ix/p-b53aa733.entry.js.map +1 -0
  936. package/dist/siemens-ix/{p-b804b8c5.entry.js → p-b6a11e17.entry.js} +2 -2
  937. package/dist/siemens-ix/p-b9e66925.entry.js +2 -0
  938. package/dist/siemens-ix/{p-2908cacd.entry.js → p-b9f67de0.entry.js} +2 -2
  939. package/dist/siemens-ix/{p-2908cacd.entry.js.map → p-b9f67de0.entry.js.map} +1 -1
  940. package/dist/siemens-ix/{p-14a41c8c.entry.js → p-ba2e041e.entry.js} +2 -2
  941. package/dist/siemens-ix/p-ba6e955a.js +2 -0
  942. package/dist/siemens-ix/p-ba6e955a.js.map +1 -0
  943. package/dist/siemens-ix/p-bf1e16f6.entry.js +2 -0
  944. package/dist/siemens-ix/p-bf1e16f6.entry.js.map +1 -0
  945. package/dist/siemens-ix/{p-ff1ac5b3.entry.js → p-c0bf3052.entry.js} +2 -2
  946. package/dist/siemens-ix/{p-1f4b8463.entry.js → p-c39a6215.entry.js} +2 -2
  947. package/dist/siemens-ix/p-c5e08d24.entry.js +2 -0
  948. package/dist/siemens-ix/p-c5e08d24.entry.js.map +1 -0
  949. package/dist/siemens-ix/{p-29df2e29.entry.js → p-c841c191.entry.js} +2 -2
  950. package/dist/siemens-ix/p-c841c191.entry.js.map +1 -0
  951. package/dist/siemens-ix/{p-5696bb62.entry.js → p-cacd4857.entry.js} +2 -2
  952. package/dist/siemens-ix/p-cdaad9de.entry.js +2 -0
  953. package/dist/siemens-ix/p-cdaad9de.entry.js.map +1 -0
  954. package/dist/siemens-ix/p-ce563a48.js +2 -0
  955. package/dist/siemens-ix/p-ce563a48.js.map +1 -0
  956. package/dist/siemens-ix/p-ce808a3f.entry.js +2 -0
  957. package/dist/siemens-ix/{p-d03df401.entry.js.map → p-ce808a3f.entry.js.map} +1 -1
  958. package/dist/siemens-ix/p-d057b634.entry.js +2 -0
  959. package/dist/siemens-ix/p-d1a5b773.entry.js +2 -0
  960. package/dist/siemens-ix/p-d1a5b773.entry.js.map +1 -0
  961. package/dist/siemens-ix/{p-16b923e9.entry.js → p-d7072aad.entry.js} +2 -2
  962. package/dist/siemens-ix/{p-af099ca4.entry.js → p-d7a0deb7.entry.js} +2 -2
  963. package/dist/siemens-ix/p-d8780f8c.entry.js +2 -0
  964. package/dist/siemens-ix/p-d8780f8c.entry.js.map +1 -0
  965. package/dist/siemens-ix/p-da71920f.entry.js +2 -0
  966. package/dist/siemens-ix/p-da71920f.entry.js.map +1 -0
  967. package/dist/siemens-ix/{p-feac09bc.entry.js → p-dc284f4d.entry.js} +2 -2
  968. package/dist/siemens-ix/p-dda1ce22.entry.js +2 -0
  969. package/dist/siemens-ix/p-dda1ce22.entry.js.map +1 -0
  970. package/dist/siemens-ix/{p-c33cee36.entry.js → p-de44d65b.entry.js} +2 -2
  971. package/dist/siemens-ix/{p-c33cee36.entry.js.map → p-de44d65b.entry.js.map} +1 -1
  972. package/dist/siemens-ix/p-e4441794.entry.js +2 -0
  973. package/dist/siemens-ix/p-e4441794.entry.js.map +1 -0
  974. package/dist/siemens-ix/{p-e8d3cf35.entry.js → p-e4ca3618.entry.js} +2 -2
  975. package/dist/siemens-ix/{p-e8d3cf35.entry.js.map → p-e4ca3618.entry.js.map} +1 -1
  976. package/dist/siemens-ix/p-e6652822.js +2 -0
  977. package/dist/siemens-ix/p-e6652822.js.map +1 -0
  978. package/dist/siemens-ix/{p-8629db91.entry.js → p-e89c0e29.entry.js} +2 -2
  979. package/dist/siemens-ix/{p-0b4e398e.entry.js → p-ead295d5.entry.js} +2 -2
  980. package/dist/siemens-ix/{p-0b4e398e.entry.js.map → p-ead295d5.entry.js.map} +1 -1
  981. package/dist/siemens-ix/p-ec037f98.js +2 -0
  982. package/dist/siemens-ix/p-ec037f98.js.map +1 -0
  983. package/dist/siemens-ix/p-ee50f7fa.entry.js +2 -0
  984. package/dist/siemens-ix/{p-8d0758c1.entry.js → p-f47bd4e8.entry.js} +2 -2
  985. package/dist/siemens-ix/{p-87e692d9.entry.js → p-f576c41d.entry.js} +2 -2
  986. package/dist/siemens-ix/{p-87e692d9.entry.js.map → p-f576c41d.entry.js.map} +1 -1
  987. package/dist/siemens-ix/p-f5a9140e.entry.js +2 -0
  988. package/dist/siemens-ix/p-f5a9140e.entry.js.map +1 -0
  989. package/dist/siemens-ix/p-fb593d70.entry.js +2 -0
  990. package/dist/siemens-ix/p-fb593d70.entry.js.map +1 -0
  991. package/dist/siemens-ix/{p-c1968b80.entry.js → p-fc766ada.entry.js} +2 -2
  992. package/dist/siemens-ix/p-fe01bff0.js +2 -0
  993. package/dist/siemens-ix/p-fe01bff0.js.map +1 -0
  994. package/dist/siemens-ix/p-ff6668b8.entry.js +2 -0
  995. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  996. package/dist/siemens-ix/siemens-ix.css +15 -11
  997. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  998. package/dist/siemens-ix/siemens-ix.esm.js.map +1 -1
  999. package/dist/types/components/action-card/action-card.d.ts +3 -2
  1000. package/dist/types/components/application-header/application-header.d.ts +19 -1
  1001. package/dist/types/components/basic-navigation/basic-navigation.d.ts +2 -1
  1002. package/dist/types/components/blind/blind.d.ts +4 -4
  1003. package/dist/types/components/breadcrumb/breadcrumb.d.ts +3 -3
  1004. package/dist/types/components/button/base-button.d.ts +3 -2
  1005. package/dist/types/components/button/button.d.ts +2 -2
  1006. package/dist/types/components/card/card.d.ts +2 -1
  1007. package/dist/types/components/category-filter/category-filter.d.ts +23 -12
  1008. package/dist/types/components/category-filter/test/category-filter.ct.d.ts +1 -0
  1009. package/dist/types/components/content-header/content-header.d.ts +1 -1
  1010. package/dist/types/components/css-grid/css-grid.d.ts +2 -2
  1011. package/dist/types/components/date-dropdown/date-dropdown.d.ts +3 -3
  1012. package/dist/types/components/date-picker/date-picker.d.ts +6 -7
  1013. package/dist/types/components/dropdown/dropdown-controller.d.ts +1 -6
  1014. package/dist/types/components/dropdown/dropdown.d.ts +11 -10
  1015. package/dist/types/components/dropdown-button/dropdown-button.d.ts +4 -4
  1016. package/dist/types/components/dropdown-item/dropdown-item.d.ts +2 -2
  1017. package/dist/types/components/group/group.d.ts +7 -6
  1018. package/dist/types/components/group-item/group-item.d.ts +4 -4
  1019. package/dist/types/components/menu-about/test/menu-about.ct.d.ts +1 -0
  1020. package/dist/types/components/menu-item/menu-item.d.ts +6 -5
  1021. package/dist/types/components/modal/test/modal.ct.d.ts +3 -2
  1022. package/dist/types/components/modal-header/modal-header.d.ts +3 -3
  1023. package/dist/types/components/push-card/push-card.d.ts +4 -3
  1024. package/dist/types/components/select/select.d.ts +9 -10
  1025. package/dist/types/components/slider/slider.d.ts +3 -3
  1026. package/dist/types/components/tab-item/tab-item.d.ts +1 -1
  1027. package/dist/types/components/tabs/tabs.d.ts +7 -4
  1028. package/dist/types/components/tooltip/tooltip.d.ts +10 -10
  1029. package/dist/types/components/tree/tree.d.ts +1 -1
  1030. package/dist/types/components/tree-item/tree-item.d.ts +3 -3
  1031. package/dist/types/components/typography/type-mapping.d.ts +3 -0
  1032. package/dist/types/components/typography/typography.d.ts +3 -10
  1033. package/dist/types/components/upload/test/upload.ct.d.ts +1 -0
  1034. package/dist/types/components/upload/upload.d.ts +4 -2
  1035. package/dist/types/components/utils/disposable-event-listener.d.ts +7 -0
  1036. package/dist/types/components/utils/element-reference.d.ts +1 -0
  1037. package/dist/types/components/utils/focus.d.ts +5 -4
  1038. package/dist/types/components/utils/listener.d.ts +4 -2
  1039. package/dist/types/components/utils/make-ref.d.ts +2 -2
  1040. package/dist/types/components/utils/theme-switcher.d.ts +1 -1
  1041. package/dist/types/components.d.ts +114 -75
  1042. package/dist/types/index.d.ts +2 -0
  1043. package/dist/types/tests/utils/test/page.d.ts +1 -3
  1044. package/hydrate/index.js +1536 -788
  1045. package/package.json +6 -4
  1046. package/scss/_core.scss +5 -0
  1047. package/scss/components/form/_input.scss +17 -20
  1048. package/dist/cjs/base-button-3735b8c2.js.map +0 -1
  1049. package/dist/cjs/context-98f4a0b3.js.map +0 -1
  1050. package/dist/cjs/floating-ui.dom.esm-94b4d17c.js.map +0 -1
  1051. package/dist/cjs/focus-9c8ffbb0.js.map +0 -1
  1052. package/dist/cjs/listener-bc3e7c0c.js.map +0 -1
  1053. package/dist/cjs/make-ref-c25629b7.js.map +0 -1
  1054. package/dist/cjs/theme-switcher-2d2bde85.js.map +0 -1
  1055. package/dist/esm/base-button-1b40b11d.js.map +0 -1
  1056. package/dist/esm/context-c9078420.js.map +0 -1
  1057. package/dist/esm/floating-ui.dom.esm-6e7c098f.js.map +0 -1
  1058. package/dist/esm/focus-d4d3abaf.js.map +0 -1
  1059. package/dist/esm/listener-4f3baab5.js.map +0 -1
  1060. package/dist/esm/make-ref-c80046bf.js.map +0 -1
  1061. package/dist/esm/menu-tabs-fc-d9a7dd06.js.map +0 -1
  1062. package/dist/esm/theme-switcher-b10fb4da.js.map +0 -1
  1063. package/dist/siemens-ix/p-0c8a98cd.js +0 -2
  1064. package/dist/siemens-ix/p-0c8a98cd.js.map +0 -1
  1065. package/dist/siemens-ix/p-0d2a6886.entry.js +0 -2
  1066. package/dist/siemens-ix/p-0f7ef743.entry.js +0 -2
  1067. package/dist/siemens-ix/p-112069ca.entry.js.map +0 -1
  1068. package/dist/siemens-ix/p-15b3c17e.entry.js +0 -2
  1069. package/dist/siemens-ix/p-15b3c17e.entry.js.map +0 -1
  1070. package/dist/siemens-ix/p-1cff59db.entry.js +0 -2
  1071. package/dist/siemens-ix/p-1cff59db.entry.js.map +0 -1
  1072. package/dist/siemens-ix/p-1d581190.js.map +0 -1
  1073. package/dist/siemens-ix/p-1da901d5.js.map +0 -1
  1074. package/dist/siemens-ix/p-1db6be55.js.map +0 -1
  1075. package/dist/siemens-ix/p-29df2e29.entry.js.map +0 -1
  1076. package/dist/siemens-ix/p-2ebfd4fd.entry.js +0 -2
  1077. package/dist/siemens-ix/p-2ec7f841.entry.js +0 -2
  1078. package/dist/siemens-ix/p-2ec7f841.entry.js.map +0 -1
  1079. package/dist/siemens-ix/p-309ac3ad.entry.js +0 -2
  1080. package/dist/siemens-ix/p-309ac3ad.entry.js.map +0 -1
  1081. package/dist/siemens-ix/p-315f070d.entry.js +0 -2
  1082. package/dist/siemens-ix/p-315f070d.entry.js.map +0 -1
  1083. package/dist/siemens-ix/p-32375ddb.entry.js +0 -2
  1084. package/dist/siemens-ix/p-32d4ed3b.entry.js +0 -2
  1085. package/dist/siemens-ix/p-427676f4.entry.js +0 -2
  1086. package/dist/siemens-ix/p-427676f4.entry.js.map +0 -1
  1087. package/dist/siemens-ix/p-4430117a.entry.js +0 -2
  1088. package/dist/siemens-ix/p-44db3646.entry.js +0 -2
  1089. package/dist/siemens-ix/p-4b3facea.entry.js +0 -2
  1090. package/dist/siemens-ix/p-4b3facea.entry.js.map +0 -1
  1091. package/dist/siemens-ix/p-52857629.entry.js +0 -2
  1092. package/dist/siemens-ix/p-52857629.entry.js.map +0 -1
  1093. package/dist/siemens-ix/p-53352bfb.entry.js.map +0 -1
  1094. package/dist/siemens-ix/p-5c673ae9.entry.js +0 -2
  1095. package/dist/siemens-ix/p-5c673ae9.entry.js.map +0 -1
  1096. package/dist/siemens-ix/p-60c16878.entry.js +0 -2
  1097. package/dist/siemens-ix/p-60c16878.entry.js.map +0 -1
  1098. package/dist/siemens-ix/p-6227e62b.entry.js +0 -2
  1099. package/dist/siemens-ix/p-6227e62b.entry.js.map +0 -1
  1100. package/dist/siemens-ix/p-64c3fa3d.js +0 -2
  1101. package/dist/siemens-ix/p-64c3fa3d.js.map +0 -1
  1102. package/dist/siemens-ix/p-68532fa2.js +0 -2
  1103. package/dist/siemens-ix/p-7076210b.entry.js.map +0 -1
  1104. package/dist/siemens-ix/p-713828ed.entry.js +0 -2
  1105. package/dist/siemens-ix/p-713828ed.entry.js.map +0 -1
  1106. package/dist/siemens-ix/p-7bfd6cd2.entry.js +0 -2
  1107. package/dist/siemens-ix/p-7bfd6cd2.entry.js.map +0 -1
  1108. package/dist/siemens-ix/p-7c36d3fa.js +0 -2
  1109. package/dist/siemens-ix/p-7c36d3fa.js.map +0 -1
  1110. package/dist/siemens-ix/p-7faa148f.entry.js +0 -2
  1111. package/dist/siemens-ix/p-85423643.entry.js +0 -2
  1112. package/dist/siemens-ix/p-85423643.entry.js.map +0 -1
  1113. package/dist/siemens-ix/p-8d599677.entry.js +0 -2
  1114. package/dist/siemens-ix/p-8d599677.entry.js.map +0 -1
  1115. package/dist/siemens-ix/p-92a18c10.entry.js +0 -2
  1116. package/dist/siemens-ix/p-96a3a750.entry.js.map +0 -1
  1117. package/dist/siemens-ix/p-9ebc4fc3.entry.js.map +0 -1
  1118. package/dist/siemens-ix/p-a0138163.entry.js +0 -2
  1119. package/dist/siemens-ix/p-a0138163.entry.js.map +0 -1
  1120. package/dist/siemens-ix/p-a0a44a2b.entry.js +0 -2
  1121. package/dist/siemens-ix/p-a0a44a2b.entry.js.map +0 -1
  1122. package/dist/siemens-ix/p-a8d291fa.entry.js.map +0 -1
  1123. package/dist/siemens-ix/p-b3b23af7.entry.js +0 -2
  1124. package/dist/siemens-ix/p-b3f35666.js +0 -2
  1125. package/dist/siemens-ix/p-b3f35666.js.map +0 -1
  1126. package/dist/siemens-ix/p-b4ce366d.entry.js.map +0 -1
  1127. package/dist/siemens-ix/p-c09553f3.js +0 -2
  1128. package/dist/siemens-ix/p-c09553f3.js.map +0 -1
  1129. package/dist/siemens-ix/p-c1222581.entry.js +0 -2
  1130. package/dist/siemens-ix/p-c45601cb.entry.js +0 -2
  1131. package/dist/siemens-ix/p-c45601cb.entry.js.map +0 -1
  1132. package/dist/siemens-ix/p-c55db6c7.entry.js +0 -2
  1133. package/dist/siemens-ix/p-c55db6c7.entry.js.map +0 -1
  1134. package/dist/siemens-ix/p-d03df401.entry.js +0 -2
  1135. package/dist/siemens-ix/p-d14024d3.entry.js +0 -2
  1136. package/dist/siemens-ix/p-d14024d3.entry.js.map +0 -1
  1137. package/dist/siemens-ix/p-d1f49940.entry.js +0 -2
  1138. package/dist/siemens-ix/p-d1f49940.entry.js.map +0 -1
  1139. package/dist/siemens-ix/p-d998415f.entry.js +0 -2
  1140. package/dist/siemens-ix/p-d998415f.entry.js.map +0 -1
  1141. package/dist/siemens-ix/p-e30ed20a.entry.js +0 -2
  1142. package/dist/siemens-ix/p-e30ed20a.entry.js.map +0 -1
  1143. package/dist/siemens-ix/p-e9a3f58a.entry.js +0 -2
  1144. package/dist/siemens-ix/p-e9a3f58a.entry.js.map +0 -1
  1145. package/dist/siemens-ix/p-eb6268a6.entry.js +0 -2
  1146. package/dist/siemens-ix/p-eb6268a6.entry.js.map +0 -1
  1147. package/dist/siemens-ix/p-ebb277f0.entry.js +0 -2
  1148. package/dist/siemens-ix/p-ebb277f0.entry.js.map +0 -1
  1149. package/dist/siemens-ix/p-f07110c6.entry.js +0 -2
  1150. package/dist/siemens-ix/p-f07110c6.entry.js.map +0 -1
  1151. package/dist/siemens-ix/p-fb2b78f7.entry.js.map +0 -1
  1152. package/dist/siemens-ix/p-fb47546b.entry.js.map +0 -1
  1153. package/dist/siemens-ix/p-fc5814df.entry.js.map +0 -1
  1154. package/dist/siemens-ix/p-ff148103.entry.js +0 -2
  1155. package/dist/siemens-ix/p-ff148103.entry.js.map +0 -1
  1156. /package/dist/siemens-ix/{p-bf14c60b.entry.js.map → p-0379b864.entry.js.map} +0 -0
  1157. /package/dist/siemens-ix/{p-24a8737a.entry.js.map → p-054451cb.entry.js.map} +0 -0
  1158. /package/dist/siemens-ix/{p-90440046.entry.js.map → p-06f9e19f.entry.js.map} +0 -0
  1159. /package/dist/siemens-ix/{p-fb4c79c6.entry.js.map → p-0996d9f6.entry.js.map} +0 -0
  1160. /package/dist/siemens-ix/{p-bea7c748.entry.js.map → p-0f4e62f3.entry.js.map} +0 -0
  1161. /package/dist/siemens-ix/{p-c1222581.entry.js.map → p-1a8e3fea.entry.js.map} +0 -0
  1162. /package/dist/siemens-ix/{p-bc2c74c5.entry.js.map → p-1e3d6d27.entry.js.map} +0 -0
  1163. /package/dist/siemens-ix/{p-f78246bd.entry.js.map → p-315ecf68.entry.js.map} +0 -0
  1164. /package/dist/siemens-ix/{p-68532fa2.js.map → p-3b576b4e.js.map} +0 -0
  1165. /package/dist/siemens-ix/{p-b663ca16.entry.js.map → p-41d9a2e4.entry.js.map} +0 -0
  1166. /package/dist/siemens-ix/{p-2c4c03d4.entry.js.map → p-509dba4c.entry.js.map} +0 -0
  1167. /package/dist/siemens-ix/{p-113cc793.entry.js.map → p-50bcb3f8.entry.js.map} +0 -0
  1168. /package/dist/siemens-ix/{p-dcb3e5be.entry.js.map → p-5232d441.entry.js.map} +0 -0
  1169. /package/dist/siemens-ix/{p-1a122c76.entry.js.map → p-6913e59d.entry.js.map} +0 -0
  1170. /package/dist/siemens-ix/{p-882a0233.entry.js.map → p-72472fa5.entry.js.map} +0 -0
  1171. /package/dist/siemens-ix/{p-052340f9.entry.js.map → p-7354cdb0.entry.js.map} +0 -0
  1172. /package/dist/siemens-ix/{p-32d4ed3b.entry.js.map → p-73bd61ca.entry.js.map} +0 -0
  1173. /package/dist/siemens-ix/{p-0653a145.entry.js.map → p-74461f94.entry.js.map} +0 -0
  1174. /package/dist/siemens-ix/{p-b3b23af7.entry.js.map → p-99a1cd81.entry.js.map} +0 -0
  1175. /package/dist/siemens-ix/{p-2946fd70.entry.js.map → p-ad0c6a32.entry.js.map} +0 -0
  1176. /package/dist/siemens-ix/{p-6fd7ecd0.entry.js.map → p-b247d124.entry.js.map} +0 -0
  1177. /package/dist/siemens-ix/{p-b804b8c5.entry.js.map → p-b6a11e17.entry.js.map} +0 -0
  1178. /package/dist/siemens-ix/{p-44db3646.entry.js.map → p-b9e66925.entry.js.map} +0 -0
  1179. /package/dist/siemens-ix/{p-14a41c8c.entry.js.map → p-ba2e041e.entry.js.map} +0 -0
  1180. /package/dist/siemens-ix/{p-ff1ac5b3.entry.js.map → p-c0bf3052.entry.js.map} +0 -0
  1181. /package/dist/siemens-ix/{p-1f4b8463.entry.js.map → p-c39a6215.entry.js.map} +0 -0
  1182. /package/dist/siemens-ix/{p-5696bb62.entry.js.map → p-cacd4857.entry.js.map} +0 -0
  1183. /package/dist/siemens-ix/{p-7faa148f.entry.js.map → p-d057b634.entry.js.map} +0 -0
  1184. /package/dist/siemens-ix/{p-16b923e9.entry.js.map → p-d7072aad.entry.js.map} +0 -0
  1185. /package/dist/siemens-ix/{p-af099ca4.entry.js.map → p-d7a0deb7.entry.js.map} +0 -0
  1186. /package/dist/siemens-ix/{p-feac09bc.entry.js.map → p-dc284f4d.entry.js.map} +0 -0
  1187. /package/dist/siemens-ix/{p-8629db91.entry.js.map → p-e89c0e29.entry.js.map} +0 -0
  1188. /package/dist/siemens-ix/{p-32375ddb.entry.js.map → p-ee50f7fa.entry.js.map} +0 -0
  1189. /package/dist/siemens-ix/{p-8d0758c1.entry.js.map → p-f47bd4e8.entry.js.map} +0 -0
  1190. /package/dist/siemens-ix/{p-c1968b80.entry.js.map → p-fc766ada.entry.js.map} +0 -0
  1191. /package/dist/siemens-ix/{p-0d2a6886.entry.js.map → p-ff6668b8.entry.js.map} +0 -0
@@ -14,6 +14,7 @@ test('renders', async ({ page, mount }) => {
14
14
  await expect(slider).toHaveClass(/hydrated/);
15
15
  });
16
16
  test('should show tooltip by focus', async ({ page, mount }) => {
17
+ var _a, _b;
17
18
  await mount(`<ix-slider value="20"></ix-slider>`);
18
19
  const slider = page.locator('ix-slider');
19
20
  await expect(slider).toHaveClass(/hydrated/);
@@ -21,12 +22,15 @@ test('should show tooltip by focus', async ({ page, mount }) => {
21
22
  const tooltip = slider.locator('ix-tooltip');
22
23
  await input.focus();
23
24
  await expect(tooltip).toBeVisible();
24
- const left = (await tooltip.boundingBox()).x;
25
+ const left = (_a = (await tooltip.boundingBox())) === null || _a === void 0 ? void 0 : _a.x;
26
+ if (!left) {
27
+ throw new Error('Tooltip bounding box is x is undefined.');
28
+ }
25
29
  await input.press('ArrowRight');
26
30
  await input.press('ArrowRight');
27
31
  await page.waitForTimeout(500);
28
32
  await expect(tooltip).toBeVisible();
29
- const leftAfterKeyboardNavigation = (await tooltip.boundingBox()).x;
33
+ const leftAfterKeyboardNavigation = (_b = (await tooltip.boundingBox())) === null || _b === void 0 ? void 0 : _b.x;
30
34
  expect(leftAfterKeyboardNavigation).toBeGreaterThan(left);
31
35
  await input.blur();
32
36
  await page.waitForTimeout(500);
@@ -39,10 +43,15 @@ test('should show tooltip while mouse drags slider handle', async ({ page, mount
39
43
  const tooltip = slider.locator('ix-tooltip');
40
44
  await expect(tooltip).not.toBeVisible();
41
45
  const box = await slider.boundingBox();
42
- await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);
43
- await page.mouse.down();
44
- await page.mouse.move(box.x + box.width / 3, box.y + box.height / 3);
45
- await expect(tooltip).toBeVisible();
46
+ if (box) {
47
+ await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);
48
+ await page.mouse.down();
49
+ await page.mouse.move(box.x + box.width / 3, box.y + box.height / 3);
50
+ await expect(tooltip).toBeVisible();
51
+ }
52
+ else {
53
+ throw new Error('Slider bounding box is null.');
54
+ }
46
55
  await page.mouse.up();
47
56
  await expect(tooltip).not.toBeVisible();
48
57
  });
@@ -1 +1 @@
1
- {"version":3,"file":"slider.ct.js","sourceRoot":"","sources":["../../../../src/components/slider/test/slider.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect } from '@playwright/test';\nimport { test } from '@utils/test';\n\ntest('renders', async ({ page, mount }) => {\n await mount(`<ix-slider></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n});\n\ntest('should show tooltip by focus', async ({ page, mount }) => {\n await mount(`<ix-slider value=\"20\"></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n\n const input = slider.locator('input');\n\n const tooltip = slider.locator('ix-tooltip');\n await input.focus();\n await expect(tooltip).toBeVisible();\n const left = (await tooltip.boundingBox()).x;\n\n await input.press('ArrowRight');\n await input.press('ArrowRight');\n\n await page.waitForTimeout(500);\n await expect(tooltip).toBeVisible();\n const leftAfterKeyboardNavigation = (await tooltip.boundingBox()).x;\n\n expect(leftAfterKeyboardNavigation).toBeGreaterThan(left);\n\n await input.blur();\n await page.waitForTimeout(500);\n await expect(tooltip).not.toBeVisible();\n});\n\ntest('should show tooltip while mouse drags slider handle', async ({\n page,\n mount,\n}) => {\n await mount(`<ix-slider value=\"20\"></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n\n const tooltip = slider.locator('ix-tooltip');\n\n await expect(tooltip).not.toBeVisible();\n\n const box = await slider.boundingBox();\n await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);\n await page.mouse.down();\n await page.mouse.move(box.x + box.width / 3, box.y + box.height / 3);\n await expect(tooltip).toBeVisible();\n\n await page.mouse.up();\n await expect(tooltip).not.toBeVisible();\n});\n"]}
1
+ {"version":3,"file":"slider.ct.js","sourceRoot":"","sources":["../../../../src/components/slider/test/slider.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect } from '@playwright/test';\nimport { test } from '@utils/test';\n\ntest('renders', async ({ page, mount }) => {\n await mount(`<ix-slider></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n});\n\ntest('should show tooltip by focus', async ({ page, mount }) => {\n await mount(`<ix-slider value=\"20\"></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n\n const input = slider.locator('input');\n\n const tooltip = slider.locator('ix-tooltip');\n await input.focus();\n await expect(tooltip).toBeVisible();\n const left = (await tooltip.boundingBox())?.x;\n\n if (!left) {\n throw new Error('Tooltip bounding box is x is undefined.');\n }\n\n await input.press('ArrowRight');\n await input.press('ArrowRight');\n\n await page.waitForTimeout(500);\n await expect(tooltip).toBeVisible();\n const leftAfterKeyboardNavigation = (await tooltip.boundingBox())?.x;\n\n expect(leftAfterKeyboardNavigation).toBeGreaterThan(left);\n\n await input.blur();\n await page.waitForTimeout(500);\n await expect(tooltip).not.toBeVisible();\n});\n\ntest('should show tooltip while mouse drags slider handle', async ({\n page,\n mount,\n}) => {\n await mount(`<ix-slider value=\"20\"></ix-slider>`);\n\n const slider = page.locator('ix-slider');\n await expect(slider).toHaveClass(/hydrated/);\n\n const tooltip = slider.locator('ix-tooltip');\n\n await expect(tooltip).not.toBeVisible();\n\n const box = await slider.boundingBox();\n\n if (box) {\n await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);\n await page.mouse.down();\n await page.mouse.move(box.x + box.width / 3, box.y + box.height / 3);\n await expect(tooltip).toBeVisible();\n } else {\n throw new Error('Slider bounding box is null.');\n }\n\n await page.mouse.up();\n await expect(tooltip).not.toBeVisible();\n});\n"]}
@@ -14,7 +14,7 @@ export class Spinner {
14
14
  this.hideTrack = false;
15
15
  }
16
16
  render() {
17
- return (h(Host, { key: 'b83203aa7712519c8d12c8ff55378edc167b43f7', class: {
17
+ return (h(Host, { key: 'cca7c62990508399feaa9b56202eca84105051bd', class: {
18
18
  primary: this.variant === 'primary',
19
19
  'xx-small': this.size === 'xx-small',
20
20
  'x-small': this.size === 'x-small',
@@ -38,7 +38,7 @@ export class SplitButton {
38
38
  'left-button-border': !this.outline,
39
39
  },
40
40
  };
41
- return (h(Host, { key: 'e452c205dc4ff169a9c01b757e913506be6cc217' }, h("div", { key: '926ce0fb8cca44d56d2d975a17858de163f67154', class: { 'btn-group': true, 'middle-gap': !this.outline } }, this.label ? (h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e) }), this.label)) : (h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e) }))), h("ix-icon-button", Object.assign({ key: 'acc87b0c8506fc0d7e1e4314bbf9d6edd4a2428a' }, buttonAttributes, { ref: (r) => (this.triggerElement = r), class: 'anchor', icon: this.splitIcon }))), h("ix-dropdown", { key: '2bbd1e58b11b0f8c733c969a05a9ad14d8e99c94', ref: (r) => (this.dropdownElement = r), closeBehavior: this.closeBehavior }, h("slot", { key: '1da482f78a3ac0d6b54ee6c903ce11827c2bf7b1' }))));
41
+ return (h(Host, { key: '3a1cf24ab571aaefac909e540c15f572a077c386' }, h("div", { key: '9a9f8f5e15079835a5cef5a1009d12b8a515e79b', class: { 'btn-group': true, 'middle-gap': !this.outline } }, this.label ? (h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e) }), this.label)) : (h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e) }))), h("ix-icon-button", Object.assign({ key: '1bc07a85756dc861f1a497031bcb8e7a808e3d14' }, buttonAttributes, { ref: (r) => (this.triggerElement = r), class: 'anchor', icon: this.splitIcon }))), h("ix-dropdown", { key: 'b795be074eeb92d7dac49086df1a18469c8081aa', ref: (r) => (this.dropdownElement = r), closeBehavior: this.closeBehavior }, h("slot", { key: '23aad4022b42257553fe4ee839db6b5453afd7e6' }))));
42
42
  }
43
43
  static get is() { return "ix-split-button"; }
44
44
  static get encapsulation() { return "shadow"; }
@@ -22,7 +22,7 @@ export class SplitButtonItem {
22
22
  return this.wrapperRef.waitForCurrent();
23
23
  }
24
24
  render() {
25
- return (h(Host, { key: 'dd2f9ba13231244d5eb7071c68f19ec2029b411a' }, h("ix-dropdown-item", { key: '0024bb200f0924ba9e7cdced2cc4958fb8da43df', ref: this.wrapperRef, suppressChecked: true, icon: this.icon, label: this.label, onItemClick: (e) => {
25
+ return (h(Host, { key: 'bae996f7ae7a776442894bb5847e768deb9ec93b' }, h("ix-dropdown-item", { key: 'a7208cb23490b14e792c478eef08d1aba12e51a2', ref: this.wrapperRef, suppressChecked: true, icon: this.icon, label: this.label, onItemClick: (e) => {
26
26
  e.preventDefault();
27
27
  e.stopPropagation();
28
28
  }, onClick: (e) => this.itemClick.emit(e) })));
@@ -31,7 +31,7 @@ export class TabItem {
31
31
  };
32
32
  }
33
33
  render() {
34
- return (h(Host, { key: '926d3579090f1be086eb75bdbc42865af3c51836', class: this.tabItemClasses({
34
+ return (h(Host, { key: '284337753b942d805e3301d47b46f43fd611839e', class: this.tabItemClasses({
35
35
  selected: this.selected,
36
36
  disabled: this.disabled,
37
37
  small: this.small,
@@ -46,12 +46,12 @@ export class TabItem {
46
46
  if (clientEvent.defaultPrevented) {
47
47
  event.stopPropagation();
48
48
  }
49
- } }, h("div", { key: 'fedfa30ba5108be5a8b0c0078a9512acab21f067', class: {
49
+ } }, h("div", { key: 'e53dc7eb7ceee4d3760a74f8e0ad36f70f819eb1', class: {
50
50
  circle: this.rounded,
51
51
  text: !this.rounded,
52
52
  selected: this.selected,
53
53
  disabled: this.disabled,
54
- } }, h("slot", { key: 'e1ff1b021041a04689c8ae1b1b54894f51fda854' })), h("div", { key: '8cd112dcb4dcd0513603bf4623a58bb9740d6b32', class: {
54
+ } }, h("slot", { key: 'ef8347c3459c57bc0207d91d1cb7ea9d161ed331' })), h("div", { key: '60e2d9001009e554a137804493a2e5661f31a3f6', class: {
55
55
  counter: true,
56
56
  selected: this.selected,
57
57
  hidden: !(this.rounded && this.counter !== undefined),
@@ -171,7 +171,7 @@ export class TabItem {
171
171
  "references": {}
172
172
  },
173
173
  "required": false,
174
- "optional": false,
174
+ "optional": true,
175
175
  "docs": {
176
176
  "tags": [],
177
177
  "text": "Set counter value"
@@ -1 +1 @@
1
- {"version":3,"file":"tab-item.js","sourceRoot":"","sources":["../../../src/components/tab-item/tab-item.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAW9E,MAAM,OAAO,OAAO;;wBAIC,KAAK;wBAKL,KAAK;qBAKR,KAAK;oBAKN,KAAK;uBAKF,KAAK;;sBAUgB,MAAM;yBAKP,QAAQ;;IAStC,cAAc,CAAC,KAQtB;QACC,OAAO;YACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,WAAW,EAAE,KAAK,CAAC,KAAK;YACxB,IAAI,EAAE,KAAK,CAAC,KAAK;YACjB,SAAS,EAAE,KAAK,CAAC,MAAM,KAAK,WAAW;YACvC,MAAM,EAAE,KAAK,CAAC,SAAS,KAAK,QAAQ;YACpC,GAAG,EAAE,KAAK,CAAC,SAAS,KAAK,KAAK;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC;gBACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,MAAM,EAAE,IAAI,CAAC,OAAO;aACrB,CAAC,EACF,QAAQ,EAAE,CAAC,EACX,OAAO,EAAE,CAAC,KAAiB,EAAE,EAAE;gBAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACrC,WAAW,EAAE,KAAK;iBACnB,CAAC,CAAC;gBAEH,IAAI,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACjC,KAAK,CAAC,eAAe,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC;YAED,4DACE,KAAK,EAAE;oBACL,MAAM,EAAE,IAAI,CAAC,OAAO;oBACpB,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB;gBAED,8DAAa,CACT;YACN,4DACE,KAAK,EAAE;oBACL,OAAO,EAAE,IAAI;oBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;oBACrD,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,IAEA,IAAI,CAAC,OAAO,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\n\nexport type TabClickDetail = {\n nativeEvent: MouseEvent;\n};\n\n@Component({\n tag: 'ix-tab-item',\n styleUrl: 'tab-item.scss',\n shadow: true,\n})\nexport class TabItem {\n /**\n * Set selected tab\n */\n @Prop() selected = false;\n\n /**\n * Set disabled tab\n */\n @Prop() disabled = false;\n\n /**\n * Set small size tab\n */\n @Prop() small = false;\n\n /**\n * Set icon only tab\n */\n @Prop() icon = false;\n\n /**\n * Set rounded tab\n */\n @Prop() rounded = false;\n\n /**\n * Set counter value\n */\n @Prop() counter: number;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set selected placement\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * Emitted when the tab is clicked.\n *\n * @since 2.0.0\n */\n @Event() tabClick: EventEmitter<TabClickDetail>;\n\n private tabItemClasses(props: {\n selected: boolean;\n disabled: boolean;\n small: boolean;\n icon: boolean;\n circle: boolean;\n layout: 'auto' | 'stretched';\n placement: 'bottom' | 'top';\n }) {\n return {\n selected: props.selected,\n disabled: props.disabled,\n 'small-tab': props.small,\n icon: props.small,\n stretched: props.layout === 'stretched',\n bottom: props.placement === 'bottom',\n top: props.placement === 'top',\n circle: props.circle,\n };\n }\n\n render() {\n return (\n <Host\n class={this.tabItemClasses({\n selected: this.selected,\n disabled: this.disabled,\n small: this.small,\n icon: this.icon,\n layout: this.layout,\n placement: this.placement,\n circle: this.rounded,\n })}\n tabIndex={0}\n onClick={(event: MouseEvent) => {\n const clientEvent = this.tabClick.emit({\n nativeEvent: event,\n });\n\n if (clientEvent.defaultPrevented) {\n event.stopPropagation();\n }\n }}\n >\n <div\n class={{\n circle: this.rounded,\n text: !this.rounded,\n selected: this.selected,\n disabled: this.disabled,\n }}\n >\n <slot></slot>\n </div>\n <div\n class={{\n counter: true,\n selected: this.selected,\n hidden: !(this.rounded && this.counter !== undefined),\n disabled: this.disabled,\n }}\n >\n {this.counter}\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tab-item.js","sourceRoot":"","sources":["../../../src/components/tab-item/tab-item.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAW9E,MAAM,OAAO,OAAO;;wBAIC,KAAK;wBAKL,KAAK;qBAKR,KAAK;oBAKN,KAAK;uBAKF,KAAK;;sBAUgB,MAAM;yBAKP,QAAQ;;IAStC,cAAc,CAAC,KAQtB;QACC,OAAO;YACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,WAAW,EAAE,KAAK,CAAC,KAAK;YACxB,IAAI,EAAE,KAAK,CAAC,KAAK;YACjB,SAAS,EAAE,KAAK,CAAC,MAAM,KAAK,WAAW;YACvC,MAAM,EAAE,KAAK,CAAC,SAAS,KAAK,QAAQ;YACpC,GAAG,EAAE,KAAK,CAAC,SAAS,KAAK,KAAK;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC;gBACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,MAAM,EAAE,IAAI,CAAC,OAAO;aACrB,CAAC,EACF,QAAQ,EAAE,CAAC,EACX,OAAO,EAAE,CAAC,KAAiB,EAAE,EAAE;gBAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACrC,WAAW,EAAE,KAAK;iBACnB,CAAC,CAAC;gBAEH,IAAI,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACjC,KAAK,CAAC,eAAe,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC;YAED,4DACE,KAAK,EAAE;oBACL,MAAM,EAAE,IAAI,CAAC,OAAO;oBACpB,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB;gBAED,8DAAa,CACT;YACN,4DACE,KAAK,EAAE;oBACL,OAAO,EAAE,IAAI;oBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;oBACrD,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBACxB,IAEA,IAAI,CAAC,OAAO,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\n\nexport type TabClickDetail = {\n nativeEvent: MouseEvent;\n};\n\n@Component({\n tag: 'ix-tab-item',\n styleUrl: 'tab-item.scss',\n shadow: true,\n})\nexport class TabItem {\n /**\n * Set selected tab\n */\n @Prop() selected = false;\n\n /**\n * Set disabled tab\n */\n @Prop() disabled = false;\n\n /**\n * Set small size tab\n */\n @Prop() small = false;\n\n /**\n * Set icon only tab\n */\n @Prop() icon = false;\n\n /**\n * Set rounded tab\n */\n @Prop() rounded = false;\n\n /**\n * Set counter value\n */\n @Prop() counter?: number;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set selected placement\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * Emitted when the tab is clicked.\n *\n * @since 2.0.0\n */\n @Event() tabClick!: EventEmitter<TabClickDetail>;\n\n private tabItemClasses(props: {\n selected: boolean;\n disabled: boolean;\n small: boolean;\n icon: boolean;\n circle: boolean;\n layout: 'auto' | 'stretched';\n placement: 'bottom' | 'top';\n }) {\n return {\n selected: props.selected,\n disabled: props.disabled,\n 'small-tab': props.small,\n icon: props.small,\n stretched: props.layout === 'stretched',\n bottom: props.placement === 'bottom',\n top: props.placement === 'top',\n circle: props.circle,\n };\n }\n\n render() {\n return (\n <Host\n class={this.tabItemClasses({\n selected: this.selected,\n disabled: this.disabled,\n small: this.small,\n icon: this.icon,\n layout: this.layout,\n placement: this.placement,\n circle: this.rounded,\n })}\n tabIndex={0}\n onClick={(event: MouseEvent) => {\n const clientEvent = this.tabClick.emit({\n nativeEvent: event,\n });\n\n if (clientEvent.defaultPrevented) {\n event.stopPropagation();\n }\n }}\n >\n <div\n class={{\n circle: this.rounded,\n text: !this.rounded,\n selected: this.selected,\n disabled: this.disabled,\n }}\n >\n <slot></slot>\n </div>\n <div\n class={{\n counter: true,\n selected: this.selected,\n hidden: !(this.rounded && this.counter !== undefined),\n disabled: this.disabled,\n }}\n >\n {this.counter}\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -24,12 +24,8 @@ export class Tabs {
24
24
  this.currentScrollAmount = 0;
25
25
  this.scrollAmount = 100;
26
26
  this.scrollActionAmount = 0;
27
- }
28
- get arrowLeftElement() {
29
- return this.hostElement.shadowRoot.querySelector('[data-arrow-left]');
30
- }
31
- get arrowRightElement() {
32
- return this.hostElement.shadowRoot.querySelector('[data-arrow-right]');
27
+ this.showArrowPrevious = false;
28
+ this.showArrowNext = false;
33
29
  }
34
30
  onWindowResize() {
35
31
  this.totalItems = 0;
@@ -46,13 +42,24 @@ export class Tabs {
46
42
  return this.getTabs()[tabIndex];
47
43
  }
48
44
  getTabsWrapper() {
49
- return this.hostElement.shadowRoot.querySelector('.items-content');
45
+ var _a;
46
+ return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.items-content');
47
+ }
48
+ initResizeObserver() {
49
+ const parentElement = this.hostElement.parentElement;
50
+ if (!parentElement)
51
+ return;
52
+ this.resizeObserver = new ResizeObserver(() => {
53
+ this.renderArrows();
54
+ });
55
+ this.resizeObserver.observe(parentElement);
50
56
  }
51
57
  showArrows() {
52
58
  try {
53
59
  const tabWrapper = this.getTabsWrapper();
54
- return (tabWrapper.scrollWidth >
55
- Math.ceil(tabWrapper.getBoundingClientRect().width) &&
60
+ return (tabWrapper &&
61
+ tabWrapper.scrollWidth >
62
+ Math.ceil(tabWrapper.getBoundingClientRect().width) &&
56
63
  this.layout === 'auto');
57
64
  }
58
65
  catch (error) {
@@ -61,7 +68,7 @@ export class Tabs {
61
68
  }
62
69
  showPreviousArrow() {
63
70
  try {
64
- return this.showArrows() && this.scrollActionAmount < 0;
71
+ return this.showArrows() === true && this.scrollActionAmount < 0;
65
72
  }
66
73
  catch (error) {
67
74
  return false;
@@ -70,8 +77,11 @@ export class Tabs {
70
77
  showNextArrow() {
71
78
  try {
72
79
  const tabWrapper = this.getTabsWrapper();
80
+ if (!tabWrapper) {
81
+ return false;
82
+ }
73
83
  const tabWrapperRect = tabWrapper.getBoundingClientRect();
74
- return (this.showArrows() &&
84
+ return (this.showArrows() === true &&
75
85
  this.scrollActionAmount >
76
86
  (tabWrapper.scrollWidth - tabWrapperRect.width) * -1);
77
87
  }
@@ -79,39 +89,47 @@ export class Tabs {
79
89
  return false;
80
90
  }
81
91
  }
82
- getArrowStyle(condition) {
83
- return {
84
- opacity: condition ? '1' : '0',
85
- zIndex: condition ? '1' : '-1',
86
- };
87
- }
88
92
  move(amount, click = false) {
89
- const tabWrapper = this.getTabsWrapper();
90
- const maxScrollWidth = (tabWrapper.scrollWidth - tabWrapper.getBoundingClientRect().width) * -1;
91
- amount = this.currentScrollAmount + amount;
92
- amount = amount > 0 ? 0 : amount < maxScrollWidth ? maxScrollWidth : amount;
93
+ const tabsWrapper = this.getTabsWrapper();
94
+ if (!tabsWrapper) {
95
+ return;
96
+ }
97
+ const tabsWrapperVisibleWidth = tabsWrapper.getBoundingClientRect().width;
98
+ const maxScrollWidth = -this.currentScrollAmount +
99
+ tabsWrapperVisibleWidth -
100
+ tabsWrapper.scrollWidth;
101
+ amount = amount < maxScrollWidth ? maxScrollWidth : amount;
102
+ amount += this.currentScrollAmount;
103
+ amount = Math.min(amount, 0);
93
104
  const styles = [
94
105
  `transform: translateX(${amount}px);`,
95
106
  click ? 'transition: all ease-in-out 400ms;' : '',
96
107
  ].join('');
97
- tabWrapper.setAttribute('style', styles);
108
+ tabsWrapper.setAttribute('style', styles);
98
109
  if (click)
99
110
  this.currentScrollAmount = this.scrollActionAmount = amount;
100
111
  else
101
112
  this.scrollActionAmount = amount;
102
113
  }
103
- moveTabToView(tabIndex) {
114
+ onSelectedChange(newValue) {
115
+ var _a;
104
116
  if (!this.showArrows())
105
117
  return;
106
- const tab = this.getTab(tabIndex).getBoundingClientRect();
107
- const amount = tab.x * -1;
108
- this.move(amount, true);
118
+ const tabRect = this.getTab(newValue).getBoundingClientRect();
119
+ const wrapperWidth = (_a = this.getTabsWrapper()) === null || _a === void 0 ? void 0 : _a.clientWidth;
120
+ const arrowWidth = 32;
121
+ if (tabRect.left < arrowWidth) {
122
+ this.move(-tabRect.left + arrowWidth, true);
123
+ }
124
+ else if (wrapperWidth && tabRect.right > wrapperWidth - arrowWidth) {
125
+ this.move(wrapperWidth - tabRect.right - arrowWidth, true);
126
+ }
109
127
  }
110
128
  setSelected(index) {
111
129
  this.selected = index;
112
130
  }
113
131
  clickTab(index) {
114
- if (this.dragStop()) {
132
+ if (!this.clickAction.isClick || this.dragStop()) {
115
133
  return;
116
134
  }
117
135
  const { defaultPrevented } = this.selectedChange.emit(index);
@@ -119,7 +137,6 @@ export class Tabs {
119
137
  return;
120
138
  }
121
139
  this.setSelected(index);
122
- this.moveTabToView(index);
123
140
  }
124
141
  dragStart(element, event) {
125
142
  if (!this.showArrows())
@@ -133,18 +150,22 @@ export class Tabs {
133
150
  const tabPositionX = parseFloat(window.getComputedStyle(element).left);
134
151
  const mousedownPositionX = event.clientX;
135
152
  const move = (event) => this.dragMove(event, tabPositionX, mousedownPositionX);
136
- window.addEventListener('mouseup', () => {
153
+ const windowClick = () => {
137
154
  window.removeEventListener('mousemove', move, false);
155
+ window.removeEventListener('click', windowClick, false);
138
156
  this.dragStop();
139
- });
157
+ };
158
+ window.addEventListener('click', windowClick);
140
159
  window.addEventListener('mousemove', move, false);
141
160
  }
142
161
  dragMove(event, tabX, mousedownX) {
143
162
  this.move(event.clientX + tabX - mousedownX);
144
163
  }
145
164
  dragStop() {
146
- clearTimeout(this.clickAction.timeout);
147
- this.clickAction.timeout = null;
165
+ if (this.clickAction.timeout) {
166
+ clearTimeout(this.clickAction.timeout);
167
+ this.clickAction.timeout = null;
168
+ }
148
169
  if (this.clickAction.isClick)
149
170
  return false;
150
171
  this.currentScrollAmount = this.scrollActionAmount;
@@ -162,6 +183,7 @@ export class Tabs {
162
183
  element.setAttribute('selected', index === this.selected ? 'true' : 'false');
163
184
  element.setAttribute('placement', this.placement);
164
185
  });
186
+ this.initResizeObserver();
165
187
  }
166
188
  componentDidRender() {
167
189
  const tabs = this.getTabs();
@@ -171,11 +193,12 @@ export class Tabs {
171
193
  });
172
194
  }
173
195
  componentWillRender() {
196
+ this.renderArrows();
197
+ }
198
+ renderArrows() {
174
199
  requestAnimationFrameNoNgZone(() => {
175
- const showNextArrow = this.showNextArrow();
176
- const previousArrow = this.showPreviousArrow();
177
- Object.assign(this.arrowLeftElement.style, this.getArrowStyle(previousArrow));
178
- Object.assign(this.arrowRightElement.style, this.getArrowStyle(showNextArrow));
200
+ this.showArrowNext = this.showNextArrow();
201
+ this.showArrowPrevious = this.showPreviousArrow();
179
202
  });
180
203
  }
181
204
  componentDidLoad() {
@@ -184,6 +207,10 @@ export class Tabs {
184
207
  element.addEventListener('mousedown', (event) => this.dragStart(element, event));
185
208
  });
186
209
  }
210
+ disconnectedCallback() {
211
+ var _a;
212
+ (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
213
+ }
187
214
  onTabClick(event) {
188
215
  if (event.defaultPrevented) {
189
216
  return;
@@ -197,13 +224,13 @@ export class Tabs {
197
224
  });
198
225
  }
199
226
  render() {
200
- return (h(Host, { key: 'a851dd22c0036611316b4c86dee7683c2cf13367' }, h("div", { key: '3cdc8ce203a7fdcb431bc8514e97e1dc99ccf42f', class: "arrow", "data-arrow-left": true, onClick: () => this.move(this.scrollAmount, true) }, h("ix-icon", { key: 'a9a56482c144ccdfdbcb037ef4a1f3ba87907f59', name: 'chevron-left-small' })), h("div", { key: 'c94814d93009f941f491ee27aab2d1f0a58641ef', class: {
227
+ return (h(Host, { key: '7f56f404c30ce0efd9971b1d5a8d98179c8c0e3b' }, this.showArrowPrevious && (h("div", { key: '5aab91bd6947e5775cac09c3778cb8610aa4f527', class: "arrow", onClick: () => this.move(this.scrollAmount, true) }, h("ix-icon", { key: 'c387a77b0d6c88f288097d33e71b24bacdf5942a', name: 'chevron-left-small' }))), h("div", { key: '9d3d4b218bb482a97a12ed1d3b60a0c0778e148f', class: {
201
228
  'tab-items': true,
202
229
  'overflow-shadow': true,
203
- 'shadow-left': this.showPreviousArrow(),
204
- 'shadow-right': this.showNextArrow(),
205
- 'shadow-both': this.showNextArrow() && this.showPreviousArrow(),
206
- } }, h("div", { key: 'e3b6d3d72736895e294b284e57ded8d225376405', class: "items-content" }, h("slot", { key: '66fad8fbd1c2c599e3614377d0ef917b11653a2c' }))), h("div", { key: '27512bc8fb342ac6247dd69261bdbdab2a8d42dc', class: "arrow right", "data-arrow-right": true, onClick: () => this.move(-this.scrollAmount, true) }, h("ix-icon", { key: '99ab01071111e8fca336712967e7e2c0a8643450', name: 'chevron-right-small' }))));
230
+ 'shadow-left': this.showArrowPrevious,
231
+ 'shadow-right': this.showArrowNext,
232
+ 'shadow-both': this.showArrowNext && this.showArrowPrevious,
233
+ } }, h("div", { key: '3692d6262fa4c6ec31ee7e87b1fb24e9c5dafd85', class: "items-content" }, h("slot", { key: '8c8053f371fcc4b6a2b2a24c8fc45bd5517df874' }))), this.showArrowNext && (h("div", { key: 'ffa28714c41cb40cf9accc96a15a2e28542f7ca2', class: "arrow right", onClick: () => this.move(-this.scrollAmount, true) }, h("ix-icon", { key: 'f048b24c5704ac92311427ae05f23898d3a08ca4', name: 'chevron-right-small' })))));
207
234
  }
208
235
  static get is() { return "ix-tabs"; }
209
236
  static get encapsulation() { return "shadow"; }
@@ -316,7 +343,9 @@ export class Tabs {
316
343
  "totalItems": {},
317
344
  "currentScrollAmount": {},
318
345
  "scrollAmount": {},
319
- "scrollActionAmount": {}
346
+ "scrollActionAmount": {},
347
+ "showArrowPrevious": {},
348
+ "showArrowNext": {}
320
349
  };
321
350
  }
322
351
  static get events() {
@@ -341,6 +370,12 @@ export class Tabs {
341
370
  }];
342
371
  }
343
372
  static get elementRef() { return "hostElement"; }
373
+ static get watchers() {
374
+ return [{
375
+ "propName": "selected",
376
+ "methodName": "onSelectedChange"
377
+ }];
378
+ }
344
379
  static get listeners() {
345
380
  return [{
346
381
  "name": "resize",
@@ -1 +1 @@
1
- {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Prop,\n State,\n} from '@stencil/core';\nimport { requestAnimationFrameNoNgZone } from '../utils/requestAnimationFrame';\n\n@Component({\n tag: 'ix-tabs',\n styleUrl: 'tabs.scss',\n shadow: true,\n})\nexport class Tabs {\n @Element() hostElement!: HTMLIxTabsElement;\n\n /**\n * Set tab items to small size\n */\n @Prop() small = false;\n\n /**\n * Set rounded tabs\n */\n @Prop() rounded = false;\n\n /**\n * Set default selected tab by index\n */\n @Prop({ mutable: true }) selected = 0;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set placement style\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * `selected` property changed\n *\n * @since 2.0.0\n */\n @Event() selectedChange: EventEmitter<number>;\n\n @State() totalItems = 0;\n @State() currentScrollAmount = 0;\n @State() scrollAmount = 100;\n\n @State() scrollActionAmount = 0;\n\n private windowStartSize = window.innerWidth;\n\n private get arrowLeftElement() {\n return this.hostElement.shadowRoot.querySelector(\n '[data-arrow-left]'\n ) as HTMLElement;\n }\n\n private get arrowRightElement() {\n return this.hostElement.shadowRoot.querySelector(\n '[data-arrow-right]'\n ) as HTMLElement;\n }\n\n private clickAction: {\n timeout: NodeJS.Timeout;\n isClick: boolean;\n } = {\n timeout: null,\n isClick: true,\n };\n\n @Listen('resize', { target: 'window' })\n onWindowResize() {\n this.totalItems = 0;\n this.totalItems = this.getTabs().length;\n\n if (this.windowStartSize === 0)\n return (this.windowStartSize = window.innerWidth);\n this.move(this.windowStartSize - window.innerWidth);\n this.windowStartSize = window.innerWidth;\n }\n\n private getTabs() {\n return Array.from(this.hostElement.querySelectorAll('ix-tab-item'));\n }\n\n private getTab(tabIndex: number) {\n return this.getTabs()[tabIndex];\n }\n\n private getTabsWrapper() {\n return this.hostElement.shadowRoot.querySelector('.items-content');\n }\n\n private showArrows() {\n try {\n const tabWrapper = this.getTabsWrapper();\n return (\n tabWrapper.scrollWidth >\n Math.ceil(tabWrapper.getBoundingClientRect().width) &&\n this.layout === 'auto'\n );\n } catch (error) {\n return false;\n }\n }\n\n private showPreviousArrow() {\n try {\n return this.showArrows() && this.scrollActionAmount < 0;\n } catch (error) {\n return false;\n }\n }\n\n private showNextArrow() {\n try {\n const tabWrapper = this.getTabsWrapper();\n const tabWrapperRect = tabWrapper.getBoundingClientRect();\n\n return (\n this.showArrows() &&\n this.scrollActionAmount >\n (tabWrapper.scrollWidth - tabWrapperRect.width) * -1\n );\n } catch (error) {\n return false;\n }\n }\n\n private getArrowStyle(condition: boolean) {\n return {\n opacity: condition ? '1' : '0',\n zIndex: condition ? '1' : '-1',\n };\n }\n\n private move(amount: number, click = false) {\n const tabWrapper = this.getTabsWrapper();\n const maxScrollWidth =\n (tabWrapper.scrollWidth - tabWrapper.getBoundingClientRect().width) * -1;\n\n amount = this.currentScrollAmount + amount;\n amount = amount > 0 ? 0 : amount < maxScrollWidth ? maxScrollWidth : amount;\n\n const styles = [\n `transform: translateX(${amount}px);`,\n click ? 'transition: all ease-in-out 400ms;' : '',\n ].join('');\n\n tabWrapper.setAttribute('style', styles);\n\n if (click) this.currentScrollAmount = this.scrollActionAmount = amount;\n else this.scrollActionAmount = amount;\n }\n\n private moveTabToView(tabIndex: number) {\n if (!this.showArrows()) return;\n\n const tab = this.getTab(tabIndex).getBoundingClientRect();\n const amount = tab.x * -1;\n this.move(amount, true);\n }\n\n private setSelected(index: number) {\n this.selected = index;\n }\n\n private clickTab(index: number) {\n if (this.dragStop()) {\n return;\n }\n\n const { defaultPrevented } = this.selectedChange.emit(index);\n if (defaultPrevented) {\n return;\n }\n\n this.setSelected(index);\n this.moveTabToView(index);\n }\n\n private dragStart(element: HTMLIxTabItemElement, event: MouseEvent) {\n if (!this.showArrows()) return;\n if (event.button > 0) return;\n\n this.clickAction.timeout =\n this.clickAction.timeout === null\n ? setTimeout(() => (this.clickAction.isClick = false), 300)\n : null;\n\n const tabPositionX = parseFloat(window.getComputedStyle(element).left);\n const mousedownPositionX = event.clientX;\n const move = (event: MouseEvent) =>\n this.dragMove(event, tabPositionX, mousedownPositionX);\n\n window.addEventListener('mouseup', () => {\n window.removeEventListener('mousemove', move, false);\n this.dragStop();\n });\n window.addEventListener('mousemove', move, false);\n }\n\n private dragMove(event: MouseEvent, tabX: number, mousedownX: number) {\n this.move(event.clientX + tabX - mousedownX);\n }\n\n private dragStop() {\n clearTimeout(this.clickAction.timeout);\n this.clickAction.timeout = null;\n\n if (this.clickAction.isClick) return false;\n\n this.currentScrollAmount = this.scrollActionAmount;\n this.clickAction.isClick = true;\n\n return true;\n }\n\n componentWillLoad() {\n const tabs = this.getTabs();\n\n tabs.map((element, index) => {\n if (this.small) element.setAttribute('small', 'true');\n\n if (this.rounded) element.setAttribute('rounded', 'true');\n\n element.setAttribute('layout', this.layout);\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n\n element.setAttribute('placement', this.placement);\n });\n }\n\n componentDidRender() {\n const tabs = this.getTabs();\n this.totalItems = tabs.length;\n\n tabs.map((element, index) => {\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n });\n }\n\n componentWillRender() {\n requestAnimationFrameNoNgZone(() => {\n const showNextArrow = this.showNextArrow();\n const previousArrow = this.showPreviousArrow();\n\n Object.assign(\n this.arrowLeftElement.style,\n this.getArrowStyle(previousArrow)\n );\n Object.assign(\n this.arrowRightElement.style,\n this.getArrowStyle(showNextArrow)\n );\n });\n }\n\n componentDidLoad() {\n const tabs = this.getTabs();\n tabs.forEach((element) => {\n element.addEventListener('mousedown', (event) =>\n this.dragStart(element, event)\n );\n });\n }\n\n @Listen('tabClick')\n onTabClick(event: CustomEvent) {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target;\n const tabs = this.getTabs();\n\n tabs.forEach((tab, index) => {\n if (!tab.disabled && tab === target) {\n this.clickTab(index);\n }\n });\n }\n\n render() {\n return (\n <Host>\n <div\n class=\"arrow\"\n data-arrow-left\n onClick={() => this.move(this.scrollAmount, true)}\n >\n <ix-icon name={'chevron-left-small'}></ix-icon>\n </div>\n <div\n class={{\n 'tab-items': true,\n 'overflow-shadow': true,\n 'shadow-left': this.showPreviousArrow(),\n 'shadow-right': this.showNextArrow(),\n 'shadow-both': this.showNextArrow() && this.showPreviousArrow(),\n }}\n >\n <div class=\"items-content\">\n <slot></slot>\n </div>\n </div>\n <div\n class=\"arrow right\"\n data-arrow-right\n onClick={() => this.move(-this.scrollAmount, true)}\n >\n <ix-icon name={'chevron-right-small'}></ix-icon>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport { requestAnimationFrameNoNgZone } from '../utils/requestAnimationFrame';\n\n@Component({\n tag: 'ix-tabs',\n styleUrl: 'tabs.scss',\n shadow: true,\n})\nexport class Tabs {\n @Element() hostElement!: HTMLIxTabsElement;\n\n /**\n * Set tab items to small size\n */\n @Prop() small = false;\n\n /**\n * Set rounded tabs\n */\n @Prop() rounded = false;\n\n /**\n * Set default selected tab by index\n */\n @Prop({ mutable: true }) selected = 0;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set placement style\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * `selected` property changed\n *\n * @since 2.0.0\n */\n @Event() selectedChange!: EventEmitter<number>;\n\n @State() totalItems = 0;\n @State() currentScrollAmount = 0;\n @State() scrollAmount = 100;\n @State() scrollActionAmount = 0;\n @State() showArrowPrevious = false;\n @State() showArrowNext = false;\n\n private windowStartSize = window.innerWidth;\n private resizeObserver?: ResizeObserver;\n\n private clickAction: {\n timeout: NodeJS.Timeout | null;\n isClick: boolean;\n } = {\n timeout: null,\n isClick: true,\n };\n\n @Listen('resize', { target: 'window' })\n onWindowResize() {\n this.totalItems = 0;\n this.totalItems = this.getTabs().length;\n\n if (this.windowStartSize === 0)\n return (this.windowStartSize = window.innerWidth);\n this.move(this.windowStartSize - window.innerWidth);\n this.windowStartSize = window.innerWidth;\n }\n\n private getTabs() {\n return Array.from(this.hostElement.querySelectorAll('ix-tab-item'));\n }\n\n private getTab(tabIndex: number) {\n return this.getTabs()[tabIndex];\n }\n\n private getTabsWrapper() {\n return this.hostElement.shadowRoot?.querySelector('.items-content');\n }\n\n private initResizeObserver() {\n const parentElement = this.hostElement.parentElement;\n if (!parentElement) return;\n this.resizeObserver = new ResizeObserver(() => {\n this.renderArrows();\n });\n this.resizeObserver.observe(parentElement);\n }\n\n private showArrows() {\n try {\n const tabWrapper = this.getTabsWrapper();\n return (\n tabWrapper &&\n tabWrapper.scrollWidth >\n Math.ceil(tabWrapper.getBoundingClientRect().width) &&\n this.layout === 'auto'\n );\n } catch (error) {\n return false;\n }\n }\n\n private showPreviousArrow() {\n try {\n return this.showArrows() === true && this.scrollActionAmount < 0;\n } catch (error) {\n return false;\n }\n }\n\n private showNextArrow() {\n try {\n const tabWrapper = this.getTabsWrapper();\n\n if (!tabWrapper) {\n return false;\n }\n\n const tabWrapperRect = tabWrapper.getBoundingClientRect();\n\n return (\n this.showArrows() === true &&\n this.scrollActionAmount >\n (tabWrapper.scrollWidth - tabWrapperRect.width) * -1\n );\n } catch (error) {\n return false;\n }\n }\n\n private move(amount: number, click = false) {\n const tabsWrapper = this.getTabsWrapper();\n\n if (!tabsWrapper) {\n return;\n }\n\n const tabsWrapperVisibleWidth = tabsWrapper.getBoundingClientRect().width;\n const maxScrollWidth =\n -this.currentScrollAmount +\n tabsWrapperVisibleWidth -\n tabsWrapper.scrollWidth;\n\n amount = amount < maxScrollWidth ? maxScrollWidth : amount;\n amount += this.currentScrollAmount;\n amount = Math.min(amount, 0);\n\n const styles = [\n `transform: translateX(${amount}px);`,\n click ? 'transition: all ease-in-out 400ms;' : '',\n ].join('');\n\n tabsWrapper.setAttribute('style', styles);\n\n if (click) this.currentScrollAmount = this.scrollActionAmount = amount;\n else this.scrollActionAmount = amount;\n }\n\n @Watch('selected')\n onSelectedChange(newValue: number) {\n if (!this.showArrows()) return;\n\n const tabRect = this.getTab(newValue).getBoundingClientRect();\n const wrapperWidth = this.getTabsWrapper()?.clientWidth;\n const arrowWidth = 32;\n\n if (tabRect.left < arrowWidth) {\n this.move(-tabRect.left + arrowWidth, true);\n } else if (wrapperWidth && tabRect.right > wrapperWidth - arrowWidth) {\n this.move(wrapperWidth - tabRect.right - arrowWidth, true);\n }\n }\n\n private setSelected(index: number) {\n this.selected = index;\n }\n\n private clickTab(index: number) {\n if (!this.clickAction.isClick || this.dragStop()) {\n return;\n }\n\n const { defaultPrevented } = this.selectedChange.emit(index);\n if (defaultPrevented) {\n return;\n }\n\n this.setSelected(index);\n }\n\n private dragStart(element: HTMLIxTabItemElement, event: MouseEvent) {\n if (!this.showArrows()) return;\n if (event.button > 0) return;\n\n this.clickAction.timeout =\n this.clickAction.timeout === null\n ? setTimeout(() => (this.clickAction.isClick = false), 300)\n : null;\n\n const tabPositionX = parseFloat(window.getComputedStyle(element).left);\n const mousedownPositionX = event.clientX;\n const move = (event: MouseEvent) =>\n this.dragMove(event, tabPositionX, mousedownPositionX);\n const windowClick = () => {\n window.removeEventListener('mousemove', move, false);\n window.removeEventListener('click', windowClick, false);\n this.dragStop();\n };\n window.addEventListener('click', windowClick);\n window.addEventListener('mousemove', move, false);\n }\n\n private dragMove(event: MouseEvent, tabX: number, mousedownX: number) {\n this.move(event.clientX + tabX - mousedownX);\n }\n\n private dragStop() {\n if (this.clickAction.timeout) {\n clearTimeout(this.clickAction.timeout);\n this.clickAction.timeout = null;\n }\n\n if (this.clickAction.isClick) return false;\n\n this.currentScrollAmount = this.scrollActionAmount;\n this.clickAction.isClick = true;\n\n return true;\n }\n\n componentWillLoad() {\n const tabs = this.getTabs();\n\n tabs.map((element, index) => {\n if (this.small) element.setAttribute('small', 'true');\n\n if (this.rounded) element.setAttribute('rounded', 'true');\n\n element.setAttribute('layout', this.layout);\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n\n element.setAttribute('placement', this.placement);\n });\n\n this.initResizeObserver();\n }\n\n componentDidRender() {\n const tabs = this.getTabs();\n this.totalItems = tabs.length;\n\n tabs.map((element, index) => {\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n });\n }\n\n componentWillRender() {\n this.renderArrows();\n }\n\n private renderArrows() {\n requestAnimationFrameNoNgZone(() => {\n this.showArrowNext = this.showNextArrow();\n this.showArrowPrevious = this.showPreviousArrow();\n });\n }\n\n componentDidLoad() {\n const tabs = this.getTabs();\n tabs.forEach((element) => {\n element.addEventListener('mousedown', (event) =>\n this.dragStart(element, event)\n );\n });\n }\n\n disconnectedCallback() {\n this.resizeObserver?.disconnect();\n }\n\n @Listen('tabClick')\n onTabClick(event: CustomEvent) {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target;\n const tabs = this.getTabs();\n\n tabs.forEach((tab, index) => {\n if (!tab.disabled && tab === target) {\n this.clickTab(index);\n }\n });\n }\n\n render() {\n return (\n <Host>\n {this.showArrowPrevious && (\n <div class=\"arrow\" onClick={() => this.move(this.scrollAmount, true)}>\n <ix-icon name={'chevron-left-small'}></ix-icon>\n </div>\n )}\n <div\n class={{\n 'tab-items': true,\n 'overflow-shadow': true,\n 'shadow-left': this.showArrowPrevious,\n 'shadow-right': this.showArrowNext,\n 'shadow-both': this.showArrowNext && this.showArrowPrevious,\n }}\n >\n <div class=\"items-content\">\n <slot></slot>\n </div>\n </div>\n {this.showArrowNext && (\n <div\n class=\"arrow right\"\n onClick={() => this.move(-this.scrollAmount, true)}\n >\n <ix-icon name={'chevron-right-small'}></ix-icon>\n </div>\n )}\n </Host>\n );\n }\n}\n"]}
@@ -1,13 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
3
- *
4
- * SPDX-License-Identifier: MIT
5
- *
6
- * This source code is licensed under the MIT license found in the
7
- * LICENSE file in the root directory of this source tree.
8
- */
9
- /*
10
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
11
3
  *
12
4
  * SPDX-License-Identifier: MIT
13
5
  *
@@ -81,4 +73,38 @@ test('should not change tab by tabs event', async ({ mount, page }) => {
81
73
  await expect(firstTab).toHaveClass(/selected/);
82
74
  await expect(lastTab).not.toHaveClass(/selected/);
83
75
  });
76
+ test('should update layout on resize', async ({ mount, page }) => {
77
+ await mount(`
78
+ <ix-tabs>
79
+ <ix-tab-item>Item 1</ix-tab-item>
80
+ <ix-tab-item>Item 2</ix-tab-item>
81
+ <ix-tab-item>Item 3</ix-tab-item>
82
+ </ix-tabs>
83
+ `);
84
+ const tabs = page.locator('ix-tabs');
85
+ await page.setViewportSize({ width: 200, height: 100 });
86
+ const arrowNext = tabs.locator('.arrow.right');
87
+ await expect(arrowNext).toBeVisible();
88
+ await page.setViewportSize({ width: 1000, height: 100 });
89
+ await expect(arrowNext).not.toBeVisible();
90
+ });
91
+ test('should scroll selected tab into view', async ({ mount, page }) => {
92
+ await mount(`
93
+ <ix-tabs>
94
+ <ix-tab-item>Item 1</ix-tab-item>
95
+ <ix-tab-item>Item 2</ix-tab-item>
96
+ <ix-tab-item>Item 3</ix-tab-item>
97
+ <ix-tab-item>Item 4</ix-tab-item>
98
+ <ix-tab-item>Item 5</ix-tab-item>
99
+ <ix-tab-item>Item 6</ix-tab-item>
100
+ </ix-tabs>
101
+ `);
102
+ await page.setViewportSize({ width: 300, height: 100 });
103
+ const clickedTab = page.locator('ix-tab-item').nth(3);
104
+ const lastTab = page.locator('ix-tab-item').last();
105
+ await clickedTab.click();
106
+ await page.waitForTimeout(500);
107
+ await expect(clickedTab).toBeInViewport();
108
+ await expect(lastTab).not.toBeInViewport();
109
+ });
84
110
  //# sourceMappingURL=tabs.ct.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tabs.ct.js","sourceRoot":"","sources":["../../../../src/components/tabs/test/tabs.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect } from '@playwright/test';\nimport { test } from '@utils/test';\n\ntest('renders', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const tab = page.locator('ix-tab-item').nth(0);\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(tab).toHaveClass(/selected/);\n});\n\ntest('should change tab', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const tab = page.locator('ix-tab-item').nth(2);\n\n await tab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(tab).toHaveClass(/selected/);\n});\n\ntest('should not change tab by tab click event', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const firstTab = page.locator('ix-tab-item').nth(0);\n const lastTab = page.locator('ix-tab-item').nth(2);\n\n lastTab.evaluate((tabElement) => {\n tabElement.addEventListener('tabClick', (event) => event.preventDefault());\n });\n\n await lastTab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(firstTab).toHaveClass(/selected/);\n await expect(lastTab).not.toHaveClass(/selected/);\n});\n\ntest('should not change tab by tabs event', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const firstTab = page.locator('ix-tab-item').nth(0);\n const lastTab = page.locator('ix-tab-item').nth(2);\n\n tabs.evaluate((tabElement) => {\n tabElement.addEventListener('selectedChange', (event) =>\n event.preventDefault()\n );\n });\n\n await lastTab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(firstTab).toHaveClass(/selected/);\n await expect(lastTab).not.toHaveClass(/selected/);\n});\n"]}
1
+ {"version":3,"file":"tabs.ct.js","sourceRoot":"","sources":["../../../../src/components/tabs/test/tabs.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect } from '@playwright/test';\nimport { test } from '@utils/test';\n\ntest('renders', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const tab = page.locator('ix-tab-item').nth(0);\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(tab).toHaveClass(/selected/);\n});\n\ntest('should change tab', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const tab = page.locator('ix-tab-item').nth(2);\n\n await tab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(tab).toHaveClass(/selected/);\n});\n\ntest('should not change tab by tab click event', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const firstTab = page.locator('ix-tab-item').nth(0);\n const lastTab = page.locator('ix-tab-item').nth(2);\n\n lastTab.evaluate((tabElement) => {\n tabElement.addEventListener('tabClick', (event) => event.preventDefault());\n });\n\n await lastTab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(firstTab).toHaveClass(/selected/);\n await expect(lastTab).not.toHaveClass(/selected/);\n});\n\ntest('should not change tab by tabs event', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n const firstTab = page.locator('ix-tab-item').nth(0);\n const lastTab = page.locator('ix-tab-item').nth(2);\n\n tabs.evaluate((tabElement) => {\n tabElement.addEventListener('selectedChange', (event) =>\n event.preventDefault()\n );\n });\n\n await lastTab.click();\n\n await expect(tabs).toHaveClass(/hydrated/);\n await expect(firstTab).toHaveClass(/selected/);\n await expect(lastTab).not.toHaveClass(/selected/);\n});\n\ntest('should update layout on resize', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n </ix-tabs>\n `);\n const tabs = page.locator('ix-tabs');\n await page.setViewportSize({ width: 200, height: 100 });\n const arrowNext = tabs.locator('.arrow.right');\n await expect(arrowNext).toBeVisible();\n\n await page.setViewportSize({ width: 1000, height: 100 });\n await expect(arrowNext).not.toBeVisible();\n});\n\ntest('should scroll selected tab into view', async ({ mount, page }) => {\n await mount(`\n <ix-tabs>\n <ix-tab-item>Item 1</ix-tab-item>\n <ix-tab-item>Item 2</ix-tab-item>\n <ix-tab-item>Item 3</ix-tab-item>\n <ix-tab-item>Item 4</ix-tab-item>\n <ix-tab-item>Item 5</ix-tab-item>\n <ix-tab-item>Item 6</ix-tab-item>\n </ix-tabs>\n `);\n await page.setViewportSize({ width: 300, height: 100 });\n const clickedTab = page.locator('ix-tab-item').nth(3);\n const lastTab = page.locator('ix-tab-item').last();\n await clickedTab.click();\n await page.waitForTimeout(500);\n await expect(clickedTab).toBeInViewport();\n await expect(lastTab).not.toBeInViewport();\n});\n"]}
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *