@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
@@ -4,8 +4,9 @@ var index = require('./index-C8Xo8L1k.js');
4
4
  var a11y = require('./a11y-B_6chCvu.js');
5
5
  var listener = require('./listener-OBCpw0Y2.js');
6
6
  var makeRef = require('./make-ref-BaH6_YJk.js');
7
+ var validation = require('./validation-DTmSqO2d.js');
7
8
 
8
- const sliderCss = ":host{display:flex;flex-direction:column;min-height:2rem;--thumb-size:1rem;--value:0;--trace-start:0;--trace-end:0;--trace-reference:0;--trace-reference-color:var(--theme-slider-track-marker--background);--trace-color:var(--theme-slider-trace--background);--tick-color:var(--theme-slider-track-marker--background);--tick-color--active:var(--theme-slider-trace-marker--background);--track-color:var(--theme-slider-track--background)}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host input[type=range]{position:absolute;top:50%;transform:translateY(-50%);left:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;width:100%;height:1rem;margin:0}:host input[type=range].trace::before{content:\"\";position:absolute;display:block;z-index:-1;width:calc(7px + 100% * var(--trace-end) - 16px * var(--trace-end) - (7px + 100% * var(--trace-start) - 16px * var(--trace-start)));left:calc(7px + 100% * var(--trace-start) - 16px * var(--trace-start));height:4px;background-color:var(--trace-color);top:50%;transform:translateY(-50%)}:host input[type=range].trace:not(.hide-trace-reference)::after{content:\"\";position:absolute;display:block;width:2px;height:16px;background-color:var(--trace-reference-color);top:50%;transform:translateY(-50%);left:calc(7px + 100% * var(--trace-reference) - 16px * var(--trace-reference))}:host input[type=range]::-webkit-slider-runnable-track{background:transparent;height:0.25rem}:host input[type=range]::-moz-range-track{background:transparent;height:0.25rem}:host input[type=range i]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-6px}:host input[type=range i]::-moz-range-thumb{border:none;border-radius:0}:host input[type=range]::-webkit-slider-thumb{border-radius:100px;background-color:var(--theme-slider-thumb--background);height:var(--thumb-size);width:var(--thumb-size);-webkit-transition:all var(--theme-default-time) ease-in-out;transition:all var(--theme-default-time) ease-in-out;z-index:10}:host input[type=range]::-moz-range-thumb{border-radius:100px;background-color:var(--theme-slider-thumb--background);height:var(--thumb-size);width:var(--thumb-size);-moz-transition:all var(--theme-default-time) ease-in-out;transition:all var(--theme-default-time) ease-in-out;z-index:10}:host input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.2);background-color:var(--theme-slider-thumb--background--hover)}:host input[type=range]:hover::-moz-range-thumb{transform:scale(1.2);background-color:var(--theme-slider-thumb--background--hover)}:host input[type=range]:active::-webkit-slider-thumb{transform:scale(1.2);background-color:var(--theme-slider-thumb--background--active)}:host input[type=range]:active::-moz-range-thumb{transform:scale(1.2);background-color:var(--theme-slider-thumb--background--active)}:host input[type=range]:focus{outline:none}:host input[type=range]:focus-visible::-webkit-slider-thumb{outline:1px solid var(--theme-color-focus-bdr);outline-offset:0.125rem}:host input[type=range]:focus-visible::-moz-range-thumb{outline:1px solid var(--theme-color-focus-bdr);outline-offset:0.125rem}:host{}:host .ticks{display:flex;position:relative;top:50%;transform:translateY(-50%)}:host .ticks .tick{display:block;position:absolute;width:8px;height:8px;background-color:var(--tick-color);border-radius:100px;top:50%;transform:translateY(-50%);left:calc(var(--tick-value) * 100% - 4px)}:host .ticks .tick.tick-active{background-color:var(--tick-color--active)}:host .slider{position:relative;display:block;width:100%;height:1.5rem}:host .track{position:absolute;background-color:var(--track-color);height:4px;width:calc(100% - 1rem);margin-left:0.5rem;top:50%;transform:translateY(-50%);left:0px}:host .thumb{display:block;position:absolute;background-color:transparent;height:1rem;width:1rem;border-radius:100px;left:0px;top:50%;transform:translateY(-50%)}:host .hide-tooltip{display:none}:host .label{display:flex;position:relative;align-items:center;justify-content:space-between;width:100%;margin-top:0.5rem;min-height:0px}:host .label-start{margin-left:0.5rem}:host .label-end{margin-right:0.5rem}:host .label-error{margin-left:0.5rem}:host(.error){--trace-color:var(--theme-slider-trace--background--invalid);--tick-color--active:var(--theme-slider-trace-marker--background--invalid)}:host(.error) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid)}:host(.error) input[type=range]::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid)}:host(.error) input[type=range]:hover::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid--hover)}:host(.error) input[type=range]:hover::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid--hover)}:host(.error) input[type=range]:active::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid--active)}:host(.error) input[type=range]:active::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid--active)}:host(.disabled){pointer-events:none;--track-color:var(--theme-slider-track--background--disabled);--trace-color:var(--theme-slider-trace--background--disabled);--tick-color:var(--theme-slider-track-marker--background--disabled);--tick-color--active:var(--theme-slider-trace-marker--background--disabled)}:host(.disabled) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--disabled)}:host(.disabled) input[type=range]::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--disabled)}";
9
+ const sliderCss = ":host{display:flex;flex-direction:column;min-height:2rem;justify-content:center;--thumb-size:1rem;--value:0;--trace-start:0;--trace-end:0;--trace-reference:0;--trace-reference-color:var(--theme-slider-track-marker--background);--trace-color:var(--theme-slider-trace--background);--tick-color:var(--theme-slider-track-marker--background);--tick-color--active:var(--theme-slider-trace-marker--background);--track-color:var(--theme-slider-track--background)}:host *,:host *::after,:host *::before{box-sizing:border-box}:host ::-webkit-scrollbar-button{display:none}@-moz-document url-prefix(){:host *{scrollbar-color:var(--theme-scrollbar-thumb--background) var(--theme-scrollbar-track--background);scrollbar-width:thin}}:host{}:host ::-webkit-scrollbar{width:0.5rem;height:0.5rem}:host{}:host ::-webkit-scrollbar-track{border-radius:5px;background:var(--theme-scrollbar-track--background)}:host ::-webkit-scrollbar-track:hover{background:var(--theme-scrollbar-track--background--hover)}:host{}:host ::-webkit-scrollbar-thumb{border-radius:5px;background:var(--theme-scrollbar-thumb--background)}:host{}:host ::-webkit-scrollbar-thumb:hover{background:var(--theme-scrollbar-thumb--background--hover)}:host ::-webkit-scrollbar-corner{display:none}:host input[type=range]{position:absolute;top:50%;transform:translateY(-50%);left:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;width:100%;height:1.5rem;margin:0}:host input[type=range].trace::before{content:\"\";position:absolute;display:block;z-index:-1;width:calc((var(--trace-end) - var(--trace-start)) * 100%);left:calc(var(--trace-start) * 100%);height:4px;background-color:var(--trace-color);top:50%;transform:translateY(-50%);border-radius:clamp(0rem, (0.01 - var(--trace-start)) * 999rem, 0.125rem) clamp(0rem, (var(--trace-end) - 0.99) * 999rem, 0.125rem) clamp(0rem, (var(--trace-end) - 0.99) * 999rem, 0.125rem) clamp(0rem, (0.01 - var(--trace-start)) * 999rem, 0.125rem)}:host .slider-container{width:100%}:host .slider-container .slider{width:100%}:host .slider-container .slider input[type=range]{width:100%}:host input[type=range].trace:not(.hide-trace-reference)::after{content:\"\";position:absolute;display:block;width:2px;height:16px;background-color:var(--trace-reference-color);top:50%;transform:translateY(-50%);left:calc(100% * var(--trace-reference))}:host input[type=range]::-webkit-slider-runnable-track{background:transparent;height:0.25rem}:host input[type=range]::-moz-range-track{background:transparent;height:0.25rem}:host input[type=range i]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-6px}:host input[type=range i]::-moz-range-thumb{border:none;border-radius:0}:host input[type=range]::-webkit-slider-thumb{border-radius:50%;background-color:var(--theme-slider-thumb--background);height:var(--thumb-size);width:var(--thumb-size);-webkit-transition:all var(--theme-default-time) ease-in-out;transition:all var(--theme-default-time) ease-in-out;z-index:10}:host input[type=range]::-moz-range-thumb{border-radius:50%;background-color:var(--theme-slider-thumb--background);height:var(--thumb-size);width:var(--thumb-size);-moz-transition:all var(--theme-default-time) ease-in-out;transition:all var(--theme-default-time) ease-in-out;z-index:10}:host input[type=range]:hover::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--hover)}:host input[type=range]:hover::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--hover)}:host input[type=range]:active::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--active)}:host input[type=range]:active::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--active)}:host input[type=range]:focus{outline:none}:host input[type=range]:focus-visible::-webkit-slider-thumb{outline:1px solid var(--theme-color-focus-bdr);outline-offset:0.125rem}:host input[type=range]:focus-visible::-moz-range-thumb{outline:1px solid var(--theme-color-focus-bdr);outline-offset:0.125rem}:host{}:host .ticks{position:absolute;top:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none}:host .ticks circle.tick{--tick-size:6px;--tick-radius:calc(var(--tick-size) / 2);r:var(--tick-radius);fill:var(--tick-color);transform:translate(calc(var(--tick-value) * (100% - var(--thumb-size)) + var(--thumb-size) / 2), 50%)}:host .ticks .tick.tick-at-min{transform:translate(var(--tick-radius), 50%)}:host .ticks .tick.tick-at-max{transform:translate(calc(100% - var(--tick-radius)), 50%)}:host .ticks .tick.tick-active{fill:var(--tick-color--active)}:host .slider{position:relative;display:block;width:100%;height:1.5rem}:host .track{position:absolute;background-color:var(--track-color);height:4px;width:100%;top:50%;transform:translateY(-50%);left:0px;border-radius:2px}:host .thumb{display:block;position:absolute;background-color:transparent;height:1rem;width:1rem;border-radius:100px;top:50%;transform:translateY(-50%)}:host .hide-tooltip{display:none}:host .label{display:flex;position:relative;align-items:center;justify-content:space-between;width:100%;margin-top:0.5rem;min-height:0px}:host(.error),:host(.invalid){--trace-color:var(--theme-slider-trace--background--invalid);--tick-color--active:var(--theme-slider-trace-marker--background--invalid)}:host(.error) input[type=range]::-webkit-slider-thumb,:host(.invalid) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid)}:host(.error) input[type=range]::-moz-range-thumb,:host(.invalid) input[type=range]::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid)}:host(.error) input[type=range]:hover::-webkit-slider-thumb,:host(.invalid) input[type=range]:hover::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid--hover)}:host(.error) input[type=range]:hover::-moz-range-thumb,:host(.invalid) input[type=range]:hover::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid--hover)}:host(.error) input[type=range]:active::-webkit-slider-thumb,:host(.invalid) input[type=range]:active::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--invalid--active)}:host(.error) input[type=range]:active::-moz-range-thumb,:host(.invalid) input[type=range]:active::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--invalid--active)}:host(.disabled){pointer-events:none;--track-color:var(--theme-slider-track--background--disabled);--trace-color:var(--theme-slider-trace--background--disabled);--tick-color:var(--theme-slider-track-marker--background--disabled);--tick-color--active:var(--theme-slider-trace-marker--background--disabled)}:host(.disabled) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-slider-thumb--background--disabled)}:host(.disabled) input[type=range]::-moz-range-thumb{background-color:var(--theme-slider-thumb--background--disabled)}:host(.warning){--trace-color:var(--theme-color-warning-40);--tick-color--active:var(--theme-color-warning)}:host(.warning) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-color-warning)}:host(.warning) input[type=range]::-moz-range-thumb{background-color:var(--theme-color-warning)}:host(.info){--trace-color:var(--theme-color-info-40);--tick-color--active:var(--theme-color-info)}:host(.info) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-color-info)}:host(.info) input[type=range]::-moz-range-thumb{background-color:var(--theme-color-info)}:host(.valid){--trace-color:var(--theme-color-success-40);--tick-color--active:var(--theme-color-success)}:host(.valid) input[type=range]::-webkit-slider-thumb{background-color:var(--theme-color-success)}:host(.valid) input[type=range]::-moz-range-thumb{background-color:var(--theme-color-success)}";
9
10
 
