@siemens/ix 4.2.0 → 4.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (928) hide show
  1. package/READMEOSS.html +1 -1
  2. package/components/index.js +26 -2
  3. package/components/index.js.map +1 -1
  4. package/components/ix-action-card.js +9 -4
  5. package/components/ix-action-card.js.map +1 -1
  6. package/components/ix-application-header.js +24 -16
  7. package/components/ix-application-header.js.map +1 -1
  8. package/components/ix-application-switch-modal.js +6 -6
  9. package/components/ix-avatar.js +1 -1
  10. package/components/ix-blind.js +1 -1
  11. package/components/ix-breadcrumb-item.js +1 -1
  12. package/components/ix-breadcrumb.js +16 -8
  13. package/components/ix-breadcrumb.js.map +1 -1
  14. package/components/ix-button.js +1 -1
  15. package/components/ix-card-list.js +5 -5
  16. package/components/ix-card.js +1 -1
  17. package/components/ix-category-filter.js +20 -12
  18. package/components/ix-category-filter.js.map +1 -1
  19. package/components/ix-checkbox-group.js +4 -4
  20. package/components/ix-checkbox.js +1 -1
  21. package/components/ix-chip.js +4 -4
  22. package/components/ix-content-header.js +3 -3
  23. package/components/ix-custom-field.js +4 -4
  24. package/components/ix-date-dropdown.js +21 -13
  25. package/components/ix-date-dropdown.js.map +1 -1
  26. package/components/ix-date-input.js +21 -13
  27. package/components/ix-date-input.js.map +1 -1
  28. package/components/ix-date-picker.js +1 -1
  29. package/components/ix-datetime-picker.js +9 -9
  30. package/components/ix-drawer.js +8 -8
  31. package/components/ix-drawer.js.map +1 -1
  32. package/components/ix-dropdown-button.js +20 -8
  33. package/components/ix-dropdown-button.js.map +1 -1
  34. package/components/ix-dropdown-header.js +2 -2
  35. package/components/ix-dropdown-item.js +1 -1
  36. package/components/ix-dropdown-quick-actions.js +1 -1
  37. package/components/ix-dropdown.js +1 -1
  38. package/components/ix-empty-state.js +4 -4
  39. package/components/ix-event-list-item.js +4 -4
  40. package/components/ix-event-list.js +2 -2
  41. package/components/ix-expanding-search.js +6 -6
  42. package/components/ix-field-label.js +1 -1
  43. package/components/ix-field-wrapper.js +1 -1
  44. package/components/ix-filter-chip.js +1 -1
  45. package/components/ix-flip-tile-content.js +1 -1
  46. package/components/ix-flip-tile.js +5 -5
  47. package/components/ix-group-context-menu.js +1 -1
  48. package/components/ix-group.js +11 -11
  49. package/components/ix-helper-text.js +2 -2
  50. package/components/ix-icon-button.js +1 -1
  51. package/components/ix-icon-toggle-button.js +3 -3
  52. package/components/ix-input-group.js +1 -1
  53. package/components/ix-input.js +10 -10
  54. package/components/ix-key-value-list.js +1 -1
  55. package/components/ix-key-value.js +1 -1
  56. package/components/ix-kpi.js +3 -3
  57. package/components/ix-layout-auto.js +1 -1
  58. package/components/ix-layout-grid.js +1 -1
  59. package/components/ix-link-button.js +3 -3
  60. package/components/ix-menu-about-item.js +1 -1
  61. package/components/ix-menu-about-news.js +8 -8
  62. package/components/ix-menu-about.js +11 -6
  63. package/components/ix-menu-about.js.map +1 -1
  64. package/components/ix-menu-avatar-item.js +1 -1
  65. package/components/ix-menu-avatar.js +30 -10
  66. package/components/ix-menu-avatar.js.map +1 -1
  67. package/components/ix-menu-category.js +11 -11
  68. package/components/ix-menu-category.js.map +1 -1
  69. package/components/ix-menu-expand-icon.js +1 -1
  70. package/components/ix-menu-item.js +1 -1
  71. package/components/ix-menu-settings-item.js +1 -1
  72. package/components/ix-menu-settings.js +1 -1
  73. package/components/ix-menu.js +51 -21
  74. package/components/ix-menu.js.map +1 -1
  75. package/components/ix-message-bar.js +4 -4
  76. package/components/ix-message-bar.js.map +1 -1
  77. package/components/ix-modal-content.js +1 -1
  78. package/components/ix-modal-footer.js +1 -1
  79. package/components/ix-modal-header.js +1 -1
  80. package/components/ix-modal-loading.js +2 -2
  81. package/components/ix-modal.js +5 -7
  82. package/components/ix-modal.js.map +1 -1
  83. package/components/ix-number-input.js +11 -11
  84. package/components/ix-pagination.js +15 -15
  85. package/components/ix-pane-layout.js +2 -1
  86. package/components/ix-pane-layout.js.map +1 -1
  87. package/components/ix-pane.js +9 -9
  88. package/components/ix-pill.js +6 -6
  89. package/components/ix-progress-indicator.js +5 -5
  90. package/components/ix-push-card.js +9 -4
  91. package/components/ix-push-card.js.map +1 -1
  92. package/components/ix-radio-group.js +6 -6
  93. package/components/ix-radio.js +4 -4
  94. package/components/ix-row.js +1 -1
  95. package/components/ix-select-item.js +1 -1
  96. package/components/ix-select.js +1 -1
  97. package/components/ix-slider.js +111 -30
  98. package/components/ix-slider.js.map +1 -1
  99. package/components/ix-spinner.js +1 -1
  100. package/components/ix-split-button.js +13 -5
  101. package/components/ix-split-button.js.map +1 -1
  102. package/components/ix-tab-item.js +1 -1
  103. package/components/ix-tabs.js +1 -1
  104. package/components/ix-textarea.js +6 -6
  105. package/components/ix-tile.js +4 -4
  106. package/components/ix-time-input.js +21 -13
  107. package/components/ix-time-input.js.map +1 -1
  108. package/components/ix-time-picker.js +1 -1
  109. package/components/ix-toast-container.js +8 -7
  110. package/components/ix-toast-container.js.map +1 -1
  111. package/components/ix-toast.js +1 -1
  112. package/components/ix-toggle-button.js +4 -4
  113. package/components/ix-toggle-button.js.map +1 -1
  114. package/components/ix-toggle.js +4 -4
  115. package/components/ix-tooltip.js +1 -1
  116. package/components/ix-tree-item.js +1 -1
  117. package/components/ix-tree.js +34 -5
  118. package/components/ix-tree.js.map +1 -1
  119. package/components/ix-typography.js +1 -1
  120. package/components/ix-upload.js +5 -5
  121. package/components/ix-validation-tooltip.js +2 -2
  122. package/components/ix-workflow-step.js +3 -3
  123. package/components/ix-workflow-steps.js +1 -1
  124. package/components/{p-BLeWaHpy.js → p-0gGE-dfR.js} +12 -6
  125. package/components/p-0gGE-dfR.js.map +1 -0
  126. package/components/{p-Dy6xvLn4.js → p-B-O8iFhq.js} +4 -4
  127. package/components/{p-Dy6xvLn4.js.map → p-B-O8iFhq.js.map} +1 -1
  128. package/components/{p-10zMtvCF.js → p-B09CzVld.js} +133 -52
  129. package/components/p-B09CzVld.js.map +1 -0
  130. package/components/{p-DSTHZygb.js → p-BB98pUYU.js} +14 -16
  131. package/components/p-BB98pUYU.js.map +1 -0
  132. package/components/{p-BOQ00Fbs.js → p-BElY9X3b.js} +35 -25
  133. package/components/p-BElY9X3b.js.map +1 -0
  134. package/components/p-BEuV0Xpe.js +28 -0
  135. package/components/p-BEuV0Xpe.js.map +1 -0
  136. package/components/{p-B1p0kpQJ.js → p-BHD2m8UF.js} +16 -8
  137. package/components/p-BHD2m8UF.js.map +1 -0
  138. package/components/{p-ColBHyXN.js → p-BJ5sreCN.js} +5 -5
  139. package/components/{p-ColBHyXN.js.map → p-BJ5sreCN.js.map} +1 -1
  140. package/components/{p-Bk0vKwmt.js → p-BRg281yQ.js} +4 -4
  141. package/components/{p-Bk0vKwmt.js.map → p-BRg281yQ.js.map} +1 -1
  142. package/components/{p-DlVaL0Yi.js → p-BUS4kPN3.js} +13 -8
  143. package/components/p-BUS4kPN3.js.map +1 -0
  144. package/components/{p-C4KxNeD2.js → p-Bq5oov4A.js} +3 -3
  145. package/components/{p-C4KxNeD2.js.map → p-Bq5oov4A.js.map} +1 -1
  146. package/components/{p-C6_1qmP4.js → p-C5dktNss.js} +4 -4
  147. package/components/{p-C6_1qmP4.js.map → p-C5dktNss.js.map} +1 -1
  148. package/components/{p-DC9anobw.js → p-CGqmQsSj.js} +6 -6
  149. package/components/{p-DC9anobw.js.map → p-CGqmQsSj.js.map} +1 -1
  150. package/components/{p-7E7AMiQV.js → p-CPnxCsJH.js} +5 -5
  151. package/components/{p-7E7AMiQV.js.map → p-CPnxCsJH.js.map} +1 -1
  152. package/components/{p-PpLLlogo.js → p-CUdJN6-t.js} +16 -14
  153. package/components/p-CUdJN6-t.js.map +1 -0
  154. package/components/{p-CjDPpSJX.js → p-CtnJ26Ng.js} +19 -11
  155. package/components/p-CtnJ26Ng.js.map +1 -0
  156. package/components/{p-B006bhbX.js → p-CwfaZReW.js} +3 -3
  157. package/components/{p-B006bhbX.js.map → p-CwfaZReW.js.map} +1 -1
  158. package/components/{p-BIg1TSrD.js → p-D-nChuuk.js} +7 -7
  159. package/components/{p-BIg1TSrD.js.map → p-D-nChuuk.js.map} +1 -1
  160. package/components/{p-MuPiaYr1.js → p-D0T_1WDk.js} +32 -2
  161. package/components/p-D0T_1WDk.js.map +1 -0
  162. package/components/{p-Bye33cYU.js → p-D2BfqYng.js} +7 -7
  163. package/components/{p-Bye33cYU.js.map → p-D2BfqYng.js.map} +1 -1
  164. package/components/{p-DXFN8JXp.js → p-D8qc3Tjo.js} +4 -4
  165. package/components/{p-DXFN8JXp.js.map → p-D8qc3Tjo.js.map} +1 -1
  166. package/components/{p-BBwXlKhE.js → p-DBeR3Qpr.js} +3 -3
  167. package/components/{p-BBwXlKhE.js.map → p-DBeR3Qpr.js.map} +1 -1
  168. package/components/{p-CvD2yWeJ.js → p-DFkWFa-O.js} +4 -4
  169. package/components/{p-CvD2yWeJ.js.map → p-DFkWFa-O.js.map} +1 -1
  170. package/components/{p-BGdI6-nv.js → p-DTobrL4g.js} +3 -3
  171. package/components/{p-BGdI6-nv.js.map → p-DTobrL4g.js.map} +1 -1
  172. package/components/{p-BmMUyJRQ.js → p-DV7UGci6.js} +10 -10
  173. package/components/{p-BmMUyJRQ.js.map → p-DV7UGci6.js.map} +1 -1
  174. package/components/{p-CV_EVAOW.js → p-DZkGd7CV.js} +10 -4
  175. package/components/p-DZkGd7CV.js.map +1 -0
  176. package/components/{p-BI7B-PUA.js → p-Djmkeupf.js} +105 -38
  177. package/components/p-Djmkeupf.js.map +1 -0
  178. package/components/{p-1pd_0dhF.js → p-Ds0M0G_e.js} +3 -3
  179. package/components/{p-1pd_0dhF.js.map → p-Ds0M0G_e.js.map} +1 -1
  180. package/components/{p-BR5ayBuu.js → p-DtGtkvRX.js} +4 -4
  181. package/components/{p-BR5ayBuu.js.map → p-DtGtkvRX.js.map} +1 -1
  182. package/components/{p-Dp03DeD0.js → p-Dwnv8fgy.js} +5 -5
  183. package/components/{p-Dp03DeD0.js.map → p-Dwnv8fgy.js.map} +1 -1
  184. package/components/{p-BQk7HpA-.js → p-U0nRzcrj.js} +3 -3
  185. package/components/{p-BQk7HpA-.js.map → p-U0nRzcrj.js.map} +1 -1
  186. package/components/{p-BiqdnsgA.js → p-jwHZJhcU.js} +63 -58
  187. package/components/p-jwHZJhcU.js.map +1 -0
  188. package/components/{p-hwPzPVf8.js → p-rFxiFp44.js} +12 -6
  189. package/components/p-rFxiFp44.js.map +1 -0
  190. package/components/{p-ClQxnZ3d.js → p-u9QR9x88.js} +6 -6
  191. package/components/{p-ClQxnZ3d.js.map → p-u9QR9x88.js.map} +1 -1
  192. package/components/{p-BEDohapR.js → p-uIFuspHx.js} +8 -5
  193. package/components/p-uIFuspHx.js.map +1 -0
  194. package/dist/cjs/{base-button-CjsUotrL.js → base-button-DVckB2S-.js} +10 -4
  195. package/dist/cjs/base-button-DVckB2S-.js.map +1 -0
  196. package/dist/cjs/{base-icon-button-D3kZg-im.js → base-icon-button-BMxa9fiN.js} +3 -3
  197. package/dist/cjs/{base-icon-button-D3kZg-im.js.map → base-icon-button-BMxa9fiN.js.map} +1 -1
  198. package/dist/cjs/index-C8Xo8L1k.js +4 -4
  199. package/dist/cjs/{index-B7AMgiIZ.js → index-CgfiBgkm.js} +3 -3
  200. package/dist/cjs/{index-B7AMgiIZ.js.map → index-CgfiBgkm.js.map} +1 -1
  201. package/dist/cjs/index.cjs.js +25 -1
  202. package/dist/cjs/index.cjs.js.map +1 -1
  203. package/dist/cjs/ix-action-card.cjs.entry.js +5 -1
  204. package/dist/cjs/ix-action-card.entry.cjs.js.map +1 -1
  205. package/dist/cjs/ix-application-header.cjs.entry.js +19 -12
  206. package/dist/cjs/ix-application-header.entry.cjs.js.map +1 -1
  207. package/dist/cjs/ix-application-switch-modal.cjs.entry.js +1 -1
  208. package/dist/cjs/ix-avatar_2.cjs.entry.js +2 -2
  209. package/dist/cjs/ix-breadcrumb-item.cjs.entry.js +1 -1
  210. package/dist/cjs/ix-breadcrumb.cjs.entry.js +11 -4
  211. package/dist/cjs/ix-breadcrumb.entry.cjs.js.map +1 -1
  212. package/dist/cjs/ix-button.cjs.entry.js +1 -1
  213. package/dist/cjs/ix-card.ix-card-content.entry.cjs.js.map +1 -1
  214. package/dist/cjs/ix-card_2.cjs.entry.js +8 -3
  215. package/dist/cjs/ix-category-filter.cjs.entry.js +15 -8
  216. package/dist/cjs/ix-category-filter.entry.cjs.js.map +1 -1
  217. package/dist/cjs/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.cjs.js.map +1 -1
  218. package/dist/cjs/ix-col_4.cjs.entry.js +15 -8
  219. package/dist/cjs/ix-date-dropdown.cjs.entry.js +12 -5
  220. package/dist/cjs/ix-date-dropdown.entry.cjs.js.map +1 -1
  221. package/dist/cjs/ix-date-input.cjs.entry.js +11 -4
  222. package/dist/cjs/ix-date-input.entry.cjs.js.map +1 -1
  223. package/dist/cjs/ix-drawer.cjs.entry.js +6 -6
  224. package/dist/cjs/ix-drawer.entry.cjs.js.map +1 -1
  225. package/dist/cjs/ix-dropdown-button.cjs.entry.js +14 -3
  226. package/dist/cjs/ix-dropdown-button.entry.cjs.js.map +1 -1
  227. package/dist/cjs/ix-dropdown-header.cjs.entry.js +1 -1
  228. package/dist/cjs/ix-dropdown-item.cjs.entry.js +9 -3
  229. package/dist/cjs/ix-dropdown-item.entry.cjs.js.map +1 -1
  230. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +1 -1
  231. package/dist/cjs/ix-dropdown.cjs.entry.js +103 -37
  232. package/dist/cjs/ix-dropdown.entry.cjs.js.map +1 -1
  233. package/dist/cjs/ix-empty-state.cjs.entry.js +1 -1
  234. package/dist/cjs/ix-event-list-item.cjs.entry.js +4 -4
  235. package/dist/cjs/ix-event-list.cjs.entry.js +2 -2
  236. package/dist/cjs/ix-expanding-search.cjs.entry.js +4 -4
  237. package/dist/cjs/ix-field-label.ix-field-wrapper.entry.cjs.js.map +1 -1
  238. package/dist/cjs/ix-field-label_2.cjs.entry.js +14 -7
  239. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +2 -2
  240. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +1 -1
  241. package/dist/cjs/ix-flip-tile.cjs.entry.js +3 -3
  242. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +1 -1
  243. package/dist/cjs/ix-group.cjs.entry.js +8 -8
  244. package/dist/cjs/ix-helper-text.cjs.entry.js +1 -1
  245. package/dist/cjs/ix-icon-button.ix-spinner.entry.cjs.js.map +1 -1
  246. package/dist/cjs/ix-icon-button_2.cjs.entry.js +7 -4
  247. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +3 -3
  248. package/dist/cjs/ix-input-group.cjs.entry.js +1 -1
  249. package/dist/cjs/ix-input.cjs.entry.js +4 -4
  250. package/dist/cjs/ix-key-value-list.cjs.entry.js +1 -1
  251. package/dist/cjs/ix-key-value.cjs.entry.js +1 -1
  252. package/dist/cjs/ix-kpi.cjs.entry.js +3 -3
  253. package/dist/cjs/ix-layout-auto.cjs.entry.js +1 -1
  254. package/dist/cjs/ix-link-button.cjs.entry.js +3 -3
  255. package/dist/cjs/ix-menu-about-item.cjs.entry.js +1 -1
  256. package/dist/cjs/ix-menu-about-news.cjs.entry.js +4 -4
  257. package/dist/cjs/ix-menu-about.cjs.entry.js +6 -2
  258. package/dist/cjs/ix-menu-about.entry.cjs.js.map +1 -1
  259. package/dist/cjs/ix-menu-avatar.cjs.entry.js +20 -3
  260. package/dist/cjs/ix-menu-avatar.entry.cjs.js.map +1 -1
  261. package/dist/cjs/ix-menu-category.cjs.entry.js +6 -6
  262. package/dist/cjs/ix-menu-category.entry.cjs.js.map +1 -1
  263. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +10 -8
  264. package/dist/cjs/ix-menu-expand-icon.entry.cjs.js.map +1 -1
  265. package/dist/cjs/ix-menu-item.cjs.entry.js +10 -12
  266. package/dist/cjs/ix-menu-item.entry.cjs.js.map +1 -1
  267. package/dist/cjs/{ix-menu-settings-CtWl0bME.js → ix-menu-settings-BYr52N4C.js} +42 -38
  268. package/dist/cjs/ix-menu-settings-BYr52N4C.js.map +1 -0
  269. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +1 -1
  270. package/dist/cjs/ix-menu-settings.cjs.entry.js +1 -1
  271. package/dist/cjs/ix-menu.cjs.entry.js +44 -16
  272. package/dist/cjs/ix-menu.entry.cjs.js.map +1 -1
  273. package/dist/cjs/ix-message-bar.cjs.entry.js +2 -2
  274. package/dist/cjs/ix-message-bar.entry.cjs.js.map +1 -1
  275. package/dist/cjs/ix-modal-content_2.cjs.entry.js +2 -2
  276. package/dist/cjs/ix-modal-footer.cjs.entry.js +1 -1
  277. package/dist/cjs/ix-modal-loading.cjs.entry.js +1 -1
  278. package/dist/cjs/ix-modal.cjs.entry.js +5 -7
  279. package/dist/cjs/ix-modal.entry.cjs.js.map +1 -1
  280. package/dist/cjs/ix-number-input.cjs.entry.js +5 -5
  281. package/dist/cjs/ix-pagination.cjs.entry.js +4 -4
  282. package/dist/cjs/ix-pane-layout.cjs.entry.js +2 -1
  283. package/dist/cjs/ix-pane-layout.entry.cjs.js.map +1 -1
  284. package/dist/cjs/ix-pane.cjs.entry.js +6 -6
  285. package/dist/cjs/ix-pill.cjs.entry.js +4 -4
  286. package/dist/cjs/ix-progress-indicator.cjs.entry.js +3 -3
  287. package/dist/cjs/ix-push-card.cjs.entry.js +5 -1
  288. package/dist/cjs/ix-push-card.entry.cjs.js.map +1 -1
  289. package/dist/cjs/ix-radio-group.cjs.entry.js +2 -2
  290. package/dist/cjs/ix-radio.cjs.entry.js +3 -3
  291. package/dist/cjs/ix-select.cjs.entry.js +22 -13
  292. package/dist/cjs/ix-select.entry.cjs.js.map +1 -1
  293. package/dist/cjs/ix-slider.cjs.entry.js +87 -25
  294. package/dist/cjs/ix-slider.entry.cjs.js.map +1 -1
  295. package/dist/cjs/ix-split-button.cjs.entry.js +8 -1
  296. package/dist/cjs/ix-split-button.entry.cjs.js.map +1 -1
  297. package/dist/cjs/ix-tab-item.ix-tabs.entry.cjs.js.map +1 -1
  298. package/dist/cjs/ix-tab-item_2.cjs.entry.js +135 -54
  299. package/dist/cjs/ix-textarea.cjs.entry.js +2 -2
  300. package/dist/cjs/ix-tile.cjs.entry.js +4 -4
  301. package/dist/cjs/ix-time-input.cjs.entry.js +11 -4
  302. package/dist/cjs/ix-time-input.entry.cjs.js.map +1 -1
  303. package/dist/cjs/ix-time-picker.cjs.entry.js +5 -5
  304. package/dist/cjs/ix-toast-container.cjs.entry.js +4 -3
  305. package/dist/cjs/ix-toast-container.entry.cjs.js.map +1 -1
  306. package/dist/cjs/ix-toast.cjs.entry.js +7 -3
  307. package/dist/cjs/ix-toast.entry.cjs.js.map +1 -1
  308. package/dist/cjs/ix-toggle-button.cjs.entry.js +3 -3
  309. package/dist/cjs/ix-toggle-button.entry.cjs.js.map +1 -1
  310. package/dist/cjs/ix-toggle.cjs.entry.js +3 -3
  311. package/dist/cjs/ix-tooltip.cjs.entry.js +1 -1
  312. package/dist/cjs/ix-tree-item.cjs.entry.js +4 -4
  313. package/dist/cjs/ix-tree.cjs.entry.js +33 -4
  314. package/dist/cjs/ix-tree.entry.cjs.js.map +1 -1
  315. package/dist/cjs/ix-typography.cjs.entry.js +1 -1
  316. package/dist/cjs/ix-upload.cjs.entry.js +3 -3
  317. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +2 -2
  318. package/dist/cjs/ix-workflow-step.cjs.entry.js +3 -3
  319. package/dist/cjs/ix-workflow-steps.cjs.entry.js +1 -1
  320. package/dist/cjs/loader.cjs.js +1 -1
  321. package/dist/cjs/{modal-CsEGB0kd.js → modal-CUsbxNFf.js} +32 -2
  322. package/dist/cjs/modal-CUsbxNFf.js.map +1 -0
  323. package/dist/cjs/requestAnimationFrame-B0rWQ3G-.js +30 -0
  324. package/dist/cjs/requestAnimationFrame-B0rWQ3G-.js.map +1 -0
  325. package/dist/cjs/siemens-ix.cjs.js +1 -1
  326. package/dist/collection/components/action-card/action-card.js +25 -1
  327. package/dist/collection/components/action-card/action-card.js.map +1 -1
  328. package/dist/collection/components/application-header/application-header.js +46 -10
  329. package/dist/collection/components/application-header/application-header.js.map +1 -1
  330. package/dist/collection/components/breadcrumb/breadcrumb.js +37 -4
  331. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  332. package/dist/collection/components/button/base-button.js +8 -2
  333. package/dist/collection/components/button/base-button.js.map +1 -1
  334. package/dist/collection/components/card/card.css +49 -0
  335. package/dist/collection/components/card/card.js +27 -2
  336. package/dist/collection/components/card/card.js.map +1 -1
  337. package/dist/collection/components/category-filter/category-filter.js +41 -8
  338. package/dist/collection/components/category-filter/category-filter.js.map +1 -1
  339. package/dist/collection/components/date-dropdown/date-dropdown.js +38 -5
  340. package/dist/collection/components/date-dropdown/date-dropdown.js.map +1 -1
  341. package/dist/collection/components/date-input/date-input.js +37 -4
  342. package/dist/collection/components/date-input/date-input.js.map +1 -1
  343. package/dist/collection/components/date-picker/date-picker.js +38 -5
  344. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  345. package/dist/collection/components/drawer/drawer.js +6 -6
  346. package/dist/collection/components/drawer/drawer.js.map +1 -1
  347. package/dist/collection/components/dropdown/dropdown.css +42 -0
  348. package/dist/collection/components/dropdown/dropdown.js +125 -36
  349. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  350. package/dist/collection/components/dropdown-button/dropdown-button.js +42 -5
  351. package/dist/collection/components/dropdown-button/dropdown-button.js.map +1 -1
  352. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  353. package/dist/collection/components/dropdown-item/dropdown-item.js +10 -4
  354. package/dist/collection/components/dropdown-item/dropdown-item.js.map +1 -1
  355. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  356. package/dist/collection/components/empty-state/empty-state.js +1 -1
  357. package/dist/collection/components/event-list/event-list.js +2 -2
  358. package/dist/collection/components/event-list-item/event-list-item.js +4 -4
  359. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  360. package/dist/collection/components/field-label/field-label.js +14 -5
  361. package/dist/collection/components/field-label/field-label.js.map +1 -1
  362. package/dist/collection/components/field-wrapper/field-wrapper.js +2 -2
  363. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  364. package/dist/collection/components/flip-tile/flip-tile.js +3 -3
  365. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  366. package/dist/collection/components/group/group-context-menu.js +1 -1
  367. package/dist/collection/components/group/group.js +8 -8
  368. package/dist/collection/components/helper-text/helper-text.js +1 -1
  369. package/dist/collection/components/icon-button/icon-button.js +5 -2
  370. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  371. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -1
  372. package/dist/collection/components/input/input.js +4 -4
  373. package/dist/collection/components/input/number-input.js +5 -5
  374. package/dist/collection/components/input/textarea.js +2 -2
  375. package/dist/collection/components/input-group/input-group.js +1 -1
  376. package/dist/collection/components/key-value/key-value.js +1 -1
  377. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  378. package/dist/collection/components/kpi/kpi.js +3 -3
  379. package/dist/collection/components/layout-auto/layout-auto.js +1 -1
  380. package/dist/collection/components/layout-grid/layout-grid.js +2 -2
  381. package/dist/collection/components/link-button/link-button.js +3 -3
  382. package/dist/collection/components/menu/menu-expand-icon.js +33 -36
  383. package/dist/collection/components/menu/menu-expand-icon.js.map +1 -1
  384. package/dist/collection/components/menu/menu.js +50 -16
  385. package/dist/collection/components/menu/menu.js.map +1 -1
  386. package/dist/collection/components/menu-about/menu-about.js +25 -1
  387. package/dist/collection/components/menu-about/menu-about.js.map +1 -1
  388. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  389. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  390. package/dist/collection/components/menu-avatar/menu-avatar.js +90 -3
  391. package/dist/collection/components/menu-avatar/menu-avatar.js.map +1 -1
  392. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  393. package/dist/collection/components/menu-category/menu-category.js +6 -6
  394. package/dist/collection/components/menu-category/menu-category.js.map +1 -1
  395. package/dist/collection/components/menu-item/menu-item.js +10 -12
  396. package/dist/collection/components/menu-item/menu-item.js.map +1 -1
  397. package/dist/collection/components/menu-settings/menu-settings.js +25 -1
  398. package/dist/collection/components/menu-settings/menu-settings.js.map +1 -1
  399. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  400. package/dist/collection/components/message-bar/message-bar.css +0 -11
  401. package/dist/collection/components/message-bar/message-bar.js +1 -1
  402. package/dist/collection/components/modal/modal.css +1 -4
  403. package/dist/collection/components/modal/modal.js +4 -6
  404. package/dist/collection/components/modal/modal.js.map +1 -1
  405. package/dist/collection/components/modal-content/modal-content.js +1 -1
  406. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  407. package/dist/collection/components/modal-header/modal-header.js +1 -1
  408. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  409. package/dist/collection/components/pagination/pagination.js +3 -3
  410. package/dist/collection/components/pane/pane.js +6 -6
  411. package/dist/collection/components/pane-layout/pane-layout.js +2 -1
  412. package/dist/collection/components/pane-layout/pane-layout.js.map +1 -1
  413. package/dist/collection/components/pill/pill.js +4 -4
  414. package/dist/collection/components/progress-indicator/progress-indicator.js +3 -3
  415. package/dist/collection/components/push-card/push-card.js +25 -1
  416. package/dist/collection/components/push-card/push-card.js.map +1 -1
  417. package/dist/collection/components/radio/radio.js +3 -3
  418. package/dist/collection/components/radio-group/radio-group.js +2 -2
  419. package/dist/collection/components/row/row.js +1 -1
  420. package/dist/collection/components/select/select.js +49 -14
  421. package/dist/collection/components/select/select.js.map +1 -1
  422. package/dist/collection/components/select-item/select-item.js +1 -1
  423. package/dist/collection/components/slider/slider.css +86 -44
  424. package/dist/collection/components/slider/slider.js +290 -27
  425. package/dist/collection/components/slider/slider.js.map +1 -1
  426. package/dist/collection/components/spinner/spinner.js +1 -1
  427. package/dist/collection/components/split-button/split-button.js +35 -2
  428. package/dist/collection/components/split-button/split-button.js.map +1 -1
  429. package/dist/collection/components/tab-item/tab-item.js +3 -3
  430. package/dist/collection/components/tabs/tabs.js +130 -26
  431. package/dist/collection/components/tabs/tabs.js.map +1 -1
  432. package/dist/collection/components/tile/tile.js +4 -4
  433. package/dist/collection/components/time-input/time-input.js +37 -4
  434. package/dist/collection/components/time-input/time-input.js.map +1 -1
  435. package/dist/collection/components/time-picker/time-picker.js +5 -5
  436. package/dist/collection/components/toast/toast-container.js +4 -3
  437. package/dist/collection/components/toast/toast-container.js.map +1 -1
  438. package/dist/collection/components/toast/toast-utils.js +21 -0
  439. package/dist/collection/components/toast/toast-utils.js.map +1 -1
  440. package/dist/collection/components/toast/toast.css +8 -6
  441. package/dist/collection/components/toast/toast.js +26 -2
  442. package/dist/collection/components/toast/toast.js.map +1 -1
  443. package/dist/collection/components/toggle/toggle.js +3 -3
  444. package/dist/collection/components/toggle-button/toggle-button.js +3 -3
  445. package/dist/collection/components/toggle-button/toggle-button.js.map +1 -1
  446. package/dist/collection/components/tooltip/tooltip.js +1 -1
  447. package/dist/collection/components/tree/tree.js +1 -1
  448. package/dist/collection/components/tree-item/tree-item.js +4 -4
  449. package/dist/collection/components/typography/typography.js +1 -1
  450. package/dist/collection/components/upload/upload.js +3 -3
  451. package/dist/collection/components/utils/lazy-list/lazy.js +32 -3
  452. package/dist/collection/components/utils/lazy-list/lazy.js.map +1 -1
  453. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js +3 -3
  454. package/dist/collection/components/utils/menu-tabs/menu-tabs-fc.js.map +1 -1
  455. package/dist/collection/components/utils/modal/loading.js +3 -0
  456. package/dist/collection/components/utils/modal/loading.js.map +1 -1
  457. package/dist/collection/components/utils/modal/message.js +18 -0
  458. package/dist/collection/components/utils/modal/message.js.map +1 -1
  459. package/dist/collection/components/utils/modal/modal.js +12 -0
  460. package/dist/collection/components/utils/modal/modal.js.map +1 -1
  461. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  462. package/dist/collection/components/workflow-step/workflow-step.js +3 -3
  463. package/dist/collection/components/workflow-steps/workflow-steps.js +1 -1
  464. package/dist/esm/{base-button-TVpiK7pg.js → base-button-D4FlHdn0.js} +10 -4
  465. package/dist/esm/base-button-D4FlHdn0.js.map +1 -0
  466. package/dist/esm/{base-icon-button-B3ULQ24g.js → base-icon-button-rBR4ri6c.js} +3 -3
  467. package/dist/esm/{base-icon-button-B3ULQ24g.js.map → base-icon-button-rBR4ri6c.js.map} +1 -1
  468. package/dist/esm/{index-Kp5Wf9wr.js → index-75AAQH08.js} +3 -3
  469. package/dist/esm/{index-Kp5Wf9wr.js.map → index-75AAQH08.js.map} +1 -1
  470. package/dist/esm/index-CtoreFVF.js +4 -4
  471. package/dist/esm/index.js +26 -2
  472. package/dist/esm/index.js.map +1 -1
  473. package/dist/esm/ix-action-card.entry.js +5 -1
  474. package/dist/esm/ix-action-card.entry.js.map +1 -1
  475. package/dist/esm/ix-application-header.entry.js +19 -12
  476. package/dist/esm/ix-application-header.entry.js.map +1 -1
  477. package/dist/esm/ix-application-switch-modal.entry.js +1 -1
  478. package/dist/esm/ix-avatar_2.entry.js +2 -2
  479. package/dist/esm/ix-breadcrumb-item.entry.js +1 -1
  480. package/dist/esm/ix-breadcrumb.entry.js +11 -4
  481. package/dist/esm/ix-breadcrumb.entry.js.map +1 -1
  482. package/dist/esm/ix-button.entry.js +1 -1
  483. package/dist/esm/ix-card.ix-card-content.entry.js.map +1 -1
  484. package/dist/esm/ix-card_2.entry.js +8 -3
  485. package/dist/esm/ix-category-filter.entry.js +15 -8
  486. package/dist/esm/ix-category-filter.entry.js.map +1 -1
  487. package/dist/esm/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.js.map +1 -1
  488. package/dist/esm/ix-col_4.entry.js +15 -8
  489. package/dist/esm/ix-date-dropdown.entry.js +12 -5
  490. package/dist/esm/ix-date-dropdown.entry.js.map +1 -1
  491. package/dist/esm/ix-date-input.entry.js +11 -4
  492. package/dist/esm/ix-date-input.entry.js.map +1 -1
  493. package/dist/esm/ix-drawer.entry.js +6 -6
  494. package/dist/esm/ix-drawer.entry.js.map +1 -1
  495. package/dist/esm/ix-dropdown-button.entry.js +14 -3
  496. package/dist/esm/ix-dropdown-button.entry.js.map +1 -1
  497. package/dist/esm/ix-dropdown-header.entry.js +1 -1
  498. package/dist/esm/ix-dropdown-item.entry.js +9 -3
  499. package/dist/esm/ix-dropdown-item.entry.js.map +1 -1
  500. package/dist/esm/ix-dropdown-quick-actions.entry.js +1 -1
  501. package/dist/esm/ix-dropdown.entry.js +103 -37
  502. package/dist/esm/ix-dropdown.entry.js.map +1 -1
  503. package/dist/esm/ix-empty-state.entry.js +1 -1
  504. package/dist/esm/ix-event-list-item.entry.js +4 -4
  505. package/dist/esm/ix-event-list.entry.js +2 -2
  506. package/dist/esm/ix-expanding-search.entry.js +4 -4
  507. package/dist/esm/ix-field-label.ix-field-wrapper.entry.js.map +1 -1
  508. package/dist/esm/ix-field-label_2.entry.js +14 -7
  509. package/dist/esm/ix-filter-chip_2.entry.js +2 -2
  510. package/dist/esm/ix-flip-tile-content.entry.js +1 -1
  511. package/dist/esm/ix-flip-tile.entry.js +3 -3
  512. package/dist/esm/ix-group-context-menu_2.entry.js +1 -1
  513. package/dist/esm/ix-group.entry.js +8 -8
  514. package/dist/esm/ix-helper-text.entry.js +1 -1
  515. package/dist/esm/ix-icon-button.ix-spinner.entry.js.map +1 -1
  516. package/dist/esm/ix-icon-button_2.entry.js +7 -4
  517. package/dist/esm/ix-icon-toggle-button.entry.js +3 -3
  518. package/dist/esm/ix-input-group.entry.js +1 -1
  519. package/dist/esm/ix-input.entry.js +4 -4
  520. package/dist/esm/ix-key-value-list.entry.js +1 -1
  521. package/dist/esm/ix-key-value.entry.js +1 -1
  522. package/dist/esm/ix-kpi.entry.js +3 -3
  523. package/dist/esm/ix-layout-auto.entry.js +1 -1
  524. package/dist/esm/ix-link-button.entry.js +3 -3
  525. package/dist/esm/ix-menu-about-item.entry.js +1 -1
  526. package/dist/esm/ix-menu-about-news.entry.js +4 -4
  527. package/dist/esm/ix-menu-about.entry.js +6 -2
  528. package/dist/esm/ix-menu-about.entry.js.map +1 -1
  529. package/dist/esm/ix-menu-avatar.entry.js +20 -3
  530. package/dist/esm/ix-menu-avatar.entry.js.map +1 -1
  531. package/dist/esm/ix-menu-category.entry.js +6 -6
  532. package/dist/esm/ix-menu-category.entry.js.map +1 -1
  533. package/dist/esm/ix-menu-expand-icon.entry.js +10 -8
  534. package/dist/esm/ix-menu-expand-icon.entry.js.map +1 -1
  535. package/dist/esm/ix-menu-item.entry.js +10 -12
  536. package/dist/esm/ix-menu-item.entry.js.map +1 -1
  537. package/dist/esm/{ix-menu-settings-f9o5GGw5.js → ix-menu-settings-CG60xQKd.js} +42 -38
  538. package/dist/esm/ix-menu-settings-CG60xQKd.js.map +1 -0
  539. package/dist/esm/ix-menu-settings-item.entry.js +1 -1
  540. package/dist/esm/ix-menu-settings.entry.js +1 -1
  541. package/dist/esm/ix-menu.entry.js +44 -16
  542. package/dist/esm/ix-menu.entry.js.map +1 -1
  543. package/dist/esm/ix-message-bar.entry.js +2 -2
  544. package/dist/esm/ix-message-bar.entry.js.map +1 -1
  545. package/dist/esm/ix-modal-content_2.entry.js +2 -2
  546. package/dist/esm/ix-modal-footer.entry.js +1 -1
  547. package/dist/esm/ix-modal-loading.entry.js +1 -1
  548. package/dist/esm/ix-modal.entry.js +5 -7
  549. package/dist/esm/ix-modal.entry.js.map +1 -1
  550. package/dist/esm/ix-number-input.entry.js +5 -5
  551. package/dist/esm/ix-pagination.entry.js +4 -4
  552. package/dist/esm/ix-pane-layout.entry.js +2 -1
  553. package/dist/esm/ix-pane-layout.entry.js.map +1 -1
  554. package/dist/esm/ix-pane.entry.js +6 -6
  555. package/dist/esm/ix-pill.entry.js +4 -4
  556. package/dist/esm/ix-progress-indicator.entry.js +3 -3
  557. package/dist/esm/ix-push-card.entry.js +5 -1
  558. package/dist/esm/ix-push-card.entry.js.map +1 -1
  559. package/dist/esm/ix-radio-group.entry.js +2 -2
  560. package/dist/esm/ix-radio.entry.js +3 -3
  561. package/dist/esm/ix-select.entry.js +22 -13
  562. package/dist/esm/ix-select.entry.js.map +1 -1
  563. package/dist/esm/ix-slider.entry.js +87 -25
  564. package/dist/esm/ix-slider.entry.js.map +1 -1
  565. package/dist/esm/ix-split-button.entry.js +8 -1
  566. package/dist/esm/ix-split-button.entry.js.map +1 -1
  567. package/dist/esm/ix-tab-item.ix-tabs.entry.js.map +1 -1
  568. package/dist/esm/ix-tab-item_2.entry.js +134 -53
  569. package/dist/esm/ix-textarea.entry.js +2 -2
  570. package/dist/esm/ix-tile.entry.js +4 -4
  571. package/dist/esm/ix-time-input.entry.js +11 -4
  572. package/dist/esm/ix-time-input.entry.js.map +1 -1
  573. package/dist/esm/ix-time-picker.entry.js +5 -5
  574. package/dist/esm/ix-toast-container.entry.js +4 -3
  575. package/dist/esm/ix-toast-container.entry.js.map +1 -1
  576. package/dist/esm/ix-toast.entry.js +7 -3
  577. package/dist/esm/ix-toast.entry.js.map +1 -1
  578. package/dist/esm/ix-toggle-button.entry.js +3 -3
  579. package/dist/esm/ix-toggle-button.entry.js.map +1 -1
  580. package/dist/esm/ix-toggle.entry.js +3 -3
  581. package/dist/esm/ix-tooltip.entry.js +1 -1
  582. package/dist/esm/ix-tree-item.entry.js +4 -4
  583. package/dist/esm/ix-tree.entry.js +33 -4
  584. package/dist/esm/ix-tree.entry.js.map +1 -1
  585. package/dist/esm/ix-typography.entry.js +1 -1
  586. package/dist/esm/ix-upload.entry.js +3 -3
  587. package/dist/esm/ix-validation-tooltip.entry.js +2 -2
  588. package/dist/esm/ix-workflow-step.entry.js +3 -3
  589. package/dist/esm/ix-workflow-steps.entry.js +1 -1
  590. package/dist/esm/loader.js +1 -1
  591. package/dist/esm/{modal-BTxff2hq.js → modal-DCXtePY2.js} +32 -2
  592. package/dist/esm/modal-DCXtePY2.js.map +1 -0
  593. package/dist/esm/requestAnimationFrame-BEuV0Xpe.js +28 -0
  594. package/dist/esm/requestAnimationFrame-BEuV0Xpe.js.map +1 -0
  595. package/dist/esm/siemens-ix.js +1 -1
  596. package/dist/siemens-ix/index.esm.js +1 -1
  597. package/dist/siemens-ix/index.esm.js.map +1 -1
  598. package/dist/siemens-ix/ix-action-card.entry.esm.js.map +1 -1
  599. package/dist/siemens-ix/ix-application-header.entry.esm.js.map +1 -1
  600. package/dist/siemens-ix/ix-breadcrumb.entry.esm.js.map +1 -1
  601. package/dist/siemens-ix/ix-card.ix-card-content.entry.esm.js.map +1 -1
  602. package/dist/siemens-ix/ix-category-filter.entry.esm.js.map +1 -1
  603. package/dist/siemens-ix/ix-col.ix-date-picker.ix-layout-grid.ix-row.entry.esm.js.map +1 -1
  604. package/dist/siemens-ix/ix-date-dropdown.entry.esm.js.map +1 -1
  605. package/dist/siemens-ix/ix-date-input.entry.esm.js.map +1 -1
  606. package/dist/siemens-ix/ix-drawer.entry.esm.js.map +1 -1
  607. package/dist/siemens-ix/ix-dropdown-button.entry.esm.js.map +1 -1
  608. package/dist/siemens-ix/ix-dropdown-item.entry.esm.js.map +1 -1
  609. package/dist/siemens-ix/ix-dropdown.entry.esm.js.map +1 -1
  610. package/dist/siemens-ix/ix-field-label.ix-field-wrapper.entry.esm.js.map +1 -1
  611. package/dist/siemens-ix/ix-icon-button.ix-spinner.entry.esm.js.map +1 -1
  612. package/dist/siemens-ix/ix-menu-about.entry.esm.js.map +1 -1
  613. package/dist/siemens-ix/ix-menu-avatar.entry.esm.js.map +1 -1
  614. package/dist/siemens-ix/ix-menu-category.entry.esm.js.map +1 -1
  615. package/dist/siemens-ix/ix-menu-expand-icon.entry.esm.js.map +1 -1
  616. package/dist/siemens-ix/ix-menu-item.entry.esm.js.map +1 -1
  617. package/dist/siemens-ix/ix-menu.entry.esm.js.map +1 -1
  618. package/dist/siemens-ix/ix-message-bar.entry.esm.js.map +1 -1
  619. package/dist/siemens-ix/ix-modal.entry.esm.js.map +1 -1
  620. package/dist/siemens-ix/ix-pane-layout.entry.esm.js.map +1 -1
  621. package/dist/siemens-ix/ix-push-card.entry.esm.js.map +1 -1
  622. package/dist/siemens-ix/ix-select.entry.esm.js.map +1 -1
  623. package/dist/siemens-ix/ix-slider.entry.esm.js.map +1 -1
  624. package/dist/siemens-ix/ix-split-button.entry.esm.js.map +1 -1
  625. package/dist/siemens-ix/ix-tab-item.ix-tabs.entry.esm.js.map +1 -1
  626. package/dist/siemens-ix/ix-time-input.entry.esm.js.map +1 -1
  627. package/dist/siemens-ix/ix-toast-container.entry.esm.js.map +1 -1
  628. package/dist/siemens-ix/ix-toast.entry.esm.js.map +1 -1
  629. package/dist/siemens-ix/ix-toggle-button.entry.esm.js.map +1 -1
  630. package/dist/siemens-ix/ix-tree.entry.esm.js.map +1 -1
  631. package/dist/siemens-ix/p-00d9e974.entry.js +2 -0
  632. package/dist/siemens-ix/{p-26c629c3.entry.js.map → p-00d9e974.entry.js.map} +1 -1
  633. package/dist/siemens-ix/p-00f783c2.entry.js +2 -0
  634. package/dist/siemens-ix/p-00f783c2.entry.js.map +1 -0
  635. package/dist/siemens-ix/{p-eba7f62c.entry.js → p-012e0b64.entry.js} +2 -2
  636. package/dist/siemens-ix/p-01f33c21.entry.js +2 -0
  637. package/dist/siemens-ix/p-01f33c21.entry.js.map +1 -0
  638. package/dist/siemens-ix/{p-c94739d0.entry.js → p-0693e4bf.entry.js} +2 -2
  639. package/dist/siemens-ix/p-07ab03fe.entry.js +2 -0
  640. package/dist/siemens-ix/p-07ab03fe.entry.js.map +1 -0
  641. package/dist/siemens-ix/{p-dc8de6cb.entry.js → p-0c5021bc.entry.js} +2 -2
  642. package/dist/siemens-ix/{p-b9880608.entry.js → p-0f80678c.entry.js} +2 -2
  643. package/dist/siemens-ix/p-13dc936a.entry.js +2 -0
  644. package/dist/siemens-ix/p-13dc936a.entry.js.map +1 -0
  645. package/dist/siemens-ix/{p-d3a60c52.entry.js → p-163090c1.entry.js} +2 -2
  646. package/dist/siemens-ix/{p-d3a60c52.entry.js.map → p-163090c1.entry.js.map} +1 -1
  647. package/dist/siemens-ix/{p-ea15fc79.entry.js → p-18d39c8a.entry.js} +2 -2
  648. package/dist/siemens-ix/{p-b3453edf.entry.js → p-1b4cfce2.entry.js} +2 -2
  649. package/dist/siemens-ix/{p-de12078d.entry.js → p-22735495.entry.js} +2 -2
  650. package/dist/siemens-ix/p-24af7715.entry.js +2 -0
  651. package/dist/siemens-ix/p-24af7715.entry.js.map +1 -0
  652. package/dist/siemens-ix/p-29d397e7.entry.js +2 -0
  653. package/dist/siemens-ix/p-29d397e7.entry.js.map +1 -0
  654. package/dist/siemens-ix/p-2e1bb4bf.entry.js +2 -0
  655. package/dist/siemens-ix/p-2e1bb4bf.entry.js.map +1 -0
  656. package/dist/siemens-ix/{p-1de1a2bf.entry.js → p-2eda608a.entry.js} +2 -2
  657. package/dist/siemens-ix/{p-6a4bc78a.entry.js → p-2f83d5de.entry.js} +2 -2
  658. package/dist/siemens-ix/p-332b3d09.entry.js +2 -0
  659. package/dist/siemens-ix/{p-c15e64a8.entry.js → p-346c5039.entry.js} +2 -2
  660. package/dist/siemens-ix/p-38ba4776.entry.js +2 -0
  661. package/dist/siemens-ix/p-38ba4776.entry.js.map +1 -0
  662. package/dist/siemens-ix/{p-b7ef70d4.entry.js → p-3ff8cf24.entry.js} +2 -2
  663. package/dist/siemens-ix/p-3ff8cf24.entry.js.map +1 -0
  664. package/dist/siemens-ix/{p-4431f891.entry.js → p-4a6f8ce8.entry.js} +2 -2
  665. package/dist/siemens-ix/p-4a9cceff.entry.js +2 -0
  666. package/dist/siemens-ix/{p-0ce03ad3.entry.js.map → p-4a9cceff.entry.js.map} +1 -1
  667. package/dist/siemens-ix/{p-396e1f3d.entry.js → p-4d004e44.entry.js} +2 -2
  668. package/dist/siemens-ix/{p-b76df1c7.entry.js → p-4d540a34.entry.js} +2 -2
  669. package/dist/siemens-ix/p-4d540a34.entry.js.map +1 -0
  670. package/dist/siemens-ix/p-4e985847.entry.js +2 -0
  671. package/dist/siemens-ix/p-4e985847.entry.js.map +1 -0
  672. package/dist/siemens-ix/p-5306efc0.entry.js +2 -0
  673. package/dist/siemens-ix/p-5306efc0.entry.js.map +1 -0
  674. package/dist/siemens-ix/p-568e5673.entry.js +2 -0
  675. package/dist/siemens-ix/p-568e5673.entry.js.map +1 -0
  676. package/dist/siemens-ix/{p-38e45020.entry.js → p-591664be.entry.js} +2 -2
  677. package/dist/siemens-ix/{p-c5c863e1.entry.js → p-6794955e.entry.js} +2 -2
  678. package/dist/siemens-ix/{p-79537728.entry.js → p-69526242.entry.js} +2 -2
  679. package/dist/siemens-ix/p-7752df0f.entry.js +2 -0
  680. package/dist/siemens-ix/p-78ac2dbc.entry.js +2 -0
  681. package/dist/siemens-ix/{p-8f9368b8.entry.js → p-7ab95193.entry.js} +2 -2
  682. package/dist/siemens-ix/p-7c3ed8dc.entry.js +2 -0
  683. package/dist/siemens-ix/p-7c3ed8dc.entry.js.map +1 -0
  684. package/dist/siemens-ix/{p-fb8877bc.entry.js → p-7df00cac.entry.js} +2 -2
  685. package/dist/siemens-ix/p-7df00cac.entry.js.map +1 -0
  686. package/dist/siemens-ix/{p-e7bdc0a0.entry.js → p-7fa55c16.entry.js} +2 -2
  687. package/dist/siemens-ix/p-7fa55c16.entry.js.map +1 -0
  688. package/dist/siemens-ix/{p-ff83eafd.entry.js → p-7fbcc15c.entry.js} +2 -2
  689. package/dist/siemens-ix/p-828db41e.entry.js +2 -0
  690. package/dist/siemens-ix/{p-6dc6eb63.entry.js.map → p-828db41e.entry.js.map} +1 -1
  691. package/dist/siemens-ix/{p-496e98ac.entry.js → p-82c3a8a2.entry.js} +2 -2
  692. package/dist/siemens-ix/p-899b445d.entry.js +2 -0
  693. package/dist/siemens-ix/p-899b445d.entry.js.map +1 -0
  694. package/dist/siemens-ix/{p-5779f16e.entry.js → p-8b6f2e0e.entry.js} +2 -2
  695. package/dist/siemens-ix/p-8c8bad0a.entry.js +2 -0
  696. package/dist/siemens-ix/{p-b8f4b001.entry.js → p-8e26b723.entry.js} +2 -2
  697. package/dist/siemens-ix/p-8e26b723.entry.js.map +1 -0
  698. package/dist/siemens-ix/{p-7bc90e7e.entry.js → p-8e7f7343.entry.js} +2 -2
  699. package/dist/siemens-ix/{p-484bddf4.entry.js → p-922a49d7.entry.js} +2 -2
  700. package/dist/siemens-ix/{p-196cffb5.entry.js → p-9362445d.entry.js} +2 -2
  701. package/dist/siemens-ix/p-9492ebc4.entry.js +2 -0
  702. package/dist/siemens-ix/p-9492ebc4.entry.js.map +1 -0
  703. package/dist/siemens-ix/{p-d2c18c15.entry.js → p-96c371c8.entry.js} +2 -2
  704. package/dist/siemens-ix/{p-2ffde2d5.entry.js → p-97c3d27e.entry.js} +2 -2
  705. package/dist/siemens-ix/{p-f119c105.entry.js → p-98cf2c22.entry.js} +2 -2
  706. package/dist/siemens-ix/{p-ca3b24b1.entry.js → p-99dda4c4.entry.js} +2 -2
  707. package/dist/siemens-ix/{p-e48977ed.entry.js → p-9b917ecd.entry.js} +2 -2
  708. package/dist/siemens-ix/p-9ea48663.entry.js +2 -0
  709. package/dist/siemens-ix/p-9ea48663.entry.js.map +1 -0
  710. package/dist/siemens-ix/{p-CObJ-t0Z.js → p-B3-0mRq1.js} +2 -2
  711. package/dist/siemens-ix/{p-CObJ-t0Z.js.map → p-B3-0mRq1.js.map} +1 -1
  712. package/dist/siemens-ix/p-BEuV0Xpe.js +2 -0
  713. package/dist/siemens-ix/p-BEuV0Xpe.js.map +1 -0
  714. package/dist/siemens-ix/p-BYhznbns.js +2 -0
  715. package/dist/siemens-ix/p-BYhznbns.js.map +1 -0
  716. package/dist/siemens-ix/p-BvohuWNe.js +2 -0
  717. package/dist/siemens-ix/p-BvohuWNe.js.map +1 -0
  718. package/dist/siemens-ix/p-CSUx_zC3.js +2 -0
  719. package/dist/siemens-ix/{p-DpM4lbAX.js.map → p-CSUx_zC3.js.map} +1 -1
  720. package/dist/siemens-ix/{p-BC0Exw_O.js → p-IHkSWEwz.js} +1 -1
  721. package/dist/siemens-ix/p-IHkSWEwz.js.map +1 -0
  722. package/dist/siemens-ix/p-a9c3bb03.entry.js +2 -0
  723. package/dist/siemens-ix/p-a9c3bb03.entry.js.map +1 -0
  724. package/dist/siemens-ix/{p-4c18f123.entry.js → p-ad911b63.entry.js} +2 -2
  725. package/dist/siemens-ix/{p-74e7b03f.entry.js → p-b1eac110.entry.js} +2 -2
  726. package/dist/siemens-ix/p-b7438aeb.entry.js +2 -0
  727. package/dist/siemens-ix/p-b7438aeb.entry.js.map +1 -0
  728. package/dist/siemens-ix/{p-d10b9798.entry.js → p-b7734b9d.entry.js} +2 -2
  729. package/dist/siemens-ix/{p-df6bb698.entry.js → p-bc85feef.entry.js} +2 -2
  730. package/dist/siemens-ix/{p-a4225101.entry.js → p-c6ee37e4.entry.js} +2 -2
  731. package/dist/siemens-ix/{p-a8308559.entry.js → p-ca2533b1.entry.js} +2 -2
  732. package/dist/siemens-ix/p-cb5e0db6.entry.js +2 -0
  733. package/dist/siemens-ix/{p-3f62166e.entry.js.map → p-cb5e0db6.entry.js.map} +1 -1
  734. package/dist/siemens-ix/{p-667e3184.entry.js → p-ceb7b1da.entry.js} +2 -2
  735. package/dist/siemens-ix/{p-e0b9cf68.entry.js → p-d2ce70ac.entry.js} +2 -2
  736. package/dist/siemens-ix/{p-8fc2bea6.entry.js → p-d384611d.entry.js} +2 -2
  737. package/dist/siemens-ix/p-d63ac3e3.entry.js +2 -0
  738. package/dist/siemens-ix/p-d63ac3e3.entry.js.map +1 -0
  739. package/dist/siemens-ix/p-d73d0805.entry.js +2 -0
  740. package/dist/siemens-ix/p-d73d0805.entry.js.map +1 -0
  741. package/dist/siemens-ix/{p-b41a7abb.entry.js → p-d82ac1e1.entry.js} +2 -2
  742. package/dist/siemens-ix/{p-7beba4ad.entry.js → p-d9776ef8.entry.js} +2 -2
  743. package/dist/siemens-ix/p-db913bc4.entry.js +2 -0
  744. package/dist/siemens-ix/p-db913bc4.entry.js.map +1 -0
  745. package/dist/siemens-ix/{p-367df024.entry.js → p-dc0be9bf.entry.js} +2 -2
  746. package/dist/siemens-ix/p-dc0be9bf.entry.js.map +1 -0
  747. package/dist/siemens-ix/{p-33b3ed5b.entry.js → p-de59209e.entry.js} +2 -2
  748. package/dist/siemens-ix/{p-cf041cfd.entry.js → p-e29533a3.entry.js} +2 -2
  749. package/dist/siemens-ix/{p-3ce5fd87.entry.js → p-e4dabf5b.entry.js} +2 -2
  750. package/dist/siemens-ix/p-e4dabf5b.entry.js.map +1 -0
  751. package/dist/siemens-ix/{p-cd1afcc9.entry.js → p-e69d8217.entry.js} +2 -2
  752. package/dist/siemens-ix/{p-7827c263.entry.js → p-e7ef43ed.entry.js} +2 -2
  753. package/dist/siemens-ix/{p-8f17f6ec.entry.js → p-ec9dc8d8.entry.js} +2 -2
  754. package/dist/siemens-ix/p-ec9dc8d8.entry.js.map +1 -0
  755. package/dist/siemens-ix/{p-77fd2138.entry.js → p-f4264893.entry.js} +2 -2
  756. package/dist/siemens-ix/p-f42f74c2.entry.js +2 -0
  757. package/dist/siemens-ix/p-f7cb5560.entry.js +2 -0
  758. package/dist/siemens-ix/p-f7cb5560.entry.js.map +1 -0
  759. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  760. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  761. package/dist/types/components/action-card/action-card.d.ts +4 -0
  762. package/dist/types/components/application-header/application-header.d.ts +8 -0
  763. package/dist/types/components/breadcrumb/breadcrumb.d.ts +7 -0
  764. package/dist/types/components/card/card.d.ts +4 -0
  765. package/dist/types/components/category-filter/category-filter.d.ts +7 -0
  766. package/dist/types/components/date-dropdown/date-dropdown.d.ts +8 -1
  767. package/dist/types/components/date-input/date-input.d.ts +7 -0
  768. package/dist/types/components/date-picker/date-picker.d.ts +7 -0
  769. package/dist/types/components/dropdown/dropdown.d.ts +11 -1
  770. package/dist/types/components/dropdown-button/dropdown-button.d.ts +7 -0
  771. package/dist/types/components/field-label/field-label.d.ts +2 -0
  772. package/dist/types/components/menu/menu-expand-icon.d.ts +5 -2
  773. package/dist/types/components/menu/menu.d.ts +6 -0
  774. package/dist/types/components/menu-about/menu-about.d.ts +4 -0
  775. package/dist/types/components/menu-avatar/menu-avatar.d.ts +20 -0
  776. package/dist/types/components/menu-item/menu-item.d.ts +1 -1
  777. package/dist/types/components/menu-settings/menu-settings.d.ts +4 -0
  778. package/dist/types/components/modal/modal.d.ts +0 -1
  779. package/dist/types/components/push-card/push-card.d.ts +4 -0
  780. package/dist/types/components/select/select.d.ts +7 -0
  781. package/dist/types/components/slider/slider.d.ts +57 -2
  782. package/dist/types/components/split-button/split-button.d.ts +8 -1
  783. package/dist/types/components/tabs/tabs.d.ts +12 -0
  784. package/dist/types/components/time-input/time-input.d.ts +7 -0
  785. package/dist/types/components/toast/toast-utils.d.ts +13 -0
  786. package/dist/types/components/toast/toast.d.ts +4 -0
  787. package/dist/types/components/toggle-button/toggle-button.d.ts +1 -3
  788. package/dist/types/components/utils/lazy-list/lazy.d.ts +2 -0
  789. package/dist/types/components/utils/modal/loading.d.ts +3 -0
  790. package/dist/types/components/utils/modal/message.d.ts +3 -0
  791. package/dist/types/components/utils/modal/modal.d.ts +63 -0
  792. package/dist/types/components.d.ts +326 -7
  793. package/hydrate/index.js +1144 -678
  794. package/hydrate/index.mjs +1144 -678
  795. package/package.json +1 -1
  796. package/components/p-10zMtvCF.js.map +0 -1
  797. package/components/p-B1p0kpQJ.js.map +0 -1
  798. package/components/p-BEDohapR.js.map +0 -1
  799. package/components/p-BI7B-PUA.js.map +0 -1
  800. package/components/p-BLeWaHpy.js.map +0 -1
  801. package/components/p-BOQ00Fbs.js.map +0 -1
  802. package/components/p-BiqdnsgA.js.map +0 -1
  803. package/components/p-CV_EVAOW.js.map +0 -1
  804. package/components/p-CjDPpSJX.js.map +0 -1
  805. package/components/p-DSTHZygb.js.map +0 -1
  806. package/components/p-DlVaL0Yi.js.map +0 -1
  807. package/components/p-MuPiaYr1.js.map +0 -1
  808. package/components/p-PpLLlogo.js.map +0 -1
  809. package/components/p-hwPzPVf8.js.map +0 -1
  810. package/dist/cjs/base-button-CjsUotrL.js.map +0 -1
  811. package/dist/cjs/ix-menu-settings-CtWl0bME.js.map +0 -1
  812. package/dist/cjs/modal-CsEGB0kd.js.map +0 -1
  813. package/dist/esm/base-button-TVpiK7pg.js.map +0 -1
  814. package/dist/esm/ix-menu-settings-f9o5GGw5.js.map +0 -1
  815. package/dist/esm/modal-BTxff2hq.js.map +0 -1
  816. package/dist/siemens-ix/p-0411df39.entry.js +0 -2
  817. package/dist/siemens-ix/p-0c325f08.entry.js +0 -2
  818. package/dist/siemens-ix/p-0c325f08.entry.js.map +0 -1
  819. package/dist/siemens-ix/p-0ce03ad3.entry.js +0 -2
  820. package/dist/siemens-ix/p-0d621531.entry.js +0 -2
  821. package/dist/siemens-ix/p-0d621531.entry.js.map +0 -1
  822. package/dist/siemens-ix/p-0eca5a77.entry.js +0 -2
  823. package/dist/siemens-ix/p-0eca5a77.entry.js.map +0 -1
  824. package/dist/siemens-ix/p-2597a988.entry.js +0 -2
  825. package/dist/siemens-ix/p-2597a988.entry.js.map +0 -1
  826. package/dist/siemens-ix/p-26c629c3.entry.js +0 -2
  827. package/dist/siemens-ix/p-31a8eaf9.entry.js +0 -2
  828. package/dist/siemens-ix/p-33fcea65.entry.js +0 -2
  829. package/dist/siemens-ix/p-33fcea65.entry.js.map +0 -1
  830. package/dist/siemens-ix/p-367df024.entry.js.map +0 -1
  831. package/dist/siemens-ix/p-37bd983a.entry.js +0 -2
  832. package/dist/siemens-ix/p-37bd983a.entry.js.map +0 -1
  833. package/dist/siemens-ix/p-3ce5fd87.entry.js.map +0 -1
  834. package/dist/siemens-ix/p-3f62166e.entry.js +0 -2
  835. package/dist/siemens-ix/p-4c1f90cb.entry.js +0 -2
  836. package/dist/siemens-ix/p-4c1f90cb.entry.js.map +0 -1
  837. package/dist/siemens-ix/p-4e4d792d.entry.js +0 -2
  838. package/dist/siemens-ix/p-4e4d792d.entry.js.map +0 -1
  839. package/dist/siemens-ix/p-5b57bde1.entry.js +0 -2
  840. package/dist/siemens-ix/p-5b57bde1.entry.js.map +0 -1
  841. package/dist/siemens-ix/p-68aaf0fe.entry.js +0 -2
  842. package/dist/siemens-ix/p-68aaf0fe.entry.js.map +0 -1
  843. package/dist/siemens-ix/p-6dc6eb63.entry.js +0 -2
  844. package/dist/siemens-ix/p-7bad0544.entry.js +0 -2
  845. package/dist/siemens-ix/p-7bad0544.entry.js.map +0 -1
  846. package/dist/siemens-ix/p-8418f756.entry.js +0 -2
  847. package/dist/siemens-ix/p-8418f756.entry.js.map +0 -1
  848. package/dist/siemens-ix/p-8b42ad35.entry.js +0 -2
  849. package/dist/siemens-ix/p-8b42ad35.entry.js.map +0 -1
  850. package/dist/siemens-ix/p-8f17f6ec.entry.js.map +0 -1
  851. package/dist/siemens-ix/p-8fa8d0e3.entry.js +0 -2
  852. package/dist/siemens-ix/p-92ec7f27.entry.js +0 -2
  853. package/dist/siemens-ix/p-BC0Exw_O.js.map +0 -1
  854. package/dist/siemens-ix/p-BcCDexod.js +0 -2
  855. package/dist/siemens-ix/p-BcCDexod.js.map +0 -1
  856. package/dist/siemens-ix/p-DiMfcbUU.js +0 -2
  857. package/dist/siemens-ix/p-DiMfcbUU.js.map +0 -1
  858. package/dist/siemens-ix/p-DpM4lbAX.js +0 -2
  859. package/dist/siemens-ix/p-a3baca2f.entry.js +0 -2
  860. package/dist/siemens-ix/p-a61972c5.entry.js +0 -2
  861. package/dist/siemens-ix/p-a61972c5.entry.js.map +0 -1
  862. package/dist/siemens-ix/p-b76df1c7.entry.js.map +0 -1
  863. package/dist/siemens-ix/p-b7ef70d4.entry.js.map +0 -1
  864. package/dist/siemens-ix/p-b8f4b001.entry.js.map +0 -1
  865. package/dist/siemens-ix/p-ba9ed3d1.entry.js +0 -2
  866. package/dist/siemens-ix/p-ba9ed3d1.entry.js.map +0 -1
  867. package/dist/siemens-ix/p-c1160cf8.entry.js +0 -2
  868. package/dist/siemens-ix/p-c1160cf8.entry.js.map +0 -1
  869. package/dist/siemens-ix/p-d193381f.entry.js +0 -2
  870. package/dist/siemens-ix/p-d193381f.entry.js.map +0 -1
  871. package/dist/siemens-ix/p-e42f62a1.entry.js +0 -2
  872. package/dist/siemens-ix/p-e42f62a1.entry.js.map +0 -1
  873. package/dist/siemens-ix/p-e7bdc0a0.entry.js.map +0 -1
  874. package/dist/siemens-ix/p-ea37abf6.entry.js +0 -2
  875. package/dist/siemens-ix/p-ea37abf6.entry.js.map +0 -1
  876. package/dist/siemens-ix/p-ea410634.entry.js +0 -2
  877. package/dist/siemens-ix/p-ea410634.entry.js.map +0 -1
  878. package/dist/siemens-ix/p-fb8877bc.entry.js.map +0 -1
  879. package/dist/siemens-ix/p-fc73c8cc.entry.js +0 -2
  880. package/dist/siemens-ix/p-fc73c8cc.entry.js.map +0 -1
  881. /package/dist/siemens-ix/{p-eba7f62c.entry.js.map → p-012e0b64.entry.js.map} +0 -0
  882. /package/dist/siemens-ix/{p-c94739d0.entry.js.map → p-0693e4bf.entry.js.map} +0 -0
  883. /package/dist/siemens-ix/{p-dc8de6cb.entry.js.map → p-0c5021bc.entry.js.map} +0 -0
  884. /package/dist/siemens-ix/{p-b9880608.entry.js.map → p-0f80678c.entry.js.map} +0 -0
  885. /package/dist/siemens-ix/{p-ea15fc79.entry.js.map → p-18d39c8a.entry.js.map} +0 -0
  886. /package/dist/siemens-ix/{p-b3453edf.entry.js.map → p-1b4cfce2.entry.js.map} +0 -0
  887. /package/dist/siemens-ix/{p-de12078d.entry.js.map → p-22735495.entry.js.map} +0 -0
  888. /package/dist/siemens-ix/{p-1de1a2bf.entry.js.map → p-2eda608a.entry.js.map} +0 -0
  889. /package/dist/siemens-ix/{p-6a4bc78a.entry.js.map → p-2f83d5de.entry.js.map} +0 -0
  890. /package/dist/siemens-ix/{p-a3baca2f.entry.js.map → p-332b3d09.entry.js.map} +0 -0
  891. /package/dist/siemens-ix/{p-c15e64a8.entry.js.map → p-346c5039.entry.js.map} +0 -0
  892. /package/dist/siemens-ix/{p-4431f891.entry.js.map → p-4a6f8ce8.entry.js.map} +0 -0
  893. /package/dist/siemens-ix/{p-396e1f3d.entry.js.map → p-4d004e44.entry.js.map} +0 -0
  894. /package/dist/siemens-ix/{p-38e45020.entry.js.map → p-591664be.entry.js.map} +0 -0
  895. /package/dist/siemens-ix/{p-c5c863e1.entry.js.map → p-6794955e.entry.js.map} +0 -0
  896. /package/dist/siemens-ix/{p-79537728.entry.js.map → p-69526242.entry.js.map} +0 -0
  897. /package/dist/siemens-ix/{p-8fa8d0e3.entry.js.map → p-7752df0f.entry.js.map} +0 -0
  898. /package/dist/siemens-ix/{p-0411df39.entry.js.map → p-78ac2dbc.entry.js.map} +0 -0
  899. /package/dist/siemens-ix/{p-8f9368b8.entry.js.map → p-7ab95193.entry.js.map} +0 -0
  900. /package/dist/siemens-ix/{p-ff83eafd.entry.js.map → p-7fbcc15c.entry.js.map} +0 -0
  901. /package/dist/siemens-ix/{p-496e98ac.entry.js.map → p-82c3a8a2.entry.js.map} +0 -0
  902. /package/dist/siemens-ix/{p-5779f16e.entry.js.map → p-8b6f2e0e.entry.js.map} +0 -0
  903. /package/dist/siemens-ix/{p-31a8eaf9.entry.js.map → p-8c8bad0a.entry.js.map} +0 -0
  904. /package/dist/siemens-ix/{p-7bc90e7e.entry.js.map → p-8e7f7343.entry.js.map} +0 -0
  905. /package/dist/siemens-ix/{p-484bddf4.entry.js.map → p-922a49d7.entry.js.map} +0 -0
  906. /package/dist/siemens-ix/{p-196cffb5.entry.js.map → p-9362445d.entry.js.map} +0 -0
  907. /package/dist/siemens-ix/{p-d2c18c15.entry.js.map → p-96c371c8.entry.js.map} +0 -0
  908. /package/dist/siemens-ix/{p-2ffde2d5.entry.js.map → p-97c3d27e.entry.js.map} +0 -0
  909. /package/dist/siemens-ix/{p-f119c105.entry.js.map → p-98cf2c22.entry.js.map} +0 -0
  910. /package/dist/siemens-ix/{p-ca3b24b1.entry.js.map → p-99dda4c4.entry.js.map} +0 -0
  911. /package/dist/siemens-ix/{p-e48977ed.entry.js.map → p-9b917ecd.entry.js.map} +0 -0
  912. /package/dist/siemens-ix/{p-4c18f123.entry.js.map → p-ad911b63.entry.js.map} +0 -0
  913. /package/dist/siemens-ix/{p-74e7b03f.entry.js.map → p-b1eac110.entry.js.map} +0 -0
  914. /package/dist/siemens-ix/{p-d10b9798.entry.js.map → p-b7734b9d.entry.js.map} +0 -0
  915. /package/dist/siemens-ix/{p-df6bb698.entry.js.map → p-bc85feef.entry.js.map} +0 -0
  916. /package/dist/siemens-ix/{p-a4225101.entry.js.map → p-c6ee37e4.entry.js.map} +0 -0
  917. /package/dist/siemens-ix/{p-a8308559.entry.js.map → p-ca2533b1.entry.js.map} +0 -0
  918. /package/dist/siemens-ix/{p-667e3184.entry.js.map → p-ceb7b1da.entry.js.map} +0 -0
  919. /package/dist/siemens-ix/{p-e0b9cf68.entry.js.map → p-d2ce70ac.entry.js.map} +0 -0
  920. /package/dist/siemens-ix/{p-8fc2bea6.entry.js.map → p-d384611d.entry.js.map} +0 -0
  921. /package/dist/siemens-ix/{p-b41a7abb.entry.js.map → p-d82ac1e1.entry.js.map} +0 -0
  922. /package/dist/siemens-ix/{p-7beba4ad.entry.js.map → p-d9776ef8.entry.js.map} +0 -0
  923. /package/dist/siemens-ix/{p-33b3ed5b.entry.js.map → p-de59209e.entry.js.map} +0 -0
  924. /package/dist/siemens-ix/{p-cf041cfd.entry.js.map → p-e29533a3.entry.js.map} +0 -0
  925. /package/dist/siemens-ix/{p-cd1afcc9.entry.js.map → p-e69d8217.entry.js.map} +0 -0
  926. /package/dist/siemens-ix/{p-7827c263.entry.js.map → p-e7ef43ed.entry.js.map} +0 -0
  927. /package/dist/siemens-ix/{p-77fd2138.entry.js.map → p-f4264893.entry.js.map} +0 -0
  928. /package/dist/siemens-ix/{p-92ec7f27.entry.js.map → p-f42f74c2.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"slider.js","sourceRoot":"","sources":["../../../src/components/slider/slider.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 State,\n Watch,\n} from '@stencil/core';\nimport { A11yAttributes, a11yHostAttributes } from '../utils/a11y';\nimport { OnListener } from '../utils/listener';\nimport { makeRef } from '../utils/make-ref';\nimport type { SliderMarker } from './slider.types';\n\nfunction between(min: number, value: number, max: number) {\n if (value < min) {\n return min;\n } else if (value > max) {\n return max;\n } else {\n return value;\n }\n}\n\n/**\n * @slot label-start - Element will be displayed at the start of the slider\n * @slot label-end - Element will be displayed at the end of the slider\n */\n@Component({\n tag: 'ix-slider',\n styleUrl: 'slider.scss',\n shadow: true,\n})\nexport class Slider {\n @Element() hostElement!: HTMLIxSliderElement;\n\n /**\n * Legal number intervals\n *\n * {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#step}\n */\n @Prop() step: number = 1;\n\n /**\n * Minimum slider value\n */\n @Prop() min = 0;\n\n /**\n * Maximum slider value\n */\n @Prop() max = 100;\n\n /**\n * Current value of the slider\n */\n @Prop() value = 0;\n\n /**\n * Define tick marker on the slider. Marker has to be within slider min/max\n */\n @Prop() marker?: SliderMarker;\n\n /**\n * Show a trace line\n */\n @Prop() trace = false;\n\n /**\n * Define the start point of the trace line\n */\n @Prop() traceReference = 0;\n\n /**\n * Show control as disabled\n */\n @Prop() disabled = false;\n\n /**\n * Show error state and message\n */\n @Prop() error?: boolean | string;\n\n /**\n *\n */\n @Event() valueChange!: EventEmitter<number>;\n\n @State() rangeInput = 0;\n @State() rangeMin = 0;\n @State() rangeMax = 100;\n @State() rangeTraceReference = 0;\n @State() showTooltip = false;\n\n private a11yAttributes?: A11yAttributes;\n\n private readonly thumbRef = makeRef<HTMLDivElement>();\n private readonly tooltipRef = makeRef<HTMLIxTooltipElement>();\n\n get tooltip() {\n return this.tooltipRef.current;\n }\n\n get pseudoThumb() {\n return this.thumbRef.current;\n }\n\n get slider() {\n return this.hostElement.shadowRoot?.getElementById(\n 'slider'\n ) as HTMLInputElement;\n }\n\n @Watch('showTooltip')\n onShowTooltipChange() {\n if (this.showTooltip && this.pseudoThumb) {\n this.tooltip?.showTooltip(this.pseudoThumb);\n return;\n }\n\n this.tooltip?.hideTooltip();\n }\n\n componentWillLoad() {\n this.a11yAttributes = a11yHostAttributes(this.hostElement, [\n 'role',\n 'aria-valuemin',\n 'aria-valuemax',\n 'aria-valuenow',\n ]);\n this.updateRangeVariables();\n }\n\n @Watch('value')\n @Watch('max')\n @Watch('min')\n @Watch('traceReference')\n private updateRangeVariables() {\n this.rangeInput = between(this.min, this.value, this.max);\n this.rangeTraceReference = between(this.min, this.traceReference, this.max);\n this.rangeMin = Math.min(this.min, this.max);\n this.rangeMax = Math.max(this.min, this.max);\n }\n\n private onInput(event: InputEvent) {\n event.stopPropagation();\n const value = parseFloat(this.slider.value);\n\n if (!isNaN(value)) {\n const oldValue = this.rangeInput;\n this.rangeInput = value;\n\n const { defaultPrevented } = this.emitInputEvent();\n\n if (defaultPrevented) {\n this.rangeInput = oldValue;\n this.slider.value = oldValue.toString();\n }\n }\n }\n\n private emitInputEvent() {\n return this.valueChange.emit(this.rangeInput);\n }\n\n private isMarkerActive(markerValue: number) {\n const start = Math.min(this.traceReference, this.rangeInput);\n const end = Math.max(this.traceReference, this.rangeInput);\n const value = markerValue;\n\n return value >= start && value <= end;\n }\n\n // Listen globally on window because sometimes the event listener\n // of the DOM element input itself is not called if the release\n // click is not inside the element anymore\n @OnListener<Slider>('pointerup', (self) => self.showTooltip)\n onPointerUp() {\n this.showTooltip = false;\n }\n\n render() {\n const range = this.rangeMax - this.rangeMin;\n\n let traceReferenceInPercentage =\n (this.rangeTraceReference - this.rangeMin) / range;\n\n let valueInPercentage = (this.rangeInput - this.rangeMin) / range;\n\n const distance = valueInPercentage - traceReferenceInPercentage;\n\n let traceStart = traceReferenceInPercentage;\n let traceEnd = valueInPercentage;\n\n if (distance <= 0) {\n traceStart = valueInPercentage;\n traceEnd = traceReferenceInPercentage;\n }\n\n return (\n <Host\n class={{\n disabled: this.disabled,\n error: !!this.error,\n }}\n onPointerDown={() => setTimeout(() => (this.showTooltip = true))}\n >\n <div class=\"slider\">\n <div class=\"track\">\n <div\n ref={this.thumbRef}\n class=\"thumb\"\n style={{\n left: `calc(${valueInPercentage} * 100% - 8px)`,\n }}\n ></div>\n <div class=\"ticks\">\n {this.marker\n ? this.marker.map((markerValue) => {\n if (markerValue > this.max || markerValue < this.min) {\n return;\n }\n\n let left = (markerValue - this.rangeMin) / range;\n\n return (\n <div\n class={{\n tick: true,\n 'tick-active':\n this.isMarkerActive(markerValue) && this.trace,\n }}\n style={{\n '--tick-value': `${left}`,\n }}\n ></div>\n );\n })\n : null}\n </div>\n </div>\n\n <input\n id=\"slider\"\n type=\"range\"\n list={this.marker ? 'markers' : undefined}\n step={this.step}\n min={this.min}\n max={this.max}\n value={this.rangeInput}\n tabindex={this.disabled ? -1 : 0}\n onInput={(event) => this.onInput(event)}\n style={{\n '--value': `${valueInPercentage}`,\n '--trace-reference': `${traceReferenceInPercentage}`,\n '--trace-start': `${traceStart}`,\n '--trace-end': `${traceEnd}`,\n }}\n class={{\n trace:\n this.trace && traceReferenceInPercentage !== valueInPercentage,\n 'hide-trace-reference':\n this.trace &&\n (this.traceReference <= this.min ||\n this.traceReference >= this.max),\n }}\n onFocus={() => {\n this.showTooltip = true;\n }}\n onBlur={() => {\n this.showTooltip = false;\n }}\n role=\"slider\"\n aria-valuenow={this.rangeInput}\n aria-valuemin={this.min}\n aria-valuemax={this.max}\n {...this.a11yAttributes}\n />\n\n <ix-tooltip\n ref={this.tooltipRef}\n class={{\n 'hide-tooltip': !this.showTooltip,\n }}\n animationFrame={true}\n for={this.thumbRef.waitForCurrent()}\n >\n {this.rangeInput}\n </ix-tooltip>\n </div>\n <div class=\"label\">\n <div class=\"label-start\">\n <slot name=\"label-start\"></slot>\n </div>\n <div class=\"label-end\">\n <slot name=\"label-end\"></slot>\n </div>\n </div>\n {this.error ? (\n <ix-typography class={'label-error'} textColor=\"alarm\">\n {this.error}\n </ix-typography>\n ) : null}\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"slider.js","sourceRoot":"","sources":["../../../src/components/slider/slider.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 AttachInternals,\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Method,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport { A11yAttributes, a11yHostAttributes } from '../utils/a11y';\nimport { OnListener } from '../utils/listener';\nimport { makeRef } from '../utils/make-ref';\nimport {\n ValidationResults,\n HookValidationLifecycle,\n FieldWrapperInterface,\n IxFormValidationState,\n} from '../utils/input';\nimport type { SliderMarker } from './slider.types';\n\nfunction between(min: number, value: number, max: number) {\n if (value < min) {\n return min;\n } else if (value > max) {\n return max;\n } else {\n return value;\n }\n}\n\n/**\n * @form-ready\n * @slot label-start - Element will be displayed at the start of the slider\n * @slot label-end - Element will be displayed at the end of the slider\n */\n@Component({\n tag: 'ix-slider',\n styleUrl: 'slider.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class Slider implements FieldWrapperInterface, IxFormValidationState {\n @AttachInternals() formInternals!: ElementInternals;\n @Element() hostElement!: HTMLIxSliderElement;\n\n /**\n * Show text below the field component\n * @since 4.3.0\n */\n @Prop() helperText?: string;\n\n /**\n * Label for the field component\n * @since 4.3.0\n */\n @Prop() label?: string;\n\n /**\n * Error text for the field component\n * @since 4.3.0\n */\n @Prop() invalidText?: string;\n\n /**\n * Info text for the field component\n * @since 4.3.0\n */\n @Prop() infoText?: string;\n\n /**\n * Warning text for the field component\n * @since 4.3.0\n */\n @Prop() warningText?: string;\n\n /**\n * Valid text for the field component\n * @since 4.3.0\n */\n @Prop() validText?: string;\n\n /**\n * Show helper, info, warning, error and valid text as tooltip\n * @since 4.3.0\n */\n @Prop() showTextAsTooltip: boolean = false;\n\n /**\n * Legal number intervals\n *\n * {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#step}\n */\n @Prop() step: number = 1;\n\n /**\n * Minimum slider value\n */\n @Prop() min = 0;\n\n /**\n * Maximum slider value\n */\n @Prop() max = 100;\n\n /**\n * Current value of the slider\n */\n @Prop() value = 0;\n\n /**\n * Define tick marker on the slider. Marker has to be within slider min/max\n */\n @Prop() marker?: SliderMarker;\n\n /**\n * Show a trace line\n */\n @Prop() trace = false;\n\n /**\n * Define the start point of the trace line\n */\n @Prop() traceReference = 0;\n\n /**\n * Show control as disabled\n */\n @Prop() disabled = false;\n\n /**\n * Show error state and message\n *\n * @deprecated Will be removed in 5.0.0. Use invalid class instead.\n */\n @Prop() error?: boolean | string;\n\n /**\n * Will emit the value when it changes\n */\n @Event() valueChange!: EventEmitter<number>;\n\n @State() rangeInput = 0;\n @State() rangeMin = 0;\n @State() rangeMax = 100;\n @State() rangeTraceReference = 0;\n @State() showTooltip = false;\n @State() isInvalid = false;\n @State() isValid = false;\n @State() isInfo = false;\n @State() isWarning = false;\n\n private a11yAttributes?: A11yAttributes;\n private lastFormValue?: string;\n private touched = false;\n private readonly controlRef = makeRef<HTMLElement>();\n private readonly thumbRef = makeRef<HTMLDivElement>();\n private readonly tooltipRef = makeRef<HTMLIxTooltipElement>();\n\n private get hasLabels() {\n return !!this.hostElement.querySelector(\n '[slot=\"label-start\"], [slot=\"label-end\"]'\n );\n }\n\n get tooltip() {\n return this.tooltipRef.current;\n }\n\n get pseudoThumb() {\n return this.thumbRef.current;\n }\n\n get slider() {\n return this.hostElement.shadowRoot?.getElementById(\n 'slider'\n ) as HTMLInputElement;\n }\n\n @Watch('showTooltip')\n onShowTooltipChange() {\n if (this.showTooltip && this.pseudoThumb) {\n this.tooltip?.showTooltip(this.pseudoThumb);\n return;\n }\n\n this.tooltip?.hideTooltip();\n }\n\n @HookValidationLifecycle()\n onClassField({\n isInvalid,\n isInfo,\n isValid,\n isWarning,\n isInvalidByRequired,\n }: ValidationResults) {\n this.isInvalid = isInvalid || isInvalidByRequired;\n this.isInfo = isInfo;\n this.isValid = isValid;\n this.isWarning = isWarning;\n }\n\n componentWillLoad() {\n this.a11yAttributes = a11yHostAttributes(this.hostElement, [\n 'role',\n 'aria-valuemin',\n 'aria-valuemax',\n 'aria-valuenow',\n ]);\n this.updateRangeVariables();\n this.setFormValueIfChanged(this.value);\n }\n\n @Watch('value')\n @Watch('max')\n @Watch('min')\n @Watch('traceReference')\n private updateRangeVariables() {\n this.rangeInput = between(this.min, this.value, this.max);\n this.rangeTraceReference = between(this.min, this.traceReference, this.max);\n this.rangeMin = Math.min(this.min, this.max);\n this.rangeMax = Math.max(this.min, this.max);\n if (this.value !== undefined) {\n this.setFormValueIfChanged(this.value);\n }\n }\n\n private updateFormInternalValue(value: number) {\n this.setFormValueIfChanged(value);\n this.valueChange.emit(value);\n }\n\n private setFormValueIfChanged(value: number) {\n const valueStr = value.toString();\n if (this.lastFormValue !== valueStr) {\n this.formInternals.setFormValue(valueStr);\n this.lastFormValue = valueStr;\n }\n }\n\n private onInput(event: InputEvent) {\n event.stopPropagation();\n const value = parseFloat(this.slider.value);\n\n if (!isNaN(value)) {\n const oldValue = this.rangeInput;\n this.rangeInput = value;\n\n const { defaultPrevented } = this.emitInputEvent();\n\n if (defaultPrevented) {\n this.rangeInput = oldValue;\n this.slider.value = oldValue.toString();\n } else {\n this.updateFormInternalValue(value);\n }\n }\n }\n\n private emitInputEvent() {\n return this.valueChange.emit(this.rangeInput);\n }\n\n private isMarkerActive(markerValue: number) {\n const start = Math.min(this.traceReference, this.rangeInput);\n const end = Math.max(this.traceReference, this.rangeInput);\n const value = markerValue;\n\n return value >= start && value <= end;\n }\n\n // Listen globally on window because sometimes the event listener\n // of the DOM element input itself is not called if the release\n // click is not inside the element anymore\n @OnListener<Slider>('pointerup', (self) => self.showTooltip)\n onPointerUp() {\n this.showTooltip = false;\n }\n\n /** @internal */\n @Method()\n hasValidValue(): Promise<boolean> {\n return Promise.resolve(true);\n }\n\n /** @internal */\n @Method()\n isTouched(): Promise<boolean> {\n return Promise.resolve(this.touched);\n }\n\n render() {\n const range = this.rangeMax - this.rangeMin;\n\n let traceReferenceInPercentage =\n (this.rangeTraceReference - this.rangeMin) / range;\n\n let valueInPercentage = (this.rangeInput - this.rangeMin) / range;\n\n const distance = valueInPercentage - traceReferenceInPercentage;\n\n let traceStart = traceReferenceInPercentage;\n let traceEnd = valueInPercentage;\n\n if (distance <= 0) {\n traceStart = valueInPercentage;\n traceEnd = traceReferenceInPercentage;\n }\n\n return (\n <Host\n class={{\n disabled: this.disabled,\n error: !!this.error,\n invalid: this.isInvalid,\n info: this.isInfo,\n valid: this.isValid,\n warning: this.isWarning,\n }}\n onPointerDown={() => setTimeout(() => (this.showTooltip = true))}\n >\n <ix-field-wrapper\n label={this.label}\n helperText={this.helperText}\n invalidText={this.invalidText}\n infoText={this.infoText}\n warningText={this.warningText}\n validText={this.validText}\n showTextAsTooltip={this.showTextAsTooltip}\n isValid={this.isValid}\n isInfo={this.isInfo}\n isWarning={this.isWarning}\n isInvalid={this.isInvalid}\n controlRef={this.controlRef}\n >\n <div class=\"slider-container\">\n <div class=\"slider\">\n <div class=\"track\">\n <div\n ref={this.thumbRef}\n class=\"thumb\"\n style={{\n left: `calc(${valueInPercentage} * (100% - 1rem))`,\n }}\n ></div>\n <svg class=\"ticks\" xmlns=\"http://www.w3.org/2000/svg\">\n {this.marker\n ?.filter(\n (markerValue) =>\n markerValue >= this.min && markerValue <= this.max\n )\n .map((markerValue) => {\n const markerPosition =\n (markerValue - this.rangeMin) / range;\n\n return (\n <circle\n class={{\n tick: true,\n 'tick-active':\n this.isMarkerActive(markerValue) && this.trace,\n 'tick-at-min': markerPosition === 0,\n 'tick-at-max': markerPosition === 1,\n }}\n cx=\"0\"\n cy=\"0\"\n style={{\n '--tick-value': `${markerPosition}`,\n }}\n ></circle>\n );\n })}\n </svg>\n </div>\n\n <input\n id=\"slider\"\n ref={this.controlRef}\n type=\"range\"\n list={this.marker ? 'markers' : undefined}\n step={this.step}\n min={this.min}\n max={this.max}\n value={this.rangeInput}\n tabindex={this.disabled ? -1 : 0}\n onInput={(event) => this.onInput(event)}\n onFocus={() => {\n this.showTooltip = true;\n this.touched = true;\n }}\n onBlur={() => {\n this.showTooltip = false;\n }}\n style={{\n '--value': `${valueInPercentage}`,\n '--trace-reference': `${traceReferenceInPercentage}`,\n '--trace-start': `${traceStart}`,\n '--trace-end': `${traceEnd}`,\n }}\n class={{\n trace:\n this.trace &&\n traceReferenceInPercentage !== valueInPercentage,\n 'hide-trace-reference':\n this.trace &&\n (this.traceReference <= this.min ||\n this.traceReference >= this.max),\n }}\n role=\"slider\"\n aria-valuenow={this.rangeInput}\n aria-valuemin={this.min}\n aria-valuemax={this.max}\n {...this.a11yAttributes}\n />\n\n <ix-tooltip\n ref={this.tooltipRef}\n class={{\n 'hide-tooltip': !this.showTooltip,\n }}\n animationFrame={true}\n for={this.thumbRef.waitForCurrent()}\n >\n {this.rangeInput}\n </ix-tooltip>\n </div>\n {this.hasLabels && (\n <div class=\"label\">\n <div>\n <slot name=\"label-start\"></slot>\n </div>\n <div>\n <slot name=\"label-end\"></slot>\n </div>\n </div>\n )}\n {this.error ? (\n <ix-typography textColor=\"alarm\">{this.error}</ix-typography>\n ) : null}\n </div>\n </ix-field-wrapper>\n </Host>\n );\n }\n}\n"]}
@@ -23,7 +23,7 @@ export class Spinner {
23
23
  this.hideTrack = false;
24
24
  }
25
25
  render() {
26
- return (h(Host, { key: '6f99a58994e1eb03a05b6af195b843094ebea59b' }, h("div", { key: '01ff7d8f23eb80440970086c8791471623cfe424', class: {
26
+ return (h(Host, { key: '8aa6edb9059ebaafe7f052083ca680c2bc5df2cc' }, h("div", { key: 'ef628ecd03a1a6b3cdd36d90fb60676fc03fc90d', class: {
27
27
  primary: this.variant === 'primary',
28
28
  [this.size]: true,
29
29
  'hide-track': this.hideTrack,
@@ -6,8 +6,8 @@
6
6
  * This source code is licensed under the MIT license found in the
7
7
  * LICENSE file in the root directory of this source tree.
8
8
  */
9
- import { h, Host, } from "@stencil/core";
10
9
  import { iconContextMenu } from "@siemens/ix-icons/icons";
10
+ import { h, Host, } from "@stencil/core";
11
11
  import { makeRef } from "../utils/make-ref";
12
12
  export class SplitButton {
13
13
  constructor() {
@@ -39,6 +39,13 @@ export class SplitButton {
39
39
  * Placement of the dropdown
40
40
  */
41
41
  this.placement = 'bottom-start';
42
+ /**
43
+ * Enable Popover API rendering for dropdown.
44
+ *
45
+ * @default false
46
+ * @since 4.3.0
47
+ */
48
+ this.enableTopLayer = false;
42
49
  this.toggle = false;
43
50
  this.triggerElementRef = makeRef();
44
51
  }
@@ -58,7 +65,7 @@ export class SplitButton {
58
65
  'left-button-border': !hasOutline,
59
66
  } });
60
67
  const dropdownButtonAttributes = Object.assign(Object.assign({}, baseAttributes), { disabled: this.isDisabledIcon });
61
- return (h(Host, { key: '18955e55bbab4f5899f27cf2b38892c60bece302' }, h("div", { key: '8cc32b2686c3e02ee1f2a43d4a5f310cd2930dad', class: { 'btn-group': true, 'middle-gap': !hasOutline } }, this.label ? (h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }), this.label)) : (h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }))), h("ix-icon-button", Object.assign({ key: 'ae7a2875314967f3100d1abcef3528a9822b0503' }, dropdownButtonAttributes, { ref: this.triggerElementRef, class: 'anchor', icon: (_a = this.splitIcon) !== null && _a !== void 0 ? _a : iconContextMenu, "aria-label": this.ariaLabelSplitIconButton }))), h("ix-dropdown", { key: 'd81abc1f01f55f2bc85740898e7f59173e62e182', closeBehavior: this.closeBehavior, trigger: this.triggerElementRef.waitForCurrent() }, h("slot", { key: '19c2623131a8ab3799e5a9bb75cc356bf500fffd' }))));
68
+ return (h(Host, { key: '034329433940b847951719d6df094e7e799c9b2b' }, h("div", { key: 'e08144dd52c338d0cb3a271a95442709a4bd10ba', class: { 'btn-group': true, 'middle-gap': !hasOutline } }, this.label ? (h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }), this.label)) : (h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }))), h("ix-icon-button", Object.assign({ key: '4b7776b9328af463c873eb524e8808966b61fff1' }, dropdownButtonAttributes, { ref: this.triggerElementRef, class: 'anchor', icon: (_a = this.splitIcon) !== null && _a !== void 0 ? _a : iconContextMenu, "aria-label": this.ariaLabelSplitIconButton }))), h("ix-dropdown", { key: 'fbc53f2d73b27ed465a8dc4ae42357a61a6300c7', closeBehavior: this.closeBehavior, trigger: this.triggerElementRef.waitForCurrent(), enableTopLayer: this.enableTopLayer }, h("slot", { key: 'e776d44c8f78e89bed7f065edd55168563b0f23c' }))));
62
69
  }
63
70
  static get is() { return "ix-split-button"; }
64
71
  static get encapsulation() { return "shadow"; }
@@ -318,6 +325,32 @@ export class SplitButton {
318
325
  "setter": false,
319
326
  "reflect": false,
320
327
  "defaultValue": "'bottom-start'"
328
+ },
329
+ "enableTopLayer": {
330
+ "type": "boolean",
331
+ "attribute": "enable-top-layer",
332
+ "mutable": false,
333
+ "complexType": {
334
+ "original": "boolean",
335
+ "resolved": "boolean",
336
+ "references": {}
337
+ },
338
+ "required": false,
339
+ "optional": false,
340
+ "docs": {
341
+ "tags": [{
342
+ "name": "default",
343
+ "text": "false"
344
+ }, {
345
+ "name": "since",
346
+ "text": "4.3.0"
347
+ }],
348
+ "text": "Enable Popover API rendering for dropdown."
349
+ },
350
+ "getter": false,
351
+ "setter": false,
352
+ "reflect": false,
353
+ "defaultValue": "false"
321
354
  }
322
355
  };
