@siemens/ix 1.6.2 → 2.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1110) hide show
  1. package/dist/cjs/a11y-fa9abd92.js +82 -0
  2. package/dist/cjs/a11y-fa9abd92.js.map +1 -0
  3. package/dist/cjs/base-button-497db257.js.map +1 -1
  4. package/dist/cjs/context-2ce9a350.js +26 -0
  5. package/dist/cjs/context-2ce9a350.js.map +1 -0
  6. package/dist/cjs/{flip-tile-state-b5ff5ea0.js → flip-tile-state-183236a1.js} +6 -6
  7. package/dist/cjs/{flip-tile-state-b5ff5ea0.js.map → flip-tile-state-183236a1.js.map} +1 -1
  8. package/dist/cjs/{floating-ui.dom.esm-01fe5abe.js → floating-ui.dom.esm-b79b633f.js} +1 -103
  9. package/dist/cjs/floating-ui.dom.esm-b79b633f.js.map +1 -0
  10. package/dist/cjs/{icon-4c954853.js → icon-eeb2940a.js} +2 -2
  11. package/dist/cjs/{icon-4c954853.js.map → icon-eeb2940a.js.map} +1 -1
  12. package/dist/cjs/{index-c978628a.js → index-e56a1d39.js} +77 -21
  13. package/dist/cjs/index-e56a1d39.js.map +1 -0
  14. package/dist/cjs/index.cjs.js +46 -7
  15. package/dist/cjs/index.cjs.js.map +1 -1
  16. package/dist/cjs/ix-action-card.cjs.entry.js +1 -1
  17. package/dist/cjs/ix-animated-tab_2.cjs.entry.js +1 -1
  18. package/dist/cjs/ix-application-header.cjs.entry.js +21 -18
  19. package/dist/cjs/ix-application-header.cjs.entry.js.map +1 -1
  20. package/dist/cjs/ix-avatar.cjs.entry.js +39 -0
  21. package/dist/cjs/ix-avatar.cjs.entry.js.map +1 -0
  22. package/dist/cjs/ix-basic-navigation.cjs.entry.js +13 -15
  23. package/dist/cjs/ix-basic-navigation.cjs.entry.js.map +1 -1
  24. package/dist/cjs/ix-blind.cjs.entry.js +3 -12
  25. package/dist/cjs/ix-blind.cjs.entry.js.map +1 -1
  26. package/dist/cjs/ix-breadcrumb_2.cjs.entry.js +1 -1
  27. package/dist/cjs/ix-burger-menu.cjs.entry.js +7 -3
  28. package/dist/cjs/ix-burger-menu.cjs.entry.js.map +1 -1
  29. package/dist/cjs/ix-button.cjs.entry.js +22 -4
  30. package/dist/cjs/ix-button.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +1 -1
  32. package/dist/cjs/ix-card-list.cjs.entry.js +1 -1
  33. package/dist/cjs/ix-card_2.cjs.entry.js +36 -0
  34. package/dist/cjs/ix-card_2.cjs.entry.js.map +1 -0
  35. package/dist/cjs/ix-category-filter.cjs.entry.js +2 -2
  36. package/dist/cjs/ix-category-filter.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ix-chip.cjs.entry.js +23 -15
  38. package/dist/cjs/ix-chip.cjs.entry.js.map +1 -1
  39. package/dist/cjs/ix-content-header.cjs.entry.js +3 -3
  40. package/dist/cjs/ix-content-header.cjs.entry.js.map +1 -1
  41. package/dist/cjs/ix-css-grid-item.cjs.entry.js +1 -1
  42. package/dist/cjs/ix-css-grid.cjs.entry.js +1 -1
  43. package/dist/cjs/ix-date-picker_2.cjs.entry.js +8 -9
  44. package/dist/cjs/ix-date-picker_2.cjs.entry.js.map +1 -1
  45. package/dist/cjs/ix-date-time-card.cjs.entry.js +2 -3
  46. package/dist/cjs/ix-date-time-card.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ix-datetime-picker.cjs.entry.js +2 -2
  48. package/dist/cjs/ix-datetime-picker.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ix-divider.cjs.entry.js +1 -1
  50. package/dist/cjs/ix-drawer.cjs.entry.js +4 -1
  51. package/dist/cjs/ix-drawer.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ix-dropdown-button.cjs.entry.js +7 -6
  53. package/dist/cjs/ix-dropdown-button.cjs.entry.js.map +1 -1
  54. package/dist/cjs/ix-dropdown-header.cjs.entry.js +22 -0
  55. package/dist/cjs/ix-dropdown-header.cjs.entry.js.map +1 -0
  56. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +1 -1
  57. package/dist/cjs/ix-dropdown_2.cjs.entry.js +67 -33
  58. package/dist/cjs/ix-dropdown_2.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ix-empty-state.cjs.entry.js +1 -1
  60. package/dist/cjs/ix-event-list_2.cjs.entry.js +44 -25
  61. package/dist/cjs/ix-event-list_2.cjs.entry.js.map +1 -1
  62. package/dist/cjs/ix-expanding-search.cjs.entry.js +5 -8
  63. package/dist/cjs/ix-expanding-search.cjs.entry.js.map +1 -1
  64. package/dist/cjs/ix-filter-chip.cjs.entry.js +3 -3
  65. package/dist/cjs/ix-filter-chip.cjs.entry.js.map +1 -1
  66. package/dist/cjs/ix-flip-tile_2.cjs.entry.js +3 -3
  67. package/dist/cjs/ix-flip-tile_2.cjs.entry.js.map +1 -1
  68. package/dist/cjs/ix-group-context-menu.cjs.entry.js +26 -14
  69. package/dist/cjs/ix-group-context-menu.cjs.entry.js.map +1 -1
  70. package/dist/cjs/ix-group_2.cjs.entry.js +159 -0
  71. package/dist/cjs/ix-group_2.cjs.entry.js.map +1 -0
  72. package/dist/cjs/ix-icon-button.cjs.entry.js +26 -5
  73. package/dist/cjs/ix-icon-button.cjs.entry.js.map +1 -1
  74. package/dist/cjs/ix-icon.cjs.entry.js +2 -2
  75. package/dist/cjs/ix-index-button.cjs.entry.js +4 -4
  76. package/dist/cjs/ix-index-button.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ix-input-group.cjs.entry.js +2 -2
  78. package/dist/cjs/ix-input-group.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ix-key-value-list.cjs.entry.js +1 -1
  80. package/dist/cjs/ix-key-value.cjs.entry.js +1 -1
  81. package/dist/cjs/ix-kpi.cjs.entry.js +1 -1
  82. package/dist/cjs/ix-link-button.cjs.entry.js +30 -0
  83. package/dist/cjs/ix-link-button.cjs.entry.js.map +1 -0
  84. package/dist/cjs/ix-map-navigation_2.cjs.entry.js +17 -7
  85. package/dist/cjs/ix-map-navigation_2.cjs.entry.js.map +1 -1
  86. package/dist/cjs/ix-menu-category.cjs.entry.js +138 -0
  87. package/dist/cjs/ix-menu-category.cjs.entry.js.map +1 -0
  88. package/dist/cjs/ix-menu_9.cjs.entry.js +252 -339
  89. package/dist/cjs/ix-menu_9.cjs.entry.js.map +1 -1
  90. package/dist/cjs/ix-message-bar.cjs.entry.js +1 -1
  91. package/dist/cjs/ix-modal-content.cjs.entry.js +21 -0
  92. package/dist/cjs/ix-modal-content.cjs.entry.js.map +1 -0
  93. package/dist/cjs/ix-modal-example.cjs.entry.js +6 -4
  94. package/dist/cjs/ix-modal-example.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ix-modal-footer.cjs.entry.js +21 -0
  96. package/dist/cjs/ix-modal-footer.cjs.entry.js.map +1 -0
  97. package/dist/cjs/ix-modal-header.cjs.entry.js +48 -0
  98. package/dist/cjs/ix-modal-header.cjs.entry.js.map +1 -0
  99. package/dist/cjs/ix-modal-loading.cjs.entry.js +21 -0
  100. package/dist/cjs/ix-modal-loading.cjs.entry.js.map +1 -0
  101. package/dist/cjs/ix-modal.cjs.entry.js +130 -0
  102. package/dist/cjs/ix-modal.cjs.entry.js.map +1 -0
  103. package/dist/cjs/ix-pagination.cjs.entry.js +4 -4
  104. package/dist/cjs/ix-pagination.cjs.entry.js.map +1 -1
  105. package/dist/cjs/ix-pill.cjs.entry.js +28 -10
  106. package/dist/cjs/ix-pill.cjs.entry.js.map +1 -1
  107. package/dist/cjs/ix-push-card.cjs.entry.js +1 -1
  108. package/dist/cjs/ix-select_2.cjs.entry.js +20 -8
  109. package/dist/cjs/ix-select_2.cjs.entry.js.map +1 -1
  110. package/dist/cjs/ix-spinner.cjs.entry.js +10 -3
  111. package/dist/cjs/ix-spinner.cjs.entry.js.map +1 -1
  112. package/dist/cjs/ix-split-button_2.cjs.entry.js +15 -11
  113. package/dist/cjs/ix-split-button_2.cjs.entry.js.map +1 -1
  114. package/dist/cjs/ix-tab-item.cjs.entry.js +2 -2
  115. package/dist/cjs/ix-tab-item.cjs.entry.js.map +1 -1
  116. package/dist/cjs/ix-tabs.cjs.entry.js +14 -6
  117. package/dist/cjs/ix-tabs.cjs.entry.js.map +1 -1
  118. package/dist/cjs/ix-tile.cjs.entry.js +18 -3
  119. package/dist/cjs/ix-tile.cjs.entry.js.map +1 -1
  120. package/dist/cjs/ix-toast_2.cjs.entry.js +6 -7
  121. package/dist/cjs/ix-toast_2.cjs.entry.js.map +1 -1
  122. package/dist/cjs/ix-toggle.cjs.entry.js +11 -30
  123. package/dist/cjs/ix-toggle.cjs.entry.js.map +1 -1
  124. package/dist/cjs/ix-tooltip.cjs.entry.js +2 -2
  125. package/dist/cjs/ix-tree_2.cjs.entry.js +1 -1
  126. package/dist/cjs/ix-typography.cjs.entry.js +46 -0
  127. package/dist/cjs/ix-typography.cjs.entry.js.map +1 -0
  128. package/dist/cjs/ix-upload.cjs.entry.js +19 -7
  129. package/dist/cjs/ix-upload.cjs.entry.js.map +1 -1
  130. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +6 -19
  131. package/dist/cjs/ix-validation-tooltip.cjs.entry.js.map +1 -1
  132. package/dist/cjs/ix-workflow-step_2.cjs.entry.js +14 -18
  133. package/dist/cjs/ix-workflow-step_2.cjs.entry.js.map +1 -1
  134. package/dist/cjs/loader.cjs.js +2 -2
  135. package/dist/cjs/menu-service-d1b87142.js +80 -0
  136. package/dist/cjs/menu-service-d1b87142.js.map +1 -0
  137. package/dist/cjs/modal-26ae4715.js +253 -0
  138. package/dist/cjs/modal-26ae4715.js.map +1 -0
  139. package/dist/cjs/my-component.cjs.entry.js +1 -1
  140. package/dist/cjs/my-component.cjs.entry.js.map +1 -1
  141. package/dist/cjs/service-0e27b06b.js +145 -0
  142. package/dist/cjs/service-0e27b06b.js.map +1 -0
  143. package/dist/cjs/shadow-dom-f9b90696.js +21 -0
  144. package/dist/cjs/shadow-dom-f9b90696.js.map +1 -0
  145. package/dist/cjs/siemens-ix.cjs.js +2 -2
  146. package/dist/collection/collection-manifest.json +18 -20
  147. package/dist/collection/components/application-header/application-header.css +2 -2
  148. package/dist/collection/components/application-header/application-header.js +43 -16
  149. package/dist/collection/components/application-header/application-header.js.map +1 -1
  150. package/dist/collection/components/avatar/avatar.css +70 -0
  151. package/dist/collection/components/avatar/avatar.js +80 -0
  152. package/dist/collection/components/avatar/avatar.js.map +1 -0
  153. package/dist/collection/components/basic-navigation/basic-navigation.css +32 -4
  154. package/dist/collection/components/basic-navigation/basic-navigation.js +11 -13
  155. package/dist/collection/components/basic-navigation/basic-navigation.js.map +1 -1
  156. package/dist/collection/components/button/base-button.js.map +1 -1
  157. package/dist/collection/components/button/button.css +31 -2
  158. package/dist/collection/components/button/button.js +60 -4
  159. package/dist/collection/components/button/button.js.map +1 -1
  160. package/dist/collection/components/button/test/button.ct.js +36 -0
  161. package/dist/collection/components/button/test/button.ct.js.map +1 -0
  162. package/dist/collection/components/category-filter/category-filter.js +1 -1
  163. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  164. package/dist/collection/components/chip/chip.css +149 -149
  165. package/dist/collection/components/chip/chip.js +22 -14
  166. package/dist/collection/components/chip/chip.js.map +1 -1
  167. package/dist/collection/components/content-header/content-header.js +4 -4
  168. package/dist/collection/components/content-header/content-header.js.map +1 -1
  169. package/dist/collection/components/date-picker/date-picker.css +12 -2
  170. package/dist/collection/components/date-picker/date-picker.js +4 -4
  171. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  172. package/dist/collection/components/date-time-card/date-time-card.css +28 -8
  173. package/dist/collection/components/date-time-card/date-time-card.js +1 -2
  174. package/dist/collection/components/date-time-card/date-time-card.js.map +1 -1
  175. package/dist/collection/components/datetime-picker/datetime-picker.css +16 -6
  176. package/dist/collection/components/datetime-picker/datetime-picker.js +1 -1
  177. package/dist/collection/components/datetime-picker/datetime-picker.js.map +1 -1
  178. package/dist/collection/components/drawer/drawer.js +3 -0
  179. package/dist/collection/components/drawer/drawer.js.map +1 -1
  180. package/dist/collection/components/drawer/test/drawer.ct.js +47 -0
  181. package/dist/collection/components/drawer/test/drawer.ct.js.map +1 -0
  182. package/dist/collection/components/dropdown/dropdown.css +16 -471
  183. package/dist/collection/components/dropdown/dropdown.js +77 -63
  184. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  185. package/dist/collection/components/dropdown/placement.js.map +1 -1
  186. package/dist/collection/components/dropdown-button/dropdown-button.css +16 -2
  187. package/dist/collection/components/dropdown-button/dropdown-button.js +13 -9
  188. package/dist/collection/components/dropdown-button/dropdown-button.js.map +1 -1
  189. package/dist/collection/components/dropdown-header/dropdown-header.css +32 -0
  190. package/dist/collection/components/{group-dropdown-item/group-dropdown-item.js → dropdown-header/dropdown-header.js} +11 -26
  191. package/dist/collection/components/dropdown-header/dropdown-header.js.map +1 -0
  192. package/dist/collection/components/dropdown-item/dropdown-item.css +85 -37
  193. package/dist/collection/components/dropdown-item/dropdown-item.js +57 -12
  194. package/dist/collection/components/dropdown-item/dropdown-item.js.map +1 -1
  195. package/dist/collection/components/event-list/event-list.css +20 -35
  196. package/dist/collection/components/event-list/event-list.js +35 -16
  197. package/dist/collection/components/event-list/event-list.js.map +1 -1
  198. package/dist/collection/components/event-list-item/event-list-item.css +62 -35
  199. package/dist/collection/components/event-list-item/event-list-item.js +17 -10
  200. package/dist/collection/components/event-list-item/event-list-item.js.map +1 -1
  201. package/dist/collection/components/expanding-search/expanding-search.css +262 -8
  202. package/dist/collection/components/expanding-search/expanding-search.js +4 -7
  203. package/dist/collection/components/expanding-search/expanding-search.js.map +1 -1
  204. package/dist/collection/components/expanding-search/test/expanding-search.ct.js +56 -0
  205. package/dist/collection/components/expanding-search/test/expanding-search.ct.js.map +1 -0
  206. package/dist/collection/components/filter-chip/filter-chip.css +39 -26
  207. package/dist/collection/components/filter-chip/filter-chip.js +2 -2
  208. package/dist/collection/components/filter-chip/filter-chip.js.map +1 -1
  209. package/dist/collection/components/flip-tile/flip-tile-state.js +5 -5
  210. package/dist/collection/components/flip-tile/flip-tile-state.js.map +1 -1
  211. package/dist/collection/components/flip-tile/flip-tile.js +1 -1
  212. package/dist/collection/components/flip-tile/flip-tile.js.map +1 -1
  213. package/dist/collection/components/group/group-context-menu.css +2 -3
  214. package/dist/collection/components/group/group-context-menu.js +27 -15
  215. package/dist/collection/components/group/group-context-menu.js.map +1 -1
  216. package/dist/collection/components/group/group.css +6 -0
  217. package/dist/collection/components/group/group.js +29 -48
  218. package/dist/collection/components/group/group.js.map +1 -1
  219. package/dist/collection/components/group-item/group-item.css +59 -33
  220. package/dist/collection/components/group-item/group-item.js +2 -2
  221. package/dist/collection/components/group-item/group-item.js.map +1 -1
  222. package/dist/collection/components/icon-button/icon-button.css +34 -3
  223. package/dist/collection/components/icon-button/icon-button.js +52 -7
  224. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  225. package/dist/collection/components/icon-button/test/icon-button.ct.js +26 -0
  226. package/dist/collection/components/icon-button/test/icon-button.ct.js.map +1 -0
  227. package/dist/collection/components/index-button/index-button.js +5 -5
  228. package/dist/collection/components/index-button/index-button.js.map +1 -1
  229. package/dist/collection/components/input-group/input-group.css +2 -0
  230. package/dist/collection/components/link-button/link-button.css +440 -0
  231. package/dist/collection/components/link-button/link-button.js +98 -0
  232. package/dist/collection/components/link-button/link-button.js.map +1 -0
  233. package/dist/collection/components/map-navigation/map-navigation.css +17 -1
  234. package/dist/collection/components/map-navigation/map-navigation.js +18 -7
  235. package/dist/collection/components/map-navigation/map-navigation.js.map +1 -1
  236. package/dist/collection/components/menu/burger-menu.css +388 -5
  237. package/dist/collection/components/menu/burger-menu.js +42 -2
  238. package/dist/collection/components/menu/burger-menu.js.map +1 -1
  239. package/dist/collection/components/menu/menu.css +1727 -24
  240. package/dist/collection/components/menu/menu.js +319 -335
  241. package/dist/collection/components/menu/menu.js.map +1 -1
  242. package/dist/collection/components/menu/test/menu.ct.js +164 -0
  243. package/dist/collection/components/menu/test/menu.ct.js.map +1 -0
  244. package/dist/collection/components/menu-about/menu-about.js +8 -7
  245. package/dist/collection/components/menu-about/menu-about.js.map +1 -1
  246. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  247. package/dist/collection/components/menu-about-item/menu-about-item.js.map +1 -1
  248. package/dist/collection/components/menu-about-news/menu-about-news.css +21 -6
  249. package/dist/collection/components/menu-about-news/menu-about-news.js +3 -3
  250. package/dist/collection/components/menu-about-news/menu-about-news.js.map +1 -1
  251. package/dist/collection/components/menu-avatar/menu-avatar.css +13 -1
  252. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -9
  253. package/dist/collection/components/menu-avatar/menu-avatar.js.map +1 -1
  254. package/dist/collection/components/menu-avatar-item/menu-avatar-item.css +13 -1
  255. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +2 -2
  256. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js.map +1 -1
  257. package/dist/collection/components/menu-category/menu-category.css +63 -0
  258. package/dist/collection/components/menu-category/menu-category.js +212 -0
  259. package/dist/collection/components/menu-category/menu-category.js.map +1 -0
  260. package/dist/collection/components/menu-category/test/menu-category.ct.js +107 -0
  261. package/dist/collection/components/menu-category/test/menu-category.ct.js.map +1 -0
  262. package/dist/collection/components/menu-item/menu-item.css +6 -10
  263. package/dist/collection/components/menu-item/menu-item.js +40 -7
  264. package/dist/collection/components/menu-item/menu-item.js.map +1 -1
  265. package/dist/collection/components/menu-settings/menu-settings.css +13 -0
  266. package/dist/collection/components/menu-settings/menu-settings.js +9 -8
  267. package/dist/collection/components/menu-settings/menu-settings.js.map +1 -1
  268. package/dist/collection/components/menu-settings-item/menu-settings-item.css +0 -1
  269. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  270. package/dist/collection/components/menu-settings-item/menu-settings-item.js.map +1 -1
  271. package/dist/collection/components/modal/modal.css +58 -75
  272. package/dist/collection/components/modal/modal.js +143 -312
  273. package/dist/collection/components/modal/modal.js.map +1 -1
  274. package/dist/collection/components/modal-content/modal-content.css +27 -0
  275. package/dist/collection/components/modal-content/modal-content.js +30 -0
  276. package/dist/collection/components/modal-content/modal-content.js.map +1 -0
  277. package/dist/collection/components/modal-footer/modal-footer.css +30 -0
  278. package/dist/collection/components/modal-footer/modal-footer.js +30 -0
  279. package/dist/collection/components/modal-footer/modal-footer.js.map +1 -0
  280. package/dist/collection/components/modal-header/modal-header.css +34 -0
  281. package/dist/collection/components/modal-header/modal-header.js +139 -0
  282. package/dist/collection/components/modal-header/modal-header.js.map +1 -0
  283. package/dist/collection/components/modal-loading/modal-loading.css +22 -0
  284. package/dist/collection/components/modal-loading/modal-loading.js +30 -0
  285. package/dist/collection/components/modal-loading/modal-loading.js.map +1 -0
  286. package/dist/collection/components/my-component/example-modal.js +1 -1
  287. package/dist/collection/components/my-component/example-modal.js.map +1 -1
  288. package/dist/collection/components/my-component/my-component.js.map +1 -1
  289. package/dist/collection/components/pagination/pagination.js +3 -3
  290. package/dist/collection/components/pagination/pagination.js.map +1 -1
  291. package/dist/collection/components/pill/pill.css +102 -166
  292. package/dist/collection/components/pill/pill.js +27 -9
  293. package/dist/collection/components/pill/pill.js.map +1 -1
  294. package/dist/collection/components/select/select.css +4 -1
  295. package/dist/collection/components/select/select.js +32 -5
  296. package/dist/collection/components/select/select.js.map +1 -1
  297. package/dist/collection/components/select/test/select.ct.js +115 -0
  298. package/dist/collection/components/select/test/select.ct.js.map +1 -0
  299. package/dist/collection/components/select-item/select-item.css +12 -0
  300. package/dist/collection/components/select-item/select-item.js +3 -1
  301. package/dist/collection/components/select-item/select-item.js.map +1 -1
  302. package/dist/collection/components/spinner/spinner.css +428 -23
  303. package/dist/collection/components/spinner/spinner.js +33 -5
  304. package/dist/collection/components/spinner/spinner.js.map +1 -1
  305. package/dist/collection/components/split-button/split-button.css +40 -2
  306. package/dist/collection/components/split-button/split-button.js +18 -35
  307. package/dist/collection/components/split-button/split-button.js.map +1 -1
  308. package/dist/collection/components/split-button-item/split-button-item.css +1 -1
  309. package/dist/collection/components/split-button-item/split-button-item.js +2 -2
  310. package/dist/collection/components/split-button-item/split-button-item.js.map +1 -1
  311. package/dist/collection/components/tab-item/tab-item.css +115 -82
  312. package/dist/collection/components/tab-item/tab-item.js +1 -0
  313. package/dist/collection/components/tab-item/tab-item.js.map +1 -1
  314. package/dist/collection/components/tabs/tabs.css +37 -19
  315. package/dist/collection/components/tabs/tabs.js +13 -4
  316. package/dist/collection/components/tabs/tabs.js.map +1 -1
  317. package/dist/collection/components/tile/tile.css +57 -27
  318. package/dist/collection/components/tile/tile.js +23 -2
  319. package/dist/collection/components/tile/tile.js.map +1 -1
  320. package/dist/collection/components/time-picker/time-picker.css +253 -30
  321. package/dist/collection/components/time-picker/time-picker.js +3 -4
  322. package/dist/collection/components/time-picker/time-picker.js.map +1 -1
  323. package/dist/collection/components/toast/toast-container.js +2 -3
  324. package/dist/collection/components/toast/toast-container.js.map +1 -1
  325. package/dist/collection/components/toast/toast.css +37 -0
  326. package/dist/collection/components/toast/toast.js +5 -5
  327. package/dist/collection/components/toast/toast.js.map +1 -1
  328. package/dist/collection/components/toggle/test/toggle.ct.js +52 -0
  329. package/dist/collection/components/toggle/test/toggle.ct.js.map +1 -0
  330. package/dist/collection/components/toggle/toggle.css +72 -153
  331. package/dist/collection/components/toggle/toggle.js +11 -60
  332. package/dist/collection/components/toggle/toggle.js.map +1 -1
  333. package/dist/collection/components/typography/typography.css +53 -14
  334. package/dist/collection/components/typography/typography.js +2 -2
  335. package/dist/collection/components/typography/typography.js.map +1 -1
  336. package/dist/collection/components/upload/upload.css +24 -3
  337. package/dist/collection/components/upload/upload.js +18 -6
  338. package/dist/collection/components/upload/upload.js.map +1 -1
  339. package/dist/collection/components/utils/a11y.js +66 -0
  340. package/dist/collection/components/utils/a11y.js.map +1 -1
  341. package/dist/collection/components/utils/delegate.js +29 -0
  342. package/dist/collection/components/utils/delegate.js.map +1 -0
  343. package/dist/collection/components/utils/menu-service/menu-service.js +25 -0
  344. package/dist/collection/components/utils/menu-service/menu-service.js.map +1 -1
  345. package/dist/collection/components/{modal-container/modal-container.css → utils/modal/index.js} +4 -6
  346. package/dist/collection/components/utils/modal/index.js.map +1 -0
  347. package/dist/collection/components/utils/modal/loading.js +35 -0
  348. package/dist/collection/components/utils/modal/loading.js.map +1 -0
  349. package/dist/collection/components/utils/modal/message.js +138 -0
  350. package/dist/collection/components/utils/modal/message.js.map +1 -0
  351. package/dist/collection/components/utils/modal/modal.js +77 -0
  352. package/dist/collection/components/utils/modal/modal.js.map +1 -0
  353. package/dist/collection/components/utils/screen/context.js +4 -0
  354. package/dist/collection/components/utils/screen/context.js.map +1 -1
  355. package/dist/collection/components/utils/screen/mode.js +57 -9
  356. package/dist/collection/components/utils/screen/mode.js.map +1 -1
  357. package/dist/collection/components/utils/screen/service.js +26 -4
  358. package/dist/collection/components/utils/screen/service.js.map +1 -1
  359. package/dist/collection/components/utils/shadow-dom.js +19 -0
  360. package/dist/collection/components/utils/shadow-dom.js.map +1 -0
  361. package/dist/collection/components/validation-tooltip/validation-tooltip.js +29 -12
  362. package/dist/collection/components/validation-tooltip/validation-tooltip.js.map +1 -1
  363. package/dist/collection/components/workflow-step/workflow-step.css +13 -0
  364. package/dist/collection/components/workflow-step/workflow-step.js +3 -12
  365. package/dist/collection/components/workflow-step/workflow-step.js.map +1 -1
  366. package/dist/collection/components/workflow-steps/workflow-steps.css +13 -0
  367. package/dist/collection/components/workflow-steps/workflow-steps.js +19 -14
  368. package/dist/collection/components/workflow-steps/workflow-steps.js.map +1 -1
  369. package/dist/collection/index.js +2 -1
  370. package/dist/collection/index.js.map +1 -1
  371. package/dist/collection/tests/utils/test/page.js +12 -5
  372. package/dist/collection/tests/utils/test/page.js.map +1 -1
  373. package/dist/components/a11y.js +79 -0
  374. package/dist/components/a11y.js.map +1 -0
  375. package/dist/components/application-header.js +40 -18
  376. package/dist/components/application-header.js.map +1 -1
  377. package/dist/components/avatar.js +53 -0
  378. package/dist/components/avatar.js.map +1 -0
  379. package/dist/components/base-button.js.map +1 -1
  380. package/dist/components/burger-menu.js +28 -4
  381. package/dist/components/burger-menu.js.map +1 -1
  382. package/dist/components/button.js +37 -5
  383. package/dist/components/button.js.map +1 -1
  384. package/dist/components/context.js +22 -0
  385. package/dist/components/context.js.map +1 -0
  386. package/dist/components/date-picker.js +22 -15
  387. package/dist/components/date-picker.js.map +1 -1
  388. package/dist/components/date-time-card.js +3 -3
  389. package/dist/components/date-time-card.js.map +1 -1
  390. package/dist/components/divider.js +32 -0
  391. package/dist/components/divider.js.map +1 -0
  392. package/dist/components/dropdown-item.js +21 -13
  393. package/dist/components/dropdown-item.js.map +1 -1
  394. package/dist/components/dropdown.js +50 -22
  395. package/dist/components/dropdown.js.map +1 -1
  396. package/dist/components/filter-chip.js +18 -5
  397. package/dist/components/filter-chip.js.map +1 -1
  398. package/dist/components/flip-tile-state.js +5 -5
  399. package/dist/components/flip-tile-state.js.map +1 -1
  400. package/dist/components/floating-ui.dom.esm.js +1 -102
  401. package/dist/components/floating-ui.dom.esm.js.map +1 -1
  402. package/dist/components/group-context-menu.js +52 -19
  403. package/dist/components/group-context-menu.js.map +1 -1
  404. package/dist/components/group-item.js +4 -3
  405. package/dist/components/group-item.js.map +1 -1
  406. package/dist/components/icon-button.js +35 -7
  407. package/dist/components/icon-button.js.map +1 -1
  408. package/dist/components/index-button.js +3 -3
  409. package/dist/components/index-button.js.map +1 -1
  410. package/dist/components/index.js +37 -2
  411. package/dist/components/index.js.map +1 -1
  412. package/dist/components/{ix-group-dropdown-item.d.ts → ix-avatar.d.ts} +4 -4
  413. package/dist/components/ix-avatar.js +8 -0
  414. package/dist/components/ix-avatar.js.map +1 -0
  415. package/dist/components/ix-basic-navigation.js +35 -18
  416. package/dist/components/ix-basic-navigation.js.map +1 -1
  417. package/dist/components/ix-blind.js +1 -10
  418. package/dist/components/ix-blind.js.map +1 -1
  419. package/dist/components/ix-card-list.js +16 -10
  420. package/dist/components/ix-card-list.js.map +1 -1
  421. package/dist/components/ix-category-filter.js +15 -9
  422. package/dist/components/ix-category-filter.js.map +1 -1
  423. package/dist/components/ix-chip.js +38 -17
  424. package/dist/components/ix-chip.js.map +1 -1
  425. package/dist/components/ix-content-header.js +12 -6
  426. package/dist/components/ix-content-header.js.map +1 -1
  427. package/dist/components/ix-datetime-picker.js +21 -14
  428. package/dist/components/ix-datetime-picker.js.map +1 -1
  429. package/dist/components/ix-divider.js +1 -28
  430. package/dist/components/ix-divider.js.map +1 -1
  431. package/dist/components/ix-drawer.js +13 -4
  432. package/dist/components/ix-drawer.js.map +1 -1
  433. package/dist/components/ix-dropdown-button.js +22 -14
  434. package/dist/components/ix-dropdown-button.js.map +1 -1
  435. package/dist/components/{ix-modal-container.d.ts → ix-dropdown-header.d.ts} +4 -4
  436. package/dist/components/ix-dropdown-header.js +44 -0
  437. package/dist/components/ix-dropdown-header.js.map +1 -0
  438. package/dist/components/ix-empty-state.js +10 -4
  439. package/dist/components/ix-empty-state.js.map +1 -1
  440. package/dist/components/ix-event-list-item.js +21 -11
  441. package/dist/components/ix-event-list-item.js.map +1 -1
  442. package/dist/components/ix-event-list.js +34 -17
  443. package/dist/components/ix-event-list.js.map +1 -1
  444. package/dist/components/ix-expanding-search.js +16 -12
  445. package/dist/components/ix-expanding-search.js.map +1 -1
  446. package/dist/components/ix-flip-tile.js +11 -5
  447. package/dist/components/ix-flip-tile.js.map +1 -1
  448. package/dist/components/ix-group.js +50 -49
  449. package/dist/components/ix-group.js.map +1 -1
  450. package/dist/components/ix-input-group.js +1 -1
  451. package/dist/components/ix-input-group.js.map +1 -1
  452. package/dist/components/ix-link-button.d.ts +11 -0
  453. package/dist/components/ix-link-button.js +54 -0
  454. package/dist/components/ix-link-button.js.map +1 -0
  455. package/dist/components/ix-map-navigation.js +35 -17
  456. package/dist/components/ix-map-navigation.js.map +1 -1
  457. package/dist/components/ix-menu-about-item.js +3 -2
  458. package/dist/components/ix-menu-about-item.js.map +1 -1
  459. package/dist/components/ix-menu-about-news.js +27 -8
  460. package/dist/components/ix-menu-about-news.js.map +1 -1
  461. package/dist/components/ix-menu-about.js +18 -10
  462. package/dist/components/ix-menu-about.js.map +1 -1
  463. package/dist/components/ix-menu-avatar.js +11 -19
  464. package/dist/components/ix-menu-avatar.js.map +1 -1
  465. package/dist/components/ix-menu-category.d.ts +11 -0
  466. package/dist/components/ix-menu-category.js +196 -0
  467. package/dist/components/ix-menu-category.js.map +1 -0
  468. package/dist/components/ix-menu-settings-item.js +3 -2
  469. package/dist/components/ix-menu-settings-item.js.map +1 -1
  470. package/dist/components/ix-menu-settings.js +19 -11
  471. package/dist/components/ix-menu-settings.js.map +1 -1
  472. package/dist/components/ix-menu.js +238 -315
  473. package/dist/components/ix-menu.js.map +1 -1
  474. package/dist/components/ix-message-bar.js +10 -4
  475. package/dist/components/ix-message-bar.js.map +1 -1
  476. package/dist/components/ix-modal-content.d.ts +11 -0
  477. package/dist/components/ix-modal-content.js +35 -0
  478. package/dist/components/ix-modal-content.js.map +1 -0
  479. package/dist/components/ix-modal-example.js +10 -15
  480. package/dist/components/ix-modal-example.js.map +1 -1
  481. package/dist/components/{ix-counter-pill.d.ts → ix-modal-footer.d.ts} +4 -4
  482. package/dist/components/ix-modal-footer.js +35 -0
  483. package/dist/components/ix-modal-footer.js.map +1 -0
  484. package/dist/components/ix-modal-header.d.ts +11 -0
  485. package/dist/components/ix-modal-header.js +90 -0
  486. package/dist/components/ix-modal-header.js.map +1 -0
  487. package/dist/components/ix-modal-loading.d.ts +11 -0
  488. package/dist/components/ix-modal-loading.js +41 -0
  489. package/dist/components/ix-modal-loading.js.map +1 -0
  490. package/dist/components/ix-modal.js +148 -1
  491. package/dist/components/ix-modal.js.map +1 -1
  492. package/dist/components/ix-pagination.js +25 -19
  493. package/dist/components/ix-pagination.js.map +1 -1
  494. package/dist/components/ix-pill.js +29 -10
  495. package/dist/components/ix-pill.js.map +1 -1
  496. package/dist/components/ix-split-button-item.js +4 -3
  497. package/dist/components/ix-split-button-item.js.map +1 -1
  498. package/dist/components/ix-split-button.js +36 -14
  499. package/dist/components/ix-split-button.js.map +1 -1
  500. package/dist/components/ix-tile.js +22 -4
  501. package/dist/components/ix-tile.js.map +1 -1
  502. package/dist/components/ix-toast-container.js +12 -6
  503. package/dist/components/ix-toast-container.js.map +1 -1
  504. package/dist/components/ix-toggle.js +15 -34
  505. package/dist/components/ix-toggle.js.map +1 -1
  506. package/dist/components/ix-upload.js +28 -10
  507. package/dist/components/ix-upload.js.map +1 -1
  508. package/dist/components/ix-validation-tooltip.js +6 -18
  509. package/dist/components/ix-validation-tooltip.js.map +1 -1
  510. package/dist/components/ix-workflow-step.js +6 -5
  511. package/dist/components/ix-workflow-step.js.map +1 -1
  512. package/dist/components/ix-workflow-steps.js +13 -16
  513. package/dist/components/ix-workflow-steps.js.map +1 -1
  514. package/dist/components/map-navigation-overlay.js +10 -4
  515. package/dist/components/map-navigation-overlay.js.map +1 -1
  516. package/dist/components/menu-avatar-item.js +3 -2
  517. package/dist/components/menu-avatar-item.js.map +1 -1
  518. package/dist/components/menu-item.js +17 -3
  519. package/dist/components/menu-item.js.map +1 -1
  520. package/dist/components/menu-service.js +78 -0
  521. package/dist/components/menu-service.js.map +1 -0
  522. package/dist/components/modal.js +225 -165
  523. package/dist/components/modal.js.map +1 -1
  524. package/dist/components/my-component.js.map +1 -1
  525. package/dist/components/select-item.js +4 -2
  526. package/dist/components/select-item.js.map +1 -1
  527. package/dist/components/select.js +33 -17
  528. package/dist/components/select.js.map +1 -1
  529. package/dist/components/service.js +83 -81
  530. package/dist/components/service.js.map +1 -1
  531. package/dist/components/spinner.js +11 -3
  532. package/dist/components/spinner.js.map +1 -1
  533. package/dist/components/tab-item.js +3 -2
  534. package/dist/components/tab-item.js.map +1 -1
  535. package/dist/components/tabs.js +22 -7
  536. package/dist/components/tabs.js.map +1 -1
  537. package/dist/components/time-picker.js +19 -13
  538. package/dist/components/time-picker.js.map +1 -1
  539. package/dist/components/toast.js +17 -10
  540. package/dist/components/toast.js.map +1 -1
  541. package/dist/components/typography.js +3 -3
  542. package/dist/components/typography.js.map +1 -1
  543. package/dist/esm/a11y-aa83c2d1.js +79 -0
  544. package/dist/esm/a11y-aa83c2d1.js.map +1 -0
  545. package/dist/esm/base-button-5bfeb71c.js.map +1 -1
  546. package/dist/esm/context-381170ae.js +22 -0
  547. package/dist/esm/context-381170ae.js.map +1 -0
  548. package/dist/esm/{flip-tile-state-051bb2fd.js → flip-tile-state-db31345f.js} +6 -6
  549. package/dist/esm/{flip-tile-state-051bb2fd.js.map → flip-tile-state-db31345f.js.map} +1 -1
  550. package/dist/esm/{floating-ui.dom.esm-3130eda0.js → floating-ui.dom.esm-9b203a02.js} +2 -103
  551. package/dist/esm/floating-ui.dom.esm-9b203a02.js.map +1 -0
  552. package/dist/esm/{icon-c659fc0f.js → icon-4ac90a6d.js} +2 -2
  553. package/dist/esm/{icon-c659fc0f.js.map → icon-4ac90a6d.js.map} +1 -1
  554. package/dist/esm/{index-8ddfb6d8.js → index-7334ee80.js} +77 -22
  555. package/dist/esm/index-7334ee80.js.map +1 -0
  556. package/dist/esm/index.js +40 -5
  557. package/dist/esm/index.js.map +1 -1
  558. package/dist/esm/ix-action-card.entry.js +1 -1
  559. package/dist/esm/ix-animated-tab_2.entry.js +1 -1
  560. package/dist/esm/ix-application-header.entry.js +20 -17
  561. package/dist/esm/ix-application-header.entry.js.map +1 -1
  562. package/dist/esm/ix-avatar.entry.js +35 -0
  563. package/dist/esm/ix-avatar.entry.js.map +1 -0
  564. package/dist/esm/ix-basic-navigation.entry.js +13 -15
  565. package/dist/esm/ix-basic-navigation.entry.js.map +1 -1
  566. package/dist/esm/ix-blind.entry.js +2 -11
  567. package/dist/esm/ix-blind.entry.js.map +1 -1
  568. package/dist/esm/ix-breadcrumb_2.entry.js +1 -1
  569. package/dist/esm/ix-burger-menu.entry.js +7 -3
  570. package/dist/esm/ix-burger-menu.entry.js.map +1 -1
  571. package/dist/esm/ix-button.entry.js +22 -4
  572. package/dist/esm/ix-button.entry.js.map +1 -1
  573. package/dist/esm/ix-card-accordion_2.entry.js +1 -1
  574. package/dist/esm/ix-card-list.entry.js +1 -1
  575. package/dist/esm/ix-card_2.entry.js +31 -0
  576. package/dist/esm/ix-card_2.entry.js.map +1 -0
  577. package/dist/esm/ix-category-filter.entry.js +2 -2
  578. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  579. package/dist/esm/ix-chip.entry.js +23 -15
  580. package/dist/esm/ix-chip.entry.js.map +1 -1
  581. package/dist/esm/ix-content-header.entry.js +3 -3
  582. package/dist/esm/ix-content-header.entry.js.map +1 -1
  583. package/dist/esm/ix-css-grid-item.entry.js +1 -1
  584. package/dist/esm/ix-css-grid.entry.js +1 -1
  585. package/dist/esm/ix-date-picker_2.entry.js +8 -9
  586. package/dist/esm/ix-date-picker_2.entry.js.map +1 -1
  587. package/dist/esm/ix-date-time-card.entry.js +2 -3
  588. package/dist/esm/ix-date-time-card.entry.js.map +1 -1
  589. package/dist/esm/ix-datetime-picker.entry.js +2 -2
  590. package/dist/esm/ix-datetime-picker.entry.js.map +1 -1
  591. package/dist/esm/ix-divider.entry.js +1 -1
  592. package/dist/esm/ix-drawer.entry.js +4 -1
  593. package/dist/esm/ix-drawer.entry.js.map +1 -1
  594. package/dist/esm/ix-dropdown-button.entry.js +7 -6
  595. package/dist/esm/ix-dropdown-button.entry.js.map +1 -1
  596. package/dist/esm/ix-dropdown-header.entry.js +18 -0
  597. package/dist/esm/ix-dropdown-header.entry.js.map +1 -0
  598. package/dist/esm/ix-dropdown-quick-actions.entry.js +1 -1
  599. package/dist/esm/ix-dropdown_2.entry.js +67 -33
  600. package/dist/esm/ix-dropdown_2.entry.js.map +1 -1
  601. package/dist/esm/ix-empty-state.entry.js +1 -1
  602. package/dist/esm/ix-event-list_2.entry.js +44 -25
  603. package/dist/esm/ix-event-list_2.entry.js.map +1 -1
  604. package/dist/esm/ix-expanding-search.entry.js +5 -8
  605. package/dist/esm/ix-expanding-search.entry.js.map +1 -1
  606. package/dist/esm/ix-filter-chip.entry.js +3 -3
  607. package/dist/esm/ix-filter-chip.entry.js.map +1 -1
  608. package/dist/esm/ix-flip-tile_2.entry.js +3 -3
  609. package/dist/esm/ix-flip-tile_2.entry.js.map +1 -1
  610. package/dist/esm/ix-group-context-menu.entry.js +26 -14
  611. package/dist/esm/ix-group-context-menu.entry.js.map +1 -1
  612. package/dist/esm/ix-group_2.entry.js +154 -0
  613. package/dist/esm/ix-group_2.entry.js.map +1 -0
  614. package/dist/esm/ix-icon-button.entry.js +26 -5
  615. package/dist/esm/ix-icon-button.entry.js.map +1 -1
  616. package/dist/esm/ix-icon.entry.js +2 -2
  617. package/dist/esm/ix-index-button.entry.js +4 -4
  618. package/dist/esm/ix-index-button.entry.js.map +1 -1
  619. package/dist/esm/ix-input-group.entry.js +2 -2
  620. package/dist/esm/ix-input-group.entry.js.map +1 -1
  621. package/dist/esm/ix-key-value-list.entry.js +1 -1
  622. package/dist/esm/ix-key-value.entry.js +1 -1
  623. package/dist/esm/ix-kpi.entry.js +1 -1
  624. package/dist/esm/ix-link-button.entry.js +26 -0
  625. package/dist/esm/ix-link-button.entry.js.map +1 -0
  626. package/dist/esm/ix-map-navigation_2.entry.js +17 -7
  627. package/dist/esm/ix-map-navigation_2.entry.js.map +1 -1
  628. package/dist/esm/ix-menu-category.entry.js +134 -0
  629. package/dist/esm/ix-menu-category.entry.js.map +1 -0
  630. package/dist/esm/ix-menu_9.entry.js +251 -338
  631. package/dist/esm/ix-menu_9.entry.js.map +1 -1
  632. package/dist/esm/ix-message-bar.entry.js +1 -1
  633. package/dist/esm/ix-modal-content.entry.js +17 -0
  634. package/dist/esm/ix-modal-content.entry.js.map +1 -0
  635. package/dist/esm/ix-modal-example.entry.js +4 -2
  636. package/dist/esm/ix-modal-example.entry.js.map +1 -1
  637. package/dist/esm/ix-modal-footer.entry.js +17 -0
  638. package/dist/esm/ix-modal-footer.entry.js.map +1 -0
  639. package/dist/esm/ix-modal-header.entry.js +44 -0
  640. package/dist/esm/ix-modal-header.entry.js.map +1 -0
  641. package/dist/esm/ix-modal-loading.entry.js +17 -0
  642. package/dist/esm/ix-modal-loading.entry.js.map +1 -0
  643. package/dist/esm/ix-modal.entry.js +126 -0
  644. package/dist/esm/ix-modal.entry.js.map +1 -0
  645. package/dist/esm/ix-pagination.entry.js +4 -4
  646. package/dist/esm/ix-pagination.entry.js.map +1 -1
  647. package/dist/esm/ix-pill.entry.js +28 -10
  648. package/dist/esm/ix-pill.entry.js.map +1 -1
  649. package/dist/esm/ix-push-card.entry.js +1 -1
  650. package/dist/esm/ix-select_2.entry.js +20 -8
  651. package/dist/esm/ix-select_2.entry.js.map +1 -1
  652. package/dist/esm/ix-spinner.entry.js +10 -3
  653. package/dist/esm/ix-spinner.entry.js.map +1 -1
  654. package/dist/esm/ix-split-button_2.entry.js +15 -11
  655. package/dist/esm/ix-split-button_2.entry.js.map +1 -1
  656. package/dist/esm/ix-tab-item.entry.js +2 -2
  657. package/dist/esm/ix-tab-item.entry.js.map +1 -1
  658. package/dist/esm/ix-tabs.entry.js +14 -6
  659. package/dist/esm/ix-tabs.entry.js.map +1 -1
  660. package/dist/esm/ix-tile.entry.js +18 -3
  661. package/dist/esm/ix-tile.entry.js.map +1 -1
  662. package/dist/esm/ix-toast_2.entry.js +6 -7
  663. package/dist/esm/ix-toast_2.entry.js.map +1 -1
  664. package/dist/esm/ix-toggle.entry.js +11 -30
  665. package/dist/esm/ix-toggle.entry.js.map +1 -1
  666. package/dist/esm/ix-tooltip.entry.js +2 -2
  667. package/dist/esm/ix-tree_2.entry.js +1 -1
  668. package/dist/esm/ix-typography.entry.js +42 -0
  669. package/dist/esm/ix-typography.entry.js.map +1 -0
  670. package/dist/esm/ix-upload.entry.js +19 -7
  671. package/dist/esm/ix-upload.entry.js.map +1 -1
  672. package/dist/esm/ix-validation-tooltip.entry.js +6 -19
  673. package/dist/esm/ix-validation-tooltip.entry.js.map +1 -1
  674. package/dist/esm/ix-workflow-step_2.entry.js +14 -18
  675. package/dist/esm/ix-workflow-step_2.entry.js.map +1 -1
  676. package/dist/esm/loader.js +3 -3
  677. package/dist/esm/menu-service-b3076949.js +78 -0
  678. package/dist/esm/menu-service-b3076949.js.map +1 -0
  679. package/dist/esm/modal-68c6d3f6.js +245 -0
  680. package/dist/esm/modal-68c6d3f6.js.map +1 -0
  681. package/dist/esm/my-component.entry.js +1 -1
  682. package/dist/esm/my-component.entry.js.map +1 -1
  683. package/dist/esm/service-586129b5.js +143 -0
  684. package/dist/esm/service-586129b5.js.map +1 -0
  685. package/dist/esm/shadow-dom-6860b1c4.js +18 -0
  686. package/dist/esm/shadow-dom-6860b1c4.js.map +1 -0
  687. package/dist/esm/siemens-ix.js +3 -3
  688. package/dist/siemens-ix/index.esm.js +1 -1
  689. package/dist/siemens-ix/index.esm.js.map +1 -1
  690. package/dist/siemens-ix/{p-d848739e.entry.js → p-00f74fc9.entry.js} +2 -2
  691. package/dist/siemens-ix/p-01c37ebe.entry.js +2 -0
  692. package/dist/siemens-ix/p-01c37ebe.entry.js.map +1 -0
  693. package/dist/siemens-ix/{p-6acce5c9.entry.js → p-02f01e39.entry.js} +2 -2
  694. package/dist/siemens-ix/p-0574cf88.entry.js +2 -0
  695. package/dist/siemens-ix/p-0574cf88.entry.js.map +1 -0
  696. package/dist/siemens-ix/p-06603826.entry.js +2 -0
  697. package/dist/siemens-ix/p-06603826.entry.js.map +1 -0
  698. package/dist/siemens-ix/p-06fcaee3.entry.js +2 -0
  699. package/dist/siemens-ix/p-06fcaee3.entry.js.map +1 -0
  700. package/dist/siemens-ix/{p-07c932da.entry.js → p-07a0b330.entry.js} +2 -2
  701. package/dist/siemens-ix/{p-3f4a9e1f.entry.js → p-09ce5f12.entry.js} +2 -2
  702. package/dist/siemens-ix/p-0b71cde4.js +2 -0
  703. package/dist/siemens-ix/p-0b71cde4.js.map +1 -0
  704. package/dist/siemens-ix/{p-f74c7692.entry.js → p-0c9ead45.entry.js} +2 -2
  705. package/dist/siemens-ix/{p-f74c7692.entry.js.map → p-0c9ead45.entry.js.map} +1 -1
  706. package/dist/siemens-ix/p-0dea55bf.entry.js +2 -0
  707. package/dist/siemens-ix/p-0dea55bf.entry.js.map +1 -0
  708. package/dist/siemens-ix/p-0e86b47b.entry.js +2 -0
  709. package/dist/siemens-ix/p-0e86b47b.entry.js.map +1 -0
  710. package/dist/siemens-ix/{p-13bda5ea.entry.js → p-0fab8cae.entry.js} +2 -2
  711. package/dist/siemens-ix/p-157f7ec0.entry.js +2 -0
  712. package/dist/siemens-ix/p-157f7ec0.entry.js.map +1 -0
  713. package/dist/siemens-ix/p-15996fa7.entry.js +2 -0
  714. package/dist/siemens-ix/p-15996fa7.entry.js.map +1 -0
  715. package/dist/siemens-ix/p-1b1bc523.entry.js +2 -0
  716. package/dist/siemens-ix/p-1b1bc523.entry.js.map +1 -0
  717. package/dist/siemens-ix/p-1b227e9a.js +2 -0
  718. package/dist/siemens-ix/{p-15bebd8a.js.map → p-1b227e9a.js.map} +1 -1
  719. package/dist/siemens-ix/{p-003e9355.entry.js → p-20aa7350.entry.js} +2 -2
  720. package/dist/siemens-ix/p-2ea3d53a.entry.js +2 -0
  721. package/dist/siemens-ix/p-2ea3d53a.entry.js.map +1 -0
  722. package/dist/siemens-ix/p-303b8c2f.entry.js +2 -0
  723. package/dist/siemens-ix/p-303b8c2f.entry.js.map +1 -0
  724. package/dist/siemens-ix/{p-f6ae45fb.entry.js → p-33670e98.entry.js} +2 -2
  725. package/dist/siemens-ix/p-34633470.entry.js +2 -0
  726. package/dist/siemens-ix/p-34633470.entry.js.map +1 -0
  727. package/dist/siemens-ix/{p-3ec2368b.entry.js → p-34807901.entry.js} +2 -2
  728. package/dist/siemens-ix/{p-3ec2368b.entry.js.map → p-34807901.entry.js.map} +1 -1
  729. package/dist/siemens-ix/p-38e69215.entry.js +2 -0
  730. package/dist/siemens-ix/p-38e69215.entry.js.map +1 -0
  731. package/dist/siemens-ix/p-3a99b0c8.entry.js +2 -0
  732. package/dist/siemens-ix/p-3a99b0c8.entry.js.map +1 -0
  733. package/dist/siemens-ix/p-45738e84.js +2 -0
  734. package/dist/siemens-ix/p-45738e84.js.map +1 -0
  735. package/dist/siemens-ix/{p-a89a1fa5.entry.js → p-4d194d55.entry.js} +2 -2
  736. package/dist/siemens-ix/{p-652ba2c1.entry.js → p-56a27b34.entry.js} +2 -2
  737. package/dist/siemens-ix/{p-652ba2c1.entry.js.map → p-56a27b34.entry.js.map} +1 -1
  738. package/dist/siemens-ix/p-5b39e04e.js.map +1 -1
  739. package/dist/siemens-ix/p-5fedb19b.entry.js +2 -0
  740. package/dist/siemens-ix/p-5fedb19b.entry.js.map +1 -0
  741. package/dist/siemens-ix/p-627148db.entry.js +2 -0
  742. package/dist/siemens-ix/p-627148db.entry.js.map +1 -0
  743. package/dist/siemens-ix/p-62f4db99.entry.js +2 -0
  744. package/dist/siemens-ix/p-62f4db99.entry.js.map +1 -0
  745. package/dist/siemens-ix/{p-626fbee2.entry.js → p-63b82e40.entry.js} +2 -2
  746. package/dist/siemens-ix/{p-626fbee2.entry.js.map → p-63b82e40.entry.js.map} +1 -1
  747. package/dist/siemens-ix/p-68c44614.entry.js +2 -0
  748. package/dist/siemens-ix/p-68c44614.entry.js.map +1 -0
  749. package/dist/siemens-ix/p-7021c2d1.entry.js +2 -0
  750. package/dist/siemens-ix/p-7021c2d1.entry.js.map +1 -0
  751. package/dist/siemens-ix/{p-d2225fc2.entry.js → p-709d38fe.entry.js} +2 -2
  752. package/dist/siemens-ix/p-785726e8.entry.js +2 -0
  753. package/dist/siemens-ix/p-785726e8.entry.js.map +1 -0
  754. package/dist/siemens-ix/p-7d2aec76.entry.js +2 -0
  755. package/dist/siemens-ix/{p-f207e578.entry.js.map → p-7d2aec76.entry.js.map} +1 -1
  756. package/dist/siemens-ix/{p-1331a920.entry.js → p-81333042.entry.js} +2 -2
  757. package/dist/siemens-ix/p-8c14a4a3.entry.js +2 -0
  758. package/dist/siemens-ix/p-8c14a4a3.entry.js.map +1 -0
  759. package/dist/siemens-ix/p-8ce73af1.entry.js +2 -0
  760. package/dist/siemens-ix/p-8ce73af1.entry.js.map +1 -0
  761. package/dist/siemens-ix/{p-85f01dba.entry.js → p-904aa275.entry.js} +2 -2
  762. package/dist/siemens-ix/{p-cd3cfc78.entry.js → p-918450cd.entry.js} +2 -2
  763. package/dist/siemens-ix/p-9547706d.entry.js +2 -0
  764. package/dist/siemens-ix/p-9547706d.entry.js.map +1 -0
  765. package/dist/siemens-ix/p-9903e755.entry.js +2 -0
  766. package/dist/siemens-ix/p-9903e755.entry.js.map +1 -0
  767. package/dist/siemens-ix/p-9c030990.js +2 -0
  768. package/dist/siemens-ix/p-9c030990.js.map +1 -0
  769. package/dist/siemens-ix/p-9d264ca8.entry.js +2 -0
  770. package/dist/siemens-ix/p-9d264ca8.entry.js.map +1 -0
  771. package/dist/siemens-ix/p-a64d88de.entry.js +2 -0
  772. package/dist/siemens-ix/p-a64d88de.entry.js.map +1 -0
  773. package/dist/siemens-ix/p-a8e8a942.entry.js +2 -0
  774. package/dist/siemens-ix/p-a8e8a942.entry.js.map +1 -0
  775. package/dist/siemens-ix/p-a9619a92.entry.js +2 -0
  776. package/dist/siemens-ix/p-a9619a92.entry.js.map +1 -0
  777. package/dist/siemens-ix/{p-a7212f01.entry.js → p-b21bc31c.entry.js} +2 -2
  778. package/dist/siemens-ix/p-b6d52b6f.entry.js +2 -0
  779. package/dist/siemens-ix/p-b6d52b6f.entry.js.map +1 -0
  780. package/dist/siemens-ix/{p-6c033b08.entry.js → p-b89172b4.entry.js} +2 -2
  781. package/dist/siemens-ix/p-b899b25b.js +3 -0
  782. package/dist/siemens-ix/p-b899b25b.js.map +1 -0
  783. package/dist/siemens-ix/p-bf019e35.entry.js +2 -0
  784. package/dist/siemens-ix/p-bf019e35.entry.js.map +1 -0
  785. package/dist/siemens-ix/p-c0345859.entry.js +2 -0
  786. package/dist/siemens-ix/p-c0345859.entry.js.map +1 -0
  787. package/dist/siemens-ix/{p-55b54a81.entry.js → p-c4ea8815.entry.js} +2 -2
  788. package/dist/siemens-ix/p-c4ea8815.entry.js.map +1 -0
  789. package/dist/siemens-ix/p-c84a43ef.entry.js +2 -0
  790. package/dist/siemens-ix/p-c84a43ef.entry.js.map +1 -0
  791. package/dist/siemens-ix/p-d0a8aa6f.entry.js +2 -0
  792. package/dist/siemens-ix/p-d43bf856.js +2 -0
  793. package/dist/siemens-ix/p-d43bf856.js.map +1 -0
  794. package/dist/siemens-ix/{p-b60bd26c.entry.js → p-d48d74af.entry.js} +2 -2
  795. package/dist/siemens-ix/{p-b60bd26c.entry.js.map → p-d48d74af.entry.js.map} +1 -1
  796. package/dist/siemens-ix/p-d737ad96.js +2 -0
  797. package/dist/siemens-ix/p-d737ad96.js.map +1 -0
  798. package/dist/siemens-ix/p-d7e8417d.entry.js +2 -0
  799. package/dist/siemens-ix/p-d7e8417d.entry.js.map +1 -0
  800. package/dist/siemens-ix/p-d81d0f62.entry.js +2 -0
  801. package/dist/siemens-ix/p-d81d0f62.entry.js.map +1 -0
  802. package/dist/siemens-ix/p-d991a3d6.entry.js +2 -0
  803. package/dist/siemens-ix/p-d991a3d6.entry.js.map +1 -0
  804. package/dist/siemens-ix/{p-b1db27a3.js → p-db74796e.js} +2 -2
  805. package/dist/siemens-ix/p-dbca4dd5.entry.js +2 -0
  806. package/dist/siemens-ix/p-dbca4dd5.entry.js.map +1 -0
  807. package/dist/siemens-ix/p-e1c92dcb.entry.js +2 -0
  808. package/dist/siemens-ix/p-e1c92dcb.entry.js.map +1 -0
  809. package/dist/siemens-ix/p-e275814e.js +2 -0
  810. package/dist/siemens-ix/p-e275814e.js.map +1 -0
  811. package/dist/siemens-ix/p-e3db25ef.entry.js +2 -0
  812. package/dist/siemens-ix/p-e3db25ef.entry.js.map +1 -0
  813. package/dist/siemens-ix/p-e8f2e141.entry.js +2 -0
  814. package/dist/siemens-ix/p-e8f2e141.entry.js.map +1 -0
  815. package/dist/siemens-ix/p-eca0b89c.entry.js +2 -0
  816. package/dist/siemens-ix/p-eca0b89c.entry.js.map +1 -0
  817. package/dist/siemens-ix/p-ef73f7e3.entry.js +2 -0
  818. package/dist/siemens-ix/p-ef73f7e3.entry.js.map +1 -0
  819. package/dist/siemens-ix/{p-bd24f35f.entry.js → p-f0219d7a.entry.js} +2 -2
  820. package/dist/siemens-ix/p-f22423c2.js +2 -0
  821. package/dist/siemens-ix/p-f22423c2.js.map +1 -0
  822. package/dist/siemens-ix/{p-1e8ee4af.entry.js → p-f38e7420.entry.js} +2 -2
  823. package/dist/siemens-ix/p-f4d634f5.entry.js +2 -0
  824. package/dist/siemens-ix/p-f4d634f5.entry.js.map +1 -0
  825. package/dist/siemens-ix/{p-94ab7c1c.entry.js → p-fafe1aeb.entry.js} +2 -2
  826. package/dist/siemens-ix/{p-94ab7c1c.entry.js.map → p-fafe1aeb.entry.js.map} +1 -1
  827. package/dist/siemens-ix/p-fe073f2a.entry.js +2 -0
  828. package/dist/siemens-ix/p-fe073f2a.entry.js.map +1 -0
  829. package/dist/siemens-ix/{p-6124d173.entry.js → p-ff17104c.entry.js} +2 -2
  830. package/dist/siemens-ix/siemens-ix-core.css +12289 -0
  831. package/dist/siemens-ix/siemens-ix.css +941 -875
  832. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  833. package/dist/siemens-ix/siemens-ix.esm.js.map +1 -1
  834. package/dist/siemens-ix/theme/classic-dark.css +1062 -0
  835. package/dist/siemens-ix/theme/classic-light.css +1062 -0
  836. package/dist/siemens-ix/theme/legacy-classic-dark.css +1061 -0
  837. package/dist/siemens-ix/theme/legacy-classic-light.css +1061 -0
  838. package/dist/types/components/application-header/application-header.d.ts +5 -1
  839. package/dist/types/components/avatar/avatar.d.ts +17 -0
  840. package/dist/types/components/basic-navigation/basic-navigation.d.ts +2 -3
  841. package/dist/types/components/button/base-button.d.ts +2 -1
  842. package/dist/types/components/button/button.d.ts +18 -1
  843. package/dist/types/components/button/test/button.ct.d.ts +1 -0
  844. package/dist/types/components/content-header/content-header.d.ts +1 -1
  845. package/dist/types/components/date-time-card/date-time-card.d.ts +0 -1
  846. package/dist/types/components/drawer/drawer.d.ts +1 -0
  847. package/dist/types/components/drawer/test/drawer.ct.d.ts +1 -0
  848. package/dist/types/components/dropdown/dropdown.d.ts +10 -13
  849. package/dist/types/components/dropdown/placement.d.ts +3 -4
  850. package/dist/types/components/dropdown-button/dropdown-button.d.ts +3 -1
  851. package/dist/types/components/dropdown-header/dropdown-header.d.ts +10 -0
  852. package/dist/types/components/dropdown-item/dropdown-item.d.ts +9 -0
  853. package/dist/types/components/event-list/event-list.d.ts +3 -1
  854. package/dist/types/components/event-list-item/event-list-item.d.ts +4 -2
  855. package/dist/types/components/expanding-search/test/expanding-search.ct.d.ts +1 -0
  856. package/dist/types/components/flip-tile/flip-tile-state.d.ts +5 -5
  857. package/dist/types/components/group/group-context-menu.d.ts +3 -4
  858. package/dist/types/components/group/group.d.ts +7 -8
  859. package/dist/types/components/icon-button/icon-button.d.ts +16 -1
  860. package/dist/types/components/icon-button/test/icon-button.ct.d.ts +1 -0
  861. package/dist/types/components/link-button/link-button.d.ts +20 -0
  862. package/dist/types/components/map-navigation/map-navigation.d.ts +3 -1
  863. package/dist/types/components/menu/burger-menu.d.ts +9 -1
  864. package/dist/types/components/menu/menu.d.ts +45 -34
  865. package/dist/types/components/menu/test/menu.ct.d.ts +1 -0
  866. package/dist/types/components/menu-about/menu-about.d.ts +4 -1
  867. package/dist/types/components/menu-category/menu-category.d.ts +37 -0
  868. package/dist/types/components/menu-category/test/menu-category.ct.d.ts +1 -0
  869. package/dist/types/components/menu-item/menu-item.d.ts +9 -2
  870. package/dist/types/components/menu-settings/menu-settings.d.ts +4 -1
  871. package/dist/types/components/modal/modal.d.ts +35 -66
  872. package/dist/types/components/modal-content/modal-content.d.ts +6 -0
  873. package/dist/types/components/modal-footer/modal-footer.d.ts +6 -0
  874. package/dist/types/components/modal-header/modal-header.d.ts +28 -0
  875. package/dist/types/components/modal-loading/modal-loading.d.ts +6 -0
  876. package/dist/types/components/select/select.d.ts +9 -1
  877. package/dist/types/components/select/test/select.ct.d.ts +1 -0
  878. package/dist/types/components/spinner/spinner.d.ts +7 -2
  879. package/dist/types/components/split-button/split-button.d.ts +3 -9
  880. package/dist/types/components/tile/tile.d.ts +5 -0
  881. package/dist/types/components/time-picker/time-picker.d.ts +0 -1
  882. package/dist/types/components/toast/toast-container.d.ts +0 -1
  883. package/dist/types/components/toast/toast.d.ts +1 -1
  884. package/dist/types/components/toggle/test/toggle.ct.d.ts +1 -0
  885. package/dist/types/components/toggle/toggle.d.ts +3 -10
  886. package/dist/types/components/utils/a11y.d.ts +7 -0
  887. package/dist/types/components/utils/delegate.d.ts +15 -0
  888. package/dist/types/components/utils/menu-service/menu-service.d.ts +3 -0
  889. package/dist/types/components/utils/modal/index.d.ts +3 -0
  890. package/dist/types/components/utils/modal/loading.d.ts +4 -0
  891. package/dist/types/components/utils/modal/message.d.ts +41 -0
  892. package/dist/types/components/utils/modal/modal.d.ts +25 -0
  893. package/dist/types/components/utils/screen/context.d.ts +1 -0
  894. package/dist/types/components/utils/screen/mode.d.ts +5 -2
  895. package/dist/types/components/utils/screen/service.d.ts +5 -0
  896. package/dist/types/components/utils/shadow-dom.d.ts +3 -0
  897. package/dist/types/components/validation-tooltip/validation-tooltip.d.ts +8 -2
  898. package/dist/types/components/workflow-step/workflow-step.d.ts +1 -1
  899. package/dist/types/components/workflow-steps/workflow-steps.d.ts +1 -1
  900. package/dist/types/components.d.ts +466 -265
  901. package/dist/types/index.d.ts +2 -1
  902. package/package.json +7 -6
  903. package/scss/components/_buttons.scss +4 -0
  904. package/scss/components/_dropdown.scss +1 -0
  905. package/scss/components/_forms.scss +1 -0
  906. package/scss/components/_links.scss +24 -0
  907. package/scss/ix-core.scss +84 -0
  908. package/scss/mixins/_hover.scss +32 -0
  909. package/{dist/collection/components/group-dropdown-item/group-dropdown-item.css → scss/mixins/shadow-dom/_host-disabled.scss} +6 -3
  910. package/scss/mixins/shadow-dom/_hover.scss +26 -0
  911. package/scss/theme/classic-dark/_borderRadius.scss +5 -5
  912. package/scss/theme/classic-dark/_borderWidth.scss +5 -5
  913. package/scss/theme/classic-dark/_boxShadow.scss +7 -7
  914. package/scss/theme/classic-dark/_color.scss +423 -418
  915. package/scss/theme/classic-dark/_other.scss +4 -4
  916. package/scss/theme/classic-dark/_sizing.scss +1 -1
  917. package/scss/theme/classic-light/_borderRadius.scss +4 -4
  918. package/scss/theme/classic-light/_borderWidth.scss +5 -5
  919. package/scss/theme/classic-light/_boxShadow.scss +7 -7
  920. package/scss/theme/classic-light/_color.scss +420 -415
  921. package/scss/theme/classic-light/_other.scss +4 -4
  922. package/scss/theme/classic-light/_sizing.scss +1 -1
  923. package/scss/theme/legacy-classic-dark/_border.scss +35 -0
  924. package/scss/theme/legacy-classic-dark/_borderRadius.scss +24 -0
  925. package/scss/theme/legacy-classic-dark/_borderWidth.scss +18 -0
  926. package/scss/theme/legacy-classic-dark/_boxShadow.scss +19 -0
  927. package/scss/theme/legacy-classic-dark/_color.scss +864 -0
  928. package/scss/theme/legacy-classic-dark/_fontFamilies.scss +8 -0
  929. package/scss/theme/legacy-classic-dark/_fontSizes.scss +13 -0
  930. package/scss/theme/legacy-classic-dark/_fontWeights.scss +9 -0
  931. package/scss/theme/legacy-classic-dark/_index.scss +16 -0
  932. package/scss/theme/legacy-classic-dark/_lineHeights.scss +18 -0
  933. package/scss/theme/legacy-classic-dark/_other.scss +16 -0
  934. package/scss/theme/legacy-classic-dark/_sizing.scss +16 -0
  935. package/scss/theme/legacy-classic-dark/_spacing.scss +9 -0
  936. package/scss/theme/legacy-classic-dark/_typography.scss +23 -0
  937. package/scss/theme/legacy-classic-light/_border.scss +35 -0
  938. package/scss/theme/legacy-classic-light/_borderRadius.scss +24 -0
  939. package/scss/theme/legacy-classic-light/_borderWidth.scss +18 -0
  940. package/scss/theme/legacy-classic-light/_boxShadow.scss +19 -0
  941. package/scss/theme/legacy-classic-light/_color.scss +864 -0
  942. package/scss/theme/legacy-classic-light/_fontFamilies.scss +8 -0
  943. package/scss/theme/legacy-classic-light/_fontSizes.scss +13 -0
  944. package/scss/theme/legacy-classic-light/_fontWeights.scss +9 -0
  945. package/scss/theme/legacy-classic-light/_index.scss +16 -0
  946. package/scss/theme/legacy-classic-light/_lineHeights.scss +18 -0
  947. package/scss/theme/legacy-classic-light/_other.scss +16 -0
  948. package/scss/theme/legacy-classic-light/_sizing.scss +16 -0
  949. package/scss/theme/legacy-classic-light/_spacing.scss +9 -0
  950. package/scss/theme/legacy-classic-light/_typography.scss +23 -0
  951. package/dist/cjs/context-a0900b95.js +0 -77
  952. package/dist/cjs/context-a0900b95.js.map +0 -1
  953. package/dist/cjs/floating-ui.dom.esm-01fe5abe.js.map +0 -1
  954. package/dist/cjs/index-c978628a.js.map +0 -1
  955. package/dist/cjs/ix-card_3.cjs.entry.js +0 -74
  956. package/dist/cjs/ix-card_3.cjs.entry.js.map +0 -1
  957. package/dist/cjs/ix-counter-pill.cjs.entry.js +0 -35
  958. package/dist/cjs/ix-counter-pill.cjs.entry.js.map +0 -1
  959. package/dist/cjs/ix-group_3.cjs.entry.js +0 -181
  960. package/dist/cjs/ix-group_3.cjs.entry.js.map +0 -1
  961. package/dist/cjs/ix-modal_2.cjs.entry.js +0 -227
  962. package/dist/cjs/ix-modal_2.cjs.entry.js.map +0 -1
  963. package/dist/cjs/modal-utils-b645989b.js +0 -44
  964. package/dist/cjs/modal-utils-b645989b.js.map +0 -1
  965. package/dist/cjs/service-18dc5907.js +0 -75
  966. package/dist/cjs/service-18dc5907.js.map +0 -1
  967. package/dist/collection/components/counter-pill/counter-pill.css +0 -323
  968. package/dist/collection/components/counter-pill/counter-pill.js +0 -135
  969. package/dist/collection/components/counter-pill/counter-pill.js.map +0 -1
  970. package/dist/collection/components/dropdown/alignment.js +0 -10
  971. package/dist/collection/components/dropdown/alignment.js.map +0 -1
  972. package/dist/collection/components/group-dropdown-item/group-dropdown-item.js.map +0 -1
  973. package/dist/collection/components/modal/modal-utils.js +0 -37
  974. package/dist/collection/components/modal/modal-utils.js.map +0 -1
  975. package/dist/collection/components/modal-container/modal-container.js +0 -126
  976. package/dist/collection/components/modal-container/modal-container.js.map +0 -1
  977. package/dist/components/ix-counter-pill.js +0 -54
  978. package/dist/components/ix-counter-pill.js.map +0 -1
  979. package/dist/components/ix-group-dropdown-item.js +0 -51
  980. package/dist/components/ix-group-dropdown-item.js.map +0 -1
  981. package/dist/components/ix-modal-container.js +0 -8
  982. package/dist/components/ix-modal-container.js.map +0 -1
  983. package/dist/components/modal-container.js +0 -109
  984. package/dist/components/modal-container.js.map +0 -1
  985. package/dist/components/modal-utils.js +0 -40
  986. package/dist/components/modal-utils.js.map +0 -1
  987. package/dist/esm/context-f6a2b727.js +0 -73
  988. package/dist/esm/context-f6a2b727.js.map +0 -1
  989. package/dist/esm/floating-ui.dom.esm-3130eda0.js.map +0 -1
  990. package/dist/esm/index-8ddfb6d8.js.map +0 -1
  991. package/dist/esm/ix-card_3.entry.js +0 -68
  992. package/dist/esm/ix-card_3.entry.js.map +0 -1
  993. package/dist/esm/ix-counter-pill.entry.js +0 -31
  994. package/dist/esm/ix-counter-pill.entry.js.map +0 -1
  995. package/dist/esm/ix-group_3.entry.js +0 -175
  996. package/dist/esm/ix-group_3.entry.js.map +0 -1
  997. package/dist/esm/ix-modal_2.entry.js +0 -222
  998. package/dist/esm/ix-modal_2.entry.js.map +0 -1
  999. package/dist/esm/modal-utils-aecbcba5.js +0 -40
  1000. package/dist/esm/modal-utils-aecbcba5.js.map +0 -1
  1001. package/dist/esm/service-fc436c5b.js +0 -73
  1002. package/dist/esm/service-fc436c5b.js.map +0 -1
  1003. package/dist/siemens-ix/p-1572aab3.js +0 -2
  1004. package/dist/siemens-ix/p-1572aab3.js.map +0 -1
  1005. package/dist/siemens-ix/p-15bebd8a.js +0 -2
  1006. package/dist/siemens-ix/p-1c64b073.js +0 -3
  1007. package/dist/siemens-ix/p-1c64b073.js.map +0 -1
  1008. package/dist/siemens-ix/p-3172249b.entry.js +0 -2
  1009. package/dist/siemens-ix/p-3172249b.entry.js.map +0 -1
  1010. package/dist/siemens-ix/p-3ddf017b.entry.js +0 -2
  1011. package/dist/siemens-ix/p-40982e21.entry.js +0 -2
  1012. package/dist/siemens-ix/p-40982e21.entry.js.map +0 -1
  1013. package/dist/siemens-ix/p-4597dd77.entry.js +0 -2
  1014. package/dist/siemens-ix/p-4597dd77.entry.js.map +0 -1
  1015. package/dist/siemens-ix/p-46ced516.entry.js +0 -2
  1016. package/dist/siemens-ix/p-46ced516.entry.js.map +0 -1
  1017. package/dist/siemens-ix/p-47422d47.entry.js +0 -2
  1018. package/dist/siemens-ix/p-47422d47.entry.js.map +0 -1
  1019. package/dist/siemens-ix/p-4851ea38.entry.js +0 -2
  1020. package/dist/siemens-ix/p-4851ea38.entry.js.map +0 -1
  1021. package/dist/siemens-ix/p-4e851aa3.entry.js +0 -2
  1022. package/dist/siemens-ix/p-4e851aa3.entry.js.map +0 -1
  1023. package/dist/siemens-ix/p-51c81a20.entry.js +0 -2
  1024. package/dist/siemens-ix/p-51c81a20.entry.js.map +0 -1
  1025. package/dist/siemens-ix/p-529d7530.js +0 -2
  1026. package/dist/siemens-ix/p-529d7530.js.map +0 -1
  1027. package/dist/siemens-ix/p-55b54a81.entry.js.map +0 -1
  1028. package/dist/siemens-ix/p-67be3720.entry.js +0 -2
  1029. package/dist/siemens-ix/p-67be3720.entry.js.map +0 -1
  1030. package/dist/siemens-ix/p-821ca55e.entry.js +0 -2
  1031. package/dist/siemens-ix/p-821ca55e.entry.js.map +0 -1
  1032. package/dist/siemens-ix/p-8719eeff.entry.js +0 -2
  1033. package/dist/siemens-ix/p-8719eeff.entry.js.map +0 -1
  1034. package/dist/siemens-ix/p-9a82921b.entry.js +0 -2
  1035. package/dist/siemens-ix/p-9a82921b.entry.js.map +0 -1
  1036. package/dist/siemens-ix/p-a08e1bbc.entry.js +0 -2
  1037. package/dist/siemens-ix/p-a08e1bbc.entry.js.map +0 -1
  1038. package/dist/siemens-ix/p-a422c64a.entry.js +0 -2
  1039. package/dist/siemens-ix/p-a422c64a.entry.js.map +0 -1
  1040. package/dist/siemens-ix/p-a73580a5.entry.js +0 -2
  1041. package/dist/siemens-ix/p-a73580a5.entry.js.map +0 -1
  1042. package/dist/siemens-ix/p-b14308ed.js +0 -2
  1043. package/dist/siemens-ix/p-b14308ed.js.map +0 -1
  1044. package/dist/siemens-ix/p-b5c40bb3.entry.js +0 -2
  1045. package/dist/siemens-ix/p-b5c40bb3.entry.js.map +0 -1
  1046. package/dist/siemens-ix/p-c5124f7b.entry.js +0 -2
  1047. package/dist/siemens-ix/p-c5124f7b.entry.js.map +0 -1
  1048. package/dist/siemens-ix/p-c7109071.entry.js +0 -2
  1049. package/dist/siemens-ix/p-c7109071.entry.js.map +0 -1
  1050. package/dist/siemens-ix/p-c724bb65.entry.js +0 -2
  1051. package/dist/siemens-ix/p-c724bb65.entry.js.map +0 -1
  1052. package/dist/siemens-ix/p-ca4d28fb.entry.js +0 -2
  1053. package/dist/siemens-ix/p-ca4d28fb.entry.js.map +0 -1
  1054. package/dist/siemens-ix/p-cd4e3593.entry.js +0 -2
  1055. package/dist/siemens-ix/p-cd4e3593.entry.js.map +0 -1
  1056. package/dist/siemens-ix/p-cd75b455.entry.js +0 -2
  1057. package/dist/siemens-ix/p-cd75b455.entry.js.map +0 -1
  1058. package/dist/siemens-ix/p-cf2717c1.entry.js +0 -2
  1059. package/dist/siemens-ix/p-cf2717c1.entry.js.map +0 -1
  1060. package/dist/siemens-ix/p-d5302336.entry.js +0 -2
  1061. package/dist/siemens-ix/p-d5302336.entry.js.map +0 -1
  1062. package/dist/siemens-ix/p-d784a04b.entry.js +0 -2
  1063. package/dist/siemens-ix/p-d784a04b.entry.js.map +0 -1
  1064. package/dist/siemens-ix/p-d7e23a1f.entry.js +0 -2
  1065. package/dist/siemens-ix/p-d7e23a1f.entry.js.map +0 -1
  1066. package/dist/siemens-ix/p-dbcec49e.entry.js +0 -2
  1067. package/dist/siemens-ix/p-dbcec49e.entry.js.map +0 -1
  1068. package/dist/siemens-ix/p-dc98d3f4.entry.js +0 -2
  1069. package/dist/siemens-ix/p-dc98d3f4.entry.js.map +0 -1
  1070. package/dist/siemens-ix/p-df138b2a.entry.js +0 -2
  1071. package/dist/siemens-ix/p-df138b2a.entry.js.map +0 -1
  1072. package/dist/siemens-ix/p-ea55afa3.entry.js +0 -2
  1073. package/dist/siemens-ix/p-ea55afa3.entry.js.map +0 -1
  1074. package/dist/siemens-ix/p-eccc2475.entry.js +0 -2
  1075. package/dist/siemens-ix/p-eccc2475.entry.js.map +0 -1
  1076. package/dist/siemens-ix/p-ecd1145b.entry.js +0 -2
  1077. package/dist/siemens-ix/p-ecd1145b.entry.js.map +0 -1
  1078. package/dist/siemens-ix/p-f207e578.entry.js +0 -2
  1079. package/dist/siemens-ix/p-f34a16c6.js +0 -2
  1080. package/dist/siemens-ix/p-f34a16c6.js.map +0 -1
  1081. package/dist/siemens-ix/p-f48b706b.entry.js +0 -2
  1082. package/dist/siemens-ix/p-f48b706b.entry.js.map +0 -1
  1083. package/dist/siemens-ix/p-f50697b9.entry.js +0 -2
  1084. package/dist/siemens-ix/p-f50697b9.entry.js.map +0 -1
  1085. package/dist/siemens-ix/p-feb8c2c4.entry.js +0 -2
  1086. package/dist/siemens-ix/p-feb8c2c4.entry.js.map +0 -1
  1087. package/dist/types/components/counter-pill/counter-pill.d.ts +0 -24
  1088. package/dist/types/components/dropdown/alignment.d.ts +0 -2
  1089. package/dist/types/components/group-dropdown-item/group-dropdown-item.d.ts +0 -11
  1090. package/dist/types/components/modal/modal-utils.d.ts +0 -29
  1091. package/dist/types/components/modal-container/modal-container.d.ts +0 -12
  1092. /package/dist/siemens-ix/{p-d848739e.entry.js.map → p-00f74fc9.entry.js.map} +0 -0
  1093. /package/dist/siemens-ix/{p-6acce5c9.entry.js.map → p-02f01e39.entry.js.map} +0 -0
  1094. /package/dist/siemens-ix/{p-07c932da.entry.js.map → p-07a0b330.entry.js.map} +0 -0
  1095. /package/dist/siemens-ix/{p-3f4a9e1f.entry.js.map → p-09ce5f12.entry.js.map} +0 -0
  1096. /package/dist/siemens-ix/{p-13bda5ea.entry.js.map → p-0fab8cae.entry.js.map} +0 -0
  1097. /package/dist/siemens-ix/{p-003e9355.entry.js.map → p-20aa7350.entry.js.map} +0 -0
  1098. /package/dist/siemens-ix/{p-f6ae45fb.entry.js.map → p-33670e98.entry.js.map} +0 -0
  1099. /package/dist/siemens-ix/{p-a89a1fa5.entry.js.map → p-4d194d55.entry.js.map} +0 -0
  1100. /package/dist/siemens-ix/{p-d2225fc2.entry.js.map → p-709d38fe.entry.js.map} +0 -0
  1101. /package/dist/siemens-ix/{p-1331a920.entry.js.map → p-81333042.entry.js.map} +0 -0
  1102. /package/dist/siemens-ix/{p-85f01dba.entry.js.map → p-904aa275.entry.js.map} +0 -0
  1103. /package/dist/siemens-ix/{p-cd3cfc78.entry.js.map → p-918450cd.entry.js.map} +0 -0
  1104. /package/dist/siemens-ix/{p-a7212f01.entry.js.map → p-b21bc31c.entry.js.map} +0 -0
  1105. /package/dist/siemens-ix/{p-6c033b08.entry.js.map → p-b89172b4.entry.js.map} +0 -0
  1106. /package/dist/siemens-ix/{p-3ddf017b.entry.js.map → p-d0a8aa6f.entry.js.map} +0 -0
  1107. /package/dist/siemens-ix/{p-b1db27a3.js.map → p-db74796e.js.map} +0 -0
  1108. /package/dist/siemens-ix/{p-bd24f35f.entry.js.map → p-f0219d7a.entry.js.map} +0 -0
  1109. /package/dist/siemens-ix/{p-1e8ee4af.entry.js.map → p-f38e7420.entry.js.map} +0 -0
  1110. /package/dist/siemens-ix/{p-6124d173.entry.js.map → p-ff17104c.entry.js.map} +0 -0