10
11
  /*
11
12
  * SPDX-FileCopyrightText: 2023 Siemens AG
@@ -40,6 +41,18 @@ const Slider = class {
40
41
  constructor(hostRef) {
41
42
  index.registerInstance(this, hostRef);
42
43
  this.valueChange = index.createEvent(this, "valueChange", 7);
44
+ if (hostRef.$hostElement$["s-ei"]) {
45
+ this.formInternals = hostRef.$hostElement$["s-ei"];
46
+ }
47
+ else {
48
+ this.formInternals = hostRef.$hostElement$.attachInternals();
49
+ hostRef.$hostElement$["s-ei"] = this.formInternals;
50
+ }
51
+ /**
52
+ * Show helper, info, warning, error and valid text as tooltip
53
+ * @since 4.3.0
54
+ */
55
+ this.showTextAsTooltip = false;
43
56
  /**
44
57
  * Legal number intervals
45
58
  *
@@ -75,9 +88,18 @@ const Slider = class {
75
88
  this.rangeMax = 100;
76
89
  this.rangeTraceReference = 0;
77
90
  this.showTooltip = false;
91
+ this.isInvalid = false;
92
+ this.isValid = false;
93
+ this.isInfo = false;
94
+ this.isWarning = false;
95
+ this.touched = false;
96
+ this.controlRef = makeRef.makeRef();
78
97
  this.thumbRef = makeRef.makeRef();
79
98
  this.tooltipRef = makeRef.makeRef();
80
99
  }
100
+ get hasLabels() {
101
+ return !!this.hostElement.querySelector('[slot="label-start"], [slot="label-end"]');
102
+ }
81
103
  get tooltip() {
82
104
  return this.tooltipRef.current;
83
105
  }
@@ -96,6 +118,12 @@ const Slider = class {
96
118
  }
97
119
  (_b = this.tooltip) === null || _b === void 0 ? void 0 : _b.hideTooltip();
98
120
  }
121
+ onClassField({ isInvalid, isInfo, isValid, isWarning, isInvalidByRequired, }) {
122
+ this.isInvalid = isInvalid || isInvalidByRequired;
123
+ this.isInfo = isInfo;
124
+ this.isValid = isValid;
125
+ this.isWarning = isWarning;
126
+ }
99
127
  componentWillLoad() {
100
128
  this.a11yAttributes = a11y.a11yHostAttributes(this.hostElement, [
101
129
  'role',
@@ -104,12 +132,27 @@ const Slider = class {
104
132
  'aria-valuenow',
105
133
  ]);
106
134
  this.updateRangeVariables();
135
+ this.setFormValueIfChanged(this.value);
107
136
  }
108
137
  updateRangeVariables() {
109
138
  this.rangeInput = between(this.min, this.value, this.max);
110
139
  this.rangeTraceReference = between(this.min, this.traceReference, this.max);
111
140
  this.rangeMin = Math.min(this.min, this.max);
112
141
  this.rangeMax = Math.max(this.min, this.max);
142
+ if (this.value !== undefined) {
143
+ this.setFormValueIfChanged(this.value);
144
+ }
145
+ }
146
+ updateFormInternalValue(value) {
147
+ this.setFormValueIfChanged(value);
148
+ this.valueChange.emit(value);
149
+ }
150
+ setFormValueIfChanged(value) {
151
+ const valueStr = value.toString();
152
+ if (this.lastFormValue !== valueStr) {
153
+ this.formInternals.setFormValue(valueStr);
154
+ this.lastFormValue = valueStr;
155
+ }
113
156
  }
114
157
  onInput(event) {
115
158
  event.stopPropagation();
@@ -122,6 +165,9 @@ const Slider = class {
122
165
  this.rangeInput = oldValue;
123
166
  this.slider.value = oldValue.toString();
124
167
  }
168
+ else {
169
+ this.updateFormInternalValue(value);
170
+ }
125
171
  }
126
172
  }
127
173
  emitInputEvent() {
@@ -139,7 +185,16 @@ const Slider = class {
139
185
  onPointerUp() {
140
186
  this.showTooltip = false;
141
187
  }
188
+ /** @internal */
189
+ hasValidValue() {
190
+ return Promise.resolve(true);
191
+ }
192
+ /** @internal */
193
+ isTouched() {
194
+ return Promise.resolve(this.touched);
195
+ }
142
196
  render() {
197
+ var _a;
143
198
  const range = this.rangeMax - this.rangeMin;
144
199
  let traceReferenceInPercentage = (this.rangeTraceReference - this.rangeMin) / range;
145
200
  let valueInPercentage = (this.rangeInput - this.rangeMin) / range;
@@ -150,42 +205,46 @@ const Slider = class {
150
205
  traceStart = valueInPercentage;
151
206
  traceEnd = traceReferenceInPercentage;
152
207
  }
153
- return (index.h(index.Host, { key: '03faa36448299850133ed4e7c1dbfd5f7a28a91b', class: {
208
+ return (index.h(index.Host, { key: 'dcce2da89192816ddc61f9f1950a399ebdf53766', class: {
154
209
  disabled: this.disabled,
155
210
  error: !!this.error,
156
- }, onPointerDown: () => setTimeout(() => (this.showTooltip = true)) }, index.h("div", { key: '686f462a50a42a4a29a20d22d3637af74a3799ae', class: "slider" }, index.h("div", { key: '8ef5374cd9e421bb2265b1c0b0b7f2c1f2ecf6ff', class: "track" }, index.h("div", { key: '969da1a4f687d3a254c3353fa0f36ee5ce61130a', ref: this.thumbRef, class: "thumb", style: {
157
- left: `calc(${valueInPercentage} * 100% - 8px)`,
158
- } }), index.h("div", { key: '7daba2cb0cf28c3d4b130eeebedae72827109cea', class: "ticks" }, this.marker
159
- ? this.marker.map((markerValue) => {
160
- if (markerValue > this.max || markerValue < this.min) {
161
- return;
162
- }
163
- let left = (markerValue - this.rangeMin) / range;
164
- return (index.h("div", { class: {
165
- tick: true,
166
- 'tick-active': this.isMarkerActive(markerValue) && this.trace,
167
- }, style: {
168
- '--tick-value': `${left}`,
169
- } }));
170
- })
171
- : null)), index.h("input", Object.assign({ key: '2bcc70bf378b44230c3dc7223e6f24707a6a3265', id: "slider", type: "range", list: this.marker ? 'markers' : undefined, step: this.step, min: this.min, max: this.max, value: this.rangeInput, tabindex: this.disabled ? -1 : 0, onInput: (event) => this.onInput(event), style: {
211
+ invalid: this.isInvalid,
212
+ info: this.isInfo,
213
+ valid: this.isValid,
214
+ warning: this.isWarning,
215
+ }, onPointerDown: () => setTimeout(() => (this.showTooltip = true)) }, index.h("ix-field-wrapper", { key: 'a3ce51bbc6f18cfbc99c3ef821016c6421217ffe', label: this.label, helperText: this.helperText, invalidText: this.invalidText, infoText: this.infoText, warningText: this.warningText, validText: this.validText, showTextAsTooltip: this.showTextAsTooltip, isValid: this.isValid, isInfo: this.isInfo, isWarning: this.isWarning, isInvalid: this.isInvalid, controlRef: this.controlRef }, index.h("div", { key: '602a467d24592696b8f5ebaf13f1b7d5e3451e38', class: "slider-container" }, index.h("div", { key: 'b9ded80de026dfc23f6892ef5fab71bcf9444011', class: "slider" }, index.h("div", { key: '78472ae8734b51390efeac850ffe2400e8fd67be', class: "track" }, index.h("div", { key: '0183018c9421d77caa857d6e8ff83dce0b7714f1', ref: this.thumbRef, class: "thumb", style: {
216
+ left: `calc(${valueInPercentage} * (100% - 1rem))`,
217
+ } }), index.h("svg", { key: '3a43071be5fb88e7ae8d0f8abd34f7cef203fb54', class: "ticks", xmlns: "http://www.w3.org/2000/svg" }, (_a = this.marker) === null || _a === void 0 ? void 0 : _a.filter((markerValue) => markerValue >= this.min && markerValue <= this.max).map((markerValue) => {
218
+ const markerPosition = (markerValue - this.rangeMin) / range;
219
+ return (index.h("circle", { class: {
220
+ tick: true,
221
+ 'tick-active': this.isMarkerActive(markerValue) && this.trace,
222
+ 'tick-at-min': markerPosition === 0,
223
+ 'tick-at-max': markerPosition === 1,
224
+ }, cx: "0", cy: "0", style: {
225
+ '--tick-value': `${markerPosition}`,
226
+ } }));
227
+ }))), index.h("input", Object.assign({ key: '1f1304342e72682bc040994e96297a31a61f4d00', id: "slider", ref: this.controlRef, type: "range", list: this.marker ? 'markers' : undefined, step: this.step, min: this.min, max: this.max, value: this.rangeInput, tabindex: this.disabled ? -1 : 0, onInput: (event) => this.onInput(event), onFocus: () => {
228
+ this.showTooltip = true;
229
+ this.touched = true;
230
+ }, onBlur: () => {
231
+ this.showTooltip = false;
232
+ }, style: {
172
233
  '--value': `${valueInPercentage}`,
173
234
  '--trace-reference': `${traceReferenceInPercentage}`,
174
235
  '--trace-start': `${traceStart}`,
175
236
  '--trace-end': `${traceEnd}`,
176
237
  }, class: {
177
- trace: this.trace && traceReferenceInPercentage !== valueInPercentage,
238
+ trace: this.trace &&
239
+ traceReferenceInPercentage !== valueInPercentage,
178
240
  'hide-trace-reference': this.trace &&
179
241
  (this.traceReference <= this.min ||
180
242
  this.traceReference >= this.max),
181
- }, onFocus: () => {
182
- this.showTooltip = true;
183
- }, onBlur: () => {
184
- this.showTooltip = false;
185
- }, role: "slider", "aria-valuenow": this.rangeInput, "aria-valuemin": this.min, "aria-valuemax": this.max }, this.a11yAttributes)), index.h("ix-tooltip", { key: 'c887ce7b3d18a92de4cf359fb9f8706393a82529', ref: this.tooltipRef, class: {
243
+ }, role: "slider", "aria-valuenow": this.rangeInput, "aria-valuemin": this.min, "aria-valuemax": this.max }, this.a11yAttributes)), index.h("ix-tooltip", { key: 'e0c3c6b098a2112cbcc27a90a8cdb696148109dc', ref: this.tooltipRef, class: {
186
244
  'hide-tooltip': !this.showTooltip,
187
- }, animationFrame: true, for: this.thumbRef.waitForCurrent() }, this.rangeInput)), index.h("div", { key: '8de8c23aa94fc924842631eb4d312efc5ee7cc6f', class: "label" }, index.h("div", { key: '402d7e1bd4bdd648e361b88f211d7d80e5c907b3', class: "label-start" }, index.h("slot", { key: 'f9a3a0ecc744b3ab91dda8d425309ce78c57e1f1', name: "label-start" })), index.h("div", { key: '188c06d13b00c0124603b6a0513cfa24e5467b62', class: "label-end" }, index.h("slot", { key: 'cc4e9bd389f10ab7e293a80844012877070b2750', name: "label-end" }))), this.error ? (index.h("ix-typography", { class: 'label-error', textColor: "alarm" }, this.error)) : null));
245
+ }, animationFrame: true, for: this.thumbRef.waitForCurrent() }, this.rangeInput)), this.hasLabels && (index.h("div", { key: '0a04945ac1055fbcd7e4b05b1188071e5e58180b', class: "label" }, index.h("div", { key: 'e1d1f0963b6e56947afeb9e371c1404b9b0fb819' }, index.h("slot", { key: '16e408212c6193e840f399343cfe2d3a8e260e30', name: "label-start" })), index.h("div", { key: '569530a9d3f987a0993ea8f79709b5f2252e0956' }, index.h("slot", { key: 'aba45e17633571d07a3dc95d46502dd6ebdc0aae', name: "label-end" })))), this.error ? (index.h("ix-typography", { textColor: "alarm" }, this.error)) : null))));
188
246
  }