323
356
  }
@@ -1 +1 @@
1
- {"version":3,"file":"split-button.js","sourceRoot":"","sources":["../../../src/components/split-button/split-button.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 State,\n} from '@stencil/core';\nimport { AlignedPlacement } from '../dropdown/placement';\nimport { iconContextMenu } from '@siemens/ix-icons/icons';\nimport { CloseBehavior } from '../dropdown/dropdown-controller';\nimport type { SplitButtonVariant } from './split-button.types';\nimport { makeRef } from '../utils/make-ref';\n\n@Component({\n tag: 'ix-split-button',\n styleUrl: 'split-button.scss',\n shadow: true,\n})\nexport class SplitButton {\n @Element() hostElement!: HTMLIxSplitButtonElement;\n\n /**\n * Color variant of button\n */\n @Prop() variant: SplitButtonVariant = 'primary';\n\n /**\n * Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.\n */\n @Prop() closeBehavior: CloseBehavior = 'both';\n\n /**\n * Button label\n */\n @Prop() label?: string;\n\n /**\n * ARIA label for the button (use if no label and icon button)\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelButton?: string;\n\n /**\n * Button icon\n */\n @Prop() icon?: string;\n\n /**\n * Icon of the button on the right\n */\n @Prop() splitIcon?: string;\n\n /**\n * ARIA label for the split icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelSplitIconButton?: string;\n\n /**\n * Disabled\n */\n @Prop() disabled = false;\n\n /**\n * Disables only the main button while keeping the dropdown trigger enabled\n *\n * @since 4.1.0\n */\n @Prop() disableButton = false;\n\n /**\n * Disables only the dropdown trigger while keeping the main button enabled\n *\n * @since 4.1.0\n */\n @Prop() disableDropdownButton = false;\n\n /**\n * Placement of the dropdown\n */\n @Prop() placement: AlignedPlacement = 'bottom-start';\n\n @State() toggle = false;\n\n /**\n * Button clicked\n */\n @Event() buttonClick!: EventEmitter<MouseEvent>;\n\n private readonly triggerElementRef = makeRef<HTMLElement>();\n\n private get isDisabledButton() {\n return this.disabled || this.disableButton;\n }\n\n private get isDisabledIcon() {\n return this.disabled || this.disableDropdownButton;\n }\n\n render() {\n const hasOutline = this.variant.toLocaleLowerCase().includes('secondary');\n const baseAttributes = {\n variant: this.variant,\n };\n\n const buttonAttributes = {\n ...baseAttributes,\n disabled: this.isDisabledButton,\n class: {\n 'left-button-border': !hasOutline,\n },\n };\n\n const dropdownButtonAttributes = {\n ...baseAttributes,\n disabled: this.isDisabledIcon,\n };\n\n return (\n <Host>\n <div class={{ 'btn-group': true, 'middle-gap': !hasOutline }}>\n {this.label ? (\n <ix-button\n {...buttonAttributes}\n icon={this.icon}\n onClick={(e) => this.buttonClick.emit(e)}\n aria-label={this.ariaLabelButton}\n >\n {this.label}\n </ix-button>\n ) : (\n <ix-icon-button\n {...buttonAttributes}\n icon={this.icon}\n onClick={(e) => this.buttonClick.emit(e)}\n aria-label={this.ariaLabelButton}\n ></ix-icon-button>\n )}\n <ix-icon-button\n {...dropdownButtonAttributes}\n ref={this.triggerElementRef}\n class={'anchor'}\n icon={this.splitIcon ?? iconContextMenu}\n aria-label={this.ariaLabelSplitIconButton}\n ></ix-icon-button>\n </div>\n\n <ix-dropdown\n closeBehavior={this.closeBehavior}\n trigger={this.triggerElementRef.waitForCurrent()}\n >\n <slot></slot>\n </ix-dropdown>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"split-button.js","sourceRoot":"","sources":["../../../src/components/split-button/split-button.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 { iconContextMenu } from '@siemens/ix-icons/icons';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n State,\n} from '@stencil/core';\nimport { CloseBehavior } from '../dropdown/dropdown-controller';\nimport { AlignedPlacement } from '../dropdown/placement';\nimport { makeRef } from '../utils/make-ref';\nimport type { SplitButtonVariant } from './split-button.types';\n\n@Component({\n tag: 'ix-split-button',\n styleUrl: 'split-button.scss',\n shadow: true,\n})\nexport class SplitButton {\n @Element() hostElement!: HTMLIxSplitButtonElement;\n\n /**\n * Color variant of button\n */\n @Prop() variant: SplitButtonVariant = 'primary';\n\n /**\n * Controls if the dropdown will be closed in response to a click event depending on the position of the event relative to the dropdown.\n */\n @Prop() closeBehavior: CloseBehavior = 'both';\n\n /**\n * Button label\n */\n @Prop() label?: string;\n\n /**\n * ARIA label for the button (use if no label and icon button)\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelButton?: string;\n\n /**\n * Button icon\n */\n @Prop() icon?: string;\n\n /**\n * Icon of the button on the right\n */\n @Prop() splitIcon?: string;\n\n /**\n * ARIA label for the split icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelSplitIconButton?: string;\n\n /**\n * Disabled\n */\n @Prop() disabled = false;\n\n /**\n * Disables only the main button while keeping the dropdown trigger enabled\n *\n * @since 4.1.0\n */\n @Prop() disableButton = false;\n\n /**\n * Disables only the dropdown trigger while keeping the main button enabled\n *\n * @since 4.1.0\n */\n @Prop() disableDropdownButton = false;\n\n /**\n * Placement of the dropdown\n */\n @Prop() placement: AlignedPlacement = 'bottom-start';\n\n /**\n * Enable Popover API rendering for dropdown.\n *\n * @default false\n * @since 4.3.0\n */\n @Prop() enableTopLayer: boolean = false;\n\n @State() toggle = false;\n\n /**\n * Button clicked\n */\n @Event() buttonClick!: EventEmitter<MouseEvent>;\n\n private readonly triggerElementRef = makeRef<HTMLElement>();\n\n private get isDisabledButton() {\n return this.disabled || this.disableButton;\n }\n\n private get isDisabledIcon() {\n return this.disabled || this.disableDropdownButton;\n }\n\n render() {\n const hasOutline = this.variant.toLocaleLowerCase().includes('secondary');\n const baseAttributes = {\n variant: this.variant,\n };\n\n const buttonAttributes = {\n ...baseAttributes,\n disabled: this.isDisabledButton,\n class: {\n 'left-button-border': !hasOutline,\n },\n };\n\n const dropdownButtonAttributes = {\n ...baseAttributes,\n disabled: this.isDisabledIcon,\n };\n\n return (\n <Host>\n <div class={{ 'btn-group': true, 'middle-gap': !hasOutline }}>\n {this.label ? (\n <ix-button\n {...buttonAttributes}\n icon={this.icon}\n onClick={(e) => this.buttonClick.emit(e)}\n aria-label={this.ariaLabelButton}\n >\n {this.label}\n </ix-button>\n ) : (\n <ix-icon-button\n {...buttonAttributes}\n icon={this.icon}\n onClick={(e) => this.buttonClick.emit(e)}\n aria-label={this.ariaLabelButton}\n ></ix-icon-button>\n )}\n <ix-icon-button\n {...dropdownButtonAttributes}\n ref={this.triggerElementRef}\n class={'anchor'}\n icon={this.splitIcon ?? iconContextMenu}\n aria-label={this.ariaLabelSplitIconButton}\n ></ix-icon-button>\n </div>\n\n <ix-dropdown\n closeBehavior={this.closeBehavior}\n trigger={this.triggerElementRef.waitForCurrent()}\n enableTopLayer={this.enableTopLayer}\n >\n <slot></slot>\n </ix-dropdown>\n </Host>\n );\n }\n}\n"]}
@@ -51,7 +51,7 @@ export class TabItem {
51
51
  };
52
52
  }