@@ -8,23 +8,29 @@
8
8
  */
9
9
  import { autoUpdate, computePosition, flip, inline, offset, shift, } from '@floating-ui/dom';
10
10
  import { h, Host, } from '@stencil/core';
11
+ const dropdownDisposer = new Map();
12
+ let sequenceId = 0;
11
13
  export class Dropdown {
12
14
  constructor() {
13
15
  this.autoUpdateCleanup = null;
16
+ this.localUId = `dropdown-${sequenceId++}-${new Date().valueOf()}`;
17
+ this.suppressAutomaticPlacement = false;
14
18
  this.show = false;
15
19
  this.trigger = undefined;
16
20
  this.anchor = undefined;
17
21
  this.closeBehavior = 'both';
18
22
  this.placement = 'bottom-start';
19
23
  this.positioningStrategy = 'fixed';
20
- this.adjustDropdownWidthToReferenceWith = false;
21
- this.adjustDropdownWidthToReferenceWidth = false;
22
24
  this.header = undefined;
23
25
  this.offset = undefined;
24
26
  this.triggerEvent = 'click';
25
27
  this.overwriteDropdownStyle = undefined;
26
28
  this.toggleBind = this.toggle.bind(this);
27
29
  this.openBind = this.open.bind(this);
30
+ if (dropdownDisposer.has(this.localUId)) {
31
+ console.warn('Dropdown with duplicated id detected');
32
+ }
33
+ dropdownDisposer.set(this.localUId, this.close.bind(this));
28
34
  }
29
35
  get dropdownItems() {
30
36
  return Array.from(this.hostElement.querySelectorAll('ix-dropdown-item'));
@@ -119,6 +125,13 @@ export class Dropdown {
119
125
  this.applyDropdownPosition();
120
126
  }
121
127
  }
128
+ if (newShow) {
129
+ dropdownDisposer.forEach((dispose, id) => {
130
+ if (id !== this.localUId && !this.isAnchorSubmenu()) {
131
+ dispose();
132
+ }
133
+ });
134
+ }
122
135
  }