247
+ static get formAssociated() { return true; }
189
248
  get hostElement() { return index.getElement(this); }
190
249
  static get watchers() { return {
191
250
  "showTooltip": ["onShowTooltipChange"],
@@ -195,6 +254,9 @@ const Slider = class {
195
254
  "traceReference": ["updateRangeVariables"]
196
255
  }; }
197
256
  };
257
+ __decorate([
258
+ validation.HookValidationLifecycle()
259
+ ], Slider.prototype, "onClassField", null);
198
260
  __decorate([
199
261
  listener.OnListener('pointerup', (self) => self.showTooltip)
200
262
  ], Slider.prototype, "onPointerUp", null);
@@ -1 +1 @@
1
- {"version":3,"file":"ix-slider.entry.cjs.js","sources":["src/components/slider/slider.scss?tag=ix-slider&encapsulation=shadow","src/components/slider/slider.tsx"],"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@use 'mixins/shadow-dom/component';\n\n@mixin track {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']::-webkit-slider-runnable-track {\n @content;\n }\n\n // Firefox\n input[type='range']::-moz-range-track {\n @content;\n }\n}\n\n@mixin clear-browser-thumb {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range' i]::-webkit-slider-thumb {\n -webkit-appearance: none;\n appearance: none;\n margin-top: -6px;\n }\n\n // Firefox\n input[type='range' i]::-moz-range-thumb {\n border: none;\n border-radius: 0;\n }\n}\n\n@mixin thumb {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-hover {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:hover::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:hover::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-active {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:active::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:active::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-focus {\n input[type='range']:focus {\n outline: none;\n }\n\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:focus-visible::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:focus-visible::-moz-range-thumb {\n @content;\n }\n}\n\n:host {\n display: flex;\n flex-direction: column;\n min-height: 2rem;\n\n // Slider specific calculations\n --thumb-size: 1rem;\n --value: 0;\n --trace-start: 0;\n --trace-end: 0;\n --trace-reference: 0;\n\n // Theme colors:\n --trace-reference-color: var(--theme-slider-track-marker--background);\n --trace-color: var(--theme-slider-trace--background);\n --tick-color: var(--theme-slider-track-marker--background);\n --tick-color--active: var(--theme-slider-trace-marker--background);\n --track-color: var(--theme-slider-track--background);\n\n @include component.ix-component;\n\n input[type='range'] {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n left: 0;\n appearance: none;\n background: transparent;\n cursor: pointer;\n width: 100%;\n height: 1rem;\n margin: 0;\n }\n\n // Trace line\n input[type='range'].trace::before {\n content: '';\n position: absolute;\n display: block;\n z-index: -1;\n\n width: calc(\n calc(7px + calc(100% * var(--trace-end)) - calc(16px * var(--trace-end))) -\n calc(\n 7px + calc(100% * var(--trace-start)) -\n calc(16px * var(--trace-start))\n )\n );\n\n left: calc(\n 7px + calc(100% * var(--trace-start)) - calc(16px * var(--trace-start))\n );\n\n height: 4px;\n background-color: var(--trace-color);\n top: 50%;\n transform: translateY(-50%);\n }\n\n // Trace reference\n input[type='range'].trace:not(.hide-trace-reference)::after {\n content: '';\n position: absolute;\n display: block;\n width: 2px;\n height: 16px;\n background-color: var(--trace-reference-color);\n top: 50%;\n transform: translateY(-50%);\n left: calc(\n 7px + calc(100% * var(--trace-reference)) -\n calc(16px * var(--trace-reference))\n );\n }\n\n @include track() {\n background: transparent;\n height: 0.25rem;\n }\n\n @include clear-browser-thumb();\n\n @include thumb() {\n border-radius: 100px;\n background-color: var(--theme-slider-thumb--background);\n height: var(--thumb-size);\n width: var(--thumb-size);\n transition: all var(--theme-default-time) ease-in-out;\n z-index: 10;\n }\n\n @include thumb-hover() {\n transform: scale(1.2);\n background-color: var(--theme-slider-thumb--background--hover);\n }\n\n @include thumb-active() {\n transform: scale(1.2);\n\n background-color: var(--theme-slider-thumb--background--active);\n }\n\n @include thumb-focus() {\n outline: 1px solid var(--theme-color-focus-bdr);\n outline-offset: 0.125rem;\n }\n\n /* style datalist */\n .ticks {\n display: flex;\n position: relative;\n top: 50%;\n transform: translateY(-50%);\n }\n .ticks .tick {\n display: block;\n position: absolute;\n width: 8px;\n height: 8px;\n background-color: var(--tick-color);\n border-radius: 100px;\n top: 50%;\n transform: translateY(-50%);\n left: calc(var(--tick-value) * 100% - 4px);\n }\n\n .ticks .tick.tick-active {\n background-color: var(--tick-color--active);\n }\n\n .slider {\n position: relative;\n display: block;\n width: 100%;\n height: 1.5rem;\n }\n\n .track {\n position: absolute;\n background-color: var(--track-color);\n height: 4px;\n width: calc(100% - 1rem);\n margin-left: 0.5rem;\n top: 50%;\n transform: translateY(-50%);\n left: 0px;\n }\n\n .thumb {\n display: block;\n position: absolute;\n background-color: transparent;\n height: 1rem;\n width: 1rem;\n border-radius: 100px;\n left: 0px;\n top: 50%;\n transform: translateY(-50%);\n }\n\n .hide-tooltip {\n display: none;\n }\n\n .label {\n display: flex;\n position: relative;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n margin-top: 0.5rem;\n\n min-height: 0px;\n }\n\n .label-start {\n margin-left: 0.5rem;\n }\n\n .label-end {\n margin-right: 0.5rem;\n }\n\n .label-error {\n margin-left: 0.5rem;\n }\n}\n\n:host(.error) {\n --trace-color: var(--theme-slider-trace--background--invalid);\n --tick-color--active: var(--theme-slider-trace-marker--background--invalid);\n\n @include thumb {\n background-color: var(--theme-slider-thumb--background--invalid);\n }\n\n @include thumb-hover() {\n background-color: var(--theme-slider-thumb--background--invalid--hover);\n }\n\n @include thumb-active() {\n background-color: var(--theme-slider-thumb--background--invalid--active);\n }\n}\n\n:host(.disabled) {\n pointer-events: none;\n\n --track-color: var(--theme-slider-track--background--disabled);\n --trace-color: var(--theme-slider-trace--background--disabled);\n --tick-color: var(--theme-slider-track-marker--background--disabled);\n --tick-color--active: var(--theme-slider-trace-marker--background--disabled);\n\n @include thumb {\n background-color: var(--theme-slider-thumb--background--disabled);\n }\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\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"],"names":["makeRef","a11yHostAttributes","h","Host","OnListener"],"mappings":"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"}
1
+ {"version":3,"file":"ix-slider.entry.cjs.js","sources":["src/components/slider/slider.scss?tag=ix-slider&encapsulation=shadow","src/components/slider/slider.tsx"],"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@use 'mixins/shadow-dom/component';\n\n@mixin track {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']::-webkit-slider-runnable-track {\n @content;\n }\n\n // Firefox\n input[type='range']::-moz-range-track {\n @content;\n }\n}\n\n@mixin clear-browser-thumb {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range' i]::-webkit-slider-thumb {\n -webkit-appearance: none;\n appearance: none;\n margin-top: -6px;\n }\n\n // Firefox\n input[type='range' i]::-moz-range-thumb {\n border: none;\n border-radius: 0;\n }\n}\n\n@mixin thumb {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-hover {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:hover::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:hover::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-active {\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:active::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:active::-moz-range-thumb {\n @content;\n }\n}\n\n@mixin thumb-focus {\n input[type='range']:focus {\n outline: none;\n }\n\n // Chrome, Safari, Opera, and Edge Chromium\n input[type='range']:focus-visible::-webkit-slider-thumb {\n @content;\n }\n\n // Firefox\n input[type='range']:focus-visible::-moz-range-thumb {\n @content;\n }\n}\n\n:host {\n display: flex;\n flex-direction: column;\n min-height: 2rem;\n justify-content: center;\n\n --thumb-size: 1rem;\n --value: 0;\n --trace-start: 0;\n --trace-end: 0;\n --trace-reference: 0;\n\n // Theme colors:\n --trace-reference-color: var(--theme-slider-track-marker--background);\n --trace-color: var(--theme-slider-trace--background);\n --tick-color: var(--theme-slider-track-marker--background);\n --tick-color--active: var(--theme-slider-trace-marker--background);\n --track-color: var(--theme-slider-track--background);\n\n @include component.ix-component;\n\n input[type='range'] {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n left: 0;\n appearance: none;\n background: transparent;\n cursor: pointer;\n width: 100%;\n height: 1.5rem;\n margin: 0;\n }\n\n // Trace line\n input[type='range'].trace::before {\n content: '';\n position: absolute;\n display: block;\n z-index: -1;\n width: calc((var(--trace-end) - var(--trace-start)) * 100%);\n left: calc(var(--trace-start) * 100%);\n height: 4px;\n background-color: var(--trace-color);\n top: 50%;\n transform: translateY(-50%);\n border-radius: clamp(\n 0rem,\n calc((0.01 - var(--trace-start)) * 999rem),\n 0.125rem\n )\n clamp(0rem, calc((var(--trace-end) - 0.99) * 999rem), 0.125rem)\n clamp(0rem, calc((var(--trace-end) - 0.99) * 999rem), 0.125rem)\n clamp(0rem, calc((0.01 - var(--trace-start)) * 999rem), 0.125rem);\n }\n\n .slider-container {\n width: 100%;\n\n .slider {\n width: 100%;\n\n input[type='range'] {\n width: 100%;\n }\n }\n }\n\n // Trace reference\n input[type='range'].trace:not(.hide-trace-reference)::after {\n content: '';\n position: absolute;\n display: block;\n width: 2px;\n height: 16px;\n background-color: var(--trace-reference-color);\n top: 50%;\n transform: translateY(-50%);\n left: calc(100% * var(--trace-reference));\n }\n\n @include track() {\n background: transparent;\n height: 0.25rem;\n }\n\n @include clear-browser-thumb();\n\n @include thumb() {\n border-radius: 50%;\n background-color: var(--theme-slider-thumb--background);\n height: var(--thumb-size);\n width: var(--thumb-size);\n transition: all var(--theme-default-time) ease-in-out;\n z-index: 10;\n }\n\n @include thumb-hover() {\n background-color: var(--theme-slider-thumb--background--hover);\n }\n\n @include thumb-active() {\n background-color: var(--theme-slider-thumb--background--active);\n }\n\n @include thumb-focus() {\n outline: 1px solid var(--theme-color-focus-bdr);\n outline-offset: 0.125rem;\n }\n\n /* style datalist */\n .ticks {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n overflow: visible;\n pointer-events: none;\n }\n\n .ticks circle.tick {\n --tick-size: 6px;\n --tick-radius: calc(var(--tick-size) / 2);\n r: var(--tick-radius);\n fill: var(--tick-color);\n transform: translate(\n calc(\n var(--tick-value) * (100% - var(--thumb-size)) + var(--thumb-size) / 2\n ),\n 50%\n );\n }\n\n .ticks .tick.tick-at-min {\n transform: translate(var(--tick-radius), 50%);\n }\n\n .ticks .tick.tick-at-max {\n transform: translate(calc(100% - var(--tick-radius)), 50%);\n }\n\n .ticks .tick.tick-active {\n fill: var(--tick-color--active);\n }\n\n .slider {\n position: relative;\n display: block;\n width: 100%;\n height: 1.5rem;\n }\n\n .track {\n position: absolute;\n background-color: var(--track-color);\n height: 4px;\n width: 100%;\n top: 50%;\n transform: translateY(-50%);\n left: 0px;\n border-radius: 2px;\n }\n\n .thumb {\n display: block;\n position: absolute;\n background-color: transparent;\n height: 1rem;\n width: 1rem;\n border-radius: 100px;\n top: 50%;\n transform: translateY(-50%);\n }\n\n .hide-tooltip {\n display: none;\n }\n\n .label {\n display: flex;\n position: relative;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n margin-top: 0.5rem;\n\n min-height: 0px;\n }\n}\n\n:host(.error),\n:host(.invalid) {\n --trace-color: var(--theme-slider-trace--background--invalid);\n --tick-color--active: var(--theme-slider-trace-marker--background--invalid);\n\n @include thumb {\n background-color: var(--theme-slider-thumb--background--invalid);\n }\n\n @include thumb-hover() {\n background-color: var(--theme-slider-thumb--background--invalid--hover);\n }\n\n @include thumb-active() {\n background-color: var(--theme-slider-thumb--background--invalid--active);\n }\n}\n\n:host(.disabled) {\n pointer-events: none;\n\n --track-color: var(--theme-slider-track--background--disabled);\n --trace-color: var(--theme-slider-trace--background--disabled);\n --tick-color: var(--theme-slider-track-marker--background--disabled);\n --tick-color--active: var(--theme-slider-trace-marker--background--disabled);\n\n @include thumb {\n background-color: var(--theme-slider-thumb--background--disabled);\n }\n}\n\n:host(.warning) {\n --trace-color: var(--theme-color-warning-40);\n --tick-color--active: var(--theme-color-warning);\n\n @include thumb() {\n background-color: var(--theme-color-warning);\n }\n}\n\n:host(.info) {\n --trace-color: var(--theme-color-info-40);\n --tick-color--active: var(--theme-color-info);\n\n @include thumb() {\n background-color: var(--theme-color-info);\n }\n}\n\n:host(.valid) {\n --trace-color: var(--theme-color-success-40);\n --tick-color--active: var(--theme-color-success);\n\n @include thumb() {\n background-color: var(--theme-color-success);\n }\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\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"],"names":["makeRef","a11yHostAttributes","h","Host","HookValidationLifecycle","OnListener"],"mappings":"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"}
@@ -38,6 +38,13 @@ const SplitButton = class {
38
38
  * Placement of the dropdown
39
39
  */
40
40
  this.placement = 'bottom-start';
41
+ /**
42
+ * Enable Popover API rendering for dropdown.
43
+ *
44
+ * @default false
45
+ * @since 4.3.0
46
+ */
47
+ this.enableTopLayer = false;
41
48
  this.toggle = false;
42
49
  this.triggerElementRef = makeRef.makeRef();
43
50
  }
