@siemens/ix 0.0.0-pr-1318-20240627080522 → 0.0.0-pr-1522-20241021144048

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 (1498) hide show
  1. package/components/a11y.js +3 -4
  2. package/components/a11y.js.map +1 -1
  3. package/components/application-header.js +51 -15
  4. package/components/application-header.js.map +1 -1
  5. package/components/avatar.js +1 -1
  6. package/components/avatar.js.map +1 -1
  7. package/components/base-button.js +2 -2
  8. package/components/base-button.js.map +1 -1
  9. package/components/button.js +2 -2
  10. package/components/button.js.map +1 -1
  11. package/components/card-accordion.js +6 -6
  12. package/components/card-accordion.js.map +1 -1
  13. package/components/card-content.js +1 -1
  14. package/components/card-title.js +1 -1
  15. package/components/card.js +4 -4
  16. package/components/card.js.map +1 -1
  17. package/components/col.js +1 -1
  18. package/components/col.js.map +1 -1
  19. package/components/context.js +6 -3
  20. package/components/context.js.map +1 -1
  21. package/components/date-picker.js +53 -41
  22. package/components/date-picker.js.map +1 -1
  23. package/components/date-time-card.js +2 -2
  24. package/components/date-time-card.js.map +1 -1
  25. package/components/divider.js +1 -1
  26. package/{dist/esm/dropdown-controller-d6d8b14a.js → components/dropdown-controller.js} +16 -11
  27. package/components/dropdown-controller.js.map +1 -0
  28. package/components/dropdown-item.js +4 -4
  29. package/components/dropdown-item.js.map +1 -1
  30. package/components/dropdown.js +120 -206
  31. package/components/dropdown.js.map +1 -1
  32. package/components/filter-chip.js +1 -1
  33. package/components/floating-ui.dom.esm.js +533 -60
  34. package/components/floating-ui.dom.esm.js.map +1 -1
  35. package/components/group-context-menu.js +1 -1
  36. package/components/group-context-menu.js.map +1 -1
  37. package/components/group-item.js +4 -8
  38. package/components/group-item.js.map +1 -1
  39. package/components/icon-button.js +1 -1
  40. package/components/index.js +5 -19
  41. package/components/index.js.map +1 -1
  42. package/components/ix-action-card.js +1 -1
  43. package/components/ix-action-card.js.map +1 -1
  44. package/components/ix-application-sidebar.js +1 -1
  45. package/components/ix-application-switch-modal.js +1 -1
  46. package/components/ix-application.js +4 -4
  47. package/components/ix-application.js.map +1 -1
  48. package/components/ix-basic-navigation.js +18 -12
  49. package/components/ix-basic-navigation.js.map +1 -1
  50. package/components/ix-blind.js +5 -5
  51. package/components/ix-blind.js.map +1 -1
  52. package/components/ix-breadcrumb.js +9 -10
  53. package/components/ix-breadcrumb.js.map +1 -1
  54. package/components/ix-card-list.js +6 -6
  55. package/components/ix-card-list.js.map +1 -1
  56. package/components/ix-category-filter.js +129 -71
  57. package/components/ix-category-filter.js.map +1 -1
  58. package/components/ix-chip.js +4 -4
  59. package/components/ix-chip.js.map +1 -1
  60. package/components/ix-content-header.js +2 -2
  61. package/components/ix-content-header.js.map +1 -1
  62. package/components/ix-content.js +3 -3
  63. package/components/ix-css-grid-item.js +1 -1
  64. package/components/ix-css-grid.js +8 -3
  65. package/components/ix-css-grid.js.map +1 -1
  66. package/components/ix-date-dropdown.js +25 -16
  67. package/components/ix-date-dropdown.js.map +1 -1
  68. package/components/ix-datetime-picker.js +1 -1
  69. package/components/ix-drawer.js +2 -2
  70. package/components/ix-dropdown-button.js +5 -7
  71. package/components/ix-dropdown-button.js.map +1 -1
  72. package/components/ix-dropdown-header.js +1 -1
  73. package/components/ix-dropdown-header.js.map +1 -1
  74. package/components/ix-dropdown-quick-actions.js +1 -1
  75. package/components/ix-empty-state.js +1 -1
  76. package/components/ix-empty-state.js.map +1 -1
  77. package/components/ix-event-list-item.js +4 -4
  78. package/components/ix-event-list.js +2 -2
  79. package/components/ix-expanding-search.js +4 -4
  80. package/components/ix-flip-tile-content.js +1 -1
  81. package/components/ix-flip-tile.js +4 -4
  82. package/components/{ix-text-field.d.ts → ix-form-field.d.ts} +4 -4
  83. package/components/ix-form-field.js +44 -0
  84. package/components/ix-form-field.js.map +1 -0
  85. package/components/ix-group.js +69 -44
  86. package/components/ix-group.js.map +1 -1
  87. package/components/ix-icon-toggle-button.js +1 -2
  88. package/components/ix-icon-toggle-button.js.map +1 -1
  89. package/components/ix-input-group.js +1 -1
  90. package/components/ix-key-value-list.js +1 -1
  91. package/components/ix-key-value.js +1 -1
  92. package/components/ix-kpi.js +3 -3
  93. package/components/ix-kpi.js.map +1 -1
  94. package/components/ix-link-button.js +3 -3
  95. package/components/ix-map-navigation.js +21 -15
  96. package/components/ix-map-navigation.js.map +1 -1
  97. package/components/ix-menu-about-item.js +1 -1
  98. package/components/ix-menu-about-news.js +4 -4
  99. package/components/ix-menu-about-news.js.map +1 -1
  100. package/components/ix-menu-about.js +1 -1
  101. package/components/ix-menu-avatar.js +2 -2
  102. package/components/ix-menu-category.js +5 -5
  103. package/components/ix-menu-category.js.map +1 -1
  104. package/components/ix-menu-settings-item.js +1 -1
  105. package/components/ix-menu.js +12 -12
  106. package/components/ix-menu.js.map +1 -1
  107. package/components/ix-message-bar.js +1 -1
  108. package/components/ix-modal-example.js +1 -1
  109. package/components/ix-modal-footer.js +1 -1
  110. package/components/ix-modal-loading.js +1 -1
  111. package/components/ix-modal.js +11 -4
  112. package/components/ix-modal.js.map +1 -1
  113. package/components/ix-pagination.js +17 -35
  114. package/components/ix-pagination.js.map +1 -1
  115. package/components/ix-pane-layout.js +1 -1
  116. package/components/ix-pane.js +6 -6
  117. package/components/ix-pane.js.map +1 -1
  118. package/components/ix-pill.js +4 -4
  119. package/components/ix-pill.js.map +1 -1
  120. package/components/ix-playground-internal.js +1 -1
  121. package/components/ix-playground-internal.js.map +1 -1
  122. package/components/ix-push-card.js +1 -1
  123. package/components/ix-push-card.js.map +1 -1
  124. package/components/ix-slider.js +21 -14
  125. package/components/ix-slider.js.map +1 -1
  126. package/components/ix-split-button-item.js +1 -1
  127. package/components/ix-split-button.js +1 -1
  128. package/components/ix-tile.js +4 -4
  129. package/components/ix-tile.js.map +1 -1
  130. package/components/ix-toast-container.js +2 -2
  131. package/components/ix-toast-container.js.map +1 -1
  132. package/components/ix-toggle-button.js +2 -2
  133. package/components/ix-toggle.js +5 -43
  134. package/components/ix-toggle.js.map +1 -1
  135. package/components/ix-tree.js +21 -7
  136. package/components/ix-tree.js.map +1 -1
  137. package/components/ix-upload.js +60 -4
  138. package/components/ix-upload.js.map +1 -1
  139. package/components/ix-validation-tooltip.js +2 -2
  140. package/components/ix-workflow-step.js +3 -3
  141. package/components/ix-workflow-step.js.map +1 -1
  142. package/components/ix-workflow-steps.js +1 -1
  143. package/components/ix-workflow-steps.js.map +1 -1
  144. package/components/layout-grid.js +2 -2
  145. package/components/layout-grid.js.map +1 -1
  146. package/components/listener.js +2 -2
  147. package/components/listener.js.map +1 -1
  148. package/components/logical-filter-operator.js +1 -1
  149. package/components/logical-filter-operator.js.map +1 -1
  150. package/components/make-ref.js +7 -17
  151. package/components/make-ref.js.map +1 -1
  152. package/components/map-navigation-overlay.js +2 -2
  153. package/components/menu-avatar-item.js +1 -1
  154. package/components/menu-expand-icon.js +1 -1
  155. package/components/menu-expand-icon.js.map +1 -1
  156. package/components/menu-item.js +14 -14
  157. package/components/menu-item.js.map +1 -1
  158. package/components/menu-tabs-fc.js +17 -14
  159. package/components/menu-tabs-fc.js.map +1 -1
  160. package/components/modal-content.js +2 -2
  161. package/components/modal-content.js.map +1 -1
  162. package/components/modal-header.js +2 -2
  163. package/components/modal-header.js.map +1 -1
  164. package/components/row.js +1 -1
  165. package/components/row.js.map +1 -1
  166. package/components/select-item.js +1 -1
  167. package/components/select.js +117 -203
  168. package/components/select.js.map +1 -1
  169. package/components/service.js +2 -2
  170. package/components/service.js.map +1 -1
  171. package/components/shadow-dom.js +1 -1
  172. package/components/shadow-dom.js.map +1 -1
  173. package/components/spinner.js +1 -1
  174. package/components/tab-item.js +3 -3
  175. package/components/tab-item.js.map +1 -1
  176. package/components/tabs.js +77 -43
  177. package/components/tabs.js.map +1 -1
  178. package/components/theme-switcher.js +1 -0
  179. package/components/theme-switcher.js.map +1 -1
  180. package/components/time-picker.js +4 -4
  181. package/components/time-picker.js.map +1 -1
  182. package/components/toast.js +2 -2
  183. package/components/toast.js.map +1 -1
  184. package/components/tooltip.js +25 -23
  185. package/components/tooltip.js.map +1 -1
  186. package/components/tree-item.js +8 -8
  187. package/components/tree-item.js.map +1 -1
  188. package/components/typography.js +3 -25
  189. package/components/typography.js.map +1 -1
  190. package/dist/cjs/{a11y-32046b56.js → a11y-eba397e8.js} +4 -5
  191. package/dist/cjs/a11y-eba397e8.js.map +1 -0
  192. package/dist/cjs/{base-button-16d4fadf.js → base-button-a472cf2f.js} +4 -4
  193. package/dist/cjs/base-button-a472cf2f.js.map +1 -0
  194. package/dist/cjs/{base-icon-button-aba2ddbf.js → base-icon-button-9ff5faad.js} +3 -3
  195. package/dist/cjs/{base-icon-button-aba2ddbf.js.map → base-icon-button-9ff5faad.js.map} +1 -1
  196. package/dist/cjs/{context-98f4a0b3.js → context-6644f454.js} +7 -4
  197. package/dist/cjs/context-6644f454.js.map +1 -0
  198. package/dist/cjs/disposable-event-listener-1ed769b9.js +20 -0
  199. package/dist/cjs/disposable-event-listener-1ed769b9.js.map +1 -0
  200. package/dist/cjs/{dropdown-controller-403dc7fa.js → dropdown-controller-1781ef55.js} +15 -11
  201. package/dist/cjs/dropdown-controller-1781ef55.js.map +1 -0
  202. package/dist/cjs/{floating-ui.dom.esm-94b4d17c.js → floating-ui.dom.esm-9dde6cd6.js} +534 -60
  203. package/dist/cjs/floating-ui.dom.esm-9dde6cd6.js.map +1 -0
  204. package/dist/cjs/{focus-9c8ffbb0.js → focus-83f8f1ba.js} +21 -18
  205. package/dist/cjs/focus-83f8f1ba.js.map +1 -0
  206. package/dist/cjs/{index-0f6297c8.js → index-529f21c1.js} +156 -78
  207. package/dist/cjs/index-529f21c1.js.map +1 -0
  208. package/dist/cjs/index.cjs.js +4 -19
  209. package/dist/cjs/index.cjs.js.map +1 -1
  210. package/dist/cjs/ix-action-card.cjs.entry.js +2 -2
  211. package/dist/cjs/ix-action-card.cjs.entry.js.map +1 -1
  212. package/dist/cjs/ix-application-header.cjs.entry.js +36 -10
  213. package/dist/cjs/ix-application-header.cjs.entry.js.map +1 -1
  214. package/dist/cjs/ix-application-sidebar.cjs.entry.js +2 -2
  215. package/dist/cjs/ix-application-switch-modal.cjs.entry.js +2 -2
  216. package/dist/cjs/ix-application.cjs.entry.js +9 -9
  217. package/dist/cjs/ix-application.cjs.entry.js.map +1 -1
  218. package/dist/cjs/ix-avatar_2.cjs.entry.js +6 -6
  219. package/dist/cjs/ix-avatar_2.cjs.entry.js.map +1 -1
  220. package/dist/cjs/ix-basic-navigation.cjs.entry.js +5 -5
  221. package/dist/cjs/ix-basic-navigation.cjs.entry.js.map +1 -1
  222. package/dist/cjs/ix-blind.cjs.entry.js +7 -7
  223. package/dist/cjs/ix-blind.cjs.entry.js.map +1 -1
  224. package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +3 -3
  225. package/dist/cjs/ix-breadcrumb.cjs.entry.js +11 -10
  226. package/dist/cjs/ix-breadcrumb.cjs.entry.js.map +1 -1
  227. package/dist/cjs/ix-button.cjs.entry.js +4 -4
  228. package/dist/cjs/ix-button.cjs.entry.js.map +1 -1
  229. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +8 -8
  230. package/dist/cjs/ix-card-accordion_2.cjs.entry.js.map +1 -1
  231. package/dist/cjs/ix-card-list.cjs.entry.js +7 -7
  232. package/dist/cjs/ix-card-list.cjs.entry.js.map +1 -1
  233. package/dist/cjs/ix-card_2.cjs.entry.js +6 -6
  234. package/dist/cjs/ix-card_2.cjs.entry.js.map +1 -1
  235. package/dist/cjs/ix-category-filter.cjs.entry.js +132 -72
  236. package/dist/cjs/ix-category-filter.cjs.entry.js.map +1 -1
  237. package/dist/cjs/ix-chip.cjs.entry.js +5 -5
  238. package/dist/cjs/ix-chip.cjs.entry.js.map +1 -1
  239. package/dist/cjs/ix-col_4.cjs.entry.js +59 -43
  240. package/dist/cjs/ix-col_4.cjs.entry.js.map +1 -1
  241. package/dist/cjs/ix-content-header.cjs.entry.js +3 -3
  242. package/dist/cjs/ix-content-header.cjs.entry.js.map +1 -1
  243. package/dist/cjs/ix-content.cjs.entry.js +5 -5
  244. package/dist/cjs/ix-css-grid-item.cjs.entry.js +2 -2
  245. package/dist/cjs/ix-css-grid.cjs.entry.js +9 -4
  246. package/dist/cjs/ix-css-grid.cjs.entry.js.map +1 -1
  247. package/dist/cjs/ix-date-dropdown.cjs.entry.js +26 -16
  248. package/dist/cjs/ix-date-dropdown.cjs.entry.js.map +1 -1
  249. package/dist/cjs/ix-date-time-card.cjs.entry.js +2 -2
  250. package/dist/cjs/ix-date-time-card.cjs.entry.js.map +1 -1
  251. package/dist/cjs/ix-datetime-picker.cjs.entry.js +2 -2
  252. package/dist/cjs/ix-divider.cjs.entry.js +2 -2
  253. package/dist/cjs/ix-drawer.cjs.entry.js +3 -3
  254. package/dist/cjs/ix-dropdown-button.cjs.entry.js +5 -6
  255. package/dist/cjs/ix-dropdown-button.cjs.entry.js.map +1 -1
  256. package/dist/cjs/ix-dropdown-header.cjs.entry.js +2 -2
  257. package/dist/cjs/ix-dropdown-header.cjs.entry.js.map +1 -1
  258. package/dist/cjs/ix-dropdown-item.cjs.entry.js +5 -5
  259. package/dist/cjs/ix-dropdown-item.cjs.entry.js.map +1 -1
  260. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +2 -2
  261. package/dist/cjs/ix-dropdown.cjs.entry.js +87 -49
  262. package/dist/cjs/ix-dropdown.cjs.entry.js.map +1 -1
  263. package/dist/cjs/ix-empty-state.cjs.entry.js +2 -2
  264. package/dist/cjs/ix-empty-state.cjs.entry.js.map +1 -1
  265. package/dist/cjs/ix-event-list-item.cjs.entry.js +6 -6
  266. package/dist/cjs/ix-event-list.cjs.entry.js +3 -3
  267. package/dist/cjs/ix-expanding-search.cjs.entry.js +5 -5
  268. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +3 -3
  269. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +2 -2
  270. package/dist/cjs/ix-flip-tile.cjs.entry.js +5 -5
  271. package/dist/cjs/ix-form-field.cjs.entry.js +28 -0
  272. package/dist/cjs/ix-form-field.cjs.entry.js.map +1 -0
  273. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +7 -11
  274. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js.map +1 -1
  275. package/dist/cjs/ix-group.cjs.entry.js +69 -45
  276. package/dist/cjs/ix-group.cjs.entry.js.map +1 -1
  277. package/dist/cjs/ix-icon-button_2.cjs.entry.js +6 -6
  278. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +5 -6
  279. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js.map +1 -1
  280. package/dist/cjs/ix-input-group.cjs.entry.js +3 -3
  281. package/dist/cjs/ix-key-value-list.cjs.entry.js +2 -2
  282. package/dist/cjs/ix-key-value.cjs.entry.js +2 -2
  283. package/dist/cjs/ix-kpi.cjs.entry.js +4 -4
  284. package/dist/cjs/ix-kpi.cjs.entry.js.map +1 -1
  285. package/dist/cjs/ix-link-button.cjs.entry.js +4 -4
  286. package/dist/cjs/ix-map-navigation-overlay.cjs.entry.js +3 -3
  287. package/dist/cjs/ix-map-navigation.cjs.entry.js +5 -5
  288. package/dist/cjs/ix-map-navigation.cjs.entry.js.map +1 -1
  289. package/dist/cjs/ix-menu-about-item.cjs.entry.js +2 -2
  290. package/dist/cjs/ix-menu-about-news.cjs.entry.js +5 -5
  291. package/dist/cjs/ix-menu-about-news.cjs.entry.js.map +1 -1
  292. package/dist/cjs/ix-menu-about.cjs.entry.js +3 -3
  293. package/dist/cjs/ix-menu-avatar.cjs.entry.js +4 -4
  294. package/dist/cjs/ix-menu-category.cjs.entry.js +7 -7
  295. package/dist/cjs/ix-menu-category.cjs.entry.js.map +1 -1
  296. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +4 -4
  297. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js.map +1 -1
  298. package/dist/cjs/ix-menu-item.cjs.entry.js +15 -15
  299. package/dist/cjs/ix-menu-item.cjs.entry.js.map +1 -1
  300. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +2 -2
  301. package/dist/cjs/ix-menu-settings.cjs.entry.js +2 -2
  302. package/dist/cjs/ix-menu.cjs.entry.js +16 -16
  303. package/dist/cjs/ix-menu.cjs.entry.js.map +1 -1
  304. package/dist/cjs/ix-message-bar.cjs.entry.js +2 -2
  305. package/dist/cjs/ix-modal-content_2.cjs.entry.js +6 -6
  306. package/dist/cjs/ix-modal-content_2.cjs.entry.js.map +1 -1
  307. package/dist/cjs/ix-modal-example.cjs.entry.js +2 -2
  308. package/dist/cjs/ix-modal-footer.cjs.entry.js +2 -2
  309. package/dist/cjs/ix-modal-loading.cjs.entry.js +2 -2
  310. package/dist/cjs/ix-modal.cjs.entry.js +14 -7
  311. package/dist/cjs/ix-modal.cjs.entry.js.map +1 -1
  312. package/dist/cjs/ix-pagination.cjs.entry.js +6 -6
  313. package/dist/cjs/ix-pagination.cjs.entry.js.map +1 -1
  314. package/dist/cjs/ix-pane-layout.cjs.entry.js +3 -3
  315. package/dist/cjs/ix-pane.cjs.entry.js +8 -8
  316. package/dist/cjs/ix-pane.cjs.entry.js.map +1 -1
  317. package/dist/cjs/ix-pill.cjs.entry.js +5 -5
  318. package/dist/cjs/ix-pill.cjs.entry.js.map +1 -1
  319. package/dist/cjs/ix-playground-internal.cjs.entry.js +2 -2
  320. package/dist/cjs/ix-playground-internal.cjs.entry.js.map +1 -1
  321. package/dist/cjs/ix-push-card.cjs.entry.js +2 -2
  322. package/dist/cjs/ix-push-card.cjs.entry.js.map +1 -1
  323. package/dist/cjs/ix-select.cjs.entry.js +108 -157
  324. package/dist/cjs/ix-select.cjs.entry.js.map +1 -1
  325. package/dist/cjs/ix-slider.cjs.entry.js +24 -17
  326. package/dist/cjs/ix-slider.cjs.entry.js.map +1 -1
  327. package/dist/cjs/ix-split-button-item.cjs.entry.js +3 -3
  328. package/dist/cjs/ix-split-button.cjs.entry.js +2 -2
  329. package/dist/cjs/ix-tab-item_2.cjs.entry.js +75 -45
  330. package/dist/cjs/ix-tab-item_2.cjs.entry.js.map +1 -1
  331. package/dist/cjs/ix-tile.cjs.entry.js +5 -5
  332. package/dist/cjs/ix-tile.cjs.entry.js.map +1 -1
  333. package/dist/cjs/ix-time-picker.cjs.entry.js +5 -5
  334. package/dist/cjs/ix-time-picker.cjs.entry.js.map +1 -1
  335. package/dist/cjs/ix-toast-container.cjs.entry.js +3 -3
  336. package/dist/cjs/ix-toast-container.cjs.entry.js.map +1 -1
  337. package/dist/cjs/ix-toast.cjs.entry.js +3 -3
  338. package/dist/cjs/ix-toast.cjs.entry.js.map +1 -1
  339. package/dist/cjs/ix-toggle-button.cjs.entry.js +5 -5
  340. package/dist/cjs/ix-toggle.cjs.entry.js +5 -42
  341. package/dist/cjs/ix-toggle.cjs.entry.js.map +1 -1
  342. package/dist/cjs/ix-tooltip.cjs.entry.js +299 -0
  343. package/dist/cjs/ix-tooltip.cjs.entry.js.map +1 -0
  344. package/dist/cjs/ix-tree-item.cjs.entry.js +9 -9
  345. package/dist/cjs/ix-tree-item.cjs.entry.js.map +1 -1
  346. package/dist/cjs/ix-tree.cjs.entry.js +22 -8
  347. package/dist/cjs/ix-tree.cjs.entry.js.map +1 -1
  348. package/dist/cjs/ix-typography.cjs.entry.js +4 -25
  349. package/dist/cjs/ix-typography.cjs.entry.js.map +1 -1
  350. package/dist/cjs/ix-upload.cjs.entry.js +59 -5
  351. package/dist/cjs/ix-upload.cjs.entry.js.map +1 -1
  352. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +4 -4
  353. package/dist/cjs/ix-workflow-step.cjs.entry.js +4 -4
  354. package/dist/cjs/ix-workflow-step.cjs.entry.js.map +1 -1
  355. package/dist/cjs/ix-workflow-steps.cjs.entry.js +2 -2
  356. package/dist/cjs/ix-workflow-steps.cjs.entry.js.map +1 -1
  357. package/dist/cjs/{listener-0881dc51.js → listener-164d1a4a.js} +4 -4
  358. package/dist/cjs/listener-164d1a4a.js.map +1 -0
  359. package/dist/cjs/loader.cjs.js +2 -2
  360. package/dist/cjs/{logical-filter-operator-5564322e.js → logical-filter-operator-4917393f.js} +2 -2
  361. package/dist/cjs/{logical-filter-operator-5564322e.js.map → logical-filter-operator-4917393f.js.map} +1 -1
  362. package/dist/cjs/{make-ref-01530e5a.js → make-ref-499e1e41.js} +8 -18
  363. package/dist/cjs/make-ref-499e1e41.js.map +1 -0
  364. package/dist/cjs/{menu-tabs-fc-f6b706e3.js → menu-tabs-fc-b532aeb4.js} +19 -16
  365. package/dist/cjs/menu-tabs-fc-b532aeb4.js.map +1 -0
  366. package/dist/cjs/{service-a42add5f.js → service-39a8e5fe.js} +3 -3
  367. package/dist/cjs/service-39a8e5fe.js.map +1 -0
  368. package/dist/cjs/{shadow-dom-73f9d553.js → shadow-dom-454acc38.js} +2 -2
  369. package/dist/cjs/{shadow-dom-73f9d553.js.map → shadow-dom-454acc38.js.map} +1 -1
  370. package/dist/cjs/siemens-ix.cjs.js +2 -2
  371. package/dist/cjs/{theme-switcher-2d2bde85.js → theme-switcher-88b70d73.js} +2 -1
  372. package/dist/cjs/theme-switcher-88b70d73.js.map +1 -0
  373. package/dist/collection/collection-manifest.json +1 -13
  374. package/dist/collection/components/action-card/action-card.js +8 -5
  375. package/dist/collection/components/action-card/action-card.js.map +1 -1
  376. package/dist/collection/components/application/application.css +26 -6
  377. package/dist/collection/components/application/application.js +3 -3
  378. package/dist/collection/components/application/application.js.map +1 -1
  379. package/dist/collection/components/application-header/application-header.css +9 -7
  380. package/dist/collection/components/application-header/application-header.js +78 -6
  381. package/dist/collection/components/application-header/application-header.js.map +1 -1
  382. package/dist/collection/components/application-header/application-switch-modal/application-switch-modal.js +1 -1
  383. package/dist/collection/components/application-sidebar/application-sidebar.js +1 -1
  384. package/dist/collection/components/avatar/avatar.css +42 -0
  385. package/dist/collection/components/basic-navigation/basic-navigation.js +7 -4
  386. package/dist/collection/components/basic-navigation/basic-navigation.js.map +1 -1
  387. package/dist/collection/components/blind/blind.css +1 -1
  388. package/dist/collection/components/blind/blind.js +10 -10
  389. package/dist/collection/components/blind/blind.js.map +1 -1
  390. package/dist/collection/components/blind/test/blind.ct.js +1 -1
  391. package/dist/collection/components/blind/test/blind.ct.js.map +1 -1
  392. package/dist/collection/components/breadcrumb/breadcrumb.js +9 -10
  393. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  394. package/dist/collection/components/button/base-button.js +2 -2
  395. package/dist/collection/components/button/base-button.js.map +1 -1
  396. package/dist/collection/components/button/button.js +3 -3
  397. package/dist/collection/components/button/button.js.map +1 -1
  398. package/dist/collection/components/card/card.css +3 -3
  399. package/dist/collection/components/card/card.js +10 -6
  400. package/dist/collection/components/card/card.js.map +1 -1
  401. package/dist/collection/components/card-accordion/card-accordion.css +4 -4
  402. package/dist/collection/components/card-accordion/card-accordion.js +5 -5
  403. package/dist/collection/components/card-accordion/card-accordion.js.map +1 -1
  404. package/dist/collection/components/card-content/card-content.js +1 -1
  405. package/dist/collection/components/card-list/card-list.css +6 -0
  406. package/dist/collection/components/card-list/card-list.js +5 -5
  407. package/dist/collection/components/card-list/card-list.js.map +1 -1
  408. package/dist/collection/components/card-title/card-title.js +1 -1
  409. package/dist/collection/components/category-filter/category-filter.css +32 -132
  410. package/dist/collection/components/category-filter/category-filter.js +138 -78
  411. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  412. package/dist/collection/components/category-filter/logical-filter-operator.js +1 -1
  413. package/dist/collection/components/category-filter/logical-filter-operator.js.map +1 -1
  414. package/dist/collection/components/category-filter/test/category-filter.ct.js +52 -0
  415. package/dist/collection/components/category-filter/test/category-filter.ct.js.map +1 -0
  416. package/dist/collection/components/chip/chip.css +2 -2
  417. package/dist/collection/components/chip/chip.js +5 -5
  418. package/dist/collection/components/chip/chip.js.map +1 -1
  419. package/dist/collection/components/col/col.css +1 -1
  420. package/dist/collection/components/col/col.js +2 -2
  421. package/dist/collection/components/col/col.js.map +1 -1
  422. package/dist/collection/components/content/content.js +3 -3
  423. package/dist/collection/components/content-header/content-header.css +6 -3
  424. package/dist/collection/components/content-header/content-header.js +2 -2
  425. package/dist/collection/components/content-header/content-header.js.map +1 -1
  426. package/dist/collection/components/css-grid/css-grid-item.js +1 -1
  427. package/dist/collection/components/css-grid/css-grid.js +9 -4
  428. package/dist/collection/components/css-grid/css-grid.js.map +1 -1
  429. package/dist/collection/components/date-dropdown/date-dropdown.js +34 -21
  430. package/dist/collection/components/date-dropdown/date-dropdown.js.map +1 -1
  431. package/dist/collection/components/date-picker/date-picker.js +62 -48
  432. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  433. package/dist/collection/components/date-time-card/date-time-card.js +7 -6
  434. package/dist/collection/components/date-time-card/date-time-card.js.map +1 -1
  435. package/dist/collection/components/datetime-picker/datetime-picker.js +1 -1
  436. package/dist/collection/components/divider/divider.js +1 -1
  437. package/dist/collection/components/drawer/drawer.js +2 -2
  438. package/dist/collection/components/dropdown/dropdown-controller.js +14 -13
  439. package/dist/collection/components/dropdown/dropdown-controller.js.map +1 -1
  440. package/dist/collection/components/dropdown/dropdown.js +101 -65
  441. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  442. package/dist/collection/components/dropdown/test/dropdown.ct.js +19 -8
  443. package/dist/collection/components/dropdown/test/dropdown.ct.js.map +1 -1
  444. package/dist/collection/components/dropdown-button/dropdown-button.ct.js +28 -0
  445. package/dist/collection/components/dropdown-button/dropdown-button.ct.js.map +1 -1
  446. package/dist/collection/components/dropdown-button/dropdown-button.js +7 -13
  447. package/dist/collection/components/dropdown-button/dropdown-button.js.map +1 -1
  448. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  449. package/dist/collection/components/dropdown-header/dropdown-header.js.map +1 -1
  450. package/dist/collection/components/dropdown-item/dropdown-item.css +3 -3
  451. package/dist/collection/components/dropdown-item/dropdown-item.js +5 -5
  452. package/dist/collection/components/dropdown-item/dropdown-item.js.map +1 -1
  453. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  454. package/dist/collection/components/empty-state/empty-state.js +1 -1
  455. package/dist/collection/components/empty-state/empty-state.js.map +1 -1
  456. package/dist/collection/components/event-list/event-list.js +2 -2
  457. package/dist/collection/components/event-list-item/event-list-item.js +4 -4
  458. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  459. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  460. package/dist/collection/components/flip-tile/flip-tile.js +4 -4
  461. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  462. package/dist/collection/components/{text-field/number-field.css → form-field/form-field.css} +15 -242
  463. package/dist/collection/components/form-field/form-field.js +56 -0
  464. package/dist/collection/components/form-field/form-field.js.map +1 -0
  465. package/dist/collection/components/grid/layout-grid.css +1 -1
  466. package/dist/collection/components/grid/layout-grid.js +3 -3
  467. package/dist/collection/components/grid/layout-grid.js.map +1 -1
  468. package/dist/collection/components/group/group-context-menu.css +1 -1
  469. package/dist/collection/components/group/group-context-menu.js +2 -2
  470. package/dist/collection/components/group/group-context-menu.js.map +1 -1
  471. package/dist/collection/components/group/group.css +3 -2
  472. package/dist/collection/components/group/group.js +84 -48
  473. package/dist/collection/components/group/group.js.map +1 -1
  474. package/dist/collection/components/group/test/group.ct.js +70 -2
  475. package/dist/collection/components/group/test/group.ct.js.map +1 -1
  476. package/dist/collection/components/group-item/group-item.css +0 -4
  477. package/dist/collection/components/group-item/group-item.js +9 -12
  478. package/dist/collection/components/group-item/group-item.js.map +1 -1
  479. package/dist/collection/components/icon-button/icon-button.js +1 -1
  480. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -2
  481. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js.map +1 -1
  482. package/dist/collection/components/input-group/input-group.js +1 -1
  483. package/dist/collection/components/key-value/key-value.js +1 -1
  484. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  485. package/dist/collection/components/kpi/kpi.css +1 -1
  486. package/dist/collection/components/kpi/kpi.js +4 -4
  487. package/dist/collection/components/kpi/kpi.js.map +1 -1
  488. package/dist/collection/components/link-button/link-button.js +3 -3
  489. package/dist/collection/components/map-navigation/map-navigation.css +3 -3
  490. package/dist/collection/components/map-navigation/map-navigation.js +2 -2
  491. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js +2 -2
  492. package/dist/collection/components/menu/menu-expand-icon.css +1 -1
  493. package/dist/collection/components/menu/menu-expand-icon.js +3 -3
  494. package/dist/collection/components/menu/menu-expand-icon.js.map +1 -1
  495. package/dist/collection/components/menu/menu.css +4 -3
  496. package/dist/collection/components/menu/menu.js +12 -12
  497. package/dist/collection/components/menu/menu.js.map +1 -1
  498. package/dist/collection/components/menu/test/menu.ct.js +1 -1
  499. package/dist/collection/components/menu/test/menu.ct.js.map +1 -1
  500. package/dist/collection/components/menu-about/menu-about.js +1 -1
  501. package/dist/collection/components/menu-about/test/menu-about.ct.js +44 -0
  502. package/dist/collection/components/menu-about/test/menu-about.ct.js.map +1 -0
  503. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  504. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  505. package/dist/collection/components/menu-about-news/menu-about-news.js.map +1 -1
  506. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -2
  507. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  508. package/dist/collection/components/menu-category/menu-category.js +5 -5
  509. package/dist/collection/components/menu-category/menu-category.js.map +1 -1
  510. package/dist/collection/components/menu-item/menu-item.js +24 -21
  511. package/dist/collection/components/menu-item/menu-item.js.map +1 -1
  512. package/dist/collection/components/menu-settings/menu-settings.js +1 -1
  513. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  514. package/dist/collection/components/message-bar/message-bar.js +1 -1
  515. package/dist/collection/components/modal/modal.css +19 -9
  516. package/dist/collection/components/modal/modal.js +11 -4
  517. package/dist/collection/components/modal/modal.js.map +1 -1
  518. package/dist/collection/components/modal/test/modal.ct.js +47 -1
  519. package/dist/collection/components/modal/test/modal.ct.js.map +1 -1
  520. package/dist/collection/components/modal-content/modal-content.css +2 -2
  521. package/dist/collection/components/modal-content/modal-content.js +1 -1
  522. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  523. package/dist/collection/components/modal-header/modal-header.css +6 -7
  524. package/dist/collection/components/modal-header/modal-header.js +4 -4
  525. package/dist/collection/components/modal-header/modal-header.js.map +1 -1
  526. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  527. package/dist/collection/components/pagination/pagination.js +5 -4
  528. package/dist/collection/components/pagination/pagination.js.map +1 -1
  529. package/dist/collection/components/pane/pane.css +1 -1
  530. package/dist/collection/components/pane/pane.js +7 -7
  531. package/dist/collection/components/pane/pane.js.map +1 -1
  532. package/dist/collection/components/pane/test/panes.ct.js +1 -1
  533. package/dist/collection/components/pane/test/panes.ct.js.map +1 -1
  534. package/dist/collection/components/pane-layout/pane-layout.js +1 -1
  535. package/dist/collection/components/pill/pill.css +2 -2
  536. package/dist/collection/components/pill/pill.js +5 -5
  537. package/dist/collection/components/pill/pill.js.map +1 -1
  538. package/dist/collection/components/playground/example-modal.js +1 -1
  539. package/dist/collection/components/playground/playground.js +2 -2
  540. package/dist/collection/components/playground/playground.js.map +1 -1
  541. package/dist/collection/components/push-card/push-card.js +9 -6
  542. package/dist/collection/components/push-card/push-card.js.map +1 -1
  543. package/dist/collection/components/row/row.css +1 -1
  544. package/dist/collection/components/row/row.js +2 -2
  545. package/dist/collection/components/row/row.js.map +1 -1
  546. package/dist/collection/components/select/select.css +0 -52
  547. package/dist/collection/components/select/select.js +105 -423
  548. package/dist/collection/components/select/select.js.map +1 -1
  549. package/dist/collection/components/select/test/select.ct.js +139 -80
  550. package/dist/collection/components/select/test/select.ct.js.map +1 -1
  551. package/dist/collection/components/select-item/select-item.js +1 -1
  552. package/dist/collection/components/slider/slider.css +1 -1
  553. package/dist/collection/components/slider/slider.js +24 -16
  554. package/dist/collection/components/slider/slider.js.map +1 -1
  555. package/dist/collection/components/slider/test/slider.ct.js +15 -6
  556. package/dist/collection/components/slider/test/slider.ct.js.map +1 -1
  557. package/dist/collection/components/spinner/spinner.js +1 -1
  558. package/dist/collection/components/split-button/split-button.js +1 -1
  559. package/dist/collection/components/split-button-item/split-button-item.js +1 -1
  560. package/dist/collection/components/tab-item/tab-item.js +5 -5
  561. package/dist/collection/components/tab-item/tab-item.js.map +1 -1
  562. package/dist/collection/components/tabs/tabs.css +1 -1
  563. package/dist/collection/components/tabs/tabs.js +78 -43
  564. package/dist/collection/components/tabs/tabs.js.map +1 -1
  565. package/dist/collection/components/tabs/test/tabs.ct.js +35 -9
  566. package/dist/collection/components/tabs/test/tabs.ct.js.map +1 -1
  567. package/dist/collection/components/tile/tile.css +1 -1
  568. package/dist/collection/components/tile/tile.js +5 -5
  569. package/dist/collection/components/tile/tile.js.map +1 -1
  570. package/dist/collection/components/time-picker/time-picker.css +13 -86
  571. package/dist/collection/components/time-picker/time-picker.js +3 -3
  572. package/dist/collection/components/time-picker/time-picker.js.map +1 -1
  573. package/dist/collection/components/toast/styles/toast-container.css +1 -1
  574. package/dist/collection/components/toast/toast-container.js +3 -3
  575. package/dist/collection/components/toast/toast-container.js.map +1 -1
  576. package/dist/collection/components/toast/toast-utils.js.map +1 -1
  577. package/dist/collection/components/toast/toast.css +1 -1
  578. package/dist/collection/components/toast/toast.js +3 -3
  579. package/dist/collection/components/toast/toast.js.map +1 -1
  580. package/dist/collection/components/toggle/test/toggle.ct.js +1 -24
  581. package/dist/collection/components/toggle/test/toggle.ct.js.map +1 -1
  582. package/dist/collection/components/toggle/toggle.css +1 -132
  583. package/dist/collection/components/toggle/toggle.js +2 -157
  584. package/dist/collection/components/toggle/toggle.js.map +1 -1
  585. package/dist/collection/components/toggle-button/toggle-button.js +2 -2
  586. package/dist/collection/components/tooltip/tooltip.css +15 -5
  587. package/dist/collection/components/tooltip/tooltip.js +39 -35
  588. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  589. package/dist/collection/components/tree/test/tree.ct.js +37 -1
  590. package/dist/collection/components/tree/test/tree.ct.js.map +1 -1
  591. package/dist/collection/components/tree/tree-model.js.map +1 -1
  592. package/dist/collection/components/tree/tree.css +1 -1
  593. package/dist/collection/components/tree/tree.js +26 -11
  594. package/dist/collection/components/tree/tree.js.map +1 -1
  595. package/dist/collection/components/tree-item/tree-item.css +9 -0
  596. package/dist/collection/components/tree-item/tree-item.js +13 -12
  597. package/dist/collection/components/tree-item/tree-item.js.map +1 -1
  598. package/dist/collection/components/typography/test/ix-typography.spec.js +0 -14
  599. package/dist/collection/components/typography/test/ix-typography.spec.js.map +1 -1
  600. package/dist/collection/components/typography/type-mapping.js +3 -0
  601. package/dist/collection/components/typography/type-mapping.js.map +1 -1
  602. package/dist/collection/components/typography/typography.js +6 -42
  603. package/dist/collection/components/typography/typography.js.map +1 -1
  604. package/dist/collection/components/upload/test/upload.ct.js +17 -0
  605. package/dist/collection/components/upload/test/upload.ct.js.map +1 -0
  606. package/dist/collection/components/upload/upload.js +50 -6
  607. package/dist/collection/components/upload/upload.js.map +1 -1
  608. package/dist/collection/components/utils/a11y.js +2 -3
  609. package/dist/collection/components/utils/a11y.js.map +1 -1
  610. package/dist/collection/components/utils/application-layout/service.js +2 -2
  611. package/dist/collection/components/utils/application-layout/service.js.map +1 -1
  612. package/dist/collection/components/utils/condition-checks.js +1 -1
  613. package/dist/collection/components/utils/condition-checks.js.map +1 -1
  614. package/dist/collection/components/utils/context.js +6 -3
  615. package/dist/collection/components/utils/context.js.map +1 -1
  616. package/dist/collection/components/utils/disposable-event-listener.js +19 -0
  617. package/dist/collection/components/utils/disposable-event-listener.js.map +1 -0
  618. package/dist/collection/components/utils/element-reference.js +2 -0
  619. package/dist/collection/components/utils/element-reference.js.map +1 -0
  620. package/dist/collection/components/utils/focus.js +19 -17
  621. package/dist/collection/components/utils/focus.js.map +1 -1
  622. package/dist/collection/components/utils/listener.js +2 -2
  623. package/dist/collection/components/utils/listener.js.map +1 -1
  624. package/dist/collection/components/utils/make-ref.js +7 -17
  625. package/dist/collection/components/utils/make-ref.js.map +1 -1
  626. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +11 -8
  627. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js.map +1 -1
  628. package/dist/collection/components/utils/notification-color.js.map +1 -1
  629. package/dist/collection/components/utils/shadow-dom.js +1 -1
  630. package/dist/collection/components/utils/shadow-dom.js.map +1 -1
  631. package/dist/collection/components/utils/theme-switcher.js +1 -0
  632. package/dist/collection/components/utils/theme-switcher.js.map +1 -1
  633. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  634. package/dist/collection/components/workflow-step/workflow-step.css +1 -1
  635. package/dist/collection/components/workflow-step/workflow-step.js +4 -4
  636. package/dist/collection/components/workflow-step/workflow-step.js.map +1 -1
  637. package/dist/collection/components/workflow-steps/test/workflow-steps.ct.js +2 -2
  638. package/dist/collection/components/workflow-steps/test/workflow-steps.ct.js.map +1 -1
  639. package/dist/collection/components/workflow-steps/workflow-steps.css +1 -1
  640. package/dist/collection/components/workflow-steps/workflow-steps.js +2 -2
  641. package/dist/collection/components/workflow-steps/workflow-steps.js.map +1 -1
  642. package/dist/collection/index.js +1 -6
  643. package/dist/collection/index.js.map +1 -1
  644. package/dist/collection/tests/application/application.e2e.js.map +1 -1
  645. package/dist/collection/tests/application-header/application-header.e2e.js +9 -0
  646. package/dist/collection/tests/application-header/application-header.e2e.js.map +1 -1
  647. package/dist/collection/tests/avatar/avatar.e2e.js +6 -0
  648. package/dist/collection/tests/avatar/avatar.e2e.js.map +1 -1
  649. package/dist/collection/tests/card-list/card-list.e2e.js +7 -1
  650. package/dist/collection/tests/card-list/card-list.e2e.js.map +1 -1
  651. package/dist/collection/tests/dropdown/dropdown.e2e.js +6 -0
  652. package/dist/collection/tests/dropdown/dropdown.e2e.js.map +1 -1
  653. package/dist/collection/tests/group/group.e2e.js +12 -3
  654. package/dist/collection/tests/group/group.e2e.js.map +1 -1
  655. package/dist/collection/tests/input/input.e2e.js +12 -0
  656. package/dist/collection/tests/input/input.e2e.js.map +1 -1
  657. package/dist/collection/tests/slider/slider.e2e.js +31 -0
  658. package/dist/collection/tests/slider/slider.e2e.js.map +1 -1
  659. package/dist/collection/tests/tabs/tabs.e2e.js +1 -1
  660. package/dist/collection/tests/tabs/tabs.e2e.js.map +1 -1
  661. package/dist/collection/tests/tooltip/tooltip.e2e.js +22 -0
  662. package/dist/collection/tests/tooltip/tooltip.e2e.js.map +1 -1
  663. package/dist/collection/tests/tree/tree.e2e.js +12 -0
  664. package/dist/collection/tests/tree/tree.e2e.js.map +1 -1
  665. package/dist/collection/tests/utils/test/index.js +0 -11
  666. package/dist/collection/tests/utils/test/index.js.map +1 -1
  667. package/dist/collection/tests/utils/test/page.js +3 -12
  668. package/dist/collection/tests/utils/test/page.js.map +1 -1
  669. package/dist/esm/{a11y-13dedaef.js → a11y-2e34777f.js} +4 -5
  670. package/dist/esm/a11y-2e34777f.js.map +1 -0
  671. package/dist/esm/{base-button-ea06697f.js → base-button-103d6f26.js} +4 -4
  672. package/dist/esm/base-button-103d6f26.js.map +1 -0
  673. package/dist/esm/{base-icon-button-c64fdb50.js → base-icon-button-9770fa3e.js} +3 -3
  674. package/dist/esm/{base-icon-button-c64fdb50.js.map → base-icon-button-9770fa3e.js.map} +1 -1
  675. package/dist/esm/{context-c9078420.js → context-42311cff.js} +7 -4
  676. package/dist/esm/context-42311cff.js.map +1 -0
  677. package/dist/esm/disposable-event-listener-ff2cb862.js +18 -0
  678. package/dist/esm/disposable-event-listener-ff2cb862.js.map +1 -0
  679. package/dist/esm/dropdown-controller-c79f65b3.js +148 -0
  680. package/dist/esm/dropdown-controller-c79f65b3.js.map +1 -0
  681. package/dist/esm/{floating-ui.dom.esm-6e7c098f.js → floating-ui.dom.esm-d4ad786a.js} +534 -61
  682. package/dist/esm/floating-ui.dom.esm-d4ad786a.js.map +1 -0
  683. package/dist/esm/{focus-d4d3abaf.js → focus-5ccebfbc.js} +21 -18
  684. package/dist/esm/focus-5ccebfbc.js.map +1 -0
  685. package/dist/esm/{index-9103b14c.js → index-5429f20b.js} +156 -78
  686. package/dist/esm/index-5429f20b.js.map +1 -0
  687. package/dist/esm/index.js +4 -19
  688. package/dist/esm/index.js.map +1 -1
  689. package/dist/esm/ix-action-card.entry.js +2 -2
  690. package/dist/esm/ix-action-card.entry.js.map +1 -1
  691. package/dist/esm/ix-application-header.entry.js +36 -10
  692. package/dist/esm/ix-application-header.entry.js.map +1 -1
  693. package/dist/esm/ix-application-sidebar.entry.js +2 -2
  694. package/dist/esm/ix-application-switch-modal.entry.js +2 -2
  695. package/dist/esm/ix-application.entry.js +9 -9
  696. package/dist/esm/ix-application.entry.js.map +1 -1
  697. package/dist/esm/ix-avatar_2.entry.js +6 -6
  698. package/dist/esm/ix-avatar_2.entry.js.map +1 -1
  699. package/dist/esm/ix-basic-navigation.entry.js +5 -5
  700. package/dist/esm/ix-basic-navigation.entry.js.map +1 -1
  701. package/dist/esm/ix-blind.entry.js +7 -7
  702. package/dist/esm/ix-blind.entry.js.map +1 -1
  703. package/dist/esm/ix-breadcrumb-item.entry.js +3 -3
  704. package/dist/esm/ix-breadcrumb.entry.js +11 -10
  705. package/dist/esm/ix-breadcrumb.entry.js.map +1 -1
  706. package/dist/esm/ix-button.entry.js +4 -4
  707. package/dist/esm/ix-button.entry.js.map +1 -1
  708. package/dist/esm/ix-card-accordion_2.entry.js +8 -8
  709. package/dist/esm/ix-card-accordion_2.entry.js.map +1 -1
  710. package/dist/esm/ix-card-list.entry.js +7 -7
  711. package/dist/esm/ix-card-list.entry.js.map +1 -1
  712. package/dist/esm/ix-card_2.entry.js +6 -6
  713. package/dist/esm/ix-card_2.entry.js.map +1 -1
  714. package/dist/esm/ix-category-filter.entry.js +132 -72
  715. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  716. package/dist/esm/ix-chip.entry.js +5 -5
  717. package/dist/esm/ix-chip.entry.js.map +1 -1
  718. package/dist/esm/ix-col_4.entry.js +59 -43
  719. package/dist/esm/ix-col_4.entry.js.map +1 -1
  720. package/dist/esm/ix-content-header.entry.js +3 -3
  721. package/dist/esm/ix-content-header.entry.js.map +1 -1
  722. package/dist/esm/ix-content.entry.js +5 -5
  723. package/dist/esm/ix-css-grid-item.entry.js +2 -2
  724. package/dist/esm/ix-css-grid.entry.js +9 -4
  725. package/dist/esm/ix-css-grid.entry.js.map +1 -1
  726. package/dist/esm/ix-date-dropdown.entry.js +26 -16
  727. package/dist/esm/ix-date-dropdown.entry.js.map +1 -1
  728. package/dist/esm/ix-date-time-card.entry.js +2 -2
  729. package/dist/esm/ix-date-time-card.entry.js.map +1 -1
  730. package/dist/esm/ix-datetime-picker.entry.js +2 -2
  731. package/dist/esm/ix-divider.entry.js +2 -2
  732. package/dist/esm/ix-drawer.entry.js +3 -3
  733. package/dist/esm/ix-dropdown-button.entry.js +5 -6
  734. package/dist/esm/ix-dropdown-button.entry.js.map +1 -1
  735. package/dist/esm/ix-dropdown-header.entry.js +2 -2
  736. package/dist/esm/ix-dropdown-header.entry.js.map +1 -1
  737. package/dist/esm/ix-dropdown-item.entry.js +5 -5
  738. package/dist/esm/ix-dropdown-item.entry.js.map +1 -1
  739. package/dist/esm/ix-dropdown-quick-actions.entry.js +2 -2
  740. package/dist/esm/ix-dropdown.entry.js +86 -48
  741. package/dist/esm/ix-dropdown.entry.js.map +1 -1
  742. package/dist/esm/ix-empty-state.entry.js +2 -2
  743. package/dist/esm/ix-empty-state.entry.js.map +1 -1
  744. package/dist/esm/ix-event-list-item.entry.js +6 -6
  745. package/dist/esm/ix-event-list.entry.js +3 -3
  746. package/dist/esm/ix-expanding-search.entry.js +5 -5
  747. package/dist/esm/ix-filter-chip_2.entry.js +3 -3
  748. package/dist/esm/ix-flip-tile-content.entry.js +2 -2
  749. package/dist/esm/ix-flip-tile.entry.js +5 -5
  750. package/dist/esm/ix-form-field.entry.js +24 -0
  751. package/dist/esm/ix-form-field.entry.js.map +1 -0
  752. package/dist/esm/ix-group-context-menu_2.entry.js +7 -11
  753. package/dist/esm/ix-group-context-menu_2.entry.js.map +1 -1
  754. package/dist/esm/ix-group.entry.js +69 -45
  755. package/dist/esm/ix-group.entry.js.map +1 -1
  756. package/dist/esm/ix-icon-button_2.entry.js +6 -6
  757. package/dist/esm/ix-icon-toggle-button.entry.js +5 -6
  758. package/dist/esm/ix-icon-toggle-button.entry.js.map +1 -1
  759. package/dist/esm/ix-input-group.entry.js +3 -3
  760. package/dist/esm/ix-key-value-list.entry.js +2 -2
  761. package/dist/esm/ix-key-value.entry.js +2 -2
  762. package/dist/esm/ix-kpi.entry.js +4 -4
  763. package/dist/esm/ix-kpi.entry.js.map +1 -1
  764. package/dist/esm/ix-link-button.entry.js +4 -4
  765. package/dist/esm/ix-map-navigation-overlay.entry.js +3 -3
  766. package/dist/esm/ix-map-navigation.entry.js +5 -5
  767. package/dist/esm/ix-map-navigation.entry.js.map +1 -1
  768. package/dist/esm/ix-menu-about-item.entry.js +2 -2
  769. package/dist/esm/ix-menu-about-news.entry.js +5 -5
  770. package/dist/esm/ix-menu-about-news.entry.js.map +1 -1
  771. package/dist/esm/ix-menu-about.entry.js +3 -3
  772. package/dist/esm/ix-menu-avatar.entry.js +4 -4
  773. package/dist/esm/ix-menu-category.entry.js +7 -7
  774. package/dist/esm/ix-menu-category.entry.js.map +1 -1
  775. package/dist/esm/ix-menu-expand-icon.entry.js +4 -4
  776. package/dist/esm/ix-menu-expand-icon.entry.js.map +1 -1
  777. package/dist/esm/ix-menu-item.entry.js +15 -15
  778. package/dist/esm/ix-menu-item.entry.js.map +1 -1
  779. package/dist/esm/ix-menu-settings-item.entry.js +2 -2
  780. package/dist/esm/ix-menu-settings.entry.js +2 -2
  781. package/dist/esm/ix-menu.entry.js +16 -16
  782. package/dist/esm/ix-menu.entry.js.map +1 -1
  783. package/dist/esm/ix-message-bar.entry.js +2 -2
  784. package/dist/esm/ix-modal-content_2.entry.js +6 -6
  785. package/dist/esm/ix-modal-content_2.entry.js.map +1 -1
  786. package/dist/esm/ix-modal-example.entry.js +2 -2
  787. package/dist/esm/ix-modal-footer.entry.js +2 -2
  788. package/dist/esm/ix-modal-loading.entry.js +2 -2
  789. package/dist/esm/ix-modal.entry.js +14 -7
  790. package/dist/esm/ix-modal.entry.js.map +1 -1
  791. package/dist/esm/ix-pagination.entry.js +6 -6
  792. package/dist/esm/ix-pagination.entry.js.map +1 -1
  793. package/dist/esm/ix-pane-layout.entry.js +3 -3
  794. package/dist/esm/ix-pane.entry.js +8 -8
  795. package/dist/esm/ix-pane.entry.js.map +1 -1
  796. package/dist/esm/ix-pill.entry.js +5 -5
  797. package/dist/esm/ix-pill.entry.js.map +1 -1
  798. package/dist/esm/ix-playground-internal.entry.js +2 -2
  799. package/dist/esm/ix-playground-internal.entry.js.map +1 -1
  800. package/dist/esm/ix-push-card.entry.js +2 -2
  801. package/dist/esm/ix-push-card.entry.js.map +1 -1
  802. package/dist/esm/ix-select.entry.js +108 -157
  803. package/dist/esm/ix-select.entry.js.map +1 -1
  804. package/dist/esm/ix-slider.entry.js +24 -17
  805. package/dist/esm/ix-slider.entry.js.map +1 -1
  806. package/dist/esm/ix-split-button-item.entry.js +3 -3
  807. package/dist/esm/ix-split-button.entry.js +2 -2
  808. package/dist/esm/ix-tab-item_2.entry.js +75 -45
  809. package/dist/esm/ix-tab-item_2.entry.js.map +1 -1
  810. package/dist/esm/ix-tile.entry.js +5 -5
  811. package/dist/esm/ix-tile.entry.js.map +1 -1
  812. package/dist/esm/ix-time-picker.entry.js +5 -5
  813. package/dist/esm/ix-time-picker.entry.js.map +1 -1
  814. package/dist/esm/ix-toast-container.entry.js +3 -3
  815. package/dist/esm/ix-toast-container.entry.js.map +1 -1
  816. package/dist/esm/ix-toast.entry.js +3 -3
  817. package/dist/esm/ix-toast.entry.js.map +1 -1
  818. package/dist/esm/ix-toggle-button.entry.js +5 -5
  819. package/dist/esm/ix-toggle.entry.js +5 -42
  820. package/dist/esm/ix-toggle.entry.js.map +1 -1
  821. package/dist/esm/ix-tooltip.entry.js +295 -0
  822. package/dist/esm/ix-tooltip.entry.js.map +1 -0
  823. package/dist/esm/ix-tree-item.entry.js +9 -9
  824. package/dist/esm/ix-tree-item.entry.js.map +1 -1
  825. package/dist/esm/ix-tree.entry.js +22 -8
  826. package/dist/esm/ix-tree.entry.js.map +1 -1
  827. package/dist/esm/ix-typography.entry.js +4 -25
  828. package/dist/esm/ix-typography.entry.js.map +1 -1
  829. package/dist/esm/ix-upload.entry.js +59 -5
  830. package/dist/esm/ix-upload.entry.js.map +1 -1
  831. package/dist/esm/ix-validation-tooltip.entry.js +4 -4
  832. package/dist/esm/ix-workflow-step.entry.js +4 -4
  833. package/dist/esm/ix-workflow-step.entry.js.map +1 -1
  834. package/dist/esm/ix-workflow-steps.entry.js +2 -2
  835. package/dist/esm/ix-workflow-steps.entry.js.map +1 -1
  836. package/dist/esm/{listener-98571ba8.js → listener-ade7081c.js} +4 -4
  837. package/dist/esm/listener-ade7081c.js.map +1 -0
  838. package/dist/esm/loader.js +3 -3
  839. package/dist/esm/{logical-filter-operator-f6701df5.js → logical-filter-operator-d793d1c3.js} +2 -2
  840. package/dist/esm/{logical-filter-operator-f6701df5.js.map → logical-filter-operator-d793d1c3.js.map} +1 -1
  841. package/dist/esm/{make-ref-6b3b4e16.js → make-ref-4b76e9b5.js} +8 -18
  842. package/dist/esm/make-ref-4b76e9b5.js.map +1 -0
  843. package/dist/esm/{menu-tabs-fc-7ec1fb5d.js → menu-tabs-fc-b549da52.js} +19 -16
  844. package/dist/esm/menu-tabs-fc-b549da52.js.map +1 -0
  845. package/dist/esm/{service-02cc9011.js → service-c7fc628b.js} +3 -3
  846. package/dist/esm/service-c7fc628b.js.map +1 -0
  847. package/dist/esm/{shadow-dom-60e9243d.js → shadow-dom-cc0bc152.js} +2 -2
  848. package/dist/esm/{shadow-dom-60e9243d.js.map → shadow-dom-cc0bc152.js.map} +1 -1
  849. package/dist/esm/siemens-ix.js +3 -3
  850. package/dist/esm/{theme-switcher-b10fb4da.js → theme-switcher-5fcf712d.js} +2 -1
  851. package/dist/esm/theme-switcher-5fcf712d.js.map +1 -0
  852. package/dist/siemens-ix/index.esm.js +1 -1
  853. package/dist/siemens-ix/index.esm.js.map +1 -1
  854. package/dist/siemens-ix/{p-781a1922.entry.js → p-0379b864.entry.js} +2 -2
  855. package/dist/siemens-ix/{p-846cf6d2.entry.js → p-054451cb.entry.js} +2 -2
  856. package/dist/siemens-ix/{p-9840f086.entry.js → p-0691b6a5.entry.js} +2 -2
  857. package/dist/siemens-ix/{p-9840f086.entry.js.map → p-0691b6a5.entry.js.map} +1 -1
  858. package/dist/siemens-ix/{p-504f43d4.entry.js → p-06f9e19f.entry.js} +2 -2
  859. package/dist/siemens-ix/{p-504f43d4.entry.js.map → p-06f9e19f.entry.js.map} +1 -1
  860. package/dist/siemens-ix/p-093c25b1.entry.js +2 -0
  861. package/dist/siemens-ix/p-093c25b1.entry.js.map +1 -0
  862. package/dist/siemens-ix/p-0996d9f6.entry.js +2 -0
  863. package/dist/siemens-ix/{p-5924a783.entry.js → p-09e0ede1.entry.js} +2 -2
  864. package/dist/siemens-ix/{p-5924a783.entry.js.map → p-09e0ede1.entry.js.map} +1 -1
  865. package/dist/siemens-ix/{p-ec0806c3.entry.js → p-0b8718d9.entry.js} +2 -2
  866. package/dist/siemens-ix/p-0b8718d9.entry.js.map +1 -0
  867. package/dist/siemens-ix/{p-1da901d5.js → p-0e983f70.js} +2 -2
  868. package/dist/siemens-ix/p-0e983f70.js.map +1 -0
  869. package/dist/siemens-ix/p-0f099811.entry.js +2 -0
  870. package/dist/siemens-ix/{p-4b69ab0d.entry.js.map → p-0f099811.entry.js.map} +1 -1
  871. package/dist/siemens-ix/{p-8d737a35.entry.js → p-0f4e62f3.entry.js} +2 -2
  872. package/dist/siemens-ix/p-10368ba0.entry.js +2 -0
  873. package/dist/siemens-ix/{p-02ed5606.entry.js.map → p-10368ba0.entry.js.map} +1 -1
  874. package/dist/siemens-ix/p-10a522ca.js +2 -0
  875. package/dist/siemens-ix/p-10a522ca.js.map +1 -0
  876. package/dist/siemens-ix/p-156fa685.entry.js +2 -0
  877. package/dist/siemens-ix/p-156fa685.entry.js.map +1 -0
  878. package/dist/siemens-ix/p-157b1b28.js +2 -0
  879. package/dist/siemens-ix/p-157b1b28.js.map +1 -0
  880. package/dist/siemens-ix/p-17240a7f.entry.js +2 -0
  881. package/dist/siemens-ix/p-17240a7f.entry.js.map +1 -0
  882. package/dist/siemens-ix/p-178ce002.js +2 -0
  883. package/dist/siemens-ix/p-178ce002.js.map +1 -0
  884. package/dist/siemens-ix/p-1a8e3fea.entry.js +2 -0
  885. package/dist/siemens-ix/{p-3de71a19.entry.js → p-1b6dda61.entry.js} +2 -2
  886. package/dist/siemens-ix/p-1b6dda61.entry.js.map +1 -0
  887. package/dist/siemens-ix/{p-b789e0e7.entry.js → p-1e3d6d27.entry.js} +2 -2
  888. package/dist/siemens-ix/{p-37ca7ed4.js → p-24afab39.js} +2 -2
  889. package/dist/{cjs/menu-tabs-fc-f6b706e3.js.map → siemens-ix/p-24afab39.js.map} +1 -1
  890. package/dist/siemens-ix/p-26609c63.entry.js +2 -0
  891. package/dist/siemens-ix/p-26609c63.entry.js.map +1 -0
  892. package/dist/siemens-ix/{p-b0fe18f7.entry.js → p-2c1540ba.entry.js} +2 -2
  893. package/dist/siemens-ix/{p-b0fe18f7.entry.js.map → p-2c1540ba.entry.js.map} +1 -1
  894. package/dist/siemens-ix/{p-921c59c4.entry.js → p-2f232c45.entry.js} +2 -2
  895. package/dist/siemens-ix/p-2f232c45.entry.js.map +1 -0
  896. package/dist/siemens-ix/{p-8a9fc2f0.entry.js → p-3028d530.entry.js} +2 -2
  897. package/dist/siemens-ix/{p-8a9fc2f0.entry.js.map → p-3028d530.entry.js.map} +1 -1
  898. package/dist/siemens-ix/p-3150070f.entry.js +2 -0
  899. package/dist/siemens-ix/p-3150070f.entry.js.map +1 -0
  900. package/dist/siemens-ix/{p-6c412b52.entry.js → p-315ecf68.entry.js} +2 -2
  901. package/dist/siemens-ix/{p-712e0ee0.js → p-345e1c73.js} +1 -1
  902. package/dist/siemens-ix/{p-712e0ee0.js.map → p-345e1c73.js.map} +1 -1
  903. package/dist/siemens-ix/{p-9ec92185.entry.js → p-380a7d93.entry.js} +2 -2
  904. package/dist/siemens-ix/p-380a7d93.entry.js.map +1 -0
  905. package/dist/siemens-ix/p-3b576b4e.js +2 -0
  906. package/dist/siemens-ix/{p-6bd0ba14.entry.js → p-3be4c628.entry.js} +2 -2
  907. package/dist/siemens-ix/p-3be4c628.entry.js.map +1 -0
  908. package/dist/siemens-ix/p-3e867ef9.entry.js +2 -0
  909. package/dist/siemens-ix/p-3e867ef9.entry.js.map +1 -0
  910. package/dist/siemens-ix/p-40f20208.entry.js +2 -0
  911. package/dist/siemens-ix/p-40f20208.entry.js.map +1 -0
  912. package/dist/siemens-ix/{p-61265df9.entry.js → p-41935530.entry.js} +2 -2
  913. package/dist/siemens-ix/{p-61265df9.entry.js.map → p-41935530.entry.js.map} +1 -1
  914. package/dist/siemens-ix/{p-293dd6d1.entry.js → p-41d9a2e4.entry.js} +2 -2
  915. package/dist/siemens-ix/p-476e4a9d.entry.js +2 -0
  916. package/dist/siemens-ix/p-476e4a9d.entry.js.map +1 -0
  917. package/dist/siemens-ix/{p-25ee1b62.js → p-4ac31849.js} +1 -1
  918. package/dist/siemens-ix/{p-25ee1b62.js.map → p-4ac31849.js.map} +1 -1
  919. package/dist/siemens-ix/{p-35690183.entry.js → p-509dba4c.entry.js} +2 -2
  920. package/dist/siemens-ix/{p-6ca97a73.entry.js → p-50bcb3f8.entry.js} +2 -2
  921. package/dist/siemens-ix/{p-628f031a.entry.js → p-5232d441.entry.js} +2 -2
  922. package/dist/siemens-ix/{p-b5c4fd55.entry.js → p-619a80d3.entry.js} +2 -2
  923. package/dist/siemens-ix/{p-b5c4fd55.entry.js.map → p-619a80d3.entry.js.map} +1 -1
  924. package/dist/siemens-ix/p-633a8884.entry.js +2 -0
  925. package/dist/siemens-ix/p-633a8884.entry.js.map +1 -0
  926. package/dist/siemens-ix/{p-724b98ce.entry.js → p-66d4e328.entry.js} +2 -2
  927. package/dist/siemens-ix/{p-724b98ce.entry.js.map → p-66d4e328.entry.js.map} +1 -1
  928. package/dist/siemens-ix/{p-3b38f812.entry.js → p-6913e59d.entry.js} +2 -2
  929. package/dist/siemens-ix/{p-aae05303.entry.js → p-6a9577b5.entry.js} +2 -2
  930. package/dist/siemens-ix/p-6a9577b5.entry.js.map +1 -0
  931. package/dist/siemens-ix/p-72472fa5.entry.js +2 -0
  932. package/dist/siemens-ix/{p-0d907964.entry.js.map → p-72472fa5.entry.js.map} +1 -1
  933. package/dist/siemens-ix/{p-ed991838.js → p-72d096e9.js} +2 -2
  934. package/dist/siemens-ix/p-72d096e9.js.map +1 -0
  935. package/dist/siemens-ix/{p-9cc0d11b.entry.js → p-7354cdb0.entry.js} +2 -2
  936. package/dist/siemens-ix/p-737954bf.entry.js +2 -0
  937. package/dist/siemens-ix/p-737954bf.entry.js.map +1 -0
  938. package/dist/siemens-ix/p-737c61da.entry.js +2 -0
  939. package/dist/siemens-ix/{p-b6c0dfb5.entry.js.map → p-737c61da.entry.js.map} +1 -1
  940. package/dist/siemens-ix/p-73bd61ca.entry.js +2 -0
  941. package/dist/siemens-ix/{p-dde0af66.entry.js → p-74461f94.entry.js} +2 -2
  942. package/dist/siemens-ix/{p-f37ac17d.entry.js → p-7815494b.entry.js} +2 -2
  943. package/dist/siemens-ix/p-7815494b.entry.js.map +1 -0
  944. package/dist/siemens-ix/{p-f0bbd496.entry.js → p-8578629c.entry.js} +2 -2
  945. package/dist/siemens-ix/p-8578629c.entry.js.map +1 -0
  946. package/dist/siemens-ix/p-8a56153a.entry.js +2 -0
  947. package/dist/siemens-ix/{p-f3c3366d.entry.js.map → p-8a56153a.entry.js.map} +1 -1
  948. package/dist/siemens-ix/{p-104097fb.entry.js → p-8b21fc75.entry.js} +2 -2
  949. package/dist/siemens-ix/p-8b21fc75.entry.js.map +1 -0
  950. package/dist/siemens-ix/p-8b2b4ce3.entry.js +2 -0
  951. package/dist/siemens-ix/p-8b2b4ce3.entry.js.map +1 -0
  952. package/dist/siemens-ix/p-8f48462b.entry.js +2 -0
  953. package/dist/siemens-ix/p-8f48462b.entry.js.map +1 -0
  954. package/dist/siemens-ix/p-9144ea56.entry.js +2 -0
  955. package/dist/siemens-ix/p-9144ea56.entry.js.map +1 -0
  956. package/dist/siemens-ix/p-98af5c4d.entry.js +2 -0
  957. package/dist/siemens-ix/p-98af5c4d.entry.js.map +1 -0
  958. package/dist/siemens-ix/p-99a1cd81.entry.js +2 -0
  959. package/dist/siemens-ix/{p-06965e5f.entry.js → p-9b8c6123.entry.js} +2 -2
  960. package/dist/siemens-ix/p-9b8c6123.entry.js.map +1 -0
  961. package/dist/siemens-ix/p-9cd40e56.entry.js +2 -0
  962. package/dist/siemens-ix/p-9cd40e56.entry.js.map +1 -0
  963. package/dist/siemens-ix/{p-80051a81.entry.js → p-ad0c6a32.entry.js} +2 -2
  964. package/dist/siemens-ix/p-af7a836c.entry.js +2 -0
  965. package/dist/siemens-ix/p-af7a836c.entry.js.map +1 -0
  966. package/dist/siemens-ix/{p-8dcf30ce.entry.js → p-b247d124.entry.js} +2 -2
  967. package/dist/siemens-ix/p-b53aa733.entry.js +2 -0
  968. package/dist/siemens-ix/p-b53aa733.entry.js.map +1 -0
  969. package/dist/siemens-ix/{p-9569e1a2.entry.js → p-b6a11e17.entry.js} +2 -2
  970. package/dist/siemens-ix/p-b9e66925.entry.js +2 -0
  971. package/dist/siemens-ix/{p-fad5daa1.entry.js → p-b9f67de0.entry.js} +2 -2
  972. package/dist/siemens-ix/{p-fad5daa1.entry.js.map → p-b9f67de0.entry.js.map} +1 -1
  973. package/dist/siemens-ix/{p-1f771917.entry.js → p-ba2e041e.entry.js} +2 -2
  974. package/dist/siemens-ix/p-ba6e955a.js +2 -0
  975. package/dist/siemens-ix/p-ba6e955a.js.map +1 -0
  976. package/dist/siemens-ix/p-bf1e16f6.entry.js +2 -0
  977. package/dist/siemens-ix/p-bf1e16f6.entry.js.map +1 -0
  978. package/dist/siemens-ix/{p-35fa9e1a.entry.js → p-c0bf3052.entry.js} +2 -2
  979. package/dist/siemens-ix/{p-1ec8d2b9.entry.js → p-c39a6215.entry.js} +2 -2
  980. package/dist/siemens-ix/p-c5e08d24.entry.js +2 -0
  981. package/dist/siemens-ix/p-c5e08d24.entry.js.map +1 -0
  982. package/dist/siemens-ix/{p-b973db5e.entry.js → p-c841c191.entry.js} +2 -2
  983. package/dist/siemens-ix/p-c841c191.entry.js.map +1 -0
  984. package/dist/siemens-ix/p-c8c3efb6.entry.js +2 -0
  985. package/dist/siemens-ix/p-c8c3efb6.entry.js.map +1 -0
  986. package/dist/siemens-ix/p-cacd4857.entry.js +2 -0
  987. package/dist/siemens-ix/p-cacd4857.entry.js.map +1 -0
  988. package/dist/siemens-ix/p-cdaad9de.entry.js +2 -0
  989. package/dist/siemens-ix/p-cdaad9de.entry.js.map +1 -0
  990. package/dist/siemens-ix/p-ce563a48.js +2 -0
  991. package/dist/siemens-ix/p-ce563a48.js.map +1 -0
  992. package/dist/siemens-ix/p-ce808a3f.entry.js +2 -0
  993. package/dist/siemens-ix/p-ce808a3f.entry.js.map +1 -0
  994. package/dist/siemens-ix/p-d057b634.entry.js +2 -0
  995. package/dist/siemens-ix/p-d1a5b773.entry.js +2 -0
  996. package/dist/siemens-ix/p-d1a5b773.entry.js.map +1 -0
  997. package/dist/siemens-ix/p-d7072aad.entry.js +2 -0
  998. package/dist/siemens-ix/{p-c6dcff7e.entry.js → p-d7a0deb7.entry.js} +2 -2
  999. package/dist/siemens-ix/p-d8780f8c.entry.js +2 -0
  1000. package/dist/siemens-ix/p-d8780f8c.entry.js.map +1 -0
  1001. package/dist/siemens-ix/p-da71920f.entry.js +2 -0
  1002. package/dist/siemens-ix/p-da71920f.entry.js.map +1 -0
  1003. package/dist/siemens-ix/{p-bd24bbde.entry.js → p-dc284f4d.entry.js} +2 -2
  1004. package/dist/siemens-ix/p-dda1ce22.entry.js +2 -0
  1005. package/dist/siemens-ix/p-dda1ce22.entry.js.map +1 -0
  1006. package/dist/siemens-ix/{p-e1bd7b4f.entry.js → p-de44d65b.entry.js} +2 -2
  1007. package/dist/siemens-ix/{p-e1bd7b4f.entry.js.map → p-de44d65b.entry.js.map} +1 -1
  1008. package/dist/siemens-ix/p-e4441794.entry.js +2 -0
  1009. package/dist/siemens-ix/p-e4441794.entry.js.map +1 -0
  1010. package/dist/siemens-ix/{p-15a5bc5a.entry.js → p-e4ca3618.entry.js} +2 -2
  1011. package/dist/siemens-ix/{p-15a5bc5a.entry.js.map → p-e4ca3618.entry.js.map} +1 -1
  1012. package/dist/siemens-ix/p-e6652822.js +2 -0
  1013. package/dist/siemens-ix/p-e6652822.js.map +1 -0
  1014. package/dist/siemens-ix/{p-97f475db.entry.js → p-e89c0e29.entry.js} +2 -2
  1015. package/dist/siemens-ix/{p-ac05950c.entry.js → p-ead295d5.entry.js} +2 -2
  1016. package/dist/siemens-ix/{p-ac05950c.entry.js.map → p-ead295d5.entry.js.map} +1 -1
  1017. package/dist/siemens-ix/p-ec037f98.js +2 -0
  1018. package/dist/siemens-ix/p-ec037f98.js.map +1 -0
  1019. package/dist/siemens-ix/p-ee50f7fa.entry.js +2 -0
  1020. package/dist/siemens-ix/{p-75c61fbf.entry.js → p-f47bd4e8.entry.js} +2 -2
  1021. package/dist/siemens-ix/p-f576c41d.entry.js +2 -0
  1022. package/dist/siemens-ix/{p-18d15442.entry.js.map → p-f576c41d.entry.js.map} +1 -1
  1023. package/dist/siemens-ix/p-f5a9140e.entry.js +2 -0
  1024. package/dist/siemens-ix/p-f5a9140e.entry.js.map +1 -0
  1025. package/dist/siemens-ix/p-f87cd962.js +3 -0
  1026. package/dist/siemens-ix/p-f87cd962.js.map +1 -0
  1027. package/dist/siemens-ix/p-fb593d70.entry.js +2 -0
  1028. package/dist/siemens-ix/p-fb593d70.entry.js.map +1 -0
  1029. package/dist/siemens-ix/{p-702f9349.js → p-fbe017b7.js} +2 -2
  1030. package/dist/siemens-ix/p-fbe017b7.js.map +1 -0
  1031. package/dist/siemens-ix/{p-934ae9a0.entry.js → p-fc766ada.entry.js} +2 -2
  1032. package/dist/siemens-ix/p-fe01bff0.js +2 -0
  1033. package/dist/siemens-ix/p-fe01bff0.js.map +1 -0
  1034. package/dist/siemens-ix/p-ff6668b8.entry.js +2 -0
  1035. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  1036. package/dist/siemens-ix/siemens-ix.css +18 -87
  1037. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  1038. package/dist/siemens-ix/siemens-ix.esm.js.map +1 -1
  1039. package/dist/types/components/action-card/action-card.d.ts +3 -2
  1040. package/dist/types/components/application-header/application-header.d.ts +19 -1
  1041. package/dist/types/components/basic-navigation/basic-navigation.d.ts +2 -1
  1042. package/dist/types/components/blind/blind.d.ts +4 -4
  1043. package/dist/types/components/breadcrumb/breadcrumb.d.ts +3 -3
  1044. package/dist/types/components/button/base-button.d.ts +3 -2
  1045. package/dist/types/components/button/button.d.ts +2 -2
  1046. package/dist/types/components/card/card.d.ts +2 -1
  1047. package/dist/types/components/category-filter/category-filter.d.ts +23 -12
  1048. package/dist/types/components/content-header/content-header.d.ts +1 -1
  1049. package/dist/types/components/css-grid/css-grid.d.ts +2 -2
  1050. package/dist/types/components/date-dropdown/date-dropdown.d.ts +3 -3
  1051. package/dist/types/components/date-picker/date-picker.d.ts +6 -7
  1052. package/dist/types/components/date-time-card/date-time-card.d.ts +1 -1
  1053. package/dist/types/components/dropdown/dropdown-controller.d.ts +1 -7
  1054. package/dist/types/components/dropdown/dropdown.d.ts +11 -10
  1055. package/dist/types/components/dropdown-button/dropdown-button.d.ts +4 -4
  1056. package/dist/types/components/dropdown-item/dropdown-item.d.ts +2 -2
  1057. package/dist/types/components/form-field/form-field.d.ts +10 -0
  1058. package/dist/types/components/group/group.d.ts +7 -6
  1059. package/dist/types/components/group-item/group-item.d.ts +4 -4
  1060. package/dist/types/components/menu-item/menu-item.d.ts +6 -5
  1061. package/dist/types/components/modal/test/modal.ct.d.ts +3 -2
  1062. package/dist/types/components/modal-header/modal-header.d.ts +3 -3
  1063. package/dist/types/components/push-card/push-card.d.ts +4 -3
  1064. package/dist/types/components/select/select.d.ts +12 -93
  1065. package/dist/types/components/slider/slider.d.ts +3 -3
  1066. package/dist/types/components/tab-item/tab-item.d.ts +2 -2
  1067. package/dist/types/components/tabs/tabs.d.ts +7 -4
  1068. package/dist/types/components/toggle/toggle.d.ts +1 -29
  1069. package/dist/types/components/tooltip/tooltip.d.ts +10 -10
  1070. package/dist/types/components/tree/tree.d.ts +1 -1
  1071. package/dist/types/components/tree-item/tree-item.d.ts +3 -3
  1072. package/dist/types/components/typography/type-mapping.d.ts +3 -0
  1073. package/dist/types/components/typography/typography.d.ts +3 -10
  1074. package/dist/types/components/upload/upload.d.ts +4 -2
  1075. package/dist/types/components/utils/a11y.d.ts +5 -5
  1076. package/dist/types/components/utils/disposable-event-listener.d.ts +7 -0
  1077. package/dist/types/components/utils/element-reference.d.ts +1 -0
  1078. package/dist/types/components/utils/focus.d.ts +5 -4
  1079. package/dist/types/components/utils/listener.d.ts +4 -2
  1080. package/dist/types/components/utils/make-ref.d.ts +2 -2
  1081. package/dist/types/components/utils/theme-switcher.d.ts +1 -1
  1082. package/dist/types/components.d.ts +221 -1866
  1083. package/dist/types/index.d.ts +2 -1
  1084. package/dist/types/tests/utils/test/index.d.ts +0 -3
  1085. package/dist/types/tests/utils/test/page.d.ts +1 -3
  1086. package/hydrate/index.js +1802 -3122
  1087. package/package.json +8 -6
  1088. package/scss/_core.scss +5 -0
  1089. package/scss/components/form/_input.scss +19 -72
  1090. package/components/field-label.js +0 -127
  1091. package/components/field-label.js.map +0 -1
  1092. package/components/field-wrapper.js +0 -97
  1093. package/components/field-wrapper.js.map +0 -1
  1094. package/components/helper-text-util.js +0 -48
  1095. package/components/helper-text-util.js.map +0 -1
  1096. package/components/ix-checkbox-group.d.ts +0 -11
  1097. package/components/ix-checkbox-group.js +0 -105
  1098. package/components/ix-checkbox-group.js.map +0 -1
  1099. package/components/ix-checkbox.d.ts +0 -11
  1100. package/components/ix-checkbox.js +0 -141
  1101. package/components/ix-checkbox.js.map +0 -1
  1102. package/components/ix-custom-field.d.ts +0 -11
  1103. package/components/ix-custom-field.js +0 -116
  1104. package/components/ix-custom-field.js.map +0 -1
  1105. package/components/ix-date-field.d.ts +0 -11
  1106. package/components/ix-date-field.js +0 -351
  1107. package/components/ix-date-field.js.map +0 -1
  1108. package/components/ix-field-label.d.ts +0 -11
  1109. package/components/ix-field-label.js +0 -8
  1110. package/components/ix-field-label.js.map +0 -1
  1111. package/components/ix-field-wrapper.d.ts +0 -11
  1112. package/components/ix-field-wrapper.js +0 -8
  1113. package/components/ix-field-wrapper.js.map +0 -1
  1114. package/components/ix-helper-text.d.ts +0 -11
  1115. package/components/ix-helper-text.js +0 -97
  1116. package/components/ix-helper-text.js.map +0 -1
  1117. package/components/ix-layout-form.d.ts +0 -11
  1118. package/components/ix-layout-form.js +0 -113
  1119. package/components/ix-layout-form.js.map +0 -1
  1120. package/components/ix-number-field.d.ts +0 -11
  1121. package/components/ix-number-field.js +0 -217
  1122. package/components/ix-number-field.js.map +0 -1
  1123. package/components/ix-radio-group.d.ts +0 -11
  1124. package/components/ix-radio-group.js +0 -169
  1125. package/components/ix-radio-group.js.map +0 -1
  1126. package/components/ix-radio.d.ts +0 -11
  1127. package/components/ix-radio.js +0 -115
  1128. package/components/ix-radio.js.map +0 -1
  1129. package/components/ix-text-field.js +0 -223
  1130. package/components/ix-text-field.js.map +0 -1
  1131. package/components/ix-textarea-field.d.ts +0 -11
  1132. package/components/ix-textarea-field.js +0 -177
  1133. package/components/ix-textarea-field.js.map +0 -1
  1134. package/components/text-field.util.js +0 -167
  1135. package/components/text-field.util.js.map +0 -1
  1136. package/components/validation.js +0 -112
  1137. package/components/validation.js.map +0 -1
  1138. package/dist/cjs/a11y-32046b56.js.map +0 -1
  1139. package/dist/cjs/base-button-16d4fadf.js.map +0 -1
  1140. package/dist/cjs/context-98f4a0b3.js.map +0 -1
  1141. package/dist/cjs/dropdown-controller-403dc7fa.js.map +0 -1
  1142. package/dist/cjs/floating-ui.dom.esm-94b4d17c.js.map +0 -1
  1143. package/dist/cjs/focus-9c8ffbb0.js.map +0 -1
  1144. package/dist/cjs/helper-text-util-9f617ef2.js +0 -40
  1145. package/dist/cjs/helper-text-util-9f617ef2.js.map +0 -1
  1146. package/dist/cjs/index-0f6297c8.js.map +0 -1
  1147. package/dist/cjs/index-762a29a3.js +0 -24
  1148. package/dist/cjs/index-762a29a3.js.map +0 -1
  1149. package/dist/cjs/ix-checkbox-group.cjs.entry.js +0 -56
  1150. package/dist/cjs/ix-checkbox-group.cjs.entry.js.map +0 -1
  1151. package/dist/cjs/ix-checkbox.cjs.entry.js +0 -114
  1152. package/dist/cjs/ix-checkbox.cjs.entry.js.map +0 -1
  1153. package/dist/cjs/ix-custom-field.cjs.entry.js +0 -65
  1154. package/dist/cjs/ix-custom-field.cjs.entry.js.map +0 -1
  1155. package/dist/cjs/ix-date-field.cjs.entry.js +0 -255
  1156. package/dist/cjs/ix-date-field.cjs.entry.js.map +0 -1
  1157. package/dist/cjs/ix-field-label_3.cjs.entry.js +0 -438
  1158. package/dist/cjs/ix-field-label_3.cjs.entry.js.map +0 -1
  1159. package/dist/cjs/ix-helper-text.cjs.entry.js +0 -70
  1160. package/dist/cjs/ix-helper-text.cjs.entry.js.map +0 -1
  1161. package/dist/cjs/ix-layout-form.cjs.entry.js +0 -94
  1162. package/dist/cjs/ix-layout-form.cjs.entry.js.map +0 -1
  1163. package/dist/cjs/ix-number-field.cjs.entry.js +0 -148
  1164. package/dist/cjs/ix-number-field.cjs.entry.js.map +0 -1
  1165. package/dist/cjs/ix-radio-group.cjs.entry.js +0 -116
  1166. package/dist/cjs/ix-radio-group.cjs.entry.js.map +0 -1
  1167. package/dist/cjs/ix-radio.cjs.entry.js +0 -96
  1168. package/dist/cjs/ix-radio.cjs.entry.js.map +0 -1
  1169. package/dist/cjs/ix-text-field.cjs.entry.js +0 -151
  1170. package/dist/cjs/ix-text-field.cjs.entry.js.map +0 -1
  1171. package/dist/cjs/ix-textarea-field.cjs.entry.js +0 -118
  1172. package/dist/cjs/ix-textarea-field.cjs.entry.js.map +0 -1
  1173. package/dist/cjs/listener-0881dc51.js.map +0 -1
  1174. package/dist/cjs/make-ref-01530e5a.js.map +0 -1
  1175. package/dist/cjs/service-a42add5f.js.map +0 -1
  1176. package/dist/cjs/text-field.util-d7c5c1cd.js +0 -179
  1177. package/dist/cjs/text-field.util-d7c5c1cd.js.map +0 -1
  1178. package/dist/cjs/theme-switcher-2d2bde85.js.map +0 -1
  1179. package/dist/cjs/validation-c5a41d68.js +0 -117
  1180. package/dist/cjs/validation-c5a41d68.js.map +0 -1
  1181. package/dist/collection/components/checkbox/checkbox.css +0 -437
  1182. package/dist/collection/components/checkbox/checkbox.js +0 -323
  1183. package/dist/collection/components/checkbox/checkbox.js.map +0 -1
  1184. package/dist/collection/components/checkbox/tests/checkbox.ct.js +0 -52
  1185. package/dist/collection/components/checkbox/tests/checkbox.ct.js.map +0 -1
  1186. package/dist/collection/components/checkbox-group/checkbox-group.css +0 -35
  1187. package/dist/collection/components/checkbox-group/checkbox-group.js +0 -173
  1188. package/dist/collection/components/checkbox-group/checkbox-group.js.map +0 -1
  1189. package/dist/collection/components/custom-field/custom-field.css +0 -11
  1190. package/dist/collection/components/custom-field/custom-field.js +0 -216
  1191. package/dist/collection/components/custom-field/custom-field.js.map +0 -1
  1192. package/dist/collection/components/custom-field/tests/custom-field.ct.js +0 -68
  1193. package/dist/collection/components/custom-field/tests/custom-field.ct.js.map +0 -1
  1194. package/dist/collection/components/date-field/date-field.css +0 -938
  1195. package/dist/collection/components/date-field/date-field.js +0 -696
  1196. package/dist/collection/components/date-field/date-field.js.map +0 -1
  1197. package/dist/collection/components/date-field/tests/date-field.ct.js +0 -114
  1198. package/dist/collection/components/date-field/tests/date-field.ct.js.map +0 -1
  1199. package/dist/collection/components/field-label/field-label.css +0 -14
  1200. package/dist/collection/components/field-label/field-label.js +0 -173
  1201. package/dist/collection/components/field-label/field-label.js.map +0 -1
  1202. package/dist/collection/components/field-label/tests/field-label.ct.js +0 -70
  1203. package/dist/collection/components/field-label/tests/field-label.ct.js.map +0 -1
  1204. package/dist/collection/components/field-wrapper/field-wrapper.css +0 -71
  1205. package/dist/collection/components/field-wrapper/field-wrapper.js +0 -309
  1206. package/dist/collection/components/field-wrapper/field-wrapper.js.map +0 -1
  1207. package/dist/collection/components/field-wrapper/helper-text-util.js +0 -26
  1208. package/dist/collection/components/field-wrapper/helper-text-util.js.map +0 -1
  1209. package/dist/collection/components/field-wrapper/tests/field-wrapper.ct.js +0 -63
  1210. package/dist/collection/components/field-wrapper/tests/field-wrapper.ct.js.map +0 -1
  1211. package/dist/collection/components/helper-text/helper-text.css +0 -34
  1212. package/dist/collection/components/helper-text/helper-text.js +0 -179
  1213. package/dist/collection/components/helper-text/helper-text.js.map +0 -1
  1214. package/dist/collection/components/layout-form/layout-form.css +0 -15
  1215. package/dist/collection/components/layout-form/layout-form.js +0 -126
  1216. package/dist/collection/components/layout-form/layout-form.js.map +0 -1
  1217. package/dist/collection/components/radio/radio.css +0 -428
  1218. package/dist/collection/components/radio/radio.js +0 -276
  1219. package/dist/collection/components/radio/radio.js.map +0 -1
  1220. package/dist/collection/components/radio/test/radio.ct.js +0 -36
  1221. package/dist/collection/components/radio/test/radio.ct.js.map +0 -1
  1222. package/dist/collection/components/radio-group/radio-group.css +0 -35
  1223. package/dist/collection/components/radio-group/radio-group.js +0 -296
  1224. package/dist/collection/components/radio-group/radio-group.js.map +0 -1
  1225. package/dist/collection/components/radio-group/test/radio-group.ct.js +0 -99
  1226. package/dist/collection/components/radio-group/test/radio-group.ct.js.map +0 -1
  1227. package/dist/collection/components/text-field/input.fc.js +0 -38
  1228. package/dist/collection/components/text-field/input.fc.js.map +0 -1
  1229. package/dist/collection/components/text-field/number-field.js +0 -586
  1230. package/dist/collection/components/text-field/number-field.js.map +0 -1
  1231. package/dist/collection/components/text-field/tests/form-ready.ct.js +0 -63
  1232. package/dist/collection/components/text-field/tests/form-ready.ct.js.map +0 -1
  1233. package/dist/collection/components/text-field/text-field.animation.js +0 -36
  1234. package/dist/collection/components/text-field/text-field.animation.js.map +0 -1
  1235. package/dist/collection/components/text-field/text-field.css +0 -899
  1236. package/dist/collection/components/text-field/text-field.js +0 -594
  1237. package/dist/collection/components/text-field/text-field.js.map +0 -1
  1238. package/dist/collection/components/text-field/text-field.util.js +0 -93
  1239. package/dist/collection/components/text-field/text-field.util.js.map +0 -1
  1240. package/dist/collection/components/text-field/textarea-field.css +0 -550
  1241. package/dist/collection/components/text-field/textarea-field.js +0 -595
  1242. package/dist/collection/components/text-field/textarea-field.js.map +0 -1
  1243. package/dist/collection/components/utils/attributes.js +0 -25
  1244. package/dist/collection/components/utils/attributes.js.map +0 -1
  1245. package/dist/collection/components/utils/field/index.js +0 -9
  1246. package/dist/collection/components/utils/field/index.js.map +0 -1
  1247. package/dist/collection/components/utils/field/validation.js +0 -108
  1248. package/dist/collection/components/utils/field/validation.js.map +0 -1
  1249. package/dist/collection/components/utils/testing/index.js +0 -9
  1250. package/dist/collection/components/utils/testing/index.js.map +0 -1
  1251. package/dist/collection/components/utils/uuid.js +0 -16
  1252. package/dist/collection/components/utils/uuid.js.map +0 -1
  1253. package/dist/collection/tests/form-fields/form-fields.e2e.js +0 -57
  1254. package/dist/collection/tests/form-fields/form-fields.e2e.js.map +0 -1
  1255. package/dist/esm/a11y-13dedaef.js.map +0 -1
  1256. package/dist/esm/base-button-ea06697f.js.map +0 -1
  1257. package/dist/esm/context-c9078420.js.map +0 -1
  1258. package/dist/esm/dropdown-controller-d6d8b14a.js.map +0 -1
  1259. package/dist/esm/floating-ui.dom.esm-6e7c098f.js.map +0 -1
  1260. package/dist/esm/focus-d4d3abaf.js.map +0 -1
  1261. package/dist/esm/helper-text-util-3dd33b44.js +0 -38
  1262. package/dist/esm/helper-text-util-3dd33b44.js.map +0 -1
  1263. package/dist/esm/index-9103b14c.js.map +0 -1
  1264. package/dist/esm/index-f51bf247.js +0 -14
  1265. package/dist/esm/index-f51bf247.js.map +0 -1
  1266. package/dist/esm/ix-checkbox-group.entry.js +0 -52
  1267. package/dist/esm/ix-checkbox-group.entry.js.map +0 -1
  1268. package/dist/esm/ix-checkbox.entry.js +0 -110
  1269. package/dist/esm/ix-checkbox.entry.js.map +0 -1
  1270. package/dist/esm/ix-custom-field.entry.js +0 -61
  1271. package/dist/esm/ix-custom-field.entry.js.map +0 -1
  1272. package/dist/esm/ix-date-field.entry.js +0 -251
  1273. package/dist/esm/ix-date-field.entry.js.map +0 -1
  1274. package/dist/esm/ix-field-label_3.entry.js +0 -432
  1275. package/dist/esm/ix-field-label_3.entry.js.map +0 -1
  1276. package/dist/esm/ix-helper-text.entry.js +0 -66
  1277. package/dist/esm/ix-helper-text.entry.js.map +0 -1
  1278. package/dist/esm/ix-layout-form.entry.js +0 -90
  1279. package/dist/esm/ix-layout-form.entry.js.map +0 -1
  1280. package/dist/esm/ix-number-field.entry.js +0 -144
  1281. package/dist/esm/ix-number-field.entry.js.map +0 -1
  1282. package/dist/esm/ix-radio-group.entry.js +0 -112
  1283. package/dist/esm/ix-radio-group.entry.js.map +0 -1
  1284. package/dist/esm/ix-radio.entry.js +0 -92
  1285. package/dist/esm/ix-radio.entry.js.map +0 -1
  1286. package/dist/esm/ix-text-field.entry.js +0 -147
  1287. package/dist/esm/ix-text-field.entry.js.map +0 -1
  1288. package/dist/esm/ix-textarea-field.entry.js +0 -114
  1289. package/dist/esm/ix-textarea-field.entry.js.map +0 -1
  1290. package/dist/esm/listener-98571ba8.js.map +0 -1
  1291. package/dist/esm/make-ref-6b3b4e16.js.map +0 -1
  1292. package/dist/esm/menu-tabs-fc-7ec1fb5d.js.map +0 -1
  1293. package/dist/esm/service-02cc9011.js.map +0 -1
  1294. package/dist/esm/text-field.util-6a84bffd.js +0 -167
  1295. package/dist/esm/text-field.util-6a84bffd.js.map +0 -1
  1296. package/dist/esm/theme-switcher-b10fb4da.js.map +0 -1
  1297. package/dist/esm/validation-9db7dfa3.js +0 -112
  1298. package/dist/esm/validation-9db7dfa3.js.map +0 -1
  1299. package/dist/siemens-ix/p-02ed5606.entry.js +0 -2
  1300. package/dist/siemens-ix/p-0681f4d8.entry.js +0 -2
  1301. package/dist/siemens-ix/p-0681f4d8.entry.js.map +0 -1
  1302. package/dist/siemens-ix/p-06965e5f.entry.js.map +0 -1
  1303. package/dist/siemens-ix/p-08215ad3.entry.js +0 -2
  1304. package/dist/siemens-ix/p-08215ad3.entry.js.map +0 -1
  1305. package/dist/siemens-ix/p-0bed10af.entry.js +0 -2
  1306. package/dist/siemens-ix/p-0d907964.entry.js +0 -2
  1307. package/dist/siemens-ix/p-0dfc3b80.entry.js +0 -2
  1308. package/dist/siemens-ix/p-104097fb.entry.js.map +0 -1
  1309. package/dist/siemens-ix/p-18d15442.entry.js +0 -2
  1310. package/dist/siemens-ix/p-1da901d5.js.map +0 -1
  1311. package/dist/siemens-ix/p-1df98c59.entry.js +0 -2
  1312. package/dist/siemens-ix/p-1df98c59.entry.js.map +0 -1
  1313. package/dist/siemens-ix/p-224ebf90.js +0 -2
  1314. package/dist/siemens-ix/p-224ebf90.js.map +0 -1
  1315. package/dist/siemens-ix/p-2442ad01.entry.js +0 -2
  1316. package/dist/siemens-ix/p-2442ad01.entry.js.map +0 -1
  1317. package/dist/siemens-ix/p-277980fa.entry.js +0 -2
  1318. package/dist/siemens-ix/p-277980fa.entry.js.map +0 -1
  1319. package/dist/siemens-ix/p-36c0f378.js +0 -2
  1320. package/dist/siemens-ix/p-36c0f378.js.map +0 -1
  1321. package/dist/siemens-ix/p-3730ac72.entry.js +0 -2
  1322. package/dist/siemens-ix/p-3730ac72.entry.js.map +0 -1
  1323. package/dist/siemens-ix/p-3782e028.js +0 -2
  1324. package/dist/siemens-ix/p-3782e028.js.map +0 -1
  1325. package/dist/siemens-ix/p-37ca7ed4.js.map +0 -1
  1326. package/dist/siemens-ix/p-399bb0ce.entry.js +0 -2
  1327. package/dist/siemens-ix/p-399bb0ce.entry.js.map +0 -1
  1328. package/dist/siemens-ix/p-3a5f7b61.entry.js +0 -2
  1329. package/dist/siemens-ix/p-3a5f7b61.entry.js.map +0 -1
  1330. package/dist/siemens-ix/p-3de71a19.entry.js.map +0 -1
  1331. package/dist/siemens-ix/p-4017727a.entry.js +0 -2
  1332. package/dist/siemens-ix/p-4017727a.entry.js.map +0 -1
  1333. package/dist/siemens-ix/p-42c66a44.js +0 -2
  1334. package/dist/siemens-ix/p-42c66a44.js.map +0 -1
  1335. package/dist/siemens-ix/p-4a335b55.entry.js +0 -2
  1336. package/dist/siemens-ix/p-4a335b55.entry.js.map +0 -1
  1337. package/dist/siemens-ix/p-4b69ab0d.entry.js +0 -2
  1338. package/dist/siemens-ix/p-50cae62d.entry.js +0 -2
  1339. package/dist/siemens-ix/p-53e62b51.entry.js +0 -2
  1340. package/dist/siemens-ix/p-56d01130.entry.js +0 -2
  1341. package/dist/siemens-ix/p-56d01130.entry.js.map +0 -1
  1342. package/dist/siemens-ix/p-576b09c9.entry.js +0 -2
  1343. package/dist/siemens-ix/p-576b09c9.entry.js.map +0 -1
  1344. package/dist/siemens-ix/p-5a6d8b69.entry.js +0 -2
  1345. package/dist/siemens-ix/p-5a6d8b69.entry.js.map +0 -1
  1346. package/dist/siemens-ix/p-5bf40a9f.entry.js +0 -2
  1347. package/dist/siemens-ix/p-5eb935a3.entry.js +0 -2
  1348. package/dist/siemens-ix/p-5eb935a3.entry.js.map +0 -1
  1349. package/dist/siemens-ix/p-628c8612.entry.js +0 -2
  1350. package/dist/siemens-ix/p-628c8612.entry.js.map +0 -1
  1351. package/dist/siemens-ix/p-6bd0ba14.entry.js.map +0 -1
  1352. package/dist/siemens-ix/p-6f83793b.entry.js +0 -2
  1353. package/dist/siemens-ix/p-6f83793b.entry.js.map +0 -1
  1354. package/dist/siemens-ix/p-702f9349.js.map +0 -1
  1355. package/dist/siemens-ix/p-70a7bd22.entry.js +0 -2
  1356. package/dist/siemens-ix/p-70a7bd22.entry.js.map +0 -1
  1357. package/dist/siemens-ix/p-73e0eb40.entry.js +0 -2
  1358. package/dist/siemens-ix/p-73e0eb40.entry.js.map +0 -1
  1359. package/dist/siemens-ix/p-787293f4.entry.js +0 -2
  1360. package/dist/siemens-ix/p-787293f4.entry.js.map +0 -1
  1361. package/dist/siemens-ix/p-79c848ec.entry.js +0 -2
  1362. package/dist/siemens-ix/p-79c848ec.entry.js.map +0 -1
  1363. package/dist/siemens-ix/p-7c36d3fa.js +0 -2
  1364. package/dist/siemens-ix/p-7c36d3fa.js.map +0 -1
  1365. package/dist/siemens-ix/p-7f4b78e5.js +0 -2
  1366. package/dist/siemens-ix/p-7f4b78e5.js.map +0 -1
  1367. package/dist/siemens-ix/p-815dd9a1.entry.js +0 -2
  1368. package/dist/siemens-ix/p-815dd9a1.entry.js.map +0 -1
  1369. package/dist/siemens-ix/p-83b8b502.entry.js +0 -2
  1370. package/dist/siemens-ix/p-83b8b502.entry.js.map +0 -1
  1371. package/dist/siemens-ix/p-86b46723.entry.js +0 -2
  1372. package/dist/siemens-ix/p-86b46723.entry.js.map +0 -1
  1373. package/dist/siemens-ix/p-87d7aaf9.entry.js +0 -2
  1374. package/dist/siemens-ix/p-87d7aaf9.entry.js.map +0 -1
  1375. package/dist/siemens-ix/p-8e10d2f2.entry.js +0 -2
  1376. package/dist/siemens-ix/p-8e10d2f2.entry.js.map +0 -1
  1377. package/dist/siemens-ix/p-9010831e.entry.js +0 -2
  1378. package/dist/siemens-ix/p-9010831e.entry.js.map +0 -1
  1379. package/dist/siemens-ix/p-921c59c4.entry.js.map +0 -1
  1380. package/dist/siemens-ix/p-9ec92185.entry.js.map +0 -1
  1381. package/dist/siemens-ix/p-a9b0c087.entry.js +0 -2
  1382. package/dist/siemens-ix/p-aae05303.entry.js.map +0 -1
  1383. package/dist/siemens-ix/p-ac6c6d3f.entry.js +0 -2
  1384. package/dist/siemens-ix/p-ac6c6d3f.entry.js.map +0 -1
  1385. package/dist/siemens-ix/p-aca94a5e.entry.js +0 -2
  1386. package/dist/siemens-ix/p-aca94a5e.entry.js.map +0 -1
  1387. package/dist/siemens-ix/p-ae7fdfa6.entry.js +0 -2
  1388. package/dist/siemens-ix/p-ae7fdfa6.entry.js.map +0 -1
  1389. package/dist/siemens-ix/p-b3f35666.js +0 -2
  1390. package/dist/siemens-ix/p-b3f35666.js.map +0 -1
  1391. package/dist/siemens-ix/p-b6c0dfb5.entry.js +0 -2
  1392. package/dist/siemens-ix/p-b8ed7953.entry.js +0 -2
  1393. package/dist/siemens-ix/p-b8ed7953.entry.js.map +0 -1
  1394. package/dist/siemens-ix/p-b973db5e.entry.js.map +0 -1
  1395. package/dist/siemens-ix/p-b9b59a08.entry.js +0 -2
  1396. package/dist/siemens-ix/p-b9b59a08.entry.js.map +0 -1
  1397. package/dist/siemens-ix/p-bc1e92ac.js +0 -2
  1398. package/dist/siemens-ix/p-c09553f3.js +0 -2
  1399. package/dist/siemens-ix/p-c09553f3.js.map +0 -1
  1400. package/dist/siemens-ix/p-c3db120e.entry.js +0 -2
  1401. package/dist/siemens-ix/p-c66e4a5f.entry.js +0 -2
  1402. package/dist/siemens-ix/p-c71d1690.entry.js +0 -2
  1403. package/dist/siemens-ix/p-c71d1690.entry.js.map +0 -1
  1404. package/dist/siemens-ix/p-cce7a3d5.js +0 -2
  1405. package/dist/siemens-ix/p-cce7a3d5.js.map +0 -1
  1406. package/dist/siemens-ix/p-ce8a0611.entry.js +0 -2
  1407. package/dist/siemens-ix/p-ce8a0611.entry.js.map +0 -1
  1408. package/dist/siemens-ix/p-cf65d3b6.entry.js +0 -2
  1409. package/dist/siemens-ix/p-cf65d3b6.entry.js.map +0 -1
  1410. package/dist/siemens-ix/p-cfcd2bd3.entry.js +0 -2
  1411. package/dist/siemens-ix/p-cfcd2bd3.entry.js.map +0 -1
  1412. package/dist/siemens-ix/p-d7131f75.entry.js +0 -2
  1413. package/dist/siemens-ix/p-d7131f75.entry.js.map +0 -1
  1414. package/dist/siemens-ix/p-da8517ed.js +0 -2
  1415. package/dist/siemens-ix/p-da8517ed.js.map +0 -1
  1416. package/dist/siemens-ix/p-dead9c8e.js +0 -2
  1417. package/dist/siemens-ix/p-dead9c8e.js.map +0 -1
  1418. package/dist/siemens-ix/p-e5218382.entry.js +0 -2
  1419. package/dist/siemens-ix/p-e5218382.entry.js.map +0 -1
  1420. package/dist/siemens-ix/p-e72dfb3c.entry.js +0 -2
  1421. package/dist/siemens-ix/p-e72dfb3c.entry.js.map +0 -1
  1422. package/dist/siemens-ix/p-ec0806c3.entry.js.map +0 -1
  1423. package/dist/siemens-ix/p-ed991838.js.map +0 -1
  1424. package/dist/siemens-ix/p-edd99767.entry.js +0 -2
  1425. package/dist/siemens-ix/p-edd99767.entry.js.map +0 -1
  1426. package/dist/siemens-ix/p-ef6171a2.entry.js +0 -2
  1427. package/dist/siemens-ix/p-f0bbd496.entry.js.map +0 -1
  1428. package/dist/siemens-ix/p-f22e4bb2.entry.js +0 -2
  1429. package/dist/siemens-ix/p-f22e4bb2.entry.js.map +0 -1
  1430. package/dist/siemens-ix/p-f37ac17d.entry.js.map +0 -1
  1431. package/dist/siemens-ix/p-f3c3366d.entry.js +0 -2
  1432. package/dist/siemens-ix/p-f86a894a.js +0 -3
  1433. package/dist/siemens-ix/p-f86a894a.js.map +0 -1
  1434. package/dist/types/components/checkbox/checkbox.d.ts +0 -61
  1435. package/dist/types/components/checkbox-group/checkbox-group.d.ts +0 -40
  1436. package/dist/types/components/custom-field/custom-field.d.ts +0 -46
  1437. package/dist/types/components/date-field/date-field.d.ts +0 -127
  1438. package/dist/types/components/field-label/field-label.d.ts +0 -27
  1439. package/dist/types/components/field-label/tests/field-label.ct.d.ts +0 -1
  1440. package/dist/types/components/field-wrapper/field-wrapper.d.ts +0 -64
  1441. package/dist/types/components/field-wrapper/helper-text-util.d.ts +0 -11
  1442. package/dist/types/components/field-wrapper/tests/field-wrapper.ct.d.ts +0 -1
  1443. package/dist/types/components/helper-text/helper-text.d.ts +0 -37
  1444. package/dist/types/components/layout-form/layout-form.d.ts +0 -22
  1445. package/dist/types/components/radio/radio.d.ts +0 -53
  1446. package/dist/types/components/radio/test/radio.ct.d.ts +0 -1
  1447. package/dist/types/components/radio-group/radio-group.d.ts +0 -60
  1448. package/dist/types/components/radio-group/test/radio-group.ct.d.ts +0 -1
  1449. package/dist/types/components/text-field/input.fc.d.ts +0 -50
  1450. package/dist/types/components/text-field/number-field.d.ts +0 -117
  1451. package/dist/types/components/text-field/tests/form-ready.ct.d.ts +0 -1
  1452. package/dist/types/components/text-field/text-field.animation.d.ts +0 -1
  1453. package/dist/types/components/text-field/text-field.d.ts +0 -119
  1454. package/dist/types/components/text-field/text-field.util.d.ts +0 -13
  1455. package/dist/types/components/text-field/textarea-field.d.ts +0 -127
  1456. package/dist/types/components/utils/attributes.d.ts +0 -2
  1457. package/dist/types/components/utils/field/index.d.ts +0 -60
  1458. package/dist/types/components/utils/field/validation.d.ts +0 -15
  1459. package/dist/types/components/utils/testing/index.d.ts +0 -0
  1460. package/dist/types/components/utils/uuid.d.ts +0 -1
  1461. package/scss/mixins/_field.scss +0 -18
  1462. package/scss/mixins/validation/_form-component.scss +0 -63
  1463. /package/dist/siemens-ix/{p-781a1922.entry.js.map → p-0379b864.entry.js.map} +0 -0
  1464. /package/dist/siemens-ix/{p-846cf6d2.entry.js.map → p-054451cb.entry.js.map} +0 -0
  1465. /package/dist/siemens-ix/{p-53e62b51.entry.js.map → p-0996d9f6.entry.js.map} +0 -0
  1466. /package/dist/siemens-ix/{p-8d737a35.entry.js.map → p-0f4e62f3.entry.js.map} +0 -0
  1467. /package/dist/siemens-ix/{p-c66e4a5f.entry.js.map → p-1a8e3fea.entry.js.map} +0 -0
  1468. /package/dist/siemens-ix/{p-b789e0e7.entry.js.map → p-1e3d6d27.entry.js.map} +0 -0
  1469. /package/dist/siemens-ix/{p-6c412b52.entry.js.map → p-315ecf68.entry.js.map} +0 -0
  1470. /package/dist/siemens-ix/{p-bc1e92ac.js.map → p-3b576b4e.js.map} +0 -0
  1471. /package/dist/siemens-ix/{p-293dd6d1.entry.js.map → p-41d9a2e4.entry.js.map} +0 -0
  1472. /package/dist/siemens-ix/{p-35690183.entry.js.map → p-509dba4c.entry.js.map} +0 -0
  1473. /package/dist/siemens-ix/{p-6ca97a73.entry.js.map → p-50bcb3f8.entry.js.map} +0 -0
  1474. /package/dist/siemens-ix/{p-628f031a.entry.js.map → p-5232d441.entry.js.map} +0 -0
  1475. /package/dist/siemens-ix/{p-3b38f812.entry.js.map → p-6913e59d.entry.js.map} +0 -0
  1476. /package/dist/siemens-ix/{p-9cc0d11b.entry.js.map → p-7354cdb0.entry.js.map} +0 -0
  1477. /package/dist/siemens-ix/{p-a9b0c087.entry.js.map → p-73bd61ca.entry.js.map} +0 -0
  1478. /package/dist/siemens-ix/{p-dde0af66.entry.js.map → p-74461f94.entry.js.map} +0 -0
  1479. /package/dist/siemens-ix/{p-0bed10af.entry.js.map → p-99a1cd81.entry.js.map} +0 -0
  1480. /package/dist/siemens-ix/{p-80051a81.entry.js.map → p-ad0c6a32.entry.js.map} +0 -0
  1481. /package/dist/siemens-ix/{p-8dcf30ce.entry.js.map → p-b247d124.entry.js.map} +0 -0
  1482. /package/dist/siemens-ix/{p-9569e1a2.entry.js.map → p-b6a11e17.entry.js.map} +0 -0
  1483. /package/dist/siemens-ix/{p-0dfc3b80.entry.js.map → p-b9e66925.entry.js.map} +0 -0
  1484. /package/dist/siemens-ix/{p-1f771917.entry.js.map → p-ba2e041e.entry.js.map} +0 -0
  1485. /package/dist/siemens-ix/{p-35fa9e1a.entry.js.map → p-c0bf3052.entry.js.map} +0 -0
  1486. /package/dist/siemens-ix/{p-1ec8d2b9.entry.js.map → p-c39a6215.entry.js.map} +0 -0
  1487. /package/dist/siemens-ix/{p-5bf40a9f.entry.js.map → p-d057b634.entry.js.map} +0 -0
  1488. /package/dist/siemens-ix/{p-c3db120e.entry.js.map → p-d7072aad.entry.js.map} +0 -0
  1489. /package/dist/siemens-ix/{p-c6dcff7e.entry.js.map → p-d7a0deb7.entry.js.map} +0 -0
  1490. /package/dist/siemens-ix/{p-bd24bbde.entry.js.map → p-dc284f4d.entry.js.map} +0 -0
  1491. /package/dist/siemens-ix/{p-97f475db.entry.js.map → p-e89c0e29.entry.js.map} +0 -0
  1492. /package/dist/siemens-ix/{p-50cae62d.entry.js.map → p-ee50f7fa.entry.js.map} +0 -0
  1493. /package/dist/siemens-ix/{p-75c61fbf.entry.js.map → p-f47bd4e8.entry.js.map} +0 -0
  1494. /package/dist/siemens-ix/{p-934ae9a0.entry.js.map → p-fc766ada.entry.js.map} +0 -0
  1495. /package/dist/siemens-ix/{p-ef6171a2.entry.js.map → p-ff6668b8.entry.js.map} +0 -0
  1496. /package/dist/types/components/{checkbox/tests/checkbox.ct.d.ts → category-filter/test/category-filter.ct.d.ts} +0 -0
  1497. /package/dist/types/components/{custom-field/tests/custom-field.ct.d.ts → menu-about/test/menu-about.ct.d.ts} +0 -0
  1498. /package/dist/types/components/{date-field/tests/date-field.ct.d.ts → upload/test/upload.ct.d.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../../../src/components/tooltip/tooltip.tsx"],"names":[],"mappings":";;;;;;AAAA;;;;;;;GAOG;AACH,OAAO,EACL,KAAK,EACL,UAAU,EACV,eAAe,EAEf,IAAI,EACJ,MAAM,EACN,KAAK,GACN,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EACL,SAAS,EACT,OAAO,EACP,CAAC,EACD,IAAI,EACJ,MAAM,EACN,IAAI,EACJ,KAAK,GACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AASzD,MAAM,aAAa,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAE7E;;;;;GAKG;AAMH,MAAM,OAAO,OAAO;;;;2BAcI,KAAK;yBAQ8B,KAAK;yBAG1C,CAAC;yBAGD,EAAE;8BAGG,KAAK;uBAEX,KAAK;;IAUxB,IAAY,YAAY;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAEO,iBAAiB;QACvB,IAAI,IAAI,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;YACzC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,gBAAgB;IAEhB,KAAK,CAAC,WAAW,CAAC,aAAkB;QAClC,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACtC,MAAM,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;QAE/C,IAAI,CAAC,kBAAkB,GAAG,UAAU,CAAC,GAAG,EAAE;YACxC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAChC,mEAAmE;YACnE,uDAAuD;YACvD,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;QAC3C,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IACrB,CAAC;IAED,gBAAgB;IAEhB,KAAK,CAAC,WAAW;QACf,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACtC,IAAI,SAAS,GAAG,EAAE,CAAC;QAEnB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACrD,SAAS,GAAG,GAAG,CAAC;QAClB,CAAC;QAED,IAAI,CAAC,kBAAkB,GAAG,UAAU,CAAC,GAAG,EAAE;YACxC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,EAAE,SAAS,CAAC,CAAC;QACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAEO,oBAAoB,CAAC,EAC3B,SAAS,EACT,cAAc,GACQ;QACtB,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,cAAc,CAAC,KAAK,CAAC;QAEpC,IAAI,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YAChC,OAAO;gBACL,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;gBACtB,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC;aACtB,CAAC;QACJ,CAAC;QAED,IAAI,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,OAAO;gBACL,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;gBACvB,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC;aACtB,CAAC;QACJ,CAAC;QAED,IAAI,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,OAAO;gBACL,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;gBACtB,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;aACvB,CAAC;QACJ,CAAC;QAED,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YACjC,OAAO;gBACL,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;gBACxB,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC;aACtB,CAAC;QACJ,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,sBAAsB,CAAC,MAAe;QAClD,MAAM,eAAe,GAAG,MAAM,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE;YACtE,QAAQ,EAAE,OAAO;YACjB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,UAAU,EAAE;gBACV,KAAK,EAAE;gBACP,MAAM,CAAC,EAAE,CAAC;gBACV,KAAK,CAAC;oBACJ,OAAO,EAAE,IAAI,CAAC,YAAY;iBAC3B,CAAC;gBACF,IAAI,CAAC;oBACH,gBAAgB,EAAE,kBAAkB;oBACpC,OAAO,EAAE,EAAE;iBACZ,CAAC;aACH;SACF,CAAC,CAAC;QACH,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,yBAAyB,CAAC,eAAsC;QACtE,MAAM,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,CAAC;QACjE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;IACxD,CAAC;IAEO,KAAK,CAAC,oBAAoB,CAAC,MAAe;QAChD,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,OAAO,IAAI,OAAO,CAAwB,CAAC,OAAO,EAAE,EAAE;YACpD,IAAI,CAAC,iBAAiB,GAAG,UAAU,CACjC,MAAM,EACN,IAAI,CAAC,WAAW,EAChB,KAAK,IAAI,EAAE;gBACT,UAAU,CAAC,KAAK,IAAI,EAAE;oBACpB,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;oBAElE,IAAI,eAAe,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;wBACzC,IAAI,CAAC,yBAAyB,CAAC,eAAe,CAAC,CAAC;oBAClD,CAAC;oBAED,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,eAAe,CAAC;oBACjC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;wBACpC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;wBAChC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;qBAChC,CAAC,CAAC;oBAEH,OAAO,CAAC,eAAe,CAAC,CAAC;gBAC3B,CAAC,CAAC,CAAC;YACL,CAAC,EACD;gBACE,cAAc,EAAE,IAAI;gBACpB,cAAc,EAAE,IAAI;gBACpB,aAAa,EAAE,IAAI;gBACnB,cAAc,EAAE,IAAI,CAAC,cAAc;aACpC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,mBAAmB;QAC/B,IAAI,OAAO,IAAI,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;YACjC,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1E,CAAC;QAED,IAAI,IAAI,CAAC,GAAG,YAAY,WAAW,EAAE,CAAC;YACpC,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QACrC,CAAC;QAED,IAAI,IAAI,CAAC,GAAG,YAAY,OAAO,EAAE,CAAC;YAChC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC;YAC/B,OAAO,CAAC,OAAO,CAAC,CAAC;QACnB,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,uBAAuB;QACnC,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE5D,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,kBAAkB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACrC,MAAM,YAAY,GAAG,GAAG,EAAE;gBACxB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC5B,CAAC,CAAC;YAEF,MAAM,YAAY,GAAG,GAAG,EAAE;gBACxB,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,CAAC;YAEF,MAAM,SAAS,GAAG,GAAG,EAAE;gBACrB,IAAI,IAAI,CAAC,kBAAkB,KAAK,SAAS,EAAE,CAAC;oBAC1C,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;gBACxC,CAAC;gBAED,YAAY,EAAE,CAAC;YACjB,CAAC,CAAC;YAEF,MAAM,UAAU,GAAG,GAAG,EAAE;gBACtB,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,CAAC;YAEF,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;YACrD,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;YACrD,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;YAC/C,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAEjD,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE;gBAC1B,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;gBACxD,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;gBACxD,OAAO,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;gBAClD,OAAO,CAAC,mBAAmB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YACtD,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,uBAAuB;QAC7B,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC;QAC7B,WAAW,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAC1E,WAAW,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAEvE,WAAW,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACrE,WAAW,CAAC,gBAAgB,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IACrE,CAAC;IAGK,AAAN,KAAK,CAAC,SAAS,CAAC,KAAoB;QAClC,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACxC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE;YACnC,UAAU,EAAE,IAAI;YAChB,eAAe,EAAE,CAAC,iBAAiB,CAAC;YACpC,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,iBAAiB;QACf,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,oBAAoB;;QAClB,MAAA,IAAI,CAAC,QAAQ,0CAAE,UAAU,EAAE,CAAC;QAC5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE;gBACL,OAAO,EAAE,IAAI,CAAC,OAAO;aACtB,EACD,IAAI,EAAC,SAAS;YAEd,4DAAK,KAAK,EAAE,eAAe;gBACzB,6DAAM,IAAI,EAAC,YAAY,GAAQ;gBAC/B,sEAAe,OAAO,EAAC,eAAe;oBACnC,IAAI,CAAC,YAAY;oBAClB,6DAAM,IAAI,EAAC,eAAe,GAAQ,CACpB,CACZ;YACN,4DAAK,KAAK,EAAE,iBAAiB;gBAC3B,8DAAa,CACT;YACN,4DAAK,KAAK,EAAC,OAAO,GAAO,CACpB,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF;AArEO;IADL,UAAU,CAAU,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC;wCAKtD","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport {\n arrow,\n autoUpdate,\n computePosition,\n ComputePositionReturn,\n flip,\n offset,\n shift,\n} from '@floating-ui/dom';\nimport {\n Component,\n Element,\n h,\n Host,\n Method,\n Prop,\n State,\n} from '@stencil/core';\nimport { OnListener } from '../utils/listener';\nimport { tooltipController } from './tooltip-controller';\nimport { IxOverlayComponent } from '../utils/overlay';\n\ntype ArrowPosition = {\n top?: string;\n left?: string;\n right?: string;\n};\n\nconst numberToPixel = (value: number) => (value != null ? `${value}px` : '');\n\n/**\n * @slot title-icon - Icon of tooltip title\n * @slot title-content - Content of tooltip title\n *\n * @since 1.4.0\n */\n@Component({\n tag: 'ix-tooltip',\n styleUrl: 'tooltip.scss',\n shadow: true,\n})\nexport class Tooltip implements IxOverlayComponent {\n /**\n * CSS selector for hover trigger element e.g. `for=\"[data-my-custom-select]\"`\n */\n @Prop() for: string | HTMLElement | Promise<HTMLElement>;\n\n /**\n * Title of the tooltip\n */\n @Prop() titleContent: string;\n\n /**\n * Define if the user can access the tooltip via mouse.\n */\n @Prop() interactive = false;\n\n /**\n * Initial placement of the tooltip. If the placement don\"t have enough space,\n * the tooltip will placed on another location.\n *\n * @since 1.5.0\n */\n @Prop() placement: 'top' | 'right' | 'bottom' | 'left' = 'top';\n\n /** @internal */\n @Prop() showDelay = 0;\n\n /** @internal */\n @Prop() hideDelay = 50;\n\n /** @internal */\n @Prop() animationFrame = false;\n\n @State() visible = false;\n\n @Element() hostElement: HTMLIxTooltipElement;\n\n private observer: MutationObserver;\n private hideTooltipTimeout: NodeJS.Timeout;\n private showTooltipTimeout: NodeJS.Timeout;\n private disposeAutoUpdate?: () => void;\n private disposeListener: () => void;\n\n private get arrowElement(): HTMLElement {\n return this.hostElement.shadowRoot.querySelector('.arrow');\n }\n\n private destroyAutoUpdate() {\n if (this.disposeAutoUpdate !== undefined) {\n this.disposeAutoUpdate();\n }\n }\n\n /** @internal */\n @Method()\n async showTooltip(anchorElement: any) {\n clearTimeout(this.hideTooltipTimeout);\n await this.applyTooltipPosition(anchorElement);\n\n this.showTooltipTimeout = setTimeout(() => {\n tooltipController.present(this);\n // Need to compute and apply tooltip position after initial render,\n // because arrow has no valid bounding rect before that\n this.applyTooltipPosition(anchorElement);\n }, this.showDelay);\n }\n\n /** @internal */\n @Method()\n async hideTooltip() {\n clearTimeout(this.showTooltipTimeout);\n let hideDelay = 50;\n\n if (this.interactive && this.hideDelay === hideDelay) {\n hideDelay = 150;\n }\n\n this.hideTooltipTimeout = setTimeout(() => {\n tooltipController.dismiss(this);\n }, hideDelay);\n this.destroyAutoUpdate();\n }\n\n private computeArrowPosition({\n placement,\n middlewareData,\n }: ComputePositionReturn): ArrowPosition {\n let { x, y } = middlewareData.arrow;\n\n if (placement.startsWith('top')) {\n return {\n left: numberToPixel(x),\n top: numberToPixel(y),\n };\n }\n\n if (placement.startsWith('right')) {\n return {\n left: numberToPixel(-6),\n top: numberToPixel(y),\n };\n }\n\n if (placement.startsWith('bottom')) {\n return {\n left: numberToPixel(x),\n top: numberToPixel(-6),\n };\n }\n\n if (placement.startsWith('left')) {\n return {\n right: numberToPixel(-6),\n top: numberToPixel(y),\n };\n }\n }\n\n private async computeTooltipPosition(target: Element) {\n const computeResponse = await computePosition(target, this.hostElement, {\n strategy: 'fixed',\n placement: this.placement,\n middleware: [\n shift(),\n offset(12),\n arrow({\n element: this.arrowElement,\n }),\n flip({\n fallbackStrategy: 'initialPlacement',\n padding: 10,\n }),\n ],\n });\n return computeResponse;\n }\n\n private applyTooltipArrowPosition(computeResponse: ComputePositionReturn) {\n const arrowPosition = this.computeArrowPosition(computeResponse);\n Object.assign(this.arrowElement.style, arrowPosition);\n }\n\n private async applyTooltipPosition(target: Element) {\n if (!target) {\n return;\n }\n\n return new Promise<ComputePositionReturn>((resolve) => {\n this.disposeAutoUpdate = autoUpdate(\n target,\n this.hostElement,\n async () => {\n setTimeout(async () => {\n const computeResponse = await this.computeTooltipPosition(target);\n\n if (computeResponse.middlewareData.arrow) {\n this.applyTooltipArrowPosition(computeResponse);\n }\n\n const { x, y } = computeResponse;\n Object.assign(this.hostElement.style, {\n left: x !== null ? `${x}px` : '',\n top: y !== null ? `${y}px` : '',\n });\n\n resolve(computeResponse);\n });\n },\n {\n ancestorResize: true,\n ancestorScroll: true,\n elementResize: true,\n animationFrame: this.animationFrame,\n }\n );\n });\n }\n\n private clearHideTimeout() {\n if (this.interactive) {\n clearTimeout(this.hideTooltipTimeout);\n }\n }\n\n private async queryAnchorElements(): Promise<Array<HTMLElement> | undefined> {\n if (typeof this.for === 'string') {\n return Promise.resolve(Array.from(document.querySelectorAll(this.for)));\n }\n\n if (this.for instanceof HTMLElement) {\n return Promise.resolve([this.for]);\n }\n\n if (this.for instanceof Promise) {\n const element = await this.for;\n return [element];\n }\n }\n\n private async registerTriggerListener() {\n const triggerElementList = await this.queryAnchorElements();\n\n if (this.disposeListener) {\n this.disposeListener();\n }\n\n if (!triggerElementList) {\n return;\n }\n\n triggerElementList.forEach((element) => {\n const onMouseEnter = () => {\n this.showTooltip(element);\n };\n\n const onMouseLeave = () => {\n this.hideTooltip();\n };\n\n const onFocusIn = () => {\n if (this.showTooltipTimeout !== undefined) {\n clearTimeout(this.showTooltipTimeout);\n }\n\n onMouseEnter();\n };\n\n const onFocusOut = () => {\n this.hideTooltip();\n };\n\n element.addEventListener('mouseenter', onMouseEnter);\n element.addEventListener('mouseleave', onMouseLeave);\n element.addEventListener('focusin', onFocusIn);\n element.addEventListener('focusout', onFocusOut);\n\n this.disposeListener = () => {\n element.removeEventListener('mouseenter', onMouseEnter);\n element.removeEventListener('mouseleave', onMouseLeave);\n element.removeEventListener('focusin', onFocusIn);\n element.removeEventListener('focusout', onFocusOut);\n };\n });\n }\n\n private registerTooltipListener() {\n const { hostElement } = this;\n hostElement.addEventListener('mouseenter', () => this.clearHideTimeout());\n hostElement.addEventListener('focusin', () => this.clearHideTimeout());\n\n hostElement.addEventListener('mouseleave', () => this.hideTooltip());\n hostElement.addEventListener('focusout', () => this.hideTooltip());\n }\n\n @OnListener<Tooltip>('keydown', (self) => self.visible)\n async onKeydown(event: KeyboardEvent) {\n if (event.code === 'Escape') {\n this.hideTooltip();\n }\n }\n\n componentWillLoad() {\n this.registerTriggerListener();\n }\n\n componentDidLoad() {\n this.observer = new MutationObserver(() => {\n this.registerTriggerListener();\n });\n\n this.observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['data-ix-tooltip'],\n childList: true,\n subtree: true,\n });\n\n this.registerTooltipListener();\n }\n\n connectedCallback() {\n tooltipController.connected(this);\n }\n\n disconnectedCallback() {\n this.observer?.disconnect();\n this.destroyAutoUpdate();\n tooltipController.disconnected(this);\n }\n\n isPresent(): boolean {\n return this.visible;\n }\n\n present(): void {\n this.visible = true;\n }\n\n dismiss(): void {\n this.visible = false;\n }\n\n render() {\n return (\n <Host\n class={{\n visible: this.visible,\n }}\n role=\"tooltip\"\n >\n <div class={'tooltip-title'}>\n <slot name=\"title-icon\"></slot>\n <ix-typography variant=\"default-title\">\n {this.titleContent}\n <slot name=\"title-content\"></slot>\n </ix-typography>\n </div>\n <div class={'tooltip-content'}>\n <slot></slot>\n </div>\n <div class=\"arrow\"></div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../../../src/components/tooltip/tooltip.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 */\nimport {\n arrow,\n autoUpdate,\n computePosition,\n ComputePositionReturn,\n flip,\n hide,\n offset,\n shift,\n} from '@floating-ui/dom';\nimport {\n Component,\n Element,\n h,\n Host,\n Method,\n Prop,\n State,\n} from '@stencil/core';\nimport { OnListener } from '../utils/listener';\nimport { tooltipController } from './tooltip-controller';\nimport { IxOverlayComponent } from '../utils/overlay';\nimport { ElementReference } from '../utils/element-reference';\n\ntype ArrowPosition = {\n top?: string;\n left?: string;\n right?: string;\n};\n\nconst numberToPixel = (value?: number | null) =>\n value != null ? `${value}px` : '';\n\n/**\n * @slot title-icon - Icon of tooltip title\n * @slot title-content - Content of tooltip title\n *\n * @since 1.4.0\n */\n@Component({\n tag: 'ix-tooltip',\n styleUrl: 'tooltip.scss',\n shadow: true,\n})\nexport class Tooltip implements IxOverlayComponent {\n /**\n * CSS selector for hover trigger element e.g. `for=\"[data-my-custom-select]\"`\n */\n @Prop() for?: ElementReference;\n\n /**\n * Title of the tooltip\n */\n @Prop() titleContent?: string;\n\n /**\n * Define if the user can access the tooltip via mouse.\n */\n @Prop() interactive = false;\n\n /**\n * Initial placement of the tooltip.\n * If the selected placement doesn't have enough space, the tooltip will be repositioned to another location.\n * @since 1.5.0\n */\n @Prop() placement: 'top' | 'right' | 'bottom' | 'left' = 'top';\n\n /** @internal */\n @Prop() showDelay = 0;\n\n /** @internal */\n @Prop() hideDelay = 50;\n\n /** @internal */\n @Prop() animationFrame = false;\n\n @State() visible = false;\n\n @Element() hostElement!: HTMLIxTooltipElement;\n\n private observer?: MutationObserver;\n private hideTooltipTimeout?: NodeJS.Timeout;\n private showTooltipTimeout?: NodeJS.Timeout;\n private disposeAutoUpdate?: () => void;\n private disposeListener?: () => void;\n\n private get arrowElement(): HTMLElement {\n return this.hostElement.shadowRoot!.querySelector('.arrow')!;\n }\n\n private destroyAutoUpdate() {\n if (this.disposeAutoUpdate !== undefined) {\n this.disposeAutoUpdate();\n }\n }\n\n /** @internal */\n @Method()\n async showTooltip(anchorElement: Element) {\n clearTimeout(this.hideTooltipTimeout);\n await this.applyTooltipPosition(anchorElement);\n\n this.showTooltipTimeout = setTimeout(() => {\n tooltipController.present(this);\n // Need to compute and apply tooltip position after initial render,\n // because arrow has no valid bounding rect before that\n this.applyTooltipPosition(anchorElement);\n }, this.showDelay);\n }\n\n /** @internal */\n @Method()\n async hideTooltip() {\n clearTimeout(this.showTooltipTimeout);\n let hideDelay = 50;\n\n if (this.interactive && this.hideDelay === hideDelay) {\n hideDelay = 150;\n }\n\n this.hideTooltipTimeout = setTimeout(() => {\n tooltipController.dismiss(this);\n }, hideDelay);\n this.destroyAutoUpdate();\n }\n\n private computeArrowPosition({\n placement,\n middlewareData,\n }: ComputePositionReturn): ArrowPosition | undefined {\n let { x, y } = middlewareData.arrow!;\n const resetPosition = {\n top: 'unset',\n right: 'unset',\n bottom: 'unset',\n left: 'unset',\n };\n\n if (placement.startsWith('top')) {\n return {\n ...resetPosition,\n left: numberToPixel(x),\n top: numberToPixel(y),\n };\n }\n\n if (placement.startsWith('right')) {\n return {\n ...resetPosition,\n left: numberToPixel(-6),\n top: numberToPixel(y),\n };\n }\n\n if (placement.startsWith('bottom')) {\n return {\n ...resetPosition,\n left: numberToPixel(x),\n top: numberToPixel(-6),\n };\n }\n\n if (placement.startsWith('left')) {\n return {\n ...resetPosition,\n right: numberToPixel(-6),\n top: numberToPixel(y),\n };\n }\n }\n\n private async computeTooltipPosition(target: Element) {\n return computePosition(target, this.hostElement, {\n strategy: 'fixed',\n placement: this.placement,\n middleware: [\n shift(),\n offset(12),\n arrow({\n element: this.arrowElement,\n }),\n flip({\n fallbackStrategy: 'initialPlacement',\n fallbackAxisSideDirection: 'end',\n padding: 10,\n }),\n hide(),\n ],\n });\n }\n\n private applyTooltipArrowPosition(computeResponse: ComputePositionReturn) {\n const arrowPosition = this.computeArrowPosition(computeResponse);\n Object.assign(this.arrowElement.style, arrowPosition);\n }\n\n private async applyTooltipPosition(target: Element) {\n if (!target) {\n return;\n }\n\n return new Promise<ComputePositionReturn>((resolve) => {\n this.destroyAutoUpdate();\n this.disposeAutoUpdate = autoUpdate(\n target,\n this.hostElement,\n async () => {\n setTimeout(async () => {\n const computeResponse = await this.computeTooltipPosition(target);\n\n const isHidden =\n computeResponse.middlewareData.hide?.referenceHidden;\n\n if (isHidden) {\n setTimeout(() => this.hideTooltip());\n resolve(computeResponse);\n }\n\n if (computeResponse.middlewareData.arrow) {\n this.applyTooltipArrowPosition(computeResponse);\n }\n\n const { x, y } = computeResponse;\n Object.assign(this.hostElement.style, {\n left: x !== null ? `${x}px` : '',\n top: y !== null ? `${y}px` : '',\n });\n\n resolve(computeResponse);\n });\n },\n {\n ancestorResize: true,\n ancestorScroll: true,\n elementResize: true,\n animationFrame: this.animationFrame,\n }\n );\n });\n }\n\n private clearHideTimeout() {\n if (this.interactive) {\n clearTimeout(this.hideTooltipTimeout);\n }\n }\n\n private async queryAnchorElements(): Promise<Array<HTMLElement> | undefined> {\n if (typeof this.for === 'string') {\n return Promise.resolve(Array.from(document.querySelectorAll(this.for)));\n }\n\n if (this.for instanceof HTMLElement) {\n return Promise.resolve([this.for]);\n }\n\n if (this.for instanceof Promise) {\n const element = await this.for;\n return [element];\n }\n }\n\n private async registerTriggerListener() {\n const triggerElementList = await this.queryAnchorElements();\n\n if (this.disposeListener) {\n this.disposeListener();\n }\n\n if (!triggerElementList) {\n return;\n }\n\n triggerElementList.forEach((element) => {\n const onMouseEnter = () => {\n this.showTooltip(element);\n };\n\n const onMouseLeave = () => {\n this.hideTooltip();\n };\n\n const onFocusIn = () => {\n if (this.showTooltipTimeout !== undefined) {\n clearTimeout(this.showTooltipTimeout);\n }\n\n onMouseEnter();\n };\n\n const onFocusOut = () => {\n this.hideTooltip();\n };\n\n element.addEventListener('mouseenter', onMouseEnter);\n element.addEventListener('mouseleave', onMouseLeave);\n element.addEventListener('focusin', onFocusIn);\n element.addEventListener('focusout', onFocusOut);\n\n this.disposeListener = () => {\n element.removeEventListener('mouseenter', onMouseEnter);\n element.removeEventListener('mouseleave', onMouseLeave);\n element.removeEventListener('focusin', onFocusIn);\n element.removeEventListener('focusout', onFocusOut);\n };\n });\n }\n\n private registerTooltipListener() {\n const { hostElement } = this;\n hostElement.addEventListener('mouseenter', () => this.clearHideTimeout());\n hostElement.addEventListener('focusin', () => this.clearHideTimeout());\n\n hostElement.addEventListener('mouseleave', () => this.hideTooltip());\n hostElement.addEventListener('focusout', () => this.hideTooltip());\n }\n\n @OnListener<Tooltip>('keydown', (self) => self.visible)\n async onKeydown(event: KeyboardEvent) {\n if (event.code === 'Escape') {\n this.hideTooltip();\n }\n }\n\n componentWillLoad() {\n this.registerTriggerListener();\n }\n\n componentDidLoad() {\n this.observer = new MutationObserver(() => {\n this.registerTriggerListener();\n });\n\n this.observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['data-ix-tooltip'],\n childList: true,\n subtree: true,\n });\n\n this.registerTooltipListener();\n }\n\n connectedCallback() {\n tooltipController.connected(this);\n }\n\n disconnectedCallback() {\n this.observer?.disconnect();\n this.destroyAutoUpdate();\n tooltipController.disconnected(this);\n }\n\n isPresent(): boolean {\n return this.visible;\n }\n\n present(): void {\n this.visible = true;\n }\n\n dismiss(): void {\n this.visible = false;\n }\n\n render() {\n return (\n <Host\n class={{\n visible: this.visible,\n }}\n role=\"tooltip\"\n >\n <div class=\"tooltip-container\">\n <div class={'tooltip-title'}>\n <slot name=\"title-icon\"></slot>\n <ix-typography format=\"h5\">\n {this.titleContent}\n <slot name=\"title-content\"></slot>\n </ix-typography>\n </div>\n <div class={'tooltip-content'}>\n <slot></slot>\n </div>\n <div class=\"arrow\"></div>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -151,4 +151,40 @@ test('update tree', async ({ mount, page }) => {
151
151
  await expect(newChildItem).toBeVisible();
152
152
  await expect(newChildItem).toHaveCSS('padding-left', '32px');
153
153
  });
154
+ test('dropdown trigger', async ({ mount, page }) => {
155
+ const tree = await initializeTree(mount, page);
156
+ await tree.evaluate((t) => (t.renderItem = (_index, item, _dataList, context, update) => {
157
+ const el = document.createElement('ix-tree-item');
158
+ const treeItem = item;
159
+ el.hasChildren = treeItem.hasChildren;
160
+ el.context = context[treeItem.id];
161
+ el.id = `trigger-${treeItem.id}`;
162
+ const div = document.createElement('div');
163
+ div.style.display = 'flex';
164
+ const name = document.createElement('span');
165
+ const dd = document.createElement('ix-dropdown');
166
+ const ddItem = document.createElement('ix-dropdown-item');
167
+ ddItem.innerHTML = 'Action 1';
168
+ dd.trigger = `trigger-${treeItem.id}`;
169
+ div.appendChild(name);
170
+ div.appendChild(dd);
171
+ dd.appendChild(ddItem);
172
+ name.innerText = treeItem.id;
173
+ el.appendChild(div);
174
+ update((updateTreeItem) => {
175
+ name.innerText = updateTreeItem.data.name;
176
+ });
177
+ return el;
178
+ }));
179
+ const root = tree.locator('ix-tree-item').first();
180
+ await root.locator('.icon-toggle-container').click();
181
+ const item1 = tree.locator('ix-tree-item').nth(1);
182
+ const dropdown1 = item1.locator('ix-dropdown');
183
+ await item1.click();
184
+ await expect(dropdown1).toBeVisible();
185
+ const item2 = tree.locator('ix-tree-item').nth(2);
186
+ const dropdown2 = item2.locator('ix-dropdown');
187
+ await item2.click();
188
+ await expect(dropdown2).toBeVisible();
189
+ });
154
190
  //# sourceMappingURL=tree.ct.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tree.ct.js","sourceRoot":"","sources":["../../../../src/components/tree/test/tree.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect, Locator, Page } from '@playwright/test';\nimport { test } from '@utils/test';\n\nconst defaultModel = {\n root: {\n id: 'root',\n data: {\n name: '',\n },\n hasChildren: true,\n children: ['sample'],\n },\n sample: {\n id: 'sample',\n data: {\n name: 'Sample',\n },\n hasChildren: true,\n children: ['sample-child-1', 'sample-child-2', 'sample-child-3'],\n },\n 'sample-child-1': {\n id: 'sample-child-1',\n data: {\n name: 'Sample Child 1',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-2': {\n id: 'sample-child-2',\n data: {\n name: 'Sample Child 2',\n },\n hasChildren: true,\n children: ['sample-child-4'],\n },\n 'sample-child-3': {\n id: 'sample-child-3',\n data: {\n name: 'Sample Child 3',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-4': {\n id: 'sample-child-4',\n data: {\n name: 'Sample Child 4',\n },\n hasChildren: false,\n children: [],\n },\n};\n\nconst initializeTree = async (mount, page: Page) => {\n await mount(`\n <div style=\" height: 20rem; width: 100%;\">\n <ix-tree root=\"root\"></ix-tree>\n </div>\n `);\n const tree = page.locator('ix-tree');\n\n await tree.evaluate(\n (element: HTMLIxTreeElement, [model]) => {\n element.model = model;\n },\n [defaultModel]\n );\n\n const item = tree.locator('ix-tree-item').nth(0);\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n\n return tree;\n};\n\nconst updateModel = async (tree: Locator, updatedModel: any) => {\n await tree.evaluate(\n (element: HTMLIxTreeElement, [model]) => {\n element.model = model;\n },\n [updatedModel]\n );\n};\n\ntest('renders', async ({ mount, page }) => {\n const tree = await initializeTree(mount, page);\n const item = tree.locator('ix-tree-item').nth(0);\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n});\n\ntest('update tree', async ({ mount, page }) => {\n const tree = await initializeTree(mount, page);\n\n const item = tree.locator('ix-tree-item').nth(0);\n await item.locator('.icon-toggle-container').click();\n\n const item2 = tree.locator('ix-tree-item').nth(2);\n await item2.locator('.icon-toggle-container').click();\n\n const item3 = tree.locator('ix-tree-item').nth(4);\n await expect(item3).toBeVisible();\n await expect(item3).toHaveText('Sample Child 3');\n await expect(item3).toHaveCSS('padding-left', '16px');\n\n await updateModel(tree, {\n root: {\n id: 'root',\n data: {\n name: '',\n },\n hasChildren: true,\n children: ['sample'],\n },\n sample: {\n id: 'sample',\n data: {\n name: 'Sample',\n },\n hasChildren: true,\n children: ['sample-child-1', 'sample-child-2'],\n },\n 'sample-child-1': {\n id: 'sample-child-1',\n data: {\n name: 'Sample Child 1',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-2': {\n id: 'sample-child-2',\n data: {\n name: 'Sample Child 2',\n },\n hasChildren: true,\n children: ['sample-child-3', 'sample-child-4'],\n },\n 'sample-child-3': {\n id: 'sample-child-3',\n data: {\n name: 'Sample Child 3',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-4': {\n id: 'sample-child-4',\n data: {\n name: 'Sample Child 4',\n },\n hasChildren: false,\n children: [],\n },\n });\n\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n await expect(item2).toBeVisible();\n\n const newChildItem = tree.locator('ix-tree-item').nth(3);\n await expect(newChildItem).toBeVisible();\n await expect(newChildItem).toHaveCSS('padding-left', '32px');\n});\n"]}
1
+ {"version":3,"file":"tree.ct.js","sourceRoot":"","sources":["../../../../src/components/tree/test/tree.ct.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { expect, Locator, Page } from '@playwright/test';\nimport { test } from '@utils/test';\nimport { TreeItem } from '../tree-model';\n\nconst defaultModel = {\n root: {\n id: 'root',\n data: {\n name: '',\n },\n hasChildren: true,\n children: ['sample'],\n },\n sample: {\n id: 'sample',\n data: {\n name: 'Sample',\n },\n hasChildren: true,\n children: ['sample-child-1', 'sample-child-2', 'sample-child-3'],\n },\n 'sample-child-1': {\n id: 'sample-child-1',\n data: {\n name: 'Sample Child 1',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-2': {\n id: 'sample-child-2',\n data: {\n name: 'Sample Child 2',\n },\n hasChildren: true,\n children: ['sample-child-4'],\n },\n 'sample-child-3': {\n id: 'sample-child-3',\n data: {\n name: 'Sample Child 3',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-4': {\n id: 'sample-child-4',\n data: {\n name: 'Sample Child 4',\n },\n hasChildren: false,\n children: [],\n },\n};\n\nconst initializeTree = async (mount, page: Page) => {\n await mount(`\n <div style=\" height: 20rem; width: 100%;\">\n <ix-tree root=\"root\"></ix-tree>\n </div>\n `);\n const tree = page.locator('ix-tree');\n\n await tree.evaluate(\n (element: HTMLIxTreeElement, [model]) => {\n element.model = model;\n },\n [defaultModel]\n );\n\n const item = tree.locator('ix-tree-item').nth(0);\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n\n return tree;\n};\n\nconst updateModel = async (tree: Locator, updatedModel: any) => {\n await tree.evaluate(\n (element: HTMLIxTreeElement, [model]) => {\n element.model = model;\n },\n [updatedModel]\n );\n};\n\ntest('renders', async ({ mount, page }) => {\n const tree = await initializeTree(mount, page);\n const item = tree.locator('ix-tree-item').nth(0);\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n});\n\ntest('update tree', async ({ mount, page }) => {\n const tree = await initializeTree(mount, page);\n\n const item = tree.locator('ix-tree-item').nth(0);\n await item.locator('.icon-toggle-container').click();\n\n const item2 = tree.locator('ix-tree-item').nth(2);\n await item2.locator('.icon-toggle-container').click();\n\n const item3 = tree.locator('ix-tree-item').nth(4);\n await expect(item3).toBeVisible();\n await expect(item3).toHaveText('Sample Child 3');\n await expect(item3).toHaveCSS('padding-left', '16px');\n\n await updateModel(tree, {\n root: {\n id: 'root',\n data: {\n name: '',\n },\n hasChildren: true,\n children: ['sample'],\n },\n sample: {\n id: 'sample',\n data: {\n name: 'Sample',\n },\n hasChildren: true,\n children: ['sample-child-1', 'sample-child-2'],\n },\n 'sample-child-1': {\n id: 'sample-child-1',\n data: {\n name: 'Sample Child 1',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-2': {\n id: 'sample-child-2',\n data: {\n name: 'Sample Child 2',\n },\n hasChildren: true,\n children: ['sample-child-3', 'sample-child-4'],\n },\n 'sample-child-3': {\n id: 'sample-child-3',\n data: {\n name: 'Sample Child 3',\n },\n hasChildren: false,\n children: [],\n },\n 'sample-child-4': {\n id: 'sample-child-4',\n data: {\n name: 'Sample Child 4',\n },\n hasChildren: false,\n children: [],\n },\n });\n\n await expect(tree).toHaveClass(/hydrated/);\n await expect(item).toBeVisible();\n await expect(item2).toBeVisible();\n\n const newChildItem = tree.locator('ix-tree-item').nth(3);\n await expect(newChildItem).toBeVisible();\n await expect(newChildItem).toHaveCSS('padding-left', '32px');\n});\n\ntest('dropdown trigger', async ({ mount, page }) => {\n const tree = await initializeTree(mount, page);\n\n await tree.evaluate(\n (t) =>\n ((t as HTMLIxTreeElement).renderItem = (\n _index,\n item,\n _dataList,\n context,\n update\n ) => {\n const el = document.createElement('ix-tree-item');\n const treeItem = item as TreeItem<unknown>;\n el.hasChildren = treeItem.hasChildren;\n el.context = context[treeItem.id];\n el.id = `trigger-${treeItem.id}`;\n\n const div = document.createElement('div');\n div.style.display = 'flex';\n\n const name = document.createElement('span');\n const dd = document.createElement('ix-dropdown');\n const ddItem = document.createElement('ix-dropdown-item');\n ddItem.innerHTML = 'Action 1';\n dd.trigger = `trigger-${treeItem.id}`;\n\n div.appendChild(name);\n div.appendChild(dd);\n dd.appendChild(ddItem);\n\n name.innerText = treeItem.id;\n\n el.appendChild(div);\n\n update((updateTreeItem) => {\n name.innerText = updateTreeItem.data.name;\n });\n\n return el;\n })\n );\n\n const root = tree.locator('ix-tree-item').first();\n await root.locator('.icon-toggle-container').click();\n\n const item1 = tree.locator('ix-tree-item').nth(1);\n const dropdown1 = item1.locator('ix-dropdown');\n await item1.click();\n await expect(dropdown1).toBeVisible();\n\n const item2 = tree.locator('ix-tree-item').nth(2);\n const dropdown2 = item2.locator('ix-dropdown');\n await item2.click();\n await expect(dropdown2).toBeVisible();\n});\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"tree-model.js","sourceRoot":"","sources":["../../../src/components/tree/tree-model.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG","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\nexport type TreeItemId = string;\nexport type TreeContext = Record<string, TreeItemContext>;\nexport type TreeModel<T> = Record<TreeItemId, TreeItem<T>>;\n\nexport type UpdateCallback = (\n treeItem: TreeItem<any>,\n context: TreeContext\n) => void;\n\nexport interface TreeItem<T> {\n id: TreeItemId;\n data: T;\n hasChildren: boolean;\n children: TreeItemId[];\n}\n\nexport interface TreeItemVisual<T> extends TreeItem<T> {\n level: number;\n}\n\nexport interface TreeItemContext {\n isExpanded: boolean;\n isSelected: boolean;\n}\n"]}
1
+ {"version":3,"file":"tree-model.js","sourceRoot":"","sources":["../../../src/components/tree/tree-model.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nexport type TreeItemId = string;\nexport type TreeContext = Record<string, TreeItemContext>;\nexport type TreeModel<T> = Record<TreeItemId, TreeItem<T>>;\n\nexport type UpdateCallback = (\n treeItem: TreeItem<any>,\n context: TreeContext\n) => void;\n\nexport interface TreeItem<T> {\n id: TreeItemId;\n data: T;\n hasChildren: boolean;\n children: TreeItemId[];\n}\n\nexport interface TreeItemVisual<T> extends TreeItem<T> {\n level: number;\n}\n\nexport interface TreeItemContext {\n isExpanded: boolean;\n isSelected: boolean;\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -9,6 +9,7 @@
9
9
  import { h, Host, } from "@stencil/core";
10
10
  import Hyperlist from "hyperlist";
11
11
  import { renderDefaultItem } from "../tree-item/default-tree-item";
12
+ import { dropdownController } from "../dropdown/dropdown-controller";
12
13
  export class Tree {
13
14
  constructor() {
14
15
  this.toggleListener = new Map();
@@ -16,7 +17,7 @@ export class Tree {
16
17
  this.updates = new Map();
17
18
  this.hasFirstRender = false;
18
19
  this.root = undefined;
19
- this.model = undefined;
20
+ this.model = {};
20
21
  this.renderItem = undefined;
21
22
  this.context = {};
22
23
  }
@@ -52,7 +53,9 @@ export class Tree {
52
53
  setToggleListener(item, renderedTreeItem, index);
53
54
  if (this.updates.has(item.id)) {
54
55
  const doUpdate = this.updates.get(item.id);
55
- doUpdate(item, Object.assign({}, this.context));
56
+ if (doUpdate) {
57
+ doUpdate(item, Object.assign({}, this.context));
58
+ }
56
59
  }
57
60
  this.updatePadding(renderedTreeItem, item);
58
61
  return renderedTreeItem;
@@ -72,16 +75,27 @@ export class Tree {
72
75
  el.style.paddingRight = '1rem';
73
76
  this.updatePadding(el, item);
74
77
  if (!this.itemClickListener.has(el)) {
75
- const itemClickCallback = (e) => {
76
- e.preventDefault();
77
- e.stopPropagation();
78
+ const itemClickCallback = (event) => {
79
+ const path = event.composedPath();
80
+ const treeIndex = path.indexOf(this.hostElement);
81
+ const treePath = path.slice(0, treeIndex);
82
+ const hasTrigger = dropdownController.pathIncludesTrigger(treePath);
83
+ if (event.defaultPrevented) {
84
+ return;
85
+ }
86
+ if (hasTrigger) {
87
+ return;
88
+ }
78
89
  Object.values(this.context).forEach((c) => (c.isSelected = false));
79
90
  const context = this.getContext(item.id);
80
91
  context.isSelected = true;
81
92
  this.setContext(item.id, context);
82
93
  this.nodeClicked.emit(item.id);
83
94
  };
84
- el.addEventListener('itemClick', itemClickCallback);
95
+ el.addEventListener('toggle', (event) => {
96
+ event.preventDefault();
97
+ });
98
+ el.addEventListener('click', itemClickCallback);
85
99
  this.itemClickListener.set(el, itemClickCallback);
86
100
  }
87
101
  setToggleListener(item, el, index);
@@ -183,7 +197,7 @@ export class Tree {
183
197
  this.hyperlist = new Hyperlist(this.hostElement, config);
184
198
  }
185
199
  render() {
186
- return (h(Host, { key: 'a64e17e0c6466065fe8de80715cbac794a6e7a95' }, h("slot", { key: 'a348c8357097c31e323d95033546d841f1986680' })));
200
+ return (h(Host, { key: 'd58c48d0890011d947993a87ec727e606adc0125' }, h("slot", { key: '3d284f5146f832a6a151148d9bb37be803acd048' })));
187
201
  }
188
202
  static get is() { return "ix-tree"; }
189
203
  static get encapsulation() { return "shadow"; }
@@ -207,7 +221,7 @@ export class Tree {
207
221
  "resolved": "string",
208
222
  "references": {}
209
223
  },
210
- "required": false,
224
+ "required": true,
211
225
  "optional": false,
212
226
  "docs": {
213
227
  "tags": [],
@@ -235,7 +249,8 @@ export class Tree {
235
249
  "docs": {
236
250
  "tags": [],
237
251
  "text": "Tree model"
238
- }
252
+ },
253
+ "defaultValue": "{}"
239
254
  },
240
255
  "renderItem": {
241
256
  "type": "unknown",
@@ -269,7 +284,7 @@ export class Tree {
269
284
  }
270
285
  },
271
286
  "required": false,
272
- "optional": false,
287
+ "optional": true,
273
288
  "docs": {
274
289
  "tags": [],
275
290
  "text": "Render function of tree items"
@@ -1 +1 @@
1
- {"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/components/tree/tree.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n Watch,\n} from '@stencil/core';\nimport Hyperlist from 'hyperlist';\nimport { renderDefaultItem } from '../tree-item/default-tree-item';\nimport {\n TreeContext,\n TreeItem,\n TreeItemContext,\n TreeItemVisual,\n TreeModel,\n UpdateCallback,\n} from './tree-model';\n\n@Component({\n tag: 'ix-tree',\n styleUrl: 'tree.css',\n shadow: true,\n})\nexport class Tree {\n @Element() hostElement!: HTMLIxTreeElement;\n\n /**\n * Initial root element will not be rendered\n */\n @Prop() root: string;\n\n /**\n * Tree model\n */\n @Prop() model: TreeModel<any>;\n\n /**\n * Render function of tree items\n */\n @Prop() renderItem: <T = any>(\n index: number,\n data: T,\n dataList: Array<T>,\n context: TreeContext,\n update: (callback: UpdateCallback) => void\n ) => HTMLElement;\n\n /**\n * Selection and collapsed state management\n */\n @Prop({ mutable: true }) context: TreeContext = {};\n\n /**\n * Context changed\n */\n @Event() contextChange: EventEmitter<TreeContext>;\n\n /**\n * Node toggled event\n * @since 1.5.0\n */\n @Event() nodeToggled: EventEmitter<{ id: string; isExpaned: boolean }>;\n\n /**\n * Node clicked event\n * @since 1.5.0\n */\n @Event() nodeClicked: EventEmitter<string>;\n\n /**\n * Emits removed nodes\n */\n @Event() nodeRemoved: EventEmitter<any>;\n\n private hyperlist: Hyperlist;\n\n private toggleListener = new Map<HTMLElement, Function>();\n private itemClickListener = new Map<HTMLElement, Function>();\n private updates = new Map<string, UpdateCallback>();\n private observer: MutationObserver;\n private hasFirstRender = false;\n\n private updatePadding(element: HTMLElement, item: TreeItemVisual<unknown>) {\n element.style.paddingLeft = item.level + 'rem';\n }\n\n private getVirtualizerOptions() {\n const list = this.buildTreeList(this.model[this.root]);\n\n let setToggleListener = (\n item: TreeItemVisual<any>,\n el: HTMLElement,\n index: number\n ) => {\n if (item.hasChildren && !this.toggleListener.has(el)) {\n const toggleCallback = (e: Event) => {\n e.preventDefault();\n e.stopPropagation();\n const context = this.getContext(list[index].id);\n context.isExpanded = !context.isExpanded;\n this.nodeToggled.emit({ id: item.id, isExpaned: context.isExpanded });\n this.setContext(item.id, context);\n };\n el.addEventListener('toggle', toggleCallback);\n this.toggleListener.set(el, toggleCallback);\n }\n };\n\n return {\n itemHeight: 32,\n total: list.length,\n generate: (index: number) => {\n const item = list[index];\n\n const renderedTreeItem = this.hostElement.querySelector(\n `[data-tree-node-id=\"${item.id}\"]`\n ) as HTMLIxTreeItemElement;\n\n const context = this.getContext(item.id);\n\n if (renderedTreeItem) {\n renderedTreeItem.hasChildren = item.hasChildren;\n renderedTreeItem.context = { ...context };\n\n setToggleListener(item, renderedTreeItem, index);\n\n if (this.updates.has(item.id)) {\n const doUpdate = this.updates.get(item.id);\n doUpdate(item, { ...this.context });\n }\n\n this.updatePadding(renderedTreeItem, item);\n return renderedTreeItem;\n }\n\n const update = (callback: UpdateCallback) => {\n this.updates.set(item.id, callback);\n };\n\n let innerElement: HTMLElement | null = null;\n if (this.renderItem) {\n innerElement = this.renderItem(\n index,\n item,\n list,\n { ...this.context },\n update\n );\n }\n\n if (innerElement === null) {\n innerElement = renderDefaultItem(item, context, update);\n }\n\n const el = innerElement;\n el.setAttribute('data-tree-node-id', item.id);\n el.style.paddingRight = '1rem';\n this.updatePadding(el, item);\n\n if (!this.itemClickListener.has(el)) {\n const itemClickCallback = (e: Event) => {\n e.preventDefault();\n e.stopPropagation();\n Object.values(this.context).forEach((c) => (c.isSelected = false));\n const context = this.getContext(item.id);\n context.isSelected = true;\n this.setContext(item.id, context);\n this.nodeClicked.emit(item.id);\n };\n el.addEventListener('itemClick', itemClickCallback);\n this.itemClickListener.set(el, itemClickCallback);\n }\n\n setToggleListener(item, el, index);\n\n return el;\n },\n };\n }\n\n private setContext(id: string, context: TreeItemContext) {\n this.context = {\n ...this.context,\n [id]: context,\n };\n\n this.contextChange.emit(this.context);\n }\n\n private getContext(id: string): TreeItemContext {\n if (!this.context) {\n return {\n isExpanded: false,\n isSelected: false,\n };\n }\n if (!this.context[id]) {\n this.context[id] = {\n isExpanded: false,\n isSelected: false,\n };\n }\n return this.context[id];\n }\n\n private buildTreeList(\n root: TreeItem<any>,\n level: number = 0\n ): TreeItemVisual<any>[] {\n const itemList: TreeItemVisual<any>[] = [];\n\n if (root?.hasChildren) {\n const newLevel = level + 1;\n root.children.forEach((id: string) => {\n const item = this.model[id];\n const context = this.getContext(id);\n itemList.push({ ...item, level });\n if (item.hasChildren && context.isExpanded) {\n itemList.push(...this.buildTreeList(item, newLevel));\n }\n });\n }\n\n return itemList;\n }\n\n componentDidLoad() {\n this.initList();\n\n this.observer = new MutationObserver((records) => {\n let removed = [];\n\n records.forEach((record) => {\n removed = [...removed, ...Array.from(record.removedNodes)];\n\n record.addedNodes.forEach((an) => {\n const index = removed.indexOf(an);\n if (index >= 0) {\n removed.splice(index, 1);\n }\n });\n });\n\n this.nodeRemoved.emit(removed);\n });\n\n this.observer.observe(this.hostElement, {\n childList: true,\n });\n }\n\n componentWillRender() {\n this.hasFirstRender = true;\n\n if (this.isListInitialized()) {\n this.refreshList();\n } else {\n this.initList();\n }\n }\n\n disconnectedCallback() {\n this.hyperlist?.destroy();\n this.observer?.disconnect();\n }\n\n @Watch('model')\n modelChange() {\n if (this.hasFirstRender && !this.isListInitialized()) {\n this.initList();\n }\n }\n\n private isListInitialized() {\n const itemPositions = this.hyperlist?._itemPositions;\n\n return (\n itemPositions !== undefined &&\n itemPositions.length &&\n !itemPositions?.some(\n (item: number) => item === undefined || Number.isNaN(item)\n )\n );\n }\n\n private refreshList() {\n if (this.hyperlist) {\n this.hyperlist.refresh(this.hostElement, this.getVirtualizerOptions());\n }\n }\n\n private initList() {\n if (!this.model) {\n return;\n }\n\n this.hyperlist?.destroy();\n const config = this.getVirtualizerOptions();\n this.hyperlist = new Hyperlist(this.hostElement, config);\n }\n\n render() {\n return (\n <Host>\n <slot></slot>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tree.js","sourceRoot":"","sources":["../../../src/components/tree/tree.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,SAAS,EACT,OAAO,EACP,KAAK,EAEL,CAAC,EACD,IAAI,EACJ,IAAI,EACJ,KAAK,GACN,MAAM,eAAe,CAAC;AACvB,OAAO,SAAS,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AASnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAOrE,MAAM,OAAO,IAAI;;QAqDP,mBAAc,GAAG,IAAI,GAAG,EAAyB,CAAC;QAClD,sBAAiB,GAAG,IAAI,GAAG,EAAyB,CAAC;QACrD,YAAO,GAAG,IAAI,GAAG,EAA0B,CAAC;QAE5C,mBAAc,GAAG,KAAK,CAAC;;qBA9CC,EAAE;;uBAgBc,EAAE;;IAgC1C,aAAa,CAAC,OAAoB,EAAE,IAA6B;QACvE,OAAO,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACjD,CAAC;IAEO,qBAAqB;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvD,IAAI,iBAAiB,GAAG,CACtB,IAAyB,EACzB,EAAe,EACf,KAAa,EACb,EAAE;YACF,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;gBACrD,MAAM,cAAc,GAAG,CAAC,CAAQ,EAAE,EAAE;oBAClC,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,CAAC,CAAC,eAAe,EAAE,CAAC;oBACpB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;oBAChD,OAAO,CAAC,UAAU,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;oBACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;oBACtE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBACpC,CAAC,CAAC;gBACF,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;gBAC9C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE,cAAc,CAAC,CAAC;YAC9C,CAAC;QACH,CAAC,CAAC;QAEF,OAAO;YACL,UAAU,EAAE,EAAE;YACd,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,QAAQ,EAAE,CAAC,KAAa,EAAE,EAAE;gBAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gBAEzB,MAAM,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CACrD,uBAAuB,IAAI,CAAC,EAAE,IAAI,CACV,CAAC;gBAE3B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEzC,IAAI,gBAAgB,EAAE,CAAC;oBACrB,gBAAgB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;oBAChD,gBAAgB,CAAC,OAAO,qBAAQ,OAAO,CAAE,CAAC;oBAE1C,iBAAiB,CAAC,IAAI,EAAE,gBAAgB,EAAE,KAAK,CAAC,CAAC;oBAEjD,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;wBAC9B,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;wBAE3C,IAAI,QAAQ,EAAE,CAAC;4BACb,QAAQ,CAAC,IAAI,oBAAO,IAAI,CAAC,OAAO,EAAG,CAAC;wBACtC,CAAC;oBACH,CAAC;oBAED,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;oBAC3C,OAAO,gBAAgB,CAAC;gBAC1B,CAAC;gBAED,MAAM,MAAM,GAAG,CAAC,QAAwB,EAAE,EAAE;oBAC1C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;gBACtC,CAAC,CAAC;gBAEF,IAAI,YAAY,GAAuB,IAAI,CAAC;gBAC5C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;oBACpB,YAAY,GAAG,IAAI,CAAC,UAAU,CAC5B,KAAK,EACL,IAAI,EACJ,IAAI,oBACC,IAAI,CAAC,OAAO,GACjB,MAAM,CACP,CAAC;gBACJ,CAAC;gBAED,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;oBAC1B,YAAY,GAAG,iBAAiB,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;gBAC1D,CAAC;gBAED,MAAM,EAAE,GAAG,YAAY,CAAC;gBACxB,EAAE,CAAC,YAAY,CAAC,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC9C,EAAE,CAAC,KAAK,CAAC,YAAY,GAAG,MAAM,CAAC;gBAC/B,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;gBAE7B,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC;oBACpC,MAAM,iBAAiB,GAAG,CAAC,KAAY,EAAE,EAAE;wBACzC,MAAM,IAAI,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;wBAClC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;wBAC1C,MAAM,UAAU,GAAG,kBAAkB,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;wBAEpE,IAAI,KAAK,CAAC,gBAAgB,EAAE,CAAC;4BAC3B,OAAO;wBACT,CAAC;wBAED,IAAI,UAAU,EAAE,CAAC;4BACf,OAAO;wBACT,CAAC;wBAED,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC;wBACnE,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;wBACzC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;wBAC1B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;wBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBACjC,CAAC,CAAC;oBACF,EAAE,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;wBACtC,KAAK,CAAC,cAAc,EAAE,CAAC;oBACzB,CAAC,CAAC,CAAC;oBACH,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;oBAChD,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,EAAE,iBAAiB,CAAC,CAAC;gBACpD,CAAC;gBAED,iBAAiB,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;gBAEnC,OAAO,EAAE,CAAC;YACZ,CAAC;SACF,CAAC;IACJ,CAAC;IAEO,UAAU,CAAC,EAAU,EAAE,OAAwB;QACrD,IAAI,CAAC,OAAO,mCACP,IAAI,CAAC,OAAO,KACf,CAAC,EAAE,CAAC,EAAE,OAAO,GACd,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAEO,UAAU,CAAC,EAAU;QAC3B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO;gBACL,UAAU,EAAE,KAAK;gBACjB,UAAU,EAAE,KAAK;aAClB,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;YACtB,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG;gBACjB,UAAU,EAAE,KAAK;gBACjB,UAAU,EAAE,KAAK;aAClB,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC1B,CAAC;IAEO,aAAa,CACnB,IAAmB,EACnB,QAAgB,CAAC;QAEjB,MAAM,QAAQ,GAA0B,EAAE,CAAC;QAE3C,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,WAAW,EAAE,CAAC;YACtB,MAAM,QAAQ,GAAG,KAAK,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,EAAU,EAAE,EAAE;gBACnC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;gBACpC,QAAQ,CAAC,IAAI,iCAAM,IAAI,KAAE,KAAK,IAAG,CAAC;gBAClC,IAAI,IAAI,CAAC,WAAW,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;oBAC3C,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACvD,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEhB,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAAC,CAAC,OAAO,EAAE,EAAE;YAC/C,IAAI,OAAO,GAAc,EAAE,CAAC;YAE5B,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACzB,OAAO,GAAG,CAAC,GAAG,OAAO,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC;gBAE3D,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;oBAC/B,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;oBAClC,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;wBACf,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;oBAC3B,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE;YACtC,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAE3B,IAAI,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;YAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAED,oBAAoB;;QAClB,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,EAAE,CAAC;QAC1B,MAAA,IAAI,CAAC,QAAQ,0CAAE,UAAU,EAAE,CAAC;IAC9B,CAAC;IAGD,WAAW;QACT,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;YACrD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAEO,iBAAiB;;QACvB,MAAM,aAAa,GAAG,MAAA,IAAI,CAAC,SAAS,0CAAE,cAAc,CAAC;QAErD,OAAO,CACL,aAAa,KAAK,SAAS;YAC3B,aAAa,CAAC,MAAM;YACpB,CAAC,CAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,IAAI,CAClB,CAAC,IAAY,EAAE,EAAE,CAAC,IAAI,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAC3D,CAAA,CACF,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IAEO,QAAQ;;QACd,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;QAED,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,EAAE,CAAC;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;IAC3D,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,8DAAa,CACR,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n Watch,\n} from '@stencil/core';\nimport Hyperlist from 'hyperlist';\nimport { renderDefaultItem } from '../tree-item/default-tree-item';\nimport {\n TreeContext,\n TreeItem,\n TreeItemContext,\n TreeItemVisual,\n TreeModel,\n UpdateCallback,\n} from './tree-model';\nimport { dropdownController } from '../dropdown/dropdown-controller';\n\n@Component({\n tag: 'ix-tree',\n styleUrl: 'tree.css',\n shadow: true,\n})\nexport class Tree {\n @Element() hostElement!: HTMLIxTreeElement;\n\n /**\n * Initial root element will not be rendered\n */\n @Prop() root!: string;\n\n /**\n * Tree model\n */\n @Prop() model: TreeModel<any> = {};\n\n /**\n * Render function of tree items\n */\n @Prop() renderItem?: <T = any>(\n index: number,\n data: T,\n dataList: Array<T>,\n context: TreeContext,\n update: (callback: UpdateCallback) => void\n ) => HTMLElement;\n\n /**\n * Selection and collapsed state management\n */\n @Prop({ mutable: true }) context: TreeContext = {};\n\n /**\n * Context changed\n */\n @Event() contextChange!: EventEmitter<TreeContext>;\n\n /**\n * Node toggled event\n * @since 1.5.0\n */\n @Event() nodeToggled!: EventEmitter<{ id: string; isExpaned: boolean }>;\n\n /**\n * Node clicked event\n * @since 1.5.0\n */\n @Event() nodeClicked!: EventEmitter<string>;\n\n /**\n * Emits removed nodes\n */\n @Event() nodeRemoved!: EventEmitter<any>;\n\n private hyperlist: Hyperlist;\n\n private toggleListener = new Map<HTMLElement, Function>();\n private itemClickListener = new Map<HTMLElement, Function>();\n private updates = new Map<string, UpdateCallback>();\n private observer!: MutationObserver;\n private hasFirstRender = false;\n\n private updatePadding(element: HTMLElement, item: TreeItemVisual<unknown>) {\n element.style.paddingLeft = item.level + 'rem';\n }\n\n private getVirtualizerOptions() {\n const list = this.buildTreeList(this.model[this.root]);\n\n let setToggleListener = (\n item: TreeItemVisual<any>,\n el: HTMLElement,\n index: number\n ) => {\n if (item.hasChildren && !this.toggleListener.has(el)) {\n const toggleCallback = (e: Event) => {\n e.preventDefault();\n e.stopPropagation();\n const context = this.getContext(list[index].id);\n context.isExpanded = !context.isExpanded;\n this.nodeToggled.emit({ id: item.id, isExpaned: context.isExpanded });\n this.setContext(item.id, context);\n };\n el.addEventListener('toggle', toggleCallback);\n this.toggleListener.set(el, toggleCallback);\n }\n };\n\n return {\n itemHeight: 32,\n total: list.length,\n generate: (index: number) => {\n const item = list[index];\n\n const renderedTreeItem = this.hostElement.querySelector(\n `[data-tree-node-id=\"${item.id}\"]`\n ) as HTMLIxTreeItemElement;\n\n const context = this.getContext(item.id);\n\n if (renderedTreeItem) {\n renderedTreeItem.hasChildren = item.hasChildren;\n renderedTreeItem.context = { ...context };\n\n setToggleListener(item, renderedTreeItem, index);\n\n if (this.updates.has(item.id)) {\n const doUpdate = this.updates.get(item.id);\n\n if (doUpdate) {\n doUpdate(item, { ...this.context });\n }\n }\n\n this.updatePadding(renderedTreeItem, item);\n return renderedTreeItem;\n }\n\n const update = (callback: UpdateCallback) => {\n this.updates.set(item.id, callback);\n };\n\n let innerElement: HTMLElement | null = null;\n if (this.renderItem) {\n innerElement = this.renderItem(\n index,\n item,\n list,\n { ...this.context },\n update\n );\n }\n\n if (innerElement === null) {\n innerElement = renderDefaultItem(item, context, update);\n }\n\n const el = innerElement;\n el.setAttribute('data-tree-node-id', item.id);\n el.style.paddingRight = '1rem';\n this.updatePadding(el, item);\n\n if (!this.itemClickListener.has(el)) {\n const itemClickCallback = (event: Event) => {\n const path = event.composedPath();\n const treeIndex = path.indexOf(this.hostElement);\n const treePath = path.slice(0, treeIndex);\n const hasTrigger = dropdownController.pathIncludesTrigger(treePath);\n\n if (event.defaultPrevented) {\n return;\n }\n\n if (hasTrigger) {\n return;\n }\n\n Object.values(this.context).forEach((c) => (c.isSelected = false));\n const context = this.getContext(item.id);\n context.isSelected = true;\n this.setContext(item.id, context);\n this.nodeClicked.emit(item.id);\n };\n el.addEventListener('toggle', (event) => {\n event.preventDefault();\n });\n el.addEventListener('click', itemClickCallback);\n this.itemClickListener.set(el, itemClickCallback);\n }\n\n setToggleListener(item, el, index);\n\n return el;\n },\n };\n }\n\n private setContext(id: string, context: TreeItemContext) {\n this.context = {\n ...this.context,\n [id]: context,\n };\n\n this.contextChange.emit(this.context);\n }\n\n private getContext(id: string): TreeItemContext {\n if (!this.context) {\n return {\n isExpanded: false,\n isSelected: false,\n };\n }\n if (!this.context[id]) {\n this.context[id] = {\n isExpanded: false,\n isSelected: false,\n };\n }\n return this.context[id];\n }\n\n private buildTreeList(\n root: TreeItem<any>,\n level: number = 0\n ): TreeItemVisual<any>[] {\n const itemList: TreeItemVisual<any>[] = [];\n\n if (root?.hasChildren) {\n const newLevel = level + 1;\n root.children.forEach((id: string) => {\n const item = this.model[id];\n const context = this.getContext(id);\n itemList.push({ ...item, level });\n if (item.hasChildren && context.isExpanded) {\n itemList.push(...this.buildTreeList(item, newLevel));\n }\n });\n }\n\n return itemList;\n }\n\n componentDidLoad() {\n this.initList();\n\n this.observer = new MutationObserver((records) => {\n let removed: unknown[] = [];\n\n records.forEach((record) => {\n removed = [...removed, ...Array.from(record.removedNodes)];\n\n record.addedNodes.forEach((an) => {\n const index = removed.indexOf(an);\n if (index >= 0) {\n removed.splice(index, 1);\n }\n });\n });\n\n this.nodeRemoved.emit(removed);\n });\n\n this.observer.observe(this.hostElement, {\n childList: true,\n });\n }\n\n componentWillRender() {\n this.hasFirstRender = true;\n\n if (this.isListInitialized()) {\n this.refreshList();\n } else {\n this.initList();\n }\n }\n\n disconnectedCallback() {\n this.hyperlist?.destroy();\n this.observer?.disconnect();\n }\n\n @Watch('model')\n modelChange() {\n if (this.hasFirstRender && !this.isListInitialized()) {\n this.initList();\n }\n }\n\n private isListInitialized() {\n const itemPositions = this.hyperlist?._itemPositions;\n\n return (\n itemPositions !== undefined &&\n itemPositions.length &&\n !itemPositions?.some(\n (item: number) => item === undefined || Number.isNaN(item)\n )\n );\n }\n\n private refreshList() {\n if (this.hyperlist) {\n this.hyperlist.refresh(this.hostElement, this.getVirtualizerOptions());\n }\n }\n\n private initList() {\n if (!this.model) {\n return;\n }\n\n this.hyperlist?.destroy();\n const config = this.getVirtualizerOptions();\n this.hyperlist = new Hyperlist(this.hostElement, config);\n }\n\n render() {\n return (\n <Host>\n <slot></slot>\n </Host>\n );\n }\n}\n"]}
@@ -89,18 +89,27 @@
89
89
  display: none;
90
90
  }
91
91
  :host .tree-node-container {
92
+ overflow: hidden;
93
+ text-overflow: ellipsis;
94
+ white-space: nowrap;
92
95
  display: flex;
93
96
  align-items: center;
94
97
  height: 2rem;
95
98
  flex-grow: 1;
96
99
  align-items: center;
97
100
  }
101
+ :host .tree-node-container .tree-node-text {
102
+ overflow: hidden;
103
+ text-overflow: ellipsis;
104
+ white-space: nowrap;
105
+ }
98
106
  :host .icon-toggle-container {
99
107
  display: flex;
100
108
  align-items: center;
101
109
  justify-content: center;
102
110
  width: 2rem;
103
111
  height: 2rem;
112
+ min-width: 2rem;
104
113
  }
105
114
  :host .icon-toggle-container ix-icon {
106
115
  transition: transform var(--theme-default-time) ease-in-out;
@@ -1,5 +1,5 @@
1
1
  /*
2
- * SPDX-FileCopyrightText: 2023 Siemens AG
2
+ * SPDX-FileCopyrightText: 2024 Siemens AG
3
3
  *
4
4
  * SPDX-License-Identifier: MIT
5
5
  *
@@ -10,21 +10,21 @@ import { h, Host } from "@stencil/core";
10
10
  export class TreeItem {
11
11
  constructor() {
12
12
  this.text = undefined;
13
- this.hasChildren = undefined;
13
+ this.hasChildren = false;
14
14
  this.context = undefined;
15
15
  }
16
16
  render() {
17
17
  var _a, _b, _c;
18
- return (h(Host, { key: '4facce4de72cf050f1ca5160c23d513a51619182', class: {
19
- selected: (_a = this.context) === null || _a === void 0 ? void 0 : _a.isSelected,
20
- } }, h("div", { key: '6a5a090480876f134e2900b9ee04d529029b623b', class: "icon-toggle-container", onClick: (e) => {
18
+ return (h(Host, { key: 'af04e0621f45ae100e93ed008f9584fd1bfd8f1c', class: {
19
+ selected: !!((_a = this.context) === null || _a === void 0 ? void 0 : _a.isSelected),
20
+ } }, h("div", { key: 'd2322ceb29667302aa35d60ca231939130981713', class: "icon-toggle-container", onClick: (e) => {
21
21
  e.preventDefault();
22
22
  this.toggle.emit();
23
23
  } }, this.hasChildren ? (h("ix-icon", { name: 'chevron-right', size: "16", class: {
24
- ['icon-toggle-down']: (_b = this.context) === null || _b === void 0 ? void 0 : _b.isExpanded,
25
- }, color: `color-${((_c = this.context) === null || _c === void 0 ? void 0 : _c.isExpanded) ? 'primary' : 'std-text'}` })) : null), h("div", { key: 'b46d172c5cb6685270e9259b7a5d9d27a4fab5aa', class: "tree-node-container", onClick: () => {
24
+ ['icon-toggle-down']: !!((_b = this.context) === null || _b === void 0 ? void 0 : _b.isExpanded),
25
+ }, color: `color-${((_c = this.context) === null || _c === void 0 ? void 0 : _c.isExpanded) ? 'primary' : 'std-text'}` })) : null), h("div", { key: '3a601aacb532bc20d24a405ed7c898834eb170a1', class: "tree-node-container", onClick: () => {
26
26
  this.itemClick.emit();
27
- } }, this.text, h("slot", { key: 'a766a38ebb4913509fe9dceb9e2079653eca9423' }))));
27
+ } }, h("div", { key: 'f4d83073948516d65a284ec165506e692e2eccfe', class: "tree-node-text" }, this.text), h("slot", { key: 'fd4daf32a17bf1b84170049aae1cacf93b0fd586' }))));
28
28
  }
29
29
  static get is() { return "ix-tree-item"; }
30
30
  static get encapsulation() { return "shadow"; }
@@ -49,7 +49,7 @@ export class TreeItem {
49
49
  "references": {}
50
50
  },
51
51
  "required": false,
52
- "optional": false,
52
+ "optional": true,
53
53
  "docs": {
54
54
  "tags": [],
55
55
  "text": "Text"
@@ -72,7 +72,8 @@ export class TreeItem {
72
72
  "text": "Has tree item children"
73
73
  },
74
74
  "attribute": "has-children",
75
- "reflect": false
75
+ "reflect": false,
76
+ "defaultValue": "false"
76
77
  },
77
78
  "context": {
78
79
  "type": "unknown",
@@ -89,7 +90,7 @@ export class TreeItem {
89
90
  }
90
91
  },
91
92
  "required": false,
92
- "optional": false,
93
+ "optional": true,
93
94
  "docs": {
94
95
  "tags": [],
95
96
  "text": "Context"
@@ -121,7 +122,7 @@ export class TreeItem {
121
122
  "composed": true,
122
123
  "docs": {
123
124
  "tags": [],
124
- "text": "Clicked"
125
+ "text": "Click on item not on the expand/collapse icon"
125
126
  },
126
127
  "complexType": {
127
128
  "original": "void",
@@ -1 +1 @@
1
- {"version":3,"file":"tree-item.js","sourceRoot":"","sources":["../../../src/components/tree-item/tree-item.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAQ9E,MAAM,OAAO,QAAQ;;;;;;IA0BnB,MAAM;;QACJ,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE;gBACL,QAAQ,EAAE,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU;aACnC;YAED,4DACE,KAAK,EAAC,uBAAuB,EAC7B,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;oBACb,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;gBACrB,CAAC,IAEA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAClB,eACE,IAAI,EAAE,eAAe,EACrB,IAAI,EAAC,IAAI,EACT,KAAK,EAAE;oBACL,CAAC,kBAAkB,CAAC,EAAE,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU;iBAC/C,EACD,KAAK,EAAE,SACL,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU,EAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UACzC,EAAE,GACF,CACH,CAAC,CAAC,CAAC,IAAI,CACJ;YACN,4DACE,KAAK,EAAC,qBAAqB,EAC3B,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;gBACxB,CAAC;gBAEA,IAAI,CAAC,IAAI;gBACV,8DAAa,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport { TreeItemContext } from '../tree/tree-model';\n\n@Component({\n tag: 'ix-tree-item',\n styleUrl: 'tree-item.scss',\n shadow: true,\n})\nexport class TreeItem {\n /**\n * Text\n */\n @Prop() text: string;\n\n /**\n * Has tree item children\n */\n @Prop() hasChildren: boolean;\n\n /**\n * Context\n */\n @Prop() context: TreeItemContext;\n\n /**\n * Expand/Collapsed toggled\n */\n @Event() toggle: EventEmitter<void>;\n\n /**\n * Clicked\n */\n @Event() itemClick: EventEmitter<void>;\n\n render() {\n return (\n <Host\n class={{\n selected: this.context?.isSelected,\n }}\n >\n <div\n class=\"icon-toggle-container\"\n onClick={(e) => {\n e.preventDefault();\n this.toggle.emit();\n }}\n >\n {this.hasChildren ? (\n <ix-icon\n name={'chevron-right'}\n size=\"16\"\n class={{\n ['icon-toggle-down']: this.context?.isExpanded,\n }}\n color={`color-${\n this.context?.isExpanded ? 'primary' : 'std-text'\n }`}\n />\n ) : null}\n </div>\n <div\n class=\"tree-node-container\"\n onClick={() => {\n this.itemClick.emit();\n }}\n >\n {this.text}\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tree-item.js","sourceRoot":"","sources":["../../../src/components/tree-item/tree-item.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAgB,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAQ9E,MAAM,OAAO,QAAQ;;;2BASG,KAAK;;;IAiB3B,MAAM;;QACJ,OAAO,CACL,EAAC,IAAI,qDACH,KAAK,EAAE;gBACL,QAAQ,EAAE,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU,CAAA;aACrC;YAED,4DACE,KAAK,EAAC,uBAAuB,EAC7B,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;oBACb,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;gBACrB,CAAC,IAEA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAClB,eACE,IAAI,EAAE,eAAe,EACrB,IAAI,EAAC,IAAI,EACT,KAAK,EAAE;oBACL,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU,CAAA;iBACjD,EACD,KAAK,EAAE,SACL,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,UAAU,EAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UACzC,EAAE,GACF,CACH,CAAC,CAAC,CAAC,IAAI,CACJ;YACN,4DACE,KAAK,EAAC,qBAAqB,EAC3B,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;gBACxB,CAAC;gBAED,4DAAK,KAAK,EAAC,gBAAgB,IAAE,IAAI,CAAC,IAAI,CAAO;gBAC7C,8DAAa,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport { TreeItemContext } from '../tree/tree-model';\n\n@Component({\n tag: 'ix-tree-item',\n styleUrl: 'tree-item.scss',\n shadow: true,\n})\nexport class TreeItem {\n /**\n * Text\n */\n @Prop() text?: string;\n\n /**\n * Has tree item children\n */\n @Prop() hasChildren = false;\n\n /**\n * Context\n */\n @Prop() context?: TreeItemContext;\n\n /**\n * Expand/Collapsed toggled\n */\n @Event() toggle!: EventEmitter<void>;\n\n /**\n * Click on item not on the expand/collapse icon\n */\n @Event() itemClick!: EventEmitter<void>;\n\n render() {\n return (\n <Host\n class={{\n selected: !!this.context?.isSelected,\n }}\n >\n <div\n class=\"icon-toggle-container\"\n onClick={(e) => {\n e.preventDefault();\n this.toggle.emit();\n }}\n >\n {this.hasChildren ? (\n <ix-icon\n name={'chevron-right'}\n size=\"16\"\n class={{\n ['icon-toggle-down']: !!this.context?.isExpanded,\n }}\n color={`color-${\n this.context?.isExpanded ? 'primary' : 'std-text'\n }`}\n />\n ) : null}\n </div>\n <div\n class=\"tree-node-container\"\n onClick={() => {\n this.itemClick.emit();\n }}\n >\n <div class=\"tree-node-text\">{this.text}</div>\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -57,19 +57,5 @@ describe('ix-typography', () => {
57
57
  </ix-typography>
58
58
  `);
59
59
  });
60
- it('should provide fallback', async () => {
61
- const page = await newSpecPage({
62
- components: [IxTypography],
63
- html: `<ix-typography variant="h2">Example content</ix-typography>`,
64
- });
65
- expect(page.root).toEqualHtml(`
66
- <ix-typography variant="h2" class="text-h2">
67
- <mock:shadow-root>
68
- <slot></slot>
69
- </mock:shadow-root>
70
- Example content
71
- </ix-typography>
72
- `);
73
- });
74
60
  });
75
61
  //# sourceMappingURL=ix-typography.spec.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ix-typography.spec.js","sourceRoot":"","sources":["../../../../src/components/typography/test/ix-typography.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,gDAAgD;SACvD,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACnC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,6DAA6D;SACpE,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QAClC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,oEAAoE;SAC3E,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;QAC3C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,4EAA4E;SACnF,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACvC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,6DAA6D;SACpE,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { IxTypography } from '../typography';\n\ndescribe('ix-typography', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography>Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-body\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should render color', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography color=\"soft\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography color=\"soft\" class=\"typography-body\" style=\"color: var(--theme-color-soft-text);\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should show format', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography format=\"display-xl\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-display-xl\" format=\"display-xl\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should show text decoration', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography text-decoration=\"underline\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-body typography-decoration-underline\" text-decoration=\"underline\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should provide fallback', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography variant=\"h2\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography variant=\"h2\" class=\"text-h2\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n});\n"]}
1
+ {"version":3,"file":"ix-typography.spec.js","sourceRoot":"","sources":["../../../../src/components/typography/test/ix-typography.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,EAAE,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,gDAAgD;SACvD,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE,KAAK,IAAI,EAAE;QACnC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,6DAA6D;SACpE,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QAClC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,oEAAoE;SAC3E,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;QAC3C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;YAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,IAAI,EAAE,4EAA4E;SACnF,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;KAO7B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { IxTypography } from '../typography';\n\ndescribe('ix-typography', () => {\n it('renders', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography>Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-body\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should render color', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography color=\"soft\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography color=\"soft\" class=\"typography-body\" style=\"color: var(--theme-color-soft-text);\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should show format', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography format=\"display-xl\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-display-xl\" format=\"display-xl\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n\n it('should show text decoration', async () => {\n const page = await newSpecPage({\n components: [IxTypography],\n html: `<ix-typography text-decoration=\"underline\">Example content</ix-typography>`,\n });\n expect(page.root).toEqualHtml(`\n <ix-typography class=\"typography-body typography-decoration-underline\" text-decoration=\"underline\">\n <mock:shadow-root>\n <slot></slot>\n </mock:shadow-root>\n Example content\n </ix-typography>\n `);\n });\n});\n"]}
@@ -1,3 +1,6 @@
1
+ /**
2
+ * @deprecated Will be removed with 3.0.0
3
+ */
1
4
  export const VariantsMapping = {
2
5
  'x-small': 'text-xs',
3
6
  small: 'text-s',
@@ -1 +1 @@
1
- {"version":3,"file":"type-mapping.js","sourceRoot":"","sources":["../../../src/components/typography/type-mapping.ts"],"names":[],"mappings":"AAsBA,MAAM,CAAC,MAAM,eAAe,GAAuC;IACjE,SAAS,EAAE,SAAS;IACpB,KAAK,EAAE,QAAQ;IACf,OAAO,EAAE,cAAc;IACvB,gBAAgB,EAAE,qBAAqB;IACvC,OAAO,EAAE,cAAc;IACvB,gBAAgB,EAAE,qBAAqB;IACvC,KAAK,EAAE,QAAQ;IACf,cAAc,EAAE,eAAe;IAC/B,EAAE,EAAE,SAAS;IACb,eAAe,EAAE,SAAS;IAC1B,eAAe,EAAE,oBAAoB;IACrC,sBAAsB,EAAE,2BAA2B;CACpD,CAAC","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 type TypographyVariants =\n | 'x-small'\n | 'small'\n | 'caption'\n | 'caption-single'\n | 'default'\n | 'default-single'\n | 'default-title'\n | 'default-title-single'\n | 'large'\n | 'large-single'\n | 'h2'\n | 'display-large';\n\nexport const VariantsMapping: Record<TypographyVariants, string> = {\n 'x-small': 'text-xs',\n small: 'text-s',\n caption: 'text-caption',\n 'caption-single': 'text-caption-single',\n default: 'text-default',\n 'default-single': 'text-default-single',\n large: 'text-l',\n 'large-single': 'text-l-single',\n h2: 'text-h2',\n 'display-large': 'text-xl',\n 'default-title': 'text-default-title',\n 'default-title-single': 'text-default-title-single',\n};\n"]}
1
+ {"version":3,"file":"type-mapping.js","sourceRoot":"","sources":["../../../src/components/typography/type-mapping.ts"],"names":[],"mappings":"AAsBA;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAuC;IACjE,SAAS,EAAE,SAAS;IACpB,KAAK,EAAE,QAAQ;IACf,OAAO,EAAE,cAAc;IACvB,gBAAgB,EAAE,qBAAqB;IACvC,OAAO,EAAE,cAAc;IACvB,gBAAgB,EAAE,qBAAqB;IACvC,KAAK,EAAE,QAAQ;IACf,cAAc,EAAE,eAAe;IAC/B,EAAE,EAAE,SAAS;IACb,eAAe,EAAE,SAAS;IAC1B,eAAe,EAAE,oBAAoB;IACrC,sBAAsB,EAAE,2BAA2B;CACpD,CAAC","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 type TypographyVariants =\n | 'x-small'\n | 'small'\n | 'caption'\n | 'caption-single'\n | 'default'\n | 'default-single'\n | 'default-title'\n | 'default-title-single'\n | 'large'\n | 'large-single'\n | 'h2'\n | 'display-large';\n\n/**\n * @deprecated Will be removed with 3.0.0\n */\nexport const VariantsMapping: Record<TypographyVariants, string> = {\n 'x-small': 'text-xs',\n small: 'text-s',\n caption: 'text-caption',\n 'caption-single': 'text-caption-single',\n default: 'text-default',\n 'default-single': 'text-default-single',\n large: 'text-l',\n 'large-single': 'text-l-single',\n h2: 'text-h2',\n 'display-large': 'text-xl',\n 'default-title': 'text-default-title',\n 'default-title-single': 'text-default-title-single',\n};\n"]}