123
136
  changedTrigger(newTriggerValue, oldTriggerValue) {
124
137
  if (newTriggerValue) {
@@ -140,20 +153,26 @@ export class Dropdown {
140
153
  switch (this.closeBehavior) {
141
154
  case 'outside':
142
155
  if (!this.dropdownRef.contains(target)) {
143
- this.close();
156
+ this.close(event);
144
157
  }
145
158
  break;
146
159
  case 'inside':
147
160
  if (this.dropdownRef.contains(target) && this.hostElement !== target) {
148
- this.close();
161
+ this.close(event);
149
162
  }
150
163
  break;
151
164
  case 'both':
152
- if (this.hostElement !== target)
153
- this.close();
165
+ if (this.hostElement !== target) {
166
+ this.close(event);
167
+ }
154
168
  break;
155
169
  default:
156
- this.close();
170
+ this.close(event);
171
+ }
172
+ }
173
+ keydown(event) {
174
+ if (this.show === true && event.code === 'Escape') {
175
+ this.close();
157
176
  }
158
177
  }
159
178
  isNestedDropdown(element) {
@@ -185,7 +204,12 @@ export class Dropdown {
185
204
  }
186
205
  close(event) {
187
206
  if (event === null || event === void 0 ? void 0 : event.defaultPrevented) {
188
- return;
207
+ const target = event.target;
208
+ if (target.contains(this.anchorElement) ||
209
+ target.contains(this.triggerElement) ||
210
+ target.shadowRoot.contains(this.anchorElement) ||
211
+ target.shadowRoot.contains(this.triggerElement))
212
+ return;
189
213
  }
190
214
  this.show = false;
191
215
  this.showChanged.emit(false);
@@ -202,16 +226,10 @@ export class Dropdown {
202
226
  strategy: this.positioningStrategy,
203
227
  middleware: [],
204
228
  };
205
- if (isSubmenu) {
206
- positionConfig.placement = 'right-start';
207
- }
208
- if (this.placement.includes('auto') || isSubmenu) {
229
+ if (!this.suppressAutomaticPlacement) {
209
230
  positionConfig.middleware.push(flip({ fallbackStrategy: 'initialPlacement' }));
210
- positionConfig.placement = 'bottom-start';
211
- }
212
- else {
213
- positionConfig.placement = this.placement;
214
231
  }
232
+ positionConfig.placement = isSubmenu ? 'right-start' : this.placement;
215
233
  positionConfig.middleware = [
216
234
  ...positionConfig.middleware,
217
235
  inline(),
@@ -246,16 +264,27 @@ export class Dropdown {
246
264
  }
247
265
  async componentDidLoad() {
248
266
  if (this.trigger) {
249
- this.registerListener(this.trigger);
267
+ this.changedTrigger(this.trigger, null);
250
268
  }
251
269
  }
252
270
  async componentDidRender() {
271
+ var _a;
253
272
  await this.applyDropdownPosition();
273
+ this.anchorElement = await (this.anchor
274
+ ? this.resolveElement(this.anchor)
275
+ : this.resolveElement(this.trigger));
276
+ if (this.isAnchorSubmenu() &&
277
+ ((_a = this.anchorElement) === null || _a === void 0 ? void 0 : _a.tagName) === 'IX-DROPDOWN-ITEM') {
278
+ this.anchorElement.isSubMenu = true;
279
+ }
254
280
  }
255
281
  disconnectedCallback() {
256
282
  if (this.autoUpdateCleanup) {
257
283
  this.autoUpdateCleanup();
258
284
  }
285
+ if (dropdownDisposer.has(this.localUId)) {
286
+ dropdownDisposer.delete(this.localUId);
287
+ }
259
288
  }
260
289
  /**
261
290
  * Update position of dropdown
@@ -272,7 +301,7 @@ export class Dropdown {
272
301
  margin: '0',
273
302
  minWidth: '0px',
274
303
  position: this.positioningStrategy,
275
- } }, h("div", { style: { display: 'contents' } }, this.header ? h("div", { class: "dropdown-header" }, this.header) : '', h("slot", null))));
304
+ }, role: "list" }, h("div", { style: { display: 'contents' } }, this.header ? h("div", { class: "dropdown-header" }, this.header) : '', h("slot", null))));
276
305
  }
277
306
  static get is() { return "ix-dropdown"; }
278
307
  static get encapsulation() { return "shadow"; }
@@ -288,6 +317,27 @@ export class Dropdown {
288
317
  }
289
318
  static get properties() {
290
319
  return {
320
+ "suppressAutomaticPlacement": {
321
+ "type": "boolean",
322
+ "mutable": false,
323
+ "complexType": {
324
+ "original": "boolean",
325
+ "resolved": "boolean",
326
+ "references": {}
327
+ },
328
+ "required": false,
329
+ "optional": false,
330
+ "docs": {
331
+ "tags": [{
332
+ "name": "since",
333
+ "text": "2.0.0"
334
+ }],
335
+ "text": "Suppress the automatic placement of the dropdown."
336
+ },
337
+ "attribute": "suppress-automatic-placement",
338
+ "reflect": false,
339
+ "defaultValue": "false"
340
+ },
291
341
  "show": {
292
342
  "type": "boolean",
293
343
  "mutable": true,
@@ -370,10 +420,10 @@ export class Dropdown {
370
420
  "type": "string",
371
421
  "mutable": false,
372
422
  "complexType": {
373
- "original": "Placement",
374
- "resolved": "\"auto\" | \"auto-end\" | \"auto-start\" | \"bottom\" | \"bottom-end\" | \"bottom-start\" | \"left\" | \"left-end\" | \"left-start\" | \"right\" | \"right-end\" | \"right-start\" | \"top\" | \"top-end\" | \"top-start\"",
423
+ "original": "AlignedPlacement",
424
+ "resolved": "\"bottom-end\" | \"bottom-start\" | \"left-end\" | \"left-start\" | \"right-end\" | \"right-start\" | \"top-end\" | \"top-start\"",
375
425
  "references": {
376
- "Placement": {
426
+ "AlignedPlacement": {
377
427
  "location": "import",
378
428
  "path": "./placement"
379
429
  }
@@ -407,48 +457,6 @@ export class Dropdown {
407
457
  "reflect": false,
408
458
  "defaultValue": "'fixed'"
409
459
  },
410
- "adjustDropdownWidthToReferenceWith": {
411
- "type": "boolean",
412
- "mutable": false,
413
- "complexType": {
414
- "original": "boolean",
415
- "resolved": "boolean",
416
- "references": {}
417
- },
418
- "required": false,
419
- "optional": false,
420
- "docs": {
421
- "tags": [{
422
- "name": "deprecated",
423
- "text": "Will be removed in 2.0.0. Property has a typo use `adjustDropdownWidthToReferenceWidth` instead."
424
- }],
425
- "text": "Adjust dropdown width to the parent width"
426
- },
427
- "attribute": "adjust-dropdown-width-to-reference-with",
428
- "reflect": false,
429
- "defaultValue": "false"
430
- },
431
- "adjustDropdownWidthToReferenceWidth": {
432
- "type": "boolean",
433
- "mutable": false,
434
- "complexType": {
435
- "original": "boolean",
436
- "resolved": "boolean",
437
- "references": {}
438
- },
439
- "required": false,
440
- "optional": false,
441
- "docs": {
442
- "tags": [{
443
- "name": "deprecated",
444
- "text": "Will be removed. Not used anymore"
445
- }],
446
- "text": "Adjust dropdown width to the parent width"
447
- },
448
- "attribute": "adjust-dropdown-width-to-reference-width",
449
- "reflect": false,
450
- "defaultValue": "false"
451
- },
452
460
  "header": {
453
461
  "type": "string",
454
462
  "mutable": false,
@@ -598,6 +606,12 @@ export class Dropdown {
598
606
  "target": "window",
599
607
  "capture": false,
600
608
  "passive": false
609
+ }, {
610
+ "name": "keydown",
611
+ "method": "keydown",
612
+ "target": "window",
613
+ "capture": false,
614
+ "passive": false
601
615
  }];
602
616
  }
603
617
  }
@@ -1 +1 @@
1
- {"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../../src/components/dropdown/dropdown.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 autoUpdate,\n computePosition,\n ComputePositionConfig,\n flip,\n inline,\n offset,\n shift,\n} from '@floating-ui/dom';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Method,\n Prop,\n Watch,\n} from '@stencil/core';\nimport { BasePlacement, Placement, PlacementWithAlignment } from './placement';\n\n/**\n * @internal\n */\nexport type DropdownTriggerEvent = 'click' | 'hover' | 'focus';\n\n@Component({\n tag: 'ix-dropdown',\n styleUrl: 'dropdown.scss',\n shadow: true,\n})\nexport class Dropdown {\n @Element() hostElement!: HTMLIxDropdownElement;\n\n /**\n * Show dropdown\n */\n @Prop({ mutable: true, reflect: true }) show = false;\n\n /**\n * Define an element that triggers the dropdown.\n * A trigger can either be a string that will be interpreted as id attribute or a DOM element.\n */\n @Prop() trigger: string | HTMLElement;\n\n /**\n * Define an anchor element\n */\n @Prop() anchor: string | HTMLElement;\n\n /**\n * Close behavior\n */\n @Prop() closeBehavior: 'inside' | 'outside' | 'both' | boolean = 'both';\n\n /**\n * Placement of the dropdown\n */\n @Prop() placement: Placement = 'bottom-start';\n\n /**\n * Position strategy\n */\n @Prop() positioningStrategy: 'absolute' | 'fixed' = 'fixed';\n\n /**\n * Adjust dropdown width to the parent width\n * @deprecated Will be removed in 2.0.0. Property has a typo use `adjustDropdownWidthToReferenceWidth` instead.\n */\n @Prop() adjustDropdownWidthToReferenceWith = false;\n\n /**\n * Adjust dropdown width to the parent width\n *\n * @deprecated Will be removed. Not used anymore\n */\n @Prop() adjustDropdownWidthToReferenceWidth = false;\n\n /**\n * An optional header shown at the top of the dropdown\n */\n @Prop() header?: string;\n\n /**\n * Move dropdown along main axis of alignment\n *\n * @internal\n */\n @Prop() offset: {\n mainAxis?: number;\n crossAxis?: number;\n alignmentAxis?: number;\n };\n\n /**\n * Define one or more events to open dropdown\n * @internal\n */\n @Prop() triggerEvent: DropdownTriggerEvent | DropdownTriggerEvent[] = 'click';\n\n /**\n * @internal\n */\n @Prop() overwriteDropdownStyle: (delegate: {\n dropdownRef: HTMLElement;\n triggerRef?: HTMLElement;\n }) => Promise<Partial<CSSStyleDeclaration>>;\n\n /**\n * Fire event after visibility of dropdown has changed\n */\n @Event() showChanged: EventEmitter<boolean>;\n\n private autoUpdateCleanup: () => void = null;\n\n private triggerElement?: Element;\n private anchorElement?: Element;\n\n private dropdownRef: HTMLElement;\n\n private toggleBind: any;\n private openBind: any;\n\n constructor() {\n this.toggleBind = this.toggle.bind(this);\n this.openBind = this.open.bind(this);\n }\n\n get dropdownItems() {\n return Array.from(this.hostElement.querySelectorAll('ix-dropdown-item'));\n }\n\n private addEventListenersFor(triggerEvent: DropdownTriggerEvent) {\n switch (triggerEvent) {\n case 'click':\n if (this.closeBehavior === 'outside') {\n this.triggerElement.addEventListener('click', this.openBind);\n } else {\n this.triggerElement.addEventListener('click', this.toggleBind);\n }\n break;\n\n case 'hover':\n this.triggerElement.addEventListener('mouseenter', this.openBind);\n break;\n\n case 'focus':\n this.triggerElement.addEventListener('focusin', this.openBind);\n break;\n }\n }\n\n private removeEventListenersFor(\n triggerEvent: DropdownTriggerEvent,\n triggerElement: Element\n ) {\n switch (triggerEvent) {\n case 'click':\n if (this.closeBehavior === 'outside') {\n triggerElement.removeEventListener('click', this.openBind);\n } else {\n triggerElement.removeEventListener('click', this.toggleBind);\n }\n break;\n\n case 'hover':\n triggerElement.removeEventListener('mouseenter', this.openBind);\n break;\n\n case 'focus':\n triggerElement.removeEventListener('focusin', this.openBind);\n break;\n }\n }\n\n private async registerListener(element: string | HTMLElement) {\n this.triggerElement = await this.resolveElement(element);\n if (this.triggerElement) {\n if (Array.isArray(this.triggerEvent)) {\n this.triggerEvent.forEach((triggerEvent) => {\n this.addEventListenersFor(triggerEvent);\n });\n } else {\n this.addEventListenersFor(this.triggerEvent);\n }\n }\n }\n\n private async unregisterListener(element: string | HTMLElement) {\n const trigger = await this.resolveElement(element);\n if (Array.isArray(this.triggerEvent)) {\n this.triggerEvent.forEach((triggerEvent) => {\n this.removeEventListenersFor(triggerEvent, trigger);\n });\n } else {\n this.removeEventListenersFor(this.triggerEvent, trigger);\n }\n }\n\n private resolveElement(element: string | HTMLElement): Promise<Element> {\n if (typeof element !== 'string') {\n return Promise.resolve(element);\n }\n\n const selector = `#${element}`;\n return new Promise((resolve) => {\n if (document.querySelector(selector)) {\n return resolve(document.querySelector(selector));\n }\n\n const observer = new MutationObserver(() => {\n if (document.querySelector(selector)) {\n resolve(document.querySelector(selector));\n observer.disconnect();\n }\n });\n\n observer.observe(document.body, {\n childList: true,\n subtree: true,\n });\n });\n }\n\n @Watch('show')\n async changedShow(newShow: boolean) {\n if (newShow) {\n this.anchorElement = await (this.anchor\n ? this.resolveElement(this.anchor)\n : this.resolveElement(this.trigger));\n\n if (this.anchorElement) {\n this.applyDropdownPosition();\n }\n }\n }\n\n @Watch('trigger')\n changedTrigger(\n newTriggerValue: string | HTMLElement,\n oldTriggerValue: string | HTMLElement\n ) {\n if (newTriggerValue) {\n this.registerListener(newTriggerValue);\n }\n\n if (oldTriggerValue) {\n this.unregisterListener(oldTriggerValue);\n }\n }\n\n @Listen('click', {\n target: 'window',\n })\n clickOutside(event: Event) {\n const target = event.target as HTMLElement;\n\n if (\n this.show === false ||\n this.closeBehavior === false ||\n this.anchorElement?.contains(target) ||\n this.triggerElement?.contains(target)\n ) {\n return;\n }\n\n switch (this.closeBehavior) {\n case 'outside':\n if (!this.dropdownRef.contains(target)) {\n this.close();\n }\n break;\n case 'inside':\n if (this.dropdownRef.contains(target) && this.hostElement !== target) {\n this.close();\n }\n break;\n case 'both':\n if (this.hostElement !== target) this.close();\n break;\n default:\n this.close();\n }\n }\n\n private isNestedDropdown(element: Element) {\n return element.closest('ix-dropdown');\n }\n\n private isAnchorSubmenu() {\n const anchor = this.anchorElement?.closest('ix-dropdown-item');\n if (!anchor) {\n return false;\n }\n\n return true;\n }\n\n private toggle(event?: Event) {\n event?.preventDefault();\n\n if (this.isNestedDropdown(event.target as HTMLElement)) {\n event?.stopPropagation();\n }\n\n this.show = !this.show;\n this.showChanged.emit(this.show);\n }\n\n private open(event?: Event) {\n event?.preventDefault();\n\n if (this.isNestedDropdown(event.target as HTMLElement)) {\n event?.stopPropagation();\n }\n\n this.show = true;\n this.showChanged.emit(true);\n }\n\n private close(event?: Event) {\n if (event?.defaultPrevented) {\n return;\n }\n\n this.show = false;\n this.showChanged.emit(false);\n }\n\n private async applyDropdownPosition() {\n if (!this.anchorElement) {\n return;\n }\n if (!this.dropdownRef) {\n return;\n }\n const isSubmenu = this.isAnchorSubmenu();\n\n let positionConfig: Partial<ComputePositionConfig> = {\n strategy: this.positioningStrategy,\n middleware: [],\n };\n\n if (isSubmenu) {\n positionConfig.placement = 'right-start';\n }\n\n if (this.placement.includes('auto') || isSubmenu) {\n positionConfig.middleware.push(\n flip({ fallbackStrategy: 'initialPlacement' })\n );\n positionConfig.placement = 'bottom-start';\n } else {\n positionConfig.placement = this.placement as\n | BasePlacement\n | PlacementWithAlignment;\n }\n\n positionConfig.middleware = [\n ...positionConfig.middleware,\n inline(),\n shift(),\n ];\n\n if (this.offset) {\n positionConfig.middleware.push(offset(this.offset));\n }\n\n if (this.autoUpdateCleanup) {\n this.autoUpdateCleanup();\n this.autoUpdateCleanup = null;\n }\n this.autoUpdateCleanup = autoUpdate(\n this.anchorElement,\n this.dropdownRef,\n async () => {\n const computeResponse = await computePosition(\n this.anchorElement,\n this.dropdownRef,\n positionConfig\n );\n Object.assign(this.dropdownRef.style, {\n top: '0',\n left: '0',\n transform: `translate(${Math.round(computeResponse.x)}px,${Math.round(\n computeResponse.y\n )}px)`,\n });\n if (this.overwriteDropdownStyle) {\n const overwriteStyle = await this.overwriteDropdownStyle({\n dropdownRef: this.dropdownRef,\n triggerRef: this.triggerElement as HTMLElement,\n });\n\n Object.assign(this.dropdownRef.style, overwriteStyle);\n }\n },\n {\n ancestorResize: true,\n ancestorScroll: true,\n elementResize: true,\n }\n );\n }\n\n async componentDidLoad() {\n if (this.trigger) {\n this.registerListener(this.trigger);\n }\n }\n\n async componentDidRender() {\n await this.applyDropdownPosition();\n }\n\n disconnectedCallback() {\n if (this.autoUpdateCleanup) {\n this.autoUpdateCleanup();\n }\n }\n\n /**\n * Update position of dropdown\n */\n @Method()\n async updatePosition() {\n this.applyDropdownPosition();\n }\n\n render() {\n return (\n <Host\n ref={(ref) => (this.dropdownRef = ref)}\n class={{\n 'dropdown-menu': true,\n show: this.show,\n overflow: true,\n }}\n style={{\n margin: '0',\n minWidth: '0px',\n position: this.positioningStrategy,\n }}\n >\n <div style={{ display: 'contents' }}>\n {this.header ? <div class=\"dropdown-header\">{this.header}</div> : ''}\n\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../../src/components/dropdown/dropdown.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 autoUpdate,\n computePosition,\n ComputePositionConfig,\n flip,\n inline,\n offset,\n shift,\n} from '@floating-ui/dom';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Method,\n Prop,\n Watch,\n} from '@stencil/core';\nimport { AlignedPlacement } from './placement';\n\n/**\n * @internal\n */\nexport type DropdownTriggerEvent = 'click' | 'hover' | 'focus';\n\ntype DisposeDropdown = () => void;\nconst dropdownDisposer = new Map<string, DisposeDropdown>();\nlet sequenceId = 0;\n\n@Component({\n tag: 'ix-dropdown',\n styleUrl: 'dropdown.scss',\n shadow: true,\n})\nexport class Dropdown {\n @Element() hostElement!: HTMLIxDropdownElement;\n\n /**\n * Suppress the automatic placement of the dropdown.\n *\n * @since 2.0.0\n */\n @Prop() suppressAutomaticPlacement = false;\n\n /**\n * Show dropdown\n */\n @Prop({ mutable: true, reflect: true }) show = false;\n\n /**\n * Define an element that triggers the dropdown.\n * A trigger can either be a string that will be interpreted as id attribute or a DOM element.\n */\n @Prop() trigger: string | HTMLElement;\n\n /**\n * Define an anchor element\n */\n @Prop() anchor: string | HTMLElement;\n\n /**\n * Close behavior\n */\n @Prop() closeBehavior: 'inside' | 'outside' | 'both' | boolean = 'both';\n\n /**\n * Placement of the dropdown\n */\n @Prop() placement: AlignedPlacement = 'bottom-start';\n\n /**\n * Position strategy\n */\n @Prop() positioningStrategy: 'absolute' | 'fixed' = 'fixed';\n\n /**\n * An optional header shown at the top of the dropdown\n */\n @Prop() header?: string;\n\n /**\n * Move dropdown along main axis of alignment\n *\n * @internal\n */\n @Prop() offset: {\n mainAxis?: number;\n crossAxis?: number;\n alignmentAxis?: number;\n };\n\n /**\n * Define one or more events to open dropdown\n * @internal\n */\n @Prop() triggerEvent: DropdownTriggerEvent | DropdownTriggerEvent[] = 'click';\n\n /**\n * @internal\n */\n @Prop() overwriteDropdownStyle: (delegate: {\n dropdownRef: HTMLElement;\n triggerRef?: HTMLElement;\n }) => Promise<Partial<CSSStyleDeclaration>>;\n\n /**\n * Fire event after visibility of dropdown has changed\n */\n @Event() showChanged: EventEmitter<boolean>;\n\n private autoUpdateCleanup: () => void = null;\n\n private triggerElement?: Element;\n private anchorElement?: Element;\n\n private dropdownRef: HTMLElement;\n\n private toggleBind: any;\n private openBind: any;\n\n private localUId = `dropdown-${sequenceId++}-${new Date().valueOf()}`;\n\n constructor() {\n this.toggleBind = this.toggle.bind(this);\n this.openBind = this.open.bind(this);\n\n if (dropdownDisposer.has(this.localUId)) {\n console.warn('Dropdown with duplicated id detected');\n }\n\n dropdownDisposer.set(this.localUId, this.close.bind(this));\n }\n\n get dropdownItems() {\n return Array.from(this.hostElement.querySelectorAll('ix-dropdown-item'));\n }\n\n private addEventListenersFor(triggerEvent: DropdownTriggerEvent) {\n switch (triggerEvent) {\n case 'click':\n if (this.closeBehavior === 'outside') {\n this.triggerElement.addEventListener('click', this.openBind);\n } else {\n this.triggerElement.addEventListener('click', this.toggleBind);\n }\n break;\n\n case 'hover':\n this.triggerElement.addEventListener('mouseenter', this.openBind);\n break;\n\n case 'focus':\n this.triggerElement.addEventListener('focusin', this.openBind);\n break;\n }\n }\n\n private removeEventListenersFor(\n triggerEvent: DropdownTriggerEvent,\n triggerElement: Element\n ) {\n switch (triggerEvent) {\n case 'click':\n if (this.closeBehavior === 'outside') {\n triggerElement.removeEventListener('click', this.openBind);\n } else {\n triggerElement.removeEventListener('click', this.toggleBind);\n }\n break;\n\n case 'hover':\n triggerElement.removeEventListener('mouseenter', this.openBind);\n break;\n\n case 'focus':\n triggerElement.removeEventListener('focusin', this.openBind);\n break;\n }\n }\n\n private async registerListener(element: string | HTMLElement) {\n this.triggerElement = await this.resolveElement(element);\n if (this.triggerElement) {\n if (Array.isArray(this.triggerEvent)) {\n this.triggerEvent.forEach((triggerEvent) => {\n this.addEventListenersFor(triggerEvent);\n });\n } else {\n this.addEventListenersFor(this.triggerEvent);\n }\n }\n }\n\n private async unregisterListener(element: string | HTMLElement) {\n const trigger = await this.resolveElement(element);\n if (Array.isArray(this.triggerEvent)) {\n this.triggerEvent.forEach((triggerEvent) => {\n this.removeEventListenersFor(triggerEvent, trigger);\n });\n } else {\n this.removeEventListenersFor(this.triggerEvent, trigger);\n }\n }\n\n private resolveElement(element: string | HTMLElement): Promise<Element> {\n if (typeof element !== 'string') {\n return Promise.resolve(element);\n }\n\n const selector = `#${element}`;\n return new Promise((resolve) => {\n if (document.querySelector(selector)) {\n return resolve(document.querySelector(selector));\n }\n\n const observer = new MutationObserver(() => {\n if (document.querySelector(selector)) {\n resolve(document.querySelector(selector));\n observer.disconnect();\n }\n });\n\n observer.observe(document.body, {\n childList: true,\n subtree: true,\n });\n });\n }\n\n @Watch('show')\n async changedShow(newShow: boolean) {\n if (newShow) {\n this.anchorElement = await (this.anchor\n ? this.resolveElement(this.anchor)\n : this.resolveElement(this.trigger));\n\n if (this.anchorElement) {\n this.applyDropdownPosition();\n }\n }\n\n if (newShow) {\n dropdownDisposer.forEach((dispose, id) => {\n if (id !== this.localUId && !this.isAnchorSubmenu()) {\n dispose();\n }\n });\n }\n }\n\n @Watch('trigger')\n changedTrigger(\n newTriggerValue: string | HTMLElement,\n oldTriggerValue: string | HTMLElement\n ) {\n if (newTriggerValue) {\n this.registerListener(newTriggerValue);\n }\n\n if (oldTriggerValue) {\n this.unregisterListener(oldTriggerValue);\n }\n }\n\n @Listen('click', {\n target: 'window',\n })\n clickOutside(event: Event) {\n const target = event.target as HTMLElement;\n if (\n this.show === false ||\n this.closeBehavior === false ||\n this.anchorElement?.contains(target) ||\n this.triggerElement?.contains(target)\n ) {\n return;\n }\n switch (this.closeBehavior) {\n case 'outside':\n if (!this.dropdownRef.contains(target)) {\n this.close(event);\n }\n break;\n case 'inside':\n if (this.dropdownRef.contains(target) && this.hostElement !== target) {\n this.close(event);\n }\n break;\n case 'both':\n if (this.hostElement !== target) {\n this.close(event);\n }\n break;\n default:\n this.close(event);\n }\n }\n\n @Listen('keydown', {\n target: 'window',\n })\n keydown(event: KeyboardEvent) {\n if (this.show === true && event.code === 'Escape') {\n this.close();\n }\n }\n\n private isNestedDropdown(element: Element) {\n return element.closest('ix-dropdown');\n }\n\n private isAnchorSubmenu() {\n const anchor = this.anchorElement?.closest('ix-dropdown-item');\n if (!anchor) {\n return false;\n }\n\n return true;\n }\n\n private toggle(event?: Event) {\n event?.preventDefault();\n\n if (this.isNestedDropdown(event.target as HTMLElement)) {\n event?.stopPropagation();\n }\n\n this.show = !this.show;\n this.showChanged.emit(this.show);\n }\n\n private open(event?: Event) {\n event?.preventDefault();\n\n if (this.isNestedDropdown(event.target as HTMLElement)) {\n event?.stopPropagation();\n }\n\n this.show = true;\n this.showChanged.emit(true);\n }\n\n private close(event?: Event) {\n if (event?.defaultPrevented) {\n const target = event.target as HTMLElement;\n if (\n target.contains(this.anchorElement) ||\n target.contains(this.triggerElement) ||\n target.shadowRoot.contains(this.anchorElement) ||\n target.shadowRoot.contains(this.triggerElement)\n )\n return;\n }\n\n this.show = false;\n this.showChanged.emit(false);\n }\n\n private async applyDropdownPosition() {\n if (!this.anchorElement) {\n return;\n }\n if (!this.dropdownRef) {\n return;\n }\n const isSubmenu = this.isAnchorSubmenu();\n\n let positionConfig: Partial<ComputePositionConfig> = {\n strategy: this.positioningStrategy,\n middleware: [],\n };\n\n if (!this.suppressAutomaticPlacement) {\n positionConfig.middleware.push(\n flip({ fallbackStrategy: 'initialPlacement' })\n );\n }\n\n positionConfig.placement = isSubmenu ? 'right-start' : this.placement;\n\n positionConfig.middleware = [\n ...positionConfig.middleware,\n inline(),\n shift(),\n ];\n\n if (this.offset) {\n positionConfig.middleware.push(offset(this.offset));\n }\n\n if (this.autoUpdateCleanup) {\n this.autoUpdateCleanup();\n this.autoUpdateCleanup = null;\n }\n\n this.autoUpdateCleanup = autoUpdate(\n this.anchorElement,\n this.dropdownRef,\n async () => {\n const computeResponse = await computePosition(\n this.anchorElement,\n this.dropdownRef,\n positionConfig\n );\n Object.assign(this.dropdownRef.style, {\n top: '0',\n left: '0',\n transform: `translate(${Math.round(computeResponse.x)}px,${Math.round(\n computeResponse.y\n )}px)`,\n });\n if (this.overwriteDropdownStyle) {\n const overwriteStyle = await this.overwriteDropdownStyle({\n dropdownRef: this.dropdownRef,\n triggerRef: this.triggerElement as HTMLElement,\n });\n\n Object.assign(this.dropdownRef.style, overwriteStyle);\n }\n },\n {\n ancestorResize: true,\n ancestorScroll: true,\n elementResize: true,\n }\n );\n }\n\n async componentDidLoad() {\n if (this.trigger) {\n this.changedTrigger(this.trigger, null);\n }\n }\n\n async componentDidRender() {\n await this.applyDropdownPosition();\n this.anchorElement = await (this.anchor\n ? this.resolveElement(this.anchor)\n : this.resolveElement(this.trigger));\n\n if (\n this.isAnchorSubmenu() &&\n this.anchorElement?.tagName === 'IX-DROPDOWN-ITEM'\n ) {\n (this.anchorElement as HTMLIxDropdownItemElement).isSubMenu = true;\n }\n }\n\n disconnectedCallback() {\n if (this.autoUpdateCleanup) {\n this.autoUpdateCleanup();\n }\n\n if (dropdownDisposer.has(this.localUId)) {\n dropdownDisposer.delete(this.localUId);\n }\n }\n\n /**\n * Update position of dropdown\n */\n @Method()\n async updatePosition() {\n this.applyDropdownPosition();\n }\n\n render() {\n return (\n <Host\n ref={(ref) => (this.dropdownRef = ref)}\n class={{\n 'dropdown-menu': true,\n show: this.show,\n overflow: true,\n }}\n style={{\n margin: '0',\n minWidth: '0px',\n position: this.positioningStrategy,\n }}\n role=\"list\"\n >\n <div style={{ display: 'contents' }}>\n {this.header ? <div class=\"dropdown-header\">{this.header}</div> : ''}\n\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"placement.js","sourceRoot":"","sources":["../../../src/components/dropdown/placement.ts"],"names":[],"mappings":"","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 */\nexport declare const top: 'top';\nexport declare const bottom: 'bottom';\nexport declare const right: 'right';\nexport declare const left: 'left';\n\nexport declare type BasePlacement =\n | typeof top\n | typeof bottom\n | typeof right\n | typeof left;\n\nexport declare type AutoPlacement = 'auto' | 'auto-start' | 'auto-end';\n\nexport declare type PlacementWithAlignment =\n | 'top-start'\n | 'top-end'\n | 'bottom-start'\n | 'bottom-end'\n | 'right-start'\n | 'right-end'\n | 'left-start'\n | 'left-end';\n\nexport declare type Placement =\n | AutoPlacement\n | BasePlacement\n | PlacementWithAlignment;\n"]}
1
+ {"version":3,"file":"placement.js","sourceRoot":"","sources":["../../../src/components/dropdown/placement.ts"],"names":[],"mappings":"","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 */\nexport declare const top: 'top';\nexport declare const bottom: 'bottom';\nexport declare const right: 'right';\nexport declare const left: 'left';\n\nexport type Alignment = 'start' | 'end';\nexport type Side = 'top' | 'right' | 'bottom' | 'left';\nexport type AlignedPlacement = `${Side}-${Alignment}`;\n"]}
@@ -18,14 +18,24 @@
18
18
  /* Font sizes */
19
19
  /* Line heights */
20
20
  /* Animation timings */
21
+ /*
22
+ * SPDX-FileCopyrightText: 2023 Siemens AG
23
+ *
24
+ * SPDX-License-Identifier: MIT
25
+ *
26
+ * This source code is licensed under the MIT license found in the
27
+ * LICENSE file in the root directory of this source tree.
28
+ */
21
29
  :host {
22
30
  display: inline-block;
23
31
  position: relative;
24
32
  height: 2rem;
25
33
  width: auto;
26
34
  }
27
- :host.disabled {
28
- pointer-events: none;
35
+ :host *,
36
+ :host *::after,
37
+ :host *::before {
38
+ box-sizing: border-box;
29
39
  }
30
40
  :host .hide {
31
41
  display: none;
@@ -89,4 +99,8 @@
89
99
  width: auto !important;
90
100
  inset: auto !important;
91
101
  transform: unset !important;
102
+ }
103
+
104
+ :host(.disabled) {
105
+ pointer-events: none;
92
106
  }
@@ -12,7 +12,7 @@ import { h, Host } from '@stencil/core';
12
12
  */
13
13
  export class DropdownButton {
14
14
  constructor() {
15
- this.variant = 'Primary';
15
+ this.variant = 'primary';
16
16
  this.outline = false;
17
17
  this.ghost = false;
18
18
  this.active = false;
@@ -25,8 +25,8 @@ export class DropdownButton {
25
25
  return (h("div", { class: {
26
26
  triangle: true,
27
27
  hide: this.label !== '',
28
- primary: this.variant === 'Primary',
29
- secondary: this.variant === 'Secondary',
28
+ primary: this.variant === 'primary',
29
+ secondary: this.variant === 'secondary',
30
30
  ghost: this.ghost,
31
31
  outline: this.outline,
32
32
  disabled: this.disabled,
@@ -37,10 +37,10 @@ export class DropdownButton {
37
37
  disabled: this.disabled,
38
38
  } }, h("div", { class: "dropdown-button", ref: (ref) => {
39
39
  this.dropdownAnchor = ref;
40
- } }, this.label ? (h("ix-button", { variant: this.variant, outline: this.outline, ghost: this.ghost, disabled: this.disabled }, h("ix-icon", { name: this.icon, size: "24", class: { hide: this.icon === '' || this.icon === undefined } }), h("div", { class: 'button-label' }, this.label), h("ix-icon", { name: "chevron-down-small", size: "24" }))) : (h("div", null, h("ix-icon-button", { icon: this.icon, variant: this.variant, outline: this.outline, ghost: this.ghost, disabled: this.disabled }), this.getTriangle()))), h("ix-dropdown", { class: "dropdown", trigger: this.dropdownAnchor, placement: "bottom", positioningStrategy: 'fixed', adjustDropdownWidthToReferenceWidth: true }, h("slot", null))));
40
+ } }, this.label ? (h("ix-button", { variant: this.variant, outline: this.outline, ghost: this.ghost, disabled: this.disabled }, h("ix-icon", { name: this.icon, size: "24", class: { hide: this.icon === '' || this.icon === undefined } }), h("div", { class: 'button-label' }, this.label), h("ix-icon", { name: "chevron-down-small", size: "24" }))) : (h("div", null, h("ix-icon-button", { icon: this.icon, variant: this.variant, outline: this.outline, ghost: this.ghost, disabled: this.disabled }), this.getTriangle()))), h("ix-dropdown", { class: "dropdown", trigger: this.dropdownAnchor, positioningStrategy: 'fixed' }, h("slot", null))));
41
41
  }
42
42
  static get is() { return "ix-dropdown-button"; }
43
- static get encapsulation() { return "scoped"; }
43
+ static get encapsulation() { return "shadow"; }
44
44
  static get originalStyleUrls() {
45
45
  return {
46
46
  "$": ["dropdown-button.scss"]
@@ -58,7 +58,7 @@ export class DropdownButton {
58
58
  "mutable": false,
59
59
  "complexType": {
60
60
  "original": "DropdownButtonVariant",
61
- "resolved": "\"Primary\" | \"Secondary\"",
61
+ "resolved": "\"primary\" | \"secondary\"",
62
62
  "references": {
63
63
  "DropdownButtonVariant": {
64
64
  "location": "local",
@@ -74,7 +74,7 @@ export class DropdownButton {
74
74
  },
75
75
  "attribute": "variant",
76
76
  "reflect": false,
77
- "defaultValue": "'Primary'"
77
+ "defaultValue": "'primary'"
78
78
  },
79
79
  "outline": {
80
80
  "type": "boolean",
@@ -123,8 +123,11 @@ export class DropdownButton {
123
123
  "required": false,
124
124
  "optional": false,
125
125
  "docs": {
126
- "tags": [],
127
- "text": "Active button"
126
+ "tags": [{
127
+ "name": "deprecated",
128
+ "text": "Will be removed in 3.0.0"
129
+ }],
130
+ "text": "Active button (has no effect)"
128
131
  },
129
132
  "attribute": "active",
130
133
  "reflect": false,
@@ -189,5 +192,6 @@ export class DropdownButton {
189
192
  "dropdownAnchor": {}
190
193
  };
191
194
  }
195
+ static get elementRef() { return "hostElement"; }
192
196
  }
193
197
  //# sourceMappingURL=dropdown-button.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"dropdown-button.js","sourceRoot":"","sources":["../../../src/components/dropdown-button/dropdown-button.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAKhE;;GAEG;AAMH,MAAM,OAAO,cAAc;;mBAIgB,SAAS;mBAKhC,KAAK;iBAKP,KAAK;kBAKJ,KAAK;oBAKH,KAAK;;;;;EAchB,WAAW;IACjB,OAAO,CACL,WACE,KAAK,EAAE;QACL,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,IAAI,CAAC,KAAK,KAAK,EAAE;QACvB,OAAO,EAAE,IAAI,CAAC,OAAO,KAAK,SAAS;QACnC,SAAS,EAAE,IAAI,CAAC,OAAO,KAAK,WAAW;QACvC,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;OACxB,GACI,CACR,CAAC;EACJ,CAAC;EAED,MAAM;IACJ,OAAO,CACL,EAAC,IAAI,IACH,KAAK,EAAE;QACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;OACxB;MAED,WACE,KAAK,EAAC,iBAAiB,EACvB,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE;UACX,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC;QAC5B,CAAC,IAEA,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CACZ,iBACE,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QAEvB,eACE,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,IAAI,EAAC,IAAI,EACT,KAAK,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,EAAE,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,GACnD;QACX,WAAK,KAAK,EAAE,cAAc,IAAG,IAAI,CAAC,KAAK,CAAO;QAC9C,eAAS,IAAI,EAAC,oBAAoB,EAAC,IAAI,EAAC,IAAI,GAAW,CAC7C,CACb,CAAC,CAAC,CAAC,CACF;QACE,sBACE,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,GACP;QACjB,IAAI,CAAC,WAAW,EAAE,CACf,CACP,CACG;MAEN,mBACE,KAAK,EAAC,UAAU,EAChB,OAAO,EAAE,IAAI,CAAC,cAAc,EAC5B,SAAS,EAAC,QAAQ,EAClB,mBAAmB,EAAE,OAAO,EAC5B,mCAAmC,EAAE,IAAI;QAEzC,eAAa,CACD,CACT,CACR,CAAC;EACJ,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, h, Host, Prop, State } from '@stencil/core';\nimport { ButtonVariant } from '../button/button';\n\nexport type DropdownButtonVariant = ButtonVariant;\n\n/**\n * @since 1.3.0\n */\n@Component({\n tag: 'ix-dropdown-button',\n styleUrl: 'dropdown-button.scss',\n scoped: true,\n})\nexport class DropdownButton {\n /**\n * Button variant\n */\n @Prop() variant: DropdownButtonVariant = 'Primary';\n\n /**\n * Outline button\n */\n @Prop() outline = false;\n\n /**\n * Button with no background or outline\n */\n @Prop() ghost = false;\n\n /**\n * Active button\n */\n @Prop() active = false;\n\n /**\n * Disable button\n */\n @Prop() disabled = false;\n\n /**\n * Set label\n */\n @Prop() label: string;\n\n /**\n * Button icon\n */\n @Prop() icon: string;\n\n @State() dropdownAnchor!: HTMLElement;\n\n private getTriangle() {\n return (\n <div\n class={{\n triangle: true,\n hide: this.label !== '',\n primary: this.variant === 'Primary',\n secondary: this.variant === 'Secondary',\n ghost: this.ghost,\n outline: this.outline,\n disabled: this.disabled,\n }}\n ></div>\n );\n }\n\n render() {\n return (\n <Host\n class={{\n disabled: this.disabled,\n }}\n >\n <div\n class=\"dropdown-button\"\n ref={(ref) => {\n this.dropdownAnchor = ref;\n }}\n >\n {this.label ? (\n <ix-button\n variant={this.variant}\n outline={this.outline}\n ghost={this.ghost}\n disabled={this.disabled}\n >\n <ix-icon\n name={this.icon}\n size=\"24\"\n class={{ hide: this.icon === '' || this.icon === undefined }}\n ></ix-icon>\n <div class={'button-label'}>{this.label}</div>\n <ix-icon name=\"chevron-down-small\" size=\"24\"></ix-icon>\n </ix-button>\n ) : (\n <div>\n <ix-icon-button\n icon={this.icon}\n variant={this.variant}\n outline={this.outline}\n ghost={this.ghost}\n disabled={this.disabled}\n ></ix-icon-button>\n {this.getTriangle()}\n </div>\n )}\n </div>\n\n <ix-dropdown\n class=\"dropdown\"\n trigger={this.dropdownAnchor}\n placement=\"bottom\"\n positioningStrategy={'fixed'}\n adjustDropdownWidthToReferenceWidth={true}\n >\n <slot></slot>\n </ix-dropdown>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"dropdown-button.js","sourceRoot":"","sources":["../../../src/components/dropdown-button/dropdown-button.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAKzE;;GAEG;AAMH,MAAM,OAAO,cAAc;;mBAMgB,SAAS;mBAKhC,KAAK;iBAKP,KAAK;kBAMJ,KAAK;oBAKH,KAAK;;;;;EAchB,WAAW;IACjB,OAAO,CACL,WACE,KAAK,EAAE;QACL,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,IAAI,CAAC,KAAK,KAAK,EAAE;QACvB,OAAO,EAAE,IAAI,CAAC,OAAO,KAAK,SAAS;QACnC,SAAS,EAAE,IAAI,CAAC,OAAO,KAAK,WAAW;QACvC,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,OAAO,EAAE,IAAI,CAAC,OAAO;QACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;OACxB,GACI,CACR,CAAC;EACJ,CAAC;EAED,MAAM;IACJ,OAAO,CACL,EAAC,IAAI,IACH,KAAK,EAAE;QACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;OACxB;MAED,WACE,KAAK,EAAC,iBAAiB,EACvB,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE;UACX,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC;QAC5B,CAAC,IAEA,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CACZ,iBACE,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QAEvB,eACE,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,IAAI,EAAC,IAAI,EACT,KAAK,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,EAAE,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,GACnD;QACX,WAAK,KAAK,EAAE,cAAc,IAAG,IAAI,CAAC,KAAK,CAAO;QAC9C,eAAS,IAAI,EAAC,oBAAoB,EAAC,IAAI,EAAC,IAAI,GAAW,CAC7C,CACb,CAAC,CAAC,CAAC,CACF;QACE,sBACE,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,GACP;QACjB,IAAI,CAAC,WAAW,EAAE,CACf,CACP,CACG;MAEN,mBACE,KAAK,EAAC,UAAU,EAChB,OAAO,EAAE,IAAI,CAAC,cAAc,EAC5B,mBAAmB,EAAE,OAAO;QAE5B,eAAa,CACD,CACT,CACR,CAAC;EACJ,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, Element, h, Host, Prop, State } from '@stencil/core';\nimport { ButtonVariant } from '../button/button';\n\nexport type DropdownButtonVariant = ButtonVariant;\n\n/**\n * @since 1.3.0\n */\n@Component({\n tag: 'ix-dropdown-button',\n styleUrl: 'dropdown-button.scss',\n shadow: true,\n})\nexport class DropdownButton {\n @Element() hostElement!: HTMLIxDropdownButtonElement;\n\n /**\n * Button variant\n */\n @Prop() variant: DropdownButtonVariant = 'primary';\n\n /**\n * Outline button\n */\n @Prop() outline = false;\n\n /**\n * Button with no background or outline\n */\n @Prop() ghost = false;\n\n /**\n * Active button (has no effect)\n * @deprecated Will be removed in 3.0.0\n */\n @Prop() active = false;\n\n /**\n * Disable button\n */\n @Prop() disabled = false;\n\n /**\n * Set label\n */\n @Prop() label: string;\n\n /**\n * Button icon\n */\n @Prop() icon: string;\n\n @State() dropdownAnchor!: HTMLElement;\n\n private getTriangle() {\n return (\n <div\n class={{\n triangle: true,\n hide: this.label !== '',\n primary: this.variant === 'primary',\n secondary: this.variant === 'secondary',\n ghost: this.ghost,\n outline: this.outline,\n disabled: this.disabled,\n }}\n ></div>\n );\n }\n\n render() {\n return (\n <Host\n class={{\n disabled: this.disabled,\n }}\n >\n <div\n class=\"dropdown-button\"\n ref={(ref) => {\n this.dropdownAnchor = ref;\n }}\n >\n {this.label ? (\n <ix-button\n variant={this.variant}\n outline={this.outline}\n ghost={this.ghost}\n disabled={this.disabled}\n >\n <ix-icon\n name={this.icon}\n size=\"24\"\n class={{ hide: this.icon === '' || this.icon === undefined }}\n ></ix-icon>\n <div class={'button-label'}>{this.label}</div>\n <ix-icon name=\"chevron-down-small\" size=\"24\"></ix-icon>\n </ix-button>\n ) : (\n <div>\n <ix-icon-button\n icon={this.icon}\n variant={this.variant}\n outline={this.outline}\n ghost={this.ghost}\n disabled={this.disabled}\n ></ix-icon-button>\n {this.getTriangle()}\n </div>\n )}\n </div>\n\n <ix-dropdown\n class=\"dropdown\"\n trigger={this.dropdownAnchor}\n positioningStrategy={'fixed'}\n >\n <slot></slot>\n </ix-dropdown>\n </Host>\n );\n }\n}\n"]}
@@ -0,0 +1,32 @@
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
11
+ *
12
+ * SPDX-License-Identifier: MIT
13
+ *
14
+ * This source code is licensed under the MIT license found in the
15
+ * LICENSE file in the root directory of this source tree.
16
+ */
17
+ :host {
18
+ display: flex;
19
+ align-items: center;
20
+ position: relative;
21
+ height: 2.5rem;
22
+ width: auto;
23
+ padding: 0.25rem 1rem;
24
+ overflow: hidden;
25
+ cursor: default;
26
+ color: var(--theme-color-soft-text);
27
+ }
28
+ :host *,
29
+ :host *::after,
30
+ :host *::before {
31
+ box-sizing: border-box;
32
+ }
@@ -7,24 +7,26 @@
7
7
  * LICENSE file in the root directory of this source tree.
8
8
  */
9
9
  import { h, Host } from '@stencil/core';
10
- export class GroupDropdownItem {
10
+ /**
11
+ * @since 2.0.0
12
+ */
13
+ export class DropdownHeader {
11
14
  constructor() {
12
15
  this.label = undefined;
13
- this.icon = undefined;
14
16
  }
15
17
  render() {
16
- return (h(Host, null, h("ix-dropdown-item", { label: this.label, icon: this.icon }, h("slot", null))));
18
+ return (h(Host, null, h("ix-typography", { class: 'category-text', variant: 'default-title' }, this.label)));
17
19
  }
18
- static get is() { return "ix-group-dropdown-item"; }
19
- static get encapsulation() { return "scoped"; }
20
+ static get is() { return "ix-dropdown-header"; }
21
+ static get encapsulation() { return "shadow"; }
20
22
  static get originalStyleUrls() {
21
23
  return {
22
- "$": ["group-dropdown-item.scss"]
24
+ "$": ["dropdown-header.scss"]
23
25
  };
24
26
  }
25
27
  static get styleUrls() {
26
28
  return {
27
- "$": ["group-dropdown-item.css"]
29
+ "$": ["dropdown-header.css"]
28
30
  };
29
31
  }
30
32
  static get properties() {
@@ -41,29 +43,12 @@ export class GroupDropdownItem {
41
43
  "optional": false,
42
44
  "docs": {
43
45
  "tags": [],
44
- "text": "Group dropdown label"
46
+ "text": "Display name of the header"
45
47
  },
46
48
  "attribute": "label",
47
49
  "reflect": false
48
- },
49
- "icon": {
50
- "type": "string",
51
- "mutable": false,
52
- "complexType": {
53
- "original": "string",
54
- "resolved": "string",
55
- "references": {}
56
- },
57
- "required": false,
58
- "optional": false,
59
- "docs": {
60
- "tags": [],
61
- "text": "Group dropdown icon"
62
- },
63
- "attribute": "icon",
64
- "reflect": false
65
50
  }
66
51
  };
67
52
  }
68
53
  }
69
- //# sourceMappingURL=group-dropdown-item.js.map
54
+ //# sourceMappingURL=dropdown-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdown-header.js","sourceRoot":"","sources":["../../../src/components/dropdown-header/dropdown-header.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAEzD;;GAEG;AAMH,MAAM,OAAO,cAAc;;;;EAMzB,MAAM;IACJ,OAAO,CACL,EAAC,IAAI;MACH,qBAAe,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,eAAe,IAC5D,IAAI,CAAC,KAAK,CACG,CACX,CACR,CAAC;EACJ,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, h, Host, Prop } from '@stencil/core';\n\n/**\n * @since 2.0.0\n */\n@Component({\n tag: 'ix-dropdown-header',\n styleUrl: 'dropdown-header.scss',\n shadow: true,\n})\nexport class DropdownHeader {\n /**\n * Display name of the header\n */\n @Prop() label: string;\n\n render() {\n return (\n <Host>\n <ix-typography class={'category-text'} variant={'default-title'}>\n {this.label}\n </ix-typography>\n </Host>\n );\n }\n}\n"]}