@@ -57,7 +64,7 @@ const SplitButton = class {
57
64
  'left-button-border': !hasOutline,
58
65
  } });
59
66
  const dropdownButtonAttributes = Object.assign(Object.assign({}, baseAttributes), { disabled: this.isDisabledIcon });
60
- return (index.h(index.Host, { key: '18955e55bbab4f5899f27cf2b38892c60bece302' }, index.h("div", { key: '8cc32b2686c3e02ee1f2a43d4a5f310cd2930dad', class: { 'btn-group': true, 'middle-gap': !hasOutline } }, this.label ? (index.h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }), this.label)) : (index.h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }))), index.h("ix-icon-button", Object.assign({ key: 'ae7a2875314967f3100d1abcef3528a9822b0503' }, dropdownButtonAttributes, { ref: this.triggerElementRef, class: 'anchor', icon: (_a = this.splitIcon) !== null && _a !== void 0 ? _a : index$1.iconContextMenu, "aria-label": this.ariaLabelSplitIconButton }))), index.h("ix-dropdown", { key: 'd81abc1f01f55f2bc85740898e7f59173e62e182', closeBehavior: this.closeBehavior, trigger: this.triggerElementRef.waitForCurrent() }, index.h("slot", { key: '19c2623131a8ab3799e5a9bb75cc356bf500fffd' }))));
67
+ return (index.h(index.Host, { key: '034329433940b847951719d6df094e7e799c9b2b' }, index.h("div", { key: 'e08144dd52c338d0cb3a271a95442709a4bd10ba', class: { 'btn-group': true, 'middle-gap': !hasOutline } }, this.label ? (index.h("ix-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }), this.label)) : (index.h("ix-icon-button", Object.assign({}, buttonAttributes, { icon: this.icon, onClick: (e) => this.buttonClick.emit(e), "aria-label": this.ariaLabelButton }))), index.h("ix-icon-button", Object.assign({ key: '4b7776b9328af463c873eb524e8808966b61fff1' }, dropdownButtonAttributes, { ref: this.triggerElementRef, class: 'anchor', icon: (_a = this.splitIcon) !== null && _a !== void 0 ? _a : index$1.iconContextMenu, "aria-label": this.ariaLabelSplitIconButton }))), index.h("ix-dropdown", { key: 'fbc53f2d73b27ed465a8dc4ae42357a61a6300c7', closeBehavior: this.closeBehavior, trigger: this.triggerElementRef.waitForCurrent(), enableTopLayer: this.enableTopLayer }, index.h("slot", { key: 'e776d44c8f78e89bed7f065edd55168563b0f23c' }))));
61
68
  }
62
69
  get hostElement() { return index.getElement(this); }
63
70
  };
@@ -1 +1 @@
1
- {"version":3,"file":"ix-split-button.entry.cjs.js","sources":["src/components/split-button/split-button.scss?tag=ix-split-button&encapsulation=shadow","src/components/split-button/split-button.tsx"],"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@use 'mixins/shadow-dom/component';\n@use 'legacy/components/button-group';\n\n:host {\n display: inline-block;\n\n @include component.ix-component;\n\n .btn-group {\n position: relative;\n display: inline-flex;\n vertical-align: middle;\n width: 100%;\n\n > ix-button:nth-child(1),\n > ix-icon-button:nth-child(1) {\n width: calc(100% - 2rem);\n --ix-button-border-radius-right: 0;\n }\n\n > ix-icon-button:nth-child(2) {\n width: 2rem;\n --ix-button-border-radius-left: 0;\n }\n }\n\n .middle-gap {\n gap: 0.125rem;\n }\n\n .left-button-border {\n border-top-width: 0.125rem;\n border-right-width: 0;\n border-left-width: 0.125rem;\n border-bottom-width: 0.125rem;\n }\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\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"],"names":["makeRef","h","Host","iconContextMenu"],"mappings":"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"}
1
+ {"version":3,"file":"ix-split-button.entry.cjs.js","sources":["src/components/split-button/split-button.scss?tag=ix-split-button&encapsulation=shadow","src/components/split-button/split-button.tsx"],"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@use 'mixins/shadow-dom/component';\n@use 'legacy/components/button-group';\n\n:host {\n display: inline-block;\n\n @include component.ix-component;\n\n .btn-group {\n position: relative;\n display: inline-flex;\n vertical-align: middle;\n width: 100%;\n\n > ix-button:nth-child(1),\n > ix-icon-button:nth-child(1) {\n width: calc(100% - 2rem);\n --ix-button-border-radius-right: 0;\n }\n\n > ix-icon-button:nth-child(2) {\n width: 2rem;\n --ix-button-border-radius-left: 0;\n }\n }\n\n .middle-gap {\n gap: 0.125rem;\n }\n\n .left-button-border {\n border-top-width: 0.125rem;\n border-right-width: 0;\n border-left-width: 0.125rem;\n border-bottom-width: 0.125rem;\n }\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\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"],"names":["makeRef","h","Host","iconContextMenu"],"mappings":";;;;;;AAAA,MAAM,cAAc,GAAG,ikDAAikD;;MC8B3kD,WAAW,GAAA,MAAA;AALxB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQE;;AAEG;AACK,QAAA,IAAO,CAAA,OAAA,GAAuB,SAAS;AAE/C;;AAEG;AACK,QAAA,IAAa,CAAA,aAAA,GAAkB,MAAM;AA+B7C;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAG,KAAK;AAExB;;;;AAIG;AACK,QAAA,IAAa,CAAA,aAAA,GAAG,KAAK;AAE7B;;;;AAIG;AACK,QAAA,IAAqB,CAAA,qBAAA,GAAG,KAAK;AAErC;;AAEG;AACK,QAAA,IAAS,CAAA,SAAA,GAAqB,cAAc;AAEpD;;;;;AAKG;AACK,QAAA,IAAc,CAAA,cAAA,GAAY,KAAK;AAE9B,QAAA,IAAM,CAAA,MAAA,GAAG,KAAK;AAON,QAAA,IAAiB,CAAA,iBAAA,GAAGA,eAAO,EAAe;AAoE5D;AAlEC,IAAA,IAAY,gBAAgB,GAAA;AAC1B,QAAA,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa;;AAG5C,IAAA,IAAY,cAAc,GAAA;AACxB,QAAA,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,qBAAqB;;IAGpD,MAAM,GAAA;;AACJ,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC;AACzE,QAAA,MAAM,cAAc,GAAG;YACrB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB;QAED,MAAM,gBAAgB,GACjB,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,cAAc,CACjB,EAAA,EAAA,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAC/B,KAAK,EAAE;gBACL,oBAAoB,EAAE,CAAC,UAAU;AAClC,aAAA,EAAA,CACF;QAED,MAAM,wBAAwB,GACzB,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,cAAc,CACjB,EAAA,EAAA,QAAQ,EAAE,IAAI,CAAC,cAAc,EAAA,CAC9B;QAED,QACEC,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,UAAU,EAAE,EAAA,EACzD,IAAI,CAAC,KAAK,IACTA,OAAA,CAAA,WAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACM,gBAAgB,EAAA,EACpB,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,OAAO,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAA,YAAA,EAC5B,IAAI,CAAC,eAAe,EAE/B,CAAA,EAAA,IAAI,CAAC,KAAK,CACD,KAEZA,OAAA,CAAA,gBAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACM,gBAAgB,EAAA,EACpB,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,OAAO,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAC5B,YAAA,EAAA,IAAI,CAAC,eAAe,IAChB,CACnB,EACDA,OACM,CAAA,gBAAA,EAAA,MAAA,CAAA,MAAA,CAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EAAA,wBAAwB,EAC5B,EAAA,GAAG,EAAE,IAAI,CAAC,iBAAiB,EAC3B,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE,CAAA,EAAA,GAAA,IAAI,CAAC,SAAS,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAIE,uBAAe,EAAA,YAAA,EAC3B,IAAI,CAAC,wBAAwB,EAAA,CAAA,CACzB,CACd,EAENF,OAAA,CAAA,aAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,aAAa,EAAE,IAAI,CAAC,aAAa,EACjC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,EAChD,cAAc,EAAE,IAAI,CAAC,cAAc,EAAA,EAEnCA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACD,CACT;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"ix-tab-item.ix-tabs.entry.cjs.js","sources":["src/components/tab-item/tab-item.scss?tag=ix-tab-item&encapsulation=shadow","src/components/tab-item/tab-item.tsx","src/components/utils/requestAnimationFrame.ts","src/components/tabs/tabs.scss?tag=ix-tabs&encapsulation=shadow","src/components/tabs/tabs.tsx"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n@use './common-variables' as vars;\n@use 'mixins/text-truncation';\n@use 'mixins/hover';\n@use 'mixins/shadow-dom/component';\n\n:host {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 10px vars.$large-space;\n line-height: 20px;\n font-size: 14px;\n font-weight: bold;\n background-color: var(--theme-tab--background);\n color: var(--theme-tab--color);\n\n @include component.ix-component;\n\n &::after {\n content: '';\n position: absolute;\n background-color: var(--theme-tab-indicator--background);\n width: 100%;\n height: var(--theme-tab-indicator--height);\n left: 0;\n }\n\n .text {\n @include text-truncation.ellipsis;\n\n span,\n span::before {\n pointer-events: none;\n }\n\n vertical-align: middle;\n }\n\n .circle {\n display: flex;\n justify-content: center;\n align-items: center;\n height: 3rem;\n width: 3rem;\n background-color: var(--theme-animated-tab-indicator--background);\n border-radius: 50%;\n border: 2px solid var(--theme-animated-tab-circle--border-color);\n color: var(--theme-an…icon--color);\n cursor: pointer;\n\n &.selected:not(.disabled) {\n background-color: var(--theme-animated-tab-circle--background--selected);\n color: var(--theme-animated-tab-icon--color--selected);\n border-color: var(--theme-animated-tab-circle--border-color--selected);\n\n &:hover {\n background-color: var(\n --theme-animated-tab-circle--background--selected\n );\n }\n }\n\n &:hover {\n background-color: var(--theme-animated-tab-circle--background--hover);\n }\n\n &:active {\n background-color: var(--theme-animated-tab-circle--background--active);\n }\n\n &:active {\n background-color: var(--theme-animated-tab-circle--background--active);\n }\n\n &.disabled {\n background-color: var(--theme-animated-tab-circle--background--disabled);\n border-color: var(--theme-animated-tab-circle--border-color--disabled);\n }\n }\n\n .counter {\n position: absolute;\n z-index: 1;\n height: 16px;\n width: auto;\n background-color: var(--theme-color-1);\n border: 1px solid var(--theme-tab-pill--border-color);\n border-radius: 100px;\n bottom: 6px;\n display: flex;\n justify-content: center;\n align-items: center;\n padding-left: vars.$tiny-space;\n padding-right: vars.$tiny-space;\n font-size: 12px;\n line-height: 14px;\n color: var(--theme-pill-outline--color);\n cursor: pointer;\n\n &.selected {\n border-color: var(--theme-tab-pill--border-color--selected);\n }\n\n &.disabled {\n border-color: var(--theme-tab-pill--border-color--disabled);\n }\n }\n\n .hidden {\n display: none;\n }\n}\n\n:host(.circle) {\n height: 72px;\n}\n\n:host(.top) {\n &::after {\n top: 0;\n }\n}\n\n:host(.bottom) {\n &::after {\n bottom: 0;\n }\n}\n\n:host(.stretched) {\n flex-basis: 100%;\n width: 100%;\n @include text-truncation.ellipsis;\n}\n\n:host(:hover:not(.circle)) {\n background-color: var(--theme-tab--background--hover);\n color: var(--theme-tab-color-hover);\n cursor: pointer;\n\n &::after {\n background-color: var(--theme-tab-indicator--background--hover);\n }\n}\n\n:host(:active:not(.circle)) {\n background-color: var(--theme-tab--background--active);\n color: var(--theme-tab-color--active);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--active);\n }\n}\n\n:host(:focus-visible) {\n outline: 0px solid var(--focus--border-color);\n\n .circle {\n outline: 1px solid var(--focus--border-color);\n }\n}\n\n:host(:focus-visible:not(.circle)) {\n outline: 1px solid var(--focus--border-color);\n}\n\n:host(.disabled) {\n pointer-events: none;\n color: var(--theme-tab--color--disabled);\n background-color: var(--theme-tab--background--disabled);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--disabled);\n }\n}\n\n:host(.selected:not(.disabled)) {\n background-color: var(--theme-tab--background--selected);\n color: var(--theme-tab--color--selected);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--selected);\n }\n}\n\n:host(.icon) {\n padding: vars.$large-space vars.$small-space;\n}\n\n:host(.small-tab) {\n height: 32px;\n padding: vars.$default-space;\n}\n\n:host(.small-tab.icon) {\n padding: vars.$default-space vars.$tiny-space;\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport type { TabClickDetail } from './tab-item.types';\n\n@Component({\n tag: 'ix-tab-item',\n styleUrl: 'tab-item.scss',\n shadow: true,\n})\nexport class TabItem {\n /**\n * Set selected tab\n */\n @Prop() selected = false;\n\n /**\n * Set disabled tab\n */\n @Prop() disabled = false;\n\n /**\n * Set small size tab\n */\n @Prop() small = false;\n\n /**\n * Set icon only tab\n */\n @Prop() icon = false;\n\n /**\n * Set rounded tab\n */\n @Prop() rounded = false;\n\n /**\n * Set counter value\n */\n @Prop() counter?: number;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set selected placement\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * Emitted when the tab is clicked.\n */\n @Event() tabClick!: EventEmitter<TabClickDetail>;\n\n private tabItemClasses(props: {\n selected: boolean;\n disabled: boolean;\n small: boolean;\n icon: boolean;\n circle: boolean;\n layout: 'auto' | 'stretched';\n placement: 'bottom' | 'top';\n }) {\n return {\n selected: props.selected,\n disabled: props.disabled,\n 'small-tab': props.small,\n icon: props.small,\n stretched: props.layout === 'stretched',\n bottom: props.placement === 'bottom',\n top: props.placement === 'top',\n circle: props.circle,\n };\n }\n\n render() {\n return (\n <Host\n class={this.tabItemClasses({\n selected: this.selected,\n disabled: this.disabled,\n small: this.small,\n icon: this.icon,\n layout: this.layout,\n placement: this.placement,\n circle: this.rounded,\n })}\n tabIndex={0}\n onClick={(event: MouseEvent) => {\n if (event.defaultPrevented) return;\n\n const clientEvent = this.tabClick.emit({\n nativeEvent: event,\n });\n\n if (clientEvent.defaultPrevented) {\n event.stopPropagation();\n }\n }}\n >\n <div\n class={{\n circle: this.rounded,\n text: !this.rounded,\n selected: this.selected,\n disabled: this.disabled,\n }}\n >\n <slot></slot>\n </div>\n <div\n class={{\n counter: true,\n selected: this.selected,\n hidden: !(this.rounded && this.counter !== undefined),\n disabled: this.disabled,\n }}\n >\n {this.counter}\n </div>\n </Host>\n );\n }\n}\n","/*\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\ndeclare const __zone_symbol__requestAnimationFrame: any;\n\n/**\n * Prevents angular from change detection when requesting an animation frame\n *\n * Credits goes to:\n * https://github.com/ionic-team/ionic-framework/blob/main/core/src/utils/helpers.ts\n */\nexport const requestAnimationFrameNoNgZone = (\n callback: (...args: any[]) => void\n) => {\n if (typeof __zone_symbol__requestAnimationFrame === 'function') {\n return __zone_symbol__requestAnimationFrame(callback);\n }\n if (typeof requestAnimationFrame === 'function') {\n return requestAnimationFrame(callback);\n }\n return setTimeout(callback);\n};\n","/*\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\n@use 'mixins/text-truncation';\n@use 'mixins/shadow-dom/component';\n\n:host {\n width: auto;\n display: flex;\n align-items: center;\n position: relative;\n\n @include component.ix-component;\n\n .tab-items {\n overflow: hidden;\n scroll-behavior: smooth;\n width: 100%;\n\n .items-content {\n display: flex;\n align-items: center;\n }\n }\n\n .arrow {\n // unset button styles first\n all: unset;\n\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 32px;\n height: 32px;\n top: 0;\n bottom: 0;\n left: 0;\n margin: auto 0;\n border-radius: 4px;\n color: var(--theme-btn-tertiary--color);\n background-color: var(--theme-btn-tertiary--background);\n z-index: 2;\n\n &:hover {\n color: var(--theme-btn-tertiary--color--hover);\n background-color: var(--theme-btn-tertiary--background--hover);\n }\n\n &:active {\n color: var(--theme-btn-tertiary--color--active);\n background-color: var(--theme-btn-tertiary--background--active);\n }\n\n &.right {\n left: auto;\n right: 0;\n }\n }\n\n .overflow-shadow {\n display: block;\n position: relative;\n height: 100%;\n width: 100%;\n pointer-events: all;\n\n &.shadow-left {\n mask-image: linear-gradient(90deg, transparent 0px, black 45px);\n }\n\n &.shadow-right {\n mask-image: linear-gradient(\n 90deg,\n black calc(100% - 45px),\n transparent 100%\n );\n }\n\n &.shadow-both {\n mask-image: linear-gradient(\n 90deg,\n transparent 0px,\n black 45px,\n black calc(100% - 45px),\n transparent 100%\n );\n }\n }\n}\n","/*\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"],"names":["h","Host","iconChevronLeftSmall","iconChevronRightSmall"],"mappings":"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"}
1
+ {"version":3,"file":"ix-tab-item.ix-tabs.entry.cjs.js","sources":["src/components/tab-item/tab-item.scss?tag=ix-tab-item&encapsulation=shadow","src/components/tab-item/tab-item.tsx","src/components/tabs/tabs.scss?tag=ix-tabs&encapsulation=shadow","src/components/tabs/tabs.tsx"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n@use './common-variables' as vars;\n@use 'mixins/text-truncation';\n@use 'mixins/hover';\n@use 'mixins/shadow-dom/component';\n\n:host {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 10px vars.$large-space;\n line-height: 20px;\n font-size: 14px;\n font-weight: bold;\n background-color: var(--theme-tab--background);\n color: var(--theme-tab--color);\n\n @include component.ix-component;\n\n &::after {\n content: '';\n position: absolute;\n background-color: var(--theme-tab-indicator--background);\n width: 100%;\n height: var(--theme-tab-indicator--height);\n left: 0;\n }\n\n .text {\n @include text-truncation.ellipsis;\n\n span,\n span::before {\n pointer-events: none;\n }\n\n vertical-align: middle;\n }\n\n .circle {\n display: flex;\n justify-content: center;\n align-items: center;\n height: 3rem;\n width: 3rem;\n background-color: var(--theme-animated-tab-indicator--background);\n border-radius: 50%;\n border: 2px solid var(--theme-animated-tab-circle--border-color);\n color: var(--theme-an…icon--color);\n cursor: pointer;\n\n &.selected:not(.disabled) {\n background-color: var(--theme-animated-tab-circle--background--selected);\n color: var(--theme-animated-tab-icon--color--selected);\n border-color: var(--theme-animated-tab-circle--border-color--selected);\n\n &:hover {\n background-color: var(\n --theme-animated-tab-circle--background--selected\n );\n }\n }\n\n &:hover {\n background-color: var(--theme-animated-tab-circle--background--hover);\n }\n\n &:active {\n background-color: var(--theme-animated-tab-circle--background--active);\n }\n\n &:active {\n background-color: var(--theme-animated-tab-circle--background--active);\n }\n\n &.disabled {\n background-color: var(--theme-animated-tab-circle--background--disabled);\n border-color: var(--theme-animated-tab-circle--border-color--disabled);\n }\n }\n\n .counter {\n position: absolute;\n z-index: 1;\n height: 16px;\n width: auto;\n background-color: var(--theme-color-1);\n border: 1px solid var(--theme-tab-pill--border-color);\n border-radius: 100px;\n bottom: 6px;\n display: flex;\n justify-content: center;\n align-items: center;\n padding-left: vars.$tiny-space;\n padding-right: vars.$tiny-space;\n font-size: 12px;\n line-height: 14px;\n color: var(--theme-pill-outline--color);\n cursor: pointer;\n\n &.selected {\n border-color: var(--theme-tab-pill--border-color--selected);\n }\n\n &.disabled {\n border-color: var(--theme-tab-pill--border-color--disabled);\n }\n }\n\n .hidden {\n display: none;\n }\n}\n\n:host(.circle) {\n height: 72px;\n}\n\n:host(.top) {\n &::after {\n top: 0;\n }\n}\n\n:host(.bottom) {\n &::after {\n bottom: 0;\n }\n}\n\n:host(.stretched) {\n flex-basis: 100%;\n width: 100%;\n @include text-truncation.ellipsis;\n}\n\n:host(:hover:not(.circle)) {\n background-color: var(--theme-tab--background--hover);\n color: var(--theme-tab-color-hover);\n cursor: pointer;\n\n &::after {\n background-color: var(--theme-tab-indicator--background--hover);\n }\n}\n\n:host(:active:not(.circle)) {\n background-color: var(--theme-tab--background--active);\n color: var(--theme-tab-color--active);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--active);\n }\n}\n\n:host(:focus-visible) {\n outline: 0px solid var(--focus--border-color);\n\n .circle {\n outline: 1px solid var(--focus--border-color);\n }\n}\n\n:host(:focus-visible:not(.circle)) {\n outline: 1px solid var(--focus--border-color);\n}\n\n:host(.disabled) {\n pointer-events: none;\n color: var(--theme-tab--color--disabled);\n background-color: var(--theme-tab--background--disabled);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--disabled);\n }\n}\n\n:host(.selected:not(.disabled)) {\n background-color: var(--theme-tab--background--selected);\n color: var(--theme-tab--color--selected);\n\n &::after {\n background-color: var(--theme-tab-indicator--background--selected);\n }\n}\n\n:host(.icon) {\n padding: vars.$large-space vars.$small-space;\n}\n\n:host(.small-tab) {\n height: 32px;\n padding: vars.$default-space;\n}\n\n:host(.small-tab.icon) {\n padding: vars.$default-space vars.$tiny-space;\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { Component, Event, EventEmitter, h, Host, Prop } from '@stencil/core';\nimport type { TabClickDetail } from './tab-item.types';\n\n@Component({\n tag: 'ix-tab-item',\n styleUrl: 'tab-item.scss',\n shadow: true,\n})\nexport class TabItem {\n /**\n * Set selected tab\n */\n @Prop() selected = false;\n\n /**\n * Set disabled tab\n */\n @Prop() disabled = false;\n\n /**\n * Set small size tab\n */\n @Prop() small = false;\n\n /**\n * Set icon only tab\n */\n @Prop() icon = false;\n\n /**\n * Set rounded tab\n */\n @Prop() rounded = false;\n\n /**\n * Set counter value\n */\n @Prop() counter?: number;\n\n /**\n * Set layout width style\n */\n @Prop() layout: 'auto' | 'stretched' = 'auto';\n\n /**\n * Set selected placement\n */\n @Prop() placement: 'bottom' | 'top' = 'bottom';\n\n /**\n * Emitted when the tab is clicked.\n */\n @Event() tabClick!: EventEmitter<TabClickDetail>;\n\n private tabItemClasses(props: {\n selected: boolean;\n disabled: boolean;\n small: boolean;\n icon: boolean;\n circle: boolean;\n layout: 'auto' | 'stretched';\n placement: 'bottom' | 'top';\n }) {\n return {\n selected: props.selected,\n disabled: props.disabled,\n 'small-tab': props.small,\n icon: props.small,\n stretched: props.layout === 'stretched',\n bottom: props.placement === 'bottom',\n top: props.placement === 'top',\n circle: props.circle,\n };\n }\n\n render() {\n return (\n <Host\n class={this.tabItemClasses({\n selected: this.selected,\n disabled: this.disabled,\n small: this.small,\n icon: this.icon,\n layout: this.layout,\n placement: this.placement,\n circle: this.rounded,\n })}\n tabIndex={0}\n onClick={(event: MouseEvent) => {\n if (event.defaultPrevented) return;\n\n const clientEvent = this.tabClick.emit({\n nativeEvent: event,\n });\n\n if (clientEvent.defaultPrevented) {\n event.stopPropagation();\n }\n }}\n >\n <div\n class={{\n circle: this.rounded,\n text: !this.rounded,\n selected: this.selected,\n disabled: this.disabled,\n }}\n >\n <slot></slot>\n </div>\n <div\n class={{\n counter: true,\n selected: this.selected,\n hidden: !(this.rounded && this.counter !== undefined),\n disabled: this.disabled,\n }}\n >\n {this.counter}\n </div>\n </Host>\n );\n }\n}\n","/*\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\n@use 'mixins/text-truncation';\n@use 'mixins/shadow-dom/component';\n\n:host {\n width: auto;\n display: flex;\n align-items: center;\n position: relative;\n\n @include component.ix-component;\n\n .tab-items {\n overflow: hidden;\n scroll-behavior: smooth;\n width: 100%;\n\n .items-content {\n display: flex;\n align-items: center;\n }\n }\n\n .arrow {\n // unset button styles first\n all: unset;\n\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 32px;\n height: 32px;\n top: 0;\n bottom: 0;\n left: 0;\n margin: auto 0;\n border-radius: 4px;\n color: var(--theme-btn-tertiary--color);\n background-color: var(--theme-btn-tertiary--background);\n z-index: 2;\n\n &:hover {\n color: var(--theme-btn-tertiary--color--hover);\n background-color: var(--theme-btn-tertiary--background--hover);\n }\n\n &:active {\n color: var(--theme-btn-tertiary--color--active);\n background-color: var(--theme-btn-tertiary--background--active);\n }\n\n &.right {\n left: auto;\n right: 0;\n }\n }\n\n .overflow-shadow {\n display: block;\n position: relative;\n height: 100%;\n width: 100%;\n pointer-events: all;\n\n &.shadow-left {\n mask-image: linear-gradient(90deg, transparent 0px, black 45px);\n }\n\n &.shadow-right {\n mask-image: linear-gradient(\n 90deg,\n black calc(100% - 45px),\n transparent 100%\n );\n }\n\n &.shadow-both {\n mask-image: linear-gradient(\n 90deg,\n transparent 0px,\n black 45px,\n black calc(100% - 45px),\n transparent 100%\n );\n }\n }\n}\n","/*\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"],"names":["h","Host","requestAnimationFrameNoNgZone","iconChevronLeftSmall","iconChevronRightSmall"],"mappings":";;;;;;AAAA,MAAM,UAAU,GAAG,60IAA60I;;MCiBn1I,OAAO,GAAA,MAAA;AALpB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAME;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAG,KAAK;AAExB;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAG,KAAK;AAExB;;AAEG;AACK,QAAA,IAAK,CAAA,KAAA,GAAG,KAAK;AAErB;;AAEG;AACK,QAAA,IAAI,CAAA,IAAA,GAAG,KAAK;AAEpB;;AAEG;AACK,QAAA,IAAO,CAAA,OAAA,GAAG,KAAK;AAOvB;;AAEG;AACK,QAAA,IAAM,CAAA,MAAA,GAAyB,MAAM;AAE7C;;AAEG;AACK,QAAA,IAAS,CAAA,SAAA,GAAqB,QAAQ;AA4E/C;AArES,IAAA,cAAc,CAAC,KAQtB,EAAA;QACC,OAAO;YACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,WAAW,EAAE,KAAK,CAAC,KAAK;YACxB,IAAI,EAAE,KAAK,CAAC,KAAK;AACjB,YAAA,SAAS,EAAE,KAAK,CAAC,MAAM,KAAK,WAAW;AACvC,YAAA,MAAM,EAAE,KAAK,CAAC,SAAS,KAAK,QAAQ;AACpC,YAAA,GAAG,EAAE,KAAK,CAAC,SAAS,KAAK,KAAK;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB;;IAGH,MAAM,GAAA;AACJ,QAAA,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EACH,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC;gBACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,MAAM,EAAE,IAAI,CAAC,OAAO;aACrB,CAAC,EACF,QAAQ,EAAE,CAAC,EACX,OAAO,EAAE,CAAC,KAAiB,KAAI;gBAC7B,IAAI,KAAK,CAAC,gBAAgB;oBAAE;AAE5B,gBAAA,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;AACrC,oBAAA,WAAW,EAAE,KAAK;AACnB,iBAAA,CAAC;AAEF,gBAAA,IAAI,WAAW,CAAC,gBAAgB,EAAE;oBAChC,KAAK,CAAC,eAAe,EAAE;;AAE3B,aAAC,EAAA,EAEDD,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;gBACL,MAAM,EAAE,IAAI,CAAC,OAAO;AACpB,gBAAA,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO;gBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,EAAA,EAEDA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACT,EACNA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,OAAO,EAAE,IAAI;gBACb,QAAQ,EAAE,IAAI,CAAC,QAAQ;AACvB,gBAAA,MAAM,EAAE,EAAE,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC;gBACrD,QAAQ,EAAE,IAAI,CAAC,QAAQ;AACxB,aAAA,EAAA,EAEA,IAAI,CAAC,OAAO,CACT,CACD;;;;;ACjIb,MAAM,OAAO,GAAG,suEAAsuE;;AC8BtvE,MAAM,mBAAmB,GAAG;AAC1B,IAAA,QAAQ,EAAE,UAAU;AACpB,IAAA,QAAQ,EAAE,UAAU;AACpB,IAAA,SAAS,EAAE,WAAW;AACtB,IAAA,IAAI,EAAE,MAAM;AACZ,IAAA,SAAS,EAAE,WAAW;AACtB,IAAA,MAAM,EAAE,QAAQ;AAChB,IAAA,GAAG,EAAE,KAAK;AACV,IAAA,MAAM,EAAE,QAAQ;AAChB,IAAA,QAAQ,EAAE,UAAU;CACZ;AAEV,MAAM,mBAAmB,GAAG,IAAI,GAAG,CACjC,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAmB,CACrD;MAOY,IAAI,GAAA,MAAA;AALjB,IAAA,WAAA,CAAA,OAAA,EAAA;;;AAQE;;AAEG;AACK,QAAA,IAAK,CAAA,KAAA,GAAG,KAAK;AAErB;;AAEG;AACK,QAAA,IAAO,CAAA,OAAA,GAAG,KAAK;AAEvB;;AAEG;AACsB,QAAA,IAAQ,CAAA,QAAA,GAAG,CAAC;AAErC;;AAEG;AACK,QAAA,IAAM,CAAA,MAAA,GAAyB,MAAM;AAE7C;;AAEG;AACK,QAAA,IAAS,CAAA,SAAA,GAAqB,QAAQ;AAqBrC,QAAA,IAAU,CAAA,UAAA,GAAG,CAAC;AACd,QAAA,IAAmB,CAAA,mBAAA,GAAG,CAAC;AACvB,QAAA,IAAY,CAAA,YAAA,GAAG,GAAG;AAClB,QAAA,IAAkB,CAAA,kBAAA,GAAG,CAAC;AACtB,QAAA,IAAiB,CAAA,iBAAA,GAAG,KAAK;AACzB,QAAA,IAAa,CAAA,aAAA,GAAG,KAAK;AAEtB,QAAA,IAAA,CAAA,eAAe,GAAG,MAAM,CAAC,UAAU;AAE1B,QAAA,IAAW,CAAA,WAAA,GAAG,EAAE;AAEzB,QAAA,IAAe,CAAA,eAAA,GAAG,KAAK;QAEvB,IAAA,CAAA,WAAW,GAGf;AACF,YAAA,OAAO,EAAE,IAAI;AACb,YAAA,OAAO,EAAE,IAAI;SACd;AAiZF;IA9YC,cAAc,GAAA;AACZ,QAAA,IAAI,CAAC,UAAU,GAAG,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM;AAEvC,QAAA,IAAI,IAAI,CAAC,eAAe,KAAK,CAAC;YAC5B,QAAQ,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,UAAU;QAClD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,UAAU,CAAC;AACnD,QAAA,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,UAAU;;IAGlC,OAAO,GAAA;AACb,QAAA,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;;AAG7D,IAAA,MAAM,CAAC,QAAgB,EAAA;AAC7B,QAAA,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;;IAGzB,cAAc,GAAA;;AACpB,QAAA,OAAO,CAAA,EAAA,GAAA,IAAI,CAAC,WAAW,CAAC,UAAU,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa,CAAC,gBAAgB,CAAC;;IAG7D,gBAAgB,GAAA;;AACtB,QAAA,OAAO,CAAA,EAAA,GAAA,IAAI,CAAC,WAAW,CAAC,UAAU,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,aAAa,CAAC,YAAY,CAAC;;IAGzD,kBAAkB,GAAA;AACxB,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa;AACpD,QAAA,IAAI,CAAC,aAAa;YAAE;AACpB,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,MAAK;YAC5C,IAAI,CAAC,YAAY,EAAE;AACrB,SAAC,CAAC;AACF,QAAA,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC;;IAGpC,kBAAkB,GAAA;;QACxB,CAAA,EAAA,GAAA,IAAI,CAAC,aAAa,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,UAAU,EAAE;AAEhC,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,gBAAgB,CAAC,MAAK;YAC7C,IAAI,CAAC,iBAAiB,EAAE;AAC1B,SAAC,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE;AAC3C,YAAA,SAAS,EAAE,IAAI;AACf,YAAA,OAAO,EAAE,IAAI;AACb,YAAA,UAAU,EAAE,IAAI;YAChB,eAAe,EAAE,CAAC,OAAO,CAAC;AAC3B,SAAA,CAAC;;IAGI,iBAAiB,GAAA;QACvB,IAAI,IAAI,CAAC,eAAe;YAAE;AAC1B,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI;QAE3B,qBAAqB,CAAC,MAAK;YACzB,IAAI,CAAC,mBAAmB,EAAE;AAC1B,YAAA,IAAI,CAAC,eAAe,GAAG,KAAK;AAC9B,SAAC,CAAC;;IAGI,gBAAgB,CAAC,OAA6B,EAAE,KAAa,EAAA;AACnE,QAAA,MAAM,UAAU,GAAG,KAAK,KAAK,IAAI,CAAC,QAAQ;AAC1C,QAAA,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ;QAEnC,IAAI,IAAI,CAAC,KAAK;AAAE,YAAA,OAAO,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC;QAErD,IAAI,IAAI,CAAC,OAAO;AAAE,YAAA,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC;QAEzD,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC;QAC3C,OAAO,CAAC,YAAY,CAAC,UAAU,EAAE,UAAU,CAAC,QAAQ,EAAE,CAAC;QACvD,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC;AACjD,QAAA,OAAO,CAAC,eAAe,CAAC,UAAU,EAAE,UAAU,CAAC;QAE/C,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC;;AAGpD,IAAA,oBAAoB,CAC1B,OAA6B,EAC7B,UAAmB,EACnB,UAAmB,EAAA;AAEnB,QAAA,MAAM,eAAe,GAAG,IAAI,GAAG,CAC7B,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,UAAU,CAAC,CAClD;AACD,QAAA,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO;AAE7B,QAAA,KAAK,MAAM,GAAG,IAAI,eAAe,EAAE;AACjC,YAAA,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;;AAGpB,QAAA,KAAK,MAAM,YAAY,IAAI,mBAAmB,EAAE;YAC9C,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;AACtC,gBAAA,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC;;;;IAK5B,oBAAoB,CAC1B,UAAmB,EACnB,UAAmB,EAAA;AAEnB,QAAA,MAAM,eAAe,GAAG;AACtB,YAAA,CAAC,mBAAmB,CAAC,QAAQ,GAAG,IAAI;AACpC,YAAA,CAAC,mBAAmB,CAAC,QAAQ,GAAG,UAAU;AAC1C,YAAA,CAAC,mBAAmB,CAAC,QAAQ,GAAG,UAAU;AAC1C,YAAA,CAAC,mBAAmB,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK;YAC3C,CAAC,mBAAmB,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,KAAK,WAAW;YAC5D,CAAC,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,KAAK,QAAQ;YACzD,CAAC,mBAAmB,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK;AACnD,YAAA,CAAC,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO;SAC3C;AAED,QAAA,OAAO,MAAM,CAAC,OAAO,CAAC,eAAe;aAClC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,KAAK,SAAS;aACnC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,SAAS,CAAC;;IAG5B,mBAAmB,GAAA;AACzB,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,EAAE;AACzB,YAAA,OAAO,CAAC,IAAI,CAAC,0CAA0C,CAAC;AACxD,YAAA,IAAI,CAAC,QAAQ,GAAG,EAAE;YAClB;;QAGF,IAAI,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE;YACnC;;AAGF,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ;AACnC,QAAA,MAAM,aAAa,GAAG,aAAa,GAAG,CAAC;QAEvC,IAAI,aAAa,IAAI,CAAC,IAAI,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE;AACzD,YAAA,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;YAClC;;AAGF,QAAA,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE;AACvB,YAAA,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;;;AAIlB,IAAA,cAAc,CAAC,KAAa,EAAA;AAClC,QAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;AACrB,QAAA,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC;;IAGzB,mBAAmB,GAAA;AACzB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE;AAC3B,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM;QAE7B,IAAI,CAAC,mBAAmB,EAAE;AAE1B,QAAA,KAAK,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;AAC7C,YAAA,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC;;QAGvC,IAAI,CAAC,YAAY,EAAE;;IAGb,UAAU,GAAA;AAChB,QAAA,IAAI;AACF,YAAA,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE;AACxC,YAAA,QACE,UAAU;AACV,gBAAA,UAAU,CAAC,WAAW;oBACpB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;AACrD,gBAAA,IAAI,CAAC,MAAM,KAAK,MAAM;;QAExB,OAAO,KAAK,EAAE;AACd,YAAA,OAAO,KAAK;;;IAIR,iBAAiB,GAAA;AACvB,QAAA,IAAI;AACF,YAAA,OAAO,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI,IAAI,IAAI,CAAC,kBAAkB,GAAG,CAAC;;QAChE,OAAO,KAAK,EAAE;AACd,YAAA,OAAO,KAAK;;;IAIR,aAAa,GAAA;AACnB,QAAA,IAAI;AACF,YAAA,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE;YAExC,IAAI,CAAC,UAAU,EAAE;AACf,gBAAA,OAAO,KAAK;;AAGd,YAAA,MAAM,cAAc,GAAG,UAAU,CAAC,qBAAqB,EAAE;AAEzD,YAAA,QACE,IAAI,CAAC,UAAU,EAAE,KAAK,IAAI;AAC1B,gBAAA,IAAI,CAAC,kBAAkB;AACrB,oBAAA,CAAC,UAAU,CAAC,WAAW,GAAG,cAAc,CAAC,KAAK,IAAI,EAAE;;QAExD,OAAO,KAAK,EAAE;AACd,YAAA,OAAO,KAAK;;;AAIR,IAAA,IAAI,CAAC,MAAc,EAAE,KAAK,GAAG,KAAK,EAAA;AACxC,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE;QAEzC,IAAI,CAAC,WAAW,EAAE;YAChB;;QAGF,MAAM,uBAAuB,GAAG,WAAW,CAAC,qBAAqB,EAAE,CAAC,KAAK;AACzE,QAAA,MAAM,cAAc,GAClB,CAAC,IAAI,CAAC,mBAAmB;YACzB,uBAAuB;YACvB,WAAW,CAAC,WAAW;AAEzB,QAAA,MAAM,GAAG,MAAM,GAAG,cAAc,GAAG,cAAc,GAAG,MAAM;AAC1D,QAAA,MAAM,IAAI,IAAI,CAAC,mBAAmB;QAClC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;AAE5B,QAAA,MAAM,MAAM,GAAG;AACb,YAAA,CAAA,sBAAA,EAAyB,MAAM,CAAM,IAAA,CAAA;AACrC,YAAA,KAAK,GAAG,oCAAoC,GAAG,EAAE;AAClD,SAAA,CAAC,IAAI,CAAC,EAAE,CAAC;AAEV,QAAA,WAAW,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC;AAEzC,QAAA,IAAI,KAAK;YAAE,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,kBAAkB,GAAG,MAAM;;AACjE,YAAA,IAAI,CAAC,kBAAkB,GAAG,MAAM;;AAIvC,IAAA,gBAAgB,CAAC,QAAgB,EAAA;AAC/B,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAAE;QAExB,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;AACjC,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,EAAE;AAEzC,QAAA,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS;YAAE;AAExB,QAAA,MAAM,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE;AACvD,QAAA,MAAM,OAAO,GAAG,GAAG,CAAC,qBAAqB,EAAE;QAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,IAAI,GAAG,aAAa,CAAC,IAAI;AACzD,QAAA,MAAM,gBAAgB,GAAG,eAAe,GAAG,OAAO,CAAC,KAAK;AAExD,QAAA,IAAI,eAAe,GAAG,IAAI,CAAC,WAAW,EAAE;AACtC,YAAA,IAAI,CAAC,IAAI,CAAC,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC;;aAC/C,IAAI,gBAAgB,GAAG,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE;AACpE,YAAA,IAAI,CAAC,IAAI,CACP,aAAa,CAAC,KAAK,GAAG,gBAAgB,GAAG,IAAI,CAAC,WAAW,EACzD,IAAI,CACL;;;AAIG,IAAA,WAAW,CAAC,KAAa,EAAA;AAC/B,QAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;;AAGf,IAAA,QAAQ,CAAC,KAAa,EAAA;AAC5B,QAAA,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE;YAChD;;AAGF,QAAA,MAAM,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC;QAC5D,IAAI,gBAAgB,EAAE;YACpB;;AAGF,QAAA,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;;IAGjB,SAAS,CAAC,OAA6B,EAAE,KAAiB,EAAA;AAChE,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAAE;AACxB,QAAA,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAAE;QAEtB,IAAI,CAAC,WAAW,CAAC,OAAO;AACtB,YAAA,IAAI,CAAC,WAAW,CAAC,OAAO,KAAK;AAC3B,kBAAE,UAAU,CAAC,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG,KAAK,CAAC,EAAE,GAAG;kBACxD,IAAI;AAEV,QAAA,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC;AACtE,QAAA,MAAM,kBAAkB,GAAG,KAAK,CAAC,OAAO;AACxC,QAAA,MAAM,IAAI,GAAG,CAAC,KAAiB,KAC7B,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,EAAE,kBAAkB,CAAC;QACxD,MAAM,WAAW,GAAG,MAAK;YACvB,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,EAAE,KAAK,CAAC;YACpD,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,WAAW,EAAE,KAAK,CAAC;YACvD,IAAI,CAAC,QAAQ,EAAE;AACjB,SAAC;AACD,QAAA,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,EAAE,KAAK,CAAC;;AAG3C,IAAA,QAAQ,CAAC,KAAiB,EAAE,IAAY,EAAE,UAAkB,EAAA;QAClE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,GAAG,UAAU,CAAC;;IAGtC,QAAQ,GAAA;AACd,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE;AAC5B,YAAA,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;AACtC,YAAA,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG,IAAI;;AAGjC,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO;AAAE,YAAA,OAAO,KAAK;AAE1C,QAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,kBAAkB;AAClD,QAAA,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG,IAAI;AAE/B,QAAA,OAAO,IAAI;;IAGb,iBAAiB,GAAA;QACf,IAAI,CAAC,kBAAkB,EAAE;;IAG3B,kBAAkB,GAAA;QAChB,IAAI,CAAC,mBAAmB,EAAE;;IAG5B,mBAAmB,GAAA;QACjB,IAAI,CAAC,YAAY,EAAE;;IAGb,YAAY,GAAA;QAClBE,qDAA6B,CAAC,MAAK;AACjC,YAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE;AACzC,YAAA,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,EAAE;AACnD,SAAC,CAAC;;IAGJ,gBAAgB,GAAA;AACd,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE;AAC3B,QAAA,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,KAAI;AACvB,YAAA,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,KAAK,KAC1C,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,KAAK,CAAC,CAC/B;AACH,SAAC,CAAC;QAEF,IAAI,CAAC,kBAAkB,EAAE;;IAG3B,oBAAoB,GAAA;;QAClB,CAAA,EAAA,GAAA,IAAI,CAAC,cAAc,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,UAAU,EAAE;QACjC,CAAA,EAAA,GAAA,IAAI,CAAC,aAAa,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,UAAU,EAAE;;AAIlC,IAAA,UAAU,CAAC,KAAkB,EAAA;AAC3B,QAAA,IAAI,KAAK,CAAC,gBAAgB,EAAE;YAC1B;;AAGF,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM;AAC3B,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE;QAE3B,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,KAAK,KAAI;YAC1B,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,GAAG,KAAK,MAAM,EAAE;AACnC,gBAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;;AAExB,SAAC,CAAC;;IAGJ,MAAM,GAAA;AACJ,QAAA,QACEF,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACF,IAAI,CAAC,iBAAiB,KACrBD,OAAA,CAAA,QAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAC,OAAO,EACb,OAAO,EAAE,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,EAAA,YAAA,EACrC,IAAI,CAAC,8BAA8B,EAAA,EAE/CA,OAAA,CAAA,SAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAS,IAAI,EAAEG,4BAAoB,EAAA,CAAY,CACxC,CACV,EACDH,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,WAAW,EAAE,IAAI;AACjB,gBAAA,iBAAiB,EAAE,IAAI;gBACvB,aAAa,EAAE,IAAI,CAAC,iBAAiB;gBACrC,cAAc,EAAE,IAAI,CAAC,aAAa;AAClC,gBAAA,aAAa,EAAE,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,iBAAiB;AAC5D,aAAA,EAAA,EAEDA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,eAAe,EAAA,EACxBA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAa,CACT,CACF,EACL,IAAI,CAAC,aAAa,KACjBA,OACE,CAAA,QAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,aAAa,EACnB,OAAO,EAAE,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,EAAA,YAAA,EACtC,IAAI,CAAC,+BAA+B,EAAA,EAEhDA,OAAS,CAAA,SAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAEI,6BAAqB,EAAA,CAAY,CACzC,CACV,CACI;;;;;;;;;;;;"}