53
53
  render() {
54
- return (h(Host, { key: 'f703b9ed1db79ae154acd43425ac44993a13e99e', class: this.tabItemClasses({
54
+ return (h(Host, { key: 'f0e6c03c7624e9d8ae86223da810ca909e89ceb9', class: this.tabItemClasses({
55
55
  selected: this.selected,
56
56
  disabled: this.disabled,
57
57
  small: this.small,
@@ -68,12 +68,12 @@ export class TabItem {
68
68
  if (clientEvent.defaultPrevented) {
69
69
  event.stopPropagation();
70
70
  }
71
- } }, h("div", { key: '5d9f5fa0c5a9c2f057ff8e3e960a5b15499ec84b', class: {
71
+ } }, h("div", { key: '21b8861c7547865527d9395b1c288b358ca816c3', class: {
72
72
  circle: this.rounded,
73
73
  text: !this.rounded,
74
74
  selected: this.selected,
75
75
  disabled: this.disabled,
76
- } }, h("slot", { key: 'd0c87e92e0ad1a4664024b7d79900e8bb36a6ba6' })), h("div", { key: '1812905c3f08a70565e1aea166fa372a07344a76', class: {
76
+ } }, h("slot", { key: '4e268ef6667abfd1e2b4ea85b7a34819a16c188a' })), h("div", { key: '86633194654d3ab97aaa0c37fdf22b9f2ea6dd7c', class: {
77
77
  counter: true,
78
78
  selected: this.selected,
79
79
  hidden: !(this.rounded && this.counter !== undefined),
@@ -9,6 +9,18 @@
9
9
  import { h, Host, } from "@stencil/core";
10
10
  import { requestAnimationFrameNoNgZone } from "../utils/requestAnimationFrame";
11
11
  import { iconChevronLeftSmall, iconChevronRightSmall, } from "@siemens/ix-icons/icons";
12
+ const TAB_MANAGED_CLASSES = {
13
+ SELECTED: 'selected',
14
+ DISABLED: 'disabled',
15
+ SMALL_TAB: 'small-tab',
16
+ ICON: 'icon',
17
+ STRETCHED: 'stretched',
18
+ BOTTOM: 'bottom',
19
+ TOP: 'top',
20
+ CIRCLE: 'circle',
21
+ HYDRATED: 'hydrated',
22
+ };
23
+ const MANAGED_CLASSES_SET = new Set(Object.values(TAB_MANAGED_CLASSES));
12
24
  export class Tabs {
13
25
  constructor() {
14
26
  /**
@@ -38,6 +50,8 @@ export class Tabs {
38
50
  this.showArrowPrevious = false;
39
51
  this.showArrowNext = false;
40
52
  this.windowStartSize = window.innerWidth;
53
+ this.ARROW_WIDTH = 32;
54
+ this.updateScheduled = false;
41
55
  this.clickAction = {
42
56
  timeout: null,
43
57
  isClick: true,
@@ -61,6 +75,10 @@ export class Tabs {
61
75
  var _a;
62
76
  return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.items-content');
63
77
  }
78
+ getTabsContainer() {
79
+ var _a;
80
+ return (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.tab-items');
81
+ }
64
82
  initResizeObserver() {
65
83
  const parentElement = this.hostElement.parentElement;
66
84
  if (!parentElement)
@@ -70,6 +88,100 @@ export class Tabs {
70
88
  });
71
89
  this.resizeObserver.observe(parentElement);
72
90
  }
91
+ observeSlotChanges() {
92
+ var _a;
93
+ (_a = this.classObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
94
+ this.classObserver = new MutationObserver(() => {
95
+ this.scheduleTabUpdate();
96
+ });
97
+ this.classObserver.observe(this.hostElement, {
98
+ childList: true,
99
+ subtree: true,
100
+ attributes: true,
101
+ attributeFilter: ['class'],
102
+ });
103
+ }
104
+ scheduleTabUpdate() {
105
+ if (this.updateScheduled)
106
+ return;
107
+ this.updateScheduled = true;
108
+ requestAnimationFrame(() => {
109
+ this.updateTabAttributes();
110
+ this.updateScheduled = false;
111
+ });
112
+ }
113
+ setTabAttributes(element, index) {
114
+ const isSelected = index === this.selected;
115
+ const isDisabled = element.disabled;
116
+ if (this.small)
117
+ element.setAttribute('small', 'true');
118
+ if (this.rounded)
119
+ element.setAttribute('rounded', 'true');
120
+ element.setAttribute('layout', this.layout);
121
+ element.setAttribute('selected', isSelected.toString());
122
+ element.setAttribute('placement', this.placement);
123
+ element.toggleAttribute('disabled', isDisabled);
124
+ this.applyRequiredClasses(element, isSelected, isDisabled);
125
+ }
126
+ applyRequiredClasses(element, isSelected, isDisabled) {
127
+ const requiredClasses = new Set(this.buildRequiredClasses(isSelected, isDisabled));
128
+ const { classList } = element;
129
+ for (const cls of requiredClasses) {
130
+ classList.add(cls);
131
+ }
132
+ for (const managedClass of MANAGED_CLASSES_SET) {
133
+ if (!requiredClasses.has(managedClass)) {
134
+ classList.remove(managedClass);
135
+ }
136
+ }
137
+ }
138
+ buildRequiredClasses(isSelected, isDisabled) {
139
+ const classConditions = {
140
+ [TAB_MANAGED_CLASSES.HYDRATED]: true,
141
+ [TAB_MANAGED_CLASSES.SELECTED]: isSelected,
142
+ [TAB_MANAGED_CLASSES.DISABLED]: isDisabled,
143
+ [TAB_MANAGED_CLASSES.SMALL_TAB]: this.small,
144
+ [TAB_MANAGED_CLASSES.STRETCHED]: this.layout === 'stretched',
145
+ [TAB_MANAGED_CLASSES.BOTTOM]: this.placement === 'bottom',
146
+ [TAB_MANAGED_CLASSES.TOP]: this.placement === 'top',
147
+ [TAB_MANAGED_CLASSES.CIRCLE]: this.rounded,
148
+ };
149
+ return Object.entries(classConditions)
150
+ .filter(([, condition]) => condition)
151
+ .map(([className]) => className);
152
+ }
153
+ ensureSelectedIndex() {
154
+ if (this.totalItems === 0) {
155
+ console.warn('ix-tabs: No tabs available for selection');
156
+ this.selected = -1;
157
+ return;
158
+ }
159
+ if (this.selected < this.totalItems) {
160
+ return;
161
+ }
162
+ const originalIndex = this.selected;
163
+ const previousIndex = originalIndex - 1;
164
+ if (previousIndex >= 0 && previousIndex < this.totalItems) {
165
+ this.updateSelected(previousIndex);
166
+ return;
167
+ }
168
+ if (this.totalItems > 0) {
169
+ this.updateSelected(0);
170
+ }
171
+ }
172
+ updateSelected(index) {
173
+ this.selected = index;
174
+ this.selectedChange.emit(index);
175
+ }
176
+ updateTabAttributes() {
177
+ const tabs = this.getTabs();
178
+ this.totalItems = tabs.length;
179
+ this.ensureSelectedIndex();
180
+ for (const [index, element] of tabs.entries()) {
181
+ this.setTabAttributes(element, index);
182
+ }
183
+ this.renderArrows();
184
+ }
73
185
  showArrows() {
74
186
  try {
75
187
  const tabWrapper = this.getTabsWrapper();
@@ -128,17 +240,21 @@ export class Tabs {
128
240
  this.scrollActionAmount = amount;
129
241
  }
130
242
  onSelectedChange(newValue) {
131
- var _a;
132
243
  if (!this.showArrows())
133
244
  return;
134
- const tabRect = this.getTab(newValue).getBoundingClientRect();
135
- const wrapperWidth = (_a = this.getTabsWrapper()) === null || _a === void 0 ? void 0 : _a.clientWidth;
136
- const arrowWidth = 32;
137
- if (tabRect.left < arrowWidth) {
138
- this.move(-tabRect.left + arrowWidth, true);
245
+ const tab = this.getTab(newValue);
246
+ const container = this.getTabsContainer();
247
+ if (!tab || !container)
248
+ return;
249
+ const containerRect = container.getBoundingClientRect();
250
+ const tabRect = tab.getBoundingClientRect();
251
+ const tabLeftRelative = tabRect.left - containerRect.left;
252
+ const tabRightRelative = tabLeftRelative + tabRect.width;
253
+ if (tabLeftRelative < this.ARROW_WIDTH) {
254
+ this.move(-tabLeftRelative + this.ARROW_WIDTH, true);
139
255
  }
140
- else if (wrapperWidth && tabRect.right > wrapperWidth - arrowWidth) {
141
- this.move(wrapperWidth - tabRect.right - arrowWidth, true);
256
+ else if (tabRightRelative > containerRect.width - this.ARROW_WIDTH) {
257
+ this.move(containerRect.width - tabRightRelative - this.ARROW_WIDTH, true);
142
258
  }
143
259
  }
144
260
  setSelected(index) {
@@ -189,24 +305,10 @@ export class Tabs {
189
305
  return true;
190
306
  }
191
307
  componentWillLoad() {
192
- const tabs = this.getTabs();
193
- tabs.map((element, index) => {
194
- if (this.small)
195
- element.setAttribute('small', 'true');
196
- if (this.rounded)
197
- element.setAttribute('rounded', 'true');
198
- element.setAttribute('layout', this.layout);
199
- element.setAttribute('selected', index === this.selected ? 'true' : 'false');
200
- element.setAttribute('placement', this.placement);
201
- });
202
308
  this.initResizeObserver();
203
309
  }
204
310
  componentDidRender() {
205
- const tabs = this.getTabs();
206
- this.totalItems = tabs.length;
207
- tabs.map((element, index) => {
208
- element.setAttribute('selected', index === this.selected ? 'true' : 'false');
209
- });
311
+ this.updateTabAttributes();
210
312
  }
211
313
  componentWillRender() {
212
314
  this.renderArrows();
@@ -222,10 +324,12 @@ export class Tabs {
222
324
  tabs.forEach((element) => {
223
325
  element.addEventListener('mousedown', (event) => this.dragStart(element, event));
224
326
  });
327
+ this.observeSlotChanges();
225
328
  }
226
329
  disconnectedCallback() {
227
- var _a;
330
+ var _a, _b;
228
331
  (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
332
+ (_b = this.classObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
229
333
  }
230
334
  onTabClick(event) {
231
335
  if (event.defaultPrevented) {
@@ -240,13 +344,13 @@ export class Tabs {
240
344
  });
241
345
  }
242
346
  render() {
243
- return (h(Host, { key: 'd7fad8d23dafced6cf713108107c54d02f372b6b' }, this.showArrowPrevious && (h("button", { key: 'dde7a217502a5a157e32bb34327398dba8968d34', class: "arrow", onClick: () => this.move(this.scrollAmount, true), "aria-label": this.ariaLabelChevronLeftIconButton }, h("ix-icon", { key: '08c3d49892d6955a7877bac4968fac25fe8c9742', name: iconChevronLeftSmall }))), h("div", { key: 'deb8492643ab4b49cb7848c9229805d26b0a4c99', class: {
347
+ return (h(Host, { key: 'db27e336ea0432630306faa2e51f2799f1340d2c' }, this.showArrowPrevious && (h("button", { key: 'c9edd1bab0a829dd853a8dc227b59f068ea8b24a', class: "arrow", onClick: () => this.move(this.scrollAmount, true), "aria-label": this.ariaLabelChevronLeftIconButton }, h("ix-icon", { key: '6271e2d4ccbc8d94793b0226c7117c8f1a24561a', name: iconChevronLeftSmall }))), h("div", { key: 'd1ff277b75c488f25821296fc5a7320f822f1bbd', class: {
244
348
  'tab-items': true,
245
349
  'overflow-shadow': true,
246
350
  'shadow-left': this.showArrowPrevious,
247
351
  'shadow-right': this.showArrowNext,
248
352
  'shadow-both': this.showArrowNext && this.showArrowPrevious,
249
- } }, h("div", { key: '8b888d4ac1c0e957155028d8508e0cb5862c5cb4', class: "items-content" }, h("slot", { key: 'fd39c749b7aaeaec5c65ee72b0c466dbf7d8fa7b' }))), this.showArrowNext && (h("button", { key: '028b079e241b9fc3af1cba531ae2c055f1c47d32', class: "arrow right", onClick: () => this.move(-this.scrollAmount, true), "aria-label": this.ariaLabelChevronRightIconButton }, h("ix-icon", { key: '8047e16eadc4ec22f44d70004fe9a663f74c4e01', name: iconChevronRightSmall })))));
353
+ } }, h("div", { key: '9f929a8ba8f76c0efe8604218df1fe207eeff9ff', class: "items-content" }, h("slot", { key: 'a906661489fdee6484c871c7c7c46f0f1c5153fe' }))), this.showArrowNext && (h("button", { key: '632c5d16531fe4071368a94cdef569e43fd2ec71', class: "arrow right", onClick: () => this.move(-this.scrollAmount, true), "aria-label": this.ariaLabelChevronRightIconButton }, h("ix-icon", { key: '7105649d79c2a5a6d2c8fd3e6e9a0db540a61767', name: iconChevronRightSmall })))));
250
354
  }
251
355
  static get is() { return "ix-tabs"; }
252
356
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport { requestAnimationFrameNoNgZone } from '../utils/requestAnimationFrame';\nimport {\n iconChevronLeftSmall,\n iconChevronRightSmall,\n} from '@siemens/ix-icons/icons';\n\n@Component({\n tag: 'ix-tabs',\n styleUrl: 'tabs.scss',\n shadow: true,\n})\nexport class Tabs {\n @Element() hostElement!: HTMLIxTabsElement;\n\n /**\n * Set tab items to small size\n */\n @Prop() small = false;\n\n /**\n * Set rounded tabs\n */\n @Prop() rounded = false;\n\n /**\n * Set default selected tab by index\n */\n @Prop({ mutable: true }) selected = 0;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set placement style\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * ARIA label for the chevron left icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelChevronLeftIconButton?: string;\n\n /**\n * ARIA label for the chevron right icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelChevronRightIconButton?: string;\n\n /**\n * `selected` property changed\n */\n @Event() selectedChange!: EventEmitter<number>;\n\n @State() totalItems = 0;\n @State() currentScrollAmount = 0;\n @State() scrollAmount = 100;\n @State() scrollActionAmount = 0;\n @State() showArrowPrevious = false;\n @State() showArrowNext = false;\n\n private windowStartSize = window.innerWidth;\n private resizeObserver?: ResizeObserver;\n\n private clickAction: {\n timeout: NodeJS.Timeout | null;\n isClick: boolean;\n } = {\n timeout: null,\n isClick: true,\n };\n\n @Listen('resize', { target: 'window' })\n onWindowResize() {\n this.totalItems = 0;\n this.totalItems = this.getTabs().length;\n\n if (this.windowStartSize === 0)\n return (this.windowStartSize = window.innerWidth);\n this.move(this.windowStartSize - window.innerWidth);\n this.windowStartSize = window.innerWidth;\n }\n\n private getTabs() {\n return Array.from(this.hostElement.querySelectorAll('ix-tab-item'));\n }\n\n private getTab(tabIndex: number) {\n return this.getTabs()[tabIndex];\n }\n\n private getTabsWrapper() {\n return this.hostElement.shadowRoot?.querySelector('.items-content');\n }\n\n private initResizeObserver() {\n const parentElement = this.hostElement.parentElement;\n if (!parentElement) return;\n this.resizeObserver = new ResizeObserver(() => {\n this.renderArrows();\n });\n this.resizeObserver.observe(parentElement);\n }\n\n private showArrows() {\n try {\n const tabWrapper = this.getTabsWrapper();\n return (\n tabWrapper &&\n tabWrapper.scrollWidth >\n Math.ceil(tabWrapper.getBoundingClientRect().width) &&\n this.layout === 'auto'\n );\n } catch (error) {\n return false;\n }\n }\n\n private showPreviousArrow() {\n try {\n return this.showArrows() === true && this.scrollActionAmount < 0;\n } catch (error) {\n return false;\n }\n }\n\n private showNextArrow() {\n try {\n const tabWrapper = this.getTabsWrapper();\n\n if (!tabWrapper) {\n return false;\n }\n\n const tabWrapperRect = tabWrapper.getBoundingClientRect();\n\n return (\n this.showArrows() === true &&\n this.scrollActionAmount >\n (tabWrapper.scrollWidth - tabWrapperRect.width) * -1\n );\n } catch (error) {\n return false;\n }\n }\n\n private move(amount: number, click = false) {\n const tabsWrapper = this.getTabsWrapper();\n\n if (!tabsWrapper) {\n return;\n }\n\n const tabsWrapperVisibleWidth = tabsWrapper.getBoundingClientRect().width;\n const maxScrollWidth =\n -this.currentScrollAmount +\n tabsWrapperVisibleWidth -\n tabsWrapper.scrollWidth;\n\n amount = amount < maxScrollWidth ? maxScrollWidth : amount;\n amount += this.currentScrollAmount;\n amount = Math.min(amount, 0);\n\n const styles = [\n `transform: translateX(${amount}px);`,\n click ? 'transition: all ease-in-out 400ms;' : '',\n ].join('');\n\n tabsWrapper.setAttribute('style', styles);\n\n if (click) this.currentScrollAmount = this.scrollActionAmount = amount;\n else this.scrollActionAmount = amount;\n }\n\n @Watch('selected')\n onSelectedChange(newValue: number) {\n if (!this.showArrows()) return;\n\n const tabRect = this.getTab(newValue).getBoundingClientRect();\n const wrapperWidth = this.getTabsWrapper()?.clientWidth;\n const arrowWidth = 32;\n\n if (tabRect.left < arrowWidth) {\n this.move(-tabRect.left + arrowWidth, true);\n } else if (wrapperWidth && tabRect.right > wrapperWidth - arrowWidth) {\n this.move(wrapperWidth - tabRect.right - arrowWidth, true);\n }\n }\n\n private setSelected(index: number) {\n this.selected = index;\n }\n\n private clickTab(index: number) {\n if (!this.clickAction.isClick || this.dragStop()) {\n return;\n }\n\n const { defaultPrevented } = this.selectedChange.emit(index);\n if (defaultPrevented) {\n return;\n }\n\n this.setSelected(index);\n }\n\n private dragStart(element: HTMLIxTabItemElement, event: MouseEvent) {\n if (!this.showArrows()) return;\n if (event.button > 0) return;\n\n this.clickAction.timeout =\n this.clickAction.timeout === null\n ? setTimeout(() => (this.clickAction.isClick = false), 300)\n : null;\n\n const tabPositionX = parseFloat(window.getComputedStyle(element).left);\n const mousedownPositionX = event.clientX;\n const move = (event: MouseEvent) =>\n this.dragMove(event, tabPositionX, mousedownPositionX);\n const windowClick = () => {\n window.removeEventListener('mousemove', move, false);\n window.removeEventListener('click', windowClick, false);\n this.dragStop();\n };\n window.addEventListener('click', windowClick);\n window.addEventListener('mousemove', move, false);\n }\n\n private dragMove(event: MouseEvent, tabX: number, mousedownX: number) {\n this.move(event.clientX + tabX - mousedownX);\n }\n\n private dragStop() {\n if (this.clickAction.timeout) {\n clearTimeout(this.clickAction.timeout);\n this.clickAction.timeout = null;\n }\n\n if (this.clickAction.isClick) return false;\n\n this.currentScrollAmount = this.scrollActionAmount;\n this.clickAction.isClick = true;\n\n return true;\n }\n\n componentWillLoad() {\n const tabs = this.getTabs();\n\n tabs.map((element, index) => {\n if (this.small) element.setAttribute('small', 'true');\n\n if (this.rounded) element.setAttribute('rounded', 'true');\n\n element.setAttribute('layout', this.layout);\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n\n element.setAttribute('placement', this.placement);\n });\n\n this.initResizeObserver();\n }\n\n componentDidRender() {\n const tabs = this.getTabs();\n this.totalItems = tabs.length;\n\n tabs.map((element, index) => {\n element.setAttribute(\n 'selected',\n index === this.selected ? 'true' : 'false'\n );\n });\n }\n\n componentWillRender() {\n this.renderArrows();\n }\n\n private renderArrows() {\n requestAnimationFrameNoNgZone(() => {\n this.showArrowNext = this.showNextArrow();\n this.showArrowPrevious = this.showPreviousArrow();\n });\n }\n\n componentDidLoad() {\n const tabs = this.getTabs();\n tabs.forEach((element) => {\n element.addEventListener('mousedown', (event) =>\n this.dragStart(element, event)\n );\n });\n }\n\n disconnectedCallback() {\n this.resizeObserver?.disconnect();\n }\n\n @Listen('tabClick')\n onTabClick(event: CustomEvent) {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target;\n const tabs = this.getTabs();\n\n tabs.forEach((tab, index) => {\n if (!tab.disabled && tab === target) {\n this.clickTab(index);\n }\n });\n }\n\n render() {\n return (\n <Host>\n {this.showArrowPrevious && (\n <button\n class=\"arrow\"\n onClick={() => this.move(this.scrollAmount, true)}\n aria-label={this.ariaLabelChevronLeftIconButton}\n >\n <ix-icon name={iconChevronLeftSmall}></ix-icon>\n </button>\n )}\n <div\n class={{\n 'tab-items': true,\n 'overflow-shadow': true,\n 'shadow-left': this.showArrowPrevious,\n 'shadow-right': this.showArrowNext,\n 'shadow-both': this.showArrowNext && this.showArrowPrevious,\n }}\n >\n <div class=\"items-content\">\n <slot></slot>\n </div>\n </div>\n {this.showArrowNext && (\n <button\n class=\"arrow right\"\n onClick={() => this.move(-this.scrollAmount, true)}\n aria-label={this.ariaLabelChevronRightIconButton}\n >\n <ix-icon name={iconChevronRightSmall}></ix-icon>\n </button>\n )}\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Listen,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport { requestAnimationFrameNoNgZone } from '../utils/requestAnimationFrame';\nimport {\n iconChevronLeftSmall,\n iconChevronRightSmall,\n} from '@siemens/ix-icons/icons';\n\ntype ManagedClass =\n (typeof TAB_MANAGED_CLASSES)[keyof typeof TAB_MANAGED_CLASSES];\n\nconst TAB_MANAGED_CLASSES = {\n SELECTED: 'selected',\n DISABLED: 'disabled',\n SMALL_TAB: 'small-tab',\n ICON: 'icon',\n STRETCHED: 'stretched',\n BOTTOM: 'bottom',\n TOP: 'top',\n CIRCLE: 'circle',\n HYDRATED: 'hydrated',\n} as const;\n\nconst MANAGED_CLASSES_SET = new Set(\n Object.values(TAB_MANAGED_CLASSES) as ManagedClass[]\n);\n\n@Component({\n tag: 'ix-tabs',\n styleUrl: 'tabs.scss',\n shadow: true,\n})\nexport class Tabs {\n @Element() hostElement!: HTMLIxTabsElement;\n\n /**\n * Set tab items to small size\n */\n @Prop() small = false;\n\n /**\n * Set rounded tabs\n */\n @Prop() rounded = false;\n\n /**\n * Set default selected tab by index\n */\n @Prop({ mutable: true }) selected = 0;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set placement style\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * ARIA label for the chevron left icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelChevronLeftIconButton?: string;\n\n /**\n * ARIA label for the chevron right icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelChevronRightIconButton?: string;\n\n /**\n * `selected` property changed\n */\n @Event() selectedChange!: EventEmitter<number>;\n\n @State() totalItems = 0;\n @State() currentScrollAmount = 0;\n @State() scrollAmount = 100;\n @State() scrollActionAmount = 0;\n @State() showArrowPrevious = false;\n @State() showArrowNext = false;\n\n private windowStartSize = window.innerWidth;\n private resizeObserver?: ResizeObserver;\n private readonly ARROW_WIDTH = 32;\n private classObserver?: MutationObserver;\n private updateScheduled = false;\n\n private clickAction: {\n timeout: NodeJS.Timeout | null;\n isClick: boolean;\n } = {\n timeout: null,\n isClick: true,\n };\n\n @Listen('resize', { target: 'window' })\n onWindowResize() {\n this.totalItems = 0;\n this.totalItems = this.getTabs().length;\n\n if (this.windowStartSize === 0)\n return (this.windowStartSize = window.innerWidth);\n this.move(this.windowStartSize - window.innerWidth);\n this.windowStartSize = window.innerWidth;\n }\n\n private getTabs() {\n return Array.from(this.hostElement.querySelectorAll('ix-tab-item'));\n }\n\n private getTab(tabIndex: number) {\n return this.getTabs()[tabIndex];\n }\n\n private getTabsWrapper() {\n return this.hostElement.shadowRoot?.querySelector('.items-content');\n }\n\n private getTabsContainer() {\n return this.hostElement.shadowRoot?.querySelector('.tab-items');\n }\n\n private initResizeObserver() {\n const parentElement = this.hostElement.parentElement;\n if (!parentElement) return;\n this.resizeObserver = new ResizeObserver(() => {\n this.renderArrows();\n });\n this.resizeObserver.observe(parentElement);\n }\n\n private observeSlotChanges() {\n this.classObserver?.disconnect();\n\n this.classObserver = new MutationObserver(() => {\n this.scheduleTabUpdate();\n });\n\n this.classObserver.observe(this.hostElement, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['class'],\n });\n }\n\n private scheduleTabUpdate() {\n if (this.updateScheduled) return;\n this.updateScheduled = true;\n\n requestAnimationFrame(() => {\n this.updateTabAttributes();\n this.updateScheduled = false;\n });\n }\n\n private setTabAttributes(element: HTMLIxTabItemElement, index: number) {\n const isSelected = index === this.selected;\n const isDisabled = element.disabled;\n\n if (this.small) element.setAttribute('small', 'true');\n\n if (this.rounded) element.setAttribute('rounded', 'true');\n\n element.setAttribute('layout', this.layout);\n element.setAttribute('selected', isSelected.toString());\n element.setAttribute('placement', this.placement);\n element.toggleAttribute('disabled', isDisabled);\n\n this.applyRequiredClasses(element, isSelected, isDisabled);\n }\n\n private applyRequiredClasses(\n element: HTMLIxTabItemElement,\n isSelected: boolean,\n isDisabled: boolean\n ) {\n const requiredClasses = new Set(\n this.buildRequiredClasses(isSelected, isDisabled)\n );\n const { classList } = element;\n\n for (const cls of requiredClasses) {\n classList.add(cls);\n }\n\n for (const managedClass of MANAGED_CLASSES_SET) {\n if (!requiredClasses.has(managedClass)) {\n classList.remove(managedClass);\n }\n }\n }\n\n private buildRequiredClasses(\n isSelected: boolean,\n isDisabled: boolean\n ): string[] {\n const classConditions = {\n [TAB_MANAGED_CLASSES.HYDRATED]: true,\n [TAB_MANAGED_CLASSES.SELECTED]: isSelected,\n [TAB_MANAGED_CLASSES.DISABLED]: isDisabled,\n [TAB_MANAGED_CLASSES.SMALL_TAB]: this.small,\n [TAB_MANAGED_CLASSES.STRETCHED]: this.layout === 'stretched',\n [TAB_MANAGED_CLASSES.BOTTOM]: this.placement === 'bottom',\n [TAB_MANAGED_CLASSES.TOP]: this.placement === 'top',\n [TAB_MANAGED_CLASSES.CIRCLE]: this.rounded,\n };\n\n return Object.entries(classConditions)\n .filter(([, condition]) => condition)\n .map(([className]) => className);\n }\n\n private ensureSelectedIndex() {\n if (this.totalItems === 0) {\n console.warn('ix-tabs: No tabs available for selection');\n this.selected = -1;\n return;\n }\n\n if (this.selected < this.totalItems) {\n return;\n }\n\n const originalIndex = this.selected;\n const previousIndex = originalIndex - 1;\n\n if (previousIndex >= 0 && previousIndex < this.totalItems) {\n this.updateSelected(previousIndex);\n return;\n }\n\n if (this.totalItems > 0) {\n this.updateSelected(0);\n }\n }\n\n private updateSelected(index: number) {\n this.selected = index;\n this.selectedChange.emit(index);\n }\n\n private updateTabAttributes() {\n const tabs = this.getTabs();\n this.totalItems = tabs.length;\n\n this.ensureSelectedIndex();\n\n for (const [index, element] of tabs.entries()) {\n this.setTabAttributes(element, index);\n }\n\n this.renderArrows();\n }\n\n private showArrows() {\n try {\n const tabWrapper = this.getTabsWrapper();\n return (\n tabWrapper &&\n tabWrapper.scrollWidth >\n Math.ceil(tabWrapper.getBoundingClientRect().width) &&\n this.layout === 'auto'\n );\n } catch (error) {\n return false;\n }\n }\n\n private showPreviousArrow() {\n try {\n return this.showArrows() === true && this.scrollActionAmount < 0;\n } catch (error) {\n return false;\n }\n }\n\n private showNextArrow() {\n try {\n const tabWrapper = this.getTabsWrapper();\n\n if (!tabWrapper) {\n return false;\n }\n\n const tabWrapperRect = tabWrapper.getBoundingClientRect();\n\n return (\n this.showArrows() === true &&\n this.scrollActionAmount >\n (tabWrapper.scrollWidth - tabWrapperRect.width) * -1\n );\n } catch (error) {\n return false;\n }\n }\n\n private move(amount: number, click = false) {\n const tabsWrapper = this.getTabsWrapper();\n\n if (!tabsWrapper) {\n return;\n }\n\n const tabsWrapperVisibleWidth = tabsWrapper.getBoundingClientRect().width;\n const maxScrollWidth =\n -this.currentScrollAmount +\n tabsWrapperVisibleWidth -\n tabsWrapper.scrollWidth;\n\n amount = amount < maxScrollWidth ? maxScrollWidth : amount;\n amount += this.currentScrollAmount;\n amount = Math.min(amount, 0);\n\n const styles = [\n `transform: translateX(${amount}px);`,\n click ? 'transition: all ease-in-out 400ms;' : '',\n ].join('');\n\n tabsWrapper.setAttribute('style', styles);\n\n if (click) this.currentScrollAmount = this.scrollActionAmount = amount;\n else this.scrollActionAmount = amount;\n }\n\n @Watch('selected')\n onSelectedChange(newValue: number) {\n if (!this.showArrows()) return;\n\n const tab = this.getTab(newValue);\n const container = this.getTabsContainer();\n\n if (!tab || !container) return;\n\n const containerRect = container.getBoundingClientRect();\n const tabRect = tab.getBoundingClientRect();\n const tabLeftRelative = tabRect.left - containerRect.left;\n const tabRightRelative = tabLeftRelative + tabRect.width;\n\n if (tabLeftRelative < this.ARROW_WIDTH) {\n this.move(-tabLeftRelative + this.ARROW_WIDTH, true);\n } else if (tabRightRelative > containerRect.width - this.ARROW_WIDTH) {\n this.move(\n containerRect.width - tabRightRelative - this.ARROW_WIDTH,\n true\n );\n }\n }\n\n private setSelected(index: number) {\n this.selected = index;\n }\n\n private clickTab(index: number) {\n if (!this.clickAction.isClick || this.dragStop()) {\n return;\n }\n\n const { defaultPrevented } = this.selectedChange.emit(index);\n if (defaultPrevented) {\n return;\n }\n\n this.setSelected(index);\n }\n\n private dragStart(element: HTMLIxTabItemElement, event: MouseEvent) {\n if (!this.showArrows()) return;\n if (event.button > 0) return;\n\n this.clickAction.timeout =\n this.clickAction.timeout === null\n ? setTimeout(() => (this.clickAction.isClick = false), 300)\n : null;\n\n const tabPositionX = parseFloat(window.getComputedStyle(element).left);\n const mousedownPositionX = event.clientX;\n const move = (event: MouseEvent) =>\n this.dragMove(event, tabPositionX, mousedownPositionX);\n const windowClick = () => {\n window.removeEventListener('mousemove', move, false);\n window.removeEventListener('click', windowClick, false);\n this.dragStop();\n };\n window.addEventListener('click', windowClick);\n window.addEventListener('mousemove', move, false);\n }\n\n private dragMove(event: MouseEvent, tabX: number, mousedownX: number) {\n this.move(event.clientX + tabX - mousedownX);\n }\n\n private dragStop() {\n if (this.clickAction.timeout) {\n clearTimeout(this.clickAction.timeout);\n this.clickAction.timeout = null;\n }\n\n if (this.clickAction.isClick) return false;\n\n this.currentScrollAmount = this.scrollActionAmount;\n this.clickAction.isClick = true;\n\n return true;\n }\n\n componentWillLoad() {\n this.initResizeObserver();\n }\n\n componentDidRender() {\n this.updateTabAttributes();\n }\n\n componentWillRender() {\n this.renderArrows();\n }\n\n private renderArrows() {\n requestAnimationFrameNoNgZone(() => {\n this.showArrowNext = this.showNextArrow();\n this.showArrowPrevious = this.showPreviousArrow();\n });\n }\n\n componentDidLoad() {\n const tabs = this.getTabs();\n tabs.forEach((element) => {\n element.addEventListener('mousedown', (event) =>\n this.dragStart(element, event)\n );\n });\n\n this.observeSlotChanges();\n }\n\n disconnectedCallback() {\n this.resizeObserver?.disconnect();\n this.classObserver?.disconnect();\n }\n\n @Listen('tabClick')\n onTabClick(event: CustomEvent) {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target;\n const tabs = this.getTabs();\n\n tabs.forEach((tab, index) => {\n if (!tab.disabled && tab === target) {\n this.clickTab(index);\n }\n });\n }\n\n render() {\n return (\n <Host>\n {this.showArrowPrevious && (\n <button\n class=\"arrow\"\n onClick={() => this.move(this.scrollAmount, true)}\n aria-label={this.ariaLabelChevronLeftIconButton}\n >\n <ix-icon name={iconChevronLeftSmall}></ix-icon>\n </button>\n )}\n <div\n class={{\n 'tab-items': true,\n 'overflow-shadow': true,\n 'shadow-left': this.showArrowPrevious,\n 'shadow-right': this.showArrowNext,\n 'shadow-both': this.showArrowNext && this.showArrowPrevious,\n }}\n >\n <div class=\"items-content\">\n <slot></slot>\n </div>\n </div>\n {this.showArrowNext && (\n <button\n class=\"arrow right\"\n onClick={() => this.move(-this.scrollAmount, true)}\n aria-label={this.ariaLabelChevronRightIconButton}\n >\n <ix-icon name={iconChevronRightSmall}></ix-icon>\n </button>\n )}\n </Host>\n );\n }\n}\n"]}
@@ -23,17 +23,17 @@ export class Tile {
23
23
  this.hasFooterSlot = !!this.hostElement.querySelector('[slot="footer"]');
24
24
  }
25
25
  render() {
26
- return (h(Host, { key: 'f5c50da791dcbdfeb884d33071b6d557360c1a60', class: {
26
+ return (h(Host, { key: 'e1166a8b4e348942b7ed4258f88f8be64de05933', class: {
27
27
  'tile-small': this.size === 'small',
28
28
  'tile-medium': this.size === 'medium',
29
29
  'tile-big': this.size === 'big',
30
- } }, h("div", { key: '651e393dbd8f7f7cd55373c3bdadc195dfc88cbd', class: {
30
+ } }, h("div", { key: 'a6bd9158342ed546d51c55685afe3d75c2bf31b8', class: {
31
31
  'tile-header': true,
32
32
  'has-content': this.hasHeaderSlot,
33
- } }, h("slot", { key: '1b94a241077664e5bcb535321f816b3b3faa9fad', name: "header", onSlotchange: () => this.handleHeaderSlotChange() })), h("div", { key: 'd2ce3123c9ffa767e07edf25248567ee9406fc95', class: "tile-subheader" }, h("slot", { key: '025ac544a3750fbfb145d1350e7091e969c2e369', name: "subheader" })), h("div", { key: '6ce8df1e1b426df28b42f490db11dc1d951715e6', class: "tile-content" }, h("slot", { key: '7bb66b49df63f613c3b7be8ff0da64bc16dde6b9' })), h("div", { key: '55f6e978190c3c8581310559a7a46ec6c4cc0e2f', class: {
33
+ } }, h("slot", { key: 'c24c054f14e378dc126472b4086b4be4a245cbac', name: "header", onSlotchange: () => this.handleHeaderSlotChange() })), h("div", { key: '975744cdd6f42661636fc382a2f2e3c256ccdc9f', class: "tile-subheader" }, h("slot", { key: 'a867a5e2e3cb8958c819d5d936bf955cb51e808b', name: "subheader" })), h("div", { key: '8ab40a481b778384e6773a6318545e1d0001e669', class: "tile-content" }, h("slot", { key: 'c013dd68db8ce80c3b4cfac26acf9c690fcb2439' })), h("div", { key: '00b012d9f4bce4b623fc30b1f750f4319f4144f9', class: {
34
34
  'tile-footer': true,
35
35
  'has-content': this.hasFooterSlot,
36
- } }, h("slot", { key: 'd63334865e6a32a6bb082939b44f3bf0b041b93a', name: "footer", onSlotchange: () => this.handleFooterSlotChange() }))));
36
+ } }, h("slot", { key: 'fc565c7344dadeb70cf0002392a0ee98774843df', name: "footer", onSlotchange: () => this.handleFooterSlotChange() }))));
37
37
  }
38
38
  static get is() { return "ix-tile"; }
39
39
  static get encapsulation() { return "shadow"; }